fix: #7026, Select: Editable Dropdown search not working as expected
parent
aec97b279e
commit
aa3f5c0c5a
|
@ -798,7 +798,10 @@ export default {
|
||||||
hasFocusableElements() {
|
hasFocusableElements() {
|
||||||
return getFocusableElements(this.overlay, ':not([data-p-hidden-focusable="true"])').length > 0;
|
return getFocusableElements(this.overlay, ':not([data-p-hidden-focusable="true"])').length > 0;
|
||||||
},
|
},
|
||||||
isOptionMatched(option) {
|
isOptionExactMatched(option) {
|
||||||
|
return this.isValidOption(option) && typeof this.getOptionLabel(option) === 'string' && this.getOptionLabel(option)?.toLocaleLowerCase(this.filterLocale) == this.searchValue.toLocaleLowerCase(this.filterLocale);
|
||||||
|
},
|
||||||
|
isOptionStartsWith(option) {
|
||||||
return this.isValidOption(option) && typeof this.getOptionLabel(option) === 'string' && this.getOptionLabel(option)?.toLocaleLowerCase(this.filterLocale).startsWith(this.searchValue.toLocaleLowerCase(this.filterLocale));
|
return this.isValidOption(option) && typeof this.getOptionLabel(option) === 'string' && this.getOptionLabel(option)?.toLocaleLowerCase(this.filterLocale).startsWith(this.searchValue.toLocaleLowerCase(this.filterLocale));
|
||||||
},
|
},
|
||||||
isValidOption(option) {
|
isValidOption(option) {
|
||||||
|
@ -846,11 +849,10 @@ export default {
|
||||||
let matched = false;
|
let matched = false;
|
||||||
|
|
||||||
if (isNotEmpty(this.searchValue)) {
|
if (isNotEmpty(this.searchValue)) {
|
||||||
if (this.focusedOptionIndex !== -1) {
|
optionIndex = this.visibleOptions.findIndex((option) => this.isOptionExactMatched(option));
|
||||||
optionIndex = this.visibleOptions.slice(this.focusedOptionIndex).findIndex((option) => this.isOptionMatched(option));
|
|
||||||
optionIndex = optionIndex === -1 ? this.visibleOptions.slice(0, this.focusedOptionIndex).findIndex((option) => this.isOptionMatched(option)) : optionIndex + this.focusedOptionIndex;
|
if (optionIndex === -1) {
|
||||||
} else {
|
optionIndex = this.visibleOptions.findIndex((option) => this.isOptionStartsWith(option));
|
||||||
optionIndex = this.visibleOptions.findIndex((option) => this.isOptionMatched(option));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (optionIndex !== -1) {
|
if (optionIndex !== -1) {
|
||||||
|
|
Loading…
Reference in New Issue