UNPKG

bootstrap-vue

Version:

With more than 85 components, over 45 available plugins, several directives, and 1000+ icons, BootstrapVue provides one of the most comprehensive implementations of the Bootstrap v4 component and grid system available for Vue.js v2.6, complete with extens

31 lines (27 loc) 860 B
import Vue from '../../vue' import { NAME_FORM_DATALIST } from '../../constants/components' import { htmlOrText } from '../../utils/html' import formOptionsMixin from '../../mixins/form-options' import normalizeSlotMixin from '../../mixins/normalize-slot' // @vue/component export const BFormDatalist = /*#__PURE__*/ Vue.extend({ name: NAME_FORM_DATALIST, mixins: [formOptionsMixin, normalizeSlotMixin], props: { id: { type: String, required: true } }, render(h) { const $options = this.formOptions.map((option, index) => { const { value, text, html, disabled } = option return h('option', { attrs: { value, disabled }, domProps: htmlOrText(html, text), key: `option_${index}` }) }) return h('datalist', { attrs: { id: this.id } }, [$options, this.normalizeSlot()]) } })