batchDel.vue 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <template>
  2. <el-dialog v-model="visible" title="批量删除" fullscreen :close-on-click-modal="false" @closed="$emit('closed')">
  3. <el-form ref="formRef" :model="form" :rules="rules" label-width="110">
  4. <el-form-item label="数据来源" prop="isTemp">
  5. <el-radio-group v-model="form.isTemp" @change="refreshTable">
  6. <el-radio :value="true">模版项目</el-radio>
  7. <el-radio :value="false">其他项目</el-radio>
  8. </el-radio-group>
  9. </el-form-item>
  10. <el-row>
  11. <template v-if="!form.isTemp">
  12. <el-col :lg="8" :md="12" :xs="24">
  13. <el-form-item label="项目名称" prop="targetProjectId">
  14. <el-select v-model="form.targetProjectId" filterable placeholder="请选择删除数据的项目" @change="refreshTable">
  15. <el-option v-for="item in $TOOL.data.get('PROJECT')" :key="item.fpiId" :label="item.projectName" :value="item.fpiId"></el-option>
  16. </el-select>
  17. </el-form-item>
  18. </el-col>
  19. <el-col :lg="8" :md="12" :xs="24">
  20. <el-form-item label="设备安装点" prop="targetMountedId">
  21. <el-select v-model="form.targetMountedId" filterable placeholder="请选择删除数据的安装点" @change="refreshTable">
  22. <el-option v-for="item in filterTargetM" :key="item.id" :label="item.mountedName" :value="item.id"></el-option>
  23. </el-select>
  24. </el-form-item>
  25. </el-col>
  26. </template>
  27. <el-col :lg="8" :md="12" :xs="24">
  28. <el-form-item label="识别结果">
  29. <el-select v-model="form.recordType" filterable clearable placeholder="请选择识别结果" @change="refreshTable">
  30. <el-option v-for="(label, key) in aiTypeDic" :key="key" :label="label" :value="key"></el-option>
  31. </el-select>
  32. </el-form-item>
  33. </el-col>
  34. <el-col :lg="8" :md="12" :xs="24">
  35. <el-form-item label="数据时间" prop="targetTime">
  36. <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>
  37. </el-form-item>
  38. </el-col>
  39. </el-row>
  40. <el-divider style="margin-top: 6px;" />
  41. <data-table ref="tableRef" :isTemp="form.isTemp" hideHandler :options="tableOptions"></data-table>
  42. </el-form>
  43. <template #footer>
  44. <el-button :loading="isSaving" type="primary" auto-insert-space @click="submit">提交</el-button>
  45. <el-button auto-insert-space @click="visible = false">取消</el-button>
  46. </template>
  47. </el-dialog>
  48. </template>
  49. <script setup>
  50. import moment from "moment";
  51. import XEUtils from "xe-utils";
  52. import API from "@/api";
  53. import TOOL from "@/utils/tool";
  54. import { aiTypeDic } from "@/utils/basicDic";
  55. import { rangeShortcuts } from "@/utils/shortcuts";
  56. import dataTable from "./components/record";
  57. const $emit = defineEmits(["success", "closed"]);
  58. const visible = ref(false);
  59. const isSaving = ref(false);
  60. const shortcuts = rangeShortcuts();
  61. const form = ref({
  62. isTemp: false,
  63. targetProjectId: TOOL.data.get("PROJECT_ID"),
  64. targetProjectIdNot: 1,
  65. targetMountedId: null,
  66. recordType: null,
  67. targetTime: [moment().startOf("month").format("YYYY-MM-DD HH:mm:ss"), moment().format("YYYY-MM-DD HH:mm:ss")]
  68. });
  69. const rules = reactive({
  70. isTemp: [{ required: true }],
  71. targetProjectId: [{ required: true, message: "请选择删除数据的项目" }],
  72. targetMountedId: [{ required: true, message: "请选择删除数据的安装点" }],
  73. targetTime: [{ required: true, message: "请选择删除数据的时间" }]
  74. })
  75. const tableRef = ref();
  76. const tableOptions = reactive({
  77. batchDel: false,
  78. maxHeight: 1048,
  79. toolbarConfig: { enabled: true, print: false, zoom: false },
  80. formConfig: { enabled: false, data: form },
  81. paramsColums: computed(() => [
  82. { column: "projectId", field: form.value.isTemp ? "targetProjectIdNot" : "targetProjectId" },
  83. form.value.isTemp ? {} : { column: "projectIdNot", field: "targetProjectIdNot" },
  84. { column: "mountedId", field: "targetMountedId" },
  85. { column: "recordType" },
  86. { column: "createTimeBegin", field: "targetTime[0]" },
  87. { column: "createTimeEnd", field: "targetTime[1]" }
  88. ])
  89. })
  90. const refreshTable = () => tableRef.value.refreshTable();
  91. const mounteds = ref([]);
  92. const filterTargetM = computed(() => form.value.targetProjectId ? XEUtils.filter(mounteds.value, item => item.projectId == form.value.targetProjectId) : []);
  93. const fetchMounted = async () => {
  94. const res = await API.aihazard.mounted.get();
  95. mounteds.value = res || [];
  96. }
  97. const open = () => {
  98. visible.value = true;
  99. fetchMounted();
  100. }
  101. const formRef = ref();
  102. const submit = () => {
  103. formRef.value.validate(valid => {
  104. if (valid) {
  105. const data = XEUtils.pick(form.value, "targetProjectId", "targetMountedId", "recordType");
  106. XEUtils.set(data, "targetBeginTime", XEUtils.first(form.value.targetTime));
  107. XEUtils.set(data, "targetEndTime", XEUtils.last(form.value.targetTime));
  108. if (form.value.isTemp) {
  109. XEUtils.set(data, "targetProjectId", 1);
  110. XEUtils.set(data, "targetMountedId", XEUtils.get(XEUtils.find(mounteds.value, item => item.projectId == 1), "id"));
  111. }
  112. isSaving.value = true;
  113. API.aihazard.dataMock.removeData(data).then(() => {
  114. isSaving.value = false;
  115. ElMessage.success("操作成功");
  116. visible.value = false;
  117. $emit("success");
  118. }).catch(() => isSaving.value = false);
  119. } else {
  120. return false;
  121. }
  122. });
  123. }
  124. defineExpose({
  125. open
  126. })
  127. </script>
  128. <style lang="scss" scoped>
  129. .el-form {margin-top: 5px;padding-right: var(--el-message-close-size, 16px);}
  130. .el-form-item .el-radio-group {flex-wrap: nowrap;}
  131. .el-form :deep(.el-main) {padding-right: 0;padding-bottom: 0;}
  132. </style>