batchDel.vue 6.4 KB

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