indexHorizontalDom.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443
  1. const $ = require("jquery");
  2. const { openNewWin, imageUrlPrefix, isIe8 } = require('./promise.js');
  3. const { bindTipsEvent } = require('./popupEdit.js');
  4. let showImg = require('./../images/show.png')
  5. let collapseImg = require('./../images/collapse.png')
  6. const is8Ie = isIe8() //判断是否为IE8
  7. if(is8Ie) {
  8. let reg = /undefined/g
  9. showImg = showImg.replace(reg, '')
  10. collapseImg = collapseImg.replace(reg, '')
  11. }
  12. //推荐诊断等单种类型的
  13. function renderRecommendInfo(showNum, icon, className,title,data, hasInfo, type, position) {
  14. let showNumCopy = showNum || 5
  15. const dataLen = data.length
  16. const str = `<div class="recommendInfoWrapper ${className} clearfix">
  17. <h4><img src=${icon} title="${title}" class="icon">${title}:</h4>
  18. <div class="recommendInfoBox">
  19. <div class="clearfix recommendInfoItemBox ${className + 'box'}">
  20. </div>
  21. </div>
  22. </div>`
  23. $('.push').append(str)
  24. let dataShort
  25. if(showNumCopy&& dataLen > showNumCopy) {
  26. dataShort = data.slice(0, showNumCopy)
  27. } else {
  28. dataShort = data
  29. }
  30. let childrenNodeStrShort = ''
  31. let childrenNodeStrLong = ''
  32. if(hasInfo) {
  33. for (let i = 0; i < dataShort.length; i++) {
  34. childrenNodeStrShort += `<span class="recommendInfoItem recommendInfoItemHasInfo">
  35. ${data[i].name}
  36. <span title="点击i图标可查看详细说明" class="infoMsg" data-name=${data[i].name}></span>
  37. </span>`
  38. }
  39. for (let i = 0; i < data.length; i++) {
  40. childrenNodeStrLong += `<span class="recommendInfoItem recommendInfoItemHasInfo">
  41. ${data[i].name}
  42. <span title="点击i图标可查看详细说明" class="infoMsg" data-name=${data[i].name}></span>
  43. </span>`
  44. }
  45. } else {
  46. for (let i = 0; i < dataShort.length; i++) {
  47. childrenNodeStrShort += `<span class="recommendInfoItem" data-name="${data[i].name}">
  48. ${data[i].name}
  49. </span>`
  50. }
  51. for (let i = 0; i < data.length; i++) {
  52. childrenNodeStrLong += `<span class="recommendInfoItem" data-name="${data[i].name}">
  53. ${data[i].name}
  54. </span>`
  55. }
  56. }
  57. if(!childrenNodeStrShort) {
  58. childrenNodeStrShort = '<span class ="recommendNull">暂无推荐</span>'
  59. }
  60. $('.'+className + 'box').append(childrenNodeStrShort)
  61. let childrenNodeStrAll = `<div class="${className+'boxAll'} itemAllBox">
  62. <h4>${title}:</h4>
  63. <div class="itemAll">
  64. ${childrenNodeStrLong}
  65. </div>
  66. <span class="slideup"><img src="${collapseImg}"></span>
  67. </div>`
  68. $('.push').append(childrenNodeStrAll)
  69. $('.'+className + 'box' +' .infoMsg').on('click', function(){
  70. const infoMsgName = $(this).attr('data-name')
  71. openNewWin(`information.html?type=${type}&position=${position}&name=${infoMsgName}`)
  72. })
  73. $('.'+className + 'boxAll' +' .infoMsg').on('click', function(){
  74. const infoMsgName = $(this).attr('data-name')
  75. openNewWin(`information.html?type=${type}&position=${position}&name=${infoMsgName}`)
  76. })
  77. slideToggle("."+className+"box", showNumCopy, dataLen)
  78. }
  79. //化验和辅检等多种类型
  80. function renderMultRecommendInfo(labsAndPacMode,icon, className,title,data, hasInfo, type, position) {
  81. const str = `<div class="recommendInfoWrapper ${className} clearfix">
  82. <h4 class ="${+labsAndPacMode === 1 ? 'showTopTitle':'showRightTitle'}"><img src=${icon} title="${title}" class="icon">${title}:</h4>
  83. <div class="recommendInfoBox ${className + 'box'} ${+labsAndPacMode === 1 ? 'showTopInfo':'showRightInfo'}"></div>
  84. </div>`
  85. $('.push').append(str)
  86. let hanContentNum = 0
  87. for(let i = 0; i < data.length; i++) {
  88. if(data[i].data === 0) {
  89. continue
  90. }
  91. const showNum = data[i].showNum || 5
  92. const dataLen = data[i].data.length
  93. if(dataLen === 0) {
  94. continue
  95. }
  96. let childrenNodeBoxStr = `<div class="labAndPacsWrapper ${data[i].className+'wrapper'}">
  97. <div class="labAndPacsBox ${data[i].className+'box'} clearfix">
  98. </div>
  99. </div>`
  100. let childrenNodeStr = `<span class="labAndPacsTitle ${+labsAndPacMode === 1 ? 'topSmallTitle':'rightSmallTitle'}"">${data[i].title}<i></i></span>`
  101. let childrenNodeItemStrAll = '' //更多展开框中的字符串
  102. let dataShort
  103. if(showNum&& dataLen > showNum) {
  104. dataShort = data[i].data.slice(0, showNum)
  105. } else {
  106. dataShort = data[i].data
  107. }
  108. for(let j = 0; j < dataShort.length; j++) {
  109. childrenNodeStr += `<span class="labAndPacsItem">${dataShort[j].name}</span>`
  110. }
  111. for(let j = 0; j < data[i].data.length; j++) {
  112. childrenNodeItemStrAll += `<span class="labAndPacsItem">${data[i].data[j].name}</span>`
  113. }
  114. if(data[i].data.length == 0) {
  115. childrenNodeStr +='<span class="recommendNull">暂无推荐</span>'
  116. }
  117. $('.'+className + 'box').append(childrenNodeBoxStr)
  118. $('.'+data[i].className+'box').append(childrenNodeStr)
  119. let childrenNodeStrAll = `<div class="${data[i].className+'boxAll'} itemAllBox">
  120. <h4>${data[i].title}:</h4>
  121. <div class="itemAll">
  122. ${childrenNodeItemStrAll}
  123. <span class="slideup"><img src="${collapseImg}"></span>
  124. </div>
  125. </div>`
  126. $('.push').append(childrenNodeStrAll)
  127. slideToggle("."+data[i].className+"box", showNum, dataLen)
  128. }
  129. }
  130. function renderTreat(icon, className,title, data) {
  131. $('.infoTabBox').append(`<span class="infoTab treatTab boldFont" data-box="${className}">${title}</span>`)
  132. const str = `<div class="informationBox recommendInfoWrapper ${className} clearfix">
  133. <p class="diagName boldFont">${msg.diseaseName.uniqueName?msg.diseaseName.uniqueName:''}</p>
  134. <div class="recommendInfoBox clearfix ${className + 'box'}"></div>
  135. </div>`
  136. $('.infomationBox').append(str)
  137. const commonTreatmentInfo = data.commonTreatment&&data.commonTreatment.content || ""
  138. const treatmentList = data.treatmentPlan || []
  139. renderTreatText('commonTreatment', '一般治疗', commonTreatmentInfo, className+'box')
  140. renderTreatDrug('drugTreatment', '推荐药物', treatmentList, className+'box')
  141. }
  142. function renderKnowledgeInfo(icon, className,title, data) {
  143. $('.infoTabBox').append(`<span class="infoTab tipsTab boldFont" data-box="${className}">${title}</span>`)
  144. const str = `<div class="informationBox staticWin recommendInfoWrapper ${className} clearfix">
  145. <p class="diagName">${data}</p>
  146. </div>`
  147. $('.infomationBox').append(str)
  148. $('.'+className+'.staticWin' ).on('click', function(){
  149. openNewWin(`staticSearch.html?msg=${encodeURIComponent(JSON.stringify(msg))}`)
  150. })
  151. }
  152. function renderScaleInfo(icon, className,title, data) {
  153. $('.infoTabBox').append(`<span class="infoTab tipsTab boldFont" data-box="${className}">${title}</span>`)
  154. const str = `<div class="informationBox staticWin recommendInfoWrapper ${className} clearfix">
  155. <p class="diagName">${data}</p>
  156. </div>`
  157. $('.infomationBox').append(str)
  158. $('.'+className+'.staticWin' ).on('click', function(){
  159. openNewWin(`staticSearch.html?msg=${encodeURIComponent(JSON.stringify(msg))}`)
  160. })
  161. }
  162. function renderTreatText(className,title,data, parentNode) {
  163. const childrenNodeBoxStr = `
  164. <div class = "treatItemBox ${className + 'box'} disCopy">
  165. <p class="treatItemTitle">${title}:</p>
  166. <div class="treatTextBox">
  167. <p class="${className + 'Info'} clearfix"></p>
  168. </div>
  169. </div>
  170. `
  171. $('.' + parentNode).append(childrenNodeBoxStr)
  172. if(!data) {
  173. data = '<span class="recommendNull">暂无推荐</span>'
  174. }
  175. $('.' + className+'Info').html(data)
  176. var commonTreatHeight = $(".commonTreatmentInfo").height()
  177. if(commonTreatHeight > 75){
  178. $(".treatTextBox").append('<span class="more">更多</span>')
  179. }
  180. $(".infomationBox .treatTextBox").on('click',".more",function(){
  181. openNewWin(`treatplan.html?msg=${encodeURIComponent(JSON.stringify(msg))}`)
  182. })
  183. $('.' + className + 'box' + ' img').bind('contextmenu', function(){
  184. return false
  185. })
  186. }
  187. function renderTreatDrug(className,title,data, parentNode) {
  188. const childrenNodeBoxStr = `
  189. <div class = "treatItemBox ${className + 'box'}">
  190. <p class="treatItemTitle">${title}: ${data.length ==0 ? '':'<span class="more">更多</span>'}</p>
  191. <div class="treatDrugBox">
  192. <p class="${className + 'Info'}"></p>
  193. </div>
  194. </div>
  195. `
  196. $('.' + parentNode).append(childrenNodeBoxStr)
  197. if(data.length ==0) {
  198. $('.' + className+'Info').append('<span class="recommendNull">暂无推荐</span>')
  199. }
  200. for(let i = 0; i < data.length; i++) {
  201. let childrenNodeStr =`<div class = "drugTreatmentInfoItemBox">
  202. <p class="diagTitle ellipsis"><i></i>${data[i].title}</p>`
  203. //二级标题暂时不放
  204. // for(let j = 0; j < data[i].meditionDetails.length; j++) {
  205. // if(data[i].meditionDetails[j].description) {
  206. // childrenNodeStr += `<p class="diaDescription">${data[i].meditionDetails[j].description}</p>`
  207. // }
  208. // }
  209. childrenNodeStr +=`</div>`
  210. $('.' + className+'Info').append(childrenNodeStr)
  211. }
  212. // for(let i = 0; i < data.length; i++) {
  213. // let childrenNodeStr = `<p class="drugTreatmentInfoItemBox">
  214. // ${i+1}.${data[i].bigdrugsName}${data[i].subdrugsName&&"("+data[i].subdrugsName+")"}:`
  215. // for (let j = 0; j < data[i].medicitionsList.length; j++) {
  216. // childrenNodeStr += `<span class="durgNameBox ${(data[i].medicitionsList[j].forbidden == '2' ? 'medicineWaringDis' : '' )}">${data[i].medicitionsList[j].medicitionName}`
  217. // if(data[i].medicitionsList[j].forbidden == '1') {
  218. // childrenNodeStr += `<span class="medicineWaring">慎用</span>`
  219. // } else if(data[i].medicitionsList[j].forbidden == '2') {
  220. // childrenNodeStr += `<span class="medicineWaringDisMsg">禁用</span>`
  221. // }
  222. // childrenNodeStr += `<span title="点击i图标可查看详细说明" class="infoMsg" data-name=${data[i].medicitionsList[j].medicitionName}></span>`
  223. // if(j !== data[i].medicitionsList.length-1) {
  224. // childrenNodeStr += ','
  225. // }
  226. // childrenNodeStr += '</span></span>'
  227. // // childrenNodeStr += `<span class="${(data[i].medicitionsList[j].forbidden == '2' ? 'medicineWaringDis' : '' )}">使用率${data[i].medicitionsList[j].rate}</span>`
  228. // // if(j === data[i].medicitionsList.length-1) {
  229. // // childrenNodeStr += ';'
  230. // // } else {
  231. // // childrenNodeStr += ','
  232. // // }
  233. // }
  234. // childrenNodeStr += ` </p>`
  235. // $('.' + className+'Info').append(childrenNodeStr)
  236. // }
  237. // $('.' + className+'Info'+ ' .infoMsg').on('click', function(){
  238. // const infoMsgName = $(this).attr('data-name')
  239. // openNewWin(`information.html?type=8&position=5&name=${infoMsgName}`)
  240. // })
  241. // var drugTreatmentHeight = $(".drugTreatmentInfo").height()
  242. // if(drugTreatmentHeight > 75){
  243. // $(".treatDrugBox").append('<span class="more">更多</span>')
  244. // } else if(drugTreatmentHeight > 30) {
  245. // $(".drugTreatmentInfo").append('<span class="more">更多</span>')
  246. // }
  247. $(".infomationBox .drugTreatmentbox").on('click',".more",function(){
  248. openNewWin(`treatplan.html?msg=${encodeURIComponent(JSON.stringify(msg))}`)
  249. // openNewWin(`treatplan.html?age=${msg.age}&sex=${msg.sex}&symptomJson=${msg.symptom}&vitalJson=${msg.vital}&lisJson=${msg.lis}&pacsJson=${msg.pacs}&diseaseName=${msg.diseaseName}&diagJson=${msg.diag}&otherJson=${msg.other}&hospitalCode=${msg.hosCode}`)
  250. })
  251. var treatList = $(".drugTreatmentInfo").find(".drugTreatmentInfoItemBox")
  252. // for(var h = 0;h < treatList.length;h++){
  253. // if($(treatList[h]).height() > 25){
  254. // $(treatList[h]).addClass('recommendInfoItemBoxLimit').append('<span class="slideDown">更多 <i></i></span>')
  255. // }
  256. // $(".drugTreatmentInfo").on('click',".slideDown",function(){
  257. // $(this).parents(".drugTreatmentInfoItemBox ").removeClass("recommendInfoItemBoxLimit").append('<span class="slideup">收起 <i></i></span>')
  258. // $(this).remove()
  259. // })
  260. // $(".drugTreatmentInfo").on('click',".slideup",function(){
  261. // $(this).parents(".drugTreatmentInfoItemBox ").addClass("recommendInfoItemBoxLimit").append('<span class="slideDown">更多 <i></i></span>')
  262. // $(this).remove()
  263. // })
  264. // }
  265. }
  266. function renderTipsInfo(icon, className,title,data) {
  267. $('.infoTabBox').append(`<span class="infoTab tipsTab boldFont" data-box="${className}">${title}</span>`)
  268. let str
  269. if(data.length === 0) {
  270. str = `<div class="informationBox tipsInfoWrapper ${className} clearfix">
  271. <p class="diagName recommendNull">暂无数据</p>
  272. <div class="tipsInfoBox clearfix ${className + 'box'} disCopy"></div>
  273. </div>`
  274. } else {
  275. str = `<div class="informationBox tipsInfoWrapper ${className} clearfix">
  276. <div class="tipsInfoBox clearfix ${className + 'box'} disCopy">
  277. </div>
  278. </div>`
  279. }
  280. $('.infomationBox').append(str)
  281. for(let i = 0; i < data.length; i++) {
  282. renderTipsInfoText('','诊断依据',data[i],className + 'box')
  283. }
  284. $('.' + className + 'box' + ' img').bind('contextmenu', function(){
  285. return false
  286. })
  287. // if(data.name) {
  288. // renderTipsInfoText('','诊断依据',data.details,className + 'box')
  289. // }
  290. if(data.length > 1) {
  291. $('.tipsInfoItem').each(function(i, obj){
  292. var lineHeight = parseInt($(this).css("line-height"));
  293. var height = parseInt($(this).height());
  294. if((height / lineHeight) >3 ){
  295. $(this).addClass("hasMore")
  296. $(this).css("height","60px");
  297. }else{
  298. $(this).removeClass("hasMore");
  299. }
  300. });
  301. }
  302. }
  303. function renderTipsInfoText(className,title,data, parentNode) {
  304. let childrenNodeBoxStr = `<p class="diagName boldFont">${data.name} <span class="moreInfo" data-name="${data.name}" data-type="${data.type}">详情</span></p>`
  305. if(data.details.length === 0) {
  306. childrenNodeBoxStr += `<p class="recommendNull">暂无数据</p>
  307. `
  308. } else {
  309. for(let i = 0; i < data.details.length; i++) {
  310. childrenNodeBoxStr += `<div class="tipsInfoItem">
  311. <p class="tipsInfoItemTitle">${data.details[i].title}</p>
  312. ${data.details[i].content.replace(/{imageUrlPrefix}/g, imageUrlPrefix)}
  313. </div>
  314. `
  315. }
  316. }
  317. $('.' + parentNode).append(childrenNodeBoxStr)
  318. }
  319. function renderRecommendConditTips(icon, className,title,data) {
  320. const str = `<div class="recommendInfoWrapper ${className} clearfix">
  321. <h4><img src=${icon} title="${title}" class="icon">${title}:</h4>
  322. <div class="recommendInfoBox ${className + 'box'}"></div>
  323. </div>`
  324. $('.push').append(str)
  325. if(data.length == 0) {
  326. $("."+className+"box").append('<span class="recommendNull">暂无推荐</span>')
  327. }
  328. /*let names = [];*/
  329. for(var k = 0;k < data.length;k++){
  330. var tmpBq = data[k];
  331. let hasSritical = false
  332. let tmpBqStr;
  333. if(tmpBq.details) {
  334. for(let i = 0; i < tmpBq.details.length; i++) {
  335. if(tmpBq.details[i].type == 4) {
  336. hasSritical= true
  337. }
  338. }
  339. }
  340. if(hasSritical) {
  341. /*if(names.includes(tmpBq.name)){ //name相同去重
  342. tmpBqStr='';
  343. }else{
  344. names.push(tmpBq.name);*/
  345. tmpBqStr = `<p class="mayIllness">
  346. <span class="sriticalNameBox"><span class="sriticalName">${tmpBq.name}</span>
  347. </span>
  348. </span></p>`
  349. // }
  350. } else {
  351. tmpBqStr = `<p class="mayIllness">
  352. 患者可能有 <span class="diagNameBox"><span class="diagName">${tmpBq.name}:</span>
  353. <span title="点击该名称可看详细说明" class="infoMsg" data-name=${tmpBq.name}></span>
  354. </span>
  355. </span></p>`
  356. }
  357. var tmpBqDetailStr = ''
  358. for(var m = 0;m < tmpBq.details.length;m++){
  359. var tmpBqDetail = tmpBq.details[m]
  360. if(tmpBqDetail.type == 1){
  361. tmpBqDetailStr+=`<span data-scaleName=${tmpBqDetail.content.name} class="illnessTable">【${tmpBqDetail.content.name}】</span>`
  362. }
  363. if(tmpBqDetail.type == 4){
  364. // tmpBqDetailStr+=`<span class="sriticalinfo">&nbsp;${tmpBqDetail.content.name}(诊断要点)</span>`
  365. }
  366. }
  367. /*if(tmpBqStr){*/
  368. $("."+className+"box").append('<div class="conditionMain ellipse clearfix">'+tmpBqStr+'<div class="alertModal">'+tmpBqDetailStr+'</div><span class="more">更多</span></div>')
  369. //}
  370. //$("."+className+"box").append('<div class="conditionMain ellipse clearfix">'+tmpBqStr+'<div class="alertModal">'+tmpBqDetailStr+'</div><span class="more">更多</span></div>')
  371. }
  372. $('.mayIllness .infoMsg').on('click', function(){
  373. const infoMsgName = $(this).attr('data-name')
  374. openNewWin(`information.html?type=22&position=2&name=${infoMsgName}`)
  375. })
  376. $('.alertModal .illnessTable').on('click', function(){
  377. const msg1 = JSON.parse(JSON.stringify(msg))
  378. msg1.scaleName = $(this).attr('data-scaleName')
  379. msg1.featureType = 21
  380. openNewWin(`scale.html?msg=${encodeURIComponent(JSON.stringify(msg1))}`)
  381. })
  382. $(".conditTipsbox").on('click',".more",function(){
  383. // openNewWin(`illness.html?age=${msg.age}&sex=${msg.sex}&symptomJson=${msg.symptom}&vitalJson=${msg.vital}&lisJson=${JSON.stringify(msg.lis)}&pacsJson=${msg.pacs}&diagJson=${msg.diag}&diseaseName=${msg.diseaseName}&otherJson=${msg.other}&hospitalCode=${msg.hosCode}&msg=${JSON.stringify(msg)}`)
  384. openNewWin(`illness.html?msg=${encodeURIComponent(JSON.stringify(msg))}`)
  385. })
  386. bindTipsEvent()
  387. }
  388. function slideToggle(className, showNum, dataLen){//展开收起
  389. const domName = $(className)
  390. const domNameBoxAll = $(className+'All')
  391. setTimeout(() => {
  392. if(showNum < dataLen){
  393. domName.append(`<span class="slideDown"><img src="${showImg}"></span>`)
  394. }
  395. });
  396. domName.on('click',".slideDown",function(){
  397. $(".itemAllBox").css('display', 'none')
  398. $(domNameBoxAll).css('display', 'block')
  399. })
  400. domNameBoxAll.on('click',".slideup",function(){
  401. $(domNameBoxAll).css('display', 'none')
  402. })
  403. }
  404. //打开免责申明
  405. $(".disclaimer .logo").on("click",function() {
  406. openNewWin("disclaimer.html");
  407. });
  408. module.exports = {
  409. renderRecommendInfo,
  410. renderMultRecommendInfo,
  411. renderTreat,
  412. renderRecommendConditTips,
  413. renderTipsInfo,
  414. renderKnowledgeInfo,
  415. renderScaleInfo
  416. }