import { Injectable } from '@angular/core'; import { HttpClient } from '@angular/common/http'; import { ActivatedRouteSnapshot, Resolve, RouterStateSnapshot } from '@angular/router'; import { Observable, BehaviorSubject } from 'rxjs'; @Injectable() export class FileManagerService implements Resolve { onFilesChanged: BehaviorSubject; onFileSelected: BehaviorSubject; /** * Constructor * * @param {HttpClient} _httpClient */ constructor( private _httpClient: HttpClient ) { // Set the defaults this.onFilesChanged = new BehaviorSubject({}); this.onFileSelected = new BehaviorSubject({}); } /** * Resolver * * @param {ActivatedRouteSnapshot} route * @param {RouterStateSnapshot} state * @returns {Observable | Promise | any} */ resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | any { return new Promise((resolve, reject) => { Promise.all([ this.getFiles() ]).then( ([files]) => { resolve(); }, reject ); }); } /** * Get files * * @returns {Promise} */ getFiles(): Promise { return new Promise((resolve, reject) => { this._httpClient.get('api/file-manager') .subscribe((response: any) => { this.onFilesChanged.next(response); this.onFileSelected.next(response[0]); resolve(response); }, reject); }); } }