{"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\\DetailPage\\index.vue?vue&type=script&lang=js","dependencies":[{"path":"D:\\jenkins\\workspace\\xcjy-fvue\\src\\views\\patrolAndRescue\\commandDispatch\\EventManagement\\components\\DetailPage\\index.vue","mtime":1755252406125},{"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 {refineRequestBody} from '@/utils/requestWrappers'
import {dictionaryEscape, getDictionaryByCode} from '@/utils/dictionary'
import {
  deregulation,
  eventCompleted,
  tableDetail,
  tableEdit
} from '@/api/patrolAndRescue/commandDispatch/eventManagement'
import PubSub from 'pubsub-js'
import moment from 'moment'
import BasicsInfo from '../BasicsInfo'
import {tableData as roadSectionInfoInter} from '@/api/patrolAndRescue/infoMgmtPatrolsRescues/roadSectionInfo'
import {tableData as alongRouteInfoInter} from '@/api/patrolAndRescue/infoMgmtPatrolsRescues/alongRouteInfo'
import {tableData as teamData} from '@/api/patrolAndRescue/infoMgmtPatrolsRescues/patrolAndRescueTeamsMgmt'
import AppointDialog from '../AppointDialog'
import disposalProcess from '../DisposalProcess'
import {
  compensationAdd,
  compensationDelete,
  compensationEdit,
  rescueFeeDelete,
  trafficControlDelete,
  trafficJamDelete,
  trafficJamEdit
} from '@/api/patrolAndRescue/commandDispatch/eventManagement/eventEdit'

import DetailedListGialog
  from '@/views/patrolAndRescue/roadDamageComp/RoadDamageRegister/components/EditAddPage/components/DetailedListGialog' // 赔偿清单弹窗
import rescueCostDialog from './rescueCostDialog/index.vue' // 救援费用信息弹窗
import trafficControlDialog from './trafficControlDialog/index.vue' // 拥堵列表弹窗
import TrafficJamDialog from './trafficJamDialog/index.vue'
import SaveDetailDialog
  from '@/views/patrolAndRescue/commandDispatch/EventInquiry/components/SaveDetailDialog/index.vue' // 拥堵列表弹窗
export default {
  name: 'DetailPage',
  props: {
    componentName: {
      default: 'TablePage',
      type: String
    }
  },
  components: {
    SaveDetailDialog,
    BasicsInfo,
    AppointDialog,
    disposalProcess,
    DetailedListGialog,
    rescueCostDialog,
    TrafficJamDialog,
    trafficControlDialog
  },
  data() {
    return {
      appointDialog: false,
      editSaveLoading: false,
      pageType: 'edit',
      detailForm: {},
      pubSub: null,
      eventStatus: 0,
      confirmLoading: false,
      reverse: true,
      map: null,
      mapLoading: true,
      mapDefaultOptions: {
        center: [106.5507, 29.5647] /*地图中心点*/,
        zoom: 9 /*地图默认缩放等级*/
      },
      eventGradeOptions: [
        //事件等级
        {label: '1级', value: 1},
        {label: '2级', value: 2},
        {label: '3级', value: 3},
        {label: '4级', value: 4}
      ],
      markers: [],
      roadOptions: [],
      alongRouteInfoData: [],
      teamOptions: [],
      editDialog: false,
      eventType: '',
      baseInfo: {},
      disposalProcess: false,
      compensateDialog: false, // 赔偿清单弹窗
      compensateDialogDetail: {},
      rescueDialog: false, // 救援费用信息弹窗
      rescueDialogDetail: {},
      controlDialog: false, // 管制列表弹窗
      controlDialogDetail: {},
      trafficJamDialog: false, // 拥堵列表弹窗
      trafficJamDialogDetail: {},
      releaseTimeMap: {},
      jiechuTimeMap: {},
      SaveDetailDialog: false,
      saveDetailForm: {},
      inspectOptions: [],
      popoverVisibleMap: {},
      disableShow: true
    }
  },
  computed: {},
  watch: {
    componentName: {
      handler(newVal) {
        if (newVal === this.$options.name) {
          this.openPage()
        } else {
          this.closePage()
        }
      }
    }
  },
  mounted() {
    this.pubSub = PubSub.subscribe('DetailPage', (_, data) => {
      if (data.id) {
        this.eventStatus = data.status
        this.getDetail(data.id)
      }
      this.getRoadOptions()
    })
  },
  methods: {
    initJiechuTime(row) {
      if (!this.jiechuTimeMap[row.id]) {
        this.$set(this.jiechuTimeMap, row.id, moment().format('YYYY-MM-DD HH:mm:ss'))
      }
    },
    initReleaseTime(row) {
      if (!this.releaseTimeMap[row.id]) {
        this.$set(this.releaseTimeMap, row.id, moment().format('YYYY-MM-DD HH:mm:ss'))
      }
    },
    handleReleaseTimeChange(row) {
      if (row.startTime > this.releaseTimeMap[row.id]) {
        this.$set(this.releaseTimeMap, row.id, '')
        this.$message.error('拥堵解除时间必须在拥堵开始时间之后！')
      }
      this.$set(this.popoverVisibleMap, row.id, true)
    },
    handleDateChange(row) {
      if (row.startTime > this.jiechuTimeMap[row.id]) {
        this.$set(this.jiechuTimeMap, row.id, '')
        this.$message.error('管制解除时间必须在管制开始时间之后！')
      }
      this.$set(this.popoverVisibleMap, row.id, true)
    },
    dictionChange(value, eventPlace) {
      if (!value || !eventPlace) return '-'
      const placeItem = this.getDictionaryByCode('sjfsqy')
        .find(item => item.value === eventPlace)
      if (!placeItem?.lowerDic?.['jtgz-fx']) return '-'
      const matchedItem = placeItem.lowerDic['jtgz-fx']
        .find(item => item.value === value)
      return matchedItem?.name || '-'

      // if (value && eventPlace) {
      //   let data = this.getDictionaryByCode('sjfsqy')
      //   let array = data.filter(item => item.value === eventPlace)[0].lowerDic['jtgz-fx']
      //   return array.filter(item => item.value === value)[0].name
      // } else {
      //   return '-'
      // }
    },
    rescueIncidents(row) {
      this.SaveDetailDialog = true
      this.saveDetailForm = row
    },
    handleAdd(type) {
      if (this.pageType === 'edit') {
        if (type === 'compensateDialog' && this.detailForm.compensationInfo) {
          this[type] = true
          this[type + 'Detail'] = {
            eventId: this.detailForm.id,
            roadId: this.detailForm.roadId
          }
        } else if (
          type === 'compensateDialog' &&
          !this.detailForm.compensationInfo
        ) {
          this.$router.push({
            name: 'roadDamageRegister'
          })
        }
        if (type !== 'compensateDialog') {
          this[type] = true
          this[type + 'Detail'] = {
            eventId: this.detailForm.id,
            roadId: this.detailForm.roadId
          }
        }
      } else {
        this.$message.warning('请先保存当前编辑的事件基础信息')
      }
    },
    async saveCompensation(data) {
      this.compensateDialogDetail = data
      this.compensateDialog = false
      const {
        id,
        unit,
        price,
        propertySubjectId,
        propertySubjectName,
        propertySubjectType,
        propertyTypeId,
        totle,
        num,
        memo,
        modle,
        compensationId
      } = this.compensateDialogDetail
      const params = {
        id,
        unit,
        price,
        propertySubjectId,
        propertySubjectName,
        propertySubjectType,
        propertyTypeId,
        totle,
        num,
        memo,
        modle,
        eventId: this.detailForm.id,
        compensationId: this.detailForm.compensationInfo.id
      }
      try {
        const API = data.id ? compensationEdit : compensationAdd
        const type = data.id ? '编辑' : '新增'
        const {state, message} = await API(params)
        if (state) {
          this.reload()
          this.$message.success('路产赔偿清单' + type + '成功！')
        } else {
          this.$message.error(message || '路产赔偿清单' + type + '失败！')
        }
      } catch (error) {
        this.$message.error(error || '路产赔偿清单保存失败！')
      }
    },
    handleEdit(row, type) {
      this[type + 'Detail'] = row
      this[type] = true
    },
    // 拥堵解除
    async handleRelease(row) {
      if (this.releaseTimeMap[row.id]) {
        this.$set(this.popoverVisibleMap, row.id, false)
        row.endTime = moment(this.releaseTimeMap[row.id]).format('YYYY-MM-DD HH:mm:ss')
        const {state, value, message} = await trafficJamEdit(row)
        if (state) {
          this.$message.success('拥堵解除成功')
          this.reload()
        } else {
          this.$message.error(message || '拥堵解除失败')
        }
      } else {
        this.$message.warning('请选择解除时间')
      }
    },
    handleDelete(data, type) {
      this.$confirm('是否删除该数据？', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(async () => {
        try {
          let API
          switch (type) {
            case 'compensateDialog':
              API = compensationDelete
              break
            case 'trafficJamDialog':
              API = trafficJamDelete
              break
            case 'controlDialog':
              API = trafficControlDelete
              break
            case 'rescueDialog':
              API = rescueFeeDelete
              break
          }
          let {state} = await API(data.id)
          if (state) {
            this.$message.success('删除成功')
            this.reload()
          }
        } catch (error) {
          this.$message.error(error || '删除失败！')
        }
      })
    },
    reload() {
      this.getDetail(this.detailForm.id)
    },
    getDictionaryByCode,
    dictionaryEscape,
    showAppointDialog() {
      // this.baseInfo = this.$refs.basicsContent.sendBaseData()
      // this.$refs.addEditForm.validate(async (valid, object) => {
      //   if (!valid) {
      //     this.$message.warning(
      //       `有${Object.keys(object).length + (basiceData.fieldNum || 0)
      //       }个字段未通过校验，请正确填写表单内容。`
      //     )
      //   } else {

      //   }
      // })
      this.appointDialog = true
    },
    handleUpdataHandles() {
      console.log('更新流程记录')
      this.getDetail(this.detailForm.id)
    },
    // 添加处置环节
    handleAddDisposal() {
      this.disposalProcess = true
    },
    clickEdit() {
      this.pageType = this.pageType === 'edit' ? 'detail' : 'edit'
      if (this.pageType !== 'edit') {
        this.$nextTick(() => {
          this.$refs.basicsContent.getDetail(this.detailForm)
        })
      }
    },
    async clickSave() {
      let data = this.$refs.basicsContent.sendBaseData()
      if (data.fieldNum) {
        this.$message.warning(
          `有${data.fieldNum}个字段未通过校验，请正确填写表单内容。`
        )
      } else {
        const query = {...data}
        delete query.handles
        delete query.compensationInfo
        delete query.trafficCongestions
        delete query.trafficControls
        query.eventType = JSON.stringify(query.eventType)
        try {
          this.editSaveLoading = true
          let {state, message, value} = await tableEdit(query)
          if (state) {
            this.$message.success(`编辑保存成功`)
            this.pageType = 'edit'
            this.detailForm = {...this.detailForm, ...data}
            this.detailForm.compensationDetails =
              this.detailForm?.compensationInfo?.compensationDetails || []
            this.detailForm.eventType = JSON.parse(data.eventType)
          }
        } finally {
          this.editSaveLoading = false
        }
      }
    },
    // 事件完结
    handleEventCompleted() {
      this.$confirm('确定事件已完结吗？', '提示', {
        confirmButtonText: '确认',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(async () => {
        let data = {
          eventId: this.detailForm.id,
          eventNode: 9
        }
        const {state} = await eventCompleted(data)
        if (state) {
          this.$message.success('事件完结成功！')
        }
      })
    },

    // 路段数据查询
    async getRoadOptions() {
      const {rows = []} = await roadSectionInfoInter({pageBean: {pageSize: -1}})
      this.roadOptions = rows.map(item => {
        item.roadName = item.name + ' ' + item.code
        return item
      })
      // if(!this.id) {
      //   this.$set(this.detailForm, 'roadId', this.roadOptions[0].id)
      //   this.roadChange(this.roadOptions[0].id)
      // }
    },
    // 路段选择变化
    async roadChange(value) {
      this.getTeamData(value)
      this.getInspectData(value)
      // 通过路段信息获取沿线设备信息
      this.getAlongRouteInfo(value, data => {
        const {startPatrolId, endPatrolId} = this.detailForm

        /*
         * 巡检开始，结束站
         * */
        if (startPatrolId) {
          if (!data.some(i => i.id === startPatrolId)) {
            this.detailForm.startPatrolId = ''
            setTimeout(_ => this.$message.warning('请重新选择巡检开始站..'))
          }
        }

        if (endPatrolId) {
          if (!data.some(i => i.id === endPatrolId)) {
            this.detailForm.endPatrolId = ''
            setTimeout(_ => this.$message.warning('请重新选择巡检结束站..'))
          }
        }
      })
    },
    // 通过路段信息获取沿线设备信息
    async getAlongRouteInfo(value, callback) {
      const _wipeData = () => {
        this.alongRouteInfoData = []
        callback && callback(this.alongRouteInfoData)
      }

      try {
        // 获取沿线设施
        const {rows = []} = await alongRouteInfoInter(
          refineRequestBody({
            querys: [{operation: 'IN', property: 'road_segment_id_', value}]
          }),
          'addEdit'
        )

        callback && callback(rows)
        this.alongRouteInfoData = rows
      } catch (error) {
        // 不为请求过快结束的情况下，重置
        if (error.message !== 'canceled') _wipeData()
      }
    },

    siteChange(e, type) {
      let siteInfo = this.alongRouteInfoData.find(item => item.id === e)
      this.detailForm[`${type}Name`] = siteInfo.name
    },

    // 通过路段信息获取巡查救援队伍信息
    async getTeamData(value) {
      const {rows = []} = await teamData(
        refineRequestBody({
          querys: [
            {operation: 'IN', property: 'r.id_', value},
            {operation: 'EQUAL', property: 't.type_', value: '2'}
          ]
        }),
        'addEdit'
      )
      this.teamOptions = rows
    },

    // 通过路段信息获取巡查救援队伍信息
    async getInspectData(value) {
      const {rows = []} = await teamData(
        refineRequestBody({
          querys: [
            {operation: 'IN', property: 'r.id_', value},
            {operation: 'EQUAL', property: 't.type_', value: '1'}
          ]
        }),
        'addEdit'
      )
      this.inspectOptions = rows
    },

    // 附件预览list
    getFilePreviewUrlList(files) {
      let srcList = files.map(item => {
        return item.filePreviewUrl
      })
      return srcList
    },
    eventConfirm() {
      this.$confirm('确定事件核实确认吗？', '提示', {
        confirmButtonText: '确认',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(async () => {
        this.confirmLoading = true
        const {state} = await eventConfirm(this.detailForm.id)
        if (state) {
          this.$message.success(`事件确认成功`)
          this.confirmLoading = false
          this.changePage('TablePage', 'add')
        }
      })
    },
    // 打开页面执行
    openPage() {
      // this.$refs.mineMap?.map?.resize()
    },
    changePage(pageName = '', type = '') {
      if (!pageName) return
      this.$emit('changePage', pageName, _ => {
        PubSub.publish(pageName, {type})
      })
    },
    // 关闭页面执行
    closePage() {
      const {pubSub, addEditRules, roadOptions} = this
      // 重置组件数据
      Object.assign(this.$data, this.$options.data.call(this), {
        pubSub,
        roadOptions
      })
      // this.$refs.mineMap?.resetMap(_ => this.mapLoading = false) // 重置地图
      this.$nextTick(_ => {
        this.$refs.formInfo.$el.scrollTop = 0
      })
    },
    mapLoad() {
      this.mapLoading = false
    },
    // 自定义标记点
    customTagPoints(lnglat = []) {
      this.markers[this.markers.length - 1]?.remove()
      // 自定义点标记的内部DOM元素
      let el = document.createElement('div')
      el.className = 'marker-tip'
      // Marker构造函数接收两个参数，一个为自定义的DOM元素，一个是Object参数，其中包括偏移量等
      let marker = new this.$refs.mineMap.mineMap.Marker(el, {
        anchor: 'center',
        offset: [0, 0] // offset参数为标注点相对于其左上角偏移像素大小
      })
        // 调用setLngLat方法指定Marker的坐标位置
        .setLngLat(lnglat)
        .addTo(this.$refs.mineMap.map)
      this.markers.push(marker)
    },

    // 获取详情
    async getDetail(id) {
      this.detailForm = await tableDetail(id)
      const {pegSVal = '', pegEVal = ''} = this.detailForm
      if (pegSVal) {
        let startPegArr = pegSVal.split('+')
        this.detailForm.startPeg = startPegArr[0].slice(1)
        this.detailForm.startPegAdd = startPegArr[1]
      }
      if (pegEVal) {
        let endPegArr = pegEVal.split('+')
        this.detailForm.endPeg = endPegArr[0].slice(1)
        this.detailForm.endPegAdd = endPegArr[1]
      }
      this.detailForm.compensationDetails =
        this.detailForm?.compensationInfo?.compensationDetails || []
      this.detailForm.eventType = JSON.parse(this.detailForm.eventType)
      this.roadChange(this.detailForm.roadId)
      this.disableShow = false
      console.log(this.detailForm, '详情数据/////')
    },

    getEventType() {
      const {eventType} = this.detailForm
      if (eventType) {
        if (eventType.length > 1) {
          return this.dictionaryEscape('lx_sjlxxq', eventType[1] + '')
        } else {
          return '-'
        }
      } else {
        return '-'
      }
    },

    async handleRelieve(row, index) {
      if (this.jiechuTimeMap[row.id]) {
        this.$set(this.popoverVisibleMap, row.id, false)
        row.endTime = moment(this.jiechuTimeMap[row.id]).format('YYYY-MM-DD HH:mm:ss')
        row.status = 2
        const {state, value, message} = await deregulation(row)
        if (state) {
          this.$message.success('解除管制成功')
          this.reload()
        } else {
          this.$message.error(message || '解除管制失败')
        }
      } else {
        this.$message.warning('请选择解除时间')
      }


      // this.$confirm('确认解除管制吗?', '提示', {
      //   confirmButtonText: '确定',
      //   cancelButtonText: '取消',
      //   type: 'warning'
      // }).then(() => {
      //   console.log(row)
      //
      //   row.status = 2
      //   deregulation(row).then(res => {
      //     if (res.state) {
      //       this.$message.success('解除管制成功！')
      //       this.reload()
      //     }
      //   })
      // })
    }
  },
  beforeDestroy() {
    // 在组件销毁之前 清除订阅消息
    PubSub.unsubscribe(this.pubSub)
  }
}
"},null]}