pull/2835/head
mertsincan 2022-08-02 10:34:53 +01:00
parent 5309386739
commit dcaec67475
4 changed files with 44 additions and 50 deletions

View File

@ -783,6 +783,16 @@ export default {
this.$emit('update:modelValue', value); this.$emit('update:modelValue', value);
this.$emit('change', { originalEvent: event, value }); this.$emit('change', { originalEvent: event, value });
}, },
flatOptions(options = []) {
return options.reduce((result, option, index) => {
result.push({ optionGroup: option, group: true, index });
const optionGroupChildren = this.getOptionGroupChildren(option);
optionGroupChildren && optionGroupChildren.forEach(o => result.push(o));
return result;
}, []);
},
overlayRef(el) { overlayRef(el) {
this.overlay = el; this.overlay = el;
}, },
@ -824,20 +834,7 @@ export default {
return ['p-autocomplete-loader pi-spin', this.loadingIcon]; return ['p-autocomplete-loader pi-spin', this.loadingIcon];
}, },
visibleOptions() { visibleOptions() {
let options = this.suggestions || []; return this.optionGroupLabel ? this.flatOptions(this.suggestions) : (this.suggestions || []);
if (this.optionGroupLabel) {
options = options.reduce((result, option, index) => {
result.push({ optionGroup: option, group: true, index });
let optionGroupChildren = this.getOptionGroupChildren(option);
optionGroupChildren && optionGroupChildren.forEach(o => result.push(o));
return result;
}, []);
}
return options;
}, },
inputValue() { inputValue() {
if (this.modelValue) { if (this.modelValue) {

View File

@ -771,6 +771,16 @@ export default {
this.$emit('update:modelValue', value); this.$emit('update:modelValue', value);
this.$emit('change', { originalEvent: event, value }); this.$emit('change', { originalEvent: event, value });
}, },
flatOptions(options = []) {
return options.reduce((result, option, index) => {
result.push({ optionGroup: option, group: true, index });
const optionGroupChildren = this.getOptionGroupChildren(option);
optionGroupChildren && optionGroupChildren.forEach(o => result.push(o));
return result;
}, []);
},
overlayRef(el) { overlayRef(el) {
this.overlay = el; this.overlay = el;
}, },
@ -809,18 +819,7 @@ export default {
return ['p-dropdown-trigger-icon', (this.loading ? this.loadingIcon : 'pi pi-chevron-down')]; return ['p-dropdown-trigger-icon', (this.loading ? this.loadingIcon : 'pi pi-chevron-down')];
}, },
visibleOptions() { visibleOptions() {
let options = this.options || []; const options = this.optionGroupLabel ? this.flatOptions(this.options) : (this.options || []);
if (this.optionGroupLabel) {
options = options.reduce((result, option, index) => {
result.push({ optionGroup: option, group: true, index });
let optionGroupChildren = this.getOptionGroupChildren(option);
optionGroupChildren && optionGroupChildren.forEach(o => result.push(o));
return result;
}, []);
}
return this.filterValue ? FilterService.filter(options, this.searchFields, this.filterValue, this.filterMatchMode, this.filterLocale) : options; return this.filterValue ? FilterService.filter(options, this.searchFields, this.filterValue, this.filterMatchMode, this.filterLocale) : options;
}, },

View File

@ -621,6 +621,16 @@ export default {
this.$emit('update:modelValue', value); this.$emit('update:modelValue', value);
this.$emit('change', { originalEvent: event, value }); this.$emit('change', { originalEvent: event, value });
}, },
flatOptions(options = []) {
return options.reduce((result, option, index) => {
result.push({ optionGroup: option, group: true, index });
const optionGroupChildren = this.getOptionGroupChildren(option);
optionGroupChildren && optionGroupChildren.forEach(o => result.push(o));
return result;
}, []);
},
listRef(el, contentRef) { listRef(el, contentRef) {
this.list = el; this.list = el;
contentRef && contentRef(el); // For VirtualScroller contentRef && contentRef(el); // For VirtualScroller
@ -637,18 +647,7 @@ export default {
}]; }];
}, },
visibleOptions() { visibleOptions() {
let options = this.options || []; const options = this.optionGroupLabel ? this.flatOptions(this.options) : (this.options || []);
if (this.optionGroupLabel) {
options = options.reduce((result, option, index) => {
result.push({ optionGroup: option, group: true, index });
let optionGroupChildren = this.getOptionGroupChildren(option);
optionGroupChildren && optionGroupChildren.forEach(o => result.push(o));
return result;
}, []);
}
return this.filterValue ? FilterService.filter(options, this.searchFields, this.filterValue, this.filterMatchMode, this.filterLocale) : options; return this.filterValue ? FilterService.filter(options, this.searchFields, this.filterValue, this.filterMatchMode, this.filterLocale) : options;
}, },

View File

@ -901,6 +901,16 @@ export default {
this.$emit('update:modelValue', value); this.$emit('update:modelValue', value);
this.$emit('change', { originalEvent: event, value }); this.$emit('change', { originalEvent: event, value });
}, },
flatOptions(options = []) {
return options.reduce((result, option, index) => {
result.push({ optionGroup: option, group: true, index });
const optionGroupChildren = this.getOptionGroupChildren(option);
optionGroupChildren && optionGroupChildren.forEach(o => result.push(o));
return result;
}, []);
},
overlayRef(el) { overlayRef(el) {
this.overlay = el; this.overlay = el;
}, },
@ -939,18 +949,7 @@ export default {
}]; }];
}, },
visibleOptions() { visibleOptions() {
let options = this.options || []; const options = this.optionGroupLabel ? this.flatOptions(this.options) : (this.options || []);
if (this.optionGroupLabel) {
options = options.reduce((result, option, index) => {
result.push({ optionGroup: option, group: true, index });
let optionGroupChildren = this.getOptionGroupChildren(option);
optionGroupChildren && optionGroupChildren.forEach(o => result.push(o));
return result;
}, []);
}
return this.filterValue ? FilterService.filter(options, this.searchFields, this.filterValue, this.filterMatchMode, this.filterLocale) : options; return this.filterValue ? FilterService.filter(options, this.searchFields, this.filterValue, this.filterMatchMode, this.filterLocale) : options;
}, },