indexHorizontalDom.js 19 KB

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