Ben Lin
2024-06-18 ebbd788fbb2c0b45d4473798efc57eec8ba74a25
src/layouts/default/header/components/user-dropdown/DropMenuItem.vue
@@ -1,32 +1,24 @@
<template>
  <MenuItem :key="itemKey">
  <Menu.Item :key="itemKey">
    <span class="flex items-center">
      <Icon :icon="icon" class="mr-1" />
      <span>{{ text }}</span>
    </span>
  </MenuItem>
  </Menu.Item>
</template>
<script lang="ts">
<script lang="ts" setup>
  import { Menu } from 'ant-design-vue';
  import { computed, defineComponent, getCurrentInstance } from 'vue';
  import { computed, getCurrentInstance } from 'vue';
  import Icon from '@/components/Icon/Icon.vue';
  import { propTypes } from '@/utils/propTypes';
  import { propTypes } from '/@/utils/propTypes';
  defineOptions({ name: 'DropdownMenuItem' });
  export default defineComponent({
    name: 'DropdownMenuItem',
    components: { MenuItem: Menu.Item, Icon },
    props: {
      // eslint-disable-next-line
      key: propTypes.string,
      text: propTypes.string,
      icon: propTypes.string,
    },
    setup(props) {
      const instance = getCurrentInstance();
      const itemKey = computed(() => props.key || instance?.vnode?.props?.key);
      return { itemKey };
    },
  defineProps({
    text: propTypes.string,
    icon: propTypes.string,
  });
  const instance = getCurrentInstance();
  const itemKey = computed(() => instance?.vnode?.props?.key);
</script>