{"remainingRequest":"D:\\jenkins\\workspace\\tj_zsj_web\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\jenkins\\workspace\\tj_zsj_web\\src\\views\\YunSearcher\\ResourceDetails.vue?vue&type=script&lang=js","dependencies":[{"path":"D:\\jenkins\\workspace\\tj_zsj_web\\src\\views\\YunSearcher\\ResourceDetails.vue","mtime":1742507583469},{"path":"D:\\jenkins\\workspace\\tj_zsj_web\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\tj_zsj_web\\node_modules\\thread-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\tj_zsj_web\\node_modules\\babel-loader\\lib\\index.js","mtime":456789000000},{"path":"D:\\jenkins\\workspace\\tj_zsj_web\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\tj_zsj_web\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64://
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//


import _ from 'lodash'
import moment from 'moment'
import {
  getApply,
  getApplyDetail,
  getCloudUseage,
  saveApply,
  deleteApplyDetail,
  downloadApply, deleteApplyList
} from '@/api/publicBasic/resourceBid'
import { getDictionaryByCode } from '@/utils/dictionary'
import applyDetailForm from './applyDetailForm.vue'
import applyApproval from './applyApproval.vue'
import applyRecord from './applyRecord.vue'
import fileUpload from '@/components/upload/fileListUpload.vue'
export default {
  name: 'ResourceDetails',
  data() {
    return {
      id:'',
      dialogVisible: false,
      selectedMenu:'',
      buttonLoading:false,
      type: '',
      activeNames: ['1'],
      cloudType: [],
      loading: false,
      applyform: {
        applyDate: moment().format('YYYY-MM-DD'),
        cloudType: null,
        cloudApplyFile: [],
        cloudApplyUseDetailedList: [
          {
            cloudType: 1,
            useType: 1,
          },
          {
            cloudType: 1,
            useType: 2,
          },
          {
            cloudType: 2,
            useType: 1,
          },
          {
            cloudType: 2,
            useType: 2,
          },
        ],
      },
      applyformRules: {
        applyUnitName: [
          {
            required: true,
            message: '请输入单位名称',
            trigger: ['blur', 'change'],
          },
        ],
        applyUnitContacts: [
          {
            required: true,
            message: '请输入单位联系人',
            trigger: ['blur', 'change'],
          },
        ],
        applyUnitContactsPhone: [
          {
            required: true,
            message: '请输入单位联系人电话',
            trigger: ['blur', 'change'],
          },
          {
            pattern: /^1[3-9]\d{9}$/,
            message: '手机格式不正确',
            trigger: ['blur', 'change'],
          },
        ],
        applyUnitContactsMail: [
          {
            required: true,
            message: '请输入邮箱',
            trigger: ['blur', 'change'],
          },
          {
            type: 'email',
            message: '邮箱格式不正确',
            trigger: ['blur', 'change'],
          },
        ],
        applyDate: [
          {
            required: true,
            message: '请选择申请时间',
            trigger: ['blur', 'change'],
          },
        ],
        applyAppName: [
          {
            required: true,
            message: '请输入应用系统名称',
            trigger: ['blur', 'change'],
          },
        ],
        applyAppDevelopUnit: [
          {
            required: true,
            message: '请输入应用开发单位',
            trigger: ['blur', 'change'],
          },
        ],
        cloudType: [
          {
            required: true,
            message: '请选择资源所属云平台',
            trigger: ['blur', 'change'],
          },
        ],
        appPurpose: [
          {
            required: true,
            message: '请输入软件用途简要说明',
            trigger: ['blur', 'change'],
          },
        ],
        applyAppContracts: [
          {
            required: true,
            message: '请输入应用系统联系人',
            trigger: ['blur', 'change'],
          },
        ],
        applyAppContractsPhone: [
          {
            required: true,
            message: '请输入应用系统联系人电话',
            trigger: ['blur', 'change'],
          },
          {
            pattern: /^1[3-9]\d{9}$/,
            message: '手机格式不正确',
            trigger: ['blur', 'change'],
          },
        ],
        virtualMachineNum: [
          {
            required: true,
            message: '请输入虚拟机数量',
            trigger: ['blur', 'change'],
          },
        ],
        cpuNum: [
          {
            required: true,
            message: '请输入CPU核数',
            trigger: ['blur', 'change'],
          },
        ],
        memoryCapacity: [
          {
            required: true,
            message: '请输入内存容量',
            trigger: ['blur', 'change'],
          },
        ],
        dataCapacity: [
          {
            required: true,
            message: '请输入数据量',
            trigger: ['blur', 'change'],
          },
        ],
        applyUnitOpinion: [
          {
            required: true,
            message: '请输入申请单位意见',
            trigger: ['blur', 'change'],
          },
        ],
        managerUnitOpinion: [
          {
            required: true,
            message: '请输入主管单位意见',
            trigger: ['blur', 'change'],
          },
        ],
        cpuNumTotal: [
          {
            required: true,
            message: '请输入',
            trigger: ['blur', 'change'],
          },
          {
            validator: this.validateCpuNumTotal,
            trigger: ['blur', 'change'],
          },
        ],
        cpuNumUse: [
          {
            required: true,
            message: '请输入',
            trigger: ['blur', 'change'],
          },
          {
            validator: this.validateCpuNumUse,
            trigger: ['blur', 'change'],
          },
        ],
        cpuNumUseRate: [
          {
            required: true,
            message: '请输入',
            trigger: ['blur', 'change'],
          },
        ],
        memoryCapacityTotal: [
          {
            required: true,
            message: '请输入',
            trigger: ['blur', 'change'],
          },
          {
            validator: this.validateCapacityTotal,
            trigger: ['blur', 'change'],
          },
        ],
        memoryCapacityUse: [
          {
            required: true,
            message: '请输入',
            trigger: ['blur', 'change'],
          },
          {
            validator: this.validateCapacityUse,
            trigger: ['blur', 'change'],
          },
        ],
        memoryCapacityUseRate: [
          {
            required: true,
            message: '请输入',
            trigger: ['blur', 'change'],
          },
        ],
        storageCapacityTotal: [
          {
            required: true,
            message: '请输入',
            trigger: ['blur', 'change'],
          },
          {
            validator: this.validateStorageTotal,
            trigger: ['blur', 'change'],
          },
        ],
        storageCapacityUse: [
          {
            required: true,
            message: '请输入',
            trigger: ['blur', 'change'],
          },
          {
            validator: this.validateStorageUse,
            trigger: ['blur', 'change'],
          },
        ],
        storageCapacityUseRate: [
          {
            required: true,
            message: '请输入',
            trigger: ['blur', 'change'],
          },
        ],
      },
      dadToSon: {
        bizPath: 'resourceApply',
        fileList: [],
      },
      saving: false,
      loadingDetail: false,
      detailTableData: [],
      detailDelId: [],
      readOnly: false,
      audit: false,
      finish: false,
      pageType: '',
      originUseData: [
        {
          cloudType: 1,
          useType: 1,
        },
        {
          cloudType: 1,
          useType: 2,
        },
        {
          cloudType: 2,
          useType: 1,
        },
        {
          cloudType: 2,
          useType: 2,
        },
      ],
    }
  },
  components: {
    applyApproval,
    applyDetailForm,
    applyRecord,
    fileUpload
  },
  created() {
    if(this.$route.query){
      this.handleOpen(this.$route.query.pageType,this.$route.query.type,this.$route.query.id)
      this.selectedMenu = this.$route.query.selectedMenu
    }
  },
  mounted() {
  },
  methods: {
    getDictionaryByCode,
    // 返回
    goBack(){
      this.$router.push({ path:'/platLayout/resourceListPage',query:{ pageType:this.pageType, selectedMenu:this.selectedMenu}});
      this.handleClose()
    },
    handleInitDict() {
      this.cloudType = this.getDictionaryByCode('zy-ssypt')
      if (this.cloudType.length) {
        this.applyform.cloudType = parseInt(this.cloudType[0].value)
      }
    },
    handleOpen(pageType, type, id) {
      this.pageType = pageType
      this.type = type
      this.handleInitDict()
      if (type === 'add') {
        this.dialogVisible = true
        this.getCloudUseage('init')
      } else if (type === 'edit') {
        this.id = id
        this.handleQueryApply()
        this.handleQueryApplyDetail()
        this.getCloudUseage()
      }
    },
    // 新增时获取云资源使用情况
    async getCloudUseage(type) {
      this.loading = true
      const { state, value} = await getCloudUseage()
      if(state){
        this.loading = false
        let tempData = []
        value.sort((a, b) => {
          return a.cloudType - b.cloudType
        })
        value.forEach((item) => {
          let newItem = {
            cloudType: item.cloudType,
            cpuNumTotal: item.cpuNumTotal,
            cpuNumUse: item.cpuNumUse,
            cpuNumUseRate: item.cpuNumUseRate,
            memoryCapacityTotal: item.memoryCapacityTotal,
            memoryCapacityUse: item.memoryCapacityUse,
            memoryCapacityUseRate: item.memoryCapacityUseRate,
            storageCapacityTotal: item.storageCapacityTotal,
            storageCapacityUse: item.storageCapacityUse,
            storageCapacityUseRate: item.storageCapacityUseRate,
          }
          tempData.push({...newItem, useType: 1})
          tempData.push({...newItem, useType: 2})
        })
        if (type === 'init') {
          this.applyform.cloudApplyUseDetailedList = tempData
        }
        this.originUseData = _.cloneDeep(tempData)
      }else{
        this.loading = false
      }
    },
    handleFileChange(data) {
      this.applyform.cloudApplyFile = data
    },
    handleRecord() {
      this.$nextTick(() => {
        this.$refs.applyRecord.handleOpen(this.applyform)
      })
    },
    handleSave() {
      this.saving = true
      this.$refs.applyform.validate(async (bool, object) => {
        if (bool) {
          let submitData = {}
          let tempData = _.cloneDeep(this.applyform)
          submitData.cloudApply = tempData
          submitData.cloudApplyUseDetailedList = tempData.cloudApplyUseDetailedList
          delete submitData.cloudApply.cloudApplyUseDetailedList
          const {state, message, value} = await saveApply(submitData)
          if (state) {
            this.saving = false
            this.id = value
            this.$message.success('云资源申请基础信息保存成功！')
          } else {
            this.saving = false
            this.$message.warning(message)
          }
        } else {
          this.$message.warning(
            `有${
              Object.keys(object).length
            }个字段未通过校验，请正确填写表单内容。`
          )
          this.saving = false
        }
      })
    },
    async handleQueryApply() {
      const { cloudApply,cloudApplyUseDetailedList } = await getApply(this.id)
      if(cloudApply){
        this.applyform = cloudApply
      }
      if (cloudApplyUseDetailedList) {
        this.applyform.cloudApplyUseDetailedList = cloudApplyUseDetailedList
      }
      this.status = this.applyform.status
      this.readOnly = !(this.applyform.status === 0 || this.applyform.status === 20);
      this.audit = this.applyform.status === 10;
      if (this.applyform.status === 30) {
        this.finish = true
        this.activeNames = ['2']
      } else {
        this.finish = false
      }
      if (this.applyform.cloudApplyFile) {
        this.$set(
          this.dadToSon,
          'fileList',
          this.applyform.cloudApplyFile
        )
      } else {
        this.$set(this.dadToSon, 'fileList', [])
      }
      this.dialogVisible = true
    },
    // 查询资源明细
    async handleQueryApplyDetail() {
      // this.loadingDetail = true
      const res = await getApplyDetail(this.id)
      this.detailTableData = res.value || []
      // this.loadingDetail = false
    },
    handleAddDetail() {
      if (!this.id) {
        this.$message.warning('请先保存云资源申请基础信息，再添加资源申请明细！')
        return
      } else {
        this.$nextTick(() => {
          this.$refs.applyDetailForm.handleOpen(this.pageType, 'add', this.id, {
            cloudType: this.applyform.cloudType,
          })
        })
      }
    },
    handleEditDetail(row) {
      this.$nextTick(() => {
        let type = 'edit'
        if (this.readOnly) {
          type = 'readOnly'
        }
        if (this.finish && this.readOnly) {
          type = 'excute'
        }
        this.$refs.applyDetailForm.handleOpen(this.pageType, type, this.id, row)
      })
    },
    handleSelectionChange(selection) {
      this.detailDelId = selection.map((item) => item.cloudApplyDetail.id)
    },
    handleDelDetail() {
      this.$confirm('确定删除吗？', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning',
      }).then(() => {
        const {state, message} = deleteApplyDetail(this.id)
        if (state) {
          this.$message.success('资源申请明细删除成功！')
          this.handleQueryApplyDetail()
        } else {
          this.$message.warning(message)
        }
      })
    },
    // 审核
    handleApproval(type) {
      if (!this.id) {
        this.$message.warning('请先填写私有云资源信息，再发起审核！')
        return
      } else if (!this.detailTableData.length) {
        this.$message.warning('请先填写私有云资源申请明细，再发起审核！')
        return
      } else {
        this.$nextTick(() => {
          this.$refs.applyApproval.handleOpen(type, this.id)
        })
      }
    },
    //申请表导出
    async applicationForm(){
      await downloadApply(this.id)
      this.$message.success('导出成功')
    },
    // 删除
    deleteRourceChange(){
      this.buttonLoading = true
      this.$confirm('确定删除吗？', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning',
      }).then(() => {
        const {state,message} = deleteApplyList(this.id)
        if(state){
          this.buttonLoading = false
          this.goBack()
          this.$message.success('删除成功')
        }else{
          this.buttonLoading = false
          this.$message.warning(message)
        }
      })
    },

    handleClose() {
      this.$set(this.dadToSon, 'fileList', [])
      this.activeNames = ['1']
      this.type = ''
      this.readOnly = false
      this.audit = false
      this.finish = false
      this.pageType = ''
      this.id = ''
      this.applyform = {
        applyDate: moment().format('YYYY-MM-DD'),
        cloudType: null,
        cloudApplyFile: [],
        cloudApplyUseDetailedList: [
          {
            cloudType: 1,
            useType: 1,
          },
          {
            cloudType: 1,
            useType: 2,
          },
          {
            cloudType: 2,
            useType: 1,
          },
          {
            cloudType: 2,
            useType: 2,
          },
        ],
      }
      this.detailTableData = []
      this.detailDelId = []
      this.originUseData = [] // 资源使用情况原始数据
      this.$emit('reload')
      this.dialogVisible = false
    },
    // 云平台类型变化，清空应用系统规模数据，还原分配后数据
    handleChangeCloudType() {
      delete this.applyform.cpuNum
      delete this.applyform.dataCapacity
      delete this.applyform.memoryCapacity
      this.applyform.cloudApplyUseDetailedList = _.cloneDeep(this.originUseData)
      this.$forceUpdate()
    },
    // 申请数据变化，增加使用值
    handleChangeApplyUse(dataType, cloudType, curV) {
      let changeData, originData, index
      if (cloudType === 1) {
        changeData = this.applyform.cloudApplyUseDetailedList[1]
        originData = this.originUseData[1]
        index = 1
      } else if (cloudType === 2) {
        changeData = this.applyform.cloudApplyUseDetailedList[3]
        originData = this.originUseData[3]
        index = 3
      }

      let currentValTans = curV
      // 内容、储存字段需单位换算 G -> TB 保留2位小数
      if (dataType !== 'cpuNum') {
        currentValTans = parseFloat((curV / 1024).toFixed(2))
      }

      changeData[`${dataType}Use`] = parseFloat(
        (originData[`${dataType}Use`] + currentValTans).toFixed(2)
      )

      changeData[`${dataType}UseRate`] = parseFloat(
        (
          (changeData[`${dataType}Use`] / changeData[`${dataType}Total`]) *
          100
        ).toFixed(2)
      )
      this.applyform.cloudApplyUseDetailedList.splice(index, 1, changeData)
    },
    // 总数据变化计算比率
    handleChangeTotal(dataType, index, curV) {
      let changeData = this.applyform.cloudApplyUseDetailedList[index]

      changeData[`${dataType}UseRate`] = parseFloat(
        ((changeData[`${dataType}Use`] / curV) * 100).toFixed(2)
      )

      this.applyform.cloudApplyUseDetailedList.splice(index, 1, changeData)
    },
    // 使用数据变化计算比率
    handleChangeUse(dataType, index, curV) {
      let changeData = this.applyform.cloudApplyUseDetailedList[index]

      changeData[`${dataType}UseRate`] = parseFloat(
        ((curV / changeData[`${dataType}Total`]) * 100).toFixed(2)
      )

      this.applyform.cloudApplyUseDetailedList.splice(index, 1, changeData)
    },
    // 数据字段校验
    validateCpuNumTotal(rule, value, callback) {
      let index = rule.field.split('.')[1]
      let target = this.applyform.cloudApplyUseDetailedList[index]
      if (target.cpuNumUse > value) {
        callback(new Error('CPU总核心数小于使用核心数！'))
      } else {
        callback()
      }
    },
    validateCpuNumUse(rule, value, callback) {
      let index = rule.field.split('.')[1]
      let target = this.applyform.cloudApplyUseDetailedList[index]
      if (target.cpuNumTotal < value) {
        callback(new Error('CPU使用核心数超过总核心数！'))
      } else {
        callback()
      }
    },
    validateCapacityTotal(rule, value, callback) {
      let index = rule.field.split('.')[1]
      let target = this.applyform.cloudApplyUseDetailedList[index]
      if (target.memoryCapacityUse > value) {
        callback(new Error('内存总容量数小于使用容量！'))
      } else {
        callback()
      }
    },
    validateCapacityUse(rule, value, callback) {
      let index = rule.field.split('.')[1]
      let target = this.applyform.cloudApplyUseDetailedList[index]
      if (target.memoryCapacityTotal < value) {
        callback(new Error('内存使用容量数超过总容量！'))
      } else {
        callback()
      }
    },
    validateStorageTotal(rule, value, callback) {
      let index = rule.field.split('.')[1]
      let target = this.applyform.cloudApplyUseDetailedList[index]
      if (target.storageCapacityUse > value) {
        callback(new Error('储存总容量小于使用容量！'))
      } else {
        callback()
      }
    },
    validateStorageUse(rule, value, callback) {
      let index = rule.field.split('.')[1]
      let target = this.applyform.cloudApplyUseDetailedList[index]
      if (target.storageCapacityTotal < value) {
        callback(new Error('储存使用容量超过总容量！'))
      } else {
        callback()
      }
    },
  },
}
"},null]}