qcScore.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719
  1. require("../css/qcScore.less");
  2. const $ = require('jquery');
  3. require('jquery-templates');
  4. require('./modal.js');
  5. const {post,getUrlArgObject,setBoxHeight,getCookie,initScroll} = require('./utils.js');
  6. const {api} = require('./api.js');
  7. let checkOk = require('./../images/checkOk.png')
  8. window.document.title="质控评分-"+getUrlArgObject("name");
  9. $(function(){
  10. //本页全局变量
  11. let global_flawData = {}; //缺陷数据
  12. let global_flawDataPay = {}; //缺陷数据
  13. const global_id=getUrlArgObject("id");
  14. const global_age = getUrlArgObject("age");
  15. let global_check;
  16. const global_code = getUrlArgObject("code");
  17. let global_activeTab=$(".sub-menu .page.active").attr("code"); //当前激活菜单项
  18. let global_modules ={}; //模板数据缓存
  19. let global_flaws=[]; //缺陷条目列表缓存
  20. let global_selectedFlaw = {}; //新增时选中的条目信息
  21. getAllModules();
  22. let hasAu3 = hasData('FUNC000011'); //新增缺陷权限
  23. if(hasAu3){
  24. $(".add-flaw").click(function(){
  25. getQcCasesEntry();
  26. });
  27. }
  28. function initMenu(data){
  29. const menu=[{id:0,name:"缺陷总览",parentId: -1,sonMode: []},...(data||[])];
  30. //菜单数据填充
  31. $("#subMenuTmpl").tmpl(menu).appendTo("#subMenu");
  32. $("#miniMenuTmpl").tmpl(menu).appendTo(".menu-mini ul");
  33. //菜单收起展开
  34. $(".sub-menu .list-1").on("click",function(){
  35. $(".sub-menu .list-1 .slide-up").removeClass('slide-up');
  36. $(this).toggleClass('slide-up');
  37. $(this).find("ul").slideToggle();
  38. // setTimeout(function(){
  39. // initScroll("subMenu","Y",2)
  40. // },300)
  41. });
  42. $(".sub-menu .list-1 li").on("click",function(e){
  43. e.stopPropagation();
  44. });
  45. //收起菜单
  46. $(".slide-show").click(function(){
  47. $(".sub-menu,.copy-right").animate({"width":"60px"},function(){
  48. $(this).hide();
  49. $(".menu-mini").show();
  50. });
  51. $(".tab-container").animate({"margin-left":"60px"});
  52. });
  53. //展开菜单
  54. $(".slide-hide").click(function(){
  55. $(".menu-mini").hide();
  56. $(".sub-menu,.copy-right").show().animate({"width":"220px"},function(){
  57. });
  58. $(".tab-container").animate({"margin-left":"220px"});
  59. });
  60. //右侧内容切换
  61. $(".page").on("click",function(){
  62. $(".info-item .cont,.flaw-item,td").removeClass("active"); //清空缺陷定位背景
  63. const title = $(this).attr("code");
  64. if(title==="缺陷总览"||title==="谈话告知书"||title==="知情同意书"){
  65. if(title==="缺陷总览"){
  66. getRecordDetailUpdate()
  67. }
  68. $(".flaw-table .page-item").hide();
  69. $(".flaw-table,.flaw-table .page-item[code="+title+"]").show();
  70. }else{
  71. $(".flaw-table").hide();
  72. }
  73. //选中样式
  74. $(".sub-menu .active,.menu-mini .active").removeClass('active');
  75. const mItems = $(".sub-menu .page[code="+title+"],.menu-mini .page[code="+title+"]");
  76. mItems.addClass("active");
  77. mItems.parents(".list-1").addClass("active");
  78. //显示对应内容
  79. const code=$(this).attr("code");
  80. global_activeTab=code;
  81. //initModuleData();
  82. $(".content-item,.flaw-item").hide();
  83. $(".content-item[code='"+code+"']").show();
  84. showFlawList();
  85. $("#contentInfo").scrollTop(0)
  86. });
  87. // initScroll("subMenu","Y",2)
  88. }
  89. //判断有无某一权限
  90. function hasData(data){
  91. let trdObj = JSON.parse(getCookie("trdObj"))
  92. let lis = trdObj[global_code]
  93. if(!lis){
  94. return false
  95. }
  96. if(lis.indexOf(data)>-1){//有权限
  97. return true
  98. }
  99. return false;
  100. }
  101. //获取病例明细
  102. function getRecordDetail(){
  103. post(api.getRecordDetail,{'behospitalCode':global_id}).then(function(res){
  104. if(res.data.code==='0'){
  105. const data = res.data.data;
  106. const {beHospital,result,msg,checkStatus,drgs} = data;
  107. global_check = checkStatus
  108. const info=Object.assign(beHospital,result);
  109. initMenu(JSON.parse(result.menuData));
  110. // $(".sub-menu>ul>li:first-child.page,.menu-mini>ul>li:first-child.page").addClass("active");
  111. $(".subMenu >li:first-child.page,.menu-mini>ul>li:first-child.page").addClass("active");
  112. global_activeTab=$(".sub-menu .page.active").attr("code");
  113. initPatientInfo(info);
  114. initContent(result.pageData);
  115. initList(msg);
  116. initScoreItem(msg);
  117. global_flawData=msg;
  118. global_flawDataPay=drgs;
  119. setBoxHeight();
  120. changePay()
  121. }
  122. });
  123. }
  124. function getRecordDetailUpdate(){
  125. post(api.getRecordDetail,{'behospitalCode':global_id}).then(function(res){
  126. if(res.data.code==='0'){
  127. const data = res.data.data;
  128. const {beHospital,result,msg,checkStatus,drgs} = data;
  129. // global_check = checkStatus
  130. // const info=Object.assign(beHospital,result);
  131. // initMenu(JSON.parse(result.menuData));
  132. // $(".subMenu >li:first-child.page,.menu-mini>ul>li:first-child.page").addClass("active");
  133. // global_activeTab=$(".sub-menu .page.active").attr("code");
  134. // initPatientInfo(info);
  135. // initContent(result.pageData);
  136. initList(msg);
  137. initScoreItem(msg);
  138. global_flawData=msg;
  139. global_flawDataPay=drgs;
  140. // setBoxHeight();
  141. // changePay()
  142. }
  143. });
  144. }
  145. function changePay(){
  146. $(document).on('click',".titleSpecial span",function(){
  147. let type = $(this).attr("data-type")
  148. if(type == 1){
  149. initList(global_flawDataPay,type);
  150. }else{
  151. initList(global_flawData,type);
  152. }
  153. })
  154. }
  155. //填充患者信息
  156. function initPatientInfo(data){
  157. let hasCheck = false
  158. if(hasData("FUNC000014")){
  159. hasCheck = true
  160. }
  161. const obj=Object.assign({},data,{age:!global_age||global_age=="null"?"-":global_age,hasCheck,checkState:global_check});
  162. $("#infoTmpl").tmpl(obj).appendTo("#patientInfo");
  163. $(".check").on("click", function(){
  164. checkQc()
  165. })
  166. }
  167. //显示病例模块明细
  168. function initContent(data){
  169. const obj = JSON.parse(data);
  170. let info=[];
  171. let hml='',moduleId='';
  172. formatSpecPage(obj["谈话告知书"],"谈话告知书");
  173. formatSpecPage(obj["知情同意书"],"知情同意书");
  174. for(let k in obj){
  175. if(k==="谈话告知书"||k==="知情同意书"){
  176. continue;
  177. }
  178. for(let i in obj[k]){
  179. info=formatInfoData(k,obj[k][i]);
  180. moduleId=info.mode_id;
  181. if(global_modules[moduleId]){
  182. hml=initModuleData(moduleId,obj[k]);
  183. $.tmpl(hml,info).appendTo("#contentInfo");
  184. }else{
  185. const icon=require("../images/empty1.png");
  186. const sid=moduleId?"("+moduleId+")":"";
  187. const code=k.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'');
  188. const emptyStr=`<div class="empty">
  189. <img src="${icon}" alt="空"/>
  190. <p>暂无信息~</p>
  191. </div>`;
  192. if(!$(".content-item[code="+code+"] .empty").length){ //显示一条空提示即可
  193. hml='<div class="content-item" code="'+code+'">' +
  194. '<h2 class="title">'+k+sid+'</h2>'+emptyStr+'</div>';
  195. $.tmpl(hml,{}).appendTo("#contentInfo");
  196. }
  197. }
  198. }
  199. }
  200. $(".content-item[code="+global_activeTab+"]").show();
  201. //console.log(obj)
  202. }
  203. function formatInfoData(k,data){
  204. let obj = {},name="";
  205. for(let i in data){
  206. if(i!=="mode_id"){
  207. name=i.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,"").replace(/^[0-9]+/,"a"); //过滤key中存在的特殊符号,模板会渲染不出来且不报错
  208. obj[name]=data[i].replace(/\n/g,"<br/>")||"";
  209. }else{
  210. obj[i]=data[i].replace(/\n/g,"<br/>")||"";
  211. }
  212. }
  213. return Object.assign({title:k},obj);
  214. }
  215. //知情同意书、谈话告知书
  216. function formatSpecPage(data,title,type){
  217. $(".page-item[code='缺陷总览']").children().remove()
  218. $("#appointBookTmpl").tmpl({title,data}).appendTo(".flaw-table");
  219. $(".page-anchor").on("click",function(){
  220. const code=$(this).attr("code");
  221. const pCode=$(this).parents("tr").attr("code").replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'');
  222. //菜单同步状态
  223. $(".sub-menu .page[code="+pCode+"]").parents(".list-1").click();
  224. $(".sub-menu .page[code="+pCode+"],.menu-mini .page[code="+pCode+"").click();
  225. //缺陷定位
  226. $(".info-item .cont,.flaw-item,td").removeClass("active");
  227. const flawItem=$(".flaw-item .title a[code="+code+"]");
  228. if(!flawItem.length){
  229. $.alerModal({"message":'模块数据缺失~',type:"tip",time:'1000',isFather: true, fatherWrapper: $(".flaw-table", parent.document)});
  230. return;
  231. }
  232. $(".flaw-item .title a[code="+code+"]").click();
  233. const anch=$(".flaw-item .title a[code="+code+"]").attr("href");
  234. if($(anch)[0]){
  235. $('#contentInfo').scrollTop($(anch).offset().top-60);
  236. }
  237. });
  238. if(type&&type == 1){
  239. $(".titleNo").css({
  240. 'background-color': '#00A1FF',
  241. 'color': '#fff',
  242. 'border-color': '#00A1FF'
  243. })
  244. $(".titlePay").css({
  245. 'background-color': '#fff',
  246. 'border': '1px solid #777',
  247. 'border-right':0,
  248. 'color': '#777'
  249. })
  250. }else if(type&&type==2){
  251. $(".titleNo").css({
  252. 'border-left':0,
  253. 'background-color': '#fff',
  254. 'border': '1px solid #777',
  255. 'color': '#777'
  256. })
  257. $(".titlePay").css({
  258. 'background-color': '#00A1FF',
  259. 'color': '#fff',
  260. 'border-color': '#00A1FF'
  261. })
  262. }
  263. }
  264. function initList(data,type){
  265. //$("#flawTotalList").tmpl({title:"缺陷总览",data:data}).appendTo(".flaw-table");
  266. formatSpecPage(data,"缺陷总览",type);
  267. $(".flaw-table").show();
  268. $(".flaw-table .page-item[code="+global_activeTab+"]").show();
  269. $(".slide-up").off("click").on("click",function(){
  270. const name = $(this).text();
  271. $("tr[code='"+name+"']").slideToggle();
  272. $(this).toggleClass("down");
  273. });
  274. }
  275. //评分项数据填充
  276. function initScoreItem(data){
  277. $("#flaws .flaw-box").html("");
  278. let hasAu = hasData('FUNC000013'); //修改缺陷权限
  279. let hasAu2 = hasData('FUNC000012'); //删除缺陷权限
  280. for(let k in data){
  281. $("#flawTmpl").tmpl(data[k]).appendTo("#flaws .flaw-box");
  282. }
  283. showFlawList();
  284. $(".flaw-item .oper a").click(function () {
  285. const i = $(".flaw-item[code="+global_activeTab+"]").index($(this).parents(".flaw-item"));
  286. const code=$(this).attr("code");
  287. const isEdit = $(this).is(".edit-flaw");
  288. //if(!hasAu)return
  289. if(isEdit&&hasAu){
  290. showModal('0',code,i);
  291. }else if(!isEdit&&hasAu2){
  292. showModal('1',code,i);
  293. }
  294. })
  295. $(".edit-flaw").css({"opacity":hasAu?"1":"0.5",cursor:hasAu?"pointer":"unset"});
  296. $(".del-flaw").css({"opacity":hasAu2?"1":"0.5",cursor:hasAu2?"pointer":"unset"});
  297. $(".add-flaw").css({"opacity":hasAu3?"1":"0.5",cursor:hasAu3?"pointer":"unset"});
  298. $(".flaw-item .title a[href]").click(function(){
  299. const id = $(this).attr("href");
  300. const anchors=$(this).attr("anchors").split(",");
  301. let ans = anchors.map((it)=>{
  302. return "#anchor"+it;
  303. });
  304. $(".info-item .cont,.flaw-item,td").removeClass("active");
  305. $(ans.join(",")).addClass("active");
  306. $(this).parents(".flaw-item").addClass("active");
  307. });
  308. }
  309. //显示缺陷列表
  310. function showFlawList(){
  311. const hml = $(".flaw-item[code="+global_activeTab+"]");
  312. if(hml.length){
  313. hml.show();
  314. $("#flaws .empty").hide();
  315. }else{
  316. $("#flaws .empty").length?$("#flaws .empty").show():$("#emptyTmpl").tmpl().appendTo("#flaws .flaw-box");
  317. }
  318. }
  319. //删除评分项
  320. function delScore(id,info){
  321. const param={
  322. 'behospitalCode':global_id,
  323. 'optResultAlgVO':{
  324. 'id':id
  325. }
  326. };
  327. post(api.delScore,param).then(function(res){
  328. if(res.data.code==='0'){
  329. $("#delModal").hide();
  330. updateFlaws(res.data.data);
  331. $("#anchor"+info.pageKeyList[0]).removeClass("active");
  332. $.alerModal({"message":"删除成功",type:"tip",time:'1000'});
  333. }
  334. });
  335. }
  336. //修改评分项
  337. function editScore(info){
  338. const param={
  339. "behospitalCode": global_id,
  340. "optResultAlgVO": info
  341. };
  342. post(api.editScore,param).then(function(res){
  343. if(res.data.code==='0'){
  344. $("#delModal").hide();
  345. updateFlaws(res.data.data);
  346. $.alerModal({"message":"修改成功",type:"tip",time:'1000'});
  347. }
  348. });
  349. }
  350. //添加评分项
  351. function addScore(info){
  352. const optResultAlgVO = {
  353. "casesEntryId": info.casesEntryId,
  354. "casesId": info.casesId,
  355. "casesScore": info.caseScore,
  356. "code": info.code || "",
  357. "id": info.id || "",
  358. "info":info.info || "",
  359. "isReject": info.isReject,
  360. "msg": info.msg || "",
  361. "score": info.score
  362. }
  363. const param={
  364. "behospitalCode": global_id,
  365. "optResultAlgVO": optResultAlgVO
  366. };
  367. post(api.addScore,param).then(function(res){
  368. if(res.data.code==='0'){
  369. $("#delModal").hide();
  370. updateFlaws(res.data.data);
  371. $.alerModal({"message":"添加成功",type:"tip",time:'1000'});
  372. }
  373. });
  374. }
  375. //显示删除/修改弹窗
  376. function showModal(flag,code,i){
  377. $("#delModal .modal-body").html("");
  378. $("#delModal").show();
  379. $("#delModal .cancel").hide();
  380. $(".info-item .cont,.flaw-item .title,td").removeClass("active");
  381. //事件解绑
  382. $("#delModal .confirm").off("click");
  383. $("#qcScore,#qcMsg").off("input");
  384. const flawsList = formatFlawKeys(global_flawData);
  385. const info = flawsList[global_activeTab]&&flawsList[global_activeTab][i];
  386. if(flag==='0'){ //修改
  387. $("#delModal .title").text("修改");
  388. $("#delModal .confirm").text("保存");
  389. $("#editTmpl").tmpl(info).appendTo("#delModal .modal-body");
  390. //分数输入验证
  391. $("#qcScore").on("input",function(){
  392. const val=$(this).val();
  393. if(/^[0-9]\d*$|^[0-9]\d*(.\d)?$/.test(val) && val <= 100){
  394. $(".edit-box .warning").hide();
  395. }else{
  396. $(".edit-box .warning .red").text("支持≥0且≤100的数字输入,最多保留小数点后1位~");
  397. $(".edit-box .warning").show();
  398. }
  399. });
  400. //提示信息输入验证
  401. $("#qcMsg").on("input",function(){
  402. const val=$(this).val();
  403. $(this).attr("title",val)
  404. if(val.trim()){
  405. $(".edit-box .warning").hide();
  406. }else{
  407. $(".edit-box .warning .red").text("提示信息不能为空~");
  408. $(".edit-box .warning").show();
  409. }
  410. });
  411. $("#delModal .confirm").click(function(){
  412. if($(".edit-box .warning").is(":visible")){
  413. return;
  414. }
  415. const obj = Object.assign({},info,{msg:$("#delModal #qcMsg").val(),score:$("#delModal #qcScore").val()});
  416. editScore(obj);
  417. });
  418. }else if(flag==='2'){ //新增
  419. $("#delModal .title").text("新增");
  420. $("#delModal .confirm").text("保存");
  421. $("#addFlawTmpl").tmpl().appendTo("#delModal .modal-body");
  422. $("#flawDropTmpl").tmpl({info:code}).appendTo("#delModal .modal-body ul");
  423. //分数输入验证
  424. $("#addQcScore").on("input",function(){
  425. const val=$(this).val();
  426. if(/^[0-9]\d*$|^[0-9]\d*(.\d)?$/.test(val) && val <= 100){
  427. $(".add-box .warning").hide();
  428. }else{
  429. $(".add-box .warning .red").text("支持≥0且≤100的数字输入,最多保留小数点后1位~");
  430. $(".add-box .warning").show();
  431. }
  432. });
  433. //提示信息输入验证
  434. $("#addQcMsg").on("input",function(){
  435. const val=$(this).val();
  436. $(this).attr("title",val)
  437. if(val.trim()){
  438. $(".add-box .warning").hide();
  439. }else{
  440. $(".add-box .warning .red").text("提示信息不能为空~");
  441. $(".add-box .warning").show();
  442. }
  443. });
  444. $("#delModal .confirm").click(function(){
  445. if(!$(".flaw-drop-input").attr("code")){
  446. $(".add-box .warning .red").text("请选择质控条目~");
  447. $(".add-box .warning").show();
  448. return;
  449. }
  450. const msg=$("#delModal #addQcMsg").val();
  451. const score=Number($("#delModal #addQcScore").val());
  452. // if($(".add-box .warning").is(":visible")||!msg.trim()||!score){
  453. // return;
  454. // }
  455. // console.log($(".flaw-drop-input")[0],9999999)
  456. const obj = Object.assign({},global_selectedFlaw,{msg,score});
  457. addScore(obj);
  458. });
  459. }else{
  460. $("#delModal .title").text("删除提示");
  461. $("#delModal .modal-body").html('<p>确定要删除该评分记录吗?</p>');
  462. $("#delModal .confirm").text("删除").click(function(){
  463. delScore(code,info);
  464. });
  465. $("#delModal .cancel").show().text("取消").click(function(){
  466. $("#delModal .divModal",parent.document).remove()
  467. });
  468. }
  469. }
  470. //缺陷列表key值去掉特殊符号
  471. function formatFlawKeys(data){
  472. const obj = {};
  473. for(let k in data){
  474. obj[k.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'')]=data[k];
  475. }
  476. return obj;
  477. }
  478. //获取缺陷条目下拉列表
  479. function getQcCasesEntry(name){
  480. const id=$("#subMenu [code="+global_activeTab+"]").attr("mode");
  481. const param = {
  482. 'behospitalCode':global_id,
  483. 'entryName':name||"",
  484. 'modeId':id
  485. };
  486. post(api.findQcCasesEntry,param).then(function(res){
  487. if(res.data.code==='0'){
  488. const data = res.data.data;
  489. if(name){
  490. global_flaws=data;
  491. $("#delModal .modal-body ul").html("");
  492. $("#flawDropTmpl").tmpl({info:data}).appendTo("#delModal .modal-body ul");
  493. }else{
  494. global_flaws=data;
  495. if($("#delModal").css("display") == "block"){
  496. $("#flawDropTmpl").tmpl({info:data}).appendTo("#delModal .modal-body ul");
  497. return
  498. }
  499. showModal('2',data);
  500. }
  501. }
  502. });
  503. }
  504. //增加条目弹窗元素事件
  505. $("body").on("click",".add-box .flaw-drop-input",function(){
  506. $(".add-box .drop-box").addClass("show");
  507. });
  508. $("body").on("blur",".add-box .flaw-drop-input",function(){
  509. setTimeout(function(){
  510. $(".add-box .drop-box").removeClass("show");
  511. },300)
  512. });
  513. $("body").on("input",".add-box .flaw-drop-input",function(){
  514. $(this).attr({"code":"","title":$(this).val().trim()});
  515. getQcCasesEntry($(this).val().trim());
  516. });
  517. $("body").on("click",".add-box .drop-box li",function(){
  518. const n = $(this).attr("idx");
  519. const flaw=global_flaws[n];
  520. const {score,msg,entryName,casesEntryId}=flaw;
  521. global_selectedFlaw=flaw;
  522. $(".flaw-drop-input").val(entryName).attr({"code":casesEntryId,"title":entryName});
  523. $("#addQcMsg").val(msg).attr("title",msg);
  524. $("#addQcScore").val(score);
  525. $(".add-box .warning").hide();
  526. $(".add-box .drop-box").removeClass("show");
  527. });
  528. //更新缺陷列表
  529. function updateFlaws(info){
  530. $("#patientInfo .level").text("质控等级:"+info.level);
  531. $("#patientInfo .score").text("质控得分:"+info.scoreRes);
  532. const param = {
  533. 'behospitalCode':global_id,
  534. 'paramStr':[
  535. "msg"
  536. ]
  537. };
  538. post(api.getRecordDetail,param).then(function(res){
  539. if(res.data.code==='0'){
  540. const data = res.data.data;
  541. const {msg} = data;
  542. initScoreItem(msg);
  543. global_flawData=msg;
  544. }
  545. });
  546. }
  547. //获取病例模板
  548. function getInfoModule(moduleId){
  549. const param = {
  550. moduleId:moduleId
  551. };
  552. post(api.getInfoModule,param).then(function(res){
  553. if(res.data.code==='0'){
  554. const data = res.data.data;
  555. cachemoduleDatas(data);
  556. getRecordDetail();
  557. }
  558. });
  559. }
  560. //模板数据缓存
  561. function cachemoduleDatas(data){
  562. const moudle=data.moduleDetail;
  563. global_modules[data.modeName]=[];
  564. for(let i in moudle){
  565. global_modules[data.modeName].push(moudle[i]);
  566. }
  567. }
  568. //初始化模板
  569. function initModuleData(mid,obj){
  570. const n = obj.length;
  571. const module=global_modules[mid].moduleDetail;
  572. const key = global_modules[mid].modeName.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'');
  573. let hml = '<div class="content-item" code="'+key+'">' +
  574. '<h2 class="title">'+global_modules[mid].modeName+'('+mid+')</h2>'+
  575. (n>1?'<div class="container">':'<div class="container content-ht">');
  576. for(let i in module){
  577. hml=hml+'<div class="info-item">';
  578. for(let j=0;j<module[i].length;j++) {
  579. const detal = module[i][j].questionDTO;
  580. const {tagType} = detal;
  581. switch (tagType) {
  582. case 1:
  583. hml = hml + simpleStructure(detal,obj);
  584. break;
  585. case 4:
  586. hml = hml + combineStructure(detal);
  587. break;
  588. default:
  589. break;
  590. }
  591. }
  592. hml = hml+"</div>"
  593. }
  594. return hml+"</div></div>";
  595. }
  596. //基础类型结构生成
  597. function simpleStructure(data,obj){
  598. const {name, val,monoLine,addLine,position,bold,retract,id} = data;
  599. if(name==="手术记录表格-1"){
  600. const value = val.replace("【","").replace("】","");
  601. const diag = obj[0][value]?JSON.parse(obj[0][value]):"";
  602. let thml=`<div class="cont" style="width: 100%;" id="anchor${id}">`;
  603. thml+=$("#tableTmpl").tmpl({k:"手术信息",data:diag})[0].outerHTML+"</div>";
  604. return thml;
  605. }
  606. if(name==="出院诊断表格-1"){
  607. const value = val.replace("【","").replace("】","");
  608. const diag = obj[0][value]?JSON.parse(obj[0][value]):"";
  609. let thml=`<div class="cont" style="width: 100%;" id="anchor${id}">`;
  610. thml+=$("#tableTmpl").tmpl({k:"出院诊断",data:diag})[0].outerHTML+"</div>";
  611. return thml;
  612. }
  613. const posClass = position===1?'text-left':'';
  614. const boldClass = bold===1?'text-bold':'';
  615. const retractClass = retract===1?'text-indent':'';
  616. const lineHml = ('<p class="'+posClass+' '+boldClass+' '+retractClass+'">'+ extractVars(val)+'</p>');
  617. const txtHml = ('<p style="display: inline;vertical-align: middle;" class="'+posClass+' '+boldClass+' '+retractClass+'">'+ extractVars(val)+'</p>');
  618. let hml = addLine||monoLine?`<div class="cont ${posClass}" style="width: 100%;" id="anchor${id}">`:`<div class="cont" id="anchor${id}">`;
  619. hml=hml+`<span class="label">${name}</span>`+ (addLine?lineHml:txtHml)+ `</div>`;
  620. return hml;
  621. }
  622. //组合类型结构生成
  623. function combineStructure(data){
  624. const {name,questionMapping,id} = data;
  625. let hml='<div class="inner-table"><table>';
  626. const colNum = Math.ceil(questionMapping.length/2);
  627. let tdVal='';
  628. const regexp = /(【(.+?)】)/g;
  629. for(let i=0;i<questionMapping.length;){
  630. if(questionMapping[i+1]){
  631. tdVal="<td id='anchor"+questionMapping[i].id+"'>"+questionMapping[i].name+extractVars(questionMapping[i].val)+"</td><td id='anchor"+questionMapping[i+1].id+"'>"+questionMapping[i+1].name+extractVars(questionMapping[i+1].val)+"</td>";
  632. }else{
  633. tdVal="<td id='anchor"+questionMapping[i].id+"'>"+questionMapping[i].name+extractVars(questionMapping[i].val)+"</td><td></td>";
  634. }
  635. if(i==0){
  636. hml=hml+`<tr><td rowspan="${colNum}" id='anchor${id}'>${name}</td>${tdVal}`;
  637. }else{
  638. hml=hml+`<tr>${tdVal}`;
  639. }
  640. hml=hml+"</tr>";
  641. i=((i+2)>questionMapping.length?i+1:i+2)
  642. }
  643. hml=hml+"</table></div>";
  644. return hml;
  645. }
  646. //抽取变量
  647. function extractVars(org){
  648. const regexp = /(【(.+?)】)/g;
  649. const arr = org.split(regexp);
  650. //console.log(arr)
  651. let htl = '',val='';
  652. for(let i=0;i<arr.length;i++){
  653. val = arr[i].indexOf("【")!=-1?'':(arr[i-1]&&arr[i-1].indexOf("【")!=-1?"{{html "+arr[i]+"}}":arr[i]);
  654. htl=htl+val;
  655. }
  656. return htl;
  657. }
  658. //获取所有模板
  659. function getAllModules(){
  660. const param={
  661. hospitalId:getUrlArgObject("hid"),
  662. modeId:''
  663. };
  664. post(api.getModuleById,param).then((res)=>{
  665. if(res.data.code==='0') {
  666. const data = res.data.data;
  667. global_modules=data;
  668. getRecordDetail();
  669. $("#loading").hide();
  670. setTimeout(function(){
  671. $(".operation").show()
  672. },50)
  673. }
  674. });
  675. }
  676. function checkQc(){
  677. const param={
  678. behospitalCode:getUrlArgObject("id"),
  679. hospitalId:getUrlArgObject("hid")
  680. };
  681. post(api.checkQc,param).then((res)=>{
  682. if(res.data.code==='0') {
  683. global_check = 1
  684. $(".check").text("重新核查")
  685. $.alerModal({"message":`<div class="checkTipsBox"><img class="checkImg" src=${checkOk}><p class="checkTxt">核查成功</p></div>`,type:"tip",time:'1000',isFather: false});
  686. }else{
  687. $.alerModal({"message":res.data.msg ||"核查失败",type:"tip",time:'1000',isFather: false});
  688. }
  689. });
  690. }
  691. });