import { ConfigService } from '@services/config.service'; import { Injectable } from '@angular/core'; import { HttpClient, HttpParams } from '@angular/common/http'; import { Observable, throwError } from 'rxjs'; import { catchError, map } from 'rxjs/operators'; @Injectable({ providedIn: 'root' }) export class DataService { baseUrl: string; private apiUrl: string; constructor(private http: HttpClient, private configService: ConfigService) { this.baseUrl = this.configService.apiUrl; this.apiUrl = `${this.baseUrl}/menus?page=1&itemsPerPage=1000`; } getMenus(filters: { [key: string]: string }): Observable<{ totalItems: any; data: any }> { const params = new HttpParams({ fromObject: filters }); return this.http.get(this.apiUrl, { params }).pipe( map(response => { if (response['hydra:member'] && Array.isArray(response['hydra:member'])) { return { data: response['hydra:member'], totalItems: response['hydra:totalItems'] } } else { throw new Error('Unexpected response format'); } }), catchError(error => { console.error('Error fetching commands', error); return throwError(error); }) ); } getMenu(id: string): Observable { return this.http.get(`${this.baseUrl}${id}`).pipe( map(response => { if (response.name) { return response; } else { throw new Error('Unexpected response format'); } }), catchError(error => { console.error('Error fetching menus', error); return throwError(error); }) ); } }