| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- <template>
- <el-dialog v-model="visible" title="批量删除" fullscreen :close-on-click-modal="false" @closed="$emit('closed')">
- <el-form ref="formRef" :model="form" :rules="rules" label-width="110">
- <el-form-item label="数据来源" prop="isTemp">
- <el-radio-group v-model="form.isTemp" @change="refreshTable">
- <el-radio :value="true">模版项目</el-radio>
- <el-radio :value="false">其他项目</el-radio>
- </el-radio-group>
- </el-form-item>
-
- <el-row>
- <template v-if="!form.isTemp">
- <el-col :lg="8" :md="12" :xs="24">
- <el-form-item label="项目名称" prop="targetProjectId">
- <el-select v-model="form.targetProjectId" filterable placeholder="请选择删除数据的项目" @change="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 :lg="8" :md="12" :xs="24">
- <el-form-item label="设备安装点" prop="targetMountedId">
- <el-select v-model="form.targetMountedId" filterable placeholder="请选择删除数据的安装点" @change="refreshTable">
- <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>
- </template>
- <el-col :lg="8" :md="12" :xs="24">
- <el-form-item label="识别结果">
- <el-select v-model="form.recordType" filterable clearable placeholder="请选择识别结果" @change="refreshTable">
- <el-option v-for="(label, key) in aiTypeDic" :key="key" :label="label" :value="key"></el-option>
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :lg="8" :md="12" :xs="24">
- <el-form-item label="数据时间" prop="targetTime">
- <el-date-picker v-model="form.targetTime" 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>
- <el-divider style="margin-top: 6px;" />
- <data-table ref="tableRef" :isTemp="form.isTemp" hideHandler :options="tableOptions"></data-table>
- </el-form>
- <template #footer>
- <el-button :loading="isSaving" type="primary" auto-insert-space @click="submit">提交</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 $emit = defineEmits(["success", "closed"]);
- const visible = ref(false);
- const isSaving = ref(false);
- const shortcuts = rangeShortcuts();
- const form = ref({
- isTemp: false,
- targetProjectId: TOOL.data.get("PROJECT_ID"),
- targetProjectIdNot: 1,
- targetMountedId: null,
- recordType: null,
- targetTime: [moment().startOf("month").format("YYYY-MM-DD HH:mm:ss"), moment().format("YYYY-MM-DD HH:mm:ss")]
- });
- const rules = reactive({
- isTemp: [{ required: true }],
- targetProjectId: [{ required: true, message: "请选择删除数据的项目" }],
- targetMountedId: [{ required: true, message: "请选择删除数据的安装点" }],
- targetTime: [{ 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.isTemp ? "targetProjectIdNot" : "targetProjectId" },
- form.value.isTemp ? {} : { column: "projectIdNot", field: "targetProjectIdNot" },
- { column: "mountedId", field: "targetMountedId" },
- { column: "recordType" },
- { column: "createTimeBegin", field: "targetTime[0]" },
- { column: "createTimeEnd", field: "targetTime[1]" }
- ])
- })
- const refreshTable = () => tableRef.value.refreshTable();
- const mounteds = ref([]);
- const filterTargetM = computed(() => form.value.targetProjectId ? XEUtils.filter(mounteds.value, item => item.projectId == form.value.targetProjectId) : []);
- const fetchMounted = async () => {
- const res = await API.aihazard.mounted.get();
- mounteds.value = res || [];
- }
- const open = () => {
- visible.value = true;
- fetchMounted();
- }
- const formRef = ref();
- const submit = () => {
- formRef.value.validate(valid => {
- if (valid) {
- const data = XEUtils.pick(form.value, "targetProjectId", "targetMountedId", "recordType");
- XEUtils.set(data, "targetBeginTime", XEUtils.first(form.value.targetTime));
- XEUtils.set(data, "targetEndTime", XEUtils.last(form.value.targetTime));
- if (form.value.isTemp) {
- 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.removeData(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 :deep(.el-main) {padding-right: 0;padding-bottom: 0;}
- </style>
|