2023-12-09 15:47:03 +01:00
|
|
|
<template>
|
2024-04-15 19:39:03 +02:00
|
|
|
<input-wrapper v-bind="inputWrapperProps">
|
2023-12-09 15:47:03 +01:00
|
|
|
<template #label>
|
|
|
|
|
<slot name="label" />
|
|
|
|
|
</template>
|
|
|
|
|
|
2024-04-15 19:39:03 +02:00
|
|
|
<Loader
|
|
|
|
|
v-if="loading"
|
|
|
|
|
key="loader"
|
|
|
|
|
class="h-6 w-6 text-nt-blue mx-auto"
|
|
|
|
|
/>
|
|
|
|
|
<div
|
|
|
|
|
v-for="(option, index) in options"
|
|
|
|
|
v-else
|
|
|
|
|
:key="option[optionKey]"
|
|
|
|
|
role="button"
|
|
|
|
|
:class="[
|
|
|
|
|
theme.default.input,
|
|
|
|
|
'cursor-pointer hover:bg-gray-50 dark:hover:bg-gray-900 flex',
|
|
|
|
|
{
|
|
|
|
|
'mb-2': index !== options.length,
|
|
|
|
|
'!ring-red-500 !ring-2 !border-transparent': hasError,
|
|
|
|
|
'!cursor-not-allowed !bg-gray-200': disabled,
|
|
|
|
|
},
|
|
|
|
|
]"
|
|
|
|
|
@click="onSelect(option[optionKey])"
|
2023-12-09 15:47:03 +01:00
|
|
|
>
|
|
|
|
|
<p class="flex-grow">
|
|
|
|
|
{{ option[displayKey] }}
|
|
|
|
|
</p>
|
2024-04-15 19:39:03 +02:00
|
|
|
<div
|
|
|
|
|
v-if="isSelected(option[optionKey])"
|
|
|
|
|
class="flex items-center"
|
|
|
|
|
>
|
|
|
|
|
<svg
|
|
|
|
|
:color="color"
|
|
|
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
|
|
|
class="h-5 w-5"
|
|
|
|
|
viewBox="0 0 20 20"
|
|
|
|
|
fill="currentColor"
|
|
|
|
|
>
|
|
|
|
|
<path
|
|
|
|
|
fill-rule="evenodd"
|
|
|
|
|
d="M10 18a8 8 0 100-16 8 8 0 000 16zm3.707-9.293a1 1 0 00-1.414-1.414L9 10.586 7.707 9.293a1 1 0 00-1.414 1.414l2 2a1 1 0 001.414 0l4-4z"
|
|
|
|
|
clip-rule="evenodd"
|
|
|
|
|
/>
|
2023-12-09 15:47:03 +01:00
|
|
|
</svg>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<template #help>
|
|
|
|
|
<slot name="help" />
|
|
|
|
|
</template>
|
|
|
|
|
<template #error>
|
|
|
|
|
<slot name="error" />
|
|
|
|
|
</template>
|
|
|
|
|
</input-wrapper>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
2024-04-15 19:39:03 +02:00
|
|
|
import { inputProps, useFormInput } from "./useFormInput.js"
|
|
|
|
|
import InputWrapper from "./components/InputWrapper.vue"
|
2023-12-09 15:47:03 +01:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Options: {name,value} objects
|
|
|
|
|
*/
|
|
|
|
|
export default {
|
2024-04-15 19:39:03 +02:00
|
|
|
name: "FlatSelectInput",
|
2023-12-09 15:47:03 +01:00
|
|
|
components: { InputWrapper },
|
|
|
|
|
|
|
|
|
|
props: {
|
|
|
|
|
...inputProps,
|
|
|
|
|
options: { type: Array, required: true },
|
2024-04-15 19:39:03 +02:00
|
|
|
optionKey: { type: String, default: "value" },
|
|
|
|
|
emitKey: { type: String, default: "value" },
|
|
|
|
|
displayKey: { type: String, default: "name" },
|
2023-12-09 15:47:03 +01:00
|
|
|
loading: { type: Boolean, default: false },
|
2024-04-15 19:39:03 +02:00
|
|
|
multiple: { type: Boolean, default: false },
|
2023-12-09 15:47:03 +01:00
|
|
|
},
|
2024-04-15 19:39:03 +02:00
|
|
|
setup(props, context) {
|
2023-12-09 15:47:03 +01:00
|
|
|
return {
|
2024-04-15 19:39:03 +02:00
|
|
|
...useFormInput(props, context),
|
2023-12-09 15:47:03 +01:00
|
|
|
}
|
|
|
|
|
},
|
2024-04-15 19:39:03 +02:00
|
|
|
data() {
|
2023-12-09 15:47:03 +01:00
|
|
|
return {}
|
|
|
|
|
},
|
|
|
|
|
computed: {},
|
|
|
|
|
methods: {
|
2024-04-15 19:39:03 +02:00
|
|
|
onSelect(value) {
|
2023-12-09 15:47:03 +01:00
|
|
|
if (this.disabled) {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (this.multiple) {
|
|
|
|
|
const emitValue = Array.isArray(this.compVal) ? [...this.compVal] : []
|
|
|
|
|
|
|
|
|
|
// Already in value, remove it
|
|
|
|
|
if (this.isSelected(value)) {
|
|
|
|
|
this.compVal = emitValue.filter((item) => {
|
|
|
|
|
return item !== value
|
|
|
|
|
})
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Otherwise add value
|
|
|
|
|
emitValue.push(value)
|
|
|
|
|
this.compVal = emitValue
|
|
|
|
|
} else {
|
2024-04-15 19:39:03 +02:00
|
|
|
this.compVal = this.compVal === value ? null : value
|
2023-12-09 15:47:03 +01:00
|
|
|
}
|
|
|
|
|
},
|
2024-04-15 19:39:03 +02:00
|
|
|
isSelected(value) {
|
2023-12-09 15:47:03 +01:00
|
|
|
if (!this.compVal) return false
|
|
|
|
|
|
|
|
|
|
if (this.multiple) {
|
|
|
|
|
return this.compVal.includes(value)
|
|
|
|
|
}
|
|
|
|
|
return this.compVal === value
|
2024-04-15 19:39:03 +02:00
|
|
|
},
|
|
|
|
|
},
|
2023-12-09 15:47:03 +01:00
|
|
|
}
|
|
|
|
|
</script>
|