2022-11-28 15:58:29 +09:00
|
|
|
<script lang="ts" setup>
|
2022-11-29 01:49:30 +09:00
|
|
|
import type { ComputedRef } from 'vue'
|
2022-11-29 15:29:09 +09:00
|
|
|
import type { LocaleObject } from '#i18n'
|
2022-11-28 15:58:29 +09:00
|
|
|
|
2022-11-29 15:29:09 +09:00
|
|
|
const { locale, t, setLocale } = useI18n()
|
|
|
|
const { locales } = useI18n() as { locales: ComputedRef<LocaleObject[]> }
|
2022-11-28 15:58:29 +09:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
2022-11-29 07:57:27 +09:00
|
|
|
<CommonTooltip :content="t('nav_footer.select_language')">
|
2022-11-28 15:58:29 +09:00
|
|
|
<CommonDropdown>
|
2022-11-30 06:24:26 +09:00
|
|
|
<button flex :aria-label="t('nav_footer.select_language')">
|
2022-11-28 15:58:29 +09:00
|
|
|
<div i-ri:earth-line text-lg />
|
|
|
|
</button>
|
|
|
|
|
|
|
|
<template #popper>
|
|
|
|
<CommonDropdownItem
|
2022-11-29 01:49:30 +09:00
|
|
|
v-for="item in locales"
|
|
|
|
:key="item.code"
|
|
|
|
:checked="item.code === locale"
|
2022-11-30 09:22:35 +09:00
|
|
|
@click="setLocale(item.code)"
|
2022-11-28 15:58:29 +09:00
|
|
|
>
|
2022-11-29 01:49:30 +09:00
|
|
|
{{ item.name }}
|
2022-11-28 15:58:29 +09:00
|
|
|
</CommonDropdownItem>
|
|
|
|
</template>
|
|
|
|
</CommonDropdown>
|
|
|
|
</CommonTooltip>
|
|
|
|
</template>
|