| | |
| | | destroy-on-close |
| | | :close-on-click-modal="false" |
| | | > |
| | | <el-tabs class="gd-tabs" v-model="activeName" @tab-click="tabsClick" v-if="dialogReadonly && formData.workOrderStatus >= '30'"> |
| | | <el-tabs |
| | | class="gd-tabs" |
| | | v-model="activeName" |
| | | @tab-click="tabsClick" |
| | | v-if="dialogReadonly && formData.workOrderStatus >= '30'" |
| | | > |
| | | <el-tab-pane label="基础信息" name="basic"></el-tab-pane> |
| | | <el-tab-pane label="成果数据" name="result"> |
| | | <OutcomeData :workOrderId="formData.id" /> |
| | | </el-tab-pane> |
| | | </el-tabs> |
| | | </el-tabs> |
| | | <div class="content" style="display: flex" v-if="activeName === 'basic'"> |
| | | <div class="processBox" v-if="dialogMode !== 'add'"> |
| | | <div class="detail-title">工单记录</div> |
| | |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <el-form-item label="工单类型" prop="workOrderType"> |
| | | <!-- <el-cascader |
| | | <el-cascader |
| | | class="gd-cascader" |
| | | popper-class="gd-cascader-popper" |
| | | v-model="formData.workOrderType" |
| | | :options="workOrderTypeXT" |
| | | :props="taskTypeCascaderProps" |
| | | collapse-tags |
| | | :props="{...taskTypeCascaderProps,multiple:true }" |
| | | placeholder="请选择" |
| | | clearable |
| | | /> --> |
| | | <el-cascader class="gd-cascader" popper-class="gd-cascader-popper" v-model="formData.workOrderType" |
| | | :options="workOrderTypeXT" :props="taskTypeCascaderProps" placeholder="请选择" clearable collapse-tags /> |
| | | collapse-tags |
| | | /> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | |
| | | clearable |
| | | @change="loadDemandChange" |
| | | > |
| | | <el-option |
| | | v-for="item in payloadList" |
| | | :key="item.name" |
| | | :label="item.name" |
| | | :value="item.name" |
| | | /> |
| | | <el-option v-for="item in payloadList" :key="item.name" :label="item.name" :value="item.name" /> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | |
| | | </div> |
| | | <el-table |
| | | class="separateTable" |
| | | :empty-text=" |
| | | pointList.length ? '暂无数据' : '请先在地图上绘制工单范围' |
| | | " |
| | | :empty-text="pointList.length ? '暂无数据' : '请先在地图上绘制工单范围'" |
| | | ref="deviceTableRef" |
| | | :data="pointList.length ? deviceList : []" |
| | | row-key="id" |
| | |
| | | import OrderStepBar from '@/views/orderView/orderManage/orderManage/OrderStepBar.vue' |
| | | import OutcomeData from './outcomeData.vue' |
| | | import { getDictListApi } from '@/api/zkxt' |
| | | import { getTaskTypeLabel, taskTypeCascaderProps, toTaskTypeCascaderValue, toTaskTypeRequestValue } from '../taskTypeOptions' |
| | | import { |
| | | getTaskTypeLabel, |
| | | taskTypeCascaderProps, |
| | | toTaskTypeCascaderValue, |
| | | toTaskTypeRequestValue, |
| | | } from '../taskTypeOptions' |
| | | const store = useStore() |
| | | const permission = computed(() => store.state.user.permission) |
| | | const activeName = ref('basic') |
| | |
| | | async function getDeviceList() { |
| | | try { |
| | | const str = [...pointList.value, pointList.value[0]].map(item => `${item.longitude} ${item.latitude}`).join(',') |
| | | let geom = `POLYGON((${str}))` |
| | | let geom = `POLYGON((${str}))` |
| | | const res = await gdManageDeviceListApi({ |
| | | deviceIds: dialogMode.value === 'add' ? '' : formData.value.recommendDeviceIds, |
| | | devicePayload: formData.value?.deviceLoadDemand, |
| | |
| | | if (!formData.value.id) { |
| | | formData.value.workOrderStatus = '10' |
| | | } |
| | | const payload = { |
| | | ...formData.value, |
| | | workOrderType: toTaskTypeRequestValue(formData.value.workOrderType), |
| | | } |
| | | await gdWorkOrderSaveApi(payload) |
| | | await gdWorkOrderSaveApi(formData.value) |
| | | ElMessage.success(dialogMode.value === 'add' ? '新增成功' : '更新成功') |
| | | visible.value = false |
| | | emit('success') |
| | |
| | | </script> |
| | | |
| | | <style lang="scss"> |
| | | .orderManageFormDlg{ |
| | | .el-dialog__body{ |
| | | display: flex; |
| | | flex-direction: column; |
| | | .content{ |
| | | height: 0; |
| | | flex: 1; |
| | | } |
| | | .orderManageFormDlg { |
| | | .el-dialog__body { |
| | | display: flex; |
| | | flex-direction: column; |
| | | .content { |
| | | height: 0; |
| | | flex: 1; |
| | | } |
| | | } |
| | | } |
| | | </style> |
| | | |
| | |
| | | } |
| | | } |
| | | } |
| | | |
| | | |
| | | .content { |
| | | display: flex; |