diff --git a/css/vue-next-select.css b/css/vue-next-select.css index e261e40..bebae3a 100644 --- a/css/vue-next-select.css +++ b/css/vue-next-select.css @@ -50,11 +50,13 @@ border-bottom-left-radius: 0; border-bottom-right-radius: 0; } -.vue-input > input[disabled], .vue-select.disabled { background-color: rgba(239, 239, 239); } -.vue-select.disabled * { +.vue-dropdown[data-removable='false'] .vue-dropdown-item.selected:hover, +.vue-select.disabled *, +.vue-select.disabled input, +.vue-tags[data-removable='false'] .vue-tag.selected img:hover { cursor: not-allowed; } .vue-select-header { @@ -121,9 +123,10 @@ font-size: 0.8rem; padding: 0; } -.vue-input > input[readonly] { - cursor: default; +.vue-input > input[disabled] { + background-color: rgba(239, 239, 239); } +.vue-input > input[readonly], .vue-select-header > .vue-input > input[disabled] { background-color: unset; } @@ -163,6 +166,9 @@ .vue-dropdown-item.selected:hover { background-color: #ff6a6a; } +.vue-dropdown[data-addable='false'][data-multiple='true'] .vue-dropdown-item:not(.selected):hover { + cursor: not-allowed; +} .icon.loading { display: inline-block; position: relative; diff --git a/js/gamutable.es6.js b/js/gamutable.es6.js index 1c11fa5..fd66725 100644 --- a/js/gamutable.es6.js +++ b/js/gamutable.es6.js @@ -619,6 +619,7 @@ let monTableau = { multiple taggable close-on-select + clear-on-close searchable @selected="selectValCol" @search:input="hanldeSearchInput($event, head)" diff --git a/js/gamutable.js b/js/gamutable.js index 45c56a6..8a14ff9 100644 --- a/js/gamutable.js +++ b/js/gamutable.js @@ -634,7 +634,7 @@ var monTableau = { this.quelleVue = vue; } }, - template: "\n\t
\n\t\t
\n\t\t\t\n\t\t\t\n\n\t\t\t\n\n\t\t\t\n\n\t\t\t\n\t\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\t\n\t\t\t\t\tMise \xE0 jour de la base de donn\xE9e\n\t\t\t\t\n\t\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\n\t\t\t{{tableau.length}} / {{table.length}} \xE9l\xE9ments\n\t\t
\n\n\t\t
\n\t\t\t
\n\t\t\t
\n\t\t
\n\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\n\t\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\n\t\t\t\n\t\t
\n\t\t\t\t\t\t\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\n\t\t\t\t\t\t\n\t\t\t\t\t
\n\t\t\t\t\t\t
\n\t\t\t\t\t\t\t\n\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t
\n\t\t\t\t\t
\n\t\t\t\t\t
\n\t\t
\n\t\t\t
{{tableau.length}} / {{table.length}} \xE9l\xE9ments
\n\t\t\t
\n\t\t\t\t
\n\t\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t
\n\t\t\t\t
\n\t\t\t\t\t\n\t\t\t\t
\n\t\t\t\t
\n\t\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t
\n\t\t\t
\n\t\t
\n\t
" + template: "\n\t
\n\t\t
\n\t\t\t\n\t\t\t\n\n\t\t\t\n\n\t\t\t\n\n\t\t\t\n\t\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\t\n\t\t\t\t\tMise \xE0 jour de la base de donn\xE9e\n\t\t\t\t\n\t\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\n\t\t\t{{tableau.length}} / {{table.length}} \xE9l\xE9ments\n\t\t
\n\n\t\t
\n\t\t\t
\n\t\t\t
\n\t\t
\n\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\n\t\t\t\n\t\t\t\n\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\n\t\t\t\n\t\t
\n\t\t\t\t\t\t\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\n\t\t\t\t\t\t\n\t\t\t\t\t
\n\t\t\t\t\t\t
\n\t\t\t\t\t\t\t\n\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t
\n\t\t\t\t\t
\n\t\t\t\t\t
\n\t\t
\n\t\t\t
{{tableau.length}} / {{table.length}} \xE9l\xE9ments
\n\t\t\t
\n\t\t\t\t
\n\t\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t
\n\t\t\t\t
\n\t\t\t\t\t\n\t\t\t\t
\n\t\t\t\t
\n\t\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t
\n\t\t\t
\n\t\t
\n\t
" }; var gamuTable = { components: { diff --git a/js/vue-next-select.js b/js/vue-next-select.js index 9cfd0c3..c48b61c 100644 --- a/js/vue-next-select.js +++ b/js/vue-next-select.js @@ -1,771 +1 @@ -this.VueNextSelect = (function (e) { - 'use strict'; - var l = { - inheritAttrs: !1, - name: 'vue-input', - props: { - modelValue: { required: !0, type: String }, - placeholder: { required: !0, type: String }, - disabled: { required: !0, type: Boolean }, - tabindex: { required: !0, type: Number }, - autofocus: { required: !0, type: Boolean }, - }, - emits: ['update:modelValue', 'input', 'change', 'focus', 'blur', 'escape'], - setup(l, t) { - const a = e.ref(null); - return ( - e.onMounted(() => { - l.autofocus && a.value.focus(); - }), - e.onUpdated(() => { - l.autofocus && a.value.focus(); - }), - { - handleInput: (e) => { - t.emit('input', e), t.emit('update:modelValue', e.target.value); - }, - handleChange: (e) => { - t.emit('change', e), t.emit('update:modelValue', e.target.value); - }, - handleFocus: (e) => { - t.emit('focus', e); - }, - handleBlur: (e) => { - t.emit('blur', e); - }, - input: a, - handleEscape: (e) => { - a.value.blur(), t.emit('escape', e); - }, - } - ); - }, - }; - const t = { class: 'vue-input' }; - (l.render = function (l, a, n, o, u, i) { - return ( - e.openBlock(), - e.createBlock('div', t, [ - e.renderSlot(l.$slots, 'prepend'), - e.createVNode( - 'input', - { - ref: 'input', - modelValue: n.modelValue, - placeholder: n.placeholder, - disabled: n.disabled, - onInput: a[1] || (a[1] = (...e) => o.handleInput && o.handleInput(...e)), - onChange: a[2] || (a[2] = (...e) => o.handleChange && o.handleChange(...e)), - onFocus: a[3] || (a[3] = (...e) => o.handleFocus && o.handleFocus(...e)), - onBlur: a[4] || (a[4] = (...e) => o.handleBlur && o.handleBlur(...e)), - onKeyup: - a[5] || - (a[5] = e.withKeys( - e.withModifiers((...e) => o.handleEscape && o.handleEscape(...e), ['exact']), - ['esc'] - )), - tabindex: n.tabindex, - autofocus: n.autofocus, - }, - null, - 40, - ['modelValue', 'placeholder', 'disabled', 'tabindex', 'autofocus'] - ), - e.renderSlot(l.$slots, 'append'), - ]) - ); - }), - (l.__file = 'src/components/input.vue'); - var a = { - inheritAttrs: !1, - name: 'vue-tags', - props: { - modelValue: { - required: !0, - type: Array, - validator: (e) => - e.every((e) => void 0 !== typeof e.key && void 0 !== e.label && 'boolean' == typeof e.selected), - }, - collapseTags: { type: Boolean }, - }, - emits: ['click'], - setup: (l, t) => ({ - dataAttrs: e.inject('dataAttrs'), - handleClick: (e) => { - t.emit('click', e); - }, - }), - }; - (a.render = function (l, t, a, n, o, u) { - return ( - e.openBlock(), - e.createBlock( - 'ul', - { - class: ['vue-tags', { collapsed: a.collapseTags }], - onMousedown: t[1] || (t[1] = e.withModifiers(() => {}, ['prevent'])), - tabindex: '-1', - onClick: t[2] || (t[2] = (...e) => n.handleClick && n.handleClick(...e)), - 'data-is-focusing': n.dataAttrs.isFocusing, - 'data-visible-length': n.dataAttrs.visibleLength, - 'data-not-selected-length': n.dataAttrs.notSelectedLength, - 'data-selected-length': n.dataAttrs.selectedLength, - 'data-total-length': n.dataAttrs.totalLength, - }, - [ - (e.openBlock(!0), - e.createBlock( - e.Fragment, - null, - e.renderList( - a.modelValue, - (t) => ( - e.openBlock(), - e.createBlock( - 'li', - { key: t.key, class: ['vue-tag', { selected: t.selected }] }, - [ - e.renderSlot(l.$slots, 'default', { option: t }, () => [ - e.createVNode('span', null, e.toDisplayString(t.label), 1), - ]), - ], - 2 - ) - ) - ), - 128 - )), - ], - 42, - [ - 'data-is-focusing', - 'data-visible-length', - 'data-not-selected-length', - 'data-selected-length', - 'data-total-length', - ] - ) - ); - }), - (a.__file = 'src/components/tags.vue'); - var n = { - inheritAttrs: !1, - name: 'vue-dropdown', - props: { - modelValue: { - required: !0, - type: Array, - validator: (e) => - e.every((e) => void 0 !== typeof e.key && void 0 !== e.label && 'boolean' == typeof e.selected), - }, - headerHeight: { required: !0, type: String }, - }, - emits: ['click'], - setup: (l, t) => ({ - dataAttrs: e.inject('dataAttrs'), - handleClick: (e, l) => { - t.emit('click', e, l); - }, - }), - }; - (n.render = function (l, t, a, n, o, u) { - return ( - e.openBlock(), - e.createBlock( - 'ul', - { - class: 'vue-dropdown', - onMousedown: t[1] || (t[1] = e.withModifiers(() => {}, ['prevent'])), - style: { top: a.headerHeight }, - 'data-is-focusing': n.dataAttrs.isFocusing, - 'data-visible-length': n.dataAttrs.visibleLength, - 'data-not-selected-length': n.dataAttrs.notSelectedLength, - 'data-selected-length': n.dataAttrs.selectedLength, - 'data-total-length': n.dataAttrs.totalLength, - }, - [ - (e.openBlock(!0), - e.createBlock( - e.Fragment, - null, - e.renderList( - a.modelValue, - (t) => ( - e.openBlock(), - e.createBlock( - e.Fragment, - { key: t.key }, - [ - t.visible && !1 === t.hidden - ? (e.openBlock(), - e.createBlock( - 'li', - { - key: 0, - onClick: (e) => n.handleClick(e, t), - class: ['vue-dropdown-item', { selected: t.selected }], - }, - [ - e.renderSlot(l.$slots, 'default', { option: t }, () => [ - e.createVNode('span', null, e.toDisplayString(t.label), 1), - ]), - ], - 10, - ['onClick'] - )) - : e.createCommentVNode('v-if', !0), - ], - 64 - ) - ) - ), - 128 - )), - ], - 44, - [ - 'data-is-focusing', - 'data-visible-length', - 'data-not-selected-length', - 'data-selected-length', - 'data-total-length', - ] - ) - ); - }), - (n.__file = 'src/components/dropdown.vue'); - const o = (e, l, { valueBy: t }) => t(e) === t(l), - u = (e, l, { valueBy: t }) => -1 !== e.findIndex((e) => o(e, l, { valueBy: t })), - i = (e, l, { valueBy: t }) => e.find((e) => t(e) === l), - d = (e, l, { max: t, valueBy: a }) => (u(e, l, { valueBy: a }) || e.length + 1 > t ? e : e.concat(l)), - s = (e, l, { min: t, valueBy: a }) => - !1 === u(e, l, { valueBy: a }) || e.length - 1 < t ? e : e.filter((e) => !1 === o(e, l, { valueBy: a })); - var r = { - name: 'vue-select', - inheritAttrs: !1, - props: { - modelValue: { required: !0 }, - options: { required: !0, type: Array }, - visibleOptions: { type: [Array, null], default: null }, - multiple: { default: !1, type: Boolean }, - min: { default: 0, type: Number }, - max: { default: 1 / 0, type: Number }, - closeOnSelect: { default: !1, type: Boolean }, - clearOnSelect: { default: !1, type: Boolean }, - trackBy: { type: [String, Function] }, - hideSelected: { default: !1, type: Boolean }, - labelBy: { type: [String, Function] }, - valueBy: { type: [String, Function] }, - disabled: { default: !1, type: Boolean }, - loading: { default: !1, type: Boolean }, - placeholder: { default: 'Select option', type: String }, - searchPlaceholder: { default: 'Type to search', type: String }, - searchable: { default: !1, type: Boolean }, - taggable: { default: !1, type: Boolean }, - collapseTags: { default: !1, type: Boolean }, - tabindex: { default: 0, type: Number }, - autofocus: { default: !1, type: Boolean }, - }, - emits: [ - 'update:modelValue', - 'selected', - 'removed', - 'opened', - 'closed', - 'search:input', - 'search:change', - 'search:focus', - 'search:blur', - ], - setup(l, t) { - const { trackBy: a, labelBy: n, valueBy: o, min: r, max: c, options: p } = ((l) => ({ - trackBy: e.computed(() => - 'function' == typeof l.trackBy - ? l.trackBy - : 'string' == typeof l.trackBy - ? (e) => l.trackBy.split('.').reduce((e, l) => e[l], e) - : (e) => e - ), - labelBy: e.computed(() => - 'function' == typeof l.labelBy - ? l.labelBy - : 'string' == typeof l.labelBy - ? (e) => l.labelBy.split('.').reduce((e, l) => e[l], e) - : (e) => e - ), - valueBy: e.computed(() => - 'function' == typeof l.valueBy - ? l.valueBy - : 'string' == typeof l.valueBy - ? (e) => l.valueBy.split('.').reduce((e, l) => e[l], e) - : (e) => e - ), - min: e.computed(() => (l.multiple ? l.min : Math.min(1, l.min))), - max: e.computed(() => (l.multiple ? l.max : 1)), - options: e.isRef(l.options) || e.isReactive(l.options) ? e.toRef(l, 'options') : e.ref(l.options), - }))(l), - h = e.ref(null), - v = e.ref(null), - g = e.ref(!1); - e.watch( - () => g.value, - () => { - g.value - ? (t.emit('opened'), - l.searchable && t.emit('search:focus'), - l.searchable - ? v.value && - v.value._.refs.input !== document.activeElement && - v.value._.refs.input.focus() - : !1 === l.searchable && h.value.focus()) - : (v.value && v.value._.refs.input === document.activeElement && v.value._.refs.input.blur(), - h.value && h.value === document.activeElement && h.value.blur(), - l.searchable && t.emit('search:blur'), - t.emit('closed')); - } - ); - const m = () => { - l.disabled || (g.value = !0); - }, - y = () => { - g.value = !1; - }; - e.watch( - () => l.disabled, - () => y() - ); - const f = e.ref(null), - b = - ((B = f), - (w = () => l.modelValue), - (I = e.ref('0')), - (k = function () { - setTimeout(function () { - B.value && (I.value = window.getComputedStyle(B.value).height); - }); - }), - e.watch(w, k), - e.onMounted(k), - I); - var B, w, I, k; - const V = e.computed(() => (l.searchable && l.multiple && l.taggable ? '22px' : '0px')), - M = e.computed(() => parseFloat(b.value) + parseFloat(V.value) + 'px'), - N = e.ref(''), - S = e.ref([]), - A = () => { - if (l.multiple) { - if (!1 === Array.isArray(l.modelValue)) return !1; - if (S.value.length !== l.modelValue.length) return !1; - if ( - Object.keys(S.value).some( - (e) => S.value[e] !== i(p.value, l.modelValue[e], { valueBy: o.value }) - ) - ) - return !1; - } else { - if (0 === S.value.length && null !== l.modelValue) return !1; - if (1 === S.value.length && null === l.modelValue) return !1; - if (S.value[0] !== i(p.value, l.modelValue, { valueBy: o.value })) return !1; - } - return !0; - }, - C = () => { - if (A()) return; - S.value = []; - const e = l.multiple ? l.modelValue : null === l.modelValue ? [] : [l.modelValue]; - for (const l of e) { - const e = i(p.value, l, { valueBy: o.value }); - !1 !== u(p.value, e, { valueBy: o.value }) && - (S.value = d(S.value, e, { max: 1 / 0, valueBy: o.value })); - } - }; - C(), - e.watch( - () => l.modelValue, - () => { - C(); - }, - { deep: !0 } - ); - e.watch( - () => S, - () => { - (() => { - if (A()) return; - const e = S.value.map((e) => o.value(e)); - l.multiple - ? t.emit('update:modelValue', e) - : e.length - ? t.emit('update:modelValue', e[0]) - : t.emit('update:modelValue', null); - })(); - }, - { deep: !0 } - ), - e.watch( - () => p.value, - () => { - const e = new Set(S.value.map((e) => o.value(e))); - S.value = p.value.filter((l) => e.has(o.value(l))); - }, - { deep: !0 } - ); - const D = (e, a) => { - if (!l.disabled) { - if (((a = a.originalOption), u(S.value, a, { valueBy: o.value }))) - (S.value = s(S.value, a, { min: r.value, valueBy: o.value })), t.emit('removed', a); - else { - if (!l.multiple) { - const e = S.value[0]; - (S.value = s(S.value, S.value[0], { min: 0, valueBy: o.value })), t.emit('removed', e); - } - (S.value = d(S.value, a, { max: c.value, valueBy: o.value })), t.emit('selected', a); - } - !0 === l.closeOnSelect && (g.value = !1), - !0 === l.clearOnSelect && - N.value && - ((v.value._.refs.input.value = ''), - v.value._.refs.input.dispatchEvent(new Event('input')), - v.value._.refs.input.dispatchEvent(new Event('change'))); - } - }, - F = e.computed(() => { - const e = new Set(S.value.map((e) => o.value(e))), - t = - null !== l.visibleOptions - ? new Set(l.visibleOptions.map((e) => o.value(e))) - : new Set(p.value.map((e) => o.value(e))); - return p.value.map((u) => ({ - key: a.value(u), - label: n.value(u), - selected: e.has(o.value(u)), - visible: t.has(o.value(u)), - hidden: !!l.hideSelected && e.has(o.value(u)), - originalOption: u, - })); - }), - x = e.computed(() => ({ - isFocusing: g.value, - visibleLength: F.value.filter((e) => e.visible && !1 === e.hidden).length, - notSelectedLength: p.value.length - F.value.filter((e) => e.selected).length, - selectedLength: F.value.filter((e) => e.selected).length, - totalLength: p.value.length, - })); - e.provide('dataAttrs', x); - const L = e.computed(() => { - const e = F.value.filter((e) => e.selected); - return l.multiple - ? 0 === e.length - ? l.placeholder - : 1 === e.length - ? '1 option selected' - : e.length + ' options selected' - : 0 === e.length - ? l.placeholder - : e[0].label; - }); - return { - isFocusing: g, - wrapper: h, - input: v, - focus: m, - blur: y, - toggle: () => { - g.value ? y() : m(); - }, - header: f, - headerAndInputHeight: M, - searchingInputValue: N, - handleInputForInput: (e) => { - t.emit('search:input', e); - }, - handleChangeForInput: (e) => { - t.emit('search:change', e); - }, - handleFocusForInput: (e) => { - m(); - }, - handleBlurForInput: (e) => { - y(); - }, - handleClickForDropdown: (e, l) => D(0, l), - handleClickForTag: (e, l) => D(0, l), - optionsWithInfo: F, - addOrRemoveOption: D, - dataAttrs: x, - innerPlaceholder: L, - }; - }, - components: { VInput: l, VTags: a, VDropdown: n }, - }; - const c = { ref: 'header', class: 'vue-select-header' }, - p = { key: 0, class: 'vue-input' }, - h = { class: 'icon loading' }, - v = e.createVNode('div', null, null, -1), - g = e.createVNode('div', null, null, -1), - m = e.createVNode('div', null, null, -1), - y = { class: 'icon loading' }, - f = e.createVNode('div', null, null, -1), - b = e.createVNode('div', null, null, -1), - B = e.createVNode('div', null, null, -1); - return ( - (r.render = function (l, t, a, n, o, u) { - const i = e.resolveComponent('v-tags'), - d = e.resolveComponent('v-input'), - s = e.resolveComponent('v-dropdown'); - return ( - e.openBlock(), - e.createBlock( - 'div', - { - ref: 'wrapper', - class: ['vue-select', { disabled: a.disabled }], - tabindex: n.isFocusing ? -1 : a.tabindex, - onFocus: t[9] || (t[9] = (...e) => n.focus && n.focus(...e)), - onBlur: t[10] || (t[10] = () => !a.searchable && n.blur()), - 'data-is-focusing': n.dataAttrs.isFocusing, - 'data-visible-length': n.dataAttrs.visibleLength, - 'data-not-selected-length': n.dataAttrs.notSelectedLength, - 'data-selected-length': n.dataAttrs.selectedLength, - 'data-total-length': n.dataAttrs.totalLength, - }, - [ - e.createVNode( - 'div', - c, - [ - (a.multiple && a.taggable && 0 === a.modelValue.length) || - (!1 === a.searchable && !1 === a.taggable) - ? (e.openBlock(), - e.createBlock('div', p, [ - e.createVNode( - 'input', - { - placeholder: n.innerPlaceholder, - readonly: '', - onClick: t[1] || (t[1] = (...e) => n.focus && n.focus(...e)), - }, - null, - 8, - ['placeholder'] - ), - ])) - : e.createCommentVNode('v-if', !0), - a.multiple && a.taggable - ? (e.openBlock(), - e.createBlock( - e.Fragment, - { key: 1 }, - [ - e.createVNode( - i, - { - modelValue: n.optionsWithInfo, - 'collapse-tags': a.collapseTags, - tabindex: '-1', - onClick: n.focus, - }, - { - default: e.withCtx(({ option: t }) => [ - e.renderSlot( - l.$slots, - 'tag', - { option: t.originalOption }, - () => [ - e.createVNode( - 'span', - null, - e.toDisplayString(t.label), - 1 - ), - e.createVNode( - 'img', - { - src: - '', - alt: 'delete tag', - class: 'icon delete', - onClick: e.withModifiers( - () => n.addOrRemoveOption(l.$event, t), - ['prevent', 'stop'] - ), - }, - null, - 8, - ['onClick'] - ), - ] - ), - ]), - _: 1, - }, - 8, - ['modelValue', 'collapse-tags', 'onClick'] - ), - e.createVNode( - 'span', - { - class: ['icon arrow-downward', { active: n.isFocusing }], - onClick: t[2] || (t[2] = (...e) => n.toggle && n.toggle(...e)), - onMousedown: - t[3] || - (t[3] = e.withModifiers(() => {}, ['prevent', 'stop'])), - }, - null, - 34 - ), - ], - 64 - )) - : (e.openBlock(), - e.createBlock( - e.Fragment, - { key: 2 }, - [ - a.searchable - ? (e.openBlock(), - e.createBlock( - d, - { - key: 0, - ref: 'input', - modelValue: n.searchingInputValue, - 'onUpdate:modelValue': - t[4] || (t[4] = (e) => (n.searchingInputValue = e)), - disabled: a.disabled, - placeholder: n.isFocusing - ? a.searchPlaceholder - : n.innerPlaceholder, - onInput: n.handleInputForInput, - onChange: n.handleChangeForInput, - onFocus: n.handleFocusForInput, - onBlur: n.handleBlurForInput, - onEscape: n.blur, - autofocus: a.autofocus || (a.taggable && a.searchable), - tabindex: a.tabindex, - }, - null, - 8, - [ - 'modelValue', - 'disabled', - 'placeholder', - 'onInput', - 'onChange', - 'onFocus', - 'onBlur', - 'onEscape', - 'autofocus', - 'tabindex', - ] - )) - : e.createCommentVNode('v-if', !0), - e.withDirectives(e.createVNode('span', h, [v, g, m], 512), [ - [e.vShow, a.loading], - ]), - e.withDirectives( - e.createVNode( - 'span', - { - class: ['icon arrow-downward', { active: n.isFocusing }], - onClick: - t[5] || (t[5] = (...e) => n.toggle && n.toggle(...e)), - onMousedown: - t[6] || - (t[6] = e.withModifiers(() => {}, ['prevent', 'stop'])), - }, - null, - 34 - ), - [[e.vShow, !1 === a.loading]] - ), - ], - 64 - )), - ], - 512 - ), - a.multiple && a.taggable && a.searchable - ? e.withDirectives( - (e.openBlock(), - e.createBlock( - d, - { - key: 0, - ref: 'input', - modelValue: n.searchingInputValue, - 'onUpdate:modelValue': t[7] || (t[7] = (e) => (n.searchingInputValue = e)), - disabled: a.disabled, - placeholder: a.searchPlaceholder, - onInput: n.handleInputForInput, - onChange: n.handleChangeForInput, - onFocus: n.handleFocusForInput, - onBlur: n.handleBlurForInput, - onEscape: n.blur, - tabindex: a.tabindex, - autofocus: a.autofocus || (a.taggable && a.searchable), - }, - { - append: e.withCtx(() => [ - e.withDirectives(e.createVNode('span', y, [f, b, B], 512), [ - [e.vShow, a.loading], - ]), - ]), - _: 1, - }, - 8, - [ - 'modelValue', - 'disabled', - 'placeholder', - 'onInput', - 'onChange', - 'onFocus', - 'onBlur', - 'onEscape', - 'tabindex', - 'autofocus', - ] - )), - [[e.vShow, n.isFocusing]] - ) - : e.createCommentVNode('v-if', !0), - e.withDirectives( - e.createVNode( - s, - { - modelValue: n.optionsWithInfo, - 'onUpdate:modelValue': t[8] || (t[8] = (e) => (n.optionsWithInfo = e)), - onClick: n.handleClickForDropdown, - 'header-height': n.headerAndInputHeight, - }, - { - default: e.withCtx(({ option: t }) => [ - e.renderSlot(l.$slots, 'dropdown-item', { option: t.originalOption }, () => [ - e.createVNode('span', null, e.toDisplayString(t.label), 1), - ]), - ]), - _: 1, - }, - 8, - ['modelValue', 'onClick', 'header-height'] - ), - [[e.vShow, n.isFocusing]] - ), - ], - 42, - [ - 'tabindex', - 'data-is-focusing', - 'data-visible-length', - 'data-not-selected-length', - 'data-selected-length', - 'data-total-length', - ] - ) - ); - }), - (r.__file = 'src/index.vue'), - r - ); -})(Vue); +this.VueNextSelect=function(e){"use strict";var l={inheritAttrs:!1,name:"vue-input",props:{modelValue:{required:!0,type:String},placeholder:{required:!0,type:String},disabled:{required:!0,type:Boolean},tabindex:{required:!0,type:Number},autofocus:{required:!0,type:Boolean}},emits:["update:modelValue","input","change","focus","blur","escape"],setup(l,a){const t=e.ref(null);return e.onMounted((()=>{l.autofocus&&t.value.focus()})),e.onUpdated((()=>{l.autofocus&&t.value.focus()})),{handleInput:e=>{a.emit("input",e),a.emit("update:modelValue",e.target.value)},handleChange:e=>{a.emit("change",e),a.emit("update:modelValue",e.target.value)},handleFocus:e=>{a.emit("focus",e)},handleBlur:e=>{a.emit("blur",e)},input:t,handleEscape:e=>{t.value.blur(),a.emit("escape",e)}}}};const a={class:"vue-input"};l.render=function(l,t,o,n,u,i){return e.openBlock(),e.createBlock("div",a,[e.renderSlot(l.$slots,"prepend"),e.createVNode("input",{ref:"input",modelValue:o.modelValue,placeholder:o.placeholder,disabled:o.disabled,onInput:t[1]||(t[1]=(...e)=>n.handleInput&&n.handleInput(...e)),onChange:t[2]||(t[2]=(...e)=>n.handleChange&&n.handleChange(...e)),onFocus:t[3]||(t[3]=(...e)=>n.handleFocus&&n.handleFocus(...e)),onBlur:t[4]||(t[4]=(...e)=>n.handleBlur&&n.handleBlur(...e)),onKeyup:t[5]||(t[5]=e.withKeys(e.withModifiers(((...e)=>n.handleEscape&&n.handleEscape(...e)),["exact"]),["esc"])),tabindex:o.tabindex,autofocus:o.autofocus},null,40,["modelValue","placeholder","disabled","tabindex","autofocus"]),e.renderSlot(l.$slots,"append")])},l.__file="src/components/input.vue";var t={inheritAttrs:!1,name:"vue-tags",props:{modelValue:{required:!0,type:Array,validator:e=>e.every((e=>void 0!==typeof e.key&&void 0!==e.label&&"boolean"==typeof e.selected))},collapseTags:{type:Boolean}},emits:["click"],setup:(l,a)=>({dataAttrs:e.inject("dataAttrs"),handleClick:e=>{a.emit("click",e)}})};t.render=function(l,a,t,o,n,u){return e.openBlock(),e.createBlock("ul",e.mergeProps({class:["vue-tags",{collapsed:t.collapseTags}],onMousedown:a[1]||(a[1]=e.withModifiers((()=>{}),["prevent"])),tabindex:"-1",onClick:a[2]||(a[2]=(...e)=>o.handleClick&&o.handleClick(...e))},o.dataAttrs),[(e.openBlock(!0),e.createBlock(e.Fragment,null,e.renderList(t.modelValue,(a=>(e.openBlock(),e.createBlock("li",{key:a.key,class:["vue-tag",{selected:a.selected}]},[e.renderSlot(l.$slots,"default",{option:a},(()=>[e.createVNode("span",null,e.toDisplayString(a.label),1)]))],2)))),128))],16)},t.__file="src/components/tags.vue";var o={inheritAttrs:!1,name:"vue-dropdown",props:{modelValue:{required:!0,type:Array,validator:e=>e.every((e=>void 0!==typeof e.key&&void 0!==e.label&&"boolean"==typeof e.selected))},headerHeight:{required:!0,type:String}},emits:["click"],setup:(l,a)=>({dataAttrs:e.inject("dataAttrs"),handleClick:(e,l)=>{a.emit("click",e,l)}})};o.render=function(l,a,t,o,n,u){return e.openBlock(),e.createBlock("ul",e.mergeProps({class:"vue-dropdown",onMousedown:a[1]||(a[1]=e.withModifiers((()=>{}),["prevent"])),style:{top:t.headerHeight}},o.dataAttrs),[(e.openBlock(!0),e.createBlock(e.Fragment,null,e.renderList(t.modelValue,(a=>(e.openBlock(),e.createBlock(e.Fragment,{key:a.key},[a.visible&&!1===a.hidden?(e.openBlock(),e.createBlock("li",{key:0,onClick:e=>o.handleClick(e,a),class:["vue-dropdown-item",{selected:a.selected}]},[e.renderSlot(l.$slots,"default",{option:a},(()=>[e.createVNode("span",null,e.toDisplayString(a.label),1)]))],10,["onClick"])):e.createCommentVNode("v-if",!0)],64)))),128))],16)},o.__file="src/components/dropdown.vue";const n=(e,l,{valueBy:a})=>a(e)===a(l),u=(e,l,{valueBy:a})=>e.some((e=>n(e,l,{valueBy:a}))),i=(e,l,{valueBy:a})=>e.find((e=>a(e)===l)),d=(e,l,{max:a,valueBy:t})=>u(e,l,{valueBy:t})||e.length>=a?e:e.concat(l),r=(e,l,{min:a,valueBy:t})=>!1===u(e,l,{valueBy:t})||e.length<=a?e:e.filter((e=>!1===n(e,l,{valueBy:t}))),s=l=>e.computed((()=>"function"==typeof l.value?l.value:"string"==typeof l.value?e=>l.value.split(".").reduce(((e,l)=>e[l]),e):e=>e));const c={name:"vue-select",inheritAttrs:!1,props:{modelValue:{required:!0},emptyModelValue:{default:null},options:{required:!0,type:Array},visibleOptions:{type:[Array,null],default:null},multiple:{default:!1,type:Boolean},min:{default:0,type:Number},max:{default:1/0,type:Number},closeOnSelect:{default:!1,type:Boolean},clearOnSelect:{default:!1,type:Boolean},trackBy:{type:[String,Function]},hideSelected:{default:!1,type:Boolean},labelBy:{type:[String,Function]},valueBy:{type:[String,Function]},disabled:{default:!1,type:Boolean},loading:{default:!1,type:Boolean},placeholder:{default:"Select option",type:String},searchPlaceholder:{default:"Type to search",type:String},searchable:{default:!1,type:Boolean},clearOnClose:{default:!1,type:Boolean},taggable:{default:!1,type:Boolean},collapseTags:{default:!1,type:Boolean},tabindex:{default:0,type:Number},autofocus:{default:!1,type:Boolean}},emits:["update:modelValue","selected","removed","opened","closed","search:input","search:change","search:focus","search:blur"],setup(l,a){const{trackBy:t,labelBy:o,valueBy:n,min:c,max:p,options:v}=(l=>({trackBy:s(e.toRef(l,"trackBy")),labelBy:s(e.toRef(l,"labelBy")),valueBy:s(e.toRef(l,"valueBy")),min:e.computed((()=>l.multiple?l.min:Math.min(1,l.min))),max:e.computed((()=>l.multiple?l.max:1)),options:e.isRef(l.options)||e.isReactive(l.options)?e.toRef(l,"options"):e.ref(l.options)}))(l),h=e.ref(),m=e.ref(),g=e.ref(!1);e.watch((()=>g.value),(()=>{g.value?(a.emit("opened"),l.searchable?(m.value&&m.value._.refs.input!==document.activeElement&&m.value._.refs.input.focus(),a.emit("search:focus")):h.value.focus()):(l.searchable?(m.value&&m.value._.refs.input===document.activeElement&&m.value._.refs.input.blur(),l.clearOnClose&&F(),a.emit("search:blur")):h.value.blur(),a.emit("closed"))}));const f=()=>{l.disabled||(g.value=!0)},y=()=>{g.value=!1};e.watch((()=>l.disabled),(()=>y()));const b=e.ref(),B=(V=b,I=()=>l.modelValue,w=e.ref("0"),k=function(){e.nextTick((function(){V.value&&(w.value=window.getComputedStyle(V.value).height)}))},e.watch(I,k),e.onMounted(k),w);var V,I,w,k;const M=e.computed((()=>l.searchable&&l.multiple&&l.taggable?"22px":"0px")),N=e.computed((()=>parseFloat(B.value)+parseFloat(M.value)+"px")),C=e.ref(""),S=e.ref([]),x=()=>{if(l.multiple){if(!1===Array.isArray(l.modelValue))return!1;if(S.value.length!==l.modelValue.length)return!1;if(Object.keys(S.value).some((e=>S.value[e]!==i(v.value,l.modelValue[e],{valueBy:n.value}))))return!1}else{if(0===S.value.length&&l.modelValue!==l.emptyModelValue)return!1;if(1===S.value.length&&l.modelValue===l.emptyModelValue)return!1;if(S.value[0]!==i(v.value,l.modelValue,{valueBy:n.value}))return!1}return!0},D=()=>{if(x())return;S.value=[];const e=l.multiple?l.modelValue:l.modelValue===l.emptyModelValue?[]:[l.modelValue];for(const l of e){const e=i(v.value,l,{valueBy:n.value});!1!==u(v.value,e,{valueBy:n.value})&&(S.value=d(S.value,e,{max:1/0,valueBy:n.value}))}};D(),e.watch((()=>l.modelValue),(()=>D()),{deep:!0});e.watch((()=>S),(()=>(()=>{if(x())return;const e=S.value.map((e=>n.value(e)));l.multiple?a.emit("update:modelValue",e):e.length?a.emit("update:modelValue",e[0]):a.emit("update:modelValue",l.emptyModelValue)})()),{deep:!0}),e.watch((()=>v.value),(()=>{const e=new Set(S.value.map((e=>n.value(e))));S.value=v.value.filter((l=>e.has(n.value(l))))}),{deep:!0});const F=()=>{m.value._.refs.input.value="",m.value._.refs.input.dispatchEvent(new Event("input")),m.value._.refs.input.dispatchEvent(new Event("change"))},O=e.computed((()=>{const e=new Set(S.value.map((e=>n.value(e)))),a=null!==l.visibleOptions?new Set(l.visibleOptions.map((e=>n.value(e)))):new Set(v.value.map((e=>n.value(e))));return v.value.map((u=>({key:t.value(u),label:o.value(u),selected:e.has(n.value(u)),visible:a.has(n.value(u)),hidden:!!l.hideSelected&&e.has(n.value(u)),originalOption:u})))})),A=e.computed((()=>({"data-is-focusing":g.value,"data-visible-length":O.value.filter((e=>e.visible&&!1===e.hidden)).length,"data-not-selected-length":v.value.length-O.value.filter((e=>e.selected)).length,"data-selected-length":O.value.filter((e=>e.selected)).length,"data-addable":O.value.filter((e=>e.selected)).lengthe.selected)).length>c.value,"data-total-length":v.value.length,"data-multiple":l.multiple})));e.provide("dataAttrs",A);const T=e.computed((()=>{const e=O.value.filter((e=>e.selected));return l.multiple?0===e.length?l.placeholder:1===e.length?"1 option selected":e.length+" options selected":0===e.length?l.placeholder:e[0].label+""}));return{isFocusing:g,wrapper:h,input:m,focus:f,blur:y,toggle:()=>{g.value?y():f()},header:b,headerAndInputHeight:N,searchingInputValue:C,handleInputForInput:e=>{a.emit("search:input",e)},handleChangeForInput:e=>{a.emit("search:change",e)},handleFocusForInput:e=>{f()},handleBlurForInput:e=>{y()},optionsWithInfo:O,addOrRemoveOption:(e,t)=>{if(!l.disabled){if(t=t.originalOption,u(S.value,t,{valueBy:n.value}))S.value=r(S.value,t,{min:c.value,valueBy:n.value}),a.emit("removed",t);else{if(!l.multiple){const e=S.value[0];S.value=r(S.value,S.value[0],{min:0,valueBy:n.value}),a.emit("removed",e)}S.value=d(S.value,t,{max:p.value,valueBy:n.value}),a.emit("selected",t)}!0===l.closeOnSelect&&(g.value=!1),!0===l.clearOnSelect&&C.value&&F()}},dataAttrs:A,innerPlaceholder:T}},components:{VInput:l,VTags:t,VDropdown:o},__VERSION__:"1.2.1"};const p={ref:"header",class:"vue-select-header"},v={key:0,class:"vue-input"},h={class:"icon loading"},m=e.createVNode("div",null,null,-1),g=e.createVNode("div",null,null,-1),f=e.createVNode("div",null,null,-1),y={class:"icon loading"},b=e.createVNode("div",null,null,-1),B=e.createVNode("div",null,null,-1),V=e.createVNode("div",null,null,-1);return c.render=function(l,a,t,o,n,u){const i=e.resolveComponent("v-tags"),d=e.resolveComponent("v-input"),r=e.resolveComponent("v-dropdown");return e.openBlock(),e.createBlock("div",e.mergeProps({ref:"wrapper",class:["vue-select",{disabled:l.disabled}],tabindex:l.isFocusing?-1:l.tabindex,onFocus:a[9]||(a[9]=(...e)=>l.focus&&l.focus(...e)),onBlur:a[10]||(a[10]=()=>!l.searchable&&l.blur())},l.dataAttrs),[e.createVNode("div",p,[l.multiple&&l.taggable&&0===l.modelValue.length||!1===l.searchable&&!1===l.taggable?(e.openBlock(),e.createBlock("div",v,[e.createVNode("input",{placeholder:l.innerPlaceholder,readonly:"",onClick:a[1]||(a[1]=(...e)=>l.focus&&l.focus(...e))},null,8,["placeholder"])])):e.createCommentVNode("v-if",!0),l.multiple&&l.taggable?(e.openBlock(),e.createBlock(e.Fragment,{key:1},[e.createVNode(i,{modelValue:l.optionsWithInfo,"collapse-tags":l.collapseTags,tabindex:"-1",onClick:l.focus},{default:e.withCtx((({option:a})=>[e.renderSlot(l.$slots,"tag",{option:a.originalOption},(()=>[e.createVNode("span",null,e.toDisplayString(a.label),1),e.createVNode("img",{src:"",alt:"delete tag",class:"icon delete",onClick:e.withModifiers((()=>l.addOrRemoveOption(l.$event,a)),["prevent","stop"])},null,8,["onClick"])]))])),_:1},8,["modelValue","collapse-tags","onClick"]),e.createVNode("span",{class:["icon arrow-downward",{active:l.isFocusing}],onClick:a[2]||(a[2]=(...e)=>l.toggle&&l.toggle(...e)),onMousedown:a[3]||(a[3]=e.withModifiers((()=>{}),["prevent","stop"]))},null,34)],64)):(e.openBlock(),e.createBlock(e.Fragment,{key:2},[l.searchable?(e.openBlock(),e.createBlock(d,{key:0,ref:"input",modelValue:l.searchingInputValue,"onUpdate:modelValue":a[4]||(a[4]=e=>l.searchingInputValue=e),disabled:l.disabled,placeholder:l.isFocusing?l.searchPlaceholder:l.innerPlaceholder,onInput:l.handleInputForInput,onChange:l.handleChangeForInput,onFocus:l.handleFocusForInput,onBlur:l.handleBlurForInput,onEscape:l.blur,autofocus:l.autofocus||l.taggable&&l.searchable,tabindex:l.tabindex},null,8,["modelValue","disabled","placeholder","onInput","onChange","onFocus","onBlur","onEscape","autofocus","tabindex"])):e.createCommentVNode("v-if",!0),e.withDirectives(e.createVNode("span",h,[m,g,f],512),[[e.vShow,l.loading]]),e.withDirectives(e.createVNode("span",{class:["icon arrow-downward",{active:l.isFocusing}],onClick:a[5]||(a[5]=(...e)=>l.toggle&&l.toggle(...e)),onMousedown:a[6]||(a[6]=e.withModifiers((()=>{}),["prevent","stop"]))},null,34),[[e.vShow,!1===l.loading]])],64))],512),l.multiple&&l.taggable&&l.searchable?e.withDirectives((e.openBlock(),e.createBlock(d,{key:0,ref:"input",modelValue:l.searchingInputValue,"onUpdate:modelValue":a[7]||(a[7]=e=>l.searchingInputValue=e),disabled:l.disabled,placeholder:l.searchPlaceholder,onInput:l.handleInputForInput,onChange:l.handleChangeForInput,onFocus:l.handleFocusForInput,onBlur:l.handleBlurForInput,onEscape:l.blur,tabindex:l.tabindex,autofocus:l.autofocus||l.taggable&&l.searchable},{append:e.withCtx((()=>[e.withDirectives(e.createVNode("span",y,[b,B,V],512),[[e.vShow,l.loading]])])),_:1},8,["modelValue","disabled","placeholder","onInput","onChange","onFocus","onBlur","onEscape","tabindex","autofocus"])),[[e.vShow,l.isFocusing]]):e.createCommentVNode("v-if",!0),e.withDirectives(e.createVNode(r,{modelValue:l.optionsWithInfo,"onUpdate:modelValue":a[8]||(a[8]=e=>l.optionsWithInfo=e),onClick:l.addOrRemoveOption,"header-height":l.headerAndInputHeight},{default:e.withCtx((({option:a})=>[e.renderSlot(l.$slots,"dropdown-item",{option:a.originalOption},(()=>[e.createVNode("span",null,e.toDisplayString(a.label),1)]))])),_:1},8,["modelValue","onClick","header-height"]),[[e.vShow,l.isFocusing]])],16,["tabindex"])},c.__file="src/index.vue",c}(Vue);