]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - client/src/app/root.component.ts
Refactor client @actorName matcher with new API route
[github/Chocobozzz/PeerTube.git] / client / src / app / root.component.ts
1 import { Component, OnInit } from '@angular/core'
2 import { catchError, distinctUntilChanged, map, switchMap } from 'rxjs/operators'
3 import { ActivatedRoute, Router } from '@angular/router'
4 import { RestExtractor } from '@app/core'
5 import { ActorService } from '@app/shared/shared-main/account'
6 import { HttpStatusCode } from '@shared/core-utils/miscs/http-error-codes'
7
8 @Component({
9 selector: 'my-root',
10 template: ''
11 })
12 export class RootComponent implements OnInit {
13 constructor (
14 private actorService: ActorService,
15 private route: ActivatedRoute,
16 private restExtractor: RestExtractor,
17 private router: Router
18 ) {
19 }
20
21 ngOnInit () {
22 this.route.params
23 .pipe(
24 map(params => params[ 'actorName' ]),
25 distinctUntilChanged(),
26 switchMap(actorName => this.actorService.getActor(actorName)),
27 catchError(err => this.restExtractor.redirectTo404IfNotFound(err, 'other', [
28 HttpStatusCode.BAD_REQUEST_400,
29 HttpStatusCode.NOT_FOUND_404
30 ]))
31 )
32 .subscribe(actor => {
33 if (actor.constructor.name === 'Account') {
34 this.router.navigateByUrl(`/accounts/${actor.name}`)
35 }
36
37 if (actor.constructor.name === 'VideoChannel') {
38 this.router.navigateByUrl(`/video-channels/${actor.name}`)
39 }
40 })
41 }
42 }