feat(router): add support for CanActivate guard
This commit is contained in:
@ -2,17 +2,19 @@ import { RouterStateCandidate, ActivatedRouteCandidate, RouterState, ActivatedRo
|
||||
import { TreeNode } from './utils/tree';
|
||||
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
|
||||
|
||||
export function createRouterState(curr: RouterStateCandidate, prev: RouterStateCandidate, prevState: RouterState): RouterState {
|
||||
const root = createNode(curr._root, prev ? prev._root : null, prevState ? prevState._root : null);
|
||||
export function createRouterState(curr: RouterStateCandidate, prevState: RouterState): RouterState {
|
||||
const root = createNode(curr._root, prevState ? prevState._root : null);
|
||||
const queryParams = prevState ? prevState.queryParams : new BehaviorSubject(curr.queryParams);
|
||||
const fragment = prevState ? prevState.fragment : new BehaviorSubject(curr.fragment);
|
||||
return new RouterState(root, queryParams, fragment);
|
||||
return new RouterState(root, queryParams, fragment, curr);
|
||||
}
|
||||
|
||||
function createNode(curr:TreeNode<ActivatedRouteCandidate>, prev?:TreeNode<ActivatedRouteCandidate>, prevState?:TreeNode<ActivatedRoute>):TreeNode<ActivatedRoute> {
|
||||
if (prev && equalRouteCandidates(prev.value, curr.value)) {
|
||||
function createNode(curr:TreeNode<ActivatedRouteCandidate>, prevState?:TreeNode<ActivatedRoute>):TreeNode<ActivatedRoute> {
|
||||
if (prevState && equalRouteCandidates(prevState.value.candidate, curr.value)) {
|
||||
const value = prevState.value;
|
||||
const children = createOrReuseChildren(curr, prev, prevState);
|
||||
value.candidate = curr.value;
|
||||
|
||||
const children = createOrReuseChildren(curr, prevState);
|
||||
return new TreeNode<ActivatedRoute>(value, children);
|
||||
|
||||
} else {
|
||||
@ -22,11 +24,11 @@ function createNode(curr:TreeNode<ActivatedRouteCandidate>, prev?:TreeNode<Activ
|
||||
}
|
||||
}
|
||||
|
||||
function createOrReuseChildren(curr:TreeNode<ActivatedRouteCandidate>, prev:TreeNode<ActivatedRouteCandidate>, prevState:TreeNode<ActivatedRoute>) {
|
||||
function createOrReuseChildren(curr:TreeNode<ActivatedRouteCandidate>, prevState:TreeNode<ActivatedRoute>) {
|
||||
return curr.children.map(child => {
|
||||
const index = prev.children.findIndex(p => equalRouteCandidates(p.value, child.value));
|
||||
const index = prevState.children.findIndex(p => equalRouteCandidates(p.value.candidate, child.value));
|
||||
if (index >= 0) {
|
||||
return createNode(child, prev.children[index], prevState.children[index]);
|
||||
return createNode(child, prevState.children[index]);
|
||||
} else {
|
||||
return createNode(child);
|
||||
}
|
||||
@ -34,7 +36,7 @@ function createOrReuseChildren(curr:TreeNode<ActivatedRouteCandidate>, prev:Tree
|
||||
}
|
||||
|
||||
function createActivatedRoute(c:ActivatedRouteCandidate) {
|
||||
return new ActivatedRoute(new BehaviorSubject(c.urlSegments), new BehaviorSubject(c.params), c.outlet, c.component);
|
||||
return new ActivatedRoute(new BehaviorSubject(c.urlSegments), new BehaviorSubject(c.params), c.outlet, c.component, c);
|
||||
}
|
||||
|
||||
function equalRouteCandidates(a: ActivatedRouteCandidate, b: ActivatedRouteCandidate): boolean {
|
||||
|
Reference in New Issue
Block a user