import { NgModule } from '@angular/core'
-import { Routes, RouterModule, PreloadAllModules } from '@angular/router'
+import { RouteReuseStrategy, RouterModule, Routes } from '@angular/router'
+
+import { PreloadSelectedModulesList } from './core'
+import { AppComponent } from '@app/app.component'
+import { CustomReuseStrategy } from '@app/core/routing/custom-reuse-strategy'
const routes: Routes = [
+ {
+ path: 'admin',
+ loadChildren: () => import('./+admin/admin.module').then(m => m.AdminModule)
+ },
+ {
+ path: 'my-account',
+ loadChildren: () => import('./+my-account/my-account.module').then(m => m.MyAccountModule)
+ },
+ {
+ 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: '',
- redirectTo: '/videos/list',
- pathMatch: 'full'
+ component: AppComponent // Avoid 404, app component will redirect dynamically
},
{
- path: 'admin',
- loadChildren: './+admin#AdminModule'
+ path: '**',
+ loadChildren: () => import('./+page-not-found/page-not-found.module').then(m => m.PageNotFoundModule)
}
]
imports: [
RouterModule.forRoot(routes, {
useHash: Boolean(history.pushState) === false,
- preloadingStrategy: PreloadAllModules
+ scrollPositionRestoration: 'disabled',
+ preloadingStrategy: PreloadSelectedModulesList,
+ anchorScrolling: 'disabled'
})
],
+ providers: [
+ PreloadSelectedModulesList,
+ { provide: RouteReuseStrategy, useClass: CustomReuseStrategy }
+ ],
exports: [ RouterModule ]
})
export class AppRoutingModule {}