<script setup lang="ts">
interface Props {
modelValue: Record<string, any>[]
availableChannelList: Record<string, any>[]
placeholder: string
}
const { availableChannelList, placeholder, ...rest } = defineProps<Props>()
const emit = defineEmits(['update:modelValue'])
const vModel = useVModel(rest, 'modelValue', emit)
// idx of selected channels
const localChannelValues = ref<number[]>([])
// availableChannelList with idx enriched
const availableChannelWithIdxList = ref<Record<string, any>[]>([])
function setAvailableChannelWithIdxList(availableChannelList: Record<string, any>[]) {
if (availableChannelList.length) {
// enrich idx
let idx = 0
availableChannelWithIdxList.value = availableChannelList.map((channel) => ({
...channel,
idx: idx++,
}))
// build localChannelValues from modelValue
for (const channel of rest.modelValue || []) {
const target = availableChannelWithIdxList.value.find(
(availableChannelWithIdx) =>
availableChannelWithIdx.webhook_url === channel.webhook_url && availableChannelWithIdx.channel === channel.channel,
)
if (target) {
localChannelValues.value.push(target.idx)
watch(
() => availableChannelList,
(n, o) => {
if (n !== o) {
setAvailableChannelWithIdxList(n)
},
() => localChannelValues.value,
(v) => {
const res = []
for (const channelIdx of v) {
const target = availableChannelWithIdxList.value.find((availableChannel) => availableChannel.idx === channelIdx)
// push without target.idx
res.push({ webhook_url: target.webhook_url, channel: target.channel })
vModel.value = res
onBeforeMount(() => setAvailableChannelWithIdxList(availableChannelList))
</script>
<template>
<a-select
v-model:value="localChannelValues"
mode="multiple"
:placeholder="placeholder"
max-tag-count="responsive"
dropdown-class-name="nc-dropdown-webhook-channel"
>
<a-select-option v-for="channel of availableChannelWithIdxList" :key="channel.idx" :value="channel.idx">
{{ channel.channel }}
</a-select-option>
</a-select>
</template>