indexHorizontalDom.js 20 KB

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