Combobox
Shows a combobox component.
Examples
Basic combobox
Code
vue
<template>
<Combobox v-model="value" :options="options" class="w-64" />
</template>
<script setup lang="ts">
import { ref } from 'vue'
import { Combobox } from '@/components/ui/combobox'
const value = ref(null)
const options = [
{
label: 'Red',
value: 1
},
{
label: 'Green',
value: 2
},
{
label: 'Blue',
value: 3
}
]
</script>
Disabled combobox
Code
vue
<template>
<Combobox
v-model="value"
:options="options"
class="w-64"
disabled
/>
</template>
<script setup lang="ts">
import { ref } from 'vue'
import { Combobox } from '@/components/ui/combobox'
const value = ref(null)
const options = [
{
label: 'Red',
value: 'red'
},
{
label: 'Green',
value: 'green'
},
{
label: 'Blue',
value: 'blue'
}
]
</script>
Combobox with custom label
Code
vue
<template>
<Combobox v-model="value" :options="options" class="w-64">
<template v-if="value" #label="{ option }">
<span class="flex items-center">
<span class="size-3 mr-2 inline-block rounded-full opacity-40" :style="{ backgroundColor: option.value }" /> {{ option.label }}
</span>
</template>
<template #option="{ option }">
<span class="flex items-center">
<span class="size-3 mr-2 inline-block rounded-full opacity-40" :style="{ backgroundColor: option.value }" /> {{ option.label }}
</span>
</template>
</Combobox>
</template>
<script setup lang="ts">
import { ref } from 'vue'
import { Combobox } from '@/components/ui/combobox'
const value = ref(null)
const options = [
{
label: 'Red',
value: 'red'
},
{
label: 'Green',
value: 'green'
},
{
label: 'Blue',
value: 'blue'
}
]
</script>
Combobox with async data
Code
vue
<template>
<Combobox
v-model="value"
:options="options"
:loading="loading"
disable-filter
class="w-64"
@update:search-term="search"
/>
</template>
<script setup lang="ts">
import { ref } from 'vue'
import { Combobox } from '@/components/ui/combobox'
const value = ref(null)
const loading = ref(false)
const options = ref([])
const fetch = (search?: string) => {
return new Promise((resolve) => {
setTimeout(() => {
const result = ['Red', 'Green', 'Blue', 'Yellow', 'Purple', 'Gray'].filter(option => !search || option.toLowerCase().includes(search.toLowerCase()))
options.value = result
resolve(result)
}, 200)
})
}
const search = (value: string) => {
console.log(`Imitating a search with ${value}`)
loading.value = true
fetch(value).then(() => {
loading.value = false
})
}
</script>
Combobox with multiple values
Code
vue
<template>
<Combobox
v-model="value"
multiple
:options="options"
class="w-64"
/>
</template>
<script setup lang="ts">
import { ref } from 'vue'
import { Combobox } from '@/components/ui/combobox'
const value = ref([])
const options = [
{
label: 'Red',
value: 1
},
{
label: 'Green',
value: 2
},
{
label: 'Blue',
value: 3
}
]
</script>