У меня есть список постов с настроенной нумерацией страниц. Над этим списком есть поле поиска, где вы можете заполнить слово. В списке постов поиск будет осуществляться по заголовку и контенту через 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);
}
}
Я ожидаю или хотел бы добиться того, чтобы при успешном поиске и обнаружении сообщений они отображались в списке. Нумерация страниц должна быть в возвращенном списке найденных сообщений.