]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blobdiff - client/src/app/videos/videos-routing.module.ts
Add "local" videos in menu
[github/Chocobozzz/PeerTube.git] / client / src / app / videos / videos-routing.module.ts
index 4c951200c8a69484d310eb1fa6f84320129a1a7f..561137b7013ed3391a2c47a0294953d9019ab713 100644 (file)
@@ -1,45 +1,92 @@
-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 { VideoSearchComponent } from './video-list'
+import { VideoRecentlyAddedComponent } from './video-list/video-recently-added.component'
+import { VideoTrendingComponent } from './video-list/video-trending.component'
+import { VideosComponent } from './videos.component'
 
 const videosRoutes: Routes = [
   {
     path: 'videos',
     component: VideosComponent,
+    canActivateChild: [ MetaGuard ],
     children: [
       {
         path: 'list',
-        component: VideoListComponent,
+        pathMatch: 'full',
+        redirectTo: 'recently-added'
+      },
+      {
+        path: 'trending',
+        component: VideoTrendingComponent,
         data: {
           meta: {
-            titleSuffix: ' - Videos list'
+            title: 'Trending videos'
           }
         }
       },
       {
-        path: 'add',
-        component: VideoAddComponent,
+        path: 'recently-added',
+        component: VideoRecentlyAddedComponent,
         data: {
           meta: {
-            titleSuffix: ' - Add a video'
+            title: 'Recently added videos'
           }
         }
       },
       {
-        path: ':id',
-        redirectTo: 'watch/:id'
+        path: 'local',
+        component: VideoLocalComponent,
+        data: {
+          meta: {
+            title: 'Local videos'
+          }
+        }
       },
       {
-        path: 'watch/:id',
-        component: VideoWatchComponent
+        path: 'search',
+        component: VideoSearchComponent,
+        data: {
+          meta: {
+            title: 'Search videos'
+          }
+        }
+      },
+      {
+        path: 'upload',
+        loadChildren: 'app/videos/+video-edit/video-add.module#VideoAddModule',
+        data: {
+          meta: {
+            title: 'Upload a video'
+          }
+        }
+      },
+      {
+        path: 'edit/:uuid',
+        loadChildren: 'app/videos/+video-edit/video-update.module#VideoUpdateModule',
+        data: {
+          meta: {
+            title: 'Edit a video'
+          }
+        }
+      },
+      {
+        path: ':uuid',
+        pathMatch: 'full',
+        redirectTo: 'watch/:uuid'
+      },
+      {
+        path: 'watch/:uuid',
+        loadChildren: 'app/videos/+video-watch/video-watch.module#VideoWatchModule',
+        data: {
+          preload: 3000
+        }
       }
     ]
   }
-];
+]
 
 @NgModule({
   imports: [ RouterModule.forChild(videosRoutes) ],