fix: #7026, Select: Editable Dropdown search not working as expected

pull/7027/head
ANTONA09 2024-12-30 14:44:44 +05:30
parent aec97b279e
commit aa3f5c0c5a
1 changed files with 8 additions and 6 deletions

View File

@ -798,7 +798,10 @@ export default {
hasFocusableElements() {
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));
},
isValidOption(option) {
@ -846,11 +849,10 @@ export default {
let matched = false;
if (isNotEmpty(this.searchValue)) {
if (this.focusedOptionIndex !== -1) {
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;
} else {
optionIndex = this.visibleOptions.findIndex((option) => this.isOptionMatched(option));
optionIndex = this.visibleOptions.findIndex((option) => this.isOptionExactMatched(option));
if (optionIndex === -1) {
optionIndex = this.visibleOptions.findIndex((option) => this.isOptionStartsWith(option));
}
if (optionIndex !== -1) {