getData из нескольких фильтров ничего не возвращает - PullRequest
0 голосов
/ 26 ноября 2018

Я не могу заставить мою функцию getData на app.component.ts возвращать запрос со всеми аргументами для запроса API.Я не получаю никаких ошибок, и я также не могу console.log внутри функции, потому что она не работает.Он пропускает все, что я пишу внутри getData.Есть идеи?

app.component.ts

@Component({
  /**
   * Tag to show component in html
   */
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css'],
  providers: [MedicineService]
})

export class AppComponent implements OnInit, AfterViewInit {
  @ViewChildren(FiltersComponent) filters: QueryList<FiltersComponent>;
  title = 'Base Remédios';
  _medicines: Medicine[];
  resourceType: Filter[] = [
    {
      id: 'all',
      title: 'All',
      active: true,
    },
    {
      id: 'texto1',
      title: 'Texto1',
    },
    {
      id: 'texto2',
      title: 'Texto2',
    },
    {
      id: 'texto3',
      title: 'Texto3',
    },
  ];
  levels: Filter[] = [
    {
      id: 'grupo1',
      title: 'Grupo1',
      active: true,
    },
    {
      id: 'grupo2',
      title: 'Grupo2',
    },
    {
      id: 'grupo3',
      title: 'Grupo3',
    },
  ];

  private resources: Observable<any>;

  constructor(private _medicineService: MedicineService) {
  }

  /**
   * Function to get array itens of endpoints
   */
  getMedicines(): void {
    this._medicineService.getMedicines()
      .subscribe(
        resultArray => this._medicines = resultArray,
        error => console.log(error));
  }

  ngOnInit(): void {
    this.getMedicines();
  }

  ngAfterViewInit() {
    const filters = this.filters.map(f => f.changeFilter);
    console.log('oi');
    this.resources = combineLatest(...filters).pipe(
      map((filters: ActiveFilter[]) =>
        filters.map(filter => `${filter.group}=${filter.id}`).join('&')),
      switchMap(this.getData));
  }

  getData(query) {
    return timer(1).mapTo('https://api.com?' + query);
  }

}

filter.component.ts

   export interface ActiveFilter {
  id: number | string;
  group: string;
}

export interface Filter {
  id: string | string;
  title: string;
  active?: boolean;
}

@Component({
  selector: 'app-filters',
  templateUrl: './filters.component.html',
  styleUrls: ['./filters.component.css']
})
export class FiltersComponent implements OnInit, OnDestroy {
  @Input() group: string;
  @Input() filters: Filter[] = [];

  changeFilter;

  ngOnInit(): void {
    const initialFilter = this.filters.find(f => f.active);

    this.changeFilter = new BehaviorSubject<ActiveFilter>({
      group: this.group,
      id: initialFilter.id
    });
  }

  ngOnDestroy() {
    this.changeFilter.unsubscribe();
  }

  select(filter: Filter) {
    console.log('click funciona');
    this.filters.forEach(filter => filter.active = false);
    filter.active = true;
    this.changeFilter.next({
      group: this.group,
      id: filter.id
    });
  }

}

filters.component.html

<ul>
  <li *ngFor="let filter of filters" (click)="select(filter)" [ngClass]="{ active: filter.active }">
    {{filter.title}}
  </li>
</ul>

app.component.html

<section>
      <app-filters [filters]="resourceType" group="type"></app-filters>
      <app-filters [filters]="levels" group="level"></app-filters>
 </section>

1 Ответ

0 голосов
/ 26 ноября 2018

Существует проблема с параметром, который вы передаете в switchMap функцию rxjs.

Модифицированный код -

  ngAfterViewInit() {
    const filters = this.filters.map(f => f.changeFilter);
    console.log('oi');
    this.resources = combineLatest(...filters).pipe(
      map((filters: ActiveFilter[]) =>
        filters.map(filter => `${filter.group}=${filter.id}`).join('&')),
      switchMap(()=>this.getData())); // <------ change here
  }

См. Это - https://www.learnrxjs.io/operators/transformation/switchmap.html

...