{"remainingRequest":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\jenkins\\workspace\\xcjy-fvue\\src\\views\\patrolAndRescue\\HomePage\\index.vue?vue&type=script&lang=js","dependencies":[{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\src\\views\\patrolAndRescue\\HomePage\\index.vue","mtime":1741928431670},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\thread-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\babel-loader\\lib\\index.js","mtime":456789000000},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//

import {dictionaryEscape} from '@/utils/dictionary'
import {
  getTree,
  tableDataa,
  tableDataaList,
  tableDatab,
  tableDatabList,
  tableDatac,
  tableDatacList
} from '@/api/patrolAndRescue/homePage'
import {TableMixin} from '@/mixins/tableMixin'
import pagination from '@/components/SuperPagination/index.vue'

export default {
  name: 'HomePage',
  components: {pagination},
  mixins: [TableMixin],
  computed: {},
  data() {
    return {
      pageResult: {
        typeof: Object,
        default: _ => ({
          page: 1,
          pageSize: 20,
          total: 0
        })
      },
      params: {
        pageBean: {pageSize: 10, page: 1, total: 0}
      },
      taskListotheraaa: [],//任务列表
      taskListotherbbb: [],//事件查询列表
      timeShow: 'day', // 默认选择“日”
      taskListotherccc: [],//异常信息列表
      paginationAaa: {pageSize: 10, page: 1, total: 0}, // taskListotheraaa 的分页参数
      paginationBbb: {pageSize: 10, page: 1, total: 0}, // taskListotherbbb 的分页参数
      paginationCcc: {pageSize: 10, page: 1, total: 0}, // taskListotherccc 的分页参数
      eventStatus: null, // 当前点击的事件状态-事件查询列表
      currentType: 1, // 默认类型为巡查任务
      backgroundImageUrl: require('@/assets/img/homePage/dang.png'),
      tableData: [],
      currentMenu: 'homePage',
      taskList: [],//事件查询
      taskListother: [],//当前任务
      taskListotherList: [],//异常信息
      currentActiveIndex: -1, // 新增变量，记录当前点击的索引
      orgList: [],
      currentStartTime: '', // 新增变量，存储当前开始时间
      currentEndTime: '' // 新增变量，存储当前结束时间
    }
  },
  created() {
    // 初始化默认选中“日”
    this.timeShow = 'day'
    // 获取当前日期
    const now = new Date()
    const year = now.getFullYear()
    const month = String(now.getMonth() + 1).padStart(2, '0') // 月份从 0 开始，需要 +1
    const day = String(now.getDate()).padStart(2, '0')
    this.currentStartTime = `${year}-${month}-${day}`
    this.currentEndTime = this.currentStartTime

    // 默认点击“事件总数(件)”
    this.handleTaskClick(0) // 0 表示事件总数
    this.taskListotherData()
    this.taskListotherListData()
    this.taskListData(this.currentStartTime, this.currentEndTime)
    this.Listaaa()
    this.Listbbb(this.currentStartTime, this.currentEndTime)
    this.Listccc()
    this.getOrgTreeData()
  },
  watch: {
    // 监听 timeShow 的变化
    timeShow(newVal) {
      this.handleTimeChange(newVal) // 调用时间变化处理方法
    }
    // this.openPage()
  },
  mounted() {
    let currentUser = sessionStorage.getItem('currentUserDetail')
    this.name = JSON.parse(currentUser).user.fullname
    this.deptName = JSON.parse(currentUser).org[0].deptName
    this.orgName = JSON.parse(currentUser).org[0].orgName
  },
  methods: {
    // 跳转到事件登记页面
    navigateToEventRegistrationa() {
      this.$router.push({path: 'patrolAndRescue/roadWatch/inspectionResults'})
    },
    navigateToEventRegistrationb() {
      this.$router.push({path: 'patrolAndRescue/commandDispatch/eventRegistration'})
    },
    navigateToEventRegistrationc() {
      this.$router.push({path: 'patrolAndRescue/obstacleClearingRescue/rescueRegistration'})
    },
    // 处理时间变化
    handleTimeChange(timeType) {
      let startTime = ''
      let endTime = ''

      const now = new Date()
      const year = now.getFullYear()
      const month = String(now.getMonth() + 1).padStart(2, '0') // 月份从 0 开始，需要 +1
      const day = String(now.getDate()).padStart(2, '0')

      switch (timeType) {
        case 'day': // 日
          startTime = `${year}-${month}-${day}`
          endTime = startTime // 开始时间和结束时间相同
          console.log('当前日期:', startTime)
          break
        case 'month': // 月
          startTime = `${year}-${month}-01` // 当前月的第一天
          endTime = `${year}-${month}-${new Date(year, now.getMonth() + 1, 0).getDate()}` // 当前月的最后一天
          console.log('当前月的第一天:', startTime)
          console.log('当前月的最后一天:', endTime)
          break
        case 'year': // 年
          startTime = `${year}-01-01` // 当前年的第一天
          endTime = `${year}-12-31` // 当前年的最后一天
          console.log('当前年的第一天:', startTime)
          console.log('当前年的最后一天:', endTime)
          break
        default:
          startTime = ''
          endTime = ''
      }
      // 存储当前时间范围
      this.currentStartTime = startTime
      this.currentEndTime = endTime

      // 调用 Listbbb 方法，传入时间范围
      this.Listbbb(startTime, endTime)
      // 调用 taskListData 方法，传入时间范围
      this.taskListData(startTime, endTime)
    },
    dictionaryEscape,

    //异常信息
    async taskListotherListData() {
      this.tableLoading = true
      try {
        // 确保 orgList 已赋值
        if (!this.orgList || this.orgList.length === 0) {
          await this.getOrgTreeData() // 等待 getOrgTreeData 完成
        }
        // 请求 tableData 接口
        const response = await tableDatab(this.orgList)
        if (response && response.value) {
          this.taskListotherList = response.value // 将接口返回的数据赋值给 taskListother
        }
      } catch (error) {
        console.error('请求数据失败:', error)
      } finally {
        this.tableLoading = false
      }
    },
    //事件统计
    async taskListData(startTime, endTime) {
      console.log(startTime, '统计时间')
      this.tableLoading = true
      try {
        // 确保 orgList 已赋值
        if (!this.orgList || this.orgList.length === 0) {
          await this.getOrgTreeData() // 等待 getOrgTreeData 完成
        }
        // 构造请求体
        const requestBody = {
          groupRelation: 'AND',
          groupTree: {},
          pageBean: {
            page: 1,
            pageSize: 10,
            showTotal: true
          },
          params: {
            // startTime: startTime, // 开始时间
            // endTime: endTime // 结束时间
          },
          querys: [],
          sorter: [
            {
              direction: 'ASC',
              property: ''
            }
          ]
        }
        // 请求 tableData 接口
        // 打印请求体，检查是否正确
        console.log(requestBody, '传入统计')
        console.log('Request Body:', JSON.stringify(requestBody, null, 2))
        // 打印请求体，检查是否正确
        const response = await tableDatac(requestBody, this.orgList, startTime, endTime)
        console.log(response, '111111111111122222222222')
        if (response && response.value) {
          this.taskList = response.value // 将接口返回的数据赋值给 taskListother
        }
      } catch (error) {
        console.error('请求数据失败:', error)
      } finally {
        this.tableLoading = false
      }
    },
    //事件查询点击-请求列表
    handleTaskClick(index) {
      this.currentActiveIndex = index // 更新当前点击的索引
      switch (index) {
        case 0: // 事件总数
          this.eventStatus = null // 不传 eventStatus
          break
        case 1: // 待接单事件
          this.eventStatus = 1
          break
        case 2: // 处置中事件
          this.eventStatus = 2
          break
        case 3: // 处置结束事件
          this.eventStatus = 3
          break
        case 4: // 已办结事件
          this.eventStatus = 4
          break
        default:
          this.eventStatus = null
      }
      console.log(this.currentStartTime, this.eventStatus, '时间11111111111111111111')//传进来的
      // 使用当前时间范围调用 Listbbb
      this.Listbbb(this.currentStartTime, this.currentEndTime)
    },

    //事件列表查询
    async Listbbb(startTime, endTime) {
      this.tableLoading = true
      try {
        // 确保 orgList 已赋值
        if (!this.orgList || this.orgList.length === 0) {
          await this.getOrgTreeData() // 等待 getOrgTreeData 完成
        }
        // 构造请求体
        const requestBody = {
          groupRelation: 'AND',
          groupTree: {},
          pageBean: {
            page: this.paginationBbb.page, // 当前页码
            pageSize: this.paginationBbb.pageSize, // 每页条数
            showTotal: true
          },

          params: {
            startTime: startTime, // 开始时间
            endTime: endTime // 结束时间
          },
          querys: [
            {
              group: 'main',
              operation: 'EQUAL',
              parentGroup: '',
              property: 'eventStatus',
              relation: 'AND',
              value: this.eventStatus
            },
            {
              group: 'main',
              operation: 'IN', // 使用 IN 操作符
              parentGroup: '',
              property: 'road_id_', // 属性名
              relation: 'AND',
              value: this.orgList // 传入 orgList 数组
            }
          ],
          sorter: [
            {
              direction: 'ASC',
              property: ''
            }
          ]
        }
        // 打印请求体，检查是否正确
        console.log('Request Body:', requestBody)
        const response = await tableDatabList(requestBody)
        if (response && response.rows) {
          this.taskListotherbbb = response.rows // 将接口返回的数据赋值给 taskListother
          this.paginationBbb.total = response.total || 0 // 更新总条数
          console.log(response, '事件列表')
        }
      } catch (error) {
        console.error('请求数据失败:', error)
      } finally {
        this.tableLoading = false
      }
    },
    //当前任务
    async taskListotherData() {
      this.tableLoading = true
      try {
        // 确保 orgList 已赋值
        if (!this.orgList || this.orgList.length === 0) {
          await this.getOrgTreeData() // 等待 getOrgTreeData 完成
        }
        // 请求 tableData 接口
        const response = await tableDataa(this.orgList)
        if (response && response.value) {
          this.taskListother = response.value // 将接口返回的数据赋值给 taskListother
        }
      } catch (error) {
        console.error('请求数据失败:', error)
      } finally {
        this.tableLoading = false
      }
    },
    //任务点击-请求列表
    taskChange(index) {
      if (index === 0) {
        this.currentType = 1 // 巡查任务
      } else if (index === 1) {
        this.currentType = 2 // 事件处置任务
      } else if (index === 2) {
        this.currentType = 3 // 救援任务
      }
      this.Listaaa() // 调用接口刷新数据
    },
    // 根据 currentType 返回对应的时间字段
    getTaskTime(task) {
      if (this.currentType === 1) {
        return task.taskDate // 巡查任务
      } else if (this.currentType === 2) {
        return task.eventTime // 事件处置任务
      } else if (this.currentType === 3) {
        return task.rescueTime // 救援任务
      }
      return '' // 默认返回空字符串
    },
    //任务列表
    async Listaaa() {
      this.tableLoading = true
      try {
        // 确保 orgList 已赋值
        if (!this.orgList || this.orgList.length === 0) {
          await this.getOrgTreeData() // 等待 getOrgTreeData 完成
        }
        // 构造请求体
        const requestBody = {
          groupRelation: 'AND',
          groupTree: {},
          pageBean: {
            page: this.paginationAaa.page, // 当前页码
            pageSize: this.paginationAaa.pageSize, // 每页条数
            showTotal: true
          },
          params: {},
          querys: [
            {
              group: 'main',
              operation: 'IN', // 使用 IN 操作符
              parentGroup: '',
              property: 'road_id_', // 属性名
              relation: 'AND',
              value: this.orgList // 传入 orgList 数组
            }
          ],
          sorter: [
            {
              direction: 'ASC',
              property: ''
            }
          ]
        }
        const response = await tableDataaList(requestBody, this.currentType)
        if (response && response.rows) {
          this.taskListotheraaa = response.rows // 将接口返回的数据赋值给 taskListother
          this.paginationAaa.total = response.total || 0 // 更新总条数
        }
      } catch (error) {
        console.error('请求数据失败:', error)
      } finally {
        this.tableLoading = false
      }
    },

    //异常点击
    change(index) {
      let handleType = null
      if (index === 1) {
        handleType = 1 // 现场处理
      } else if (index === 2) {
        handleType = 2 // 上报中心
      }
      this.Listccc(handleType) // 调用 Listccc 方法并传递 handleType
    },
    //异常列表
    async Listccc(handleType) {
      this.tableLoading = true
      try {
        // 确保 orgList 已赋值
        if (!this.orgList || this.orgList.length === 0) {
          await this.getOrgTreeData() // 等待 getOrgTreeData 完成
        }
        // 获取当前时间并格式化为 YYYY-MM-DD
        const now = new Date()
        const year = now.getFullYear()
        const month = String(now.getMonth() + 1).padStart(2, '0') // 月份从 0 开始，需要 +1
        const day = String(now.getDate()).padStart(2, '0')
        const formattedDate = `${year}-${month}-${day}` // 格式化为 YYYY-MM-DD
        // 构造请求体
        const requestBody = {
          groupRelation: 'AND',
          groupTree: {},
          pageBean: {
            page: this.paginationCcc.page, // 当前页码
            pageSize: this.paginationCcc.pageSize, // 每页条数
            showTotal: true
          },
          params: {},
          querys: [
            {
              'group': 'main',
              'operation': 'EQUAL',
              'parentGroup': '',
              'property': 'TASK_DATE_',
              'relation': 'AND',
              'value': formattedDate
            },
            {
              group: 'main',
              operation: 'IN', // 使用 IN 操作符
              parentGroup: '',
              property: 'road_id_', // 属性名
              relation: 'AND',
              value: this.orgList // 传入 orgList 数组
            }
          ],
          sorter: [
            {
              direction: 'ASC',
              property: ''
            }
          ]
        }
        // 如果 handleType 不为空，添加到 querys 中
        if (handleType !== null) {
          requestBody.querys.push({
            group: 'main',
            operation: 'EQUAL',
            parentGroup: '',
            property: 'handleType',
            relation: 'AND',
            value: handleType
          })
        }
        const response = await tableDatacList(requestBody)
        if (response && response.rows) {
          this.taskListotherccc = response.rows // 将接口返回的数据赋值给 taskListother
          this.paginationCcc.total = response.total || 0 // 更新总条数
        }
      } catch (error) {
        console.error('请求数据失败:', error)
      } finally {
        this.tableLoading = false
      }
    },
    // 获取公司树-将id集合起来传给后端
    async getOrgTreeData(callback) {
      try {
        this.treeLoading = true
        const valuedata = await getTree()
        // 提取所有 roadList 中的 id
        const allIds = []
        valuedata.value.forEach((item) => {
          if (item.roadList && item.roadList.length > 0) {
            item.roadList.forEach((road) => {
              if (road.id) {
                allIds.push(road.id) // 将 id 添加到数组中
              }
            })
          }
        })
        this.orgList = allIds
        console.log(this.orgList, 'id数组')
      } finally {
        this.treeLoading = false
        callback && callback(this.treeData)
        // this.tableLoading = false
      }
    },
    // 任务列表分页事件
    handleSizeChangeAaa(pageSize) {
      this.paginationAaa.pageSize = pageSize
      this.paginationAaa.page = 1 // 重置为第一页
      this.Listaaa() // 重新请求数据
    },
    handleCurrentChangeAaa(page) {
      this.paginationAaa.page = page
      this.Listaaa() // 重新请求数据
    },

    // 事件查询列表分页事件
    handleSizeChangeBbb(pageSize) {
      this.paginationBbb.pageSize = pageSize
      this.paginationBbb.page = 1 // 重置为第一页
      this.Listbbb(this.currentStartTime, this.currentEndTime) // 重新请求数据
    },
    handleCurrentChangeBbb(page) {
      this.paginationBbb.page = page
      this.Listbbb(this.currentStartTime, this.currentEndTime) // 重新请求数据
    },

    // 异常列表分页事件
    handleSizeChangeCcc(pageSize) {
      this.paginationCcc.pageSize = pageSize
      this.paginationCcc.page = 1 // 重置为第一页
      this.Listccc() // 重新请求数据
    },
    handleCurrentChangeCcc(page) {
      this.paginationCcc.page = page
      this.Listccc() // 重新请求数据
    }
  }
}
"},null]}