-import { forkJoin } from 'rxjs'
+import { forkJoin, Observable } from 'rxjs'
import { map, switchMap } from 'rxjs/operators'
import { Injectable } from '@angular/core'
-import { Resolve } from '@angular/router'
+import { ServerService } from '@app/core'
import { CustomMarkupService } from '@app/shared/shared-custom-markup'
import { AboutHTML, InstanceService } from '@app/shared/shared-instance'
-import { About } from '@shared/models/server'
+import { About, ServerStats } from '@shared/models/server'
export type ResolverData = {
+ serverStats: ServerStats
about: About
languages: string[]
categories: string[]
}
@Injectable()
-export class AboutInstanceResolver implements Resolve<any> {
+export class AboutInstanceResolver {
constructor (
private instanceService: InstanceService,
- private customMarkupService: CustomMarkupService
-
+ private customMarkupService: CustomMarkupService,
+ private serverService: ServerService
) {}
- resolve () {
+ resolve (): Observable<ResolverData> {
+ return forkJoin([
+ this.buildInstanceAboutObservable(),
+ this.buildInstanceStatsObservable()
+ ]).pipe(
+ map(([
+ [ about, languages, categories, aboutHTML, { rootElement } ],
+ serverStats
+ ]) => {
+ return {
+ serverStats,
+ about,
+ languages,
+ categories,
+ aboutHTML,
+ descriptionElement: rootElement
+ }
+ })
+ )
+ }
+
+ private buildInstanceAboutObservable () {
return this.instanceService.getAbout()
- .pipe(
- switchMap(about => {
- return forkJoin([
- Promise.resolve(about),
- this.instanceService.buildTranslatedLanguages(about),
- this.instanceService.buildTranslatedCategories(about),
- this.instanceService.buildHtml(about),
- this.customMarkupService.buildElement(about.instance.description)
- ])
- }),
- map(([ about, languages, categories, aboutHTML, { rootElement } ]) => {
- return { about, languages, categories, aboutHTML, descriptionElement: rootElement } as ResolverData
- })
- )
+ .pipe(
+ switchMap(about => {
+ return forkJoin([
+ Promise.resolve(about),
+ this.instanceService.buildTranslatedLanguages(about),
+ this.instanceService.buildTranslatedCategories(about),
+ this.instanceService.buildHtml(about),
+ this.customMarkupService.buildElement(about.instance.description)
+ ])
+ })
+ )
+ }
+
+ private buildInstanceStatsObservable () {
+ return this.serverService.getServerStats()
}
}