indexHorizontalDom.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437
  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?msg.diseaseName:''}</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?type=1`)
  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?type=2&msg=${encodeURIComponent(JSON.stringify(msg))}`)
  160. })
  161. }
  162. function renderTreatText(className,title,data, parentNode) {
  163. const childrenNodeBoxStr = `
  164. <div class = "treatItemBox ${className + 'box'}">
  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. }
  184. function renderTreatDrug(className,title,data, parentNode) {
  185. const childrenNodeBoxStr = `
  186. <div class = "treatItemBox ${className + 'box'}">
  187. <p class="treatItemTitle">${title}: ${data.length ==0 ? '':'<span class="more">更多</span>'}</p>
  188. <div class="treatDrugBox">
  189. <p class="${className + 'Info'}"></p>
  190. </div>
  191. </div>
  192. `
  193. $('.' + parentNode).append(childrenNodeBoxStr)
  194. if(data.length ==0) {
  195. $('.' + className+'Info').append('<span class="recommendNull">暂无推荐</span>')
  196. }
  197. for(let i = 0; i < data.length; i++) {
  198. let childrenNodeStr =`<div class = "drugTreatmentInfoItemBox">
  199. <p class="diagTitle ellipsis"><i></i>${data[i].title}</p>`
  200. //二级标题暂时不放
  201. // for(let j = 0; j < data[i].meditionDetails.length; j++) {
  202. // if(data[i].meditionDetails[j].description) {
  203. // childrenNodeStr += `<p class="diaDescription">${data[i].meditionDetails[j].description}</p>`
  204. // }
  205. // }
  206. childrenNodeStr +=`</div>`
  207. $('.' + className+'Info').append(childrenNodeStr)
  208. }
  209. // for(let i = 0; i < data.length; i++) {
  210. // let childrenNodeStr = `<p class="drugTreatmentInfoItemBox">
  211. // ${i+1}.${data[i].bigdrugsName}${data[i].subdrugsName&&"("+data[i].subdrugsName+")"}:`
  212. // for (let j = 0; j < data[i].medicitionsList.length; j++) {
  213. // childrenNodeStr += `<span class="durgNameBox ${(data[i].medicitionsList[j].forbidden == '2' ? 'medicineWaringDis' : '' )}">${data[i].medicitionsList[j].medicitionName}`
  214. // if(data[i].medicitionsList[j].forbidden == '1') {
  215. // childrenNodeStr += `<span class="medicineWaring">慎用</span>`
  216. // } else if(data[i].medicitionsList[j].forbidden == '2') {
  217. // childrenNodeStr += `<span class="medicineWaringDisMsg">禁用</span>`
  218. // }
  219. // childrenNodeStr += `<span title="点击i图标可查看详细说明" class="infoMsg" data-name=${data[i].medicitionsList[j].medicitionName}></span>`
  220. // if(j !== data[i].medicitionsList.length-1) {
  221. // childrenNodeStr += ','
  222. // }
  223. // childrenNodeStr += '</span></span>'
  224. // // childrenNodeStr += `<span class="${(data[i].medicitionsList[j].forbidden == '2' ? 'medicineWaringDis' : '' )}">使用率${data[i].medicitionsList[j].rate}</span>`
  225. // // if(j === data[i].medicitionsList.length-1) {
  226. // // childrenNodeStr += ';'
  227. // // } else {
  228. // // childrenNodeStr += ','
  229. // // }
  230. // }
  231. // childrenNodeStr += ` </p>`
  232. // $('.' + className+'Info').append(childrenNodeStr)
  233. // }
  234. // $('.' + className+'Info'+ ' .infoMsg').on('click', function(){
  235. // const infoMsgName = $(this).attr('data-name')
  236. // openNewWin(`information.html?type=8&position=5&name=${infoMsgName}`)
  237. // })
  238. // var drugTreatmentHeight = $(".drugTreatmentInfo").height()
  239. // if(drugTreatmentHeight > 75){
  240. // $(".treatDrugBox").append('<span class="more">更多</span>')
  241. // } else if(drugTreatmentHeight > 30) {
  242. // $(".drugTreatmentInfo").append('<span class="more">更多</span>')
  243. // }
  244. $(".infomationBox .drugTreatmentbox").on('click',".more",function(){
  245. openNewWin(`treatplan.html?msg=${encodeURIComponent(JSON.stringify(msg))}`)
  246. // 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}`)
  247. })
  248. var treatList = $(".drugTreatmentInfo").find(".drugTreatmentInfoItemBox")
  249. // for(var h = 0;h < treatList.length;h++){
  250. // if($(treatList[h]).height() > 25){
  251. // $(treatList[h]).addClass('recommendInfoItemBoxLimit').append('<span class="slideDown">更多 <i></i></span>')
  252. // }
  253. // $(".drugTreatmentInfo").on('click',".slideDown",function(){
  254. // $(this).parents(".drugTreatmentInfoItemBox ").removeClass("recommendInfoItemBoxLimit").append('<span class="slideup">收起 <i></i></span>')
  255. // $(this).remove()
  256. // })
  257. // $(".drugTreatmentInfo").on('click',".slideup",function(){
  258. // $(this).parents(".drugTreatmentInfoItemBox ").addClass("recommendInfoItemBoxLimit").append('<span class="slideDown">更多 <i></i></span>')
  259. // $(this).remove()
  260. // })
  261. // }
  262. }
  263. function renderTipsInfo(icon, className,title,data) {
  264. $('.infoTabBox').append(`<span class="infoTab tipsTab boldFont" data-box="${className}">${title}</span>`)
  265. let str
  266. if(data.length === 0) {
  267. str = `<div class="informationBox tipsInfoWrapper ${className} clearfix">
  268. <p class="diagName recommendNull">暂无数据</p>
  269. <div class="tipsInfoBox clearfix ${className + 'box'}"></div>
  270. </div>`
  271. } else {
  272. str = `<div class="informationBox tipsInfoWrapper ${className} clearfix">
  273. <div class="tipsInfoBox clearfix ${className + 'box'}">
  274. </div>
  275. </div>`
  276. }
  277. $('.infomationBox').append(str)
  278. for(let i = 0; i < data.length; i++) {
  279. renderTipsInfoText('','诊断依据',data[i],className + 'box')
  280. }
  281. // if(data.name) {
  282. // renderTipsInfoText('','诊断依据',data.details,className + 'box')
  283. // }
  284. if(data.length > 1) {
  285. $('.tipsInfoItem').each(function(i, obj){
  286. var lineHeight = parseInt($(this).css("line-height"));
  287. var height = parseInt($(this).height());
  288. if((height / lineHeight) >3 ){
  289. $(this).addClass("hasMore")
  290. $(this).css("height","60px");
  291. }else{
  292. $(this).removeClass("hasMore");
  293. }
  294. });
  295. }
  296. }
  297. function renderTipsInfoText(className,title,data, parentNode) {
  298. let childrenNodeBoxStr = `<p class="diagName boldFont">${data.name} <span class="moreInfo" data-name="${data.name}" data-type="${data.type}">详情</span></p>`
  299. if(data.details.length === 0) {
  300. childrenNodeBoxStr += `<p class="recommendNull">暂无数据</p>
  301. `
  302. } else {
  303. for(let i = 0; i < data.details.length; i++) {
  304. childrenNodeBoxStr += `<div class="tipsInfoItem">
  305. <p class="tipsInfoItemTitle">${data.details[i].title}</p>
  306. ${data.details[i].content.replace(/{imageUrlPrefix}/g, imageUrlPrefix)}
  307. </div>
  308. `
  309. }
  310. }
  311. $('.' + parentNode).append(childrenNodeBoxStr)
  312. }
  313. function renderRecommendConditTips(icon, className,title,data) {
  314. const str = `<div class="recommendInfoWrapper ${className} clearfix">
  315. <h4><img src=${icon} title="${title}" class="icon">${title}:</h4>
  316. <div class="recommendInfoBox ${className + 'box'}"></div>
  317. </div>`
  318. $('.push').append(str)
  319. if(data.length == 0) {
  320. $("."+className+"box").append('<span class="recommendNull">暂无推荐</span>')
  321. }
  322. /*let names = [];*/
  323. for(var k = 0;k < data.length;k++){
  324. var tmpBq = data[k];
  325. let hasSritical = false
  326. let tmpBqStr;
  327. if(tmpBq.details) {
  328. for(let i = 0; i < tmpBq.details.length; i++) {
  329. if(tmpBq.details[i].type == 4) {
  330. hasSritical= true
  331. }
  332. }
  333. }
  334. if(hasSritical) {
  335. /*if(names.includes(tmpBq.name)){ //name相同去重
  336. tmpBqStr='';
  337. }else{
  338. names.push(tmpBq.name);*/
  339. tmpBqStr = `<p class="mayIllness">
  340. <span class="sriticalNameBox"><span class="sriticalName">${tmpBq.name}</span>
  341. </span>
  342. </span></p>`
  343. // }
  344. } else {
  345. tmpBqStr = `<p class="mayIllness">
  346. 患者可能有 <span class="diagNameBox"><span class="diagName">${tmpBq.name}:</span>
  347. <span title="点击该名称可看详细说明" class="infoMsg" data-name=${tmpBq.name}></span>
  348. </span>
  349. </span></p>`
  350. }
  351. var tmpBqDetailStr = ''
  352. for(var m = 0;m < tmpBq.details.length;m++){
  353. var tmpBqDetail = tmpBq.details[m]
  354. if(tmpBqDetail.type == 1){
  355. tmpBqDetailStr+=`<span data-scaleName=${tmpBqDetail.content.name} class="illnessTable">【${tmpBqDetail.content.name}】</span>`
  356. }
  357. if(tmpBqDetail.type == 4){
  358. // tmpBqDetailStr+=`<span class="sriticalinfo">&nbsp;${tmpBqDetail.content.name}(诊断要点)</span>`
  359. }
  360. }
  361. /*if(tmpBqStr){*/
  362. $("."+className+"box").append('<div class="conditionMain ellipse clearfix">'+tmpBqStr+'<div class="alertModal">'+tmpBqDetailStr+'</div><span class="more">更多</span></div>')
  363. //}
  364. //$("."+className+"box").append('<div class="conditionMain ellipse clearfix">'+tmpBqStr+'<div class="alertModal">'+tmpBqDetailStr+'</div><span class="more">更多</span></div>')
  365. }
  366. $('.mayIllness .infoMsg').on('click', function(){
  367. const infoMsgName = $(this).attr('data-name')
  368. openNewWin(`information.html?type=22&position=2&name=${infoMsgName}`)
  369. })
  370. $('.alertModal .illnessTable').on('click', function(){
  371. const msg1 = JSON.parse(JSON.stringify(msg))
  372. msg1.scaleName = $(this).attr('data-scaleName')
  373. msg1.featureType = 21
  374. openNewWin(`scale.html?msg=${encodeURIComponent(JSON.stringify(msg1))}`)
  375. })
  376. $(".conditTipsbox").on('click',".more",function(){
  377. // 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)}`)
  378. openNewWin(`illness.html?msg=${encodeURIComponent(JSON.stringify(msg))}`)
  379. })
  380. bindTipsEvent()
  381. }
  382. function slideToggle(className, showNum, dataLen){//展开收起
  383. const domName = $(className)
  384. const domNameBoxAll = $(className+'All')
  385. setTimeout(() => {
  386. if(showNum < dataLen){
  387. domName.append(`<span class="slideDown"><img src="${showImg}"></span>`)
  388. }
  389. });
  390. domName.on('click',".slideDown",function(){
  391. $(".itemAllBox").css('display', 'none')
  392. $(domNameBoxAll).css('display', 'block')
  393. })
  394. domNameBoxAll.on('click',".slideup",function(){
  395. $(domNameBoxAll).css('display', 'none')
  396. })
  397. }
  398. //打开免责申明
  399. $(".disclaimer .logo").on("click",function() {
  400. openNewWin("disclaimer.html");
  401. });
  402. module.exports = {
  403. renderRecommendInfo,
  404. renderMultRecommendInfo,
  405. renderTreat,
  406. renderRecommendConditTips,
  407. renderTipsInfo,
  408. renderKnowledgeInfo,
  409. renderScaleInfo
  410. }