|
|
@@ -0,0 +1,240 @@
|
|
|
+<template>
|
|
|
+ <el-dialog v-model="visible" title="数据模拟" fullscreen :close-on-click-modal="false" @closed="$emit('closed')">
|
|
|
+ <el-tabs v-model="apiKey">
|
|
|
+ <el-tab-pane label="参数配置" name="makeData" disabled></el-tab-pane>
|
|
|
+ <el-tab-pane label="数据复制" name="copyData"></el-tab-pane>
|
|
|
+ </el-tabs>
|
|
|
+
|
|
|
+ <el-form ref="formRef" :model="form" :rules="rules" label-width="126">
|
|
|
+ <el-row>
|
|
|
+ <el-col :md="12" :xs="24">
|
|
|
+ <el-form-item label="模拟项目" prop="targetProjectId">
|
|
|
+ <el-select v-model="form.targetProjectId" filterable placeholder="请选择模拟项目" @change="form.targetMountedId = null, dataTimeRange()">
|
|
|
+ <el-option v-for="item in $TOOL.data.get('PROJECT')" :key="item.fpiId" :label="item.projectName" :value="item.fpiId"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col v-if="form.targetProjectId" :md="12" :xs="24">
|
|
|
+ <el-form-item label="数据时间范围">
|
|
|
+ <template v-if="XEUtils.isEmpty(acceptItem)">该项目未配置验收清单,<el-button type="primary" link @click="$router.push('/system/acceptItems')">去配置</el-button></template>
|
|
|
+ <template v-else-if="acceptItem.beginTime">{{ $TOOL.dateFormat(acceptItem.beginTime, "YY.M.D") }}<span>-{{ acceptItem.endTime && $TOOL.dateFormat(acceptItem.endTime, "YY.M.D") || "至今" }}</span></template>
|
|
|
+ <template v-else>该项目未配置数据时间范围,<el-button type="primary" link @click="$router.push('/basic/project')">去配置</el-button></template>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :md="12" :xs="24">
|
|
|
+ <el-form-item label="模拟项目安装点" prop="targetMountedId">
|
|
|
+ <el-select v-model="form.targetMountedId" filterable placeholder="请选择模拟项目安装点">
|
|
|
+ <el-option v-for="item in filterTargetM" :key="item.id" :label="item.mountedName" :value="item.id"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :md="12" :xs="24">
|
|
|
+ <el-form-item label="模拟年份" prop="targetYear">
|
|
|
+ <el-date-picker v-model="form.targetYear" type="year" :clearable="false" value-format="YYYY" format="YYYY" placeholder="请选择模拟年份" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :md="12" :xs="24">
|
|
|
+ <el-form-item label="模拟月份">
|
|
|
+ <el-select v-model="form.targetMonth" filterable clearable placeholder="请选择模拟月份">
|
|
|
+ <el-option v-for="item in 12" :key="item" :label="item + '月'" :value="XEUtils.padStart(item, 2, '0')"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :md="12" :xs="24">
|
|
|
+ <el-form-item label="数据来源" prop="source">
|
|
|
+ <el-radio-group v-model="form.source" @change="refreshTable">
|
|
|
+ <el-radio value="template">模版项目</el-radio>
|
|
|
+ <el-radio value="other">其他项目</el-radio>
|
|
|
+ </el-radio-group>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :md="12" :xs="24">
|
|
|
+ <el-form-item label="数据处理" prop="opsDataType">
|
|
|
+ <el-radio-group v-model="form.opsDataType">
|
|
|
+ <el-radio :value="0">重复新增</el-radio>
|
|
|
+ <el-radio :value="1">数据覆盖</el-radio>
|
|
|
+ <el-radio :value="2">数据迁移</el-radio>
|
|
|
+ </el-radio-group>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col v-if="form.opsDataType == 2" :md="12" :xs="24">
|
|
|
+ <el-form-item label="迁移数据量" prop="recordNum">
|
|
|
+ <el-input-number v-model="form.recordNum" :min="0" :controls="false" placeholder="请输入迁移数据量"></el-input-number>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+
|
|
|
+ <el-divider style="margin-top: 6px;" />
|
|
|
+
|
|
|
+ <el-row>
|
|
|
+ <template v-if="form.source == 'other'">
|
|
|
+ <el-col :md="12" :xs="24">
|
|
|
+ <el-form-item label="数据源项目" prop="sourceProjectId">
|
|
|
+ <el-select v-model="form.sourceProjectId" filterable placeholder="请选择数据源项目" @change="form.sourceMountedId = null, refreshTable()">
|
|
|
+ <el-option v-for="item in $TOOL.data.get('PROJECT')" :key="item.fpiId" :label="item.projectName" :value="item.fpiId"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :md="12" :xs="24">
|
|
|
+ <el-form-item label="数据源安装点" prop="sourceMountedId">
|
|
|
+ <el-select v-model="form.sourceMountedId" filterable placeholder="请选择数据源安装点" @change="refreshTable">
|
|
|
+ <el-option v-for="item in filterSourceM" :key="item.id" :label="item.mountedName" :value="item.id"></el-option>
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ </template>
|
|
|
+
|
|
|
+ <el-col :md="12" :xs="24">
|
|
|
+ <el-form-item label="抓拍时间" prop="sourceTime">
|
|
|
+ <el-date-picker v-model="form.sourceTime" type="datetimerange" :clearable="false" value-format="YYYY-MM-DD HH:mm:ss" :default-time="[new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 1, 1, 23, 59, 59)]" :shortcuts="shortcuts" range-separator="至" start-placeholder="开始时间" end-placeholder="结束时间" @change="refreshTable"></el-date-picker>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+
|
|
|
+ <data-table ref="tableRef" :isTemp="form.source == 'template'" hideHandler :options="tableOptions"></data-table>
|
|
|
+ </el-form>
|
|
|
+
|
|
|
+ <template #footer>
|
|
|
+ <el-button :loading="isSaving" type="primary" auto-insert-space @click="submit()">提交</el-button>
|
|
|
+ <el-button v-if="form.opsDataType != 2 && form.source == 'other'" :loading="isSaving" type="primary" auto-insert-space @click="submit('template')">保存为模版</el-button>
|
|
|
+ <el-button auto-insert-space @click="visible = false">取消</el-button>
|
|
|
+ </template>
|
|
|
+ </el-dialog>
|
|
|
+</template>
|
|
|
+
|
|
|
+<script setup>
|
|
|
+import moment from "moment";
|
|
|
+import XEUtils from "xe-utils";
|
|
|
+import API from "@/api";
|
|
|
+import TOOL from "@/utils/tool";
|
|
|
+import { aiTypeDic } from "@/utils/basicDic";
|
|
|
+import { rangeShortcuts } from "@/utils/shortcuts";
|
|
|
+import dataTable from "./components/record";
|
|
|
+
|
|
|
+const route = useRoute();
|
|
|
+const $emit = defineEmits(["success", "closed"]);
|
|
|
+const apiKey = ref("copyData");
|
|
|
+const visible = ref(false);
|
|
|
+const isSaving = ref(false);
|
|
|
+
|
|
|
+const shortcuts = rangeShortcuts();
|
|
|
+const form = ref({
|
|
|
+ targetProjectId: TOOL.data.get("PROJECT_ID"),
|
|
|
+ targetMountedId: null,
|
|
|
+ targetYear: null,
|
|
|
+ targetMonth: null,
|
|
|
+ source: "other",
|
|
|
+ opsDataType: 0,
|
|
|
+ recordNum: null,
|
|
|
+ sourceProjectId: null,
|
|
|
+ sourceProjectIdNot: 1,
|
|
|
+ sourceMountedId: null,
|
|
|
+ recordType: "AIHAZARD_REC_ILLEGAL_ENTRY",
|
|
|
+ sourceTime: [moment().startOf("month").format("YYYY-MM-DD HH:mm:ss"), moment().format("YYYY-MM-DD HH:mm:ss")]
|
|
|
+});
|
|
|
+
|
|
|
+const rules = reactive({
|
|
|
+ targetProjectId: [{ required: true, message: "请选择模拟项目" }],
|
|
|
+ targetMountedId: [{ required: true, message: "请选择模拟项目安装点" }],
|
|
|
+ targetYear: [{ required: true, message: "请选择模拟年份" }],
|
|
|
+ source: [{ required: true }],
|
|
|
+ opsDataType: [{ required: true }],
|
|
|
+ recordNum: [{ required: true, message: "请输入迁移数据量" }],
|
|
|
+ sourceProjectId: [{ required: true, message: "请选择数据源项目" }],
|
|
|
+ sourceMountedId: [{ required: true, message: "请选择数据源安装点" }],
|
|
|
+ sourceTime: [{ required: true, message: "请选择数据源抓拍时间" }]
|
|
|
+})
|
|
|
+
|
|
|
+const tableRef = ref();
|
|
|
+const tableOptions = reactive({
|
|
|
+ batchDel: false,
|
|
|
+ maxHeight: 1048,
|
|
|
+ toolbarConfig: { enabled: true, print: false, zoom: false },
|
|
|
+ formConfig: { enabled: false, data: form },
|
|
|
+ paramsColums: computed(() => [
|
|
|
+ { column: "projectId", field: form.value.source == "template" ? "sourceProjectIdNot" : "sourceProjectId" },
|
|
|
+ form.value.source == "template" ? {} : { column: "projectIdNot", field: "sourceProjectIdNot" },
|
|
|
+ { column: "mountedId", field: "sourceMountedId" },
|
|
|
+ { column: "recordType" },
|
|
|
+ { column: "createTimeBegin", field: "sourceTime[0]" },
|
|
|
+ { column: "createTimeEnd", field: "sourceTime[1]" }
|
|
|
+ ])
|
|
|
+})
|
|
|
+const refreshTable = () => tableRef.value.refreshTable();
|
|
|
+
|
|
|
+
|
|
|
+const acceptItem = ref({});
|
|
|
+const dataTimeRange = async () => {
|
|
|
+ const query = {
|
|
|
+ projectId: form.value.targetProjectId,
|
|
|
+ itemName: XEUtils.last(route.meta.title.split("-"))
|
|
|
+ }
|
|
|
+ const res = await API.system.project.bindItem.judgment(query);
|
|
|
+ acceptItem.value = res || {};
|
|
|
+}
|
|
|
+
|
|
|
+const mounteds = ref([]);
|
|
|
+const filterTargetM = computed(() => form.value.targetProjectId ? XEUtils.filter(mounteds.value, item => item.projectId == form.value.targetProjectId) : []);
|
|
|
+const filterSourceM = computed(() => form.value.sourceProjectId ? XEUtils.filter(mounteds.value, item => item.projectId == form.value.sourceProjectId) : []);
|
|
|
+const fetchMounted = async () => {
|
|
|
+ const res = await API.aihazard.mounted.get();
|
|
|
+ mounteds.value = res || [];
|
|
|
+}
|
|
|
+
|
|
|
+const open = () => {
|
|
|
+ visible.value = true;
|
|
|
+ TOOL.data.get("PROJECT_ID") && dataTimeRange();
|
|
|
+ fetchMounted();
|
|
|
+}
|
|
|
+
|
|
|
+const formRef = ref();
|
|
|
+const submit = key => {
|
|
|
+ let validateField = XEUtils.keys(rules);
|
|
|
+ if (key == "template") {
|
|
|
+ validateField = XEUtils.keys(XEUtils.omit(rules, "targetProjectId", "targetMountedId"));
|
|
|
+ formRef.value.clearValidate(["targetProjectId", "targetMountedId"]);
|
|
|
+ }
|
|
|
+
|
|
|
+ formRef.value.validateField(validateField, valid => {
|
|
|
+ if (valid) {
|
|
|
+ if (tableRef.value?.getTableTotal() == 0) return ElMessage.warning("暂无相关数据,请调整条件后重试。");
|
|
|
+
|
|
|
+ const data = XEUtils.omit(form.value, "sourceProjectId", "sourceProjectIdNot", "source", "sourceTime", "recordNum");
|
|
|
+ XEUtils.set(data, "sourceBeginTime", XEUtils.first(form.value.sourceTime));
|
|
|
+ XEUtils.set(data, "sourceEndTime", XEUtils.last(form.value.sourceTime));
|
|
|
+
|
|
|
+ form.value.opsDataType == 2 && XEUtils.set(data, "recordNum", form.value.recordNum);
|
|
|
+ form.value.source == "template" && XEUtils.set(data, "sourceMountedId", XEUtils.get(XEUtils.find(mounteds.value, item => item.projectId == 1), "id"));
|
|
|
+ if (key == "template") {
|
|
|
+ XEUtils.set(data, "targetProjectId", 1);
|
|
|
+ XEUtils.set(data, "targetMountedId", XEUtils.get(XEUtils.find(mounteds.value, item => item.projectId == 1), "id"));
|
|
|
+ }
|
|
|
+
|
|
|
+ isSaving.value = true;
|
|
|
+ API.aihazard.dataMock[apiKey.value](data).then(() => {
|
|
|
+ isSaving.value = false;
|
|
|
+ ElMessage.success("操作成功");
|
|
|
+ visible.value = false;
|
|
|
+ $emit("success");
|
|
|
+ }).catch(() => isSaving.value = false);
|
|
|
+ } else {
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ });
|
|
|
+}
|
|
|
+
|
|
|
+defineExpose({
|
|
|
+ open
|
|
|
+})
|
|
|
+</script>
|
|
|
+
|
|
|
+<style lang="scss" scoped>
|
|
|
+.el-form {margin-top: 5px;padding-right: var(--el-message-close-size, 16px);}
|
|
|
+.el-form-item .el-radio-group {flex-wrap: nowrap;}
|
|
|
+
|
|
|
+.el-form-item .el-input-number {width: 100%;}
|
|
|
+.el-form-item .el-input-number :deep(.el-input__prefix) {margin-right: 8px;}
|
|
|
+.el-form-item .el-input-number :deep(.el-input__inner) {text-align: unset;}
|
|
|
+
|
|
|
+.el-form :deep(.el-main) {padding-right: 0;padding-bottom: 0;}
|
|
|
+</style>
|