Я использую ng-select пользовательский поиск на стороне сервера для загрузки данных в зависимости от того, что пользователь вводит. В настоящее время это работает, только если ключевое слово действительно нажато. Я бы хотел запускать http-запрос каждый раз, когда раскрывающийся список открывается, даже если поисковый термин пустой
component. html
<ng-select [items]="filterValues$ | async"
[typeahead]="filterValuesInput$"
[multiple]="true"
(open)="getFilterValues(pref.id)"
[loading]="filterValuesLoading"
bindLabel="name"
[(ngModel)]="filter_values">
</ng-select>
component.ts
getFilterValues(filterId) {
this.filterValues$ = concat(
of([]), // default items
this.filterValuesInput$.pipe(
distinctUntilChanged(),
tap(() => this.filterValuesLoading = true),
switchMap(term => this.service.getFilterValues(filterName, '' + term).pipe(
map(res => res.filter_values),
catchError(() => of([])), // empty list on error
tap(() => this.filterValuesLoading = false)
))
)
);
}
Я пытаюсь понять, как switchMap () инициирует запрос только после ввода значения ввода. Как заставить его вызывать метод службы каждый раз, когда вызывается метод getFilterValues?