DdataeaseShufix: 样式优化
6b3f1a84创建于 4月17日历史提交
<script setup lang="ts">
import { toRefs } from 'vue'
import { propTypes } from '@/utils/propTypes'
import Icon from '../icon-custom/src/Icon.vue'
import { ElCol } from 'element-plus-secondary'

const props = defineProps({
  title: propTypes.string,
  tips: propTypes.string,
  iconName: propTypes.object,
  showSplitLine: propTypes.bool,
  active: propTypes.bool
})

const { title, tips, iconName, showSplitLine } = toRefs(props)
const emits = defineEmits(['customClick'])
</script>

<template>
  <el-row
    class="group_icon"
    :title="tips"
    :class="{ 'group-right-border': showSplitLine }"
    v-on:click="emits('customClick')"
  >
    <el-col :span="24" class="group_inner" :class="{ 'inner-active': active }">
      <el-icon class="toolbar-icon">
        <Icon><component :is="iconName"></component></Icon>
      </el-icon>
      <span>{{ title }}</span>
    </el-col>
  </el-row>
</template>
<style lang="less" scoped>
.group_icon {
  padding-left: 10px;
  padding-right: 10px;
}
.group_inner {
  display: flex;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  color: #ffffff99;
  position: relative;
  &::after {
    content: '';
    border-radius: 6px;
    display: none;
    position: absolute;
    width: calc(100% + 10px);
    height: calc(100% + 10px);
    top: -5px;
    left: -5px;
  }

  &:hover {
    &::after {
      display: block;
      background: rgba(255, 255, 255, 0.1);
    }
  }
  &:active {
    &::after {
      display: block;
      background: rgba(255, 255, 255, 0.2);
    }
  }
  span {
    float: left;
    font-size: 12px;
    color: #a6a6a6;
    margin-top: 4px;
  }
}

.group-right-border {
  border-right: 1px solid rgba(255, 255, 255, 0.15);
}

.inner-active {
  background: rgba(255, 255, 255, 0.1);
}

.toolbar-icon {
  font-size: 20px;
}
</style>