indexVertDom.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454
  1. const $ = require("jquery");
  2. const { openNewWin,imageUrlPrefix } = require('./promise.js');
  3. const { bindTipsEvent } = require('./popupEdit.js');
  4. function renderRecommendInfo(showNum,className,title,data, hasInfo, type, position) {
  5. let showNumCopy = showNum || 5
  6. const dataLen = data.length
  7. const str = `<div class="recommendInfoWrapper ${className}">
  8. <h4><i></i>${title}</h4>
  9. <div class="recommendInfoBox">
  10. <div class="clearfix recommendInfoItemBox ${className + 'box'}">
  11. </div>
  12. </div>
  13. </div>`
  14. $('.recommendWrap').append(str)
  15. let dataShort
  16. if(showNumCopy&& dataLen > showNumCopy) {
  17. dataShort = data.slice(0, showNumCopy)
  18. } else {
  19. dataShort = data
  20. }
  21. let childrenNodeStrShort = ''
  22. let childrenNodeStrLong = ''
  23. if(hasInfo) {
  24. for (let i = 0; i < dataShort.length; i++) {
  25. childrenNodeStrShort += `<span class="recommendInfoItem recommendInfoItemHasInfo">
  26. ${dataShort[i].name}
  27. <span title="点击i图标可查看详细说明" class="infoMsg" data-name=${dataShort[i].name}></span>
  28. </span>`
  29. }
  30. for (let i = 0; i < data.length; i++) {
  31. childrenNodeStrLong += `<span class="recommendInfoItem recommendInfoItemHasInfo">
  32. ${data[i].name}
  33. <span title="点击i图标可查看详细说明" class="infoMsg" data-name=${data[i].name}></span>
  34. </span>`
  35. }
  36. } else {
  37. for (let i = 0; i < dataShort.length; i++) {
  38. childrenNodeStrShort += `<span class="recommendInfoItem" data-name="${dataShort[i].name}">
  39. ${dataShort[i].name}
  40. </span>`
  41. }
  42. for (let i = 0; i < data.length; i++) {
  43. childrenNodeStrLong += `<span class="recommendInfoItem" data-name="${data[i].name}">
  44. ${data[i].name}
  45. </span>`
  46. }
  47. }
  48. if(!childrenNodeStrShort) {
  49. childrenNodeStrShort='<span class="recommendNull">暂无推荐</span>'
  50. }
  51. $('.'+className + 'box').append(childrenNodeStrShort)
  52. $('.'+className + 'box' +' .infoMsg').on('click', function(){
  53. const infoMsgName = $(this).attr('data-name')
  54. openNewWin(`information.html?type=${type}&position=${position}&name=${infoMsgName}`)
  55. })
  56. if(dataLen > showNumCopy) {
  57. slideToggle($("."+className+"box"), childrenNodeStrShort,childrenNodeStrLong)
  58. }
  59. }
  60. function renderMultRecommendInfo(className,title,data, hasInfo, type, position) {
  61. const str = `<div class="recommendInfoWrapper ${className}">
  62. <h4><i></i>${title}</h4>
  63. <div class="recommendInfoBox ${className + 'box'}"></div>
  64. </div>`
  65. $('.recommendWrap').append(str)
  66. let hasDataNum = 0
  67. for(let i = 0; i < data.length; i++) {
  68. const showNum = data[i].showNum || 5
  69. const dataLen = data[i].data.length
  70. if(dataLen === 0) {
  71. continue
  72. }
  73. hasDataNum++
  74. if(hasDataNum > 1) {
  75. $('.'+className + 'box').append('<div class="line"></div>')
  76. }
  77. let childrenNodeBoxStr = `<div class="labAndPacsBox ${data[i].className} clearfix"> </div>`
  78. let childrenNodeStrShort = `<span class="labAndPacsTitle">${data[i].title}<i></i></span>`
  79. let childrenNodeStrLong = `<span class="labAndPacsTitle">${data[i].title}<i></i></span>`
  80. let dataShort
  81. if(showNum&& dataLen > showNum) {
  82. dataShort = data[i].data.slice(0, showNum)
  83. } else {
  84. dataShort = data[i].data
  85. }
  86. for(let j = 0; j < dataShort.length; j++) {
  87. childrenNodeStrShort += `<span class="labAndPacsItem">${dataShort[j].name}</span>`
  88. }
  89. for(let j = 0; j < data[i].data.length; j++) {
  90. childrenNodeStrLong += `<span class="labAndPacsItem">${data[i].data[j].name}</span>`
  91. }
  92. if(data[i].data.length == 0) {
  93. childrenNodeStrShort +='<span class="recommendNull">暂无推荐</span>'
  94. }
  95. $('.'+className + 'box').append(childrenNodeBoxStr)
  96. $('.'+data[i].className).append(childrenNodeStrShort)
  97. if(dataLen > showNum) {
  98. slideToggle($("."+data[i].className), childrenNodeStrShort,childrenNodeStrLong)
  99. }
  100. }
  101. }
  102. function renderTipsInfo(className,title, data) {
  103. const str = `<div class="recommendInfoWrapper ${className}">
  104. <h4><i></i>${title}</h4>
  105. <div class="recommendInfoBox clearfix ${className + 'box'}"></div>
  106. </div>`
  107. $('.recommendWrap').append(str)
  108. if(data.length > 0) {
  109. for(let i = 0; i < data.length; i++) {
  110. renderTipsInfoMsg('tipsInfo'+i, data[i], data[i].details, className+'box')
  111. }
  112. } else {
  113. // renderTipsInfoMsg('tipsInfo', data.name, data.details, className+'box')
  114. $('.' + className+'box').append('<p class="TipsInfoNull">暂无数据</p>')
  115. }
  116. }
  117. function renderKnowledgeInfo(className,title, data) {
  118. const str = `<div class="recommendInfoWrapper ${className}">
  119. <h4><i></i>${title}</h4>
  120. <div class="recommendInfoBox clearfix ${className + 'box'}"></div>
  121. </div>`
  122. $('.recommendWrap').append(str)
  123. $('.' + className+'box').append('<p class="TipsInfoNull staticWin">'+data+'</p>')
  124. $('.'+className+' .staticWin' ).on('click', function(){
  125. openNewWin(`staticSearch.html?type=1`)
  126. })
  127. }
  128. function renderScaleInfo(className,title, data) {
  129. const str = `<div class="recommendInfoWrapper ${className}">
  130. <h4><i></i>${title}</h4>
  131. <div class="recommendInfoBox clearfix ${className + 'box'}"></div>
  132. </div>`
  133. $('.recommendWrap').append(str)
  134. $('.' + className+'box').append('<p class="TipsInfoNull staticWin">'+data+'</p>')
  135. $('.'+className+' .staticWin' ).on('click', function(){
  136. openNewWin(`staticSearch.html?type=2&msg=${encodeURIComponent(JSON.stringify(msg))}`)
  137. })
  138. }
  139. function renderTipsInfoMsg(className,item,data, parentNode) {
  140. const childrenNodeBoxStr = `
  141. <div class = "treatItemBox ${className + 'box'}">
  142. <p class="treatItemTitle">${item.name} <span class="moreInfo" data-name="${item.name}" data-type="${item.type}"}>详情</span></p>
  143. <p class="${className + 'Info'} clearfix"></p>
  144. </div>
  145. `
  146. $('.' + parentNode).append(childrenNodeBoxStr)
  147. let dataStr = ``
  148. if(data.length === 0) {
  149. dataStr += `<p class="TipsInfoNull">暂无数据</p>
  150. `
  151. } else {
  152. for(let i = 0; i < data.length; i++) {
  153. dataStr += `<p>${data[i].title}</p>
  154. ${data[i].content.replace(/{imageUrlPrefix}/g, imageUrlPrefix)}
  155. `
  156. }
  157. }
  158. $('.' + className+'Info').html(dataStr)
  159. }
  160. function renderTreat(className,title, data) {
  161. const str = `<div class="recommendInfoWrapper ${className}">
  162. <h4><i></i>${title}${msg.diseaseName?'('+msg.diseaseName+')':''}</h4>
  163. <div class="recommendInfoBox clearfix ${className + 'box'}"></div>
  164. </div>`
  165. $('.recommendWrap').append(str)
  166. const commonTreatmentInfo = data.commonTreatment&&data.commonTreatment.content || ""
  167. const treatmentList = data.treatmentPlan || []
  168. renderTreatText('commonTreatment', '一般治疗', commonTreatmentInfo, className+'box')
  169. renderTreatDrug('drugTreatment', '推荐药物', treatmentList, className+'box')
  170. }
  171. function renderTreatText(className,title,data, parentNode) {
  172. const childrenNodeBoxStr = `
  173. <div class = "treatItemBox ${className + 'box'}">
  174. <p class="treatItemTitle">${title}</p>
  175. <p class="${className + 'Info'} clearfix"></p>
  176. </div>
  177. `
  178. $('.' + parentNode).append(childrenNodeBoxStr)
  179. if(!data) {
  180. data = '<span class="recommendNull">暂无推荐</span>'
  181. }
  182. $('.' + className+'Info').html(data)
  183. var commonTreatHeight = $(".commonTreatmentInfo").height()
  184. if(commonTreatHeight > 75){
  185. $(".commonTreatmentInfo").addClass('commonTreatmentInfoLimit').append('<span class="slideDown">更多 <i></i></span>')
  186. }
  187. $(".treatItemBox").on('click',".slideDown",function(){
  188. openNewWin(`treatplan.html?msg=${encodeURIComponent(JSON.stringify(msg))}`)
  189. })
  190. }
  191. function renderTreatDrug(className,title,data, parentNode) {
  192. const childrenNodeBoxStr = `
  193. <div class = "treatItemBox ${className + 'box'}">
  194. <p class="treatItemTitle">${title} ${data.length ==0 ?'':'<span class="slideDown">更多 <i></i></span>'}</p>
  195. <p class="${className + 'Info'}"></p>
  196. </div>
  197. `
  198. $('.' + parentNode).append(childrenNodeBoxStr)
  199. if(data.length ==0) {
  200. $('.' + className+'Info').append('<span class="recommendNull">暂无推荐</span>')
  201. }
  202. for(let i = 0; i < data.length; i++) {
  203. let childrenNodeStr =`<div class = "drugTreatmentInfoItemBox">
  204. <p class="diagTitle"><i></i>${data[i].title}</p>`
  205. //二级标题暂时不放
  206. // for(let j = 0; j < data[i].meditionDetails.length; j++) {
  207. // if(data[i].meditionDetails[j].description) {
  208. // childrenNodeStr += `<p class="diagDescription">${data[i].meditionDetails[j].description}</p>`
  209. // }
  210. // }
  211. childrenNodeStr +=`</div>`
  212. $('.' + className+'Info').append(childrenNodeStr)
  213. }
  214. $(".treatItemTitle").on('click',".slideDown",function(){
  215. openNewWin(`treatplan.html?msg=${encodeURIComponent(JSON.stringify(msg))}`)
  216. })
  217. // for(let i = 0; i < data.length; i++) {
  218. // let childrenNodeStr = `<p class="drugTreatmentInfoItemBox">
  219. // ${i+1}.${data[i].bigdrugsName}${data[i].subdrugsName&&"("+data[i].subdrugsName+")"}:`
  220. // for (let j = 0; j < data[i].medicitionsList.length; j++) {
  221. // childrenNodeStr += `<span class="durgNameBox ${(data[i].medicitionsList[j].forbidden == '2' ? 'medicineWaringDis' : '' )}"><span class="durgName">${data[i].medicitionsList[j].medicitionName}</span>`
  222. // if(data[i].medicitionsList[j].forbidden == '1') {
  223. // childrenNodeStr += `<span class="medicineWaring">慎用</span>`
  224. // } else if(data[i].medicitionsList[j].forbidden == '2') {
  225. // childrenNodeStr += `<span class="medicineWaringDisMsg">禁用</span>`
  226. // }
  227. // childrenNodeStr += `<span title="点击i图标可查看详细说明" class="infoMsg" data-name=${data[i].medicitionsList[j].medicitionName}></span>`
  228. // if(j !== data[i].medicitionsList.length-1) {
  229. // childrenNodeStr += ','
  230. // }
  231. // childrenNodeStr += '</span></span>'
  232. // //隐藏使用率
  233. // // childrenNodeStr += `<span class="${(data[i].medicitionsList[j].forbidden == '2' ? 'medicineWaringDis' : '' )}">使用率${data[i].medicitionsList[j].rate}</span>`
  234. // // if(j === data[i].medicitionsList.length-1) {
  235. // // childrenNodeStr += ';'
  236. // // } else {
  237. // // childrenNodeStr += ','
  238. // // }
  239. // }
  240. // childrenNodeStr += ` </p>`
  241. // $('.' + className+'Info').append(childrenNodeStr)
  242. // }
  243. // $('.' + className+'Info'+ ' .infoMsg').on('click', function(){
  244. // const infoMsgName = $(this).attr('data-name')
  245. // openNewWin(`information.html?type=8&position=5&name=${infoMsgName}`)
  246. // })
  247. // var treatList = $(".drugTreatmentInfo").find(".drugTreatmentInfoItemBox")
  248. // for(var h = 0;h < treatList.length;h++){
  249. // if($(treatList[h]).height() > 25){
  250. // $(treatList[h]).addClass('recommendInfoItemBoxLimit').append('<span class="slideDown">更多 <i></i></span>')
  251. // }
  252. // $(".drugTreatmentInfo").on('click',".slideDown",function(){
  253. // $(this).parents(".drugTreatmentInfoItemBox ").removeClass("recommendInfoItemBoxLimit").append('<span class="slideup">收起 <i></i></span>')
  254. // $(this).remove()
  255. // })
  256. // $(".drugTreatmentInfo").on('click',".slideup",function(){
  257. // $(this).parents(".drugTreatmentInfoItemBox ").addClass("recommendInfoItemBoxLimit").append('<span class="slideDown">更多 <i></i></span>')
  258. // $(this).remove()
  259. // })
  260. // }
  261. }
  262. function renderRecommendConditTips(className,title,data) {
  263. const str = `<div class="recommendInfoWrapper ${className}">
  264. <h4><i></i>${title}</h4>
  265. <div class="recommendInfoBox ${className + 'box'}"></div>
  266. </div>`
  267. $('.recommendWrap').append(str)
  268. if(data.length == 0) {
  269. $("."+className+"box").append('<span class="recommendNull">暂无推荐</span>')
  270. };
  271. //let names = [];
  272. for(var k = 0;k < data.length;k++){
  273. let tmpBq = data[k];
  274. let hasSritical = false
  275. let tmpBqStr;
  276. if(tmpBq.details) {
  277. for(let i = 0; i < tmpBq.details.length; i++) {
  278. if(tmpBq.details[i].type == 4) {
  279. hasSritical= true
  280. }
  281. }
  282. }
  283. if(hasSritical) {
  284. /*if(names.includes(tmpBq.name)){ //name相同去重
  285. tmpBqStr='';
  286. }else{
  287. names.push(tmpBq.name);*/
  288. tmpBqStr = `<p class="mayIllness">
  289. <span class="sriticalNameBox"><span class="sriticalName">${tmpBq.name}</span>
  290. </span>
  291. </span></p>`
  292. //}
  293. } else {
  294. tmpBqStr = `<p class="mayIllness">
  295. 患者可能有 <span class="diagNameBox"><span class="diagName">${tmpBq.name}:</span>
  296. <span title="点击该名称可看详细说明" class="infoMsg" data-name=${tmpBq.name}></span>
  297. </span>
  298. </span></p>`
  299. }
  300. var tmpBqDetailStr = ''
  301. for(var m = 0;m < tmpBq.details.length;m++){
  302. var tmpBqDetail = tmpBq.details[m]
  303. if(tmpBqDetail.type == 1){
  304. tmpBqDetailStr+=`<span data-scaleName=${tmpBqDetail.content.name} class="illnessTable">${tmpBqDetail.content.name}</span>`
  305. }
  306. if(tmpBqDetail.type == 2){
  307. var deepDetailName = `<div class="modalTitle">${tmpBqDetail.content.name}<i class="closeModal"></i></div>`
  308. var deepDetailStr = ''
  309. var deepDetailResultStr = ''
  310. for(var n = 0;n < tmpBqDetail.content.details.length;n++){
  311. var deepDetail = tmpBqDetail.content.details[n]
  312. if(deepDetail.controlType == 2){//0-radio,1-checkbox,2-text,3-dropdownlist
  313. if(deepDetail.isShow == 0) {
  314. deepDetailStr+=`<li class="radioCheck"><span class="modalMaintltle">${deepDetail.name}: </span>${deepDetail.value} ${deepDetail.uint}</li>`
  315. } else {
  316. deepDetailStr+=`<li class="radioCheck"><span class="modalMaintltle">请输入${deepDetail.name}: </span><input type="text" class="${tmpBqDetail.content.name+deepDetail.name}" ${deepDetail.isShow=='0' ? 'readonly':''} placeholder="请输入" value=${deepDetail.value}><i class="uint">${deepDetail.uint}</i></li>`
  317. }
  318. }
  319. if(deepDetail.controlType == 0){
  320. let tooDeepDetailStr = ''
  321. for(var f = 0;f<deepDetail.details.length;f++){
  322. var tooDeepDetail = deepDetail.details[f]
  323. if(deepDetail.isShow == '0'){
  324. if(tooDeepDetail.state == 1) {
  325. tooDeepDetailStr+='<li class="radioChecks" data-select="'+(tooDeepDetail.state == 1?"select":"")+'"><span>'+tooDeepDetail.detailName+'</span></li>'
  326. }
  327. }else{
  328. tooDeepDetailStr+='<li class="radioChecks"><i></i><span>'+tooDeepDetail.detailName+'</span>'+(tooDeepDetail.state == 1?"<a>(智能推荐)</a>":"")+'</li>'
  329. }
  330. }
  331. deepDetailStr+=`<li class="radioCheck"><span class="modalMaintltle">${deepDetail.name}: </span>
  332. <ul class="clearfix caculateLis" data-isShow = ${deepDetail.isShow}>
  333. ${tooDeepDetailStr}
  334. </ul>
  335. </li>`
  336. }
  337. }
  338. for(var v = 0;v < tmpBqDetail.content.result.length;v++){
  339. deepDetailResultStr+='<p class="result"><span class="calculateName">'+tmpBqDetail.content.result[v].name+':</span><span class="calculateResult"></span></p>'
  340. }
  341. tmpBqDetailStr+=`<div class="mayResult">
  342. 计算公式结果:
  343. <span class="mayResultSelect" data-num="${k}">
  344. <span class="makesureResult">请选择</span>
  345. <span class="sanjiao"></span>
  346. <div class="popupModal">
  347. ${deepDetailName}
  348. <div class="modalMainTwo">
  349. <ul class="clearfix">
  350. ${deepDetailStr}
  351. </ul>
  352. <div class="calculate" data-num="${k}">计算</div>
  353. <p class="calculateError">请填写计算公式内容</p>
  354. <div class="resultLis">
  355. ${deepDetailResultStr}
  356. </div>
  357. </div>
  358. <div class="btnWrap clearfix">
  359. <div class="sureScore" data-type="2">关闭</div>
  360. </div>
  361. </div>
  362. </span>
  363. </div>`
  364. }
  365. if(tmpBqDetail.type == 3){
  366. var deepDetailName = '<span class="modalMaintltle">'+tmpBqDetail.content.name+': </span>'
  367. var deepDetailStr = ''
  368. for(var n = 0;n < tmpBqDetail.content.details.length;n++){
  369. var deepDetail = tmpBqDetail.content.details[n]
  370. deepDetailStr+='<li class="radioChecks"><i></i><span>'+deepDetail.detailName+'</span>'+(deepDetail.state == 1?"<a>(智能推荐)</a>":"")+'</li>'
  371. }
  372. tmpBqDetailStr+=`<div class="mayResult">
  373. 可能结果:
  374. <span class="mayResultSelect" data-num="${k}"><span class="makesureResult">请选择</span><i class="sanjiao"></i>
  375. <div class="popupModal">
  376. <div class="modalTitle">
  377. 结果选择<i class="closeModal"></i>
  378. </div>
  379. <div class="modalMainOne">
  380. ${deepDetailName}
  381. <ul class="clearfix">
  382. ${deepDetailStr}
  383. </ul>
  384. </div>
  385. <div class="btnWrap clearfix">
  386. <div class="sureScore" data-type="3" data-num="${k}">确定</div>
  387. </div>
  388. </div>
  389. </span>
  390. </div>`
  391. }
  392. if(tmpBqDetail.type == 4){
  393. // tmpBqDetailStr+=`<div class="sriticalinfo">诊断要点:${tmpBqDetail.content.name}</div>`
  394. }
  395. }
  396. if(tmpBqStr != '' || tmpBqDetailStr != ''){
  397. $(".conditionHintTipsNull").css("display","none")
  398. }
  399. // $(".conditionHintTips").append('<div class="conditionMain clearfix">'+tmpBqStr+'<div class="alertModal">'+tmpBqDetailStr+'</div></div>')
  400. $("."+className+"box").append('<div class="conditionMain clearfix">'+tmpBqStr+'<div class="alertModal">'+tmpBqDetailStr+'</div></div>')
  401. }
  402. $('.mayIllness .infoMsg').on('click', function(){
  403. const infoMsgName = $(this).attr('data-name')
  404. openNewWin(`information.html?type=22&position=2&name=${infoMsgName}`)
  405. })
  406. $('.alertModal .illnessTable').on('click', function(){
  407. const msg1 = JSON.parse(JSON.stringify(msg))
  408. msg1.scaleName = $(this).attr('data-scaleName')
  409. msg1.featureType = 21
  410. openNewWin(`scale.html?msg=${encodeURIComponent(JSON.stringify(msg1))}`)
  411. })
  412. bindTipsEvent()
  413. }
  414. function slideToggle(domName,childrenNodeStrShort,childrenNodeStrLong){//展开收起
  415. domName.append('<span class="slideDown">更多 <i></i></span>')
  416. domName.on('click',".slideDown",function(){
  417. domName.html(childrenNodeStrLong)
  418. domName.append('<span class="slideup">收起 <i></i></span>')
  419. $(this).remove()
  420. })
  421. domName.on('click',".slideup",function(){
  422. domName.html(childrenNodeStrShort)
  423. domName.append('<span class="slideDown">更多 <i></i></span>')
  424. $(this).remove()
  425. })
  426. }
  427. module.exports = {
  428. renderRecommendInfo,
  429. renderMultRecommendInfo,
  430. renderTreat,
  431. renderRecommendConditTips,
  432. renderTipsInfo,
  433. renderKnowledgeInfo,
  434. renderScaleInfo
  435. }