devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
208 lines (205 loc) • 6.88 kB
JavaScript
/**
* DevExtreme (cjs/__internal/ui/m_autocomplete.js)
* Version: 24.2.6
* Build date: Mon Mar 17 2025
*
* Copyright (c) 2012 - 2025 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _index = require("../../common/core/events/utils/index");
var _component_registrator = _interopRequireDefault(require("../../core/component_registrator"));
var _renderer = _interopRequireDefault(require("../../core/renderer"));
var _deferred = require("../../core/utils/deferred");
var _extend = require("../../core/utils/extend");
var _m_drop_down_list = _interopRequireDefault(require("../ui/drop_down_editor/m_drop_down_list"));
function _interopRequireDefault(e) {
return e && e.__esModule ? e : {
default: e
}
}
function _extends() {
return _extends = Object.assign ? Object.assign.bind() : function(n) {
for (var e = 1; e < arguments.length; e++) {
var t = arguments[e];
for (var r in t) {
({}).hasOwnProperty.call(t, r) && (n[r] = t[r])
}
}
return n
}, _extends.apply(null, arguments)
}
const AUTOCOMPLETE_CLASS = "dx-autocomplete";
const AUTOCOMPLETE_POPUP_WRAPPER_CLASS = "dx-autocomplete-popup-wrapper";
class Autocomplete extends _m_drop_down_list.default {
_supportedKeys() {
let item = this._list ? this._list.option("focusedElement") : null;
const parent = super._supportedKeys();
item = item && (0, _renderer.default)(item);
return _extends({}, parent, {
upArrow(e) {
if (parent.upArrow.apply(this, arguments) && !(0, _index.isCommandKeyPressed)(e)) {
e.preventDefault();
e.stopPropagation();
if (item && !this._calcNextItem(-1)) {
this._clearFocusedItem();
return false
}
}
return true
},
downArrow(e) {
if (parent.downArrow.apply(this, arguments) && !(0, _index.isCommandKeyPressed)(e)) {
e.preventDefault();
e.stopPropagation();
if (item && !this._calcNextItem(1)) {
this._clearFocusedItem();
return false
}
}
return true
},
enter(e) {
if (!item) {
this.close()
}
const {
opened: opened
} = this.option();
if (opened) {
e.preventDefault()
}
return opened
}
})
}
_getDefaultOptions() {
return _extends({}, super._getDefaultOptions(), {
minSearchLength: 1,
maxItemCount: 10,
noDataText: "",
showDropDownButton: false,
searchEnabled: true
})
}
_initMarkup() {
super._initMarkup();
this.$element().addClass("dx-autocomplete")
}
_getAriaAutocomplete() {
const {
disabled: disabled,
readOnly: readOnly
} = this.option();
const isInputEditable = !(readOnly || disabled);
return isInputEditable ? "list" : "none"
}
_displayGetterExpr() {
return this.option("valueExpr")
}
_closeOutsideDropDownHandler(_ref) {
let {
target: target
} = _ref;
return !(0, _renderer.default)(target).closest(this.$element()).length
}
_renderDimensions() {
super._renderDimensions();
this._updatePopupWidth();
this._updateListDimensions()
}
_popupWrapperClass() {
return `${super._popupWrapperClass()} dx-autocomplete-popup-wrapper`
}
_listConfig() {
return (0, _extend.extend)(super._listConfig(), {
pageLoadMode: "none",
onSelectionChanged: e => {
this._setSelectedItem(e.addedItems[0])
}
})
}
_listItemClickHandler(e) {
this._saveValueChangeEvent(e.event);
const value = this._displayGetter(e.itemData);
this.option("value", value);
this.close()
}
_setListDataSource() {
if (!this._list) {
return
}
this._list.option("selectedItems", []);
super._setListDataSource()
}
_refreshSelected() {}
_searchCanceled() {
super._searchCanceled();
this.close()
}
_loadItem(value, cache) {
const selectedItem = this._getItemFromPlain(value, cache);
return (0, _deferred.Deferred)().resolve(selectedItem).promise()
}
_dataSourceOptions() {
return {
paginate: true,
pageSize: this.option("maxItemCount")
}
}
_searchDataSource(searchValue) {
this._dataSource.pageSize(this.option("maxItemCount"));
super._searchDataSource(searchValue);
this._clearFocusedItem()
}
_clearFocusedItem() {
if (this._list) {
this._list.option("focusedElement", null);
this._list.option("selectedIndex", -1)
}
}
_renderValueEventName() {
return "input keyup"
}
_valueChangeEventHandler(e) {
const value = this._input().val() || null;
return super._valueChangeEventHandler(e, value)
}
_optionChanged(args) {
switch (args.name) {
case "readOnly":
case "disabled":
super._optionChanged(args);
this._setDefaultAria();
break;
case "maxItemCount":
this._searchDataSource();
break;
case "valueExpr":
this._compileDisplayGetter();
this._setListOption("displayExpr", this._displayGetterExpr());
super._optionChanged(args);
break;
default:
super._optionChanged(args)
}
}
clear() {
super.clear();
this.close()
}
reset() {
let value = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : void 0;
if (arguments.length) {
super.reset(value)
} else {
super.reset()
}
this.close()
}
}(0, _component_registrator.default)("dxAutocomplete", Autocomplete);
var _default = exports.default = Autocomplete;