qcScore.js 22 KB

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