Second-handle-detail.vue 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. <template>
  2. <el-dialog v-model="state.dialogVisible" draggable title="二次办理明细" width="40%" append-to-body destroy-on-close @close="close">
  3. <div class="collapse-container" v-loading="state.loading">
  4. <el-form ref="ruleFormRef" label-width="80px" :model="state.ruleForm" class="show-info-form">
  5. <el-row :gutter="35">
  6. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
  7. <el-form-item label="办理人"> {{ state.ruleForm?.auditUser }} </el-form-item>
  8. </el-col>
  9. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
  10. <el-form-item label="办理时间"> {{ formatDate(state.ruleForm?.auditTime, 'YYYY-mm-dd HH:MM:SS') }} </el-form-item>
  11. </el-col>
  12. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
  13. <el-form-item label="办理理由" class="formatted-text">
  14. {{state.ruleForm.content}}
  15. </el-form-item>
  16. </el-col>
  17. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
  18. <el-form-item label="附件">
  19. <annex-list name="附件列表" readonly :businessId="state.ruleForm.id" classify="查看附件" v-model="state.ruleForm.files" />
  20. </el-form-item>
  21. </el-col>
  22. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" v-if="state.ruleForm?.auditContent">
  23. <el-form-item label="审批意见" class="formatted-text">
  24. {{state.ruleForm.auditContent}}
  25. </el-form-item>
  26. </el-col>
  27. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" v-if="state.ruleForm?.sendBackContent">
  28. <el-form-item label="退回意见" class="formatted-text">
  29. {{state.ruleForm.sendBackContent}}
  30. </el-form-item>
  31. </el-col>
  32. </el-row>
  33. </el-form>
  34. </div>
  35. <template #footer>
  36. <span class="dialog-footer">
  37. <el-button @click="closeDialog" class="default-button">关 闭</el-button>
  38. </span>
  39. </template>
  40. </el-dialog>
  41. </template>
  42. <script setup lang="ts">
  43. import { defineAsyncComponent, reactive, ref } from 'vue';
  44. import { secondHandleDetail } from "@/api/business/secondHandle";
  45. import { formatDate } from "@/utils/formatTime";
  46. import { transformFile } from "@/utils/tools";
  47. // 引入组件
  48. const AnnexList = defineAsyncComponent(() => import('@/components/AnnexList/index.vue'));
  49. // 定义子组件向父组件传值/事件
  50. const emit = defineEmits(['updateList']);
  51. // 定义变量内容
  52. const state = reactive<any>({
  53. dialogVisible: false, // 是否显示弹窗
  54. loading: false, // 是否显示加载
  55. ruleForm: {
  56. },
  57. });
  58. const ruleFormRef = ref<RefType>();
  59. const ids = ref<any>([]);
  60. // 打开弹窗
  61. const openDialog = async (id: string) => {
  62. secondHandleDetail(id)
  63. .then((res: any) => {
  64. state.ruleForm = res.result;
  65. state.ruleForm.files = transformFile(res.result.files);
  66. state.dialogVisible = true;
  67. })
  68. .catch((err: any) => {});
  69. };
  70. // 关闭弹窗
  71. const closeDialog = () => {
  72. state.dialogVisible = false;
  73. };
  74. const close = () => {
  75. ruleFormRef.value?.clearValidate();
  76. };
  77. defineExpose({
  78. openDialog,
  79. closeDialog,
  80. });
  81. </script>