Procházet zdrojové kódy

1.新增异地医院管理情况统计UI页面

lifangpan před 2 dny
rodič
revize
a437c838bc

+ 33 - 24
app/statistics/html/comprehensive-query.html

@ -13,7 +13,7 @@
    <link rel="stylesheet" type="text/css" href="../../../css/cross.css" />
    <link rel="stylesheet" type="text/css" href="../../../css/flex.css" />
    <link rel="stylesheet" type="text/css" href="../../../css/element2.15/index.css" />
    <link rel="stylesheet" type="text/css" href="../../../css/element2.15/icon.css">
    <link rel="stylesheet" type="text/css" href="../../../css/element2.15/icon.css" />
    <link href="../../../plugins/toastr/toastr.min.css" rel="stylesheet" />
    <link rel="stylesheet" type="text/css" href="../css/common.css" />
    <link rel="stylesheet" type="text/css" href="../css/comprehensive-query.css" />
@ -54,14 +54,16 @@
                  node-key="id"
                  :props="defaultProps"
                  @node-click="treedataClick"
                  @check-change="treedataClick"></el-tree>
                  @check-change="treedataClick"
                ></el-tree>
              </template>
              <template v-if="tabsId == 2">
                <div
                  class="particulars"
                  v-for="(item,index) in detailInquire[0].children"
                  @click="handleNodeClick(item)"
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''">
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''"
                >
                  {{item.label}}
                </div>
                <!-- <el-tree highlight-current class="bgc-f2f3f5" :data="detailInquire" :props="defaultProps" @node-click="handleNodeClick"></el-tree> -->
@ -75,14 +77,16 @@
                  node-key="id"
                  :props="defaultProps"
                  @check-change="collectClick"
                  @check="collCheck"></el-tree>
                  @check="collCheck"
                ></el-tree>
              </template>
              <template v-if="tabsId == 4">
                <div
                  class="particulars"
                  v-for="(item,index) in treedataExpert"
                  @click="handleNodeClick(item,'zhuanke')"
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''">
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''"
                >
                  {{item.label}}
                </div>
                <!-- <el-tree class="bgc-f2f3f5" ref="collectTreeExpert"  :data="treedataExpert" show-checkbox node-key="id" :props="defaultProps"   @check-change="collectClick" @check='collCheck'>
@ -96,7 +100,8 @@
                  class="particulars"
                  v-for="(item,index) in mzfTabsData"
                  @click="handleNodeClick(item)"
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''">
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''"
                >
                  {{item.label}}
                </div>
                <!-- <el-tree highlight-current class="bgc-f2f3f5" :data="detailInquire" :props="defaultProps" @node-click="handleNodeClick"></el-tree> -->
@ -106,7 +111,8 @@
                  class="particulars"
                  v-for="(item,index) in mzfJcTabsData"
                  @click="handleNodeClick(item, 7)"
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''">
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''"
                >
                  {{item.label}}
                </div>
                <div class="copd-filter-option-list" v-if="handleNodeId == 64">
@ -120,7 +126,8 @@
                  class="particulars"
                  v-for="(item,index) in jtbcTabsData"
                  @click="handleNodeClick(item)"
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''">
                  :style="handleNodeId==item.id?'background-color: #409eff;color:#fff;':''"
                >
                  {{item.label}}
                </div>
              </template>
@ -129,24 +136,19 @@
                  class="particulars"
                  v-for="(item,index) in gxbTabsData"
                  @click="handleNodeClick(item)"
                  :style="{'background-color':handleNodeId==item.id?'#409eff':'',color:handleNodeId==item.id?'#fff':'','padding-left': ['77','78','79','80','81'].includes(item.id) ?'30px':''}">
                  :style="{'background-color':handleNodeId==item.id?'#409eff':'',color:handleNodeId==item.id?'#fff':'','padding-left': ['77','78','79','80','81'].includes(item.id) ?'30px':''}"
                >
                  {{item.label}}
                </div>
              </template>
              <template v-if="tabsId == 10">
                <el-tree
                  class="bgc-f2f3f5"
                  ref="collectTree"
                  :data="jkjlbTabsTree"
                  show-checkbox
                  node-key="id"
                  :props="defaultProps"
                  @check="jkjlbCheck"></el-tree>
                  <div
                <el-tree class="bgc-f2f3f5" ref="collectTree" :data="jkjlbTabsTree" show-checkbox node-key="id" :props="defaultProps" @check="jkjlbCheck"></el-tree>
                <div
                  class="particulars"
                  v-for="(item,index) in jkjlbTabsData"
                  @click="handleNodeClick(item)"
                  :style="{'background-color':handleNodeId==item.id?'#409eff':'',color:handleNodeId==item.id?'#fff':''}">
                  :style="{'background-color':handleNodeId==item.id?'#409eff':'',color:handleNodeId==item.id?'#fff':''}"
                >
                  {{item.label}}
                </div>
              </template>
@ -172,7 +174,8 @@
                    value-format="yyyy-MM-dd"
                    style="width: 140px"
                    :clearable="false"
                    :picker-options="pickerOptions"></el-date-picker>
                    :picker-options="pickerOptions"
                  ></el-date-picker>
                  <span class="c-999">-</span>
                  <el-date-picker
                    v-model="end"
@ -182,7 +185,8 @@
                    value-format="yyyy-MM-dd"
                    style="width: 140px"
                    :clearable="false"
                    :picker-options="pickerOptions"></el-date-picker>
                    :picker-options="pickerOptions"
                  ></el-date-picker>
                </div>
              </template>
              <template v-if="tabsId==2">
@ -642,7 +646,8 @@
                    style="width: 100%"
                    v-loading="loadingTwo"
                    class="mt20"
                    v-if="handleNodeId==34 || handleNodeId==35 || handleNodeId==36 || handleNodeId==37 || handleNodeId==38">
                    v-if="handleNodeId==34 || handleNodeId==35 || handleNodeId==36 || handleNodeId==37 || handleNodeId==38"
                  >
                    <el-table-column fixed type="index" label="序号" width="50" min-width="50" align="center"></el-table-column>
                    <el-table-column prop="hospitalName" label="社区名称" align="center"></el-table-column>
@ -835,6 +840,7 @@
                  <activity-hold-detail v-if="handleNodeId == 95"></activity-hold-detail>
                  <activity-register-detail v-if="handleNodeId == 96"></activity-register-detail>
                  <resident-score-detail v-if="handleNodeId == 97"></resident-score-detail>
                  <outside-hospital-manage v-if="handleNodeId == 99"></outside-hospital-manage>
                </div>
                <div v-if="handleNodeShow == 3">
                  <el-table v-if="collectCode == 1" border :data="diseaseReport" style="width: 100%" v-loading="loadingTwo" class="mt20">
@ -844,7 +850,8 @@
                      :prop="item"
                      :label="index==0?diseaseHeader[index]:''"
                      :render-header="index==0?'': renderTableHeader"
                      align="center"></el-table-column>
                      align="center"
                    ></el-table-column>
                  </el-table>
                  <el-table v-if="collectCode == 2" border :data="getDeviceReport" style="width: 100%" v-loading="loadingTwo" class="mt20">
                    <el-table-column v-if="getDeviceReport.length!=0" type="index" label="序号" align="center"></el-table-column>
@ -896,7 +903,8 @@
                      :current-page.sync="currentPage"
                      :page-size="currentSize"
                      layout="total, prev, pager, next, jumper"
                      :total="datatotal"></el-pagination>
                      :total="datatotal"
                    ></el-pagination>
                  </div>
                </template>
              </div>
@ -981,5 +989,6 @@
    <script src="../../../component/statistics/ActivityRegisterDetail/index.js" type="text/javascript" charset="utf-8"></script>
    <script src="../../../component/statistics/ResidentScoreDetail/index.js" type="text/javascript" charset="utf-8"></script>
    <script src="../../../component/statistics/MoneyRewardDetail/index.js" type="text/javascript" charset="utf-8"></script>
    <script src="../../../component/statistics/OutsideHospitalManage/index.js" type="text/javascript" charset="utf-8"></script>
  </body>
</html>

+ 219 - 254
app/statistics/js/comprehensive-query.js

@ -10,11 +10,7 @@ new Vue({
    searchStr: 1,
    end: '',
    tabledata: [], //表格数据
    levelList: [
      { level: '4', areaLevel: '2' },
      { level: '3', areaLevel: '3' },
      { level: '2', areaLevel: '4' }
    ], //两种搜索,地区等级对比
    levelList: [{ level: '4', areaLevel: '2' }, { level: '3', areaLevel: '3' }, { level: '2', areaLevel: '4' }], //两种搜索,地区等级对比
    areaLevel: '', // 2、市,3、区,4、社区,5、团队
    initareaLevel: '',
    initlevel: '',
@ -36,7 +32,7 @@ new Vue({
      label: 'label'
    },
    pickerOptions: {
      disabledDate: function (time) {
      disabledDate: function(time) {
        return time.getTime() > Date.now()
      }
    },
@ -92,11 +88,7 @@ new Vue({
      { label: '第二阶段社区医院随访进度', id: '61' },
      { label: '第二阶段三级医院随访进度及出组情况', id: '62' }
    ],
    mzfJcTabsData: [
      { label: '慢阻肺患者档案', id: '63' },
      { label: '服务人数配置及进度查询', id: '66' },
      { label: '管理情况自助查询', id: '64' }
    ],
    mzfJcTabsData: [{ label: '慢阻肺患者档案', id: '63' }, { label: '服务人数配置及进度查询', id: '66' }, { label: '管理情况自助查询', id: '64' }],
    // 慢阻肺管理情况自处查询字段列表
    copdManageSearchFilterList: [
      {
@ -194,7 +186,8 @@ new Vue({
      { label: '康复随访详情', id: '86' },
      { label: '康复下转明细', id: '87' },
      { label: '签约情况统计', id: '82' },
      { label: '消息推送明细', id: '89' }
      { label: '消息推送明细', id: '89' },
      { label: '异地医院管理情况统计', id: '99' }
    ],
    jkjlbTabsTree: [
      {
@ -259,12 +252,7 @@ new Vue({
        ]
      }
    ],
    jkjlbTabsData: [
      { label: '活动举办明细', id: '95' },
      { label: '居民活动报名明细', id: '96' },
      { label: '居民积分明细', id: '97' },
      { label: '居民红包奖励明细', id: '90' }
    ],
    jkjlbTabsData: [{ label: '活动举办明细', id: '95' }, { label: '居民活动报名明细', id: '96' }, { label: '居民积分明细', id: '97' }, { label: '居民红包奖励明细', id: '90' }],
    jkjlbList: [],
    copdFilterCheckValue: [],
    handleNodeShow: 1,
@ -473,11 +461,7 @@ new Vue({
      { value: '2', label: '已完成' },
      { value: '3', label: '未回复' }
    ],
    inviteStatus1: [
      { value: '', label: '全部' },
      { value: '1', label: '门诊患者' },
      { value: '2', label: '出院患者' }
    ],
    inviteStatus1: [{ value: '', label: '全部' }, { value: '1', label: '门诊患者' }, { value: '2', label: '出院患者' }],
    recoveryList: [],
    dialogVisible: false,
    signatoryList: [],
@ -521,10 +505,7 @@ new Vue({
        id: 'xzrs,jsxzrs',
        label: '下转接收统计',
        code: '3',
        children: [
          { id: 'xzrs', label: '下转人数', code: '3' },
          { id: 'jsxzrs', label: '接收下转人数', code: '3' }
        ]
        children: [{ id: 'xzrs', label: '下转人数', code: '3' }, { id: 'jsxzrs', label: '接收下转人数', code: '3' }]
      },
      {
        id: 'v1sxrs,v2rzrs,v3rs,v4rs,v5rs,v6rs,zgrs,tlzls',
@ -563,7 +544,7 @@ new Vue({
    datatotal: 0, //总数
    loadingTwo: false,
    setDisabled: {
      disabledDate: function (time) {
      disabledDate: function(time) {
        return time.getTime() < new Date('2023', '05', '26') || time.getTime() > Date.now()
      }
    },
@ -641,7 +622,7 @@ new Vue({
    vuedals: Vuedals.Component
  },
  watch: {
    rangeCode: function (val) {
    rangeCode: function(val) {
      var vm = this
      if (vm.initlevel != 2) {
        vm.communityCode = ''
@ -649,16 +630,16 @@ new Vue({
      vm.teamCode = ''
      vm.getTreeList()
    },
    areaCode: function (val) {
    areaCode: function(val) {
      var vm = this
      vm.selChange(3)
    },
    communityCode: function (val) {
    communityCode: function(val) {
      var vm = this
      vm.selChange(5)
    },
    'startTime': {
      handler: function (o) {
    startTime: {
      handler: function(o) {
        if (!o) {
          this.list.splice(0, 1)
        }
@ -666,8 +647,8 @@ new Vue({
      deep: true,
      immediate: true
    },
    'endTime': {
      handler: function (o) {
    endTime: {
      handler: function(o) {
        if (!o) {
          this.list.splice(0, 1)
        }
@ -676,7 +657,7 @@ new Vue({
      immediate: true
    }
  },
  mounted: function () {
  mounted: function() {
    var vm = this
    //初始化数据
    var searchStr = location.search
@ -690,18 +671,18 @@ new Vue({
    vm.getfwDictName()
    vm.getDiseaseTypeList()
    vm.height = document.body.offsetHeight - 85
    window.onresize = function () {
    window.onresize = function() {
      vm.height = document.body.offsetHeight - 85
    }
    this.s = this.startTime.format('yyyy-MM-dd')
    this.e = this.endTime.format('yyyy-MM-dd')
    this.list.unshift({ type: '0', id: 'time', label: this.s + '~' + this.e })
    for (var i = 46; i <= 98; i++) {
    for (var i = 46; i <= 99; i++) {
      this.componentId.push(i + '')
    }
    EventBus.$on('toPage', function (data) {
    EventBus.$on('toPage', function(data) {
      vm.handleNodeId = data.id
      vm.$nextTick(function () {
      vm.$nextTick(function() {
        if (vm.handleNodeId == 77) {
          vm.$refs.gxbEvaluation.getData(data)
        } else if (vm.handleNodeId == 78) {
@ -713,7 +694,7 @@ new Vue({
        }
      })
    })
    EventBus.$on('preview-person-info', function (data) {
    EventBus.$on('preview-person-info', function(data) {
      vm.$refs.personInfo.openDialog(data)
    })
  },
@ -724,18 +705,18 @@ new Vue({
  methods: {
    getfwDictName() {
      var vm = this
      statisticAPI.getDictByDictName({ name: 'health_bank_service_type' }).then(function (res) {
      statisticAPI.getDictByDictName({ name: 'health_bank_service_type' }).then(function(res) {
        vm.health_bank_service_type = res.list
      })
    },
    //获取综合查询指标
    getQuotaStr() {
      var vm = this
      statisticAPI.getDictByDictName({ name: 'jkcopd_quotaStr' }).then(function (res) {
      statisticAPI.getDictByDictName({ name: 'jkcopd_quotaStr' }).then(function(res) {
        vm.copdManageSearchFilterList = res.list
      })
    },
    startTimeChange: function (o) {
    startTimeChange: function(o) {
      if (!this.list[0] || this.list[0].type != 0) {
        this.list.unshift({
          type: '0',
@ -746,7 +727,7 @@ new Vue({
        this.list[0].label = o.format('yyyy-MM-dd') + '~' + this.endTime.format('yyyy-MM-dd')
      }
    },
    endTimeChange: function (o) {
    endTimeChange: function(o) {
      if (!this.list[0] || this.list[0].type != 0) {
        this.list.unshift({
          type: '0',
@ -758,27 +739,27 @@ new Vue({
      }
    },
    // 确定
    confirm: function () {
    confirm: function() {
      this.hospitalWorkStatistics()
    },
    // 选择
    change: function (val) {
    change: function(val) {
      this.list = this.list.concat(val)
    },
    // 已选
    deleteClick: function (item) {
    deleteClick: function(item) {
      if (item.id == 'time') {
        this.startTime = ''
        this.endTime = ''
        this.list.splice(0, 1)
      }
      var index = this.list.findIndex(function (v) {
      var index = this.list.findIndex(function(v) {
        return item.id == v.id
      })
      this.list.splice(index, 1)
    },
    // 取消
    cancel: function () {
    cancel: function() {
      this.startTime = new Date('2023', '05', '26')
      this.endTime = new Date()
      if (!this.list[0] || this.list[0].type != 0) {
@ -792,7 +773,7 @@ new Vue({
      }
    },
    // 导出
    exportHandle: function () {
    exportHandle: function() {
      var vm = this
      vm.loadingTwo = true
      statisticAPI
@ -803,11 +784,11 @@ new Vue({
          },
          '慢阻肺综合查询表.xls'
        )
        .then(function (res) {
        .then(function(res) {
          vm.loadingTwo = false
        })
    },
    renderTableHeader: function (h, item) {
    renderTableHeader: function(h, item) {
      var $index = item.$index
      return h('div', [
        h('span', this.diseaseHeader[$index - 1] + '  ', {
@ -837,7 +818,7 @@ new Vue({
        )
      ])
    },
    renderHeadeRexpert: function (h, item) {
    renderHeadeRexpert: function(h, item) {
      var index = item.$index
      return [
        index == '3'
@ -857,7 +838,7 @@ new Vue({
          'el-tooltip',
          {
            props: {
              content: (function () {
              content: (function() {
                return index == '3'
                  ? '发起邀请总次数'
                  : index == ''
@ -886,12 +867,12 @@ new Vue({
      ]
    },
    // 获取康复下转明细 ---  下转状态
    deorsumvergenceStatusFunction: function (name) {
    deorsumvergenceStatusFunction: function(name) {
      var vm = this
      signAPI.getDictByDictName({ name: name }).then(function (res) {
      signAPI.getDictByDictName({ name: name }).then(function(res) {
        if (res.status === 200) {
          if (name == 'rehabilitation_status') {
            res.list.forEach(function (v) {
            res.list.forEach(function(v) {
              vm.deorsumvergence.push({
                value: v.code,
                label: v.value
@ -899,7 +880,7 @@ new Vue({
            })
          }
          if (name == 'rehabilitation_hospital') {
            res.list.forEach(function (v) {
            res.list.forEach(function(v) {
              vm.rehabilitationHospital.push({
                value: v.code,
                label: v.value
@ -907,7 +888,7 @@ new Vue({
            })
          }
          if (name == 'archive_status') {
            res.list.forEach(function (v) {
            res.list.forEach(function(v) {
              vm.archiveList.push({
                value: v.code,
                label: v.value
@ -918,16 +899,16 @@ new Vue({
      })
    },
    // 获取社区医院
    hospitalsByType: function () {
    hospitalsByType: function() {
      var vm = this
      statisticAPI
        .hospitalsByType({
          type: 1,
          code: '350200'
        })
        .then(function (res) {
        .then(function(res) {
          if (res.status == 200) {
            res.list.forEach(function (v) {
            res.list.forEach(function(v) {
              vm.communityHospitals.push({
                value: v.code,
                label: v.name
@ -935,17 +916,17 @@ new Vue({
            })
          }
        })
        .catch(function (err) {
        .catch(function(err) {
          console.log(err, 'Errr')
        })
    },
    // 康复下转操作
    operation: function (num, item) {
    operation: function(num, item) {
      var vm = this
      if (num != 2) {
        statisticAPI
          .synchronizePationSingle({ id: item.id })
          .then(function (res) {
          .then(function(res) {
            if (res.status == 200) {
              toastr.info('操作成功')
              this.tableKey = Math.random()
@ -953,31 +934,31 @@ new Vue({
              toastr.error(res.msg)
            }
          })
          .catch(function (err) {
          .catch(function(err) {
            console.log(err, 'Errr')
          })
      } else {
        vm.signatoryList = []
        statisticAPI
          .kangfuGetSignInfo({ idcard: item.idcard })
          .then(function (res) {
          .then(function(res) {
            if (res.status == 200) {
              if (res.data != null) {
                vm.signatoryList.push(res.data)
              }
            }
          })
          .catch(function (err) {
          .catch(function(err) {
            console.log(err, 'Errr')
          })
        this.dialogVisible = true
      }
    },
    getImgurl: function (url) {
    getImgurl: function(url) {
      var imgUrl = url && url.split(',')[0]
      return httpRequest.getImgUrl(imgUrl)
    },
    reset: function () {
    reset: function() {
      if (this.tabsId == 1) {
        this.getTreeList()
      } else {
@ -1026,7 +1007,7 @@ new Vue({
      }
    },
    // 清除
    eliminateClick: function () {
    eliminateClick: function() {
      this.radio = this.handleNodeId == 44 || this.expertFamilyIdType == 'zhuanke1' || this.handleNodeId == 45 ? '2' : '1'
      this.radio1 = ''
      this.radio2 = ''
@ -1111,7 +1092,7 @@ new Vue({
      // initTime(this)
      // initScope(this)
    },
    tabsClick: function (item) {
    tabsClick: function(item) {
      var vm = this
      this.collectCode = ''
      this.copdFilterCheckValue = []
@ -1122,7 +1103,7 @@ new Vue({
      if (item.id == 5) {
        vm.handleNodeShow = 5
      }
      vm.tabsList.forEach(function (res) {
      vm.tabsList.forEach(function(res) {
        if (res.id == item.id) {
          res.show = true
        } else {
@ -1132,42 +1113,42 @@ new Vue({
      vm.eliminateClick()
    },
    // 获取汇总数据的专科医院
    specHosData: function () {
    specHosData: function() {
      var vm = this
      statisticAPI.getSpecialHospital().then(function (res) {
      statisticAPI.getSpecialHospital().then(function(res) {
        if (res.status == 200) {
          res.data.forEach(function (item) {
          res.data.forEach(function(item) {
            vm.specHosList.push({ code: item.code, name: item.name })
          })
        }
      })
    },
    getDiseaseTypeList: function () {
    getDiseaseTypeList: function() {
      var vm = this
      statisticAPI.getDiseaseTypeList({}).then(function (res) {
      statisticAPI.getDiseaseTypeList({}).then(function(res) {
        if (res.status == 200) {
          vm.specialCities = res.list
        }
      })
    },
    // 签约人群
    handleCheckedCitiesChange: function (value) {
    handleCheckedCitiesChange: function(value) {
      var vm = this
      vm.handleData = value
    },
    // 下转病种
    diseaseChange: function (value) {
    diseaseChange: function(value) {
      var vm = this
      vm.diseaseData = value
    },
    // 服务类型
    serviceTypeChange: function (value) {
    serviceTypeChange: function(value) {
      var vm = this
      vm.serviceTypeData = value
    },
    // 综合析树形图
    treedataClick: function (name, data) {
    treedataClick: function(name, data) {
      var vm = this
      vm.handleNodeShow = 1
      vm.handleNodeId = 0
@ -1177,7 +1158,7 @@ new Vue({
      // initScope(vm)
    },
    // 汇总树形图
    collectClick: function (data, isCheck) {
    collectClick: function(data, isCheck) {
      var vm = this
      vm.derive = data.label
@ -1186,13 +1167,13 @@ new Vue({
      vm.radio = '1' //签约年度  --创建时间
      vm.isCheck = isCheck
    },
    collCheck: function (data, name) {
    collCheck: function(data, name) {
      // console.log(arguments)
      var vm = this
      vm.diseaseReport = []
      vm.datatotal = 0
      vm.collect.forEach(function (item) {
        item.children.forEach(function (o) {
      vm.collect.forEach(function(item) {
        item.children.forEach(function(o) {
          if (o.code != data.code) {
            vm.$refs.collectTree.setChecked(o, false, true)
          }
@ -1200,7 +1181,7 @@ new Vue({
        if (data.id == item.id) {
          vm.$refs.collectTree.setChecked(item, vm.isCheck, true)
        } else {
          item.children.forEach(function (o) {
          item.children.forEach(function(o) {
            if (data.id == o.id) {
              vm.$refs.collectTree.setChecked(o, vm.isCheck, true)
            }
@ -1211,24 +1192,12 @@ new Vue({
      vm.handleNodeId = 'huizongshuju'
      vm.collectCode = data.code
      if (data.code == 1) {
        vm.rangeList = [
          { name: '按区', code: 'town' },
          { name: '按社区', code: 'hospital' },
          { name: '按团队', code: 'team' },
          { name: '按专科医院', code: 'specHos' }
        ]
        vm.rangeList = [{ name: '按区', code: 'town' }, { name: '按社区', code: 'hospital' }, { name: '按团队', code: 'team' }, { name: '按专科医院', code: 'specHos' }]
        vm.specHosData()
      } else if (data.code == 4) {
        vm.rangeList = [
          { name: '按区', code: 'town' },
          { name: '按社区', code: 'hospital' }
        ]
        vm.rangeList = [{ name: '按区', code: 'town' }, { name: '按社区', code: 'hospital' }]
      } else {
        vm.rangeList = [
          { name: '按区', code: 'town' },
          { name: '按社区', code: 'hospital' },
          { name: '按团队', code: 'team' }
        ]
        vm.rangeList = [{ name: '按区', code: 'town' }, { name: '按社区', code: 'hospital' }, { name: '按团队', code: 'team' }]
      }
    },
    // jkjlbClick(data, isCheck) {},
@ -1240,27 +1209,27 @@ new Vue({
      this.handleNodeId = data.code
      vm.handleNodeShow = 2 //  明细查询tabs为2
      vm.jkjlbTabsTree.forEach(function (item) {
        item.children.forEach(function (o) {
      vm.jkjlbTabsTree.forEach(function(item) {
        item.children.forEach(function(o) {
          if (o.code != data.code) {
            vm.$refs.collectTree.setChecked(o, false, true)
          }
        })
      })
      this.$nextTick(function () {
        vm.jkjlbList = vm.$refs.collectTree.getCheckedNodes().filter(function (item) {
      this.$nextTick(function() {
        vm.jkjlbList = vm.$refs.collectTree.getCheckedNodes().filter(function(item) {
          return item.root != true
        })
      })
    },
    // 点击明细查询树形图
    handleNodeClick: function (item, type) {
    handleNodeClick: function(item, type) {
      var vm = this
      vm.jkjlbList = []
      vm.jkjlbTabsTree.forEach(function (item) {
        item.children.forEach(function (o) {
          if(vm.$refs.collectTree) vm.$refs.collectTree.setChecked(o, false, true)
      vm.jkjlbTabsTree.forEach(function(item) {
        item.children.forEach(function(o) {
          if (vm.$refs.collectTree) vm.$refs.collectTree.setChecked(o, false, true)
        })
      })
      vm.copdFilterCheckValue = []
@ -1363,7 +1332,7 @@ new Vue({
      //   EventBus.$emit('jtbc-table-page', { type, id: item.id })
      //   console.log('家庭病床')
      // }
      vm.$nextTick(function () {
      vm.$nextTick(function() {
        if (vm.handleNodeId == 77) {
          vm.$refs.gxbEvaluation.getData()
        } else if (vm.handleNodeId == 78) {
@ -1375,14 +1344,14 @@ new Vue({
        }
      })
    },
    expertFamily: function (id) {
    expertFamily: function(id) {
      var vm = this
      if (id == '1') {
        vm.expertReplyList()
      }
    },
    // 邀请专科回复统计传参
    expertReply: function () {
    expertReply: function() {
      var vm = this
      vm.searchJsonTime = vm.beforeReq()
      return {
@ -1398,10 +1367,10 @@ new Vue({
      }
    },
    // 邀请专科回复统计列表
    expertReplyList: function () {
    expertReplyList: function() {
      var vm = this
      vm.loadingTwo = true
      statisticAPI.consultHelpCountPage(vm.expertReply()).then(function (res) {
      statisticAPI.consultHelpCountPage(vm.expertReply()).then(function(res) {
        if (res.status == 200) {
          vm.expertReplyData = res.detailModelList
          vm.datatotal = res.totalCount
@ -1410,24 +1379,24 @@ new Vue({
      })
    },
    analysFunction: function (id) {
    analysFunction: function(id) {
      var vm = this
      // idcard =  idcard.replace(/^(.{6})(?:\d+)(.{4})$/,"$1****$2")    身份证 医保卡 脱敏显示
      vm.detailFunction(id)
    },
    // 下转预约获取医生,科室
    getReservationHosAndDept: function (data) {
    getReservationHosAndDept: function(data) {
      var vm = this
      statisticAPI
        .getReservationHosAndDept({
          hospital: data ? data : '',
          type: data ? '2' : ''
        })
        .then(function (res) {
        .then(function(res) {
          if (res.status == 200) {
            if (data) {
              vm.administrativeOffice = []
              res.data.forEach(function (item) {
              res.data.forEach(function(item) {
                vm.administrativeOffice.push({
                  value: item.code,
                  label: item.name
@ -1435,7 +1404,7 @@ new Vue({
              })
            } else {
              vm.hospitalData = []
              res.data.forEach(function (item) {
              res.data.forEach(function(item) {
                vm.hospitalData.push({
                  value: item.code,
                  label: item.name
@ -1445,13 +1414,13 @@ new Vue({
          }
        })
    },
    hospitalChange: function (data) {
    hospitalChange: function(data) {
      var vm = this
      vm.getReservationHosAndDept(data)
    },
    // 咨询分析
    getConsultList: function () {
    getConsultList: function() {
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'statisticsExport/getConsultList'
@ -1468,7 +1437,7 @@ new Vue({
          pageSize: vm.currentSize,
          page: vm.currentPage
        })
        .then(function (res) {
        .then(function(res) {
          // console.log(res,"咨询分析")
          if (res.status == 200) {
            vm.analyseData = res.data.list
@ -1482,13 +1451,13 @@ new Vue({
        })
    },
    // 签约分析
    getSignList: function () {
    getSignList: function() {
      var vm = this
      vm.lastAjax = 'statisticsExport/getSignList'
      vm.loadingTwo = true
      var handleDataList = []
      vm.serverType = ''
      vm.handleData.forEach(function (res) {
      vm.handleData.forEach(function(res) {
        handleDataList.push(res.num)
      })
      vm.serverType = handleDataList.join(',')
@ -1511,10 +1480,10 @@ new Vue({
          pageSize: vm.currentSize,
          page: vm.currentPage
        })
        .then(function (res) {
        .then(function(res) {
          // console.log(res,"签约分析")
          if (res.status == 200) {
            res.data.list.forEach(function (item) {
            res.data.list.forEach(function(item) {
              item.sscNum = item.sscNum.replace(/^(.{4})(?:\d+)(.{1})$/, '$1****$2')
              item.idcardNum = item.idcardNum.replace(/^(.{6})(?:\d+)(.{4})$/, '$1****$2')
            })
@ -1529,14 +1498,14 @@ new Vue({
        })
    },
    // 专病分析
    getSickList: function () {
    getSickList: function() {
      var vm = this
      // vm.diseaseData
      vm.lastAjax = 'statisticsExport/getSickList'
      vm.loadingTwo = true
      var handleDataList = []
      vm.diseaseDataType = ''
      vm.diseaseData.forEach(function (res) {
      vm.diseaseData.forEach(function(res) {
        handleDataList.push(res.code)
      })
      vm.diseaseDataType = handleDataList.join(',')
@ -1558,10 +1527,10 @@ new Vue({
          page: vm.currentPage,
          patientType: vm.form2.patientType
        })
        .then(function (res) {
        .then(function(res) {
          // console.log(res,"专病分析")
          if (res.status == 200) {
            res.data.list.forEach(function (item) {
            res.data.list.forEach(function(item) {
              item.sscNum = item.sscNum.replace(/^(.{4})(?:\d+)(.{1})$/, '$1****$2')
              item.idcardNum = item.idcardNum.replace(/^(.{6})(?:\d+)(.{4})$/, '$1****$2')
            })
@ -1576,7 +1545,7 @@ new Vue({
        })
    },
    // 生日祝福分析明细
    getBirthdayPatientList: function () {
    getBirthdayPatientList: function() {
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'statisticsExport/getBirthdayPatientList'
@ -1595,10 +1564,10 @@ new Vue({
          pageSize: vm.currentSize,
          page: vm.currentPage
        })
        .then(function (res) {
        .then(function(res) {
          if (res.status == 200) {
            // console.log(res,"Sddddd")
            res.data.detailModelList.forEach(function (item) {
            res.data.detailModelList.forEach(function(item) {
              item.ssc = item.ssc.replace(/^(.{4})(?:\d+)(.{1})$/, '$1****$2')
              item.idcard = item.idcard.replace(/^(.{6})(?:\d+)(.{4})$/, '$1****$2')
            })
@ -1613,7 +1582,7 @@ new Vue({
        })
    },
    // 长处方分析明细
    getPrescriptionList: function () {
    getPrescriptionList: function() {
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'statisticsExport/getPrescriptionList'
@ -1634,9 +1603,9 @@ new Vue({
          pageSize: vm.currentSize,
          page: vm.currentPage
        })
        .then(function (res) {
        .then(function(res) {
          if (res.status == 200) {
            res.data.detailModelList.forEach(function (item) {
            res.data.detailModelList.forEach(function(item) {
              // console.log(item.finish_time,"长处方分析")
              item.ssc = item.ssc.replace(/^(.{4})(?:\d+)(.{1})$/, '$1****$2')
              item.idcard = item.idcard.replace(/^(.{6})(?:\d+)(.{4})$/, '$1****$2')
@ -1652,13 +1621,13 @@ new Vue({
        })
    },
    // 上门服务分析明细
    getDoorServiceList: function () {
    getDoorServiceList: function() {
      var vm = this
      vm.lastAjax = ''
      vm.loadingTwo = true
      var handleDataList = []
      vm.serviceTypeDataType = 'statisticsExport/getDoorServiceList'
      vm.serviceTypeData.forEach(function (res) {
      vm.serviceTypeData.forEach(function(res) {
        handleDataList.push(res.num)
      })
      vm.serviceTypeDataType = handleDataList.join(',')
@ -1678,10 +1647,10 @@ new Vue({
          pageSize: vm.currentSize,
          page: vm.currentPage
        })
        .then(function (res) {
        .then(function(res) {
          if (res.status == 200) {
            // console.log(res,"上门服务分析明细")
            res.data.detailModelList.forEach(function (item) {
            res.data.detailModelList.forEach(function(item) {
              item.ssc = item.ssc.replace(/^(.{4})(?:\d+)(.{1})$/, '$1****$2')
              item.idcard = item.idcard.replace(/^(.{6})(?:\d+)(.{4})$/, '$1****$2')
            })
@ -1696,7 +1665,7 @@ new Vue({
        })
    },
    //体征数据分析传参
    getHealthParameter: function () {
    getHealthParameter: function() {
      var vm = this
      return {
        signYear: vm.radio == '1' ? vm.chooseYear : '', //签约年度
@ -1715,11 +1684,11 @@ new Vue({
      }
    },
    //体征数据分析
    physicalSignData: function () {
    physicalSignData: function() {
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'statisticsExport/getHealthList'
      statisticAPI.getHealthList(vm.getHealthParameter()).then(function (res) {
      statisticAPI.getHealthList(vm.getHealthParameter()).then(function(res) {
        if (res.status == 200) {
          // console.log(res,"体征数据")
          vm.getHealthData = res.data.detailModelList
@ -1733,7 +1702,7 @@ new Vue({
      })
    },
    //上转预约传参
    reservationParameter: function () {
    reservationParameter: function() {
      var vm = this
      return {
        signYear: vm.radio == '1' ? vm.chooseYear : '', //签约年度
@ -1753,11 +1722,11 @@ new Vue({
      }
    },
    // 上转预约
    upTransferAppointment: function () {
    upTransferAppointment: function() {
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'statisticsExport/getDoctorReservationList'
      statisticAPI.getDoctorReservationList(vm.reservationParameter()).then(function (res) {
      statisticAPI.getDoctorReservationList(vm.reservationParameter()).then(function(res) {
        if (res.status == 200) {
          // console.log(res,"上转预约")
          vm.reservationData = res.data.detailModelList
@ -1772,7 +1741,7 @@ new Vue({
      })
    },
    //微信绑定传参
    wexinBindingParameter: function () {
    wexinBindingParameter: function() {
      var vm = this
      return {
        signYear: vm.radio == '1' ? vm.chooseYear : '', //签约年度
@ -1788,14 +1757,14 @@ new Vue({
      }
    },
    // 微信绑定
    wechatBinding: function () {
    wechatBinding: function() {
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'statisticsExport/getWexinBindingList'
      statisticAPI.getWexinBindingList(vm.wexinBindingParameter()).then(function (res) {
      statisticAPI.getWexinBindingList(vm.wexinBindingParameter()).then(function(res) {
        if (res.status == 200) {
          // console.log(res,"微信绑定")
          res.data.detailModelList.forEach(function (res) {
          res.data.detailModelList.forEach(function(res) {
            res.sex = res.sex == 1 ? '男' : '女'
            res.apply_date = new Date(res.apply_date).format('yyyy-MM-dd HH:mm:ss')
          })
@ -1810,7 +1779,7 @@ new Vue({
      })
    },
    // 居民积分明细传参
    residentIntegralParameter: function () {
    residentIntegralParameter: function() {
      var vm = this
      var parameter = {
        signYear: vm.radio == '1' ? vm.chooseYear : '', //签约年度
@ -1828,14 +1797,14 @@ new Vue({
      return parameter
    },
    // 居民积分明细
    residentIntegral: function () {
    residentIntegral: function() {
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'statisticsExport/patinetIntegralAnalysis'
      statisticAPI.patinetIntegralAnalysis(vm.residentIntegralParameter()).then(function (res) {
      statisticAPI.patinetIntegralAnalysis(vm.residentIntegralParameter()).then(function(res) {
        if (res.status == 200) {
          vm.loadingTwo = false
          res.data.list.forEach(function (item) {
          res.data.list.forEach(function(item) {
            item.ssc = item.ssc.replace(/^(.{4})(?:\d+)(.{1})$/, '$1****$2')
            // item.idcard = item.idcard.replace(/^(.{6})(?:\d+)(.{4})$/,"$1****$2")
          })
@ -1847,7 +1816,7 @@ new Vue({
        }
      })
    },
    patientFeeAnalysisParams: function () {
    patientFeeAnalysisParams: function() {
      var vm = this
      var parameter = {
        signYear: vm.radio == '1' ? vm.chooseYear : '', //签约年度
@ -1868,7 +1837,7 @@ new Vue({
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'doctor/healthBank/patientFeeAnalysis'
      statisticAPI.patientFeeAnalysis(vm.patientFeeAnalysisParams()).then(function (res) {
      statisticAPI.patientFeeAnalysis(vm.patientFeeAnalysisParams()).then(function(res) {
        if (res.status == 200) {
          vm.loadingTwo = false
          vm.redPacketData = res.data.list
@ -1880,7 +1849,7 @@ new Vue({
      })
    },
    // 入户访视明细传参
    interviewParameter: function () {
    interviewParameter: function() {
      var vm = this
      var parameter = {
        // signYear:'2020',     //签约年度
@ -1899,11 +1868,11 @@ new Vue({
      return parameter
    },
    // 入户访视
    interview: function () {
    interview: function() {
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'statisticsExport/findPatientFollowListByCondition'
      statisticAPI.findPatientFollowListByCondition(vm.interviewParameter()).then(function (res) {
      statisticAPI.findPatientFollowListByCondition(vm.interviewParameter()).then(function(res) {
        if (res.status == 200) {
          vm.loadingTwo = false
          vm.ruhuData = res.data.list
@ -1915,7 +1884,7 @@ new Vue({
      })
    },
    //邀请专科回复明细传参
    invitationDetailsParameter: function () {
    invitationDetailsParameter: function() {
      var vm = this
      vm.searchJsonTime = vm.beforeReq()
      var parameter = {
@ -1937,13 +1906,13 @@ new Vue({
      return parameter
    },
    //邀请专科回复明细列表
    invitationDetails: function () {
    invitationDetails: function() {
      var vm = this
      vm.loadingTwo = true
      statisticAPI.consultHelpDetailPage(vm.invitationDetailsParameter()).then(function (res) {
      statisticAPI.consultHelpDetailPage(vm.invitationDetailsParameter()).then(function(res) {
        if (res.status == 200) {
          vm.loadingTwo = false
          res.detailModelList.forEach(function (v) {
          res.detailModelList.forEach(function(v) {
            v.sex = v.sex == 1 ? '男' : '女'
          })
          vm.invitationList = res.detailModelList
@ -1956,7 +1925,7 @@ new Vue({
    },
    // 康复下转明细传参
    recoveryParameter: function () {
    recoveryParameter: function() {
      var vm = this
      vm.searchJsonTime = vm.beforeReq()
      var parameter = {
@ -1981,14 +1950,14 @@ new Vue({
      return parameter
    },
    // 康复下转
    recovery: function () {
    recovery: function() {
      var vm = this
      vm.loadingTwo = true
      vm.lastAjax = 'doctor/specialist/rehabilitation/rehabilitationPatientInfo'
      statisticAPI.rehabilitationPatientInfo(vm.recoveryParameter()).then(function (res) {
      statisticAPI.rehabilitationPatientInfo(vm.recoveryParameter()).then(function(res) {
        if (res.status == 200) {
          vm.loadingTwo = false
          res.detailModelList.forEach(function (v) {
          res.detailModelList.forEach(function(v) {
            v.sex = v.sex == 1 ? '男' : '女'
          })
          vm.recoveryList = res.detailModelList
@ -2001,7 +1970,7 @@ new Vue({
    },
    //专病汇总传参
    getSpecialParameter: function () {
    getSpecialParameter: function() {
      var vm = this
      var parameter = {
        signYear: vm.radio == '1' ? vm.chooseYear : '', //签约年度
@ -2018,13 +1987,13 @@ new Vue({
      return parameter
    },
    // 专病汇总
    getSpecialDiseaseReport: function () {
    getSpecialDiseaseReport: function() {
      var vm = this
      vm.loadingTwo = true
      statisticAPI.getSpecialDiseaseReport(vm.getSpecialParameter()).then(function (res) {
      statisticAPI.getSpecialDiseaseReport(vm.getSpecialParameter()).then(function(res) {
        if (res.status == 200) {
          vm.indicator = []
          res.data.column.forEach(function (v) {
          res.data.column.forEach(function(v) {
            if (v == 'kfxzrs') {
              vm.indicator.push('康复计划人数')
            }
@ -2052,7 +2021,7 @@ new Vue({
    },
    //体征分析传参
    getDeviceParameter: function () {
    getDeviceParameter: function() {
      var vm = this
      var parameter = {
        signYear: vm.radio == '1' ? vm.chooseYear : '', //签约年度
@ -2071,10 +2040,10 @@ new Vue({
    },
    // 体征分析数据
    getDeviceHealthReport: function () {
    getDeviceHealthReport: function() {
      var vm = this
      vm.loadingTwo = true
      statisticAPI.getDeviceHealthReport(vm.getDeviceParameter()).then(function (res) {
      statisticAPI.getDeviceHealthReport(vm.getDeviceParameter()).then(function(res) {
        if (res.status == 200) {
          vm.loadingTwo = false
          // console.log(res,"sss")
@ -2089,7 +2058,7 @@ new Vue({
      })
    },
    //上门汇总传参
    getDoorParameter: function () {
    getDoorParameter: function() {
      var vm = this
      var parameter = {
        signYear: vm.radio == '1' ? vm.chooseYear : '', //签约年度
@ -2107,10 +2076,10 @@ new Vue({
      return parameter
    },
    // 上门汇总
    getDoorServerOrderReport: function () {
    getDoorServerOrderReport: function() {
      var vm = this
      vm.loadingTwo = true
      statisticAPI.getDoorServerOrderReport(vm.getDoorParameter()).then(function (res) {
      statisticAPI.getDoorServerOrderReport(vm.getDoorParameter()).then(function(res) {
        if (res.status == 200) {
          vm.loadingTwo = false
          // console.log(res,"sss")
@ -2125,7 +2094,7 @@ new Vue({
      })
    },
    getredPackageParameter: function () {
    getredPackageParameter: function() {
      var vm = this
      var parameter = {
        signYear: vm.radio == '1' ? vm.chooseYear : '', //签约年度
@ -2142,10 +2111,10 @@ new Vue({
      return parameter
    },
    redPackageRewardStatistics: function () {
    redPackageRewardStatistics: function() {
      var vm = this
      vm.loadingTwo = true
      statisticAPI.redPackageRewardStatistics(vm.getredPackageParameter()).then(function (res) {
      statisticAPI.redPackageRewardStatistics(vm.getredPackageParameter()).then(function(res) {
        if (res.status == 200) {
          vm.loadingTwo = false
          vm.getDoorReport = res.data.list
@ -2159,18 +2128,18 @@ new Vue({
      })
    },
    getTreeList: function () {
    getTreeList: function() {
      var vm = this
      statisticAPI.exportTreeList({ rang: vm.rangeCode }).then(function (res) {
      statisticAPI.exportTreeList({ rang: vm.rangeCode }).then(function(res) {
        if (res.status == 200) {
          ;(vm.treedata = []), (jindex = 0)
          _.each(res.data, function (item, index) {
          _.each(res.data, function(item, index) {
            vm.treedata.push({
              id: 'p_' + jindex,
              label: index,
              children: []
            })
            _.each(item, function (citem, cindex) {
            _.each(item, function(citem, cindex) {
              vm.treedata[jindex].children.push({
                id: cindex,
                label: citem
@ -2181,7 +2150,7 @@ new Vue({
        }
      })
    },
    beforeReq: function (flag) {
    beforeReq: function(flag) {
      var vm = this,
        startDate = '',
        endDate = '',
@ -2230,7 +2199,7 @@ new Vue({
          if (!flag) {
            vm.tableHeader = []
          }
          _.each(checkTree, function (item, index) {
          _.each(checkTree, function(item, index) {
            if (!flag) {
              vm.tableHeader.push({ prop: item.label, label: item.label })
            }
@ -2254,7 +2223,7 @@ new Vue({
      return { start: startDate, end: endDate, checked: checked.join(',') }
    },
    // 查询
    searchHandle: function (status) {
    searchHandle: function(status) {
      // console.log(this.beforeReq())
      var vm = this
      vm.searchJsonTime = vm.beforeReq()
@ -2295,18 +2264,18 @@ new Vue({
        vm.detailFunction(vm.handleNodeId, status)
      }
    },
    getStatisticDataList: function () {
    getStatisticDataList: function() {
      var vm = this
      vm.isloading = true
      var params = JSON.parse(JSON.stringify(vm.searchJson))
      params.page = vm.currentPage
      statisticAPI.getStatisticDataList(params).then(function (res) {
      statisticAPI.getStatisticDataList(params).then(function(res) {
        if (res.status == 200) {
          vm.tabledata = res.data.data
          vm.datatotal = res.data.total
          if (vm.tabledata.length) {
            vm.tableHeader = []
            _.each(vm.tabledata[0], function (item, index) {
            _.each(vm.tabledata[0], function(item, index) {
              if (
                index != 'town' &&
                index != 'townName' &&
@ -2327,7 +2296,7 @@ new Vue({
      })
    },
    // 导出
    exportHandle: function () {
    exportHandle: function() {
      // var uid = JSON.parse(window.localStorage.getItem('wlyyAgentForDoc')).uid
      // var blob = new Blob(["Hello, world!"], {type: "text/plain;charset=utf-8"});
      // saveAs(blob, "hello world.txt");
@ -2357,7 +2326,7 @@ new Vue({
              },
              '综合查询.xls'
            )
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
              // toastr.info("导出成功")
@ -2367,7 +2336,7 @@ new Vue({
              // console.log(res)
              // FileSaver()
            })
            .catch(function (err) {
            .catch(function(err) {
              console.error(err)
            })
          // let str = httpRequest.server + 'statisticsExport/export?startDate='+searchJson.start+'&endDate='+searchJson.end+'&quotaStr='+searchJson.checked+'&range='+vm.rangeCode+'&area='+areaCode+'&hospital='+vm.communityCode+'&team='+vm.teamCode+'&timeLevel='+vm.timeLevel
@ -2390,10 +2359,10 @@ new Vue({
              },
              vm.derive + '.xls'
            )
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2428,10 +2397,10 @@ new Vue({
              },
              vm.derive + '.xls'
            )
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2461,10 +2430,10 @@ new Vue({
              },
              vm.derive + '.xls'
            )
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2493,10 +2462,10 @@ new Vue({
              },
              vm.derive + '.xls'
            )
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2526,10 +2495,10 @@ new Vue({
              },
              vm.derive + '.xls'
            )
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2560,10 +2529,10 @@ new Vue({
              },
              vm.derive + '.xls'
            )
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2576,10 +2545,10 @@ new Vue({
        if (vm.getHealthData.length != 0) {
          statisticAPI
            .exportHealthList(vm.getHealthParameter(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2592,10 +2561,10 @@ new Vue({
        if (vm.reservationData.length != 0) {
          statisticAPI
            .exportDoctorReservationList(vm.reservationParameter(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2608,10 +2577,10 @@ new Vue({
        if (vm.wexinBindingData.length != 0) {
          statisticAPI
            .exportWexinBindingList(vm.wexinBindingParameter(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2624,10 +2593,10 @@ new Vue({
        if (vm.jifenData.length != 0) {
          statisticAPI
            .exPatinetIntegralAnalysis(_.assign({}, vm.residentIntegralParameter(), { pageSize: 99999 }), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2640,10 +2609,10 @@ new Vue({
        if (vm.ruhuData.length != 0) {
          statisticAPI
            .exfindPatientFollowListByCondition(vm.interviewParameter(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2656,10 +2625,10 @@ new Vue({
        if (vm.recoveryList.length != 0) {
          statisticAPI
            .exportRehabilitationPatientInfo(vm.recoveryParameter(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2678,10 +2647,10 @@ new Vue({
          statisticAPI
            .exportConsultHelpDetailPage(p, vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2694,10 +2663,10 @@ new Vue({
        if (vm.diseaseReport.length != 0) {
          statisticAPI
            .exportSpecialDiseaseReport(vm.getSpecialParameter(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2710,10 +2679,10 @@ new Vue({
        if (vm.getDeviceReport.length != 0) {
          statisticAPI
            .exportDeviceHealthReport(vm.getDeviceParameter(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2726,10 +2695,10 @@ new Vue({
        if (vm.getDoorReport.length != 0) {
          statisticAPI
            .exportDoorServerOrderReport(vm.getDoorParameter(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2742,10 +2711,10 @@ new Vue({
        if (vm.getDoorReport.length != 0) {
          statisticAPI
            .exportRedPackageRewardStatistics(vm.getredPackageParameter(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2758,10 +2727,10 @@ new Vue({
        if (vm.expertReplyData.length != 0) {
          statisticAPI
            .exportConsultHelpCountPage(vm.expertReply(), vm.derive + '.xls')
            .then(function (res) {
            .then(function(res) {
              vm.fullscreenLoading = false
            })
            .catch(function (err) {
            .catch(function(err) {
              toastr.info(err)
              vm.fullscreenLoading = false
              console.error(err)
@ -2771,24 +2740,24 @@ new Vue({
        }
      }
    },
    backClick: function () {
    backClick: function() {
      history.go(-1)
    },
    bindEvent: function () {
    bindEvent: function() {
      var vm = this
      //监听后退按钮的操作
      EventBus.$on('back-click', function (arg) {
      EventBus.$on('back-click', function(arg) {
        EventBus.$emit('update-statistics-time', {}) //更新统计时间
        vm.backClick()
      })
      //监听页面刷新
      EventBus.$on('refresh-click', function (arg) {
      EventBus.$on('refresh-click', function(arg) {
        EventBus.$emit('update-statistics-time', {}) //更新统计时间
        initData(vm)
      })
      $('#main').removeClass('c-hide')
    },
    detailFunction: function (id, status) {
    detailFunction: function(id, status) {
      var vm = this
      window.ajaxInsArr[vm.lastAjax] && window.ajaxInsArr[vm.lastAjax].abort()
      if (id == 33) {
@ -2841,12 +2810,12 @@ new Vue({
        vm.expertReplyList()
      }
    },
    getSpecialistHospital: function () {
    getSpecialistHospital: function() {
      var vm = this
      vm.specializedHospital = [{ value: '', label: '全部' }]
      homeAPI.getSpecialistHospital().then(function (res) {
      homeAPI.getSpecialistHospital().then(function(res) {
        if (res.status == 200) {
          res.data.forEach(function (v) {
          res.data.forEach(function(v) {
            vm.specializedHospital.push({
              value: v.code,
              label: v.name
@ -2855,14 +2824,14 @@ new Vue({
        }
      })
    },
    pullDown: function () {
    pullDown: function() {
      this.deorsumvergenceStatusFunction('archive_status') //档案状态
      this.deorsumvergenceStatusFunction('rehabilitation_status') //下转状态
      this.deorsumvergenceStatusFunction('rehabilitation_hospital') //下转医院
      this.hospitalsByType()
    },
    // 下一页  上一页
    handleCurrentChange: function (val) {
    handleCurrentChange: function(val) {
      var vm = this
      vm.currentPage = val
      if (vm.handleNodeId == 0) {
@ -2872,7 +2841,7 @@ new Vue({
      }
    },
    //获取省市区  type:区3
    getDistrict: function (type, code, name) {
    getDistrict: function(type, code, name) {
      var vm = this,
        list = [],
        param = ''
@ -2887,7 +2856,7 @@ new Vue({
        type: type,
        code: code
      }
      homeAPI.getDistrict(params).then(function (res) {
      homeAPI.getDistrict(params).then(function(res) {
        if (res.status == 200) {
          vm[param + 'List'] = list.concat(res.list)
          vm[param + 'Code'] = vm[param + 'List'][0].code
@ -2896,7 +2865,7 @@ new Vue({
        }
      })
    },
    selChange: function (type) {
    selChange: function(type) {
      var vm = this,
        name = ''
      if (type == 3) {
@ -2908,7 +2877,7 @@ new Vue({
        vm.teamListByArea()
      }
    },
    initSelOption: function (param) {
    initSelOption: function(param) {
      var vm = this
      vm[param + 'List'] = [{ code: '', name: '全部' }]
      if (param == 'team') {
@ -2916,11 +2885,11 @@ new Vue({
      }
      vm[param + 'Code'] = vm[param + 'List'][0].code || vm[param + 'List'][0].id
    },
    getCommunityHospital: function () {
    getCommunityHospital: function() {
      var vm = this,
        list = [{ code: '', name: '全部' }],
        param = 'community'
      homeAPI.getCommunityHospital({ area: vm.areaCode == '350200' ? '' : vm.areaCode }).then(function (res) {
      homeAPI.getCommunityHospital({ area: vm.areaCode == '350200' ? '' : vm.areaCode }).then(function(res) {
        if (res.status == 200) {
          vm[param + 'List'] = list.concat(res.data)
          vm[param + 'Code'] = vm[param + 'List'][0].code
@ -2929,11 +2898,11 @@ new Vue({
        }
      })
    },
    teamListByArea: function () {
    teamListByArea: function() {
      var vm = this,
        list = [{ id: '', name: '全部' }],
        param = 'team'
      homeAPI.teamListByArea({ area: vm.areaCode == '350200' ? '' : vm.areaCode, hospital: vm.communityCode }).then(function (res) {
      homeAPI.teamListByArea({ area: vm.areaCode == '350200' ? '' : vm.areaCode, hospital: vm.communityCode }).then(function(res) {
        if (res.status == 200) {
          vm[param + 'List'] = list.concat(res.data)
          vm[param + 'Code'] = vm[param + 'List'][0].id
@ -2980,11 +2949,7 @@ function initScope(vm) {
  vm.initarea = vm.area = vm.userRole.code
  vm.areaTitle = vm.userRole.name
  vm.rangeList = [
    { name: '按区', code: 'town' },
    { name: '按社区', code: 'hospital' },
    { name: '按团队', code: 'team' }
  ]
  vm.rangeList = [{ name: '按区', code: 'town' }, { name: '按社区', code: 'hospital' }, { name: '按团队', code: 'team' }]
  if (vm.initlevel == 4) {
    //市获取区

+ 6 - 3
component/statistics/GxbEvaluation/index.html

@ -19,7 +19,8 @@
          range-separator="至"
          start-placeholder="开始日期"
          end-placeholder="结束日期"
          value-format="yyyy-MM-dd"></el-date-picker>
          value-format="yyyy-MM-dd"
        ></el-date-picker>
      </label>
    </div>
    <div class="searchDiv pb20 pr20">
@ -58,7 +59,8 @@
      <template slot-scope="scope">
        <span
          @click="openDialog(scope.row, item.prop)"
          :class="`${['totalNum', 'dailyNum', 'inScreenNum', 'lRiskNum', 'mRiskNum', 'hRiskNum', 'uhRiskNum', 'ehRiskNum','messageTimes'].includes(item.prop)&&scope.row.code?'pointer c-409eff':''}`">
          :class="`${['totalNum', 'dailyNum', 'inScreenNum', 'lRiskNum', 'mRiskNum', 'hRiskNum', 'uhRiskNum', 'ehRiskNum','messageTimes'].includes(item.prop)&&scope.row.code?'pointer c-409eff':''}`"
        >
          {{scope.row[item.prop]}}
        </span>
      </template>
@ -154,7 +156,8 @@
        :page-size="size"
        :page-sizes="[10, 20, 50]"
        layout="total, sizes, prev, pager, next, jumper"
        :total="total"></el-pagination>
        :total="total"
      ></el-pagination>
    </div>
  </el-dialog>
  <el-dialog title="消息提醒" :visible.sync="messageVisible" @close="closeMessageDialog" width="540px">

+ 114 - 0
component/statistics/OutsideHospitalManage/index.html

@ -0,0 +1,114 @@
<div id="app" class="jtbc">
  <div class="copd-filter-group ui-col-1 bgc-fff" style="min-width: 900px">
    <div class="searchDiv pb20 pr20">
      <label class="c-333 c-f14">
        <el-radio v-model="yearType" label="1">按下转年份:</el-radio>
        <el-select v-model="chooseYear" class="formWidth wd160">
          <el-option v-for="(item , index) in years" :key="index" :label="item" :value="item"></el-option>
        </el-select>
      </label>
    </div>
    <div class="searchDiv pb20 pr20">
      <label class="c-333 c-f14" style="display: flex; align-items: center">
        <el-radio v-model="yearType" label="2">自定义下转时间:</el-radio>
        <el-date-picker
          v-model="chooseTime"
          type="daterange"
          range-separator="至"
          start-placeholder="开始日期"
          end-placeholder="结束日期"
          value-format="yyyy-MM-dd"
        ></el-date-picker>
      </label>
    </div>
    <div class="searchDiv pb20">
      <el-button type="primary" size="mini" @click="queryDate">查询</el-button>
      <el-button type="ff9526" size="mini" @click="exportTable" :disabled="exportLoading">导出</el-button>
      <span class="eliminate" @click="eliminateClick">清除筛选条件</span>
    </div>
  </div>
  <el-table :data="tableData" style="width: 100%" v-loading="loading" empty-text="暂无数据">
    <el-table-column type="index" min-width="60" label="序号"></el-table-column>
    <el-table-column :label="item.label" v-for="item in tableHeader" :min-width="item.width" :key="item.prop">
      <template slot-scope="scope">
        <span :class="`${['idcard','hospitalName'].includes(item.prop)&&scope.row.code?'pointer c-409eff':''}`" @click="openDialog(scope.row, item.prop)">
          {{scope.row[item.prop]}}
        </span>
      </template>
    </el-table-column>
    <el-table-column :label="item.label" v-for="(item,index) in tableHeaderChildren" :key="index" align="center">
      <el-table-column :label="el.label" :min-width="el.width" v-for="el in item.children" :key="el.prop">
        <template slot-scope="scope">
          <span :class="`${['vd1Num','v2Num','vd3Num','v4Num'].includes(el.prop)&&scope.row.code?'pointer c-409eff':''}`" @click="openDialog(scope.row, el.prop)">
            {{scope.row[el.prop]}}
          </span>
        </template>
      </el-table-column>
    </el-table-column>
  </el-table>
  <!-- 详情 -->
  <el-dialog :visible.sync="visible" :title="title" @close="closeDialog" width="1200px">
    <el-form inline size="mini">
      <el-form-item label="居民姓名:">
        <el-input v-model="query.name" placeholder="请输入居民姓名查询"></el-input>
      </el-form-item>
      <el-form-item label="手机号码:">
        <el-input v-model="query.signHospitalName" placeholder="请输入手机号码查询"></el-input>
      </el-form-item>
      <el-form-item label="管理医生:">
        <el-input v-model="query.signDoctorName" placeholder="请输入管理医生查询"></el-input>
      </el-form-item>
      <el-form-item label="管理医院:">
        <el-select v-model="query.remind" disabled>
          <el-option label="和平县医院" value=""></el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="服务方式:">
        <el-select v-model="query.serve" disabled>
          <el-option label="全部" value=""></el-option>
        </el-select>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="dialogSearchFn">查询</el-button>
        <el-button type="warning" @click="dialogExportFn" :disabled="dialogExportLoading">导出</el-button>
        <span @click="dialogReset" style="color: #676a6c; cursor: pointer">清除筛选条件</span>
      </el-form-item>
    </el-form>
    <el-table :data="dialogTableData" v-loading="dialogLoading" border>
      <el-table-column type="index" label="序号"></el-table-column>
      <el-table-column v-for="item in dialogHeader" :label="item.label" :prop="item.prop" :render-header="renderHeader">
        <template slot-scope="scope">
          <span :class="`${item.prop =='name'?'pointer c-409eff':''}`" @click="seePatientDetail(scope.row, item.prop)">{{scope.row[item.prop]}}</span>
        </template>
      </el-table-column>
    </el-table>
    <div style="display: flex; justify-content: flex-end; margin-top: 10px">
      <el-pagination
        @current-change="handleCurrentChange"
        @size-change="handleSizeChange"
        :current-page.sync="page"
        :page-size="size"
        :page-sizes="[10, 20, 50]"
        layout="total, sizes, prev, pager, next, jumper"
        :total="total"
      ></el-pagination>
    </div>
  </el-dialog>
  <el-dialog title="消息提醒内容" :visible.sync="messageVisible" @close="closeMessageDialog" width="540px">
    <div v-html="messTxt"></div>
    <span slot="footer" class="dialog-footer">
      <el-button @click="messageVisible = false">取消</el-button>
    </span>
  </el-dialog>
  <el-pagination
    @current-change="handleCurrentChange"
    @size-change="handleSizeChange"
    :current-page.sync="page"
    :page-size="size"
    :page-sizes="[10, 20, 50]"
    layout="total, sizes, prev, pager, next, jumper"
    :total="total"
    class="pagination"
  ></el-pagination>
</div>

+ 464 - 0
component/statistics/OutsideHospitalManage/index.js

@ -0,0 +1,464 @@
var template = ''
$.ajax('../../../component/statistics/OutsideHospitalManage/index.html', {
  data: {},
  dataType: 'html',
  cache: false,
  timeout: 60000,
  async: false,
  error: function(res) {},
  success: function(res) {
    template = res
  }
})
Vue.component('outside-hospital-manage', {
  template: template,
  props: [],
  data: function() {
    return {
      years: [],
      yearType: '1',
      chooseYear: null,
      chooseTime: null,
      rangeOptions: [{ label: '区', value: 'town' }, { label: '医院', value: 'hospital' }, { label: '团队', value: 'team' }],
      hospitalOptions: [],
      teamOptions: [],
      form: {
        range: 'town'
      },
      loading: false,
      exportLoading: false,
      tableData: [
        {
          patientName: '11',
          idcard: '11',
          hospitalName: '11',
          doctorName: '',
          code: '11',
          v1Num: 1,
          vd1Num: 1
        }
      ],
      tableHeader: [
        { label: '医院名称', prop: 'patientName', width: '110' },
        { label: '患者总数', prop: 'idcard', width: '110' },
        { label: '康复管理人数', prop: 'hospitalName', width: '180' },
        { label: '康复计划数量', prop: 'doctorName', width: '110' }
      ],
      tableHeaderChildren: [
        {
          label: '复诊1',
          children: [
            {
              label: '应服务人次',
              prop: 'v1Num',
              width: '130'
            },
            {
              label: '已服务人次',
              prop: 'vd1Num',
              width: '130'
            }
          ]
        },
        {
          label: '复诊2',
          children: [
            {
              label: '应服务人次',
              prop: 'v1Num',
              width: '130'
            },
            {
              label: '已服务人次',
              prop: 'vd1Num',
              width: '130'
            }
          ]
        },
        {
          label: '复诊3',
          children: [
            {
              label: '应服务人次',
              prop: 'v1Num',
              width: '130'
            },
            {
              label: '已服务人次',
              prop: 'vd1Num',
              width: '130'
            }
          ]
        },
        {
          label: '复诊4',
          children: [
            {
              label: '应服务人次',
              prop: 'v1Num',
              width: '130'
            },
            {
              label: '已服务人次',
              prop: 'vd1Num',
              width: '130'
            }
          ]
        }
      ],
      page: 1,
      size: 10,
      total: 0,
      level: 0,
      messageVisible: false,
      messTxt: '',
      paramsObj: {
        name: '',
        type: '',
        signDoctorName: '',
        hospitalName: ''
      },
      dialogHeader: [],
      visible: false,
      // 详情
      query: {
        name: '',
        signHospitalName: '',
        signDoctorName: '',
        remind: '',
        serve: ''
      },
      dialogTableData: [
        {
          name: '11',
          sex: '男',
          age: 18,
          phoen: 1254813
        }
      ],
      dialogLoading: false,
      dialogHeader: [],
      title: '',
      dialogExportLoading: false
    }
  },
  methods: {
    closeMessageDialog() {
      this.messageVisible = false
    },
    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.paramsObj,
        page: this.page,
        size: this.size
      }
      if (this.yearType == '1') {
        params.startTime = this.chooseYear + '-01-01' + ' 00:00:00'
        params.endTime = this.chooseYear + '-12-31' + ' 11:59:59'
      } else {
        if (this.chooseTime) {
          params.startTime = this.chooseTime[0] + ' 00:00:00'
          params.endTime = this.chooseTime[1] + ' 11:59:59'
        }
      }
      httpRequest.get('statistics/collaborate/selectSmsInfoList', { 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.paramsObj
      }
      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'
        }
      }
      this.exportLoading = true
      var fileName = `消息推送明细.xls`
      httpRequest.downLoadFileForAjax('statistics/collaborate/exportSelectSmsInfoList', fileName, params).then(function() {
        vm.exportLoading = false
      })
    },
    showInfo(item) {
      this.messTxt = item.content
      this.messageVisible = true
    },
    eliminateClick() {
      this.resetArea()
      this.yearType = '1'
      this.paramsObj = {
        name: '',
        type: '',
        signDoctorName: '',
        hospitalName: ''
      }
      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()
    },
    //详情
    openDialog(row, prop) {
      // if (!row.code) return
      // this.page = 1
      // this.query = {}
      // var len = row.code.length
      // if (len == 6) {
      //   this.query.range = 'town'
      //   this.query.area = row.code
      // } else if (len == 10) {
      //   this.query.range = 'hospital'
      //   this.query.hospital = row.code
      // } else {
      //   this.query.range = 'team'
      //   this.query.team = row.code
      // }
      // this.dataRangeOption = [{ label: row.name, value: row.code }]
      if (prop == 'idcard' || prop == 'hospitalName') {
        this.title = '下转情况数据列表'
        this.dialogHeader = [
          { label: '姓名', prop: 'name', width: '110' },
          { label: '性别', prop: 'sex', width: '110' },
          { label: '年龄', prop: 'age', width: '110' },
          { label: '手机号', prop: 'phoen', width: '110' },
          { label: '下转次数', prop: 'sex', width: '110' },
          { label: '最近一次下转诊断', prop: 'age', width: '110' },
          { label: '最近一次下转时间', prop: 'phoen', width: '110' }
        ]
        this.visible = true
      } else if (prop == 'vd1Num' || prop == 'v4Num') {
        this.title = '康复复诊记录明细'
        this.dialogHeader = [
          { label: '姓名', prop: 'name' },
          { label: '性别', prop: 'sex' },
          { label: '年龄', prop: 'age' },
          { label: '手机号', prop: 'mobile' },
          { label: '管理医院', prop: 'turnHospitalName' },
          { label: '管理医生', prop: 'turnDoctorName' },
          { label: '服务方式', prop: 'createTime' },
          { label: '服务时间', prop: 'hospitalName' }
        ]
        this.visible = true
      }
    },
    closeDialog() {
      this.visible = false
    },
    dialogReset() {
      var params = {
        ...this.query
      }
      this.query = {
        visitCount: params.visitCount,
        range: typeof params.range == 'undefined' ? '' : params.range,
        area: typeof params.area == 'undefined' ? '' : params.area,
        hospital: typeof params.hospital == 'undefined' ? '' : params.hospital,
        team: typeof params.team == 'undefined' ? '' : params.team
      }
    },
    dialogExportFn() {
      var vm = this
      this.exportLoading = true
      if (this.title == '康复随访记录明细') {
        var params = {
          ...this.query
        }
        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]
          }
        }
        var fileName = `康复随访记录明细${new Date().getTime()}.xls`
        httpRequest.downLoadFileForAjax('statistics/collaborate/exportGxbRehabilitationFollowupRecord', fileName, params).then(function() {
          vm.exportLoading = false
        })
      } else {
        var params = {
          ...this.query,
          type: 2
        }
        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]
          }
        }
        var fileName = `康复随访消息推送明细${new Date().getTime()}.xls`
        httpRequest.downLoadFileForAjax('statistics/collaborate/exportSelectSmsInfoList', fileName, params).then(function() {
          vm.exportLoading = false
        })
      }
    },
    dialogSearchFn() {
      this.page = 1
      this.dialogSearch()
    },
    dialogSearch() {
      if (this.title == '康复随访记录明细') {
        this.gxbRehabilitationFollowupRecord()
      } else {
        this.selectSmsInfoList()
      }
    },
    renderHeader: function(h, item) {
      var label = item.column.label
      var column = item.column
      var tooltip = {
        签约社区: '显示为该患者当前的签约社区医院名称',
        社区医院: '显示为该患者当前的签约社区医院名称',
        签约医院: '显示为该患者当前的签约社区医院名称',
        签约医生: '显示为该患者当前的签约社区医生名称',
        家庭医生: '显示为该患者当前的签约社区医生名称'
      }
      if (label == '签约社区' || label == '签约医生' || label == '签约医院' || label == '家庭医生' || label == '社区医院') {
        return [
          label,
          h(
            'el-tooltip',
            {
              props: {
                content: (function() {
                  return tooltip[label]
                })(),
                placement: 'top'
              }
            },
            [
              h('span', {
                class: {
                  'el-icon-question': true
                }
              })
            ]
          )
        ]
      } else {
        return [column.label]
      }
    },
    // 个人案
    seePatientDetail(row, prop) {
      if (prop == 'name') {
        EventBus.$emit('preview-person-info', { type: '5', code: row.code })
      }
    }
  },
  mounted() {
    this.init()
  }
})

+ 7 - 3
component/statistics/XiaoXiMx/index.html

@ -17,7 +17,8 @@
          range-separator="至"
          start-placeholder="开始日期"
          end-placeholder="结束日期"
          value-format="yyyy-MM-dd"></el-date-picker>
          value-format="yyyy-MM-dd"
        ></el-date-picker>
      </label>
    </div>
    <div class="searchDiv pb20 pr20">
@ -50,7 +51,9 @@
  <el-table :data="tableData" style="width: 100%" v-loading="loading" empty-text="暂无数据">
    <el-table-column type="index" min-width="60" label="序号"></el-table-column>
    <el-table-column :label="item.label" v-for="item in tableHeader" :min-width="item.width" :key="item.prop">
      <template slot-scope="scope">{{scope.row[item.prop]}}</template>
      <template slot-scope="scope">
        {{scope.row[item.prop]}}
      </template>
    </el-table-column>
    <el-table-column label="操作" align="center">
      <template slot-scope="scope">
@ -72,5 +75,6 @@
    :page-sizes="[10, 20, 50]"
    layout="total, sizes, prev, pager, next, jumper"
    :total="total"
    class="pagination"></el-pagination>
    class="pagination"
  ></el-pagination>
</div>

+ 9 - 16
component/statistics/XiaoXiMx/index.js

@ -5,8 +5,8 @@ $.ajax('../../../component/statistics/XiaoXiMx/index.html', {
  cache: false,
  timeout: 60000,
  async: false,
  error: function (res) {},
  success: function (res) {
  error: function(res) {},
  success: function(res) {
    template = res
  }
})
@ -14,17 +14,13 @@ $.ajax('../../../component/statistics/XiaoXiMx/index.html', {
Vue.component('xx-situation', {
  template: template,
  props: [],
  data: function () {
  data: function() {
    return {
      years: [],
      yearType: '1',
      chooseYear: null,
      chooseTime: null,
      rangeOptions: [
        { label: '区', value: 'town' },
        { label: '医院', value: 'hospital' },
        { label: '团队', value: 'team' }
      ],
      rangeOptions: [{ label: '区', value: 'town' }, { label: '医院', value: 'hospital' }, { label: '团队', value: 'team' }],
      areaOptions: [
        { label: '思明区', value: '350203' },
        { label: '海沧区', value: '350205' },
@ -91,10 +87,7 @@ Vue.component('xx-situation', {
        this.getHospital(selectedRole.code)
      } else {
        this.level = 3 // 社区管理
        this.rangeOptions = [
          { label: '医院', value: 'hospital' },
          { label: '团队', value: 'team' }
        ]
        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 = {
@ -147,7 +140,7 @@ Vue.component('xx-situation', {
        }
      }
      httpRequest.get('statistics/collaborate/selectSmsInfoList', { data: params }).then(function (res) {
      httpRequest.get('statistics/collaborate/selectSmsInfoList', { data: params }).then(function(res) {
        if (res.status == 200) {
          vm.tableData = res.detailModelList
          vm.total = res.totalCount
@ -175,7 +168,7 @@ Vue.component('xx-situation', {
      }
      this.exportLoading = true
      var fileName = `消息推送明细.xls`
      httpRequest.downLoadFileForAjax('statistics/collaborate/exportSelectSmsInfoList', fileName, params).then(function () {
      httpRequest.downLoadFileForAjax('statistics/collaborate/exportSelectSmsInfoList', fileName, params).then(function() {
        vm.exportLoading = false
      })
    },
@ -204,7 +197,7 @@ Vue.component('xx-situation', {
        type: 5,
        code: code
      }
      httpRequest.post('common/district', { data: params }).then(function (res) {
      httpRequest.post('common/district', { data: params }).then(function(res) {
        vm.hospitalOptions = res.list
      })
    },
@ -215,7 +208,7 @@ Vue.component('xx-situation', {
        hospital: code
      }
      httpRequest.get('statisticsExport/teamList', { data: params }).then(function (res) {
      httpRequest.get('statisticsExport/teamList', { data: params }).then(function(res) {
        vm.teamOptions = res.data
      })
    },