import { Injectable } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { BehaviorSubject, filter, map, Observable, of, switchMap, take, tap, throwError, } from 'rxjs'; import { SessioninInfo } from '../models/sessionin-info'; import { SessioninInfoPagination } from '../models/sessionin-info-pagination'; @Injectable({ providedIn: 'root', }) export class SessioninInfoService { // Private private __pagination = new BehaviorSubject< SessioninInfoPagination | undefined >(undefined); private __sessioninInfo = new BehaviorSubject( undefined ); private __sessioninInfos = new BehaviorSubject( undefined ); /** * Constructor */ constructor(private _httpClient: HttpClient) {} // ----------------------------------------------------------------------------------------------------- // @ Accessors // ----------------------------------------------------------------------------------------------------- /** * Getter for pagination */ get pagination$(): Observable { return this.__pagination.asObservable(); } /** * Getter for sessioninInfo */ get sessioninInfo$(): Observable { return this.__sessioninInfo.asObservable(); } /** * Getter for sessioninInfos */ get sessioninInfos$(): Observable { return this.__sessioninInfos.asObservable(); } // ----------------------------------------------------------------------------------------------------- // @ Public methods // ----------------------------------------------------------------------------------------------------- /** * Get SessioninInfos * * * @param page * @param size * @param sort * @param order * @param search */ getSessioninInfos( page: number = 0, size: number = 10, sort: string = 'name', order: 'asc' | 'desc' | '' = 'asc', search: string = '' ): Observable<{ pagination: SessioninInfoPagination; sessioninInfos: SessioninInfo[]; }> { return this._httpClient .get<{ pagination: SessioninInfoPagination; sessioninInfos: SessioninInfo[]; }>('api/apps/report/sessionin-info/sessionin-infos', { params: { page: '' + page, size: '' + size, sort, order, search, }, }) .pipe( tap((response) => { this.__pagination.next(response.pagination); this.__sessioninInfos.next(response.sessioninInfos); }) ); } /** * Get product by id */ getSessioninInfoById(id: string | null): Observable { return this.__sessioninInfos.pipe( take(1), map((sessioninInfos) => { // Find the product const sessioninInfo = sessioninInfos?.find((item) => item.id === id) || undefined; // Update the product this.__sessioninInfo.next(sessioninInfo); // Return the product return sessioninInfo; }), switchMap((product) => { if (!product) { return throwError('Could not found product with id of ' + id + '!'); } return of(product); }) ); } /** * Create product */ createSessioninInfo(): Observable { return this.sessioninInfos$.pipe( take(1), switchMap((sessioninInfos) => this._httpClient .post('api/apps/report/sessionin-info/product', {}) .pipe( map((newSessioninInfo) => { // Update the sessioninInfos with the new product if (!!sessioninInfos) { this.__sessioninInfos.next([ newSessioninInfo, ...sessioninInfos, ]); } // Return the new product return newSessioninInfo; }) ) ) ); } }