icssIndexDom.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362
  1. const $ = require("jquery");
  2. const { openNewWin,imageUrlPrefix } = require('./promise.js');
  3. const { bindTipsEvent } = require('./popupEdit.js');
  4. function renderRecommendInfo(showNum,className,title,data, hasInfo, type, position) {
  5. let showNumCopy = showNum || 5
  6. const dataLen = data.length
  7. const str = `<div class="recommendInfoWrapper ${className}">
  8. <h4><img class="titleIcon" src="./images/knzd.png" alt="icon" />${title}</h4>
  9. <div class="recommendInfoBox">
  10. <div class="clearfix recommendInfoItemBox ${className + 'box'}">
  11. </div>
  12. </div>
  13. </div>`
  14. $('.recommendWrap').append(str)
  15. let dataShort
  16. if(showNumCopy&& dataLen > showNumCopy) {
  17. dataShort = data.slice(0, showNumCopy)
  18. } else {
  19. dataShort = data
  20. }
  21. let childrenNodeStrShort = ''
  22. let childrenNodeStrLong = ''
  23. if(hasInfo) {
  24. for (let i = 0; i < dataShort.length; i++) {
  25. childrenNodeStrShort += `<span class="recommendInfoItem recommendInfoItemHasInfo">
  26. ${dataShort[i].name}
  27. <span title="点击i图标可查看详细说明" class="infoMsg" data-name=${dataShort[i].name}></span>
  28. </span>`
  29. }
  30. for (let i = 0; i < data.length; i++) {
  31. childrenNodeStrLong += `<span class="recommendInfoItem recommendInfoItemHasInfo">
  32. ${data[i].name}
  33. <span title="点击i图标可查看详细说明" class="infoMsg" data-name=${data[i].name}></span>
  34. </span>`
  35. }
  36. } else {
  37. for (let i = 0; i < dataShort.length; i++) {
  38. childrenNodeStrShort += `<span class="recommendInfoItem" data-name="${dataShort[i].name}">
  39. ${dataShort[i].name}
  40. </span>`
  41. }
  42. for (let i = 0; i < data.length; i++) {
  43. childrenNodeStrLong += `<span class="recommendInfoItem" data-name="${data[i].name}">
  44. ${data[i].name}
  45. </span>`
  46. }
  47. }
  48. if(!childrenNodeStrShort) {
  49. childrenNodeStrShort='<span class="recommendNull">暂无推荐</span>'
  50. }
  51. $('.'+className + 'box').append(childrenNodeStrShort)
  52. $('.'+className + 'box' +' .infoMsg').on('click', function(){
  53. const infoMsgName = $(this).attr('data-name')
  54. openNewWin(`information.html?type=${encodeURIComponent(type)}&position=${encodeURIComponent(position)}&name=${encodeURIComponent(infoMsgName)}`)
  55. })
  56. if(dataLen > showNumCopy) {
  57. slideToggle($("."+className+"box"), childrenNodeStrShort,childrenNodeStrLong)
  58. }
  59. }
  60. function renderMultRecommendInfo(className,title,data, hasInfo, type, position) {
  61. const str = `<div class="recommendInfoWrapper ${className}">
  62. <h4><img class="titleIcon" src="./images/inspect.png" alt="icon" />${title}</h4>
  63. <div class="recommendInfoBox ${className + 'box'}"></div>
  64. </div>`
  65. $('.recommendWrap').append(str)
  66. let hasDataNum = 0
  67. for(let i = 0; i < data.length; i++) {
  68. const showNum = data[i].showNum || 5
  69. const dataLen = data[i].data.length
  70. if(dataLen === 0) {
  71. continue
  72. }
  73. hasDataNum++
  74. if(hasDataNum > 1) {
  75. $('.'+className + 'box').append('<div class="line"></div>')
  76. }
  77. let childrenNodeBoxStr = `<div class="labAndPacsBox ${data[i].className} clearfix"> </div>`
  78. let childrenNodeStrShort = `<span class="labAndPacsTitle">${data[i].title}<i></i></span>`
  79. let childrenNodeStrLong = `<span class="labAndPacsTitle">${data[i].title}<i></i></span>`
  80. let dataShort
  81. if(showNum&& dataLen > showNum) {
  82. dataShort = data[i].data.slice(0, showNum)
  83. } else {
  84. dataShort = data[i].data
  85. }
  86. for(let j = 0; j < dataShort.length; j++) {
  87. childrenNodeStrShort += `<span class="labAndPacsItem">${dataShort[j].name}</span>`
  88. }
  89. for(let j = 0; j < data[i].data.length; j++) {
  90. childrenNodeStrLong += `<span class="labAndPacsItem">${data[i].data[j].name}</span>`
  91. }
  92. if(data[i].data.length == 0) {
  93. childrenNodeStrShort +='<span class="recommendNull">暂无推荐</span>'
  94. }
  95. $('.'+className + 'box').append(childrenNodeBoxStr)
  96. $('.'+data[i].className).append(childrenNodeStrShort)
  97. if(dataLen > showNum) {
  98. slideToggle($("."+data[i].className), childrenNodeStrShort,childrenNodeStrLong)
  99. }
  100. }
  101. }
  102. function renderRecommendConditTips(className,title,data) {
  103. const str = `<div class="recommendInfoWrapper ${className}">
  104. <h4><img class="titleIcon" src="./images/tips.png" alt="icon" />${title}</h4>
  105. <div class="recommendInfoBox ${className + 'box'}"></div>
  106. </div>`
  107. $('.recommendWrap').append(str)
  108. if(data.length == 0) {
  109. $("."+className+"box").append('<span class="recommendNull">暂无推荐</span>')
  110. };
  111. //let names = [];
  112. for(var k = 0;k < data.length;k++){
  113. let tmpBq = data[k];
  114. let hasSritical = false
  115. let tmpBqStr;
  116. if(tmpBq.details) {
  117. for(let i = 0; i < tmpBq.details.length; i++) {
  118. if(tmpBq.details[i].type == 4) {
  119. hasSritical= true
  120. }
  121. }
  122. }
  123. if(hasSritical) {
  124. /*if(names.includes(tmpBq.name)){ //name相同去重
  125. tmpBqStr='';
  126. }else{
  127. names.push(tmpBq.name);*/
  128. tmpBqStr = `<p class="mayIllness">
  129. <span class="sriticalNameBox"><span class="sriticalName">${tmpBq.name}</span>
  130. </span>
  131. </span></p>`
  132. //}
  133. } else {
  134. tmpBqStr = `<p class="mayIllness">
  135. 患者可能有 <span class="diagNameBox"><span class="diagName">${tmpBq.name}:</span>
  136. <span title="点击该名称可看详细说明" class="infoMsg" data-name=${tmpBq.name}></span>
  137. </span>
  138. </span></p>`
  139. }
  140. var tmpBqDetailStr = ''
  141. for(var m = 0;m < tmpBq.details.length;m++){
  142. var tmpBqDetail = tmpBq.details[m]
  143. if(tmpBqDetail.type == 1){
  144. tmpBqDetailStr+=`<span data-scaleName=${tmpBqDetail.content.name} class="illnessTable">【${tmpBqDetail.content.name}】</span>`
  145. }
  146. if(tmpBqDetail.type == 2){
  147. var deepDetailName = `<div class="modalTitle">${tmpBqDetail.content.name}<i class="closeModal"></i></div>`
  148. var deepDetailStr = ''
  149. var deepDetailResultStr = ''
  150. for(var n = 0;n < tmpBqDetail.content.details.length;n++){
  151. var deepDetail = tmpBqDetail.content.details[n]
  152. if(deepDetail.controlType == 2){//0-radio,1-checkbox,2-text,3-dropdownlist
  153. if(deepDetail.isShow == 0) {
  154. deepDetailStr+=`<li class="radioCheck"><span class="modalMaintltle">${deepDetail.name}: </span>${deepDetail.value} ${deepDetail.uint}</li>`
  155. } else {
  156. deepDetailStr+=`<li class="radioCheck"><span class="modalMaintltle">请输入${deepDetail.name}: </span><input type="text" class="${tmpBqDetail.content.name+deepDetail.name}" ${deepDetail.isShow=='0' ? 'readonly':''} placeholder="请输入" value=${deepDetail.value}><i class="uint">${deepDetail.uint}</i></li>`
  157. }
  158. }
  159. if(deepDetail.controlType == 0){
  160. let tooDeepDetailStr = ''
  161. for(var f = 0;f<deepDetail.details.length;f++){
  162. var tooDeepDetail = deepDetail.details[f]
  163. if(deepDetail.isShow == '0'){
  164. if(tooDeepDetail.state == 1) {
  165. tooDeepDetailStr+='<li class="radioChecks" data-select="'+(tooDeepDetail.state == 1?"select":"")+'"><span>'+tooDeepDetail.detailName+'</span></li>'
  166. }
  167. }else{
  168. tooDeepDetailStr+='<li class="radioChecks"><i></i><span>'+tooDeepDetail.detailName+'</span>'+(tooDeepDetail.state == 1?"<a>(智能推荐)</a>":"")+'</li>'
  169. }
  170. }
  171. deepDetailStr+=`<li class="radioCheck"><span class="modalMaintltle">${deepDetail.name}: </span>
  172. <ul class="clearfix caculateLis" data-isShow = ${deepDetail.isShow}>
  173. ${tooDeepDetailStr}
  174. </ul>
  175. </li>`
  176. }
  177. }
  178. for(var v = 0;v < tmpBqDetail.content.result.length;v++){
  179. deepDetailResultStr+='<p class="result"><span class="calculateName">'+tmpBqDetail.content.result[v].name+':</span><span class="calculateResult"></span></p>'
  180. }
  181. tmpBqDetailStr+=`<div class="mayResult">
  182. 计算公式结果:
  183. <span class="mayResultSelect" data-num="${k}">
  184. <span class="makesureResult">请选择</span>
  185. <span class="sanjiao"></span>
  186. <div class="popupModal">
  187. ${deepDetailName}
  188. <div class="modalMainTwo">
  189. <ul class="clearfix">
  190. ${deepDetailStr}
  191. </ul>
  192. <div class="calculate" data-num="${k}">计算</div>
  193. <p class="calculateError">请填写计算公式内容</p>
  194. <div class="resultLis">
  195. ${deepDetailResultStr}
  196. </div>
  197. </div>
  198. <div class="btnWrap clearfix">
  199. <div class="sureScore" data-type="2">关闭</div>
  200. </div>
  201. </div>
  202. </span>
  203. </div>`
  204. }
  205. if(tmpBqDetail.type == 3){
  206. var deepDetailName = '<span class="modalMaintltle">'+tmpBqDetail.content.name+': </span>'
  207. var deepDetailStr = ''
  208. for(var n = 0;n < tmpBqDetail.content.details.length;n++){
  209. var deepDetail = tmpBqDetail.content.details[n]
  210. deepDetailStr+='<li class="radioChecks"><i></i><span>'+deepDetail.detailName+'</span>'+(deepDetail.state == 1?"<a>(智能推荐)</a>":"")+'</li>'
  211. }
  212. tmpBqDetailStr+=`<div class="mayResult">
  213. 可能结果:
  214. <span class="mayResultSelect" data-num="${k}"><span class="makesureResult">请选择</span><i class="sanjiao"></i>
  215. <div class="popupModal">
  216. <div class="modalTitle">
  217. 结果选择<i class="closeModal"></i>
  218. </div>
  219. <div class="modalMainOne">
  220. ${deepDetailName}
  221. <ul class="clearfix">
  222. ${deepDetailStr}
  223. </ul>
  224. </div>
  225. <div class="btnWrap clearfix">
  226. <div class="sureScore" data-type="3" data-num="${k}">确定</div>
  227. </div>
  228. </div>
  229. </span>
  230. </div>`
  231. }
  232. if(tmpBqDetail.type == 4){
  233. // tmpBqDetailStr+=`<div class="sriticalinfo">诊断要点:${tmpBqDetail.content.name}</div>`
  234. }
  235. }
  236. if(tmpBqStr != '' || tmpBqDetailStr != ''){
  237. $(".conditionHintTipsNull").css("display","none")
  238. }
  239. // $(".conditionHintTips").append('<div class="conditionMain clearfix">'+tmpBqStr+'<div class="alertModal">'+tmpBqDetailStr+'</div></div>')
  240. $("."+className+"box").append('<div class="conditionMain clearfix">'+tmpBqStr+'<div class="alertModal">'+tmpBqDetailStr+'</div></div>')
  241. }
  242. $('.mayIllness .infoMsg').on('click', function(){
  243. const infoMsgName = $(this).attr('data-name')
  244. openNewWin(`information.html?type=22&position=2&name=${encodeURIComponent(infoMsgName)}`)
  245. })
  246. $('.alertModal .illnessTable').on('click', function(){
  247. const msg1 = JSON.parse(JSON.stringify(msg))
  248. msg1.scaleName = $(this).attr('data-scaleName')
  249. msg1.featureType = 21
  250. openNewWin(`scale.html?msg=${encodeURIComponent(JSON.stringify(msg1))}`)
  251. })
  252. bindTipsEvent()
  253. }
  254. function renderCaseStandard(className,title,data){
  255. const str = `<div class="recommendInfoWrapper ${className}">
  256. <h4><img class="titleIcon" src="./images/knzd.png" alt="icon" />${title}</h4>
  257. <div class="recommendInfoBox">
  258. <div class="clearfix recommendInfoItemBox ${className + 'box'}">
  259. </div>
  260. </div>
  261. </div>`
  262. let childStr = ""
  263. for(let i = 0; i < data.length; i++){
  264. childStr += `<p>${data[i]}</p>`
  265. }
  266. $('.recommendWrap').append(str)
  267. $(`.${className}box`).html(childStr)
  268. }
  269. function renderWarning(showNum,className,title,data, hasInfo, type, position){
  270. let showNumCopy = showNum || 5
  271. const dataLen = data.length
  272. const str = `<div class="recommendInfoWrapper ${className}">
  273. <div class="recommendInfoBox">
  274. <div class="clearfix recommendInfoItemBox ${className + 'box'}">
  275. <h4><img class="titleIcon" src="./images/warings.png" alt="icon" />${title}</h4>
  276. </div>
  277. </div>
  278. </div>`
  279. $('.recommendWrap').append(str)
  280. let dataShort
  281. if(showNumCopy&& dataLen > showNumCopy) {
  282. dataShort = data.slice(0, showNumCopy)
  283. } else {
  284. dataShort = data
  285. }
  286. let childrenNodeStrShort = ''
  287. let childrenNodeStrLong = ''
  288. if(hasInfo) {
  289. for (let i = 0; i < dataShort.length; i++) {
  290. childrenNodeStrShort += `<span class="recommendInfoItem recommendInfoItemHasInfo">
  291. ${dataShort[i].name}
  292. <span title="点击i图标可查看详细说明" class="infoMsg" data-name=${dataShort[i].name}></span>
  293. </span>`
  294. }
  295. for (let i = 0; i < data.length; i++) {
  296. childrenNodeStrLong += `<span class="recommendInfoItem recommendInfoItemHasInfo">
  297. ${data[i].name}
  298. <span title="点击i图标可查看详细说明" class="infoMsg" data-name=${data[i].name}></span>
  299. </span>`
  300. }
  301. } else {
  302. for (let i = 0; i < dataShort.length; i++) {
  303. childrenNodeStrShort += `<span class="recommendInfoItem" data-name="${dataShort[i].name}">
  304. ${dataShort[i].name}
  305. </span>`
  306. }
  307. for (let i = 0; i < data.length; i++) {
  308. childrenNodeStrLong += `<span class="recommendInfoItem" data-name="${data[i].name}">
  309. ${data[i].name}
  310. </span>`
  311. }
  312. }
  313. if(!childrenNodeStrShort) {
  314. childrenNodeStrShort='<span class="recommendNull">暂无推荐</span>'
  315. }
  316. $('.'+className + 'box').append(childrenNodeStrShort)
  317. $('.'+className + 'box' +' .infoMsg').on('click', function(){
  318. const infoMsgName = $(this).attr('data-name')
  319. openNewWin(`information.html?type=${encodeURIComponent(type)}&position=${encodeURIComponent(position)}&name=${encodeURIComponent(infoMsgName)}`)
  320. })
  321. if(dataLen > showNumCopy) {
  322. slideToggle($("."+className+"box"), childrenNodeStrShort,childrenNodeStrLong)
  323. }
  324. }
  325. function slideToggle(domName,childrenNodeStrShort,childrenNodeStrLong){//展开收起
  326. domName.append('<span class="slideDown">更多 <i></i></span>')
  327. domName.on('click',".slideDown",function(){
  328. domName.html(childrenNodeStrLong)
  329. domName.append('<span class="slideup">收起 <i></i></span>')
  330. $(this).remove()
  331. })
  332. domName.on('click',".slideup",function(){
  333. domName.html(childrenNodeStrShort)
  334. domName.append('<span class="slideDown">更多 <i></i></span>')
  335. $(this).remove()
  336. })
  337. }
  338. module.exports ={
  339. renderCaseStandard,
  340. renderWarning,
  341. renderRecommendInfo,
  342. renderMultRecommendInfo,
  343. renderRecommendConditTips,
  344. }