mirror of
https://github.com/element-plus/element-plus.git
synced 2025-01-06 10:38:31 +08:00
8583c70fdc
* feat(theme-chalk): use @use instead of @import & remove /**/ comment * refactor(theme-chalk): refactor scss with @use module * fix(docs): scss in docs toggle to '@use' * docs: add custom theme on demand * docs: add unplugin-element-plus
70 lines
1.5 KiB
Vue
70 lines
1.5 KiB
Vue
<script setup lang="ts">
|
|
import VPLink from '../common/vp-link.vue'
|
|
import { useTranslation } from '../../composables/translation'
|
|
|
|
import TranslationIcon from '../icons/translation-icon.vue'
|
|
|
|
const { switchLang, languageMap, langs, lang, helpTranslate } = useTranslation()
|
|
</script>
|
|
|
|
<template>
|
|
<div class="translation-container">
|
|
<ClientOnly>
|
|
<ElPopover
|
|
:show-arrow="false"
|
|
trigger="hover"
|
|
popper-class="translation-popup"
|
|
>
|
|
<template #reference>
|
|
<ElIcon :size="20">
|
|
<TranslationIcon />
|
|
</ElIcon>
|
|
</template>
|
|
<div
|
|
v-for="l in langs"
|
|
:key="l"
|
|
:class="{ language: true, selected: l === lang }"
|
|
@click="switchLang(l)"
|
|
>
|
|
{{ languageMap[l] }}
|
|
</div>
|
|
<div class="language">
|
|
<VPLink href="https://crowdin.com/project/element-plus">
|
|
{{ helpTranslate }}
|
|
</VPLink>
|
|
</div>
|
|
</ElPopover>
|
|
</ClientOnly>
|
|
</div>
|
|
</template>
|
|
|
|
<style lang="scss" scoped>
|
|
@use '../../styles/mixins' as *;
|
|
.translation-container {
|
|
display: none;
|
|
height: 20px;
|
|
padding: 0 8px;
|
|
|
|
@include respond-to('md') {
|
|
display: block;
|
|
}
|
|
|
|
@at-root .translation-popup.el-popper {
|
|
box-shadow: var(--el-box-shadow-base);
|
|
|
|
.language {
|
|
cursor: pointer;
|
|
padding: 0 16px;
|
|
line-height: 28px;
|
|
&.selected {
|
|
color: var(--brand-color);
|
|
}
|
|
|
|
.link-item {
|
|
font-weight: 500;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</style>
|