import { Injectable } from '@angular/core'
-import { Router } from '@angular/router'
+import { NavigationEnd, Router } from '@angular/router'
import { ServerService } from '../server'
@Injectable()
static INIT_DEFAULT_ROUTE = '/videos/trending'
static DEFAULT_ROUTE = RedirectService.INIT_DEFAULT_ROUTE
+ private previousUrl: string
+ private currentUrl: string
+
constructor (
private router: Router,
private serverService: ServerService
RedirectService.DEFAULT_ROUTE = config.instance.defaultClientRoute
}
+ // Load default route
this.serverService.configLoaded
.subscribe(() => {
const defaultRouteConfig = this.serverService.getConfig().instance.defaultClientRoute
RedirectService.DEFAULT_ROUTE = defaultRouteConfig
}
})
+
+ // Track previous url
+ this.currentUrl = this.router.url
+ router.events.subscribe(event => {
+ if (event instanceof NavigationEnd) {
+ this.previousUrl = this.currentUrl
+ this.currentUrl = event.url
+ }
+ })
+ }
+
+ redirectToPreviousRoute () {
+ const exceptions = [
+ '/verify-account'
+ ]
+
+ if (this.previousUrl) {
+ const isException = exceptions.find(e => this.previousUrl.startsWith(e))
+ if (!isException) return this.router.navigateByUrl(this.previousUrl)
+ }
+
+ return this.redirectToHomepage()
}
- redirectToHomepage () {
+ redirectToHomepage (skipLocationChange = false) {
console.log('Redirecting to %s...', RedirectService.DEFAULT_ROUTE)
- this.router.navigate([ RedirectService.DEFAULT_ROUTE ], { replaceUrl: true })
+ this.router.navigate([ RedirectService.DEFAULT_ROUTE ], { skipLocationChange })
.catch(() => {
console.error(
'Cannot navigate to %s, resetting default route to %s.',
)
RedirectService.DEFAULT_ROUTE = RedirectService.INIT_DEFAULT_ROUTE
- return this.router.navigate([ RedirectService.DEFAULT_ROUTE ], { replaceUrl: true })
+ return this.router.navigate([ RedirectService.DEFAULT_ROUTE ], { skipLocationChange })
})
}