index.vue 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. <template>
  2. <el-dropdown trigger="click" @command="handleLanguageChange">
  3. <div>
  4. <svg-icon icon-class="language" :size="size" />
  5. </div>
  6. <template #dropdown>
  7. <el-dropdown-menu>
  8. <el-dropdown-item
  9. v-for="item in langOptions"
  10. :key="item.value"
  11. :disabled="appStore.language === item.value"
  12. :command="item.value"
  13. >
  14. {{ item.label }}
  15. </el-dropdown-item>
  16. </el-dropdown-menu>
  17. </template>
  18. </el-dropdown>
  19. </template>
  20. <script setup lang="ts">
  21. import { useI18n } from "vue-i18n";
  22. import { useAppStore } from "@/store/modules/app";
  23. defineProps({
  24. size: {
  25. type: String,
  26. required: false,
  27. },
  28. });
  29. const langOptions = [
  30. { label: "中文", value: "zh-cn" },
  31. { label: "English", value: "en" },
  32. ];
  33. const appStore = useAppStore();
  34. const { locale, t } = useI18n();
  35. function handleLanguageChange(lang: string) {
  36. locale.value = lang;
  37. appStore.changeLanguage(lang);
  38. ElMessage.success(t("langSelect.message.success"));
  39. }
  40. </script>