771 lines
22 KiB
JavaScript
771 lines
22 KiB
JavaScript
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);
|