Как исправить нумерацию страниц после результатов поиска - PullRequest
0 голосов
/ 13 июня 2019

У меня есть список постов с настроенной нумерацией страниц. Над этим списком есть поле поиска, где вы можете заполнить слово. В списке постов поиск будет осуществляться по заголовку и контенту через Angular Pipe. Поиск работает правильно, но разбиение на страницы по-прежнему выполняется в списке без поиска. Результаты поиска находятся на другой странице и не видны пользователю напрямую.

Я попытался сбросить нумерацию страниц, но мне не удалось

код поискового запроса

<form [formGroup]="formGroup" (ngSubmit)="onSearchCustomer()">
  <mat-form-field [ngStyle]="{ width: '100%' }">
    <input
      matInput
      formControlName="searchField"
      tabindex="1"
      autocomplete="off"
      placeholder="Zoek melding"
    />
  </mat-form-field>
</form>
<mat-accordion multi="true" *ngIf="posts.length > 0">
  <mat-expansion-panel *ngFor="let post of posts | searchPostsPipe: searchText">
    <mat-expansion-panel-header>
      {{ post.title }}
    </mat-expansion-panel-header>
    <p>{{ post.content }}</p>
    <mat-action-row>
      <a
        mat-button
        color="primary"
        [routerLink]="['/edit/', post.id]"
        routerLinkActive="router-link-active"
        >EDIT</a
      >
      <button mat-button color="warn" (click)="onDeletePost(post.id)">DELETE</button>
    </mat-action-row>
  </mat-expansion-panel>
</mat-accordion>
<mat-paginator
  *ngIf="posts.length > 0"
  [length]="totalPost"
  [pageSize]="postPerPage"
  [pageSizeOptions]="pageSizeOptions"
  (page)="onChangedPage($event)"
></mat-paginator>
<p class="info-text mat-body-1" *ngIf="posts.length <= 0">No posts to render yet!</p>

Угловой файл TS:

import { FormGroup, FormControl } from '@angular/forms';
import { PostService } from './../services/post.service';
import { Component, OnInit, OnDestroy } from '@angular/core';
import { Subscription } from 'rxjs';
import { PageEvent } from '@angular/material';

@Component({
  selector: 'app-post-list',
  templateUrl: './post-list.component.html',
  styleUrls: ['./post-list.component.css']
})
export class PostListComponent implements OnInit, OnDestroy {
  // posts: IPost[] = [
  //   { title: 'First post', content: 'First post content' },
  //   { title: 'Second post', content: 'Second post content' },
  //   { title: 'Third post', content: 'Third post content' },
  //   { title: 'Fourth post', content: 'Fourth post content' }
  // ];
  posts: IPost[] = [];
  postsSub$ = new Subscription();
  totalPost = 0;
  postPerPage = 3;
  currentPage = 1;
  pageSizeOptions = [1, 2, 3, 5, 10];
  isLoading = false;
  formGroup: FormGroup;
  searchText: string;

  constructor(private postService: PostService) {}

  ngOnInit() {
    this.isLoading = true;
    this.postService.getPosts(this.postPerPage, this.currentPage);
    this.postsSub$ = this.postService
      .getPostUpdateListener()
      .subscribe((postData: { posts: IPost[]; postCount: number }) => {
        this.isLoading = false;
        this.totalPost = postData.postCount;
        this.posts = postData.posts;
      });
    this.initForm();
  }

  ngOnDestroy() {
    this.postsSub$.unsubscribe();
  }

  initForm() {
    this.formGroup = new FormGroup({
      searchField: new FormControl()
    });
  }

  onSearchCustomer() {
    this.searchText = this.formGroup.get('searchField').value;
    this.resetPagination();
  }

  resetPagination() {
    console.log('#########-length', this.posts.length);
    console.log('#########-ppp', this.postPerPage);
    this.postPerPage = this.posts.length;
  }

  onDeletePost(postId: string) {
    this.isLoading = true;
    this.postService.deletePost(postId).subscribe(() => {
      this.postService.getPosts(this.postPerPage, this.currentPage);
    });
  }

  onChangedPage(pageData: PageEvent) {
    this.isLoading = true;
    this.currentPage = pageData.pageIndex + 1; // index start with 0 but backend starts with 1, 2, etc
    this.postPerPage = pageData.pageSize;
    this.postService.getPosts(this.postPerPage, this.currentPage);
  }
}

Я ожидаю или хотел бы добиться того, чтобы при успешном поиске и обнаружении сообщений они отображались в списке. Нумерация страниц должна быть в возвращенном списке найденных сообщений.

...