Special-audit-detail.vue 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <template>
  2. <el-dialog v-model="state.dialogVisible" draggable title="特提审批明细" width="50%" append-to-body destroy-on-close>
  3. <div class="collapse-container">
  4. <el-form label-width="110px" :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.detail?.order?.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.detail?.order?.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.detail?.creatorName }} </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.detail?.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.detail?.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="申请特提节点" class="mb5">
  23. {{ state.detail?.stepName }}
  24. </el-form-item>
  25. </el-col>
  26. <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
  27. <el-form-item label="审批通过后节点" class="mb5">
  28. {{ state.detail?.nextStepName }}
  29. </el-form-item>
  30. </el-col>
  31. <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
  32. <el-form-item label="特提原因">
  33. {{ state.detail?.cause }}
  34. </el-form-item>
  35. </el-col>
  36. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
  37. <el-form-item label="特提理由" class="formatted-text">
  38. {{ state.detail?.reason }}
  39. </el-form-item>
  40. </el-col>
  41. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
  42. <el-form-item label="附件">
  43. <annex-list name="特提附件" readonly classify="特提附件" v-model="state.detail.files" />
  44. </el-form-item>
  45. </el-col>
  46. <el-divider content-position="left">
  47. <el-text tag="b" size="large"> 审批详情 </el-text>
  48. </el-divider>
  49. <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
  50. <el-form-item label="审批结果">
  51. {{ state.detail?.stateText }}
  52. </el-form-item>
  53. </el-col>
  54. <!-- 审核通过才展示字段 -->
  55. <template v-if="state.detail?.state === '1'">
  56. <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
  57. <el-form-item label="特提节点">
  58. {{ state.detail?.nextStepName }}
  59. </el-form-item>
  60. </el-col>
  61. <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
  62. <el-form-item label="办理对象">
  63. {{ state.detail?.nextHandlers?.map((item) => item.value).join(',') }}
  64. </el-form-item>
  65. </el-col>
  66. <!-- <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
  67. <el-form-item label="办理时限"> {{ state.detail?.timeLimit }} {{ state.detail?.timeLimitUnitText }} </el-form-item>
  68. </el-col>-->
  69. <el-col :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
  70. <el-form-item label="无需计算期满时间" label-width="130px">
  71. {{ state.detail?.alterTime ? '是' : '否' }}
  72. </el-form-item>
  73. </el-col>
  74. </template>
  75. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" v-if="state.detail.opinion">
  76. <el-form-item label="审批意见" class="formatted-text">
  77. {{ state.detail?.opinion }}
  78. </el-form-item>
  79. </el-col>
  80. </el-row>
  81. </el-form>
  82. </div>
  83. </el-dialog>
  84. </template>
  85. <script setup lang="ts">
  86. import { defineAsyncComponent, reactive } from 'vue';
  87. import { formatDate } from '@/utils/formatTime';
  88. import { specialDetail } from '@/api/business/special';
  89. import { transformFile } from '@/utils/tools';
  90. // 引入组件
  91. const AnnexList = defineAsyncComponent(() => import('@/components/AnnexList/index.vue'));
  92. // 定义变量内容
  93. const state = reactive<any>({
  94. dialogVisible: false, // 是否显示弹窗
  95. loading: false, // 是否显示加载
  96. detail: {}, // 详情信息
  97. });
  98. // 打开弹窗
  99. const openDialog = async (id: string) => {
  100. state.loading = true;
  101. state.dialogVisible = true;
  102. try {
  103. const { result } = await specialDetail(id);
  104. state.detail = result;
  105. state.detail.files = transformFile(result.files);
  106. state.loading = false;
  107. } catch (e) {
  108. console.log(e);
  109. state.loading = false;
  110. }
  111. };
  112. // 关闭弹窗
  113. const closeDialog = () => {
  114. state.dialogVisible = false;
  115. };
  116. defineExpose({
  117. openDialog,
  118. closeDialog,
  119. });
  120. </script>