1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
import { NgModule } from '@angular/core'
import { RouterModule, Routes, UrlSegment } from '@angular/router'
import { LoginGuard } from '@app/core'
import { VideosListCommonPageComponent } from './video-list'
import { VideoOverviewComponent } from './video-list/overview/video-overview.component'
import { VideoUserSubscriptionsComponent } from './video-list/video-user-subscriptions.component'
const videosRoutes: Routes = [
{
path: '',
children: [
{
path: 'overview',
component: VideoOverviewComponent,
data: {
meta: {
title: $localize`Discover videos`
}
}
},
{
// Old URL redirection
path: 'most-liked',
redirectTo: 'trending?sort=most-liked'
},
{
matcher: (url: UrlSegment[]) => {
if (url.length === 1 && [ 'recently-added', 'trending', 'local' ].includes(url[0].path)) {
return {
consumed: url,
posParams: {
page: new UrlSegment(url[0].path, {})
}
}
}
return null
},
component: VideosListCommonPageComponent,
data: {
reuse: {
enabled: true,
key: 'videos-list'
}
}
},
{
path: 'subscriptions',
canActivate: [ LoginGuard ],
component: VideoUserSubscriptionsComponent,
data: {
meta: {
title: $localize`Subscriptions`
},
reuse: {
enabled: true,
key: 'subscription-videos-list'
}
}
}
]
}
]
@NgModule({
imports: [ RouterModule.forChild(videosRoutes) ],
exports: [ RouterModule ]
})
export class VideosRoutingModule {}
|