qcScore.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472
  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. //本页全局变量
  8. let global_flawData = {}; //缺陷数据
  9. const global_id=getUrlArgObject("id");
  10. const global_age = getUrlArgObject("age");
  11. const global_code = getUrlArgObject("code");
  12. let global_activeTab=$(".sub-menu .page.active").attr("code"); //当前激活菜单项
  13. let global_modules ={}; //模板数据缓存
  14. window.document.title="质控评分-"+getUrlArgObject("name");
  15. $(function(){
  16. //getSubMenu();
  17. //initScoreItem();
  18. //getRecordDetail();
  19. getAllModules()
  20. //getInfoModule(15); //根据对应id获取模板
  21. function initMenu(data){
  22. const menu=[{id:0,name:"缺陷总览",parentId: -1,sonMode: []},...(data||[])];
  23. //菜单数据填充
  24. $("#subMenuTmpl").tmpl(menu).appendTo("#subMenu");
  25. $("#miniMenuTmpl").tmpl(menu).appendTo(".menu-mini ul");
  26. //菜单收起展开
  27. $(".list-1").on("click",function(){
  28. $(".list-1 .slide-up").removeClass('slide-up');
  29. $(this).toggleClass('slide-up');
  30. $(this).find("ul").slideToggle();
  31. });
  32. $(".list-1 li").on("click",function(e){
  33. e.stopPropagation();
  34. });
  35. //收起菜单
  36. $(".slide-hide").click(function(){
  37. $(".sub-menu").animate({"width":"45px"},function(){
  38. $(this).hide();
  39. $(".menu-mini").show();
  40. });
  41. $(".tab-container").animate({"margin-left":"45px"});
  42. });
  43. //展开菜单
  44. $(".slide-show").click(function(){
  45. $(".menu-mini").hide();
  46. $(".sub-menu").show().animate({"width":"205px"},function(){
  47. });
  48. $(".tab-container").animate({"margin-left":"205px"});
  49. });
  50. //右侧内容切换
  51. $(".page").on("click",function(){
  52. if($(this).attr("code")==="缺陷总览"){
  53. $(".flaw-table").show();
  54. }else{
  55. $(".flaw-table").hide();
  56. }
  57. //选中样式
  58. $(".sub-menu .active").removeClass('active');
  59. $(this).parents(".list-1").addClass("active");
  60. $(this).addClass("active");
  61. //显示对应内容
  62. const code=$(this).attr("code");
  63. global_activeTab=code;
  64. //initModuleData();
  65. $(".content-item,.flaw-item").hide();
  66. $(".content-item[code='"+code+"']").show();
  67. showFlawList();
  68. });
  69. }
  70. //判断有无某一权限
  71. function hasData(data){
  72. let trdObj = JSON.parse(getCookie("trdObj"))
  73. let lis = trdObj[global_code]
  74. if(!lis){
  75. return false
  76. }
  77. if(lis.indexOf(data)>-1){//有权限
  78. return true
  79. }
  80. return false;
  81. }
  82. //获取病例明细
  83. function getRecordDetail(){
  84. post(api.getRecordDetail,{'behospitalCode':global_id}).then(function(res){
  85. if(res.data.code==='0'){
  86. const data = res.data.data;
  87. const {beHospital,result,msg} = data;
  88. const info=Object.assign(beHospital,result);
  89. initMenu(JSON.parse(result.menuData));
  90. $(".sub-menu>ul>li:first-child.page").addClass("active");
  91. global_activeTab=$(".sub-menu .page.active").attr("code");
  92. initPatientInfo(info);
  93. initContent(result.pageData);
  94. initList(msg);
  95. initScoreItem(msg);
  96. global_flawData=msg;
  97. /*let obj = JSON.parse(result.pageData)
  98. infoNotNull(obj,'查房记录')&&wardRound(obj['查房记录'],'查房记录')
  99. infoNotNull(obj,'术前讨论、术前小结')&&preoperation(obj['术前讨论、术前小结'],'术前讨论、术前小结')
  100. infoNotNull(obj,'阶段小结')&&summary(obj['阶段小结'],'阶段小结')
  101. infoNotNull(obj,'手术记录')&&operationRecord(obj['手术记录'],'手术记录')
  102. infoNotNull(obj,'会诊申请单')&&applicationForm(obj['会诊申请单'],'会诊申请单')
  103. infoNotNull(obj,'会诊结果单')&&resultForm(obj['会诊结果单'],'会诊结果单')
  104. infoNotNull(obj,'会诊记录')&&consultationNote(obj['会诊记录'],'会诊记录')
  105. infoNotNull(obj,'疑难病例讨论记录')&&difficultRecord(obj['疑难病例讨论记录'],'疑难病例讨论记录')
  106. infoNotNull(obj,'病危通知书')&&illnessNotice(obj['病危通知书'],'病危通知书')
  107. infoNotNull(obj,'病理检验送检单')&&pathologicTest(obj['病理检验送检单'],'病理检验送检单')
  108. infoNotNull(obj,'抢救记录')&&rescueRecord(obj['抢救记录'],'抢救记录')
  109. infoNotNull(obj,'输血后效果评价')&&transfusionEvaluate(obj['输血后效果评价'],'输血后效果评价')*/
  110. setBoxHeight();
  111. }
  112. });
  113. }
  114. //判断模块内容是否不为空
  115. function infoNotNull(obj,moduleName){
  116. if( obj[moduleName]&&obj[moduleName].length > 0 &&Object.keys(obj[moduleName][0]).length !== 0 ){
  117. return true
  118. }
  119. return false
  120. }
  121. //填充患者信息
  122. function initPatientInfo(data){
  123. const obj=Object.assign({},data,{age:!global_age||global_age=="null"?"-":global_age});
  124. $("#infoTmpl").tmpl(obj).appendTo("#patientInfo");
  125. }
  126. //显示病例模块明细
  127. function initContent(data){
  128. const obj = JSON.parse(data);
  129. let info=[];
  130. let hml='',moduleId='';
  131. for(let k in obj){
  132. if(k==="病案首页"){ //病案首页不使用动态模板
  133. info=formatInfoData(k,obj[k][0]);
  134. $("#indexTmpl").tmpl(info).appendTo("#contentInfo");
  135. continue;
  136. }
  137. for(let i in obj[k]){
  138. info=formatInfoData(k,obj[k][i]);
  139. moduleId=info.mode_id;
  140. if(global_modules[moduleId]){
  141. hml=initModuleData(moduleId,obj[k].length);
  142. $.tmpl(hml,info).appendTo("#contentInfo");
  143. };
  144. }
  145. }
  146. if(obj["病案首页"]&&obj["病案首页"][0]["出院诊断"]){
  147. const diag = JSON.parse(obj["病案首页"][0]["出院诊断"]);
  148. $("#tableTmpl").tmpl({k:"出院诊断",data:diag}).appendTo("#diagTable");
  149. }
  150. if(obj["病案首页"]&&obj["病案首页"][0]["手术信息"]){
  151. const diag = JSON.parse(obj["病案首页"][0]["手术信息"]);
  152. $("#tableTmpl").tmpl({k:"手术信息",data:diag}).appendTo("#surgeryTable");
  153. }
  154. $(".content-item[code="+global_activeTab+"]").show();
  155. //console.log(obj)
  156. }
  157. function formatInfoData(k,data){
  158. let obj = {},name="";
  159. for(let i in data){
  160. if(i!=="mode_id"){
  161. name=i.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,"").replace(/^[0-9]+/,"a"); //过滤key中存在的特殊符号,模板会渲染不出来且不报错
  162. obj[name]=data[i].replace(/\n/g,"<br/>")||"";
  163. }else{
  164. obj[i]=data[i].replace(/\n/g,"<br/>")||"";
  165. }
  166. }
  167. return Object.assign({title:k},obj);
  168. }
  169. /*function formatData(data,title){
  170. if(!keyMaps[title]){
  171. return data;
  172. }
  173. const keyArr=Object.keys(keyMaps[title]);
  174. let obj={};
  175. keyArr.map((k)=>{
  176. obj[keyMaps[title][k]]=data[0][k]||"";
  177. });
  178. const obj1=Object.assign({},obj,data[0]);
  179. return [obj1];
  180. }*/
  181. function initList(data){
  182. $("#flawTotalList").tmpl({data:data}).appendTo(".flaw-table");
  183. $(".slide-up").off("click").on("click",function(){
  184. const name = $(this).text();
  185. $("tr[code='"+name+"']").slideToggle();
  186. $(this).toggleClass("down");
  187. });
  188. }
  189. //评分项数据填充
  190. function initScoreItem(data){
  191. $("#flaws .flaw-box").html("");
  192. let hasAu = hasData('FUNC000013')
  193. let hasAu2 = hasData('FUNC000012')
  194. for(let k in data){
  195. $("#flawTmpl").tmpl(data[k]).appendTo("#flaws .flaw-box");
  196. }
  197. showFlawList();
  198. $(".flaw-item .oper a").click(function () {
  199. const i = $(".flaw-item[code="+global_activeTab+"]").index($(this).parents(".flaw-item"));
  200. const code=$(this).attr("code");
  201. const isEdit = $(this).is(".edit-flaw");
  202. if(!hasAu)return
  203. if(isEdit&&hasAu){
  204. showModal('0',code,i);
  205. }else if(!isEdit&&hasAu2){
  206. showModal('1',code,i);
  207. }
  208. })
  209. $(".edit-flaw").css({"opacity":hasAu?"1":"0.5",cursor:hasAu?"pointer":"unset"});
  210. $(".del-flaw").css({"opacity":hasAu2?"1":"0.5",cursor:hasAu2?"pointer":"unset"});
  211. $(".flaw-item .title a[href]").click(function(){
  212. const id = $(this).attr("href");
  213. const anchors=$(this).attr("anchors").split(",");
  214. let ans = anchors.map((it)=>{
  215. return "#anchor"+it;
  216. });
  217. $(".info-item .cont,.flaw-item .title").removeClass("active");
  218. $(ans.join(",")).addClass("active");
  219. $(this).parent().addClass("active");
  220. });
  221. }
  222. //显示缺陷列表
  223. function showFlawList(){
  224. const hml = $(".flaw-item[code="+global_activeTab+"]");
  225. if(hml.length){
  226. hml.show();
  227. $("#flaws .empty").hide();
  228. }else{
  229. $("#flaws .empty").length?$("#flaws .empty").show():$("#emptyTmpl").tmpl().appendTo("#flaws .flaw-box");
  230. }
  231. }
  232. //删除评分项
  233. function delScore(id,info){
  234. const param={
  235. 'behospitalCode':global_id,
  236. 'optResultAlgVO':{
  237. 'id':id
  238. }
  239. };
  240. post(api.delScore,param).then(function(res){
  241. if(res.data.code==='0'){
  242. $("#delModal").hide();
  243. updateFlaws(res.data.data);
  244. $("#anchor"+info.pageKeyList[0]).removeClass("active");
  245. $.alerModal({"message":"删除成功",type:"tip",time:'1000'});
  246. }
  247. });
  248. }
  249. //修改评分项
  250. function editScore(info){
  251. const param={
  252. "behospitalCode": global_id,
  253. "optResultAlgVO": info
  254. };
  255. post(api.editScore,param).then(function(res){
  256. if(res.data.code==='0'){
  257. $("#delModal").hide();
  258. updateFlaws(res.data.data);
  259. $.alerModal({"message":"修改成功",type:"tip",time:'1000'});
  260. }
  261. });
  262. }
  263. //显示删除/修改弹窗
  264. function showModal(flag,code,i){
  265. $("#delModal .modal-body").html("");
  266. $("#delModal").show();
  267. $(".info-item .cont,.flaw-item .title").removeClass("active");
  268. //事件解绑
  269. $("#delModal .confirm").off("click");
  270. $("#qcScore,#qcMsg").off("input");
  271. const flawsList = formatFlawKeys(global_flawData);
  272. const info = flawsList[global_activeTab][i];
  273. if(flag==='0'){ //修改
  274. $("#delModal .title").text("修改");
  275. $("#delModal .confirm").text("保存");
  276. $("#editTmpl").tmpl(info).appendTo("#delModal .modal-body");
  277. //分数输入验证
  278. $("#qcScore").on("input",function(){
  279. const val=$(this).val();
  280. if(/^[0-9]\d*$|^[0-9]\d*(.\d)?$/.test(val) && val <= 100){
  281. $(".edit-box .warning").hide();
  282. }else{
  283. $(".edit-box .warning .red").text("支持≥0且≤100的数字输入,最多保留小数点后1位~");
  284. $(".edit-box .warning").show();
  285. }
  286. });
  287. //提示信息输入验证
  288. $("#qcMsg").on("input",function(){
  289. const val=$(this).val();
  290. if(val.trim()){
  291. $(".edit-box .warning").hide();
  292. }else{
  293. $(".edit-box .warning .red").text("提示信息不能为空~");
  294. $(".edit-box .warning").show();
  295. }
  296. });
  297. $("#delModal .confirm").click(function(){
  298. if($(".edit-box .warning").is(":visible")){
  299. return;
  300. }
  301. const obj = Object.assign({},info,{msg:$("#delModal #qcMsg").val(),score:$("#delModal #qcScore").val()});
  302. editScore(obj);
  303. });
  304. }else{
  305. $("#delModal .title").text("删除评分");
  306. $("#delModal .confirm").text("确定");
  307. $("#delModal .modal-body").html('<p>确定要删除该评分记录吗?</p>');
  308. $("#delModal .confirm").click(function(){
  309. delScore(code,info);
  310. });
  311. }
  312. }
  313. //缺陷列表key值去掉特殊符号
  314. function formatFlawKeys(data){
  315. const obj = {};
  316. for(let k in data){
  317. obj[k.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'')]=data[k];
  318. }
  319. return obj;
  320. }
  321. //更新缺陷列表
  322. function updateFlaws(info){
  323. $("#patientInfo .level").text("质控等级:"+info.level);
  324. $("#patientInfo .score").text("质控得分:"+info.scoreRes);
  325. const param = {
  326. 'behospitalCode':global_id,
  327. 'paramStr':[
  328. "msg"
  329. ]
  330. };
  331. post(api.getRecordDetail,param).then(function(res){
  332. if(res.data.code==='0'){
  333. const data = res.data.data;
  334. const {msg} = data;
  335. initScoreItem(msg);
  336. global_flawData=msg;
  337. }
  338. });
  339. }
  340. //获取病例模板
  341. function getInfoModule(moduleId){
  342. const param = {
  343. moduleId:moduleId
  344. };
  345. post(api.getInfoModule,param).then(function(res){
  346. if(res.data.code==='0'){
  347. const data = res.data.data;
  348. cachemoduleDatas(data);
  349. getRecordDetail();
  350. }
  351. });
  352. }
  353. //模板数据缓存
  354. function cachemoduleDatas(data){
  355. const moudle=data.moduleDetail;
  356. global_modules[data.modeName]=[];
  357. for(let i in moudle){
  358. global_modules[data.modeName].push(moudle[i]);
  359. }
  360. }
  361. //初始化模板
  362. function initModuleData(mid,n){
  363. const module=global_modules[mid].moduleDetail;
  364. const key = global_modules[mid].modeName.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'');
  365. let hml = '<div class="content-item" code="'+key+'">' +
  366. '<h2 class="title">'+global_modules[mid].modeName+'('+mid+')</h2>' +
  367. (n>1?'<div class="container">':'<div class="container content-ht">');
  368. for(let i in module){
  369. hml=hml+'<div class="info-item">';
  370. for(let j=0;j<module[i].length;j++) {
  371. const detal = module[i][j].questionDTO;
  372. const {tagType} = detal;
  373. switch (tagType) {
  374. case 1:
  375. hml = hml + simpleStructure(detal);
  376. break;
  377. case 4:
  378. hml = hml + combineStructure(detal);
  379. break;
  380. default:
  381. break;
  382. }
  383. }
  384. hml = hml+"</div>"
  385. }
  386. return hml+"</div></div>";
  387. }
  388. //基础类型结构生成
  389. function simpleStructure(data){
  390. const {name, val,monoLine,addLine,position,bold,retract,id} = data;
  391. const posClass = position===1?'text-left':'';
  392. const boldClass = bold===1?'text-bold':'';
  393. const retractClass = retract===1?'text-indent':'';
  394. const lineHml = ('<p class="'+posClass+' '+boldClass+' '+retractClass+'">'+ extractVars(val)+'</p>');
  395. const txtHml = ('<p style="display: inline;vertical-align: middle;" class="'+posClass+' '+boldClass+' '+retractClass+'">'+ extractVars(val)+'</p>');
  396. let hml = addLine||monoLine?`<div class="cont ${posClass}" style="width: 100%;" id="anchor${id}">`:`<div class="cont" id="anchor${id}">`;
  397. hml=hml+`<span class="label">${name}</span>`+ (addLine?lineHml:txtHml)+ `</div>`;
  398. return hml;
  399. }
  400. //组合类型结构生成
  401. function combineStructure(data){
  402. const {name,questionMapping} = data;
  403. let hml='<div class="inner-table"><table>';
  404. const colNum = Math.ceil(questionMapping.length/2);
  405. let tdVal='';
  406. const regexp = /(【(.+?)】)/g;
  407. for(let i=0;i<questionMapping.length;){
  408. if(questionMapping[i+1]){
  409. tdVal="<td>"+questionMapping[i].name+extractVars(questionMapping[i].val)+"</td><td>"+questionMapping[i+1].name+extractVars(questionMapping[i+1].val)+"</td>";
  410. }else{
  411. tdVal="<td>"+questionMapping[i].name+extractVars(questionMapping[i].val)+"</td><td></td>";
  412. }
  413. if(i==0){
  414. hml=hml+`<tr><td rowspan="${colNum}">${name}</td>${tdVal}`;
  415. }else{
  416. hml=hml+`<tr>${tdVal}`;
  417. }
  418. hml=hml+"</tr>";
  419. i=((i+2)>questionMapping.length?i+1:i+2)
  420. }
  421. hml=hml+"</table></div>";
  422. return hml;
  423. }
  424. //抽取变量
  425. function extractVars(org){
  426. const regexp = /(【(.+?)】)/g;
  427. const arr = org.split(regexp);
  428. //console.log(arr)
  429. let htl = '',val='';
  430. for(let i=0;i<arr.length;i++){
  431. val = arr[i].indexOf("【")!=-1?'':(arr[i-1]&&arr[i-1].indexOf("【")!=-1?"{{html "+arr[i]+"}}":arr[i]);
  432. htl=htl+val;
  433. }
  434. return htl;
  435. }
  436. //获取所有模板
  437. function getAllModules(){
  438. const param={
  439. hospitalId:getUrlArgObject("hid"),
  440. modeId:''
  441. };
  442. post(api.getModuleById,param).then((res)=>{
  443. if(res.data.code==='0') {
  444. const data = res.data.data;
  445. global_modules=data;
  446. getRecordDetail();
  447. $("#loading").hide();
  448. }
  449. });
  450. }
  451. });