Ben Lin
2024-03-24 b72cc34ab2fef7d6bcaca3e2b11231713d622fce
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
<!--
 * @Author: Vben
 * @Description: Arrow component with animation
-->
<template>
  <span :class="getClass">
    <Icon icon="ion:chevron-forward" :style="$attrs.iconStyle" />
  </span>
</template>
<script lang="ts" setup>
  import { computed } from 'vue';
  import Icon from '@/components/Icon/Icon.vue';
  import { useDesign } from '/@/hooks/web/useDesign';
 
  const props = defineProps({
    /**
     * Arrow expand state
     */
    expand: { type: Boolean },
    /**
     * Arrow up by default
     */
    up: { type: Boolean },
    /**
     * Arrow down by default
     */
    down: { type: Boolean },
    /**
     * Cancel padding/margin for inline
     */
    inset: { type: Boolean },
  });
 
  const { prefixCls } = useDesign('basic-arrow');
 
  // get component class
  const getClass = computed(() => {
    const { expand, up, down, inset } = props;
    return [
      prefixCls,
      {
        [`${prefixCls}--active`]: expand,
        up,
        inset,
        down,
      },
    ];
  });
</script>
<style lang="less" scoped>
  @prefix-cls: ~'@{namespace}-basic-arrow';
 
  .@{prefix-cls} {
    display: inline-block;
    transform: rotate(0deg);
    transform-origin: center center;
    transition: all 0.3s ease 0.1s;
    cursor: pointer;
 
    &--active {
      transform: rotate(90deg);
    }
 
    &.inset {
      line-height: 0px;
    }
 
    &.up {
      transform: rotate(-90deg);
    }
 
    &.down {
      transform: rotate(90deg);
    }
 
    &.up.@{prefix-cls}--active {
      transform: rotate(90deg);
    }
 
    &.down.@{prefix-cls}--active {
      transform: rotate(-90deg);
    }
  }
</style>