2021-04-11 21:59:30 +08:00
|
|
|
import {NgModule} from '@angular/core';
|
2018-12-10 05:33:52 +08:00
|
|
|
import {RouterModule, Routes, UrlMatchResult, UrlSegment} from '@angular/router';
|
2019-03-03 17:30:12 +08:00
|
|
|
import {LoginComponent} from './ui/login/login.component';
|
|
|
|
import {GalleryComponent} from './ui/gallery/gallery.component';
|
|
|
|
import {AdminComponent} from './ui/admin/admin.component';
|
|
|
|
import {ShareLoginComponent} from './ui/sharelogin/share-login.component';
|
2018-11-30 22:36:42 +08:00
|
|
|
import {QueryParams} from '../../common/QueryParams';
|
2019-03-03 17:30:12 +08:00
|
|
|
import {DuplicateComponent} from './ui/duplicates/duplicates.component';
|
|
|
|
import {FacesComponent} from './ui/faces/faces.component';
|
2020-01-08 05:17:54 +08:00
|
|
|
import {AuthGuard} from './model/network/helper/auth.guard';
|
2021-05-29 03:01:59 +08:00
|
|
|
import {AlbumsComponent} from './ui/albums/albums.component';
|
2016-12-27 06:36:38 +08:00
|
|
|
|
2018-12-10 05:33:52 +08:00
|
|
|
export function galleryMatcherFunction(
|
|
|
|
segments: UrlSegment[]): UrlMatchResult | null {
|
|
|
|
|
|
|
|
|
|
|
|
if (segments.length === 0) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
const path = segments[0].path;
|
|
|
|
|
|
|
|
const posParams: { [key: string]: UrlSegment } = {};
|
|
|
|
if (path === 'gallery') {
|
|
|
|
if (segments.length > 1) {
|
|
|
|
posParams[QueryParams.gallery.directory] = segments[1];
|
|
|
|
}
|
|
|
|
return {consumed: segments.slice(0, Math.min(segments.length, 2)), posParams};
|
|
|
|
}
|
|
|
|
if (path === 'search') {
|
|
|
|
if (segments.length > 1) {
|
2021-01-31 19:22:56 +08:00
|
|
|
posParams[QueryParams.gallery.search.query] = segments[1];
|
2018-12-10 05:33:52 +08:00
|
|
|
}
|
|
|
|
return {consumed: segments.slice(0, Math.min(segments.length, 2)), posParams};
|
|
|
|
}
|
|
|
|
if (path === 'share') {
|
|
|
|
if (segments.length > 1) {
|
2020-01-08 05:17:54 +08:00
|
|
|
posParams[QueryParams.gallery.sharingKey_params] = segments[1];
|
2018-12-10 05:33:52 +08:00
|
|
|
}
|
|
|
|
return {consumed: segments.slice(0, Math.min(segments.length, 2)), posParams};
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
2020-01-08 05:17:54 +08:00
|
|
|
|
2021-04-11 21:59:30 +08:00
|
|
|
const routes: Routes = [
|
2017-06-11 04:32:56 +08:00
|
|
|
{
|
|
|
|
path: 'login',
|
|
|
|
component: LoginComponent
|
|
|
|
},
|
2017-07-04 01:17:49 +08:00
|
|
|
{
|
|
|
|
path: 'shareLogin',
|
|
|
|
component: ShareLoginComponent
|
|
|
|
},
|
2017-06-11 04:32:56 +08:00
|
|
|
{
|
|
|
|
path: 'admin',
|
2020-01-08 05:17:54 +08:00
|
|
|
component: AdminComponent,
|
|
|
|
canActivate: [AuthGuard]
|
2017-06-11 04:32:56 +08:00
|
|
|
},
|
2019-01-18 07:26:20 +08:00
|
|
|
{
|
|
|
|
path: 'duplicates',
|
2020-01-08 05:17:54 +08:00
|
|
|
component: DuplicateComponent,
|
|
|
|
canActivate: [AuthGuard]
|
2019-01-18 07:26:20 +08:00
|
|
|
},
|
2021-05-29 03:01:59 +08:00
|
|
|
{
|
|
|
|
path: 'albums',
|
|
|
|
component: AlbumsComponent,
|
|
|
|
canActivate: [AuthGuard]
|
|
|
|
},
|
2019-02-15 07:25:55 +08:00
|
|
|
{
|
|
|
|
path: 'faces',
|
2020-01-08 05:17:54 +08:00
|
|
|
component: FacesComponent,
|
|
|
|
canActivate: [AuthGuard]
|
2019-02-15 07:25:55 +08:00
|
|
|
},
|
2017-06-11 04:32:56 +08:00
|
|
|
{
|
2018-12-10 05:33:52 +08:00
|
|
|
matcher: galleryMatcherFunction,
|
2020-01-08 05:17:54 +08:00
|
|
|
component: GalleryComponent,
|
|
|
|
canActivate: [AuthGuard]
|
2017-07-04 01:17:49 +08:00
|
|
|
},
|
2017-07-21 03:06:48 +08:00
|
|
|
{path: '', redirectTo: '/login', pathMatch: 'full'},
|
|
|
|
{path: '**', redirectTo: '/login', pathMatch: 'full'}
|
2016-12-27 06:36:38 +08:00
|
|
|
];
|
|
|
|
|
|
|
|
|
2021-04-11 21:59:30 +08:00
|
|
|
@NgModule({
|
|
|
|
imports: [RouterModule.forRoot(routes)],
|
|
|
|
exports: [RouterModule]
|
|
|
|
})
|
|
|
|
export class AppRoutingModule {
|
|
|
|
}
|