-import { NgModule } from '@angular/core';
-import { RouterModule, Routes } from '@angular/router';
-
-import { VideoAddComponent } from './video-add';
-import { VideoListComponent } from './video-list';
-import { VideosComponent } from './videos.component';
-import { VideoWatchComponent } from './video-watch';
+import { NgModule } from '@angular/core'
+import { RouterModule, Routes } from '@angular/router'
+import { VideoLocalComponent } from '@app/videos/video-list/video-local.component'
+import { MetaGuard } from '@ngx-meta/core'
+import { VideoRecentlyAddedComponent } from './video-list/video-recently-added.component'
+import { VideoTrendingComponent } from './video-list/video-trending.component'
+import { VideosComponent } from './videos.component'
+import { VideoUserSubscriptionsComponent } from '@app/videos/video-list/video-user-subscriptions.component'
+import { VideoOverviewComponent } from '@app/videos/video-list/video-overview.component'
const videosRoutes: Routes = [
{
path: 'videos',
component: VideosComponent,
+ canActivateChild: [ MetaGuard ],
children: [
{
- path: 'list',
- component: VideoListComponent,
+ path: 'overview',
+ component: VideoOverviewComponent,
+ data: {
+ meta: {
+ title: 'Videos overview'
+ }
+ }
+ },
+ {
+ path: 'trending',
+ component: VideoTrendingComponent,
data: {
meta: {
- title: 'Videos list'
+ title: 'Trending videos'
+ },
+ reuse: {
+ enabled: true,
+ key: 'trending-videos-list'
}
}
},
{
- path: 'add',
- component: VideoAddComponent,
+ path: 'recently-added',
+ component: VideoRecentlyAddedComponent,
data: {
meta: {
- title: 'Add a video'
+ title: 'Recently added videos'
+ },
+ reuse: {
+ enabled: true,
+ key: 'recently-added-videos-list'
}
}
},
{
- path: ':id',
- redirectTo: 'watch/:id'
+ path: 'subscriptions',
+ component: VideoUserSubscriptionsComponent,
+ data: {
+ meta: {
+ title: 'Subscriptions'
+ },
+ reuse: {
+ enabled: true,
+ key: 'subscription-videos-list'
+ }
+ }
},
{
- path: 'watch/:id',
- component: VideoWatchComponent
+ path: 'local',
+ component: VideoLocalComponent,
+ data: {
+ meta: {
+ title: 'Local videos'
+ },
+ reuse: {
+ enabled: true,
+ key: 'local-videos-list'
+ }
+ }
+ },
+ {
+ path: 'upload',
+ loadChildren: 'app/videos/+video-edit/video-add.module#VideoAddModule',
+ data: {
+ meta: {
+ title: 'Upload a video'
+ }
+ }
+ },
+ {
+ path: 'update/:uuid',
+ loadChildren: 'app/videos/+video-edit/video-update.module#VideoUpdateModule',
+ data: {
+ meta: {
+ title: 'Edit a video'
+ }
+ }
+ },
+ {
+ path: 'watch',
+ loadChildren: 'app/videos/+video-watch/video-watch.module#VideoWatchModule',
+ data: {
+ preload: 3000
+ }
}
]
}
-];
+]
@NgModule({
imports: [ RouterModule.forChild(videosRoutes) ],