qcScore.js 20 KB

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