1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2025-01-14 14:43:17 +08:00

history navigation i,proved

This commit is contained in:
Braun Patrik 2016-03-27 21:21:47 +02:00
parent f8db033c56
commit 5ce3f0bcb8
5 changed files with 19 additions and 14 deletions

View File

@ -18,7 +18,7 @@ import {GeneratedUrl} from "angular2/src/router/rules/route_paths/route_path";
@Component({ @Component({
selector: 'pi-gallery2-app', selector: 'pi-gallery2-app',
template: `<router-outlet></router-outlet>`, template: `<router-outlet></router-outlet>`,
directives: [ROUTER_DIRECTIVES], directives: [ROUTER_DIRECTIVES, RouterLink],
providers: [ providers: [
HTTP_PROVIDERS, HTTP_PROVIDERS,
ROUTER_PROVIDERS, ROUTER_PROVIDERS,
@ -35,10 +35,15 @@ import {GeneratedUrl} from "angular2/src/router/rules/route_paths/route_path";
useAsDefault: true useAsDefault: true
}, },
{ {
regex: '/gallery(/([\S]*))?', path: '/gallery',
name: 'GalleryBase',
component: GalleryComponent
},
{
regex: 'gallery/([\w]*)',
name: 'Gallery', name: 'Gallery',
serializer: (params): GeneratedUrl => { serializer: (params): GeneratedUrl => {
return new GeneratedUrl(`/gallery/${params['directory']}`, {}) return new GeneratedUrl(`gallery/${params['directory']}`, {})
}, },
component: GalleryComponent component: GalleryComponent
} }
@ -46,13 +51,14 @@ import {GeneratedUrl} from "angular2/src/router/rules/route_paths/route_path";
export class AppComponent implements OnInit{ export class AppComponent implements OnInit{
constructor(private _router: Router, private _location:Location, private _authenticationService: AuthenticationService){ constructor(private _router: Router, private _location:Location, private _authenticationService: AuthenticationService){
} }
ngOnInit() { ngOnInit() {
this._authenticationService.OnAuthenticated.on((user:User) => this._authenticationService.OnAuthenticated.on((user:User) =>
{ {
this._location.replaceState('/'); // clears browser history so they can't navigate with back button // this._location.replaceState('/'); // clears browser history so they can't navigate with back button
this._router.navigate(["Gallery",{directory:"/"}]); this._router.navigate(["GalleryBase"]);
}); });
} }

View File

@ -1 +1 @@
<a [routerLink]="['Gallery',{directory: getDirectoryPath()}]">{{directory.name}}</a> <a [routerLink]="['/Gallery',{directory: getDirectoryPath()}]">{{directory.name}}</a>

View File

@ -24,16 +24,15 @@ export class GalleryComponent implements OnInit{
private _authService: AuthenticationService, private _authService: AuthenticationService,
private _router: Router, private _router: Router,
private _location:Location) { private _location:Location) {
} }
ngOnInit(){ ngOnInit(){
if (!this._authService.isAuthenticated()) { if (!this._authService.isAuthenticated()) {
this._location.replaceState('/'); // clears browser history so they can't navigate with back button // this._location.replaceState('/'); // clears browser history so they can't navigate with back button
this._router.navigate(['Login']); this._router.navigate(['Login']);
return; return;
} }
console.log(this._params.get('directory'));
let directoryName = this._params.get('directory'); let directoryName = this._params.get('directory');
directoryName = directoryName ? directoryName : ""; directoryName = directoryName ? directoryName : "";
this._galleryService.getDirectory(directoryName).then(( message:Message<Directory>) => { this._galleryService.getDirectory(directoryName).then(( message:Message<Directory>) => {

View File

@ -18,7 +18,7 @@ export class LoginComponent implements OnInit{
ngOnInit(){ ngOnInit(){
if (this._authService.isAuthenticated()) { if (this._authService.isAuthenticated()) {
this._location.replaceState('/'); // clears browser history so they can't navigate with back button // this._location.replaceState('/'); // clears browser history so they can't navigate with back button
this._router.navigate(['Gallery']); this._router.navigate(['Gallery']);
} }
} }

View File

@ -43,6 +43,6 @@
<body> <body>
<pi-gallery2-app>Loading...</pi-gallery2-app> <pi-gallery2-app>Loading...</pi-gallery2-app>
</body> </body>
<script src="https://code.angularjs.org/2.0.0-beta.10/angular2-polyfills.js"></script> <script src="https://code.angularjs.org/2.0.0-beta.12/angular2-polyfills.js"></script>
<script src="dist/app-bundle.js"></script> <script src="dist/app-bundle.js"></script>
</html> </html>