import { forkJoin } from 'rxjs'
import { map, switchMap } from 'rxjs/operators'
import { Injectable } from '@angular/core'
-import { ActivatedRouteSnapshot, Resolve } from '@angular/router'
-import { ServerService } from '@app/core'
-import { InstanceService } from '@app/shared/shared-instance'
-import { About, ServerConfig } from '@shared/models/server'
+import { Resolve } from '@angular/router'
+import { CustomMarkupService } from '@app/shared/shared-custom-markup'
+import { AboutHTML, InstanceService } from '@app/shared/shared-instance'
+import { About } from '@shared/models/server'
-export type ResolverData = { about: About, languages: string[], categories: string[], serverConfig: ServerConfig }
+export type ResolverData = {
+ about: About
+ languages: string[]
+ categories: string[]
+ aboutHTML: AboutHTML
+ descriptionElement: HTMLDivElement
+}
@Injectable()
export class AboutInstanceResolver implements Resolve<any> {
constructor (
private instanceService: InstanceService,
- private serverService: ServerService
+ private customMarkupService: CustomMarkupService
+
) {}
- resolve (route: ActivatedRouteSnapshot) {
+ resolve () {
return this.instanceService.getAbout()
.pipe(
switchMap(about => {
return forkJoin([
+ Promise.resolve(about),
this.instanceService.buildTranslatedLanguages(about),
this.instanceService.buildTranslatedCategories(about),
- this.serverService.getConfig()
- ]).pipe(map(([ languages, categories, serverConfig ]) => ({ about, languages, categories, serverConfig })))
+ 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
})
)
}