import { NgModule } from '@angular/core'
-import { RouterModule, Routes } from '@angular/router'
-
+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 { POSSIBLE_LOCALES } from '@shared/core-utils/i18n'
import { PreloadSelectedModulesList } from './core'
+import { EmptyComponent } from './empty.component'
const routes: Routes = [
{
path: 'admin',
- loadChildren: './+admin/admin.module#AdminModule'
+ canActivate: [ MenuGuards.close() ],
+ canDeactivate: [ MenuGuards.open() ],
+ loadChildren: () => import('./+admin/admin.module').then(m => m.AdminModule)
},
{
path: 'my-account',
- loadChildren: './+my-account/my-account.module#MyAccountModule'
+ 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: './+accounts/accounts.module#AccountsModule'
+ loadChildren: () => import('./+accounts/accounts.module').then(m => m.AccountsModule)
},
{
path: 'video-channels',
- loadChildren: './+video-channels/video-channels.module#VideoChannelsModule'
+ loadChildren: () => import('./+video-channels/video-channels.module').then(m => m.VideoChannelsModule)
},
{
path: 'about',
- loadChildren: './+about/about.module#AboutModule'
+ 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: '**',
- loadChildren: './+page-not-found/page-not-found.module#PageNotFoundModule'
+ path: 'search',
+ loadChildren: () => import('./+search/search.module').then(m => m.SearchModule)
+ },
+ {
+ path: 'videos',
+ loadChildren: () => import('./+videos/videos.module').then(m => m.VideosModule)
+ },
+ {
+ path: 'remote-interaction',
+ loadChildren: () => import('./+remote-interaction/remote-interaction.module').then(m => m.RemoteInteractionModule)
+ },
+ {
+ path: 'video-playlists/watch',
+ redirectTo: 'videos/watch/playlist'
+ },
+ {
+ 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, {
useHash: Boolean(history.pushState) === false,
- preloadingStrategy: PreloadSelectedModulesList
+ scrollPositionRestoration: 'disabled',
+ preloadingStrategy: PreloadSelectedModulesList,
+ anchorScrolling: 'disabled'
})
],
providers: [
- PreloadSelectedModulesList
+ MenuGuards.guards,
+ PreloadSelectedModulesList,
+ { provide: RouteReuseStrategy, useClass: CustomReuseStrategy }
],
exports: [ RouterModule ]
})