X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=client%2Fsrc%2Fapp%2Fcore%2Frouting%2Fredirect.service.ts;h=571476d1de529583b793c08ca5a2f8b3cd1fb65d;hb=a37e9e74ff07b057370d1ed6c0b391a02be8a6d2;hp=571822b767a3dd85b8ec749fb19853dc29f0a517;hpb=b91bc1d1f3591c35ab4426f6ab594b4bd9f1ef62;p=github%2FChocobozzz%2FPeerTube.git diff --git a/client/src/app/core/routing/redirect.service.ts b/client/src/app/core/routing/redirect.service.ts index 571822b76..571476d1d 100644 --- a/client/src/app/core/routing/redirect.service.ts +++ b/client/src/app/core/routing/redirect.service.ts @@ -1,49 +1,55 @@ import { Injectable } from '@angular/core' -import { NavigationEnd, Router } from '@angular/router' +import { NavigationCancel, NavigationEnd, Router } from '@angular/router' import { ServerService } from '../server' @Injectable() export class RedirectService { // Default route could change according to the instance configuration static INIT_DEFAULT_ROUTE = '/videos/trending' - static DEFAULT_ROUTE = RedirectService.INIT_DEFAULT_ROUTE + static INIT_DEFAULT_TRENDING_ALGORITHM = 'most-viewed' private previousUrl: string private currentUrl: string + private redirectingToHomepage = false + private defaultTrendingAlgorithm = RedirectService.INIT_DEFAULT_TRENDING_ALGORITHM + private defaultRoute = RedirectService.INIT_DEFAULT_ROUTE + constructor ( private router: Router, private serverService: ServerService ) { // The config is first loaded from the cache so try to get the default route - const config = this.serverService.getConfig() - if (config && config.instance && config.instance.defaultClientRoute) { - RedirectService.DEFAULT_ROUTE = config.instance.defaultClientRoute + const config = this.serverService.getHTMLConfig() + if (config?.instance?.defaultClientRoute) { + this.defaultRoute = config.instance.defaultClientRoute + } + if (config?.trending?.videos?.algorithms?.default) { + this.defaultTrendingAlgorithm = config.trending.videos.algorithms.default } - - // Load default route - this.serverService.configLoaded - .subscribe(() => { - const defaultRouteConfig = this.serverService.getConfig().instance.defaultClientRoute - - if (defaultRouteConfig) { - RedirectService.DEFAULT_ROUTE = defaultRouteConfig - } - }) // Track previous url this.currentUrl = this.router.url router.events.subscribe(event => { - if (event instanceof NavigationEnd) { + if (event instanceof NavigationEnd || event instanceof NavigationCancel) { this.previousUrl = this.currentUrl this.currentUrl = event.url } }) } - redirectToPreviousRoute () { + getDefaultRoute () { + return this.defaultRoute + } + + getDefaultTrendingAlgorithm () { + return this.defaultTrendingAlgorithm + } + + redirectToPreviousRoute (fallbackRoute: string[] = null) { const exceptions = [ - '/verify-account' + '/verify-account', + '/reset-password' ] if (this.previousUrl) { @@ -51,22 +57,33 @@ export class RedirectService { if (!isException) return this.router.navigateByUrl(this.previousUrl) } + if (fallbackRoute) { + return this.router.navigate(fallbackRoute) + } + return this.redirectToHomepage() } redirectToHomepage (skipLocationChange = false) { - console.log('Redirecting to %s...', RedirectService.DEFAULT_ROUTE) + if (this.redirectingToHomepage) return - this.router.navigate([ RedirectService.DEFAULT_ROUTE ], { skipLocationChange }) + this.redirectingToHomepage = true + + console.log('Redirecting to %s...', this.defaultRoute) + + this.router.navigateByUrl(this.defaultRoute, { skipLocationChange }) + .then(() => this.redirectingToHomepage = false) .catch(() => { + this.redirectingToHomepage = false + console.error( 'Cannot navigate to %s, resetting default route to %s.', - RedirectService.DEFAULT_ROUTE, + this.defaultRoute, RedirectService.INIT_DEFAULT_ROUTE ) - RedirectService.DEFAULT_ROUTE = RedirectService.INIT_DEFAULT_ROUTE - return this.router.navigate([ RedirectService.DEFAULT_ROUTE ], { skipLocationChange }) + this.defaultRoute = RedirectService.INIT_DEFAULT_ROUTE + return this.router.navigateByUrl(this.defaultRoute, { skipLocationChange }) }) }