qcScore.js 19 KB

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