]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blobdiff - client/src/app/app-routing.module.ts
Improve playlist add dropdown ux
[github/Chocobozzz/PeerTube.git] / client / src / app / app-routing.module.ts
index f9465dc9c4ed39bccf7fd56b13d2f8990e2076d8..bcae29c9a3e962087308c33cbd2d034082a7d4c3 100644 (file)
@@ -1,21 +1,95 @@
-import { NgModule } from '@angular/core';
-import { Routes, RouterModule } from '@angular/router';
+import { NgModule } from '@angular/core'
+import { RouteReuseStrategy, RouterModule, Routes } from '@angular/router'
+import { CustomReuseStrategy } from '@app/core/routing/custom-reuse-strategy'
+import { MenuGuards } from '@app/core/routing/menu-guard.service'
+import { PreloadSelectedModulesList } from './core'
+import { EmptyComponent } from './empty.component'
+import { POSSIBLE_LOCALES } from '@shared/core-utils/i18n'
 
 const routes: Routes = [
   {
-    path: '',
-    redirectTo: '/videos/list',
-    pathMatch: 'full'
+    path: 'admin',
+    canActivate: [ MenuGuards.close() ],
+    canDeactivate: [ MenuGuards.open() ],
+    loadChildren: () => import('./+admin/admin.module').then(m => m.AdminModule)
   },
   {
-    path: 'admin',
-    loadChildren: './+admin#AdminModule'
+    path: 'my-account',
+    loadChildren: () => import('./+my-account/my-account.module').then(m => m.MyAccountModule)
+  },
+  {
+    path: 'my-library',
+    loadChildren: () => import('./+my-library/my-library.module').then(m => m.MyLibraryModule)
+  },
+  {
+    path: 'verify-account',
+    loadChildren: () => import('./+signup/+verify-account/verify-account.module').then(m => m.VerifyAccountModule)
+  },
+  {
+    path: 'accounts',
+    loadChildren: () => import('./+accounts/accounts.module').then(m => m.AccountsModule)
+  },
+  {
+    path: 'video-channels',
+    loadChildren: () => import('./+video-channels/video-channels.module').then(m => m.VideoChannelsModule)
+  },
+  {
+    path: 'about',
+    loadChildren: () => import('./+about/about.module').then(m => m.AboutModule)
+  },
+  {
+    path: 'signup',
+    loadChildren: () => import('./+signup/+register/register.module').then(m => m.RegisterModule)
+  },
+  {
+    path: 'reset-password',
+    loadChildren: () => import('./+reset-password/reset-password.module').then(m => m.ResetPasswordModule)
+  },
+  {
+    path: 'login',
+    loadChildren: () => import('./+login/login.module').then(m => m.LoginModule)
+  },
+  {
+    path: 'search',
+    loadChildren: () => import('./+search/search.module').then(m => m.SearchModule)
+  },
+  {
+    path: 'videos',
+    loadChildren: () => import('./+videos/videos.module').then(m => m.VideosModule)
+  },
+  {
+    path: '',
+    component: EmptyComponent // Avoid 404, app component will redirect dynamically
   }
-];
+]
+
+// Avoid 404 when changing language
+for (const locale of POSSIBLE_LOCALES) {
+  routes.push({
+    path: locale,
+    component: EmptyComponent
+  })
+}
+
+routes.push({
+  path: '**',
+  loadChildren: () => import('./+page-not-found/page-not-found.module').then(m => m.PageNotFoundModule)
+})
 
 @NgModule({
-  imports: [ RouterModule.forRoot(routes) ],
+  imports: [
+    RouterModule.forRoot(routes, {
+      useHash: Boolean(history.pushState) === false,
+      scrollPositionRestoration: 'disabled',
+      preloadingStrategy: PreloadSelectedModulesList,
+      anchorScrolling: 'disabled'
+    })
+  ],
+  providers: [
+    MenuGuards.guards,
+    PreloadSelectedModulesList,
+    { provide: RouteReuseStrategy, useClass: CustomReuseStrategy }
+  ],
   exports: [ RouterModule ]
 })
 export class AppRoutingModule {}
-