import { Component, OnInit } from '@angular/core' import { ActivatedRoute } from '@angular/router' import { is18nPath } from '@peertube/peertube-core-utils' import { RedirectService } from './core/routing/redirect.service' /* * We have to use a component instead of an homepage because of a weird issue when using router.navigate in guard * * Since we also want to use the `skipLocationChange` option, we cannot use a guard that returns a UrlTree * See https://github.com/angular/angular/issues/27148 */ @Component({ template: '', standalone: true }) export class HomepageRedirectComponent implements OnInit { constructor ( private route: ActivatedRoute, private redirectService: RedirectService ) { } ngOnInit () { const url = this.route.snapshot.url if (url.length === 0 || is18nPath('/' + url[0])) { this.redirectService.redirectToHomepage(true) } } }