var template = '' $.ajax('../../../component/statistics/GxbManage/index.html', { data: {}, dataType: 'html', cache: false, timeout: 60000, async: false, error: function (res) {}, success: function (res) { template = res } }) Vue.component('gxb-manage', { template: template, props: [], data: function () { return { years: [], yearType: '1', chooseYear: null, chooseTime: null, rangeOptions: [ { label: '区', value: 'town' }, { label: '社区', value: 'hospital' }, { label: '团队', value: 'team' } ], areaOptions: [ { label: '思明区', value: '350203' }, { label: '海沧区', value: '350205' }, { label: '湖里区', value: '350206' }, { label: '集美区', value: '350211' }, { label: '同安区', value: '350212' }, { label: '翔安区', value: '350213' } ], hospitalOptions: [], teamOptions: [], form: { range: 'town' }, loading: false, exportLoading: false, tableData: [], tableHeader: [ { label: '名称', prop: 'name', width: '100' }, { label: '已评估人数', prop: 'totalNum', width: '90' }, { label: '已上转人数', prop: 'turnUpNum', width: '90' }, { label: '上转转门诊', prop: 'mzNum', width: '110' }, { label: '门诊转住院', prop: 'zyNum', width: '110' }, { label: '下转管理人数', prop: 'turnDownNum', width: '110' }, { label: '评估已登记随访', prop: 'followUpNum', width: '110' }, { label: '随访已达标', prop: 'standardNum', width: '110' } ], page: 1, size: 10, total: 0, level: 0 } }, methods: { init() { var selectedRole = JSON.parse(sessionStorage.getItem('selectedRole')) if (selectedRole.code.indexOf('350200') > -1) { this.level = 1 // 市卫健委 this.areaOptions = [ { label: '思明区', value: '350203' }, { label: '海沧区', value: '350205' }, { label: '湖里区', value: '350206' }, { label: '集美区', value: '350211' }, { label: '同安区', value: '350212' }, { label: '翔安区', value: '350213' } ] } else if (selectedRole.code.length == 6) { this.level = 2 // 区管理 this.areaOptions = [{ label: selectedRole.name.substring(0, 3), value: selectedRole.code }] this.form = { range: 'town', area: selectedRole.code } this.getHospital(selectedRole.code) } else { this.level = 3 // 社区管理 this.rangeOptions = [ { label: '社区', value: 'hospital' }, { label: '团队', value: 'team' } ] this.areaOptions = [{ label: selectedRole.name.substring(0, 3), value: selectedRole.code }] this.hospital = [{ label: selectedRole.name, value: selectedRole.code }] this.form = { range: 'hospital', area: selectedRole.code.substring(0, 6), hospital: selectedRole.code } this.getTeam(selectedRole.code) } this.initTime() this.getList() }, initTime() { var vm = this var now = new Date() vm.nowyear = vm.chooseYear = now.getFullYear() vm.years = [] for (i = vm.nowyear; i >= 2013; i--) { vm.years.push(i) } }, resetArea() { if (this.level == 1) { delete this.form.area delete this.form.hospital delete this.form.team } else if (this.level == 2) { delete this.form.hospital delete this.form.team } else { delete this.form.team } }, getList() { var vm = this this.loading = true var params = { ...this.form, page: this.page, pageSize: this.size } if (this.yearType == '1') { params.startDate = this.chooseYear + '-01-01 00:00' params.endDate = this.chooseYear + '-12-31 23:59' } else { if (this.chooseTime) { params.startDate = this.chooseTime[0] + ' 00:00' params.endDate = this.chooseTime[1] + ' 23:59' } } httpRequest.get('statistics/collaborate/gxbScreenClosedLoop', { data: params }).then(function (res) { if (res.status == 200) { vm.tableData = res.detailModelList vm.total = res.totalCount } vm.loading = false }) }, queryDate() { this.page = 1 this.getList() }, exportTable() { var vm = this var params = { ...this.form, page: this.page, pageSize: this.size } if (this.yearType == '1') { params.startDate = this.chooseYear + '-01-01' params.endDate = this.chooseYear + '-12-31' } else { if (this.chooseTime) { params.startDate = this.chooseTime[0] params.endDate = this.chooseTime[1] } } this.exportLoading = true var fileName = `冠心病管理全流程闭环情况${new Date().getTime()}.xls` httpRequest.downLoadFileForAjax('statistics/collaborate/exportGxbScreenClosedLoop', fileName, params).then(function () { vm.exportLoading = false }) }, eliminateClick() { this.resetArea() this.yearType = '1' this.chooseYear = new Date().getFullYear() this.chooseTime = null this.$forceUpdate() }, getHospital(code) { var vm = this delete this.form.hospital delete this.form.team var params = { type: 5, code: code } httpRequest.post('common/district', { data: params }).then(function (res) { vm.hospitalOptions = res.list }) }, getTeam(code) { var vm = this delete this.form.team var params = { hospital: code } httpRequest.get('statisticsExport/teamList', { data: params }).then(function (res) { vm.teamOptions = res.data }) }, handleCurrentChange(val) { this.page = val this.getList() }, handleSizeChange(val) { this.size = val this.getList() }, renderHeader: function (h, item) { var index = item.$index var column = item.column var content = { 3: '已上转人数', 4: '上转转门诊', 5: '门诊转住院', 6: '下转管理人数', 7: '评估已门诊下转', 8: '评估已出院下转' } var tooltip = { 3: '统计查询时间内,已筛查的患者中,预约了专科医院的患者人数', 4: '统计查询时间内,已上转的患者中,到院就诊的患者人数', 5: '统计查询时间内,已上转的患者中,到院就诊的患者人数', 6: '统计查询时间内,筛查时间在下转时间前的患者人数', 7: '统计查询时间内,筛查时间在门诊下转时间前的患者人数', 8: '统计查询时间内,筛查时间在出院下转时间前的患者人数' } if ([3, 4, 5, 6, 7, 8].indexOf(index) > -1) { return [ content[index], h( 'el-tooltip', { props: { content: (function () { return tooltip[index] })(), placement: 'top' } }, [ h('span', { class: { 'el-icon-question': true } }) ] ) ] } else { return [column.label] } } }, mounted() { this.init() } })