SPMMP02400_Exclusion입력.xfdl 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <FDL version="1.4">
  3. <TypeDefinition url="..\..\..\default_typedef.xml"/>
  4. <Form id="SPMMP02400" position="absolute 0 0 517 480" titletext="Exclusion입력" oninit="SPMMP02400_oninit" onload="SPMMP02400_onload">
  5. <Layouts>
  6. <Layout>
  7. <Div position="absolute 0 0 500 441" id="grp_biz" scrollbars="autoboth">
  8. <Layouts>
  9. <Layout>
  10. <Tab position="absolute 0 0 500 440" id="switch1">
  11. <Tabpages>
  12. <Tabpage text="" id="cp">
  13. <Layouts>
  14. <Layout>
  15. <Grid position="absolute 0 54 495 149" id="grd_cplist" binddataset="ds_grd_cplist" oncellclick="grp_biz_switch1_cp_ds_grd_cplist_oncellclick">
  16. <Formats>
  17. <Format id="default">
  18. <Columns>
  19. <Col size="80"/>
  20. </Columns>
  21. <Rows>
  22. <Row band="head" size="24"/>
  23. <Row band="body" size="24"/>
  24. </Rows>
  25. <Band id="head">
  26. <Cell col="0" disptype="normal" text="cpgnm"/>
  27. </Band>
  28. <Band id="body">
  29. <Cell col="0" disptype="normal" text="bind:cpgnm"/>
  30. </Band>
  31. </Format>
  32. </Formats>
  33. </Grid>
  34. <Static text="Exclusion 사유 입력" position="absolute 5 2 148 16" id="caption1" class="tit_2"/>
  35. <Static text="이 환자는 아래의 CP 적용 대상자이지만, CP 적용을 하지 않았습니다.&#13;&#10;Exclusion 대상 CP를 선택하십시오." position="absolute 0 23 495 51" id="caption2" class="hand"/>
  36. <Static text="Exclusion 사유를 선택하고 저장해 주십시오." position="absolute 0 161 370 181" id="caption3" class="hand"/>
  37. <Static text="비고" position="absolute 0 323 70 343" id="caption4" class="hand"/>
  38. <Shape position="absolute 0 48 495 54" linetype="vertical" id="line1" class="line_1"/>
  39. <Shape position="absolute 0 147 495 153" linetype="vertical" id="line2" class="line_3"/>
  40. <Shape position="absolute 0 314 495 320" linetype="vertical" id="line3" class="line_3"/>
  41. <Shape position="absolute 0 434 495 440" linetype="vertical" id="line4" class="line_3"/>
  42. <TextArea position="absolute 0 344 495 436" id="txt_etc"/>
  43. <Grid position="absolute 0 181 495 316" id="grd_masterinfo" binddataset="ds_grd_masterinfo">
  44. <Formats>
  45. <Format id="default">
  46. <Columns>
  47. <Col size="80"/>
  48. <Col size="80"/>
  49. <Col size="80"/>
  50. <Col size="80"/>
  51. <Col size="80"/>
  52. <Col size="80"/>
  53. <Col size="80"/>
  54. <Col size="80"/>
  55. <Col size="80"/>
  56. <Col size="80"/>
  57. </Columns>
  58. <Rows>
  59. <Row band="head" size="24"/>
  60. <Row band="body" size="24"/>
  61. </Rows>
  62. <Band id="head">
  63. <Cell col="0" disptype="normal" text="valuno"/>
  64. <Cell col="1" disptype="normal" text="valunm"/>
  65. <Cell col="2" disptype="normal" text="valuflag"/>
  66. <Cell col="3" disptype="normal" text="histseq"/>
  67. <Cell col="4" disptype="normal" text="cpgappno"/>
  68. <Cell col="5" disptype="normal" text="pid"/>
  69. <Cell col="6" disptype="normal" text="orddd"/>
  70. <Cell col="7" disptype="normal" text="cretno"/>
  71. <Cell col="8" disptype="normal" text="ordtype"/>
  72. <Cell col="9" disptype="normal" text="check"/>
  73. </Band>
  74. <Band id="body">
  75. <Cell col="0" disptype="normal" text="bind:valuno"/>
  76. <Cell col="1" disptype="normal" text="bind:valunm"/>
  77. <Cell col="2" disptype="normal" text="bind:valuflag"/>
  78. <Cell col="3" disptype="normal" text="bind:histseq"/>
  79. <Cell col="4" disptype="normal" text="bind:cpgappno"/>
  80. <Cell col="5" disptype="normal" text="bind:pid"/>
  81. <Cell col="6" disptype="normal" text="bind:orddd"/>
  82. <Cell col="7" disptype="normal" text="bind:cretno"/>
  83. <Cell col="8" disptype="normal" text="bind:ordtype"/>
  84. <Cell col="9" disptype="normal" text="bind:check"/>
  85. </Band>
  86. </Format>
  87. </Formats>
  88. </Grid>
  89. <Shape position="absolute 0 175 495 181" linetype="vertical" id="line6" class="line_1"/>
  90. <Shape position="absolute 0 336 495 342" linetype="vertical" id="line7" class="line_1"/>
  91. </Layout>
  92. </Layouts>
  93. </Tabpage>
  94. <Tabpage text="" id="cpg">
  95. <Layouts>
  96. <Layout>
  97. <Shape position="absolute 0 52 495 58" linetype="vertical" id="line5" class="line_1"/>
  98. <TextArea position="absolute 0 60 495 436" id="textarea1"/>
  99. <Shape position="absolute 0 434 495 440" linetype="vertical" id="line8" class="line_3"/>
  100. <Static text="미적용 사유 입력" position="absolute 5 2 123 16" id="cap_title" class="tit_2"/>
  101. <Static text="CPG는 평가용 CPG입니다.&#13;&#10;CPG 미적용 사유를 입력하십시오." position="absolute 0 25 495 53" id="cap_desc" class="hand"/>
  102. </Layout>
  103. </Layouts>
  104. </Tabpage>
  105. </Tabpages>
  106. </Tab>
  107. </Layout>
  108. </Layouts>
  109. </Div>
  110. <Div position="absolute 0 441 501 468" id="grp_btn" scrollbars="autoboth">
  111. <Layouts>
  112. <Layout>
  113. <Button position="absolute 442 2 498 24" id="btn_cncl" class="btn4" visible="false" text="취소" onclick="grp_btn_btn_cncl_onclick"/>
  114. <Button position="absolute 442 2 498 24" id="btn_cnfm" class="btn4" text="저장" onclick="grp_btn_btn_cnfm_onclick"/>
  115. </Layout>
  116. </Layouts>
  117. </Div>
  118. </Layout>
  119. </Layouts>
  120. <Objects>
  121. <Dataset id="ds_grd_cplist" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false" onrowposchanged="ds_grd_cplist_onrowposchanged">
  122. <ColumnInfo>
  123. <Column id="cpgnm" type="STRING"/>
  124. </ColumnInfo>
  125. </Dataset>
  126. <Dataset id="ds_grd_masterinfo" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" reversesubsum="false">
  127. <ColumnInfo>
  128. <Column id="valuno" type="STRING" size="256" sumtext="평가번호"/>
  129. <Column id="valunm" type="STRING" size="256" sumtext="평가명"/>
  130. <Column id="valuflag" type="STRING" size="256" sumtext="평가구분"/>
  131. <Column id="histseq" type="STRING" size="256" sumtext="이력순번"/>
  132. <Column id="cpgappno" type="INT" size="256" sumtext="cpg적용번호"/>
  133. <Column id="pid" type="STRING" size="256" sumtext="등록번호"/>
  134. <Column id="orddd" type="STRING" size="256" sumtext="진료일/입원일"/>
  135. <Column id="cretno" type="STRING" size="256" sumtext="생성번호"/>
  136. <Column id="ordtype" type="STRING" size="256" sumtext="외래입원구분"/>
  137. <Column id="check" type="STRING" size="256" sumtext="체크"/>
  138. </ColumnInfo>
  139. </Dataset>
  140. <Dataset id="ds_reqdata" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false">
  141. <ColumnInfo>
  142. <Column id="valuflag" type="STRING" size="256" sumtext="-구분1:평가2:drop사유3:exclusion사유"/>
  143. <Column id="pid" type="STRING" size="256" sumtext="등록번호"/>
  144. <Column id="orddd" type="STRING" size="256" sumtext="진료일/입원일"/>
  145. <Column id="cretno" type="STRING" size="256" sumtext="생성번호"/>
  146. <Column id="ordtype" type="STRING" size="256" sumtext="외래입원구분"/>
  147. <Column id="cpgappno" type="INT" size="256" sumtext="cpg적용번호"/>
  148. <Column id="cpgno" type="INT" size="256" sumtext="cpg적용번호"/>
  149. <Column id="cpghistseq" type="INT" size="256" sumtext="cpg적용번호"/>
  150. </ColumnInfo>
  151. </Dataset>
  152. <Dataset id="ds_save_req_data" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false">
  153. <ColumnInfo>
  154. <Column id="valuflag" type="STRING" size="256" sumtext="-구분1:평가2:drop사유3:exclusion사유"/>
  155. <Column id="cpgappno" type="STRING" size="256" sumtext="cpg적용환자"/>
  156. <Column id="pid" type="STRING" size="256" sumtext="등록번호"/>
  157. <Column id="orddd" type="STRING" size="256" sumtext="진료일/입원일"/>
  158. <Column id="cretno" type="STRING" size="256" sumtext="생성번호"/>
  159. <Column id="ordtype" type="STRING" size="256" sumtext="외래입원구분"/>
  160. <Column id="valurem" type="STRING" size="256" sumtext="평가비고"/>
  161. <Column id="cpgno" type="INT" size="256" sumtext="cpg번호"/>
  162. <Column id="cpghistseq" type="INT" size="256" sumtext="cpg이력순번"/>
  163. </ColumnInfo>
  164. </Dataset>
  165. <Dataset id="ds_save_info_data" firefirstcount="0" firenextcount="0" useclientlayout="false" updatecontrol="true" enableevent="true" loadkeymode="keep" loadfiltermode="keep" reversesubsum="false">
  166. <ColumnInfo>
  167. <Column id="valuno" type="INT" size="256" sumtext="평가번호"/>
  168. <Column id="valunm" type="STRING" size="256" sumtext="평가명"/>
  169. <Column id="valuflag" type="STRING" size="256" sumtext="평가구분"/>
  170. <Column id="histseq" type="STRING" size="256" sumtext="이력순번"/>
  171. <Column id="cpgappno" type="INT" size="256" sumtext="적용번호"/>
  172. <Column id="pid" type="STRING" size="256" sumtext="등록번호"/>
  173. <Column id="orddd" type="STRING" size="256" sumtext="진료일/입원일"/>
  174. <Column id="cretno" type="STRING" size="256" sumtext="생성번호"/>
  175. <Column id="ordtype" type="STRING" size="256" sumtext="외래입원구분"/>
  176. <Column id="check" type="STRING" size="256" sumtext="저장flag"/>
  177. </ColumnInfo>
  178. </Dataset>
  179. </Objects>
  180. <Script type="xscript4.0"><![CDATA[/***************************************************************************************
  181. * System Name :
  182. * Job Name :
  183. * Creator :
  184. * Make Date : 2014-09-17
  185. * Description :
  186. *---------------------------------------------------------------------------------------
  187. * Modify Date Modifier Modify Description
  188. *---------------------------------------------------------------------------------------
  189. * 2014-09-17 Live Converter TF->XP
  190. *
  191. *---------------------------------------------------------------------------------------
  192. ****************************************************************************************/
  193. include "com_commonxp::comm_main.xjs";
  194. function SPMMP02400_oninit(obj:Form, e:InitEventInfo)
  195. {
  196. frmf_initForm(obj);
  197. var cpgflagcd = frmf_getParameter("SMMMO024_cpgflagcd");
  198. if( cpgflagcd == "02" ){ //CPG
  199. grp_biz.switch1.tabindex = 1;
  200. grp_btn.btn_cnfm.position.left = "384px";
  201. grp_btn.btn_cncl.visible = true;
  202. grp_biz.switch1.cpg.cap_desc.text = frmf_getParameter("SMMMO024_cpgnm") + grp_biz.switch1.cpg.cap_desc.text;
  203. }else{ //"01" (CP)
  204. grp_biz.switch1.tabindex = 0;
  205. grp_btn.btn_cnfm.position.left = "442px";
  206. grp_btn.btn_cncl.visible = false;
  207. }
  208. }
  209. function SPMMP02400_onload(obj:Form, e:LoadEventInfo)
  210. {
  211. ds_grd_cplist.enableevent = false;
  212. dsf_copyDs(ds_grd_cplist, ds_cpexclusionlist);
  213. ds_grd_cplist.enableevent = true;
  214. ds_grd_cplist.rowposition = 0;
  215. //grp_biz.switch1.cp.grd_cplist.oncellclick.fireEvent( grp_biz.switch1.cp.grd_cplist, new GridClickEventInfo);
  216. }
  217. function grp_biz_switch1_cp_ds_grd_cplist_oncellclick(obj:Grid, e:GridClickEventInfo)
  218. {
  219. if( ds_grd_cplist.rowposition > -1 && ds_grd_cplist.rowposition <= ds_grd_cplist.rowcount ){
  220. ds_reqdata.clearData();
  221. ds_reqdata.addRow();
  222. ds_reqdata.setColumn(0, "cpgno", ds_grd_cplist.getColumn(ds_grd_cplist.rowposition, "cpgno") );
  223. ds_reqdata.setColumn(0, "cpghistseq", ds_grd_cplist.getColumn(ds_grd_cplist.rowposition, "cpghistseq") );
  224. var pamInfoCvs = sysf_getGlobalVariable("paminfo"); //상단정보가 있을 경우는 검색
  225. if(!utlf_isNull(pamInfoCvs) && pamInfoCvs.length > 0){//cvs가 ""이 아닌 경우에만 처리함.
  226. dsf_setCSVToDataset("ds_paminfo", pamInfoCvs);
  227. var ioflag = ds_paminfo.getColumn(0,"ioflag");
  228. var pid = ds_paminfo.getColumn(0,"pid ");
  229. var cretno = ds_paminfo.getColumn(0,"cretno");
  230. var orddd = "";
  231. if(ioflag == "O"){
  232. orddd = ds_paminfo.getColumn(0,"/orddd");
  233. }else{
  234. orddd = ds_paminfo.getColumn(0,"/indd");
  235. }
  236. ds_reqdata.setColumn(0, "pid", pid );
  237. ds_reqdata.setColumn(0, "orddd", orddd );
  238. ds_reqdata.setColumn(0, "cretno", cretno );
  239. ds_reqdata.setColumn(0, "ordtype", ioflag );
  240. }
  241. var oParam = {};
  242. oParam.id = "TRMMP02501";
  243. oParam.service = "prcpmngtapp.CPPrcpMngt";
  244. oParam.method = "reqGetValuDropExclu";
  245. oParam.inds = "req=ds_reqdata";
  246. oParam.outds = "ds_grd_masterinfo=info";
  247. oParam.async = false;
  248. //oParam.callback = "cf_TRMMP02501";
  249. tranf_submit(oParam);
  250. dsf_setDefaultVal(ds_grd_masterinfo, "check:false");
  251. }
  252. }
  253. function grp_btn_btn_cncl_onclick(obj:Button, e:ClickEventInfo)
  254. {
  255. this.close();
  256. }
  257. function grp_btn_btn_cnfm_onclick(obj:Button, e:ClickEventInfo)
  258. {
  259. //model.copyNode("/root/send/savedata", "/root/hidden");
  260. var header = "valuno▦valunm▦valuflag▦histseq▦pid▦orddd▦cretno▦ordtype▦check";
  261. //var data = "";
  262. //var nodeList = instance1.selectNodes("/root/main/masterinfo/info" + "[check = 'true']");
  263. ds_grd_masterinfo.filter("check=='true'");
  264. //CP별 exclusion 사유를 마스터에 모두 입력하면, CP사유 선택 필수 (2008.10.21 JJE)
  265. if( ds_grd_masterinfo.rowcount < 1 && grp_biz.switch1.cp.txt_etc.text == "") {
  266. sysf_messageBox("사유를 선택하지 않았습니다.\n사유를 선택하거나 비고에", "C001"); //C001:입력하십시오, C002:선택하십시오
  267. return;
  268. }
  269. if( ds_grd_masterinfo.rowcount < 1 ){
  270. //var pid = opener.model.getValue ("/root/temp/paminfo/list/pid")
  271. //var cretno = opener.model.getValue("/root/temp/paminfo/list/cretno");
  272. //var ordtype = opener.model.getValue("/root/temp/paminfo/list/ioflag");
  273. var pid = ds_paminfo.getColumn(0,"pid");
  274. var cretno = ds_paminfo.getColumn(0,"cretno");
  275. var ordtype = ds_paminfo.getColumn(0,"ioflag");
  276. if( ordtype == "O" ){
  277. //var orddd = opener.model.getValue("/root/temp/paminfo/list/orddd");
  278. var orddd = ds_paminfo.getColumn(0,"orddd");
  279. }else{
  280. //var orddd = opener.model.getValue("/root/temp/paminfo/list/indd");
  281. var orddd = ds_paminfo.getColumn(0,"indd");
  282. }
  283. data = "▩0▦(선택안함)▦3▦0▦" + pid + "▦" + orddd + "▦" + cretno + "▦" + ordtype+ "▦true";
  284. }else{
  285. for(var i=0; i<nodeList.length; i++){
  286. var node = nodeList.item(i);
  287. var valuno = node.selectSingleNode("valuno");
  288. var valunm = node.selectSingleNode("valunm");
  289. var valuflag = node.selectSingleNode("valuflag");
  290. var histseq = node.selectSingleNode("histseq");
  291. var pid = node.selectSingleNode("pid");
  292. var orddd = node.selectSingleNode("orddd");
  293. var cretno = node.selectSingleNode("cretno");
  294. var ordtype = node.selectSingleNode("ordtype");
  295. var check = node.selectSingleNode("check");
  296. data = data + "▩" + valuno.text + "▦" + valunm.text + "▦" + valuflag.text + "▦" + histseq.text + "▦" + pid.text + "▦" + orddd.text + "▦" + cretno.text + "▦" + ordtype.text + "▦" + check.text;
  297. }
  298. }
  299. dsf_setCSVToDataset("ds_save_info_data", header + data + "▩");
  300. dsf_setCSVToDataset("ds_save_req_data", data);
  301. //model.makeValue("/root/send/savedata/info", header + data + "▩");
  302. //model.makeValue("/root/send/savedata/valurem", model.getValue("/root/main/valurem"));
  303. var oParam = {};
  304. oParam.id = "TXMMP02501";
  305. oParam.service = "prcpmngtapp.CPPrcpMngt";
  306. oParam.method = "reqExeValuDropExclu";
  307. oParam.inds = "req=ds_save_req_data info=ds_save_info_data";
  308. oParam.outds = "ds_grd_masterinfo=info";
  309. oParam.async = false;
  310. //oParam.callback = "cf_TXMMP02501";
  311. tranf_submit(oParam);
  312. frmf_setParameter("TRMMP03200_saversnyn", "Y");
  313. this.close();
  314. }
  315. function ds_grd_cplist_onrowposchanged(obj:Dataset, e:DSRowPosChangeEventInfo)
  316. {
  317. if( obj.rowposition > -1 && obj.rowposition <= obj.rowcount ){
  318. sysf_trace("111");
  319. ds_reqdata.clearData();
  320. ds_reqdata.addRow();
  321. ds_reqdata.setColumn(0, "cpgno", ds_grd_cplist.getColumn(ds_grd_cplist.rowposition, "cpgno") );
  322. ds_reqdata.setColumn(0, "cpghistseq", ds_grd_cplist.getColumn(ds_grd_cplist.rowposition, "cpghistseq") );
  323. var pamInfoCvs = sysf_getGlobalVariable("paminfo"); //상단정보가 있을 경우는 검색
  324. if(!utlf_isNull(pamInfoCvs) && pamInfoCvs.length > 0){//cvs가 ""이 아닌 경우에만 처리함.
  325. dsf_setCSVToDataset("ds_paminfo", pamInfoCvs);
  326. var ioflag = ds_paminfo.getColumn(0,"ioflag");
  327. var pid = ds_paminfo.getColumn(0,"pid ");
  328. var cretno = ds_paminfo.getColumn(0,"cretno");
  329. var orddd = "";
  330. if(ioflag == "O"){
  331. orddd = ds_paminfo.getColumn(0,"/orddd");
  332. }else{
  333. orddd = ds_paminfo.getColumn(0,"/indd");
  334. }
  335. ds_reqdata.setColumn(0, "pid", pid );
  336. ds_reqdata.setColumn(0, "orddd", orddd );
  337. ds_reqdata.setColumn(0, "cretno", cretno );
  338. ds_reqdata.setColumn(0, "ordtype", ioflag );
  339. }
  340. var oParam = {};
  341. oParam.id = "TRMMP02501";
  342. oParam.service = "prcpmngtapp.CPPrcpMngt";
  343. oParam.method = "reqGetValuDropExclu";
  344. oParam.inds = "req=ds_reqdata";
  345. oParam.outds = "ds_grd_masterinfo=info";
  346. oParam.async = false;
  347. //oParam.callback = "cf_TRMMP02501";
  348. tranf_submit(oParam);
  349. dsf_setDefaultVal(ds_grd_masterinfo, "check:false");
  350. }
  351. }
  352. ]]></Script>
  353. </Form>
  354. </FDL>