indexHorizontalDom.js 18 KB

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