1
119 分钟以前 e711c834aec2293c53b07efe53e81e3573c289b6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
<template>
  <ElDrawer
    :model-value="visible"
    title="任务路径模板合并详情"
    size="920px"
    destroy-on-close
    @update:model-value="handleVisibleChange"
  >
    <ElScrollbar class="h-[calc(100vh-180px)] pr-1">
      <div v-if="loading" class="py-6">
        <ElSkeleton :rows="10" animated />
      </div>
      <div v-else class="space-y-4">
        <ElCard shadow="never" class="art-table-card">
          <template #header>
            <div class="flex items-center justify-between gap-3">
              <div>
                <h3 class="m-0 text-base font-semibold">
                  {{ detail.templateCode || detail.templateName || '任务路径模板合并' }}
                </h3>
                <p class="m-0 text-sm text-[var(--art-text-secondary)]">
                  这里展示的是后端真实记录的组合详情,不做额外推演。
                </p>
              </div>
              <ElSpace wrap>
                <ElTag :type="detail.isCurrentType || 'info'" effect="light">
                  {{ detail.isCurrentText || '--' }}
                </ElTag>
                <ElTag :type="detail.statusType || 'info'" effect="light">
                  {{ detail.statusText || '--' }}
                </ElTag>
              </ElSpace>
            </div>
          </template>
 
          <ElDescriptions :column="2" border>
            <ElDescriptionsItem label="模板编码">{{ detail.templateCode || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="模板名称">{{ detail.templateName || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="起点类型">{{ detail.sourceTypeText || detail.sourceType || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="终点类型">{{ detail.targetTypeText || detail.targetType || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="条件表达式">{{ detail.conditionExpressionText || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="条件描述">{{ detail.conditionDesc || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="版本号">{{ detail.version ?? '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="优先级">{{ detail.priority ?? '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="当前版本">{{ detail.isCurrentText || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="状态">{{ detail.statusText || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="生效时间">{{ detail.effectiveTimeText || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="失效时间">{{ detail.expireTimeText || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="超时(分)">{{ detail.timeoutMinutes ?? '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="最大重试">{{ detail.maxRetryTimes ?? '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="重试间隔(秒)">{{ detail.retryIntervalSeconds ?? '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="步序长度">{{ detail.stepSize ?? '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="创建人">{{ detail.createByText || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="创建时间">{{ detail.createTimeText || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="更新人">{{ detail.updateByText || '--' }}</ElDescriptionsItem>
            <ElDescriptionsItem label="更新时间">{{ detail.updateTimeText || '--' }}</ElDescriptionsItem>
          </ElDescriptions>
        </ElCard>
      </div>
    </ElScrollbar>
  </ElDrawer>
</template>
 
<script setup>
  import { computed } from 'vue'
 
  const props = defineProps({
    visible: { type: Boolean, default: false },
    loading: { type: Boolean, default: false },
    detail: { type: Object, default: () => ({}) }
  })
 
  const emit = defineEmits(['update:visible'])
 
  const visible = computed({
    get: () => props.visible,
    set: (value) => emit('update:visible', value)
  })
 
  function handleVisibleChange(value) {
    visible.value = value
  }
</script>