1
2 天以前 3a4a8c78098f41d3a7ce41f272cdefc35b572681
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
<template>
  <ElDrawer
    :model-value="visible"
    :title="t('pages.basicInfo.companys.dialog.titleDetail')"
    size="960px"
    destroy-on-close
    @update:model-value="handleVisibleChange"
  >
    <ElScrollbar class="h-[calc(100vh-180px)] pr-1">
      <div v-if="loading" class="py-6">
        <ElSkeleton :rows="12" animated />
      </div>
      <div v-else class="space-y-4">
        <ElDescriptions :title="t('pages.basicInfo.companys.detail.sections.basic')" :column="2" border>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.code')">{{ detail.code || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.name')">{{ detail.name || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.nameEn')">{{ detail.nameEn || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.briefCode')">{{ detail.breifCode || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.type')">{{ detail.typeText || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.contact')">{{ detail.contact || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.tel')">{{ detail.tel || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.email')">{{ detail.email || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.postCode')">{{ detail.pcode || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.province')">{{ detail.province || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.city')">{{ detail.city || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('pages.basicInfo.companys.table.address')" :span="2">{{ detail.address || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('table.status')">
            <ElTag :type="detail.statusType || 'info'" effect="light">
              {{ detail.statusTextKey ? t(detail.statusTextKey) : detail.statusText || '--' }}
            </ElTag>
          </ElDescriptionsItem>
          <ElDescriptionsItem :label="t('table.remark')" :span="2">{{ detail.memo || '--' }}</ElDescriptionsItem>
        </ElDescriptions>
 
        <ElDescriptions :title="t('pages.basicInfo.companys.detail.sections.audit')" :column="2" border>
          <ElDescriptionsItem :label="t('table.createBy')">{{ detail.createByText || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('table.createTime')">{{ detail.createTimeText || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('table.updateBy')">{{ detail.updateByText || '--' }}</ElDescriptionsItem>
          <ElDescriptionsItem :label="t('table.updateTime')">{{ detail.updateTimeText || '--' }}</ElDescriptionsItem>
        </ElDescriptions>
      </div>
    </ElScrollbar>
  </ElDrawer>
</template>
 
<script setup>
  import { computed } from 'vue'
  import { useI18n } from 'vue-i18n'
 
  const props = defineProps({
    visible: { type: Boolean, default: false },
    loading: { type: Boolean, default: false },
    detail: { type: Object, default: () => ({}) }
  })
 
  const emit = defineEmits(['update:visible'])
  const { t } = useI18n()
 
  const visible = computed({
    get: () => props.visible,
    set: (value) => emit('update:visible', value)
  })
 
  function handleVisibleChange(value) {
    visible.value = value
  }
</script>