{"remainingRequest":"D:\\jenkins\\workspace\\xcjy-fvue\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\jenkins\\workspace\\xcjy-fvue\\src\\views\\patrolAndRescue\\commandDispatch\\EventManagement\\components\\TablePage\\index.vue?vue&type=script&lang=js","dependencies":[{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\src\\views\\patrolAndRescue\\commandDispatch\\EventManagement\\components\\TablePage\\index.vue","mtime":1751014284446},{"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, getDictionaryByCode} from '@/utils/dictionary'
import {refineRequestBody, setQueryValue} from '@/utils/requestWrappers'
import pagination from '@/components/SuperPagination/index.vue'
import {TableMixin} from '@/mixins/tableMixin'
import treeSide from '@/components/treeSide/index.vue'
import SearchCommon from '@/components/SearchCommon/index.vue'
import FinishDialog from '../FinishDialog/index.vue'
import {
  eventRevocation,
  exportDataFile,
  getTree,
  tableData,
  tableDelete
} from '@/api/patrolAndRescue/commandDispatch/eventManagement'
import TreeDialog from './components/TreeDialog/index.vue'
import PubSub from 'pubsub-js'
import moment from 'moment'
import FileDialog from '@/views/patrolAndRescue/commandDispatch/EventManagement/components/FileDialog/index.vue'

export default {
  name: 'TablePage',
  components: {
    FileDialog,
    TreeDialog,
    pagination,
    treeSide,
    SearchCommon,
    FinishDialog
  },
  mixins: [TableMixin],
  data() {
    return {
      fileInfo: {},
      fileShowDialog: false,
      currentEventId: null,
      finishDialog: false,
      downloadLoading: false,
      pubSub: null,
      tableMaxHeight: '600px',
      loading: false,
      tableLoading: false,
      treeData: [], //左边树
      tabList: ['政策法规'], //左边tab
      defaultProps: {
        children: 'children',
        label: 'name'
      },
      tableData: [],
      currentDataDel: [],
      optionList: [
        {title: '事件单号', prop: ['EVENT_NO_'], type: 'input', default: true},
        {
          title: '事件类型',
          prop: ['event_Type_'],
          type: 'select',
          option: getDictionaryByCode('sjlx'),
          multiple: false,
          default: false
        },
        {
          title: '事件来源',
          prop: ['event_Src_'],
          type: 'select',
          option: getDictionaryByCode('sjly'),
          multiple: false
        },
        {
          title: '事件状态',
          prop: ['EVENT_STATUS_'],
          type: 'select',
          option: getDictionaryByCode('sj_zt'),
          multiple: false
        }

      ],
      params: {
        pageBean: {pageSize: 20, page: 1, total: 0},
        querys: [
          {operation: 'IN', property: 'roadId'},
          {operation: 'EQUAL', property: 'event_Type_', value: ''},
          {operation: 'EQUAL', property: 'event_Src_', value: ''},
          {operation: 'EQUAL', property: 'EVENT_NO_', value: ''},
          {
            operation: 'BETWEEN',
            property: 'event_time_',
            value: [
              moment()
                .startOf('month')
                .format('YYYY-MM-DD HH:mm:ss'),
              moment()
                .endOf('month')
                .format('YYYY-MM-DD HH:mm:ss')
            ]
          },
          {operation: 'EQUAL', property: 'EVENT_STATUS_', value: ''}
        ],
        sorter: [
          {
            direction: 'DESC',
            property: 'create_time_ '
          }
        ]
      },
      treeDialog: false, // 科目信息弹层
      treeItemId: '', // 树形目录id
      treeItem: {}, // 树形节点选中对象
      treeItemParentId: '' // 树形目录父级id
    }
  },
  created() {
    // 获取树形目录-
    this.getOrgTreeData(treeData => {
      // 回调中默认选中第一项并将其id作为参数请求表格
      this.treeItem = treeData[0] || {}
      let array = []
      if (this.treeItem.children.length > 0) {
        array = this.treeItem.children.map(item => item.id)
      }
      this.$nextTick(_ => {
        this.$refs.treeSide?.setCurrentKey(treeData[0]?.id) //通过 $refs 获取treeSide组件引用，并调用 setCurrentKey方法设置当前选中的树节点。
        this.$refs.treeSide?.expandHandle(true, 2)
      })
      setQueryValue(this.params, 'roadId', array) //将选中的树节点的 path 设置为查询参数的一部分，用于后续的表格数据请求。
      this.loadData() //加载表格数据
    })
    // this.loadData()
  },
  mounted() {
    this.pubSub = PubSub.subscribe('TablePage', (_, data) => {
      switch (data.type) {
        case 'add':
          this.params.pageBean.page = 1
          this.loadData()
          break
        case 'edit':
          this.loadData()
          break
      }
    })
  },
  methods: {
    filePreviewChange(row) {
      this.fileInfo = row
      this.fileShowDialog = true
    },
    finishChange() {
      this.params.pageBean.page = 1
      this.loadData()
    },
    // 时间范围切换
    datePickerChange(val) {
      setQueryValue(this.params, 'event_time_', val)
      this.params.pageBean.page = 1
      this.loadData()
    },
    // handleSelectionChange(row) {
    // this.currentDataDel = row.filter(item => item.eventStatus < 1)
    // this.currentDataDel = this.currentDataDel.map(item => item.id)
    // },
    async exportData() {
      this.downloadLoading = true
      try {
        let params = {
          groupRelation: 'AND',
          groupTree: {},
          pageBean: {
            page: 1,
            pageSize: -1,
            showTotal: true
          },
          params: {},
          querys: [
            {
              group: 'main',
              operation: 'IN',
              parentGroup: '',
              property: 'ei.id_',
              relation: 'AND',
              value: this.currentDataDel
            }
          ],
          sorter: [
            {
              direction: 'ASC',
              property: ''
            }
          ]
        }
        const response = await exportDataFile(params)
        // 创建Blob对象
        const blob = new Blob([response], {type: 'application/zip'})
        // 创建下载链接
        const downloadUrl = window.URL.createObjectURL(blob)
        const link = document.createElement('a')
        link.href = downloadUrl
        // 设置文件名（可以根据需要调整）
        link.setAttribute('download', '突发事件档案.zip')
        // 触发下载
        document.body.appendChild(link)
        link.click()
        // 清理
        document.body.removeChild(link)
        window.URL.revokeObjectURL(downloadUrl)
        this.$message.success('导出成功')
      } finally {
        this.downloadLoading = false
      }
    },
    handleFinish() {
      this.clickTimer = true
      this.$confirm('确定完结选中的事件信息吗？', '提示', {
        confirmButtonText: '确认',
        cancelButtonText: '取消',
        type: 'warning'
      })
        .then(async () => {
          let ids = this.currentDataDel.join('&ids=')
          let {state, message} = await tableFinish('ids=' + ids)
          if (state) {
            this.$message.success(`事件完结成功`)
            const {page, pageSize, total} = this.params.pageBean
            const totalPages = Math.ceil(total / pageSize) // 计算总页数
            if (totalPages > 1 && page === totalPages) {
              if (this.tableData.length === 1) {
                // 当前页只有一条数据
                this.params.pageBean.page -= 1 // 返回前一页
              }
            }
            await this.loadData()
          } else {
            this.$message.error(message)
          }
        })
        .catch(_ => _)
    },
    // 获取公司树-异步方法，用于从后端获取树形数据
    async getOrgTreeData(callback) {
      try {
        this.treeLoading = true //开始加载时显示加载状态
        let {value} = await getTree() // 调用 API 获取树形数据
        this.treeData = this.transformTreeData(value)
      } finally {
        this.treeLoading = false // 无论成功或失败，都关闭加载状态
        callback && callback(this.treeData) // 如果提供了回调函数，则调用它并传入树形数据
      }
    },
    transformTreeData(data) {
      return data.map(item => ({
        id: item.id,
        name: item.name, // 一级目录的 label
        children: item.roadList.map(grid => ({
          id: grid.id,
          name: grid.name, // 二级目录的 label
          path: grid.path
        }))
      }))
    },
    // 事件完结
    handleEventCompleted(row) {
      this.currentEventId = row.id
      this.finishDialog = true
      // this.$confirm('确定事件已完结吗？', '提示', {
      //   confirmButtonText: '确认',
      //   cancelButtonText: '取消',
      //   type: 'warning'
      // }).then(async () => {
      //   let data = {
      //     eventId: id,
      //     eventNode: 9
      //   }
      //   const {state} = await eventCompleted(data)
      //   if (state) {
      //     this.$message.success('事件完结成功！')
      //     this.loadData()
      //   }
      // })
    },
    selectable(row, index) {
      return true
    },
    // 删除
    handleDelete() {
      this.clickTimer = true
      this.$confirm('确定删除选中的事件信息吗？', '提示', {
        confirmButtonText: '确认',
        cancelButtonText: '取消',
        type: 'warning'
      })
        .then(async () => {
          let ids = this.currentDataDel.join()
          let {state, message} = await tableDelete(ids)
          if (state) {
            this.$message.success(`事件删除成功`)
            const {page, pageSize, total} = this.params.pageBean
            const totalPages = Math.ceil(total / pageSize) // 计算总页数
            if (totalPages > 1 && page === totalPages) {
              if (this.tableData.length === 1) {
                // 当前页只有一条数据
                this.params.pageBean.page -= 1 // 返回前一页
              }
            }
            await this.loadData()
          } else {
            this.$message.error(message)
          }
        })
        .catch(_ => _)
    },
    // 撤回
    revocation({id}) {
      this.$confirm('确定撤回事件吗？', '提示', {
        confirmButtonText: '确认',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(async () => {
        const {state} = await eventRevocation(id)
        if (state) {
          this.$message.success('撤回成功！')
          this.loadData()
        }
      })
    },
    dictionaryEscape,
    //获取科目树
    async getTreeData(callback) {
      this.treeData = [
        {
          name: '规章制度',
          edit: 1,
          id: '',
          parentId: '',
          children: await getTree('3')
        }
      ]
      // 保证重新刷新树数据后，选中效果不失效
      if (this.treeItem.id) {
        this.$nextTick(_ => {
          this.$refs.treeSide?.setCurrentKey(this.treeItem.id)
        })
      }
      callback && callback(this.treeData)
    },

    //获取数据
    async loadData() {
      this.tableLoading = true
      const {total = 0, rows = []} = await tableData(
        refineRequestBody(this.params)
      )
      this.params.pageBean.total = total
      this.tableData = rows
      this.tableLoading = false
    },

    //左边树节点
    currentChange(nodeItem) {
      // 判断是否是一级目录（有 children 属性）
      if (nodeItem.children && nodeItem.children.length > 0) {
        this.isAddDisabled = true // 禁用新增按钮
        // this.$message.warning('请选择二级目录进行新增操作')
        const array = nodeItem.children.map(item => item.id)
        setQueryValue(this.params, 'roadId ', array)
      } else {
        this.isAddDisabled = false // 启用新增按钮
        // 修改对应的字段值
        setQueryValue(this.params, 'roadId ', [nodeItem?.id] || [])
      }
      this.params.pageBean.page = 1
      this.calcTableHeight(500)
      PubSub.publish('TreeItemSelected', nodeItem)
      this.treeItem = nodeItem || {}
      this.loadData()
    },

    // 树节点操作
    operateEvent(type, data) {
      switch (type) {
        case '新增':
          this.treeItemParentId = data.id
          this.treeDialog = true
          break
        case '编辑':
          this.treeItemId = data.id
          this.treeItemParentId = data.parentId
          this.treeDialog = true
          break
        case '删除':
          this.$confirm('确定删除选中资料分类吗？', '提示', {
            confirmButtonText: '确认',
            cancelButtonText: '取消',
            type: 'warning'
          })
            .then(async () => {
              const {state} = await treeDelete(data.id)
              if (state) {
                this.$message.success(`删除资料分类成功`)
              } else {
                this.$message.error(`删除资料分类失败`)
              }
              await this.getTreeData()
            })
            .catch(_ => _)
          break
      }
    },

    // 目录改变
    catalogChange(dialogName) {
      this.getTreeData(_ => (this[dialogName] = false))
    },

    //修改
    handleDbClick(row) {
      if (this.clickTimer) return (this.clickTimer = false)
      if (row.eventStatus > 0) return
      this.changePage('EditAddPage', row)
    },

    // 改变页面
    changePage(pageName = '', row = {}, type = '') {
      if (!pageName) return

      this.$emit(
        'changePage',
        pageName,
        _ => {
          PubSub.publish(pageName, row)
        },
        type || '详情'
      )
    },
    //进展上报
    reportData(row) {
      this.changePage('AbnormalListPage', {
        ...row
      })
    }
  },
  beforeDestroy() {
    // 在组件销毁之前 清除订阅消息
    PubSub.unsubscribe(this.pubSub)
  }
}
"},null]}