qcScore.js 14 KB

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