Ben Lin
2024-09-12 a4ee6ba0ca28833cbbb8cf0e675561b10fa4c1af
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
84
85
86
87
88
89
90
<template>
  <div
    :class="prefixCls"
    class="flex items-center mx-auto"
    v-if="imgList && imgList.length"
    :style="getWrapStyle"
  >
    <Badge :count="!showBadge || imgList.length === 1 ? 0 : imgList.length" v-if="simpleShow">
      <div class="img-div">
        <Image.PreviewGroup>
          <template v-for="(img, index) in imgList" :key="img">
            <Image
              :width="size"
              :style="{
                display: index === 0 ? '' : 'none !important',
              }"
              :src="srcPrefix + img"
              :fallback="fallback"
            />
          </template>
        </Image.PreviewGroup>
      </div>
    </Badge>
    <Image.PreviewGroup v-else>
      <template v-for="(img, index) in imgList" :key="img">
        <Image
          :width="size"
          :style="{ marginLeft: index === 0 ? 0 : margin + 'px' }"
          :src="srcPrefix + img"
          :fallback="fallback"
        />
      </template>
    </Image.PreviewGroup>
  </div>
</template>
<script lang="ts" setup>
  import type { CSSProperties } from 'vue';
  import { computed } from 'vue';
  import { useDesign } from '@/hooks/web/useDesign';
  import { Image, Badge } from 'ant-design-vue';
  import { propTypes } from '@/utils/propTypes';
 
  defineOptions({ name: 'TableImage' });
 
  const props = defineProps({
    imgList: propTypes.arrayOf(propTypes.string),
    size: propTypes.number.def(40),
    // 是否简单显示(只显示第一张图片)
    simpleShow: propTypes.bool,
    // 简单模式下是否显示图片数量的badge
    showBadge: propTypes.bool.def(true),
    // 图片间距
    margin: propTypes.number.def(4),
    // src前缀,将会附加在imgList中每一项之前
    srcPrefix: propTypes.string.def(''),
    // fallback,加载失败显示图像占位符。
    fallback: propTypes.string.def(
      '',
    ),
  });
  const getWrapStyle = computed((): CSSProperties => {
    const { size } = props;
    const s = `${size}px`;
    return { height: s, width: s };
  });
 
  const { prefixCls } = useDesign('basic-table-img');
</script>
<style lang="less">
  @prefix-cls: ~'@{namespace}-basic-table-img';
 
  .@{prefix-cls} {
    .ant-image {
      margin-right: 4px;
      cursor: zoom-in;
 
      img {
        border-radius: 2px;
      }
    }
 
    .img-div {
      display: inline-grid;
 
      > .ant-image:nth-of-type(n + 2) {
        display: none;
      }
    }
  }
</style>