
BREACKING CHANGE: Before: @Directive({properties: ['one'], events: ['two']}) After: @Directive({inputs: ['one'], outputs: ['two']}) Before: @Component({properties: ['one'], events: ['two']}) After: @Componet({inputs: ['one'], outputs: ['two']}) Before: class A {@Property() one; @Event() two;} After: class A {@Input() one; @Output() two;}
73 lines
2.4 KiB
TypeScript
73 lines
2.4 KiB
TypeScript
import {Directive} from '../core/metadata';
|
|
import {StringMap, StringMapWrapper} from 'angular2/src/core/facade/collection';
|
|
|
|
import {Router} from './router';
|
|
import {Location} from './location';
|
|
import {Instruction, stringifyInstruction} from './instruction';
|
|
|
|
/**
|
|
* The RouterLink directive lets you link to specific parts of your app.
|
|
*
|
|
* Consider the following route configuration:
|
|
|
|
* ```
|
|
* @RouteConfig([
|
|
* { path: '/user', component: UserCmp, as: 'user' }
|
|
* ]);
|
|
* class MyComp {}
|
|
* ```
|
|
*
|
|
* When linking to this `user` route, you can write:
|
|
*
|
|
* ```
|
|
* <a [router-link]="['./user']">link to user component</a>
|
|
* ```
|
|
*
|
|
* RouterLink expects the value to be an array of route names, followed by the params
|
|
* for that level of routing. For instance `['/team', {teamId: 1}, 'user', {userId: 2}]`
|
|
* means that we want to generate a link for the `team` route with params `{teamId: 1}`,
|
|
* and with a child route `user` with params `{userId: 2}`.
|
|
*
|
|
* The first route name should be prepended with `/`, `./`, or `../`.
|
|
* If the route begins with `/`, the router will look up the route from the root of the app.
|
|
* If the route begins with `./`, the router will instead look in the current component's
|
|
* children for the route. And if the route begins with `../`, the router will look at the
|
|
* current component's parent.
|
|
*/
|
|
@Directive({
|
|
selector: '[router-link]',
|
|
inputs: ['routeParams: routerLink'],
|
|
host: {
|
|
'(click)': 'onClick()',
|
|
'[attr.href]': 'visibleHref',
|
|
'[class.router-link-active]': 'isRouteActive'
|
|
}
|
|
})
|
|
export class RouterLink {
|
|
private _routeParams: any[];
|
|
|
|
// the url displayed on the anchor element.
|
|
visibleHref: string;
|
|
|
|
// the instruction passed to the router to navigate
|
|
private _navigationInstruction: Instruction;
|
|
|
|
constructor(private _router: Router, private _location: Location) {}
|
|
|
|
get isRouteActive(): boolean { return this._router.isRouteActive(this._navigationInstruction); }
|
|
|
|
set routeParams(changes: any[]) {
|
|
this._routeParams = changes;
|
|
this._navigationInstruction = this._router.generate(this._routeParams);
|
|
|
|
// TODO: is this the right spot for this?
|
|
var navigationHref = '/' + stringifyInstruction(this._navigationInstruction);
|
|
this.visibleHref = this._location.normalizeAbsolutely(navigationHref);
|
|
}
|
|
|
|
onClick(): boolean {
|
|
this._router.navigateByInstruction(this._navigationInstruction);
|
|
return false;
|
|
}
|
|
}
|