2026-01-22 11:07:07 +08:00
|
|
|
|
<script setup lang="ts">
|
|
|
|
|
|
import {computed, ref} from "vue";
|
|
|
|
|
|
import StockComposeTaskTypeFormatter from "@/plugin/formatter/StockComposeTaskTypeFormatter.ts";
|
|
|
|
|
|
import StockComposeTaskStatusFormatter from "@/plugin/formatter/StockComposeTaskStatusFormatter.ts";
|
|
|
|
|
|
import StockComposeStepStatusFormatter from "@/plugin/formatter/StockComposeStepStatusFormatter.ts";
|
|
|
|
|
|
import TrueFalseTagStyleFormatter from "@/plugin/formatter/TrueFalseTagStyleFormatter.ts";
|
|
|
|
|
|
import StringUtils from "@/utils/StringUtils.ts";
|
|
|
|
|
|
import StockComposeTaskApi from "@/api/stockComposeTask.ts";
|
|
|
|
|
|
import MessageUtils from "@/utils/MessageUtils.ts";
|
|
|
|
|
|
import {AppServeResponseCodeEnum} from "@/constant/enums/AppServeResponseCodeEnum.ts";
|
|
|
|
|
|
import type {AppServeResponse} from "@/interface/api/AppServeResponse.ts";
|
|
|
|
|
|
import type {ReporterTaskStatusReq} from "@/interface/page/stockTask/IReporterTaskStatusReq.ts";
|
|
|
|
|
|
import type {AppServeDataResponse} from "@/interface/api/AppServeDataResponse.ts";
|
|
|
|
|
|
import type {ICourseCalculateResult} from "@/interface/page/stockTask/ICourseCalculateResult.ts";
|
2026-02-22 11:04:07 +08:00
|
|
|
|
import AppPermission from "@/components/manage/AppPermission.vue";
|
2026-02-25 09:38:46 +08:00
|
|
|
|
import {useI18n} from "vue-i18n";
|
2026-01-22 11:07:07 +08:00
|
|
|
|
|
2026-02-25 09:38:46 +08:00
|
|
|
|
const { t } = useI18n();
|
2026-01-22 11:07:07 +08:00
|
|
|
|
const modelValue = defineModel('modelValue', {required: true, default: false});
|
|
|
|
|
|
const props = defineProps(['formData']);
|
|
|
|
|
|
const emit = defineEmits(['reLoadingTableData']);
|
|
|
|
|
|
const close = () => {
|
|
|
|
|
|
modelValue.value = false;
|
|
|
|
|
|
}
|
|
|
|
|
|
const formData = computed(() => props.formData);
|
|
|
|
|
|
const stockComposeTaskStatusFormatter = new StockComposeTaskStatusFormatter();
|
|
|
|
|
|
const stockComposeTaskTypeFormatter = new StockComposeTaskTypeFormatter();
|
|
|
|
|
|
const stockComposeStepStatusFormatter = new StockComposeStepStatusFormatter();
|
|
|
|
|
|
const trueFalseTagStyleFormatter = new TrueFalseTagStyleFormatter();
|
2026-02-25 09:38:46 +08:00
|
|
|
|
const uploadString = ref<string>("-"); // 上报信息
|
2026-01-22 11:07:07 +08:00
|
|
|
|
const uploadDestination = ref<string>(""); // 上报的终点
|
|
|
|
|
|
const course = ref<string[]>([]);
|
|
|
|
|
|
|
|
|
|
|
|
// 完成任务
|
|
|
|
|
|
const completeTask = () => {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.confirmMessageBox(t('customMessage.confirmExecute'), t('baseTip.confirmTip')).then(() => {
|
2026-01-22 11:07:07 +08:00
|
|
|
|
const loadingInstance = MessageUtils.loading();
|
|
|
|
|
|
StockComposeTaskApi.completeTask(formData.value.taskId).then((res) => {
|
|
|
|
|
|
const responseString = JSON.stringify(res.data);
|
|
|
|
|
|
const response = JSON.parse(responseString) as AppServeResponse;
|
|
|
|
|
|
if (response && response.code == AppServeResponseCodeEnum.SUCCESS) {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.successMessage(t('baseTip.success'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
emit('reLoadingTableData');
|
|
|
|
|
|
close();
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.errMessageBox(response.msg, t('baseTip.warning'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
}).catch(() => {}).finally(() => {
|
|
|
|
|
|
loadingInstance.close();
|
|
|
|
|
|
})
|
|
|
|
|
|
}).catch(() => {});
|
|
|
|
|
|
};
|
|
|
|
|
|
// 重做任务
|
|
|
|
|
|
const resetTask = () => {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.confirmMessageBox(t('customMessage.confirmExecute'), t('baseTip.confirmTip')).then(() => {
|
2026-01-22 11:07:07 +08:00
|
|
|
|
const loadingInstance = MessageUtils.loading();
|
|
|
|
|
|
StockComposeTaskApi.resetTask(formData.value.taskId).then((res) => {
|
|
|
|
|
|
const responseString = JSON.stringify(res.data);
|
|
|
|
|
|
const response = JSON.parse(responseString) as AppServeResponse;
|
|
|
|
|
|
if (response && response.code == AppServeResponseCodeEnum.SUCCESS) {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.successMessage(t('baseTip.success'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
emit('reLoadingTableData');
|
|
|
|
|
|
close();
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.errMessageBox(response.msg, t('baseTip.warning'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
}).catch(() => {}).finally(() => {
|
|
|
|
|
|
loadingInstance.close();
|
|
|
|
|
|
})
|
|
|
|
|
|
}).catch(() => {});
|
|
|
|
|
|
};
|
|
|
|
|
|
// 取消任务
|
|
|
|
|
|
const cancelTask = () => {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.confirmMessageBox(t('customMessage.confirmExecute'), t('baseTip.confirmTip')).then(() => {
|
2026-01-22 11:07:07 +08:00
|
|
|
|
const loadingInstance = MessageUtils.loading();
|
|
|
|
|
|
StockComposeTaskApi.cancelTask(formData.value.taskId).then((res) => {
|
|
|
|
|
|
const responseString = JSON.stringify(res.data);
|
|
|
|
|
|
const response = JSON.parse(responseString) as AppServeResponse;
|
|
|
|
|
|
if (response && response.code == AppServeResponseCodeEnum.SUCCESS) {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.successMessage(t('baseTip.success'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
emit('reLoadingTableData');
|
|
|
|
|
|
close();
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.errMessageBox(response.msg, t('baseTip.warning'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
}).catch(() => {}).finally(() => {
|
|
|
|
|
|
loadingInstance.close();
|
|
|
|
|
|
})
|
|
|
|
|
|
}).catch(() => {});
|
|
|
|
|
|
};
|
|
|
|
|
|
// 上报任务完成
|
|
|
|
|
|
const reportTaskComplete = () => {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.confirmMessageBox(t('customMessage.confirmExecute'), t('baseTip.confirmTip')).then(() => {
|
2026-01-22 11:07:07 +08:00
|
|
|
|
const loadingInstance = MessageUtils.loading();
|
|
|
|
|
|
const reportData: ReporterTaskStatusReq = {
|
|
|
|
|
|
taskId: formData.value.taskId,
|
|
|
|
|
|
message: uploadString.value,
|
|
|
|
|
|
destination: uploadDestination.value
|
|
|
|
|
|
};
|
|
|
|
|
|
StockComposeTaskApi.reportTaskComplete(reportData).then((res) => {
|
|
|
|
|
|
const responseString = JSON.stringify(res.data);
|
|
|
|
|
|
const response = JSON.parse(responseString) as AppServeResponse;
|
|
|
|
|
|
if (response && response.code == AppServeResponseCodeEnum.SUCCESS) {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.successMessage(t('baseTip.success'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.errMessageBox(response.msg, t('baseTip.warning'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
}).catch(() => {}).finally(() => {
|
|
|
|
|
|
loadingInstance.close();
|
|
|
|
|
|
})
|
|
|
|
|
|
}).catch(() => {});
|
|
|
|
|
|
};
|
|
|
|
|
|
// 上报任务取消
|
|
|
|
|
|
const reportTaskCancel = () => {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.confirmMessageBox(t('customMessage.confirmExecute'), t('baseTip.confirmTip')).then(() => {
|
2026-01-22 11:07:07 +08:00
|
|
|
|
const loadingInstance = MessageUtils.loading();
|
|
|
|
|
|
const reportData: ReporterTaskStatusReq = {
|
|
|
|
|
|
taskId: formData.value.taskId,
|
|
|
|
|
|
message: uploadString.value,
|
|
|
|
|
|
destination: uploadDestination.value
|
|
|
|
|
|
};
|
|
|
|
|
|
StockComposeTaskApi.reportTaskCancel(reportData).then((res) => {
|
|
|
|
|
|
const responseString = JSON.stringify(res.data);
|
|
|
|
|
|
const response = JSON.parse(responseString) as AppServeResponse;
|
|
|
|
|
|
if (response && response.code == AppServeResponseCodeEnum.SUCCESS) {
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.successMessage(t('baseTip.success'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.errMessageBox(response.msg, t('baseTip.warning'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
}).catch(() => {}).finally(() => {
|
|
|
|
|
|
loadingInstance.close();
|
|
|
|
|
|
})
|
|
|
|
|
|
}).catch(() => {});
|
|
|
|
|
|
};
|
|
|
|
|
|
// 计算路线
|
|
|
|
|
|
const calculateCourse = () => {
|
|
|
|
|
|
const loadingInstance = MessageUtils.loading();
|
|
|
|
|
|
course.value = [];
|
|
|
|
|
|
StockComposeTaskApi.calculateCourse(formData.value.taskId).then((res) => {
|
|
|
|
|
|
const responseString = JSON.stringify(res.data);
|
|
|
|
|
|
const response = JSON.parse(responseString) as AppServeDataResponse<ICourseCalculateResult[]>;
|
|
|
|
|
|
if (response && response.code == AppServeResponseCodeEnum.SUCCESS && response.data != null) {
|
|
|
|
|
|
const calculateResults = response.data;
|
|
|
|
|
|
course.value = calculateResults.map(item => item.location + '(' + item.locationType + ')');
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.successMessage(t('baseTip.success'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
return;
|
|
|
|
|
|
}
|
2026-02-25 09:38:46 +08:00
|
|
|
|
MessageUtils.errMessageBox(response.msg, t('baseTip.warning'));
|
2026-01-22 11:07:07 +08:00
|
|
|
|
}).catch(() => {}).finally(() => {
|
|
|
|
|
|
loadingInstance.close();
|
|
|
|
|
|
})
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// 弹窗打开时
|
|
|
|
|
|
const open = () => {
|
|
|
|
|
|
course.value = [];
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<template>
|
|
|
|
|
|
<div>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-dialog :model-value="modelValue" :title="t('tabPage.stockComposeTask.detailTitle')" @close="close" :close-on-click-modal="false" @open="open">
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-scrollbar style="height:50vh">
|
|
|
|
|
|
<el-row>
|
|
|
|
|
|
<el-col :span="12">
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form :model="formData" label-position="right" label-width="180px" require-asterisk-position="right">
|
|
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.taskId')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.taskId" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.taskGroup')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.taskGroup" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.upperSystemTaskId')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.upperTaskId" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.taskType')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-select v-model="formData.taskType" disabled>
|
|
|
|
|
|
<el-option v-for="item in stockComposeTaskTypeFormatter.taskTypeTagStyle" :key="item.value" :label="item.label" :value="item.value"/>
|
|
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.vehicleNo')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.vehicleNo" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.taskStatus')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-select v-model="formData.taskStatus" disabled>
|
|
|
|
|
|
<el-option v-for="item in stockComposeTaskStatusFormatter.taskStatusTagStyle" :key="item.value" :label="item.label" :value="item.value"/>
|
|
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.origin')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.origin" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.destination')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.destination" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.stepStatus')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-select v-model="formData.stepStatus" disabled>
|
|
|
|
|
|
<el-option v-for="item in stockComposeStepStatusFormatter.stepStatusTagStyle" :key="item.value" :label="item.label" :value="item.value"/>
|
|
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.priority')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input-number :max="9" :min="0" v-model="formData.priority" disabled></el-input-number>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.vehicleSize')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input-number :max="9" :min="0" v-model="formData.vehicleSize" disabled></el-input-number>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.weight')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input-number :max="9" :min="0" v-model="formData.weight" disabled></el-input-number>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.canCancel')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-select v-model="formData.canCancel" disabled>
|
|
|
|
|
|
<el-option v-for="item in trueFalseTagStyleFormatter.trueFalseTagStyle" :key="item.value" :label="item.label" :value="item.value"/>
|
|
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.createTime')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.createTime" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.updateTime')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.updateTime" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.startTime')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.startTime" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.completeTime')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.completeTime" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.endTime')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.endTime" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.taskSource')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.taskSource" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.createPerson')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.createPerson" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
2026-02-25 09:38:46 +08:00
|
|
|
|
<el-form-item :label="t('tabPage.stockComposeTask.taskMsg')" required>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-input v-model="formData.taskMsg" disabled></el-input>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</el-form>
|
|
|
|
|
|
</el-col>
|
2026-02-22 11:04:07 +08:00
|
|
|
|
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-col :span="11" :offset="1">
|
2026-02-22 11:04:07 +08:00
|
|
|
|
<app-permission permission="stockComposeTask:upload">
|
|
|
|
|
|
<el-row v-if="!StringUtils.isNullOrEmpty(formData.upperTaskId)">
|
|
|
|
|
|
<el-row>
|
|
|
|
|
|
<div>上报附加信息:</div>
|
|
|
|
|
|
<el-input v-model="uploadString"></el-input>
|
|
|
|
|
|
</el-row>
|
|
|
|
|
|
<el-row>
|
|
|
|
|
|
<div>终点(仅上报完成有效):</div>
|
|
|
|
|
|
<el-input v-model="uploadDestination"></el-input>
|
|
|
|
|
|
</el-row>
|
|
|
|
|
|
<el-row style="margin-top: 10px">
|
|
|
|
|
|
<el-button-group>
|
|
|
|
|
|
<el-button type="success" @click="reportTaskComplete">上报任务完成</el-button>
|
|
|
|
|
|
<el-button type="warning" @click="reportTaskCancel">上报任务取消</el-button>
|
|
|
|
|
|
</el-button-group>
|
|
|
|
|
|
</el-row>
|
|
|
|
|
|
<el-row>
|
|
|
|
|
|
<el-text type="warning">此处仅上报不会更新任务状态,点击下方【完成任务】或者【取消任务】按钮时将会自动上报并更新任务状态</el-text>
|
|
|
|
|
|
</el-row>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
</el-row>
|
2026-02-22 11:04:07 +08:00
|
|
|
|
</app-permission>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-row v-if="course.length > 0">
|
|
|
|
|
|
<el-row>
|
|
|
|
|
|
<el-text type="primary" style="font-size: 1.2rem">模拟路径计算:</el-text>
|
|
|
|
|
|
</el-row>
|
|
|
|
|
|
<el-row v-for="(item, index) in course" :key="index">
|
|
|
|
|
|
<el-text type="success">{{item + (index == course.length - 1 ? '' : ' ----> ' )}}</el-text>
|
|
|
|
|
|
</el-row>
|
|
|
|
|
|
</el-row>
|
|
|
|
|
|
</el-col>
|
|
|
|
|
|
</el-row>
|
|
|
|
|
|
</el-scrollbar>
|
|
|
|
|
|
<template #footer>
|
|
|
|
|
|
<el-button-group>
|
|
|
|
|
|
<el-button type="info" @click="calculateCourse">模拟路径计算</el-button>
|
2026-02-22 11:04:07 +08:00
|
|
|
|
<app-permission permission="stockComposeTask:edit"><el-button type="success" @click="completeTask">完成任务</el-button></app-permission>
|
|
|
|
|
|
<app-permission permission="stockComposeTask:edit"><el-button type="primary" @click="resetTask">重做任务</el-button></app-permission>
|
|
|
|
|
|
<app-permission permission="stockComposeTask:edit"><el-button type="warning" @click="cancelTask">取消任务</el-button></app-permission>
|
2026-01-22 11:07:07 +08:00
|
|
|
|
<el-button type="danger" @click="close">关闭窗口</el-button>
|
|
|
|
|
|
</el-button-group>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-dialog>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
|
|
|
|
|
|
</style>
|