liriming
2024-09-11 55097079febeaa73b399273004bce2b6c1987304
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
<script lang="ts" setup>
import { useAppStore } from '@/store/modules/app'
 
import { propTypes } from '@/utils/propTypes'
import { useDesign } from '@/hooks/web/useDesign'
import { ElementPlusSize } from '@/types/elementPlus'
 
defineOptions({ name: 'SizeDropdown' })
 
const { getPrefixCls } = useDesign()
 
const prefixCls = getPrefixCls('size-dropdown')
 
defineProps({
  color: propTypes.string.def('')
})
 
const { t } = useI18n()
 
const appStore = useAppStore()
 
const sizeMap = computed(() => appStore.sizeMap)
 
const setCurrentSize = (size: ElementPlusSize) => {
  appStore.setCurrentSize(size)
}
</script>
 
<template>
  <ElDropdown :class="prefixCls" trigger="click" @command="setCurrentSize">
    <Icon :color="color" :size="18" class="cursor-pointer" icon="mdi:format-size" />
    <template #dropdown>
      <ElDropdownMenu>
        <ElDropdownItem v-for="item in sizeMap" :key="item" :command="item">
          {{ t(`size.${item}`) }}
        </ElDropdownItem>
      </ElDropdownMenu>
    </template>
  </ElDropdown>
</template>