indexVertDom.js 21 KB

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