elk/components/publish/PublishLanguagePicker.vue

61 lines
1.3 KiB
Vue
Raw Normal View History

<script setup lang="ts">
import ISO6391 from 'iso-639-1'
import Fuse from 'fuse.js'
let { modelValue } = $defineModel<{
2023-01-04 18:21:18 +08:00
modelValue: string
}>()
const { t } = useI18n()
const languageKeyword = $ref('')
const languageList: {
2023-01-04 18:21:18 +08:00
code: string
nativeName: string
2023-01-04 18:21:18 +08:00
name: string
}[] = ISO6391.getAllCodes().map(code => ({
code,
nativeName: ISO6391.getNativeName(code),
name: ISO6391.getName(code),
2023-01-04 18:21:18 +08:00
}))
const fuse = new Fuse(languageList, {
keys: ['code', 'nativeName', 'name'],
shouldSort: true,
})
const languages = $computed(() =>
languageKeyword.trim()
? fuse.search(languageKeyword).map(r => r.item)
: [...languageList].sort(({ code: a }, { code: b }) => {
2023-01-04 18:21:18 +08:00
return a === modelValue ? -1 : b === modelValue ? 1 : a.localeCompare(b)
}),
)
2023-01-04 18:21:18 +08:00
function chooseLanguage(language: string) {
modelValue = language
}
</script>
<template>
<div>
<input
v-model="languageKeyword"
:placeholder="t('language.search')"
p2 mb2 border-rounded w-full bg-transparent
outline-none border="~ base"
>
<div max-h-40vh overflow-auto>
<CommonDropdownItem
v-for="{ code, nativeName, name } in languages"
:key="code"
2023-01-04 18:21:18 +08:00
:text="nativeName"
:description="name"
:checked="code === modelValue"
@click="chooseLanguage(code)"
2023-01-04 18:21:18 +08:00
/>
</div>
</div>
</template>