Order-urge-detail.vue 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <template>
  2. <el-dialog v-model="state.dialogVisible" draggable title="催办详情" ref="dialogRef" width="50%" destroy-on-close @close="close">
  3. <div class="collapse-container">
  4. <el-form label-width="110px" ref="ruleFormRef" :model="state.ruleForm" class="show-info-form">
  5. <el-row :gutter="10">
  6. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
  7. <el-form-item label="工单编码"> {{ state.orderDetail.no }} </el-form-item>
  8. </el-col>
  9. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
  10. <el-form-item label="工单标题"> {{ state.orderDetail.title }} </el-form-item>
  11. </el-col>
  12. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
  13. <el-form-item label="催办人"> {{ state.urgeDetail.crUser }} </el-form-item>
  14. </el-col>
  15. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
  16. <el-form-item label="催办部门"> {{ state.urgeDetail.creatorOrgName }} </el-form-item>
  17. </el-col>
  18. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
  19. <el-form-item label="催办时间"> {{ formatDate(state.urgeDetail.creationTime, 'YYYY-mm-dd HH:MM:SS') }} </el-form-item>
  20. </el-col>
  21. <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
  22. <el-form-item label="被催办部门">{{ state.urgeDetail.orgName }}</el-form-item>
  23. </el-col>
  24. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
  25. <el-form-item label="催办内容" class="formatted-text">{{ state.urgeDetail.applyContent }}</el-form-item>
  26. </el-col>
  27. <!-- <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
  28. <el-form-item label="附件" prop="handleResult" :rules="[{ required: false, message: '请选择附件', trigger: 'change' }]">
  29. <annex-list name="催办附件" readonly classify="催办附件" v-model="state.urgeDetail.files" />
  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" name="businessUrgeDetailDialog">
  43. import { defineAsyncComponent, reactive } from 'vue';
  44. import { formatDate } from '@/utils/formatTime';
  45. import { urgeDetail, urgeSign } from '@/api/business/urge';
  46. import { ElMessage } from 'element-plus';
  47. import { transformFile } from '@/utils/tools';
  48. // 引入组件
  49. const AnnexList = defineAsyncComponent(() => import('@/components/AnnexList/index.vue'));
  50. // 定义子组件向父组件传值/事件
  51. const emit = defineEmits(['updateList']);
  52. // 定义变量内容
  53. const state = reactive<any>({
  54. dialogVisible: false, // 是否显示弹窗
  55. loading: false, // 是否显示加载
  56. ruleForm: {
  57. acceptSms: false, // 发送催办短信
  58. applyContent: '', // 催办内容
  59. },
  60. urgeDetail: {}, // 催办详情
  61. orderDetail: {}, // 工单详情
  62. orgData: [], // 被催办部门
  63. urgeObj: {},
  64. });
  65. const getDetail = async (id: string) => {
  66. try {
  67. const { result } = await urgeDetail(id);
  68. state.urgeDetail = result ?? {};
  69. state.orderDetail = result?.order ?? {};
  70. state.urgeDetail.files = transformFile(state.urgeDetail.files);
  71. state.dialogVisible = true;
  72. } catch (e) {
  73. console.log(e);
  74. }
  75. };
  76. // 催办签收
  77. const onSign = (id: string) => {
  78. urgeSign({ id }).then(() => {
  79. ElMessage.success('签收成功');
  80. emit('updateList');
  81. });
  82. };
  83. // 打开弹窗
  84. const openDialog = (val: any) => {
  85. state.urgeObj = val;
  86. getDetail(val.id);
  87. };
  88. // 关闭弹窗
  89. const closeDialog = () => {
  90. state.dialogVisible = false;
  91. };
  92. const close = () => {
  93. if (!state.urgeObj.signTime) {
  94. // 如果没有签收时间签收
  95. onSign(state.urgeObj.id);
  96. }
  97. };
  98. defineExpose({
  99. openDialog,
  100. closeDialog,
  101. });
  102. </script>