batchDel.vue 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  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-row>
  5. <el-col :lg="8" :md="12" :xs="24">
  6. <el-form-item label="项目名称" prop="targetProjectId">
  7. <el-select v-model="form.targetProjectId" filterable placeholder="请选择删除数据的项目" @change="refreshTable">
  8. <el-option v-for="item in $TOOL.data.get('PROJECT')" :key="item.fpiId" :label="item.projectName" :value="item.fpiId"></el-option>
  9. </el-select>
  10. </el-form-item>
  11. </el-col>
  12. <el-col :lg="8" :md="12" :xs="24">
  13. <el-form-item label="广播任务" prop="targetTaskId">
  14. <el-select v-model="form.targetTaskId" filterable placeholder="请选择删除数据的广播任务" @change="refreshTable">
  15. <el-option v-for="item in filterTasks" :key="item.id" :label="item.taskName" :value="item.id"></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="targetTime">
  21. <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>
  22. </el-form-item>
  23. </el-col>
  24. </el-row>
  25. <el-divider style="margin-top: 6px;" />
  26. <data-table ref="tableRef" hideHandler :options="tableOptions"></data-table>
  27. </el-form>
  28. <template #footer>
  29. <el-button :loading="isSaving" type="primary" auto-insert-space @click="submit">提交</el-button>
  30. <el-button auto-insert-space @click="visible = false">取消</el-button>
  31. </template>
  32. </el-dialog>
  33. </template>
  34. <script setup>
  35. import moment from "moment";
  36. import XEUtils from "xe-utils";
  37. import API from "@/api";
  38. import TOOL from "@/utils/tool";
  39. import { rangeShortcuts } from "@/utils/shortcuts";
  40. import dataTable from "./components/record";
  41. const $emit = defineEmits(["success", "closed"]);
  42. const visible = ref(false);
  43. const isSaving = ref(false);
  44. const shortcuts = rangeShortcuts();
  45. const form = ref({
  46. targetProjectId: TOOL.data.get("PROJECT_ID"),
  47. targetProjectIdNot: 1,
  48. targetTaskId: null,
  49. targetTime: [moment().startOf("month").format("YYYY-MM-DD HH:mm:ss"), moment().format("YYYY-MM-DD HH:mm:ss")]
  50. });
  51. const rules = reactive({
  52. targetProjectId: [{ required: true, message: "请选择删除数据的项目" }],
  53. targetTaskId: [{ required: true, message: "请选择删除数据的广播任务" }],
  54. targetTime: [{ required: true, message: "请选择删除数据的时间" }]
  55. })
  56. const tableRef = ref();
  57. const tableOptions = reactive({
  58. batchDel: false,
  59. maxHeight: 1048,
  60. toolbarConfig: { enabled: true, print: false, zoom: false },
  61. formConfig: { enabled: false, data: form },
  62. paramsColums: computed(() => [
  63. { column: "projectId", field: "targetProjectId" },
  64. { column: "projectIdNot", field: "targetProjectIdNot" },
  65. { column: "taskId", field: "targetTaskId" },
  66. { column: "createTimeBegin", field: "targetTime[0]" },
  67. { column: "createTimeEnd", field: "targetTime[1]" }
  68. ])
  69. })
  70. const refreshTable = () => tableRef.value.refreshTable();
  71. const tasks = ref([]);
  72. const filterTasks = computed(() => form.value.targetProjectId ? XEUtils.filter(tasks.value, item => item.projectId == form.value.targetProjectId) : []);
  73. const fetchTask = async () => {
  74. const res = await API.broadcast.task.get();
  75. tasks.value = res || [];
  76. }
  77. const open = () => {
  78. visible.value = true;
  79. fetchTask();
  80. }
  81. const formRef = ref();
  82. const submit = () => {
  83. formRef.value.validate(valid => {
  84. if (valid) {
  85. const data = XEUtils.pick(form.value, "targetProjectId", "targetTaskId");
  86. XEUtils.set(data, "targetBeginTime", XEUtils.first(form.value.targetTime));
  87. XEUtils.set(data, "targetEndTime", XEUtils.last(form.value.targetTime));
  88. isSaving.value = true;
  89. API.broadcast.dataMock.removeData(data).then(() => {
  90. isSaving.value = false;
  91. ElMessage.success("操作成功");
  92. visible.value = false;
  93. $emit("success");
  94. }).catch(() => isSaving.value = false);
  95. } else {
  96. return false;
  97. }
  98. });
  99. }
  100. defineExpose({
  101. open
  102. })
  103. </script>
  104. <style lang="scss" scoped>
  105. .el-form {margin-top: 5px;padding-right: var(--el-message-close-size, 16px);}
  106. .el-form-item .el-radio-group {flex-wrap: nowrap;}
  107. .el-form :deep(.el-main) {padding-right: 0;padding-bottom: 0;}
  108. </style>