когда я нажимаю, чтобы застегнуть элемент, при успешном обратном вызове с сервера я обновляю список, чтобы отразить новый набор результатов, заново создав источник данных и передавая новый набор результатов следующим образом.
component.ts
ngOnInit(): void {
this.getPortfolioData();
}
getPortfolioData() {
// alert('hiii');
this.dataSource = new FilesDataSource(this._predictionListService, this.paginator, this.sort);
fromEvent(this.filter.nativeElement, 'keyup')
.pipe(
takeUntil(this._unsubscribeAll),
debounceTime(150),
distinctUntilChanged()
)
.subscribe(() => {
if (!this.dataSource) {
return;
}
this.dataSource.filter = this.filter.nativeElement.value;
});
this.changeDetectorRefs.detectChanges();
}
addToPortfolioSubmit(stockId: string) {
if (stockId) {
const stockid = {
'stockId': stockId.toString()
}
this._predictionListService.addToPortfolio(stockid).subscribe((result) => {
this.getPortfolioData()
// window.location.reload();
}, (err) => {
console.log(err);
});
}
}
Когда я нажимаю на эту кнопку addToPortfolioSubmit.после ответа Источник данных не обновляется
export class FilesDataSource extends DataSource<any>
{
// Private
private _filterChange = new BehaviorSubject('');
private _filteredDataChange = new BehaviorSubject('');
/**
* Constructor
*
* @param {PredictionListService} _predictionListService
* @param {MatPaginator} _matPaginator
* @param {MatSort} _matSort
*/
constructor(
private _predictionListService: PredictionListService,
private _matPaginator: MatPaginator,
private _matSort: MatSort,
) {
super();
this.filteredData = this._predictionListService.predictions;
}
// -----------------------------------------------------------------------------------------------------
// @ Accessors
// -----------------------------------------------------------------------------------------------------
// Filtered data
get filteredData(): any {
return this._filteredDataChange.value;
}
set filteredData(value: any) {
this._filteredDataChange.next(value);
}
// Filter
get filter(): string {
return this._filterChange.value;
}
set filter(filter: string) {
this._filterChange.next(filter);
}
// -----------------------------------------------------------------------------------------------------
// @ Public methods
// -----------------------------------------------------------------------------------------------------
/**
* Connect function called by the table to retrieve one stream containing the data to render.
*
* @returns {Observable<any[]>}
*/
connect(): Observable<any[]> {
const displayDataChanges = [
this._predictionListService.onPredictionsChanged,
this._matPaginator.page,
this._filterChange,
this._matSort.sortChange
];
return merge(...displayDataChanges).pipe(map(() => {
let data = this._predictionListService.predictions.slice();
data = this.filterData(data);
this.filteredData = [...data];
data = this.sortData(data);
// Grab the page's slice of data.
const startIndex = this._matPaginator.pageIndex * this._matPaginator.pageSize;
return data.splice(startIndex, this._matPaginator.pageSize);
})
);
}
/**
* Sort data
*
* @param data
* @returns {any[]}
*/
sortData(data): any[] {
if (!this._matSort.active || this._matSort.direction === '') {
return data;
}
return data.sort((a, b) => {
let propertyA: number | string = '';
let propertyB: number | string = '';
switch (this._matSort.active) {
case 'ticker':
[propertyA, propertyB] = [a.ticker, b.ticker];
break;
}
const valueA = isNaN(+propertyA) ? propertyA : +propertyA;
const valueB = isNaN(+propertyB) ? propertyB : +propertyB;
return (valueA < valueB ? -1 : 1) * (this._matSort.direction === 'asc' ? 1 : -1);
});
}
/**
* Disconnect
*/
disconnect(): void {
}
}
Вот фрагмент службы для получения списка данных:
service.ts
import { ActivatedRouteSnapshot, Resolve, RouterStateSnapshot } from '@angular/router';
import { BehaviorSubject, Observable, from } from 'rxjs';
@Injectable()
export class Service implements Resolve<any>
{
predictions: any[];
id: string;
onPredictionsChanged: BehaviorSubject<any>;
httpOptions
/**
* Constructor
*
* @param {HttpClient} _httpClient
*/
constructor(
private _httpClient: HttpClient,
) {
this.httpOptions = {
headers: new HttpHeaders({
'Content-Type': 'application/json',
})
};
// Set the defaults
this.onPredictionsChanged = new BehaviorSubject({});
}
/**
* Resolver
*
* @param {ActivatedRouteSnapshot} route
* @param {RouterStateSnapshot} state
* @returns {Observable<any> | Promise<any> | any}
*/
resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable<any> | Promise<any> | any {
return new Promise((resolve, reject) => {
Promise.all([
this.getPredictions(route.params.id)
]).then(
() => {
resolve();
},
reject
);
});
}
/**
* Get Predictions
*
* @returns {Promise<any>}
*/
getPredictions(id): Promise<any> {
return new Promise((resolve, reject) => {
this._httpClient.post(getGroupsDetails, { 'group_id': id }, this.httpOptions)
.subscribe((response: any) => {
this.predictions = response.data;
this.onPredictionsChanged.next(this.predictions);
resolve(response);
}, reject);
});
}
}
API бэкэнда отлично работает, но источник данных не обновляется
Любая помощь / совет будут высоко оценены.
Заранее спасибо.