DrillActivity.vue 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <template>
  2. <div class="drill-activity-container">
  3. <div class="drill-container__title">
  4. <div class="drill-container--line"></div>
  5. <span>演练活动</span>
  6. </div>
  7. <div class="drill-container__content">
  8. <el-row :gutter="20">
  9. <el-col :span="8">
  10. <div class="drill-container__content--item">
  11. <span class="label">演练规模:</span>
  12. <span class="value">{{ getDrillScope(drillPlanItemDetail.drillScope) }}</span>
  13. </div>
  14. </el-col>
  15. <el-col :span="8">
  16. <div class="drill-container__content--item">
  17. <span class="label">演练内容:</span>
  18. <span class="value">{{ drillPlanItemDetail.drillContent }}</span>
  19. </div>
  20. </el-col>
  21. <el-col :span="8">
  22. <div class="drill-container__content--item">
  23. <span class="label">计划完成时间:</span>
  24. <span class="value">{{ drillPlanItemDetail.dueCompleteTime }}</span>
  25. </div>
  26. </el-col>
  27. </el-row>
  28. <el-row :gutter="20">
  29. <el-col :span="8">
  30. <div class="drill-container__content--item">
  31. <span class="label">责任部门:</span>
  32. <template
  33. v-for="(dept, index) in safatyJsonParse(drillPlanItemDetail.responsibleDeptNameList)"
  34. :key="index"
  35. >
  36. <span class="value">
  37. {{ dept }}
  38. <span v-if="index !== safatyJsonParse(drillPlanItemDetail.responsibleDeptNameList).length - 1">、</span>
  39. </span>
  40. </template>
  41. </div>
  42. </el-col>
  43. <el-col :span="8">
  44. <div class="drill-container__content--item" v-if="drillPlanItemDetail.coordinateDeptNameList">
  45. <span class="label">配合部门:</span>
  46. <template v-for="(dept, index) in safatyJsonParse(drillPlanItemDetail.coordinateDeptNameList)" :key="index">
  47. <span class="value">
  48. {{ dept }}
  49. <span v-if="index !== safatyJsonParse(drillPlanItemDetail.coordinateDeptNameList).length - 1">、</span>
  50. </span>
  51. </template>
  52. </div>
  53. </el-col>
  54. <el-col :span="8">
  55. <div class="drill-container__content--item">
  56. <span class="label">关联应急预案:</span>
  57. <span class="value font-primary">应急预案还没做</span>
  58. </div>
  59. </el-col>
  60. </el-row>
  61. <el-row :gutter="20">
  62. <el-col>
  63. <div class="drill-container__content--item">
  64. <span class="label">审批流程:</span>
  65. <span class="value">{{ getApprovalName(drillPlanItemDetail.approvalTemplateId) }}</span>
  66. </div>
  67. </el-col>
  68. </el-row>
  69. </div>
  70. </div>
  71. </template>
  72. <script setup lang="ts">
  73. import { ref, onMounted } from 'vue';
  74. import { useEmergencyDrillHook } from '../hook';
  75. import { DrillPlanItemDetail } from '../types';
  76. import { ApprovalInstanceType } from '@/views/system/approval/types';
  77. import { getAllApproval } from '@/api/approval/approval';
  78. const approvalList = ref<ApprovalInstanceType[]>([]);
  79. const { getDrillScopeDict, getDrillScope } = useEmergencyDrillHook();
  80. const safatyJsonParse = (str: string) => {
  81. return str.slice(1, -1).split(',');
  82. };
  83. const getApprovalList = async () => {
  84. approvalList.value = await getAllApproval();
  85. };
  86. const getApprovalName = (id: number) => {
  87. return approvalList.value.find((item) => item.id === id)?.templateName;
  88. };
  89. defineProps<{
  90. drillPlanItemDetail: DrillPlanItemDetail;
  91. }>();
  92. onMounted(() => {
  93. getDrillScopeDict();
  94. getApprovalList();
  95. });
  96. </script>
  97. <style lang="scss" scoped>
  98. @use '../style/common.scss' as *;
  99. </style>