staticSearch.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. require('../css/staticSearch.less');
  2. require('./../images/del_nor.png')
  3. var $ = require("jquery");
  4. var { post, config, getUrlArgObject, openNewWin, isIe8 } = require('./promise.js');
  5. let checkOffImg = require('./../images/check_off.png')
  6. let checkOnImg = require('./../images/check_on.png')
  7. require('./../images/empty3.png').replace(/undefined/g, '')
  8. require('./../images/icon_search.png').replace(/undefined/g, '')
  9. require('./../images/icon_arrow_down.png').replace(/undefined/g, '')
  10. require('./../images/icon_arrow_up.png').replace(/undefined/g, '')
  11. let searchType = getUrlArgObject("searchType") || ""
  12. let medicalTypesList = []
  13. let first = true
  14. let tabid = 1, type = 1
  15. const is8Ie = isIe8() //判断是否为IE8
  16. if (is8Ie) {
  17. let reg = /undefined/g
  18. checkOffImg = checkOffImg.replace(reg, '')
  19. checkOnImg = checkOnImg.replace(reg, '')
  20. }
  21. if (searchType == '1') {
  22. $(".staticSearchB>ul").css({
  23. padding: "0px",
  24. left: "0px"
  25. })
  26. document.title = "医学知识搜索"
  27. }
  28. $(".header-tab li").click(function () {
  29. // 修改tab标签样式
  30. tabid = $(this).attr("tabid");
  31. $(this).attr("class", "choice")
  32. $(this).siblings().attr("class", "")
  33. // 获取tab ID
  34. if (tabid == 1) {
  35. $(".radio-list").css('display', 'none')
  36. } else {
  37. $(".radio-list").css('display', 'block')
  38. }
  39. $(".searchKnowledge .staticSearchB .tip").css({ display: 'none' })
  40. $(".searchKnowledge .staticSearchB ul").html('')
  41. })
  42. $(".check-box").click(function () {
  43. type = $(this).find('input[name=ICD10]').val()
  44. $(this).siblings().find('input[name=ICD10]').prop("checked", false)
  45. $(this).find('input[name=ICD10]').prop("checked", true)
  46. })
  47. $(".staticSearchT input").keyup(function (e) {
  48. const ev = e || window.event;
  49. const val = $(this).val();
  50. $(this).parents(".staticSearchT").find("i").css({ display: val == "" ? "none" : "inline-block" })
  51. if (val == '') {
  52. $(".searchKnowledge .staticSearchB .empty").css({ display: 'none' })
  53. $(".searchKnowledge .staticSearchB .tip").css({ display: 'none' })
  54. $(".searchKnowledge .staticSearchB ul").html('')
  55. $(".searchKnowledge .staticSearchB .inputWarning").css("display", "block")
  56. } else {
  57. $(".searchKnowledge .staticSearchB .inputWarning").css("display", "none")
  58. }
  59. val != '' && ev.keyCode == 13 && getKnowledgeData(val);
  60. })
  61. // document.title = "医学知识搜索"
  62. $(".searchScale").css({ display: 'none' })
  63. $(".searchKnowledge").css({ display: 'block' })
  64. $(".searchKnowledge .staticSearchT").on('click', 'button', function () {
  65. var val = $(this).parents(".staticSearchT").find("input").val()
  66. if (val.trim() == '') {
  67. $(".searchKnowledge .staticSearchB ul").html("");
  68. $(".searchKnowledge .staticSearchB .tip").hide();
  69. $(".searchKnowledge .staticSearchB .inputWarning").css("display", "block")
  70. } else {
  71. getKnowledgeData(val)
  72. }
  73. })
  74. function getMedicalTypes() {
  75. post(config.dictionaryInfo, {}).then((res) => {
  76. const data = res.data
  77. if (data.code == 0) {
  78. medicalTypesList = res.data.data[7]
  79. medicalTypesList[0].checked = true
  80. renderMedicalType(medicalTypesList)
  81. } else {
  82. console.log(res)
  83. }
  84. })
  85. }
  86. function renderMedicalType(medicalTypesList) {
  87. let str = ''
  88. for (let i = 0; i < medicalTypesList.length; i++) {
  89. str += `<span class='medicalTypeItem' data-index=${i}><img src = ${medicalTypesList[i].checked ? checkOnImg : checkOffImg}>${medicalTypesList[i].name}</span>`
  90. }
  91. $('.searchTypeBox').html(str)
  92. bindMedicalTypeClick();
  93. }
  94. function bindMedicalTypeClick() {
  95. $('.searchTypeBox .medicalTypeItem').on("click", function () {
  96. const index = $(this).attr('data-index')
  97. if (index == 0) {
  98. if (medicalTypesList[0].checked) {
  99. medicalTypesList[0].checked = false
  100. } else {
  101. for (let i = 0; i < medicalTypesList.length; i++) {
  102. medicalTypesList[i].checked = false
  103. }
  104. medicalTypesList[0].checked = true
  105. }
  106. renderMedicalType(medicalTypesList)
  107. } else {
  108. if (medicalTypesList[0].checked) {
  109. medicalTypesList[0].checked = false
  110. }
  111. medicalTypesList[index].checked = !medicalTypesList[index].checked
  112. }
  113. renderMedicalType(medicalTypesList)
  114. })
  115. }
  116. getMedicalTypes()
  117. function getKnowledgeData(value) {
  118. $(".searchKnowledge .staticSearchB .inputWarning").css("display", "none")
  119. $(".searchKnowledge .staticSearchB .empty").css({ display: 'none' })
  120. $(".searchKnowledge .staticSearchB ul").html('')
  121. if (first) {
  122. adjustHeight()
  123. first = false
  124. }
  125. let url, param
  126. if (tabid == 1) {
  127. let medicalTypes = []
  128. for (let i = 0; i < medicalTypesList.length; i++) {
  129. if (medicalTypesList[i].checked) {
  130. medicalTypes.push(medicalTypesList[i].val)
  131. }
  132. }
  133. url = config.getStaticKnowledge
  134. param = {
  135. inputStr: value.replace(/\\/g, '\\\\').replace(/%/g, '\\%').replace(/\_/g, '\\_').trim(),
  136. types: medicalTypes
  137. }
  138. } else {
  139. url = config.diseaseIndex
  140. param = {
  141. current: 0,
  142. size: 100,
  143. inputStr: value.replace(/\\/g, '\\\\').replace(/%/g, '\\%').replace(/\_/g, '\\_').trim(),
  144. type: type
  145. }
  146. }
  147. $(".searchKnowledge .staticSearchB .searching").css("display", "block")
  148. post(url, param).then((res) => {
  149. $(".searchKnowledge .staticSearchB .searching").css("display", "none")
  150. const data = res.data
  151. if (data.code == 0) {
  152. var knowledgeLis = data.data
  153. var lisStr = ''
  154. if (knowledgeLis && knowledgeLis.length > 0) {
  155. for (var i = 0; i < knowledgeLis.length; i++) {
  156. var tmpPart = knowledgeLis[i];
  157. console.log(tmpPart);
  158. var ynameDom = tmpPart.code ? `<tr>
  159. <td rowspan="2" width="65"><span class="type-icon">医保版</span></td>
  160. <td><span title="${tmpPart.name}">${tmpPart.name}</span></td>
  161. </tr>
  162. <tr>
  163. <td>
  164. <span title="${tmpPart.code}" class="type-code">${tmpPart.code}</span>
  165. </td>
  166. </tr>`: '';
  167. var gnameDom = tmpPart.guoname || tmpPart.guocode ? `<tr>
  168. <td rowspan="2"><span class="type-icon type-l">国临版</span></td>
  169. <td><span title="${tmpPart.guoname}">${tmpPart.guoname}</span></td>
  170. </tr>
  171. <tr>
  172. <td>
  173. <span title="${tmpPart.guocode}" class="type-code">${tmpPart.guocode}</span>
  174. </td>
  175. </tr>`: '';
  176. var codeDom = ynameDom + gnameDom ? `<div class="codeDiv"><table width="100%"><tbody>${ynameDom}${gnameDom}</tbody></table></div>` : "";
  177. var codeIcon = ynameDom + gnameDom ? `<span class="code-slide"></span>` : "";
  178. var tmpLi = tabid == 1 ? `<li class="hide-codes" data-name='${tmpPart.name}' data-uname='${tmpPart.uniqueName}' data-type='${tmpPart.libTypeId}' data-sign='${tmpPart.type}'>
  179. <p><span class="diag-name">${tmpPart.name}<i>${tmpPart.typeName ? (' ( ' + tmpPart.typeName + ' )') : ''}</i></span>
  180. ${codeIcon}
  181. </p>
  182. ${tmpPart.retrievalName ? ('<span>• ' + tmpPart.retrievalName + '</span>') : ''}
  183. ${codeDom}
  184. </li>`: `<li class="hide-codes">
  185. <p><span style="font-size: 14px;color:#666">${tmpPart.code}</span> <span style="font-size: 14px;color:#333">${tmpPart.name}</span>
  186. </p>
  187. </li>`
  188. lisStr += tmpLi
  189. }
  190. $(".searchKnowledge .staticSearchB .empty").css({ display: 'none' })
  191. $(".searchKnowledge .staticSearchB .tip").css({ display: 'block' })
  192. $(".searchKnowledge .staticSearchB ul").html(lisStr)
  193. } else {
  194. $(".searchKnowledge .staticSearchB .empty").css({ display: 'block' })
  195. $(".searchKnowledge .staticSearchB .tip").css({ display: 'none' })
  196. $(".searchKnowledge .staticSearchB ul").html('')
  197. }
  198. } else {
  199. console.log(res)
  200. }
  201. })
  202. }
  203. function getDiseaseIndex() {
  204. }
  205. function adjustHeight() {
  206. var ht = window.innerHeight;
  207. var containerHt = $(".medicalKonwledgeWrap .container").height()
  208. var ht2 = $(".searchTypeBox").outerHeight(true)
  209. $(".staticSearchB ul").height(ht - 120 - 10 - 40 + 20 - ht2 + "px");
  210. }
  211. $(window).on('resize', function () {
  212. adjustHeight()
  213. })
  214. $(".staticSearchB ul").on("click", "li .diag-name", function () {
  215. const infoMsgName = $(this).parents("li").attr('data-name')
  216. const infoMsgUName = $(this).parents("li").attr('data-uname')
  217. const type = $(this).parents("li").attr('data-type')
  218. const sign = $(this).parents("li").attr('data-sign')
  219. if (type != 48) {
  220. openNewWin(`staticInfo.html?type=${encodeURIComponent(sign)}&position=0&name=${encodeURIComponent(infoMsgName)}`)
  221. // openNewWin(`information.html?type=${encodeURIComponent(sign)}&position=0&name=${encodeURIComponent(infoMsgName)}&uname=${encodeURIComponent(infoMsgUName)}`)
  222. } else {
  223. let msg = JSON.parse(getUrlArgObject("msg"));
  224. const msg1 = JSON.parse(JSON.stringify(msg))
  225. // console.log('scaleName', msg,infoMsgName)
  226. msg1.scaleName = infoMsgName
  227. msg1.featureType = 21
  228. openNewWin(`scale.html?msg=${encodeURIComponent(JSON.stringify(msg1))}`)
  229. }
  230. })
  231. $(".staticSearchB ul").on("click", "li .code-slide", function () {
  232. $(this).parents("li").toggleClass("hide-codes");
  233. });
  234. $(".staticSearchT").on('click', '#clearKnowledge', function () {
  235. $(".staticSearchT input").val("")
  236. $(".searchKnowledge .staticSearchB ul").html('')
  237. $(".searchKnowledge .staticSearchB .tip").css({ display: 'none' })
  238. $(".searchKnowledge .staticSearchB .empty").css({ display: 'none' })
  239. $(this).prev('.ipt').find('input').focus()
  240. $(this).css({ display: "none" })
  241. })
  242. $(function () {
  243. $(".staticSearchT .ipt").find("input").focus()
  244. })