editableDetail.js 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. require("../css/editableDetail.less");
  2. const $ = require('jquery');
  3. require('jquery-templates');
  4. require('./modal.js');
  5. const {post,getUrlArgObject} = require('./utils.js');
  6. const {api,editApi} = require('./api.js');
  7. $(function(){
  8. //本页全局变量
  9. let global_wholeData={};
  10. let global_recId = '';
  11. let global_modules ={}; //模板数据缓存
  12. getAllModules();
  13. //window.document.title=(showCheckBtns?"质控核查-":"质控评分-")+getUrlArgObject("name");
  14. //获取病例明细
  15. function getRecordDetail(){
  16. post(editApi.getDataEdit).then(function(res){
  17. if(res.data.code==='0'){
  18. const data = res.data.data;
  19. const { wholeData,modeId,recId } = data;
  20. global_recId=recId;
  21. initContent(modeId,wholeData);
  22. }else{
  23. $.alerModal({"message":res.data.msg||'获取数据失败',type:"tip",time:'1000'});
  24. }
  25. }).catch((error)=>{
  26. $.alerModal({"message":error,type:"tip",time:'1000'});
  27. });
  28. }
  29. //保存事件注册
  30. function saveDataEvent(){
  31. $("#saveBtn").off('click').on("click",function(){
  32. saveData();
  33. })
  34. }
  35. //保存数据
  36. function saveData(){
  37. const datasDom = $(".cont div[contenteditable=\"true\"]");
  38. let valName = '',obj={};
  39. for(let i=0;i<datasDom.length;i++){
  40. valName = $(datasDom[i]).attr("valname");
  41. obj[valName]=$(datasDom[i]).text();
  42. }
  43. global_wholeData = Object.assign({},global_wholeData,obj);
  44. let param = {wholeData:JSON.stringify(global_wholeData),hospitalId:getUrlArgObject("hid"),recId:global_recId};
  45. console.log(11,obj,global_wholeData);
  46. post(editApi.saveDataEdit,param).then((res)=>{
  47. if(res.data.code==='0'){
  48. $.alerModal({"message":"保存成功",type:"tip",time:'1000',win:true});
  49. }else{
  50. $.alerModal({"message":res.data.msg||"保存失败",type:"tip",time:'1000'});
  51. }
  52. }).catch((error)=>{
  53. $.alerModal({"message":error,type:"tip",time:'1000'});
  54. })
  55. }
  56. //显示病例模块明细
  57. function initContent(moduleId,data){
  58. const obj = JSON.parse(data);
  59. global_wholeData=obj;
  60. let info=[];
  61. let hml='';
  62. //formatSpecPage(obj["谈话告知书"],"谈话告知书");
  63. //formatSpecPage(obj["知情同意书"],"知情同意书");
  64. info=formatInfoData(obj);
  65. if(global_modules[moduleId]){
  66. hml=initModuleData(moduleId,obj);
  67. }else{
  68. info={};
  69. hml=`<div class="empty">
  70. <img src="${icon}" alt="空"/>
  71. <p>暂无信息~</p>
  72. </div>`;
  73. }
  74. $(".empty").remove();
  75. $.tmpl(hml,info).appendTo("#contentInfo");
  76. saveDataEvent();
  77. //console.log(obj)
  78. }
  79. function formatInfoData(data){
  80. let obj = {},name="";
  81. for(let i in data){
  82. if(i!=="mode_id"){
  83. name=i.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,"").replace(/^[0-9]+/,"a"); //过滤key中存在的特殊符号,模板会渲染不出来且不报错
  84. obj[name]=data[i].replace(/\n/g,"<br/>")||"";
  85. }else{
  86. obj[i]=data[i].replace(/\n/g,"<br/>")||"";
  87. }
  88. }
  89. return Object.assign({},obj);
  90. }
  91. //初始化模板
  92. function initModuleData(mid,obj){
  93. const n = obj.length;
  94. const module=global_modules[mid].moduleDetail;
  95. const key = global_modules[mid].modeName.replace(/[^\u4e00-\u9fa5|a-zA-Z0-9]+/g,'');
  96. let hml = '<div class="content-item" code="'+key+'">' +
  97. //'<h2 class="title">'+global_modules[mid].modeName+'('+mid+')</h2>'+
  98. (n>1?'<div class="container">':'<div class="container">');
  99. for(let i in module){
  100. hml=hml+'<div class="info-item">';
  101. for(let j=0;j<module[i].length;j++) {
  102. const detal = module[i][j].questionDTO;
  103. const {tagType} = detal;
  104. switch (tagType) {
  105. case 1:
  106. hml = hml + simpleStructure(detal,obj);
  107. break;
  108. case 4:
  109. hml = hml + combineStructure(detal);
  110. break;
  111. default:
  112. break;
  113. }
  114. }
  115. hml = hml+"</div>"
  116. }
  117. return hml+"</div></div>";
  118. }
  119. //基础类型结构生成
  120. function simpleStructure(data,obj){
  121. //console.log(data,obj,7878787)
  122. const {name, val,monoLine,addLine,position,bold,retract,id} = data;
  123. const noEdits = `'医师签名','时间','出院计划','修正诊断','4.治疗监测计划','姓名','家庭住址','出生日期','性别','工作单位','身份证号','民族','年龄','联系人(关系)','职业','婚姻状况','出生地','入院日期','记录日期','病史陈述者','电话','户口地址','目前使用的药物','成瘾药物','3.诊疗计划','1.需求评估','2.预期目标'`;
  124. let nameStr = name.replace(":","").replace(":","");
  125. const editable = noEdits.indexOf(nameStr)===-1;console.log(11,name)
  126. const posClass = position===1?'text-left':'';
  127. const boldClass = bold===1?'text-bold':'';
  128. const retractClass = retract===1?'text-indent':'';
  129. const valName = extractVars(val);
  130. const valT = valName.replace(/[{{html |}}]/g,"")
  131. const lineHml = (`<div contenteditable="${editable?true:false}" valname="`+valT+`" class="'+posClass+' '+boldClass+' '+retractClass+'">${extractVars(val)}</div>`);
  132. const txtHml = (`<div contenteditable="${editable?true:false}" valname="`+valT+`" class="fl ${posClass} ${boldClass} ${retractClass}">${ extractVars(val)}</div>`);
  133. let hml = addLine||monoLine?`<div class="cont clearfix ${posClass}" style="width: 100%;" id="anchor${id}">`:`<div class="cont" id="anchor${id}">`;
  134. hml=hml+`<span class="label ${addLine?'':'fl'}">${name}</span>`+ (addLine?lineHml:txtHml)+ `</div>`;
  135. return hml;
  136. }
  137. //组合类型结构生成
  138. function combineStructure(data){
  139. const {name,questionMapping,id} = data;
  140. let hml='<div class="inner-table"><table>';
  141. const colNum = Math.ceil(questionMapping.length/2);
  142. let tdVal='';
  143. const regexp = /(【(.+?)】)/g;
  144. for(let i=0;i<questionMapping.length;){
  145. if(questionMapping[i+1]){
  146. 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>";
  147. }else{
  148. tdVal="<td id='anchor"+questionMapping[i].id+"'>"+questionMapping[i].name+extractVars(questionMapping[i].val)+"</td><td></td>";
  149. }
  150. if(i==0){
  151. hml=hml+`<tr><td rowspan="${colNum}" id='anchor${id}'>${name}</td>${tdVal}`;
  152. }else{
  153. hml=hml+`<tr>${tdVal}`;
  154. }
  155. hml=hml+"</tr>";
  156. i=((i+2)>questionMapping.length?i+1:i+2)
  157. }
  158. hml=hml+"</table></div>";
  159. return hml;
  160. }
  161. //抽取变量
  162. function extractVars(org){
  163. const regexp = /(【(.+?)】)/g;
  164. const arr = org.split(regexp);
  165. let htl = '',val='';
  166. for(let i=0;i<arr.length;i++){
  167. val = arr[i].indexOf("【")!=-1?'':(arr[i-1]&&arr[i-1].indexOf("【")!=-1?"{{html "+arr[i]+"}}":arr[i]);
  168. htl=htl+val;
  169. }
  170. //console.log(11,org,arr,htl)
  171. return htl;
  172. }
  173. //获取所有模板
  174. function getAllModules(){
  175. const param={
  176. hospitalId:getUrlArgObject("hid")||1,
  177. modeId:''
  178. };
  179. post(api.getModuleById,param).then((res)=>{
  180. if(res.data.code==='0') {
  181. const data = res.data.data;
  182. global_modules=data;
  183. getRecordDetail();
  184. $("#loading").hide();
  185. }
  186. });
  187. }
  188. });