I have a scenario like I need to fetch file content when click on a file.
I want to cache the file content API with shareReplay(), how can I achieve it?
fileService.getContent is an API service which will fetch content with params(repository_id, filePath);
Question:
shareReplay() pipe? Inside API service? or the place I wrote below.shareReplay() to call only once.Component
fileOpened$ = new Subject();
...
this.fileOpened$.pipe(
    switchMap(file => this.fileService.getContent(this.repository_id, file.filePath)),
       shareReplay(1)
);
service:
getContent(repoId: string, path: string): Observable<string> {
    return this.http.get<string>(
        `/api/xxx/${repoId}/files/${decodeURIComponent(path)}`,
        {
            responseType: 'text' as 'json'
        });
}
I would add the shareReplay code in the service.
Because of the parameters you can create a Map that caches the Observables.
Here the stackblitz I created to demonstrate.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With