1565 lines
54 KiB
JavaScript
1565 lines
54 KiB
JavaScript
this.VueNextSelect = (function (vue) {
|
|
'use strict';
|
|
|
|
function _typeof(obj) {
|
|
"@babel/helpers - typeof";
|
|
|
|
if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
|
|
_typeof = function (obj) {
|
|
return typeof obj;
|
|
};
|
|
} else {
|
|
_typeof = function (obj) {
|
|
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
|
|
};
|
|
}
|
|
|
|
return _typeof(obj);
|
|
}
|
|
|
|
function _defineProperty(obj, key, value) {
|
|
if (key in obj) {
|
|
Object.defineProperty(obj, key, {
|
|
value: value,
|
|
enumerable: true,
|
|
configurable: true,
|
|
writable: true
|
|
});
|
|
} else {
|
|
obj[key] = value;
|
|
}
|
|
|
|
return obj;
|
|
}
|
|
|
|
function _toConsumableArray(arr) {
|
|
return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
|
|
}
|
|
|
|
function _arrayWithoutHoles(arr) {
|
|
if (Array.isArray(arr)) return _arrayLikeToArray(arr);
|
|
}
|
|
|
|
function _iterableToArray(iter) {
|
|
if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
|
|
}
|
|
|
|
function _unsupportedIterableToArray(o, minLen) {
|
|
if (!o) return;
|
|
if (typeof o === "string") return _arrayLikeToArray(o, minLen);
|
|
var n = Object.prototype.toString.call(o).slice(8, -1);
|
|
if (n === "Object" && o.constructor) n = o.constructor.name;
|
|
if (n === "Map" || n === "Set") return Array.from(o);
|
|
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
|
|
}
|
|
|
|
function _arrayLikeToArray(arr, len) {
|
|
if (len == null || len > arr.length) len = arr.length;
|
|
|
|
for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
|
|
|
|
return arr2;
|
|
}
|
|
|
|
function _nonIterableSpread() {
|
|
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
}
|
|
|
|
function _createForOfIteratorHelper(o, allowArrayLike) {
|
|
var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
|
|
|
|
if (!it) {
|
|
if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
|
|
if (it) o = it;
|
|
var i = 0;
|
|
|
|
var F = function () {};
|
|
|
|
return {
|
|
s: F,
|
|
n: function () {
|
|
if (i >= o.length) return {
|
|
done: true
|
|
};
|
|
return {
|
|
done: false,
|
|
value: o[i++]
|
|
};
|
|
},
|
|
e: function (e) {
|
|
throw e;
|
|
},
|
|
f: F
|
|
};
|
|
}
|
|
|
|
throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
}
|
|
|
|
var normalCompletion = true,
|
|
didErr = false,
|
|
err;
|
|
return {
|
|
s: function () {
|
|
it = it.call(o);
|
|
},
|
|
n: function () {
|
|
var step = it.next();
|
|
normalCompletion = step.done;
|
|
return step;
|
|
},
|
|
e: function (e) {
|
|
didErr = true;
|
|
err = e;
|
|
},
|
|
f: function () {
|
|
try {
|
|
if (!normalCompletion && it.return != null) it.return();
|
|
} finally {
|
|
if (didErr) throw err;
|
|
}
|
|
}
|
|
};
|
|
}
|
|
|
|
var script$2 = {
|
|
inheritAttrs: false,
|
|
name: 'vue-input',
|
|
props: {
|
|
autocomplete: {
|
|
required: false,
|
|
type: String
|
|
},
|
|
modelValue: {
|
|
required: true,
|
|
type: String
|
|
},
|
|
placeholder: {
|
|
required: true,
|
|
type: String
|
|
},
|
|
disabled: {
|
|
required: true,
|
|
type: Boolean
|
|
},
|
|
tabindex: {
|
|
required: true,
|
|
type: Number
|
|
},
|
|
autofocus: {
|
|
required: true,
|
|
type: Boolean
|
|
},
|
|
comboboxUid: {
|
|
required: true,
|
|
type: Number
|
|
}
|
|
},
|
|
emits: ['update:modelValue', 'input', 'change', 'focus', 'blur', 'escape'],
|
|
setup: function setup(props, context) {
|
|
var handleInput = function handleInput(event) {
|
|
context.emit('input', event);
|
|
context.emit('update:modelValue', event.target.value);
|
|
};
|
|
|
|
var handleChange = function handleChange(event) {
|
|
context.emit('change', event);
|
|
context.emit('update:modelValue', event.target.value);
|
|
};
|
|
|
|
var handleFocus = function handleFocus(event) {
|
|
context.emit('focus', event);
|
|
};
|
|
|
|
var handleBlur = function handleBlur(event) {
|
|
context.emit('blur', event);
|
|
};
|
|
|
|
var input = vue.ref(null);
|
|
|
|
var handleEscape = function handleEscape(event) {
|
|
input.value.blur();
|
|
context.emit('escape', event);
|
|
};
|
|
|
|
vue.onMounted(function () {
|
|
if (props.autofocus) input.value.focus();
|
|
});
|
|
vue.onUpdated(function () {
|
|
if (props.autofocus) input.value.focus();
|
|
});
|
|
return {
|
|
handleInput: handleInput,
|
|
handleChange: handleChange,
|
|
handleFocus: handleFocus,
|
|
handleBlur: handleBlur,
|
|
input: input,
|
|
handleEscape: handleEscape
|
|
};
|
|
}
|
|
};
|
|
|
|
var _hoisted_1$2 = {
|
|
"class": "vue-input"
|
|
};
|
|
var _hoisted_2$2 = ["autocomplete", "modelValue", "placeholder", "disabled", "tabindex", "autofocus", "aria-controls", "aria-labelledby"];
|
|
function render$3(_ctx, _cache, $props, $setup, $data, $options) {
|
|
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$2, [vue.renderSlot(_ctx.$slots, "prepend"), vue.createElementVNode("input", {
|
|
ref: "input",
|
|
autocomplete: $props.autocomplete,
|
|
modelValue: $props.modelValue,
|
|
placeholder: $props.placeholder,
|
|
disabled: $props.disabled,
|
|
onInput: _cache[0] || (_cache[0] = function () {
|
|
return $setup.handleInput && $setup.handleInput.apply($setup, arguments);
|
|
}),
|
|
onChange: _cache[1] || (_cache[1] = function () {
|
|
return $setup.handleChange && $setup.handleChange.apply($setup, arguments);
|
|
}),
|
|
onFocus: _cache[2] || (_cache[2] = function () {
|
|
return $setup.handleFocus && $setup.handleFocus.apply($setup, arguments);
|
|
}),
|
|
onBlur: _cache[3] || (_cache[3] = function () {
|
|
return $setup.handleBlur && $setup.handleBlur.apply($setup, arguments);
|
|
}),
|
|
onKeyup: _cache[4] || (_cache[4] = vue.withKeys(vue.withModifiers(function () {
|
|
return $setup.handleEscape && $setup.handleEscape.apply($setup, arguments);
|
|
}, ["exact"]), ["esc"])),
|
|
tabindex: $props.tabindex,
|
|
autofocus: $props.autofocus,
|
|
"aria-autocomplete": "list",
|
|
"aria-controls": "vs".concat($props.comboboxUid, "-listbox"),
|
|
"aria-labelledby": "vs".concat($props.comboboxUid, "-combobox")
|
|
}, null, 40
|
|
/* PROPS, HYDRATE_EVENTS */
|
|
, _hoisted_2$2), vue.renderSlot(_ctx.$slots, "append")]);
|
|
}
|
|
|
|
script$2.render = render$3;
|
|
script$2.__file = "src/components/input.vue";
|
|
|
|
var script$1 = {
|
|
inheritAttrs: false,
|
|
name: 'vue-tags',
|
|
props: {
|
|
modelValue: {
|
|
required: true,
|
|
type: Array,
|
|
validator: function validator(modelValue) {
|
|
return modelValue.every(function (option) {
|
|
return _typeof(option.key) !== undefined && option.label !== undefined && typeof option.selected === 'boolean';
|
|
});
|
|
}
|
|
},
|
|
collapseTags: {
|
|
type: Boolean
|
|
}
|
|
},
|
|
emits: ['click'],
|
|
setup: function setup(props, context) {
|
|
var dataAttrs = vue.inject('dataAttrs');
|
|
|
|
var handleClick = function handleClick(event) {
|
|
context.emit('click', event);
|
|
};
|
|
|
|
return {
|
|
dataAttrs: dataAttrs,
|
|
handleClick: handleClick
|
|
};
|
|
}
|
|
};
|
|
|
|
function render$2(_ctx, _cache, $props, $setup, $data, $options) {
|
|
return vue.openBlock(), vue.createElementBlock("ul", vue.mergeProps({
|
|
"class": ["vue-tags", {
|
|
collapsed: $props.collapseTags
|
|
}],
|
|
onMousedown: _cache[0] || (_cache[0] = vue.withModifiers(function () {}, ["prevent"])),
|
|
tabindex: "-1",
|
|
onClick: _cache[1] || (_cache[1] = function () {
|
|
return $setup.handleClick && $setup.handleClick.apply($setup, arguments);
|
|
})
|
|
}, $setup.dataAttrs), [(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($props.modelValue, function (option) {
|
|
return vue.openBlock(), vue.createElementBlock(vue.Fragment, {
|
|
key: option.key
|
|
}, [!option.group ? (vue.openBlock(), vue.createElementBlock("li", {
|
|
key: 0,
|
|
"class": vue.normalizeClass(["vue-tag", {
|
|
selected: option.selected
|
|
}])
|
|
}, [vue.renderSlot(_ctx.$slots, "default", {
|
|
option: option
|
|
}, function () {
|
|
return [vue.createElementVNode("span", null, vue.toDisplayString(option.label), 1
|
|
/* TEXT */
|
|
)];
|
|
})], 2
|
|
/* CLASS */
|
|
)) : vue.createCommentVNode("v-if", true)], 64
|
|
/* STABLE_FRAGMENT */
|
|
);
|
|
}), 128
|
|
/* KEYED_FRAGMENT */
|
|
))], 16
|
|
/* FULL_PROPS */
|
|
);
|
|
}
|
|
|
|
script$1.render = render$2;
|
|
script$1.__file = "src/components/tags.vue";
|
|
|
|
var script = {
|
|
inheritAttrs: false,
|
|
name: 'vue-dropdown',
|
|
props: {
|
|
modelValue: {
|
|
required: true,
|
|
type: Array,
|
|
validator: function validator(modelValue) {
|
|
return modelValue.every(function (option) {
|
|
return _typeof(option.key) !== undefined && option.label !== undefined && typeof option.selected === 'boolean';
|
|
});
|
|
}
|
|
},
|
|
comboboxUid: {
|
|
required: true,
|
|
type: Number
|
|
},
|
|
maxHeight: {
|
|
required: true
|
|
},
|
|
highlightedOriginalIndex: {
|
|
required: true
|
|
}
|
|
},
|
|
emits: ['click-item', 'mouseenter'],
|
|
setup: function setup(props, context) {
|
|
var dataAttrs = vue.inject('dataAttrs');
|
|
|
|
var handleClickItem = function handleClickItem(event, option) {
|
|
if (option.disabled) return;
|
|
context.emit('click-item', event, option);
|
|
};
|
|
|
|
var handleMouseenter = function handleMouseenter(event, option) {
|
|
context.emit('mouseenter', event, option);
|
|
};
|
|
|
|
return {
|
|
dataAttrs: dataAttrs,
|
|
handleClickItem: handleClickItem,
|
|
handleMouseenter: handleMouseenter
|
|
};
|
|
}
|
|
};
|
|
|
|
var _hoisted_1$1 = ["id", "aria-multiselectable", "aria-busy", "aria-disabled"];
|
|
var _hoisted_2$1 = ["onClick", "onMouseenter", "id", "aria-selected", "aria-disabled"];
|
|
function render$1(_ctx, _cache, $props, $setup, $data, $options) {
|
|
return vue.openBlock(), vue.createElementBlock("ul", vue.mergeProps({
|
|
"class": "vue-dropdown",
|
|
style: {
|
|
maxHeight: $props.maxHeight + 'px'
|
|
},
|
|
onMousedown: _cache[0] || (_cache[0] = vue.withModifiers(function () {}, ["prevent"]))
|
|
}, $setup.dataAttrs, {
|
|
role: "listbox",
|
|
id: "vs".concat($props.comboboxUid, "-listbox"),
|
|
"aria-multiselectable": $setup.dataAttrs['data-multiple'],
|
|
"aria-busy": $setup.dataAttrs['data-loading'],
|
|
"aria-disabled": $setup.dataAttrs['data-disabled']
|
|
}), [(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($props.modelValue, function (option, index) {
|
|
return vue.openBlock(), vue.createElementBlock(vue.Fragment, {
|
|
key: option.key
|
|
}, [option.visible && option.hidden === false ? (vue.openBlock(), vue.createElementBlock("li", {
|
|
key: 0,
|
|
onClick: function onClick($event) {
|
|
return $setup.handleClickItem($event, option);
|
|
},
|
|
"class": vue.normalizeClass(["vue-dropdown-item", {
|
|
selected: option.selected,
|
|
disabled: option.disabled,
|
|
highlighted: option.originalIndex === $props.highlightedOriginalIndex,
|
|
group: option.group
|
|
}]),
|
|
onMouseenter: function onMouseenter($event) {
|
|
return $setup.handleMouseenter($event, option);
|
|
},
|
|
role: "option",
|
|
id: "vs".concat($props.comboboxUid, "-option-").concat(index),
|
|
"aria-selected": option.selected ? true : option.disabled ? undefined : false,
|
|
"aria-disabled": option.disabled
|
|
}, [vue.renderSlot(_ctx.$slots, "default", {
|
|
option: option
|
|
}, function () {
|
|
return [vue.createElementVNode("span", null, vue.toDisplayString(option.label), 1
|
|
/* TEXT */
|
|
)];
|
|
})], 42
|
|
/* CLASS, PROPS, HYDRATE_EVENTS */
|
|
, _hoisted_2$1)) : vue.createCommentVNode("v-if", true)], 64
|
|
/* STABLE_FRAGMENT */
|
|
);
|
|
}), 128
|
|
/* KEYED_FRAGMENT */
|
|
))], 16
|
|
/* FULL_PROPS */
|
|
, _hoisted_1$1);
|
|
}
|
|
|
|
script.render = render$1;
|
|
script.__file = "src/components/dropdown.vue";
|
|
|
|
var isSameOption = function isSameOption(option1, option2, _ref) {
|
|
var valueBy = _ref.valueBy;
|
|
return valueBy(option1) === valueBy(option2);
|
|
};
|
|
var hasOption = function hasOption(options, option, _ref2) {
|
|
var valueBy = _ref2.valueBy;
|
|
return options.some(function (_option) {
|
|
return isSameOption(_option, option, {
|
|
valueBy: valueBy
|
|
});
|
|
});
|
|
};
|
|
var getOptionByValue = function getOptionByValue(options, value, _ref3) {
|
|
var valueBy = _ref3.valueBy;
|
|
return options.find(function (option) {
|
|
return valueBy(option) === value;
|
|
});
|
|
};
|
|
var addOption = function addOption(selectedOptions, option, _ref4) {
|
|
var max = _ref4.max,
|
|
valueBy = _ref4.valueBy;
|
|
if (hasOption(selectedOptions, option, {
|
|
valueBy: valueBy
|
|
})) return selectedOptions;
|
|
if (selectedOptions.length >= max) return selectedOptions;
|
|
return selectedOptions.concat(option);
|
|
};
|
|
var removeOption = function removeOption(selectedOptions, option, _ref5) {
|
|
var min = _ref5.min,
|
|
valueBy = _ref5.valueBy;
|
|
if (hasOption(selectedOptions, option, {
|
|
valueBy: valueBy
|
|
}) === false) return selectedOptions;
|
|
if (selectedOptions.length <= min) return selectedOptions;
|
|
return selectedOptions.filter(function (_option) {
|
|
return isSameOption(_option, option, {
|
|
valueBy: valueBy
|
|
}) === false;
|
|
});
|
|
};
|
|
|
|
var createComputedForGetterFunction = function createComputedForGetterFunction(maybePathFunc) {
|
|
return vue.computed(function () {
|
|
return typeof maybePathFunc.value === 'function' ? maybePathFunc.value : typeof maybePathFunc.value === 'string' ? function (option) {
|
|
return maybePathFunc.value.split('.').reduce(function (value, key) {
|
|
return value[key];
|
|
}, option);
|
|
} : function (option) {
|
|
return option;
|
|
};
|
|
});
|
|
};
|
|
|
|
var normalize = (function (props) {
|
|
var normalized = vue.reactive({});
|
|
var labelBy = createComputedForGetterFunction(vue.toRef(props, 'labelBy'));
|
|
vue.watchEffect(function () {
|
|
return normalized.labelBy = labelBy.value;
|
|
});
|
|
var valueBy = createComputedForGetterFunction(vue.toRef(props, 'valueBy'));
|
|
vue.watchEffect(function () {
|
|
return normalized.valueBy = valueBy.value;
|
|
});
|
|
var disabledBy = createComputedForGetterFunction(vue.toRef(props, 'disabledBy'));
|
|
vue.watchEffect(function () {
|
|
return normalized.disabledBy = disabledBy.value;
|
|
});
|
|
var groupBy = createComputedForGetterFunction(vue.toRef(props, 'groupBy'));
|
|
vue.watchEffect(function () {
|
|
return normalized.groupBy = groupBy.value;
|
|
});
|
|
var min = vue.computed(function () {
|
|
return props.multiple ? props.min : Math.min(1, props.min);
|
|
});
|
|
vue.watchEffect(function () {
|
|
return normalized.min = min.value;
|
|
});
|
|
var max = vue.computed(function () {
|
|
return props.multiple ? props.max : 1;
|
|
});
|
|
vue.watchEffect(function () {
|
|
return normalized.max = max.value;
|
|
});
|
|
vue.watchEffect(function () {
|
|
return normalized.options = props.options;
|
|
});
|
|
return normalized;
|
|
});
|
|
|
|
var usePointer = function usePointer(options, highlightedOriginalIndex) {
|
|
var pointerForward = function pointerForward() {
|
|
if (isSomeSelectable.value === false) return;
|
|
if (highlightedOriginalIndex.value === null) return;
|
|
var tempOriginalIndex = highlightedOriginalIndex.value + 1;
|
|
var safeCount = 0;
|
|
|
|
while (tempOriginalIndex !== highlightedOriginalIndex.value && safeCount++ < options.value.length) {
|
|
if (options.value.length <= tempOriginalIndex) tempOriginalIndex = 0;
|
|
if (pointerSet(tempOriginalIndex)) break;
|
|
++tempOriginalIndex;
|
|
}
|
|
};
|
|
|
|
var pointerBackward = function pointerBackward() {
|
|
if (isSomeSelectable.value === false) return;
|
|
if (highlightedOriginalIndex.value === null) return;
|
|
var tempOriginalIndex = highlightedOriginalIndex.value - 1;
|
|
var safeCount = 0;
|
|
|
|
while (tempOriginalIndex !== highlightedOriginalIndex.value && safeCount++ < options.value.length) {
|
|
if (tempOriginalIndex < 0) tempOriginalIndex = options.value.length - 1;
|
|
if (pointerSet(tempOriginalIndex)) break;
|
|
--tempOriginalIndex;
|
|
}
|
|
};
|
|
|
|
var originalIndexToOption = vue.computed(function () {
|
|
return options.value.reduce(function (acc, option) {
|
|
return Object.assign(acc, _defineProperty({}, option.originalIndex, option));
|
|
}, {});
|
|
});
|
|
|
|
var pointerSet = function pointerSet(originalIndex) {
|
|
var option = originalIndexToOption.value[originalIndex];
|
|
if (option === undefined) return false;
|
|
if (isSelectable(option) === false) return false;
|
|
highlightedOriginalIndex.value = originalIndex;
|
|
return true;
|
|
};
|
|
|
|
var isSelectable = function isSelectable(option) {
|
|
return !option.disabled && !option.hidden && option.visible;
|
|
};
|
|
|
|
var isSomeSelectable = vue.computed(function () {
|
|
return options.value.some(function (option) {
|
|
return isSelectable(option);
|
|
});
|
|
});
|
|
vue.watchEffect(function () {
|
|
if (isSomeSelectable.value === false) highlightedOriginalIndex.value = null;
|
|
|
|
if (highlightedOriginalIndex.value !== null && options.value.length <= highlightedOriginalIndex.value) {
|
|
var _iterator = _createForOfIteratorHelper(options.value.reverse()),
|
|
_step;
|
|
|
|
try {
|
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
var option = _step.value;
|
|
if (pointerSet(option.originalIndex)) break;
|
|
}
|
|
} catch (err) {
|
|
_iterator.e(err);
|
|
} finally {
|
|
_iterator.f();
|
|
}
|
|
}
|
|
|
|
if (highlightedOriginalIndex.value === null || isSelectable(options.value[highlightedOriginalIndex.value]) === false) {
|
|
var _iterator2 = _createForOfIteratorHelper(options.value),
|
|
_step2;
|
|
|
|
try {
|
|
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
var _option = _step2.value;
|
|
if (pointerSet(_option.originalIndex)) break;
|
|
}
|
|
} catch (err) {
|
|
_iterator2.e(err);
|
|
} finally {
|
|
_iterator2.f();
|
|
}
|
|
}
|
|
});
|
|
return {
|
|
pointerForward: pointerForward,
|
|
pointerBackward: pointerBackward,
|
|
pointerSet: pointerSet
|
|
};
|
|
};
|
|
|
|
var version = "2.10.4";
|
|
|
|
function escapeRegExp(pattern) {
|
|
// $& means the whole matched string
|
|
return pattern.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
}
|
|
|
|
var VueSelect = vue.defineComponent({
|
|
name: 'vue-select',
|
|
inheritAttrs: false,
|
|
props: {
|
|
// modelValue
|
|
modelValue: {
|
|
required: true
|
|
},
|
|
// TODO: default to `undefined` in next major version
|
|
// https://github.com/vuejs/vue-next/issues/3744
|
|
emptyModelValue: {},
|
|
// options
|
|
options: {
|
|
required: true,
|
|
type: Array
|
|
},
|
|
// TODO: default to `'label'` in next major version
|
|
labelBy: {
|
|
type: [String, Function]
|
|
},
|
|
// TODO: default to `'value'` in next major version
|
|
valueBy: {
|
|
type: [String, Function]
|
|
},
|
|
disabledBy: {
|
|
"default": 'disabled',
|
|
type: [String, Function]
|
|
},
|
|
groupBy: {
|
|
"default": 'group',
|
|
type: [String, Function]
|
|
},
|
|
// TODO: default to `undefined` in next major version
|
|
visibleOptions: {
|
|
type: Array,
|
|
"default": null
|
|
},
|
|
// multiple
|
|
multiple: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
min: {
|
|
"default": 0,
|
|
type: Number
|
|
},
|
|
max: {
|
|
"default": Infinity,
|
|
type: Number
|
|
},
|
|
// search
|
|
searchable: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
searchPlaceholder: {
|
|
"default": 'Type to search',
|
|
type: String
|
|
},
|
|
clearOnSelect: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
clearOnClose: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
// tag
|
|
taggable: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
collapseTags: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
// misc
|
|
autocomplete: {
|
|
"default": 'off',
|
|
type: String
|
|
},
|
|
disabled: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
loading: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
closeOnSelect: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
hideSelected: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
placeholder: {
|
|
"default": 'Select option',
|
|
type: String
|
|
},
|
|
tabindex: {
|
|
"default": 0,
|
|
type: Number
|
|
},
|
|
autofocus: {
|
|
"default": false,
|
|
type: Boolean
|
|
},
|
|
maxHeight: {
|
|
"default": 300,
|
|
type: Number
|
|
},
|
|
openDirection: {
|
|
type: String,
|
|
validator: function validator(value) {
|
|
return ['top', 'bottom'].includes(value);
|
|
}
|
|
}
|
|
},
|
|
emits: ['selected', 'removed', 'update:modelValue', 'focus', 'blur', 'toggle', // TODO: remove use `opened` in next major version
|
|
'opened', // TODO: remove use `opened` in next major version
|
|
'closed', 'search:input', 'search:change', 'search:focus', 'search:blur'],
|
|
setup: function setup(props, context) {
|
|
var normalized = normalize(props);
|
|
var normalizedEmptyModelValue = vue.computed(function () {
|
|
var _a;
|
|
|
|
return (_a = props.emptyModelValue) !== null && _a !== void 0 ? _a : null;
|
|
});
|
|
var instance = vue.getCurrentInstance();
|
|
var wrapper = vue.ref();
|
|
var dropdown = vue.ref();
|
|
var input = vue.ref();
|
|
var inputEl = vue.computed(function () {
|
|
var _a;
|
|
|
|
return (_a = input.value) === null || _a === void 0 ? void 0 : _a._.refs.input;
|
|
});
|
|
var isFocusing = vue.ref(false);
|
|
vue.watch(function () {
|
|
return isFocusing.value;
|
|
}, function () {
|
|
var _a, _b;
|
|
|
|
if (isFocusing.value) {
|
|
context.emit('opened');
|
|
context.emit('focus');
|
|
|
|
if (props.searchable) {
|
|
if (inputEl.value !== document.activeElement) {
|
|
inputEl.value.focus();
|
|
}
|
|
|
|
context.emit('search:focus');
|
|
} else {
|
|
(_a = wrapper.value) === null || _a === void 0 ? void 0 : _a.focus();
|
|
}
|
|
} else {
|
|
if (props.searchable) {
|
|
if (inputEl.value === document.activeElement) {
|
|
inputEl.value.blur();
|
|
}
|
|
|
|
if (props.clearOnClose) clearInput();
|
|
context.emit('search:blur');
|
|
} else {
|
|
(_b = wrapper.value) === null || _b === void 0 ? void 0 : _b.blur();
|
|
}
|
|
|
|
context.emit('closed');
|
|
context.emit('blur');
|
|
}
|
|
|
|
context.emit('toggle');
|
|
});
|
|
|
|
var focus = function focus() {
|
|
if (props.disabled) return;
|
|
isFocusing.value = true;
|
|
};
|
|
|
|
var blur = function blur(e) {
|
|
var _a;
|
|
|
|
if ((_a = wrapper.value) === null || _a === void 0 ? void 0 : _a.contains(e === null || e === void 0 ? void 0 : e.relatedTarget)) {
|
|
setTimeout(function () {
|
|
var _a;
|
|
|
|
(_a = wrapper.value) === null || _a === void 0 ? void 0 : _a.focus();
|
|
});
|
|
return;
|
|
}
|
|
|
|
isFocusing.value = false;
|
|
};
|
|
|
|
var toggle = function toggle() {
|
|
if (isFocusing.value) blur();else focus();
|
|
};
|
|
|
|
vue.watch(function () {
|
|
return props.disabled;
|
|
}, function () {
|
|
return blur();
|
|
}); // input
|
|
|
|
var searchingInputValue = vue.ref('');
|
|
|
|
var handleInputForInput = function handleInputForInput(event) {
|
|
context.emit('search:input', event);
|
|
};
|
|
|
|
var handleChangeForInput = function handleChangeForInput(event) {
|
|
context.emit('search:change', event);
|
|
};
|
|
|
|
var handleFocusForInput = function handleFocusForInput(event) {
|
|
focus();
|
|
};
|
|
|
|
var handleBlurForInput = function handleBlurForInput(event) {
|
|
blur();
|
|
};
|
|
|
|
var searchRe = vue.computed(function () {
|
|
return new RegExp(escapeRegExp(searchingInputValue.value), 'i');
|
|
});
|
|
var searchedOptions = vue.computed(function () {
|
|
return searchingInputValue.value ? normalized.options.filter(function (option) {
|
|
return searchRe.value.test(normalized.labelBy(option));
|
|
}) : undefined;
|
|
}); // sync model value
|
|
|
|
var normalizedModelValue = vue.ref([]);
|
|
var selectedValueSet = vue.computed(function () {
|
|
return new Set(normalizedModelValue.value.map(function (option) {
|
|
return normalized.valueBy(option);
|
|
}));
|
|
});
|
|
|
|
var isSynchronoused = function isSynchronoused() {
|
|
if (props.multiple) {
|
|
if (Array.isArray(props.modelValue) === false) return false;
|
|
if (normalizedModelValue.value.length !== props.modelValue.length) return false;
|
|
if (Object.keys(normalizedModelValue.value).some(function (index) {
|
|
return normalizedModelValue.value[index] !== getOptionByValue(normalized.options, props.modelValue[index], {
|
|
valueBy: normalized.valueBy
|
|
});
|
|
})) return false;
|
|
} else {
|
|
if (normalizedModelValue.value.length === 0 && props.modelValue !== normalizedEmptyModelValue.value) return false;
|
|
if (normalizedModelValue.value.length === 1 && props.modelValue === normalizedEmptyModelValue.value) return false;
|
|
if (normalizedModelValue.value[0] !== getOptionByValue(normalized.options, props.modelValue, {
|
|
valueBy: normalized.valueBy
|
|
})) return false;
|
|
}
|
|
|
|
return true;
|
|
};
|
|
|
|
var syncFromModelValue = function syncFromModelValue() {
|
|
if (isSynchronoused()) return;
|
|
normalizedModelValue.value = [];
|
|
var modelValue = props.multiple ? props.modelValue : props.modelValue === normalizedEmptyModelValue.value ? [] : [props.modelValue];
|
|
|
|
var _iterator = _createForOfIteratorHelper(modelValue),
|
|
_step;
|
|
|
|
try {
|
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
var value = _step.value;
|
|
var option = getOptionByValue(normalized.options, value, {
|
|
valueBy: normalized.valueBy
|
|
}); // guarantee options has modelValue
|
|
|
|
if (hasOption(normalized.options, option, {
|
|
valueBy: normalized.valueBy
|
|
}) === false) continue;
|
|
normalizedModelValue.value = addOption(normalizedModelValue.value, option, {
|
|
max: Infinity,
|
|
valueBy: normalized.valueBy
|
|
});
|
|
}
|
|
} catch (err) {
|
|
_iterator.e(err);
|
|
} finally {
|
|
_iterator.f();
|
|
}
|
|
};
|
|
|
|
syncFromModelValue();
|
|
vue.watch(function () {
|
|
return props.modelValue;
|
|
}, function () {
|
|
return syncFromModelValue();
|
|
}, {
|
|
deep: true
|
|
}); // guarantee options has modelValue
|
|
|
|
vue.watch(function () {
|
|
return normalized.options;
|
|
}, function () {
|
|
normalizedModelValue.value = normalized.options.filter(function (option) {
|
|
return selectedValueSet.value.has(normalized.valueBy(option));
|
|
});
|
|
}, {
|
|
deep: true
|
|
});
|
|
|
|
var addOrRemoveOption = function addOrRemoveOption(event, option) {
|
|
if (props.disabled) return; // TODO: hot spot, improve performance
|
|
|
|
if (option.group && props.multiple) addOrRemoveOptionForGroupOption(event, option);else addOrRemoveOptionForNonGroupOption(event, option);
|
|
syncToModelValue();
|
|
if (props.closeOnSelect === true) isFocusing.value = false;
|
|
if (props.clearOnSelect === true && searchingInputValue.value) clearInput();
|
|
};
|
|
|
|
var addOrRemoveOptionForGroupOption = function addOrRemoveOptionForGroupOption(event, option) {
|
|
option = option.originalOption;
|
|
var has = option.value.every(function (value) {
|
|
var option = getOptionByValue(normalized.options, value, {
|
|
valueBy: normalized.valueBy
|
|
});
|
|
return hasOption(normalizedModelValue.value, option, {
|
|
valueBy: normalized.valueBy
|
|
});
|
|
});
|
|
|
|
if (has) {
|
|
option.value.forEach(function (value) {
|
|
var option = getOptionByValue(normalized.options, value, {
|
|
valueBy: normalized.valueBy
|
|
});
|
|
normalizedModelValue.value = removeOption(normalizedModelValue.value, option, {
|
|
min: normalized.min,
|
|
valueBy: normalized.valueBy
|
|
});
|
|
context.emit('removed', option);
|
|
});
|
|
} else {
|
|
option.value.forEach(function (value) {
|
|
var option = getOptionByValue(normalized.options, value, {
|
|
valueBy: normalized.valueBy
|
|
});
|
|
if (hasOption(normalizedModelValue.value, option, {
|
|
valueBy: normalized.valueBy
|
|
})) return;
|
|
normalizedModelValue.value = addOption(normalizedModelValue.value, option, {
|
|
max: normalized.max,
|
|
valueBy: normalized.valueBy
|
|
});
|
|
context.emit('selected', option);
|
|
});
|
|
}
|
|
};
|
|
|
|
var addOrRemoveOptionForNonGroupOption = function addOrRemoveOptionForNonGroupOption(event, option) {
|
|
option = option.originalOption;
|
|
|
|
if (hasOption(normalizedModelValue.value, option, {
|
|
valueBy: normalized.valueBy
|
|
})) {
|
|
normalizedModelValue.value = removeOption(normalizedModelValue.value, option, {
|
|
min: normalized.min,
|
|
valueBy: normalized.valueBy
|
|
});
|
|
context.emit('removed', option);
|
|
} else {
|
|
if (!props.multiple && normalizedModelValue.value.length === 1) {
|
|
var removingOption = normalizedModelValue.value[0];
|
|
normalizedModelValue.value = removeOption(normalizedModelValue.value, normalizedModelValue.value[0], {
|
|
min: 0,
|
|
valueBy: normalized.valueBy
|
|
});
|
|
context.emit('removed', removingOption);
|
|
}
|
|
|
|
normalizedModelValue.value = addOption(normalizedModelValue.value, option, {
|
|
max: normalized.max,
|
|
valueBy: normalized.valueBy
|
|
});
|
|
context.emit('selected', option);
|
|
}
|
|
};
|
|
|
|
var syncToModelValue = function syncToModelValue() {
|
|
if (isSynchronoused()) return;
|
|
var selectedValues = normalizedModelValue.value.map(function (option) {
|
|
return normalized.valueBy(option);
|
|
});
|
|
|
|
if (props.multiple) {
|
|
context.emit('update:modelValue', selectedValues);
|
|
} else {
|
|
if (selectedValues.length) context.emit('update:modelValue', selectedValues[0]);else context.emit('update:modelValue', normalizedEmptyModelValue.value);
|
|
}
|
|
};
|
|
|
|
var clearInput = function clearInput() {
|
|
// simulate clear input value
|
|
inputEl.value.value = '';
|
|
inputEl.value.dispatchEvent(new Event('input'));
|
|
inputEl.value.dispatchEvent(new Event('change'));
|
|
};
|
|
|
|
var renderedOptions = vue.computed(function () {
|
|
var _a, _b;
|
|
|
|
return (_b = (_a = props.visibleOptions) !== null && _a !== void 0 ? _a : searchedOptions.value) !== null && _b !== void 0 ? _b : normalized.options;
|
|
});
|
|
var highlightedOriginalIndex = vue.ref(0);
|
|
var optionsWithInfo = vue.computed(function () {
|
|
var visibleValueSet = new Set(renderedOptions.value.map(function (option) {
|
|
return normalized.valueBy(option);
|
|
}));
|
|
var optionsWithInfo = normalized.options.map(function (option, index) {
|
|
var _a;
|
|
|
|
var optionWithInfo = {
|
|
key: normalized.valueBy(option),
|
|
label: normalized.labelBy(option),
|
|
// selected: selectedValueSet.value.has(normalized.valueBy(option)),
|
|
// disabled: normalized.disabledBy(option),
|
|
group: (_a = normalized.groupBy(option)) !== null && _a !== void 0 ? _a : false,
|
|
// visible: visibleValueSet.has(normalized.valueBy(option)),
|
|
// hidden: props.hideSelected ? selectedValueSet.value.has(normalized.valueBy(option)) : false,
|
|
originalIndex: index,
|
|
originalOption: option
|
|
};
|
|
optionWithInfo.selected = optionWithInfo.group ? option.value.every(function (value) {
|
|
return selectedValueSet.value.has(value);
|
|
}) : selectedValueSet.value.has(normalized.valueBy(option));
|
|
optionWithInfo.disabled = optionWithInfo.group ? normalized.disabledBy(option) || option.value.every(function (value) {
|
|
var option = getOptionByValue(normalized.options, value, {
|
|
valueBy: normalized.valueBy
|
|
});
|
|
return normalized.disabledBy(option);
|
|
}) : normalized.disabledBy(option);
|
|
optionWithInfo.visible = optionWithInfo.group ? option.value.some(function (value) {
|
|
return visibleValueSet.has(value);
|
|
}) : visibleValueSet.has(normalized.valueBy(option));
|
|
optionWithInfo.hidden = props.hideSelected ? optionWithInfo.group ? option.value.every(function (value) {
|
|
return selectedValueSet.value.has(value);
|
|
}) : selectedValueSet.value.has(normalized.valueBy(option)) : false;
|
|
return optionWithInfo;
|
|
});
|
|
|
|
var _iterator2 = _createForOfIteratorHelper(optionsWithInfo),
|
|
_step2;
|
|
|
|
try {
|
|
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
var option = _step2.value;
|
|
if (option.group === false) continue;
|
|
|
|
if (option.disabled) {
|
|
(function () {
|
|
var values = new Set(option.originalOption.value);
|
|
optionsWithInfo.filter(function (optionWithInfo) {
|
|
return values.has(normalized.valueBy(optionWithInfo.originalOption));
|
|
}).forEach(function (optionWithInfo) {
|
|
return optionWithInfo.disabled = true;
|
|
});
|
|
})();
|
|
}
|
|
}
|
|
} catch (err) {
|
|
_iterator2.e(err);
|
|
} finally {
|
|
_iterator2.f();
|
|
}
|
|
|
|
return optionsWithInfo;
|
|
});
|
|
|
|
var _usePointer = usePointer(optionsWithInfo, highlightedOriginalIndex),
|
|
_pointerForward = _usePointer.pointerForward,
|
|
_pointerBackward = _usePointer.pointerBackward,
|
|
pointerSet = _usePointer.pointerSet;
|
|
|
|
var pointerForward = function pointerForward() {
|
|
_pointerForward();
|
|
|
|
vue.nextTick(updateScrollTop);
|
|
};
|
|
|
|
var pointerBackward = function pointerBackward() {
|
|
_pointerBackward();
|
|
|
|
vue.nextTick(updateScrollTop);
|
|
};
|
|
|
|
var pointerFirst = function pointerFirst() {
|
|
var _iterator3 = _createForOfIteratorHelper(normalized.options.keys()),
|
|
_step3;
|
|
|
|
try {
|
|
for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
|
|
var index = _step3.value;
|
|
if (pointerSet(index)) break;
|
|
}
|
|
} catch (err) {
|
|
_iterator3.e(err);
|
|
} finally {
|
|
_iterator3.f();
|
|
}
|
|
|
|
vue.nextTick(updateScrollTop);
|
|
};
|
|
|
|
var pointerLast = function pointerLast() {
|
|
var _iterator4 = _createForOfIteratorHelper(_toConsumableArray(normalized.options.keys()).reverse()),
|
|
_step4;
|
|
|
|
try {
|
|
for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
|
|
var index = _step4.value;
|
|
if (pointerSet(index)) break;
|
|
}
|
|
} catch (err) {
|
|
_iterator4.e(err);
|
|
} finally {
|
|
_iterator4.f();
|
|
}
|
|
|
|
vue.nextTick(updateScrollTop);
|
|
};
|
|
|
|
var recentTypedChars = '';
|
|
var timerForClearingRecentTypedChars;
|
|
var alphanumRe = /^[\w]$/;
|
|
var sortedOriginalIndexBaseOnHighlighted = vue.computed(function () {
|
|
var indexes = _toConsumableArray(normalized.options.keys());
|
|
|
|
return indexes.slice(highlightedOriginalIndex.value).concat(indexes.slice(0, highlightedOriginalIndex.value));
|
|
});
|
|
|
|
var typeAhead = function typeAhead(event) {
|
|
var _a, _b;
|
|
|
|
if (props.searchable) return;
|
|
var changed = false;
|
|
|
|
if (alphanumRe.test(event.key)) {
|
|
recentTypedChars += event.key.toLowerCase();
|
|
changed = true;
|
|
} else if (event.code === 'Space') {
|
|
recentTypedChars += ' ';
|
|
}
|
|
|
|
if (changed) {
|
|
var _iterator5 = _createForOfIteratorHelper(sortedOriginalIndexBaseOnHighlighted.value),
|
|
_step5;
|
|
|
|
try {
|
|
for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
|
|
var index = _step5.value;
|
|
if (((_b = (_a = normalized.labelBy(normalized.options[index])) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === null || _b === void 0 ? void 0 : _b.startsWith(recentTypedChars)) !== true) continue;
|
|
if (pointerSet(index)) break;
|
|
}
|
|
} catch (err) {
|
|
_iterator5.e(err);
|
|
} finally {
|
|
_iterator5.f();
|
|
}
|
|
|
|
clearTimeout(timerForClearingRecentTypedChars);
|
|
timerForClearingRecentTypedChars = setTimeout(function () {
|
|
recentTypedChars = '';
|
|
}, 500);
|
|
}
|
|
};
|
|
|
|
var updateScrollTop = function updateScrollTop() {
|
|
var _a;
|
|
|
|
var highlightedEl = (_a = wrapper.value) === null || _a === void 0 ? void 0 : _a.querySelector('.highlighted');
|
|
if (!highlightedEl) return;
|
|
if (!dropdown.value) return;
|
|
var computedStyle = getComputedStyle(highlightedEl);
|
|
var safeCount;
|
|
safeCount = 0;
|
|
|
|
while (highlightedEl.offsetTop + parseFloat(computedStyle.height) + parseFloat(computedStyle.paddingTop) + parseFloat(computedStyle.paddingBottom) > dropdown.value.$el.clientHeight + dropdown.value.$el.scrollTop && safeCount++ < optionsWithInfo.value.length) {
|
|
dropdown.value.$el.scrollTop = dropdown.value.$el.scrollTop + parseFloat(computedStyle.height) + parseFloat(computedStyle.paddingTop) + parseFloat(computedStyle.paddingBottom);
|
|
}
|
|
|
|
safeCount = 0;
|
|
|
|
while (highlightedEl.offsetTop < dropdown.value.$el.scrollTop && safeCount++ < optionsWithInfo.value.length) {
|
|
dropdown.value.$el.scrollTop = dropdown.value.$el.scrollTop - parseFloat(computedStyle.height) - parseFloat(computedStyle.paddingTop) - parseFloat(computedStyle.paddingBottom);
|
|
}
|
|
};
|
|
|
|
vue.watch(function () {
|
|
return [isFocusing.value, normalized.options, selectedValueSet.value];
|
|
}, function (_, oldValue) {
|
|
if ((oldValue === null || oldValue === void 0 ? void 0 : oldValue[0]) === true) return;
|
|
if (isFocusing.value === false) return;
|
|
if (normalizedModelValue.value.length === 0) return;
|
|
pointerSet(normalized.options.findIndex(function (option) {
|
|
return selectedValueSet.value.has(normalized.valueBy(option));
|
|
}));
|
|
vue.nextTick(updateScrollTop);
|
|
}, {
|
|
deep: true,
|
|
immediate: true
|
|
});
|
|
var dataAttrs = vue.computed(function () {
|
|
return {
|
|
'data-is-focusing': isFocusing.value,
|
|
'data-visible-length': optionsWithInfo.value.filter(function (option) {
|
|
return option.visible && option.hidden === false;
|
|
}).length,
|
|
'data-not-selected-length': normalized.options.length - optionsWithInfo.value.filter(function (option) {
|
|
return option.selected;
|
|
}).length,
|
|
'data-selected-length': optionsWithInfo.value.filter(function (option) {
|
|
return option.selected;
|
|
}).length,
|
|
'data-addable': optionsWithInfo.value.filter(function (option) {
|
|
return option.selected;
|
|
}).length < normalized.max,
|
|
'data-removable': optionsWithInfo.value.filter(function (option) {
|
|
return option.selected;
|
|
}).length > normalized.min,
|
|
'data-total-length': normalized.options.length,
|
|
'data-multiple': props.multiple,
|
|
'data-loading': props.loading,
|
|
'data-disabled': props.disabled
|
|
};
|
|
});
|
|
vue.provide('dataAttrs', dataAttrs);
|
|
var selectedOptions = vue.computed(function () {
|
|
return optionsWithInfo.value.filter(function (option) {
|
|
return option.selected;
|
|
}).filter(function (option) {
|
|
return !option.group;
|
|
});
|
|
});
|
|
var innerPlaceholder = vue.computed(function () {
|
|
if (props.multiple) {
|
|
if (selectedOptions.value.length === 0) {
|
|
return props.placeholder;
|
|
} else if (selectedOptions.value.length === 1) {
|
|
return '1 option selected';
|
|
} else {
|
|
return selectedOptions.value.length + ' options selected';
|
|
}
|
|
} else {
|
|
if (selectedOptions.value.length === 0) {
|
|
return props.placeholder;
|
|
} else {
|
|
return selectedOptions.value[0].label + '';
|
|
}
|
|
}
|
|
});
|
|
var selected = vue.computed(function () {
|
|
var selected = selectedOptions.value.map(function (option) {
|
|
return option.originalOption;
|
|
});
|
|
if (props.multiple) return selected;
|
|
return selected[0] || normalizedEmptyModelValue.value;
|
|
});
|
|
var direction = vue.ref();
|
|
vue.watch(function () {
|
|
return [props.openDirection, isFocusing.value];
|
|
}, function () {
|
|
var _a, _b;
|
|
|
|
direction.value = (_b = (_a = props.openDirection) !== null && _a !== void 0 ? _a : calcPreferredDirection()) !== null && _b !== void 0 ? _b : 'bottom';
|
|
}, {
|
|
immediate: true
|
|
});
|
|
|
|
function calcPreferredDirection() {
|
|
if (wrapper.value === undefined) return;
|
|
if (window === undefined) return;
|
|
var spaceBelow = window.innerHeight - wrapper.value.getBoundingClientRect().bottom;
|
|
var hasEnoughSpaceBelow = spaceBelow >= props.maxHeight;
|
|
return hasEnoughSpaceBelow ? 'bottom' : 'top';
|
|
}
|
|
|
|
return {
|
|
instance: instance,
|
|
isFocusing: isFocusing,
|
|
wrapper: wrapper,
|
|
dropdown: dropdown,
|
|
input: input,
|
|
focus: focus,
|
|
blur: blur,
|
|
toggle: toggle,
|
|
searchingInputValue: searchingInputValue,
|
|
handleInputForInput: handleInputForInput,
|
|
handleChangeForInput: handleChangeForInput,
|
|
handleFocusForInput: handleFocusForInput,
|
|
handleBlurForInput: handleBlurForInput,
|
|
optionsWithInfo: optionsWithInfo,
|
|
addOrRemoveOption: addOrRemoveOption,
|
|
dataAttrs: dataAttrs,
|
|
innerPlaceholder: innerPlaceholder,
|
|
selected: selected,
|
|
highlightedOriginalIndex: highlightedOriginalIndex,
|
|
pointerForward: pointerForward,
|
|
pointerBackward: pointerBackward,
|
|
pointerFirst: pointerFirst,
|
|
pointerLast: pointerLast,
|
|
typeAhead: typeAhead,
|
|
pointerSet: pointerSet,
|
|
direction: direction
|
|
};
|
|
},
|
|
components: {
|
|
VInput: script$2,
|
|
VTags: script$1,
|
|
VDropdown: script
|
|
}
|
|
});
|
|
VueSelect.__VERSION__ = version;
|
|
|
|
var _imports_0 = '';
|
|
|
|
var _hoisted_1 = ["tabindex", "id", "role", "aria-expanded", "aria-owns", "aria-activedescendant", "aria-busy", "aria-disabled"];
|
|
var _hoisted_2 = {
|
|
"class": "vue-select-header"
|
|
};
|
|
var _hoisted_3 = {
|
|
key: 0,
|
|
"class": "vue-input"
|
|
};
|
|
var _hoisted_4 = ["placeholder", "autocomplete"];
|
|
var _hoisted_5 = ["onClick"];
|
|
|
|
var _hoisted_6 = /*#__PURE__*/vue.createElementVNode("span", {
|
|
"class": "icon loading"
|
|
}, [/*#__PURE__*/vue.createElementVNode("div"), /*#__PURE__*/vue.createElementVNode("div"), /*#__PURE__*/vue.createElementVNode("div")], -1
|
|
/* HOISTED */
|
|
);
|
|
|
|
var _hoisted_7 = {
|
|
key: 0,
|
|
"class": "vue-select-input-wrapper"
|
|
};
|
|
|
|
var _hoisted_8 = /*#__PURE__*/vue.createElementVNode("span", {
|
|
"class": "icon loading"
|
|
}, [/*#__PURE__*/vue.createElementVNode("div"), /*#__PURE__*/vue.createElementVNode("div"), /*#__PURE__*/vue.createElementVNode("div")], -1
|
|
/* HOISTED */
|
|
);
|
|
|
|
function render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
var _component_v_tags = vue.resolveComponent("v-tags");
|
|
|
|
var _component_v_input = vue.resolveComponent("v-input");
|
|
|
|
var _component_v_dropdown = vue.resolveComponent("v-dropdown");
|
|
|
|
return vue.openBlock(), vue.createElementBlock("div", vue.mergeProps({
|
|
ref: "wrapper",
|
|
"class": ["vue-select", ["direction-".concat(_ctx.direction)]],
|
|
tabindex: _ctx.isFocusing ? -1 : _ctx.tabindex,
|
|
onFocus: _cache[9] || (_cache[9] = function () {
|
|
return _ctx.focus && _ctx.focus.apply(_ctx, arguments);
|
|
}),
|
|
onBlur: _cache[10] || (_cache[10] = function (e) {
|
|
return _ctx.searchable ? false : _ctx.blur(e);
|
|
})
|
|
}, Object.assign({}, _ctx.dataAttrs, _ctx.$attrs), {
|
|
onKeypress: _cache[11] || (_cache[11] = vue.withKeys(vue.withModifiers(function () {
|
|
return _ctx.highlightedOriginalIndex !== null && _ctx.addOrRemoveOption(_ctx.$event, _ctx.optionsWithInfo[_ctx.highlightedOriginalIndex]);
|
|
}, ["prevent", "exact"]), ["enter"])),
|
|
onKeydown: [_cache[12] || (_cache[12] = vue.withKeys(vue.withModifiers(function () {
|
|
return _ctx.pointerForward && _ctx.pointerForward.apply(_ctx, arguments);
|
|
}, ["prevent", "exact"]), ["down"])), _cache[13] || (_cache[13] = vue.withKeys(vue.withModifiers(function () {
|
|
return _ctx.pointerBackward && _ctx.pointerBackward.apply(_ctx, arguments);
|
|
}, ["prevent", "exact"]), ["up"])), _cache[14] || (_cache[14] = vue.withKeys(vue.withModifiers(function () {
|
|
return _ctx.pointerFirst && _ctx.pointerFirst.apply(_ctx, arguments);
|
|
}, ["prevent", "exact"]), ["home"])), _cache[15] || (_cache[15] = vue.withKeys(vue.withModifiers(function () {
|
|
return _ctx.pointerLast && _ctx.pointerLast.apply(_ctx, arguments);
|
|
}, ["prevent", "exact"]), ["end"])), _cache[16] || (_cache[16] = function () {
|
|
return _ctx.typeAhead && _ctx.typeAhead.apply(_ctx, arguments);
|
|
})],
|
|
id: "vs".concat(_ctx.instance.uid, "-combobox"),
|
|
role: _ctx.searchable ? 'combobox' : null,
|
|
"aria-expanded": _ctx.isFocusing,
|
|
"aria-haspopup": "listbox",
|
|
"aria-owns": "vs".concat(_ctx.instance.uid, "-listbox"),
|
|
"aria-activedescendant": _ctx.highlightedOriginalIndex === null ? null : "vs".concat(_ctx.instance.uid, "-option-").concat(_ctx.highlightedOriginalIndex),
|
|
"aria-busy": _ctx.loading,
|
|
"aria-disabled": _ctx.disabled
|
|
}), [vue.createElementVNode("div", _hoisted_2, [_ctx.multiple && _ctx.taggable && _ctx.modelValue.length === 0 || _ctx.searchable === false && _ctx.taggable === false ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3, [vue.renderSlot(_ctx.$slots, "label", {
|
|
selected: _ctx.selected
|
|
}, function () {
|
|
return [vue.createElementVNode("input", {
|
|
placeholder: _ctx.innerPlaceholder,
|
|
autocomplete: _ctx.autocomplete,
|
|
readonly: "",
|
|
onClick: _cache[0] || (_cache[0] = function () {
|
|
return _ctx.focus && _ctx.focus.apply(_ctx, arguments);
|
|
})
|
|
}, null, 8
|
|
/* PROPS */
|
|
, _hoisted_4)];
|
|
})])) : vue.createCommentVNode("v-if", true), _ctx.multiple && _ctx.taggable ? (vue.openBlock(), vue.createElementBlock(vue.Fragment, {
|
|
key: 1
|
|
}, [vue.createVNode(_component_v_tags, {
|
|
modelValue: _ctx.optionsWithInfo,
|
|
"collapse-tags": _ctx.collapseTags,
|
|
tabindex: "-1",
|
|
onClick: _ctx.focus
|
|
}, {
|
|
"default": vue.withCtx(function (_ref) {
|
|
var option = _ref.option;
|
|
return [vue.renderSlot(_ctx.$slots, "tag", {
|
|
option: option.originalOption,
|
|
remove: function remove() {
|
|
return _ctx.addOrRemoveOption(_ctx.$event, option);
|
|
}
|
|
}, function () {
|
|
return [vue.createElementVNode("span", null, vue.toDisplayString(option.label), 1
|
|
/* TEXT */
|
|
), vue.createElementVNode("img", {
|
|
src: _imports_0,
|
|
alt: "delete tag",
|
|
"class": "icon delete",
|
|
onClick: vue.withModifiers(function () {
|
|
return _ctx.addOrRemoveOption(_ctx.$event, option);
|
|
}, ["prevent", "stop"])
|
|
}, null, 8
|
|
/* PROPS */
|
|
, _hoisted_5)];
|
|
})];
|
|
}),
|
|
_: 3
|
|
/* FORWARDED */
|
|
|
|
}, 8
|
|
/* PROPS */
|
|
, ["modelValue", "collapse-tags", "onClick"]), vue.renderSlot(_ctx.$slots, "toggle", {
|
|
isFocusing: _ctx.isFocusing,
|
|
toggle: _ctx.toggle
|
|
}, function () {
|
|
return [vue.createElementVNode("span", {
|
|
"class": vue.normalizeClass(["icon arrow-downward", {
|
|
active: _ctx.isFocusing
|
|
}]),
|
|
onClick: _cache[1] || (_cache[1] = function () {
|
|
return _ctx.toggle && _ctx.toggle.apply(_ctx, arguments);
|
|
}),
|
|
onMousedown: _cache[2] || (_cache[2] = vue.withModifiers(function () {}, ["prevent", "stop"]))
|
|
}, null, 34
|
|
/* CLASS, HYDRATE_EVENTS */
|
|
)];
|
|
})], 64
|
|
/* STABLE_FRAGMENT */
|
|
)) : (vue.openBlock(), vue.createElementBlock(vue.Fragment, {
|
|
key: 2
|
|
}, [_ctx.searchable ? (vue.openBlock(), vue.createBlock(_component_v_input, {
|
|
key: 0,
|
|
ref: "input",
|
|
modelValue: _ctx.searchingInputValue,
|
|
"onUpdate:modelValue": _cache[3] || (_cache[3] = function ($event) {
|
|
return _ctx.searchingInputValue = $event;
|
|
}),
|
|
disabled: _ctx.disabled,
|
|
autocomplete: _ctx.autocomplete,
|
|
placeholder: _ctx.isFocusing ? _ctx.searchPlaceholder : _ctx.innerPlaceholder,
|
|
onInput: _ctx.handleInputForInput,
|
|
onChange: _ctx.handleChangeForInput,
|
|
onFocus: _ctx.handleFocusForInput,
|
|
onBlur: _ctx.handleBlurForInput,
|
|
onEscape: _ctx.blur,
|
|
autofocus: _ctx.autofocus || _ctx.taggable && _ctx.searchable,
|
|
tabindex: _ctx.tabindex,
|
|
comboboxUid: _ctx.instance.uid
|
|
}, null, 8
|
|
/* PROPS */
|
|
, ["modelValue", "disabled", "autocomplete", "placeholder", "onInput", "onChange", "onFocus", "onBlur", "onEscape", "autofocus", "tabindex", "comboboxUid"])) : vue.createCommentVNode("v-if", true), _ctx.loading ? vue.renderSlot(_ctx.$slots, "loading", {
|
|
key: 1
|
|
}, function () {
|
|
return [_hoisted_6];
|
|
}) : vue.renderSlot(_ctx.$slots, "toggle", {
|
|
key: 2,
|
|
isFocusing: _ctx.isFocusing,
|
|
toggle: _ctx.toggle
|
|
}, function () {
|
|
return [vue.createElementVNode("span", {
|
|
"class": vue.normalizeClass(["icon arrow-downward", {
|
|
active: _ctx.isFocusing
|
|
}]),
|
|
onClick: _cache[4] || (_cache[4] = function () {
|
|
return _ctx.toggle && _ctx.toggle.apply(_ctx, arguments);
|
|
}),
|
|
onMousedown: _cache[5] || (_cache[5] = vue.withModifiers(function () {}, ["prevent", "stop"]))
|
|
}, null, 34
|
|
/* CLASS, HYDRATE_EVENTS */
|
|
)];
|
|
})], 64
|
|
/* STABLE_FRAGMENT */
|
|
))]), _ctx.multiple && _ctx.taggable && _ctx.searchable ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_7, [vue.withDirectives(vue.createVNode(_component_v_input, {
|
|
ref: "input",
|
|
modelValue: _ctx.searchingInputValue,
|
|
"onUpdate:modelValue": _cache[6] || (_cache[6] = function ($event) {
|
|
return _ctx.searchingInputValue = $event;
|
|
}),
|
|
disabled: _ctx.disabled,
|
|
autocomplete: _ctx.autocomplete,
|
|
placeholder: _ctx.isFocusing ? _ctx.searchPlaceholder : _ctx.innerPlaceholder,
|
|
onInput: _ctx.handleInputForInput,
|
|
onChange: _ctx.handleChangeForInput,
|
|
onFocus: _ctx.handleFocusForInput,
|
|
onBlur: _ctx.handleBlurForInput,
|
|
onEscape: _ctx.blur,
|
|
autofocus: _ctx.autofocus || _ctx.taggable && _ctx.searchable,
|
|
tabindex: _ctx.tabindex,
|
|
comboboxUid: _ctx.instance.uid
|
|
}, null, 8
|
|
/* PROPS */
|
|
, ["modelValue", "disabled", "autocomplete", "placeholder", "onInput", "onChange", "onFocus", "onBlur", "onEscape", "autofocus", "tabindex", "comboboxUid"]), [[vue.vShow, _ctx.isFocusing]]), _ctx.loading ? vue.renderSlot(_ctx.$slots, "loading", {
|
|
key: 0
|
|
}, function () {
|
|
return [_hoisted_8];
|
|
}) : vue.createCommentVNode("v-if", true)])) : vue.createCommentVNode("v-if", true), vue.createVNode(_component_v_dropdown, {
|
|
ref: "dropdown",
|
|
modelValue: _ctx.optionsWithInfo,
|
|
"onUpdate:modelValue": _cache[7] || (_cache[7] = function ($event) {
|
|
return _ctx.optionsWithInfo = $event;
|
|
}),
|
|
onClickItem: _ctx.addOrRemoveOption,
|
|
onMouseenter: _cache[8] || (_cache[8] = function (ev, option) {
|
|
return _ctx.pointerSet(option.originalIndex);
|
|
}),
|
|
comboboxUid: _ctx.instance.uid,
|
|
maxHeight: _ctx.maxHeight,
|
|
highlightedOriginalIndex: _ctx.highlightedOriginalIndex
|
|
}, {
|
|
"default": vue.withCtx(function (_ref2) {
|
|
var option = _ref2.option;
|
|
return [vue.renderSlot(_ctx.$slots, "dropdown-item", {
|
|
option: option.originalOption
|
|
}, function () {
|
|
return [vue.createElementVNode("span", null, vue.toDisplayString(option.label), 1
|
|
/* TEXT */
|
|
)];
|
|
})];
|
|
}),
|
|
_: 3
|
|
/* FORWARDED */
|
|
|
|
}, 8
|
|
/* PROPS */
|
|
, ["modelValue", "onClickItem", "comboboxUid", "maxHeight", "highlightedOriginalIndex"])], 16
|
|
/* FULL_PROPS */
|
|
, _hoisted_1);
|
|
}
|
|
|
|
VueSelect.render = render;
|
|
VueSelect.__file = "src/index.vue";
|
|
|
|
return VueSelect;
|
|
|
|
})(Vue);
|