index.js 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592
  1. var template = ''
  2. $.ajax('../../../component/statistics/GxbEvaluation/index.html', {
  3. data: {},
  4. dataType: 'html',
  5. cache: false,
  6. timeout: 60000,
  7. async: false,
  8. error: function (res) {},
  9. success: function (res) {
  10. template = res
  11. }
  12. })
  13. Vue.component('gxb-evaluation', {
  14. template: template,
  15. props: [],
  16. data: function () {
  17. return {
  18. years: [],
  19. yearType: '1',
  20. chooseYear: null,
  21. chooseTime: null,
  22. rangeOptions: [
  23. { label: '区', value: 'town' },
  24. { label: '社区', value: 'hospital' },
  25. { label: '团队', value: 'team' }
  26. ],
  27. areaOptions: [
  28. { label: '思明区', value: '350203' },
  29. { label: '海沧区', value: '350205' },
  30. { label: '湖里区', value: '350206' },
  31. { label: '集美区', value: '350211' },
  32. { label: '同安区', value: '350212' },
  33. { label: '翔安区', value: '350213' }
  34. ],
  35. hospitalOptions: [],
  36. teamOptions: [],
  37. form: {
  38. range: 'town'
  39. },
  40. loading: false,
  41. exportLoading: false,
  42. tableData: [],
  43. tableHeader: [],
  44. constantHeader: [
  45. { label: '评估人数', prop: 'totalNum', width: '90' },
  46. { label: '日常评估人数', prop: 'dailyNum', width: '110' },
  47. { label: '住院补筛人数', prop: 'inScreenNum', width: '110' },
  48. { label: '低危人数', prop: 'lRiskNum', width: '90' },
  49. { label: '中危人数', prop: 'mRiskNum', width: '90' },
  50. { label: '高危人数', prop: 'hRiskNum', width: '90' },
  51. { label: '极高危人数', prop: 'uhRiskNum', width: '90' },
  52. { label: '超高危人数', prop: 'ehRiskNum', width: '90' },
  53. { label: '已筛次数', prop: 'totalTimes', width: '90' },
  54. { label: '低危次数', prop: 'lRiskTimes', width: '90' },
  55. { label: '中危次数', prop: 'mRiskTimes', width: '90' },
  56. { label: '高危次数', prop: 'hRiskTimes', width: '90' },
  57. { label: '极高危次数', prop: 'uhRiskTimes', width: '90' },
  58. { label: '超高危次数', prop: 'ehRiskTimes', width: '90' },
  59. { label: '上转人次', prop: 'turnUpNum', width: '90' },
  60. { label: '消息提醒人次', prop: 'messageTimes', width: '110' },
  61. { label: '社区随访人次', prop: 'hosFollowNum', width: '110' }
  62. ],
  63. // page: 1,
  64. // size: 10,
  65. // total: 0,
  66. level: 0,
  67. visible: false,
  68. title: '',
  69. query: {},
  70. dataRangeOption: [],
  71. dialogTableData: [],
  72. dialogHeader: [],
  73. page: 1,
  74. size: 10,
  75. total: 0,
  76. messageVisible: false,
  77. messInfo: null,
  78. remind: '',
  79. dialogExportLoading: false,
  80. dialogLoading: false
  81. }
  82. },
  83. methods: {
  84. init() {
  85. var selectedRole = JSON.parse(sessionStorage.getItem('selectedRole'))
  86. if (selectedRole.code.indexOf('350200') > -1) {
  87. this.level = 1 // 市卫健委
  88. this.areaOptions = [
  89. { label: '厦门市', value: '' },
  90. { label: '思明区', value: '350203' },
  91. { label: '海沧区', value: '350205' },
  92. { label: '湖里区', value: '350206' },
  93. { label: '集美区', value: '350211' },
  94. { label: '同安区', value: '350212' },
  95. { label: '翔安区', value: '350213' }
  96. ]
  97. } else if (selectedRole.code.length == 6) {
  98. this.level = 2 // 区管理
  99. this.areaOptions = [{ label: selectedRole.name.substring(0, 3), value: selectedRole.code }]
  100. this.form = {
  101. range: 'town',
  102. area: selectedRole.code
  103. }
  104. this.getHospital(selectedRole.code)
  105. } else {
  106. this.level = 3 // 社区管理
  107. this.rangeOptions = [
  108. { label: '社区', value: 'hospital' },
  109. { label: '团队', value: 'team' }
  110. ]
  111. this.areaOptions = [{ label: selectedRole.name.substring(0, 3), value: selectedRole.code.substring(0, 6) }]
  112. this.hospitalOptions = [{ name: selectedRole.name, code: selectedRole.code }]
  113. this.form = {
  114. range: 'hospital',
  115. area: selectedRole.code.substring(0, 6),
  116. hospital: selectedRole.code
  117. }
  118. this.getTeam(selectedRole.code)
  119. }
  120. this.initTime()
  121. this.searchFn()
  122. },
  123. initTime() {
  124. var vm = this
  125. var now = new Date()
  126. var nowyear = (vm.chooseYear = now.getFullYear())
  127. vm.years = []
  128. for (i = nowyear; i >= 2013; i--) {
  129. vm.years.push(i)
  130. }
  131. },
  132. resetArea() {
  133. if (this.level == 1) {
  134. delete this.form.area
  135. delete this.form.hospital
  136. delete this.form.team
  137. } else if (this.level == 2) {
  138. delete this.form.hospital
  139. delete this.form.team
  140. } else {
  141. delete this.form.team
  142. }
  143. },
  144. searchFn() {
  145. var vm = this
  146. this.loading = true
  147. var params = {
  148. ...this.form,
  149. isTotal: 1
  150. }
  151. vm.tableData = []
  152. if (this.yearType == '1') {
  153. params.startDate = this.chooseYear + '-01-01'
  154. params.endDate = this.chooseYear + '-12-31'
  155. } else {
  156. if (this.chooseTime) {
  157. params.startDate = this.chooseTime[0]
  158. params.endDate = this.chooseTime[1]
  159. }
  160. }
  161. if (this.form.range == 'town') {
  162. this.tableHeader = getTownHeader().concat(this.constantHeader)
  163. } else if (this.form.range == 'hospital') {
  164. this.tableHeader = getHospitalHeader().concat(this.constantHeader)
  165. } else {
  166. this.tableHeader = getTeamHeader().concat(this.constantHeader)
  167. }
  168. // constantHeader
  169. httpRequest.get('statistics/collaborate/gxbScreenInfoStatistics', { data: params }).then(function (res) {
  170. if (res.status == 200) {
  171. vm.tableData = res.detailModelList.map(function (item) {
  172. var data = JSON.parse(JSON.stringify(item))
  173. if (vm.form.range == 'town') {
  174. data.town = item.name
  175. data.hasChildren = item.code && true
  176. } else if (vm.form.range == 'hospital') {
  177. data.hospital = item.name
  178. data.hasChildren = item.code && true
  179. } else if (vm.form.range == 'team') {
  180. data.team = item.name
  181. }
  182. return data
  183. })
  184. }
  185. vm.loading = false
  186. })
  187. },
  188. exportTable() {
  189. var vm = this
  190. var params = {
  191. ...this.form
  192. }
  193. if (this.yearType == '1') {
  194. params.startDate = this.chooseYear + '-01-01'
  195. params.endDate = this.chooseYear + '-12-31'
  196. } else {
  197. if (this.chooseTime) {
  198. params.startDate = this.chooseTime[0]
  199. params.endDate = this.chooseTime[1]
  200. }
  201. }
  202. this.exportLoading = true
  203. var fileName = `冠心病评估情况统计表${new Date().getTime()}.xls`
  204. httpRequest.downLoadFileForAjax('statistics/collaborate/exportGxbScreenInfoStatistics', fileName, params).then(function () {
  205. vm.exportLoading = false
  206. })
  207. },
  208. eliminateClick() {
  209. var selectedRole = JSON.parse(sessionStorage.getItem('selectedRole'))
  210. if (this.level == 1) {
  211. this.form = {
  212. range: 'town'
  213. }
  214. } else if (this.level == 2) {
  215. this.form = {
  216. range: 'town',
  217. area: selectedRole.code
  218. }
  219. this.getHospital(selectedRole.code)
  220. } else {
  221. this.form = {
  222. range: 'hospital',
  223. area: selectedRole.code.substring(0, 6),
  224. hospital: selectedRole.code
  225. }
  226. this.getTeam(selectedRole.code)
  227. }
  228. this.yearType = '1'
  229. this.chooseYear = new Date().getFullYear()
  230. this.chooseTime = null
  231. this.$forceUpdate()
  232. },
  233. getHospital(code, flag = true) {
  234. var vm = this
  235. if (flag) {
  236. delete this.form.hospital
  237. delete this.form.team
  238. }
  239. var params = {
  240. type: 5,
  241. code: code
  242. }
  243. httpRequest.post('common/district', { data: params }).then(function (res) {
  244. vm.hospitalOptions = [{ code: '', name: '全部' }]
  245. vm.hospitalOptions = vm.hospitalOptions.concat(res.list)
  246. })
  247. },
  248. getTeam(code, flag = true) {
  249. var vm = this
  250. if (flag) delete this.form.team
  251. var params = {
  252. hospital: code,
  253. area: this.form.area
  254. }
  255. httpRequest.get('statisticsExport/teamList', { data: params }).then(function (res) {
  256. vm.teamOptions = [{ id: '', name: '全部' }]
  257. vm.teamOptions = vm.teamOptions.concat(res.data)
  258. })
  259. },
  260. load(row, treeNode, resolve) {
  261. var params = {}
  262. var len = row.code.length
  263. if (len == 6) {
  264. params.range = 'hospital'
  265. params.area = row.code
  266. } else if (len == 10) {
  267. params.range = 'team'
  268. params.hospital = row.code
  269. }
  270. if (this.yearType == '1') {
  271. params.startDate = this.chooseYear + '-01-01'
  272. params.endDate = this.chooseYear + '-12-31'
  273. } else {
  274. if (this.chooseTime) {
  275. params.startDate = this.chooseTime[0]
  276. params.endDate = this.chooseTime[1]
  277. }
  278. }
  279. httpRequest.get('statistics/collaborate/gxbScreenInfoStatistics', { data: params }).then(function (res) {
  280. if (res.status == 200) {
  281. var children = res.detailModelList.map(function (item) {
  282. var data = JSON.parse(JSON.stringify(item))
  283. if (len == 6) {
  284. data.hospital = item.name
  285. data.hasChildren = true
  286. } else if (len == 10) {
  287. data.team = item.name
  288. }
  289. return data
  290. })
  291. resolve(children)
  292. }
  293. })
  294. },
  295. openDialog(row, prop) {
  296. if (!row.code) return
  297. this.page = 1
  298. var vm = this
  299. this.query = {}
  300. switch (prop) {
  301. case 'totalNum':
  302. this.query.screenResultCode = ''
  303. this.title = '个案数据列表'
  304. break
  305. case 'dailyNum':
  306. this.query.screenResultCode = ''
  307. this.query.surveyStatus = 1
  308. this.title = '个案数据列表'
  309. break
  310. case 'inScreenNum':
  311. this.query.screenResultCode = ''
  312. this.query.surveyStatus = 2
  313. this.title = '个案数据列表'
  314. break
  315. case 'lRiskNum':
  316. this.query.screenResultCode = '5'
  317. this.title = '个案数据列表'
  318. break
  319. case 'mRiskNum':
  320. this.query.screenResultCode = '4'
  321. this.title = '个案数据列表'
  322. break
  323. case 'hRiskNum':
  324. this.query.screenResultCode = '3'
  325. this.title = '个案数据列表'
  326. break
  327. case 'uhRiskNum':
  328. this.query.screenResultCode = '2'
  329. this.title = '个案数据列表'
  330. break
  331. case 'ehRiskNum':
  332. this.query.screenResultCode = '1'
  333. this.title = '个案数据列表'
  334. break
  335. case 'messageTimes':
  336. this.title = '评估随访消息推送明细'
  337. break
  338. }
  339. var len = row.code.length
  340. if (len == 6) {
  341. this.query.range = 'town'
  342. this.query.area = row.code
  343. } else if (len == 10) {
  344. this.query.range = 'hospital'
  345. this.query
  346. this.query.hospital = row.code
  347. } else {
  348. this.query.range = 'team'
  349. this.query.team = row.code
  350. }
  351. this.dataRangeOption = [{ label: row.name, value: row.code }]
  352. if (['totalNum', 'dailyNum', 'inScreenNum', 'lRiskNum', 'mRiskNum', 'hRiskNum', 'uhRiskNum', 'ehRiskNum'].includes(prop)) {
  353. this.query.sex = ''
  354. vm.dialogHeader = [
  355. { label: '姓名', prop: 'name' },
  356. { label: '性别', prop: 'sex' },
  357. { label: '年龄', prop: 'age' },
  358. { label: '评估结果', prop: 'screenResult' },
  359. { label: '评估医生', prop: 'doctorName' },
  360. { label: '评估时间', prop: 'czrq' },
  361. { label: '手机号', prop: 'mobile' },
  362. { label: '证件号码', prop: 'idcard' },
  363. { label: '签约社区', prop: 'signHospitalName' },
  364. { label: '签约医生', prop: 'signDoctorName' }
  365. ]
  366. this.gxbCaseDataPage()
  367. vm.visible = true
  368. }
  369. if (prop == 'messageTimes') {
  370. vm.dialogHeader = [
  371. { label: '姓名', prop: 'patientName' },
  372. { label: '性别', prop: 'sex' },
  373. { label: '年龄', prop: 'age' },
  374. { label: '证件号码', prop: 'idcard' },
  375. { label: '签约医院', prop: 'hospitalName' },
  376. { label: '签约医生', prop: 'doctorName' },
  377. { label: '提醒类型', prop: 'typeName' },
  378. { label: '消息推送时间', prop: 'createTime' },
  379. { label: '消息推送人', prop: 'senderName' }
  380. ]
  381. this.selectSmsInfoList()
  382. vm.visible = true
  383. }
  384. },
  385. dialogSearchFn() {
  386. this.page = 1
  387. if (this.title == '个案数据列表') {
  388. this.gxbCaseDataPage()
  389. } else {
  390. this.selectSmsInfoList()
  391. }
  392. },
  393. gxbCaseDataPage() {
  394. var vm = this
  395. vm.dialogLoading = true
  396. var params = JSON.parse(JSON.stringify(this.query))
  397. params.page = this.page
  398. params.pageSize = this.size
  399. if (this.yearType == '1') {
  400. params.startDate = this.chooseYear + '-01-01'
  401. params.endDate = this.chooseYear + '-12-31'
  402. } else {
  403. if (this.chooseTime) {
  404. params.startDate = this.chooseTime[0]
  405. params.endDate = this.chooseTime[1]
  406. }
  407. }
  408. httpRequest.get('statistics/collaborate/gxbCaseDataPage', { data: params }).then(function (res) {
  409. if (res.status == 200) {
  410. vm.dialogTableData = res.detailModelList
  411. vm.total = res.totalCount
  412. }
  413. vm.dialogLoading = false
  414. })
  415. },
  416. handleCurrentChange(val) {
  417. this.page = val
  418. if (this.title == '个案数据列表') {
  419. this.gxbCaseDataPage()
  420. } else {
  421. this.selectSmsInfoList()
  422. }
  423. },
  424. handleSizeChange(val) {
  425. this.size = val
  426. if (this.title == '个案数据列表') {
  427. this.gxbCaseDataPage()
  428. } else {
  429. this.selectSmsInfoList()
  430. }
  431. },
  432. selectSmsInfoList() {
  433. var vm = this
  434. vm.dialogLoading = true
  435. var params = {
  436. ...this.query
  437. }
  438. params.type = 1
  439. params.page = this.page
  440. params.size = this.size
  441. if (this.yearType == '1') {
  442. params.startTime = this.chooseYear + '-01-01'
  443. params.endTime = this.chooseYear + '-12-31'
  444. } else {
  445. if (this.chooseTime) {
  446. params.startTime = this.chooseTime[0]
  447. params.endTime = this.chooseTime[1]
  448. }
  449. }
  450. httpRequest.get('statistics/collaborate/selectSmsInfoList', { data: params }).then(function (res) {
  451. if (res.status == 200) {
  452. vm.dialogTableData = res.detailModelList
  453. vm.total = res.totalCount
  454. }
  455. vm.dialogLoading = false
  456. })
  457. },
  458. dialogExportFn() {
  459. this.dialogExportLoading = true
  460. var vm = this
  461. var params = {
  462. ...this.query
  463. }
  464. if (this.yearType == '1') {
  465. params.startDate = this.chooseYear + '-01-01'
  466. params.endDate = this.chooseYear + '-12-31'
  467. } else {
  468. if (this.chooseTime) {
  469. params.startDate = this.chooseTime[0]
  470. params.endDate = this.chooseTime[1]
  471. }
  472. }
  473. if (this.title == '个案数据列表') {
  474. var fileName = `个案数据列表${new Date().getTime()}.xls`
  475. httpRequest.downLoadFileForAjax('statistics/collaborate/exportGxbCaseDataPage', fileName, params).then(function () {
  476. vm.dialogExportLoading = false
  477. })
  478. } else {
  479. var fileName = `评估随访消息推送明细${new Date().getTime()}.xls`
  480. params.type = 1
  481. httpRequest.downLoadFileForAjax('statistics/collaborate/exportSelectSmsInfoList', fileName, params).then(function () {
  482. vm.dialogExportLoading = false
  483. })
  484. }
  485. },
  486. closeDialog() {
  487. this.visible = false
  488. },
  489. seePatientDetail(row, prop) {
  490. if (prop == 'name' || prop == 'patientName') {
  491. EventBus.$emit('preview-person-info', { type: '1', code: row.code })
  492. }
  493. },
  494. dialogReset() {
  495. var params = {
  496. ...this.query
  497. }
  498. this.query = {
  499. sex: '',
  500. screenResultCode: '',
  501. type: params.type,
  502. range: typeof params.range == 'undefined' ? '' : params.range,
  503. area: typeof params.area == 'undefined' ? '' : params.area,
  504. hospital: typeof params.hospital == 'undefined' ? '' : params.hospital,
  505. team: typeof params.team == 'undefined' ? '' : params.team
  506. }
  507. if (this.title != '评估随访消息推送明细') {
  508. delete this.query.type
  509. }
  510. },
  511. previewMess(row) {
  512. this.messageVisible = true
  513. this.messInfo = row.content
  514. },
  515. closeMessageDialog() {
  516. this.messageVisible = false
  517. },
  518. getData(data) {
  519. if (data) {
  520. this.yearType = data.yearType
  521. this.form.range = data.range
  522. this.form.area = data.area
  523. this.form.hospital = data.hospital
  524. this.form.team = data.team
  525. if (this.yearType == 1) {
  526. this.chooseYear = data.time
  527. } else {
  528. this.chooseTime = data.time
  529. }
  530. if (this.form.hospital) {
  531. // 如果有社区code传过来就调社区医院列表接口
  532. this.getHospital(data.area, false)
  533. }
  534. if (this.form.team) {
  535. // 如果有团队code传过来就调团队列表接口
  536. this.getTeam(data.hospital, false)
  537. }
  538. this.searchFn()
  539. } else {
  540. this.init()
  541. }
  542. },
  543. renderHeader: function (h, item) {
  544. var label = item.column.label
  545. var column = item.column
  546. var tooltip = {
  547. '签约社区': '显示为该患者当前的签约社区医院名称',
  548. '社区医院': '显示为该患者当前的签约社区医院名称',
  549. '签约医院': '显示为该患者当前的签约社区医院名称',
  550. '签约医生': '显示为该患者当前的签约社区医生名称',
  551. '家庭医生': '显示为该患者当前的签约社区医生名称'
  552. }
  553. if (label == '签约社区' || label == '签约医生' || label == '签约医院' || label == '家庭医生' || label == '社区医院') {
  554. return [
  555. label,
  556. h(
  557. 'el-tooltip',
  558. {
  559. props: {
  560. content: (function () {
  561. return tooltip[label]
  562. })(),
  563. placement: 'top'
  564. }
  565. },
  566. [
  567. h('span', {
  568. class: {
  569. 'el-icon-question': true
  570. }
  571. })
  572. ]
  573. )
  574. ]
  575. } else {
  576. return [column.label]
  577. }
  578. }
  579. },
  580. mounted() {
  581. // this.init()
  582. }
  583. })