ExportModal.vue 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. <template>
  2. <el-dialog v-model="props.visible" width="500px" :show-close="false" :close-on-click-modal="false" top="10vh"
  3. class="exportModal">
  4. <template #header="{ titleId, titleClass }">
  5. <div class="flex justify-between items-center border-b pb-3">
  6. <h4 :id="titleId" :class="titleClass">导出任务</h4>
  7. <div>
  8. <el-button type="primary" :loading="['2'].includes(props.saveLoading)" @click="submit()">
  9. 导出
  10. </el-button>
  11. <el-button @click="closeVisible()">取消</el-button>
  12. </div>
  13. </div>
  14. </template>
  15. <div class="mt-5">
  16. <el-form ref="formRef" :model="form" label-width="6em" class="flex flex-wrap form">
  17. <el-form-item label="优先级:">
  18. <el-select v-model="form.priority" placeholder="请选择" clearable>
  19. <el-option v-for="item in PRIORITY " :key="item.value" :value="item.value" :label="item.label" />
  20. </el-select>
  21. </el-form-item>
  22. <el-form-item label="执行人:">
  23. <el-select v-model="form.executorId" placeholder="请选择" clearable multiple filterable>
  24. <el-option v-for="item in executorValueData" :key="item.id" :value="item.id" :label="item.name" />
  25. </el-select>
  26. </el-form-item>
  27. <el-form-item label="开始时间:" class="w50">
  28. <el-date-picker v-model="form.startDate" type="date" placeholder="选择日期" value-format="YYYY-MM-DD" />
  29. </el-form-item>
  30. <el-form-item label="截止时间:" class="w50">
  31. <el-date-picker v-model="form.endDate" type="date" placeholder="选择日期" value-format="YYYY-MM-DD" />
  32. </el-form-item>
  33. </el-form>
  34. </div>
  35. </el-dialog>
  36. </template>
  37. <script lang="ts" setup>
  38. import { ref, watch } from 'vue';
  39. import { defalutExportForm, PRIORITY,ALL_USERS } from './api';
  40. import { post } from '@/utils/request';
  41. import { Emits, Props } from './type';
  42. const props = defineProps<Props>();
  43. const emits = defineEmits<Emits>();
  44. watch(() => props.visible, (val) => {
  45. if (val) {
  46. form.value = { ...defalutExportForm }
  47. post(ALL_USERS, {}).then(({ data }) => {
  48. executorValueData.value = data;
  49. })
  50. }
  51. })
  52. function closeVisible() {
  53. emits("close")
  54. }
  55. function submit() {
  56. const { executorId, ...rest } = form.value;
  57. const data = {
  58. ...rest,
  59. executorId: executorId.join(','),
  60. }
  61. emits("submit", data)
  62. }
  63. const formRef = ref();
  64. const form = ref<any>({})
  65. const executorValueData = ref<any>([])
  66. </script>
  67. <style lang="scss">
  68. .el-form-item {
  69. width: 100%;
  70. }
  71. .form {
  72. .w50 {
  73. @apply w-1/2;
  74. }
  75. }
  76. </style>