Socket
Socket
Sign inDemoInstall

@angular/router

Package Overview
Dependencies
6
Maintainers
1
Versions
826
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 3.0.0-alpha.3 to 3.0.0-alpha.4

11

apply_redirects.d.ts
import { Observable } from 'rxjs/Observable';
import { Route, RouterConfig } from './config';
import { UrlSegment, UrlTree } from './url_tree';
import { TreeNode } from './utils/tree';
import { RouterConfig } from './config';
import { UrlTree } from './url_tree';
export declare function applyRedirects(urlTree: UrlTree, config: RouterConfig): Observable<UrlTree>;
export declare function match(route: Route, url: TreeNode<UrlSegment>): {
consumedUrlSegments: any[];
lastSegment: TreeNode<UrlSegment>;
lastParent: TreeNode<UrlSegment>;
positionalParamSegments: {};
};

199

apply_redirects.js

@@ -6,6 +6,6 @@ "use strict";

var url_tree_1 = require('./url_tree');
var collection_1 = require('./utils/collection');
var tree_1 = require('./utils/tree');
var NoMatch = (function () {
function NoMatch() {
function NoMatch(segment) {
if (segment === void 0) { segment = null; }
this.segment = segment;
}

@@ -15,4 +15,4 @@ return NoMatch;

var GlobalRedirect = (function () {
function GlobalRedirect(segments) {
this.segments = segments;
function GlobalRedirect(paths) {
this.paths = paths;
}

@@ -23,11 +23,10 @@ return GlobalRedirect;

try {
var transformedChildren = urlTree._root.children.map(function (c) { return applyNode(config, c); });
return createUrlTree(urlTree, transformedChildren);
return createUrlTree(urlTree, expandSegment(config, urlTree.root, shared_1.PRIMARY_OUTLET));
}
catch (e) {
if (e instanceof GlobalRedirect) {
return createUrlTree(urlTree, [constructNodes(e.segments, [], [])]);
return createUrlTree(urlTree, new url_tree_1.UrlSegment([], (_a = {}, _a[shared_1.PRIMARY_OUTLET] = new url_tree_1.UrlSegment(e.paths, {}), _a)));
}
else if (e instanceof NoMatch) {
return new Observable_1.Observable(function (obs) { return obs.error(new Error('Cannot match any routes')); });
return new Observable_1.Observable(function (obs) { return obs.error(new Error("Cannot match any routes: '" + e.segment + "'")); });
}

@@ -38,13 +37,24 @@ else {

}
var _a;
}
exports.applyRedirects = applyRedirects;
function createUrlTree(urlTree, children) {
var transformedRoot = new tree_1.TreeNode(urlTree.root, children);
return of_1.of(new url_tree_1.UrlTree(transformedRoot, urlTree.queryParams, urlTree.fragment));
function createUrlTree(urlTree, root) {
return of_1.of(new url_tree_1.UrlTree(root, urlTree.queryParams, urlTree.fragment));
}
function applyNode(config, url) {
for (var _i = 0, config_1 = config; _i < config_1.length; _i++) {
var r = config_1[_i];
function expandSegment(routes, segment, outlet) {
if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {
return new url_tree_1.UrlSegment([], expandSegmentChildren(routes, segment));
}
else {
return expandPathsWithParams(segment, routes, segment.pathsWithParams, outlet, true);
}
}
function expandSegmentChildren(routes, segment) {
return url_tree_1.mapChildren(segment, function (child, childOutlet) { return expandSegment(routes, child, childOutlet); });
}
function expandPathsWithParams(segment, routes, paths, outlet, allowRedirects) {
for (var _i = 0, routes_1 = routes; _i < routes_1.length; _i++) {
var r = routes_1[_i];
try {
return matchNode(config, r, url);
return expandPathsWithParamsAgainstRoute(segment, routes, r, paths, outlet, allowRedirects);
}

@@ -56,87 +66,112 @@ catch (e) {

}
throw new NoMatch();
throw new NoMatch(segment);
}
function matchNode(config, route, url) {
if (!route.path)
function expandPathsWithParamsAgainstRoute(segment, routes, route, paths, outlet, allowRedirects) {
if ((route.outlet ? route.outlet : shared_1.PRIMARY_OUTLET) !== outlet)
throw new NoMatch();
if ((route.outlet ? route.outlet : shared_1.PRIMARY_OUTLET) !== url.value.outlet) {
if (route.redirectTo && !allowRedirects)
throw new NoMatch();
if (route.redirectTo) {
return expandPathsWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet);
}
else {
return matchPathsWithParamsAgainstRoute(segment, route, paths);
}
}
function expandPathsWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet) {
if (route.path === '**') {
var newSegments_1 = applyRedirectCommands([], route.redirectTo, {});
return constructNodes(newSegments_1, [], []);
return expandWildCardWithParamsAgainstRouteUsingRedirect(route);
}
var m = match(route, url);
if (!m)
throw new NoMatch();
var consumedUrlSegments = m.consumedUrlSegments, lastSegment = m.lastSegment, lastParent = m.lastParent, positionalParamSegments = m.positionalParamSegments;
var newSegments = applyRedirectCommands(consumedUrlSegments, route.redirectTo, positionalParamSegments);
var childConfig = route.children ? route.children : [];
var transformedChildren = lastSegment.children.map(function (c) { return applyNode(childConfig, c); });
var secondarySubtrees = lastParent ? lastParent.children.slice(1) : [];
var transformedSecondarySubtrees = secondarySubtrees.map(function (c) { return applyNode(config, c); });
return constructNodes(newSegments, transformedChildren, transformedSecondarySubtrees);
else {
return expandRegularPathWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet);
}
}
function match(route, url) {
function expandWildCardWithParamsAgainstRouteUsingRedirect(route) {
var newPaths = applyRedirectCommands([], route.redirectTo, {});
if (route.redirectTo.startsWith('/')) {
throw new GlobalRedirect(newPaths);
}
else {
return new url_tree_1.UrlSegment(newPaths, {});
}
}
function expandRegularPathWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet) {
var _a = match(segment, route, paths), consumedPaths = _a.consumedPaths, lastChild = _a.lastChild, positionalParamSegments = _a.positionalParamSegments;
var newPaths = applyRedirectCommands(consumedPaths, route.redirectTo, positionalParamSegments);
if (route.redirectTo.startsWith('/')) {
throw new GlobalRedirect(newPaths);
}
else {
return expandPathsWithParams(segment, routes, newPaths.concat(paths.slice(lastChild)), outlet, false);
}
}
function matchPathsWithParamsAgainstRoute(segment, route, paths) {
if (route.path === '**') {
return new url_tree_1.UrlSegment(paths, {});
}
else {
var _a = match(segment, route, paths), consumedPaths = _a.consumedPaths, lastChild = _a.lastChild;
var childConfig = route.children ? route.children : [];
var slicedPath = paths.slice(lastChild);
if (childConfig.length === 0 && slicedPath.length === 0) {
return new url_tree_1.UrlSegment(consumedPaths, {});
}
else if (slicedPath.length === 0 && Object.keys(segment.children).length > 0) {
var children = expandSegmentChildren(childConfig, segment);
return new url_tree_1.UrlSegment(consumedPaths, children);
}
else {
var cs = expandPathsWithParams(segment, childConfig, slicedPath, shared_1.PRIMARY_OUTLET, true);
return new url_tree_1.UrlSegment(consumedPaths.concat(cs.pathsWithParams), cs.children);
}
}
}
function match(segment, route, paths) {
if (route.index || route.path === '' || route.path === '/') {
if (route.terminal && (Object.keys(segment.children).length > 0 || paths.length > 0)) {
throw new NoMatch();
}
else {
return { consumedPaths: [], lastChild: 0, positionalParamSegments: {} };
}
}
var path = route.path.startsWith('/') ? route.path.substring(1) : route.path;
var parts = path.split('/');
var positionalParamSegments = {};
var consumedUrlSegments = [];
var lastParent = null;
var lastSegment = null;
var current = url;
var consumedPaths = [];
var currentIndex = 0;
for (var i = 0; i < parts.length; ++i) {
if (!current)
return null;
if (currentIndex >= paths.length)
throw new NoMatch();
var current = paths[currentIndex];
var p = parts[i];
var isLastSegment = i === parts.length - 1;
var isLastParent = i === parts.length - 2;
var isPosParam = p.startsWith(':');
if (!isPosParam && p != current.value.path)
return null;
if (isLastSegment) {
lastSegment = current;
}
if (isLastParent) {
lastParent = current;
}
if (!isPosParam && p !== current.path)
throw new NoMatch();
if (isPosParam) {
positionalParamSegments[p.substring(1)] = current.value;
positionalParamSegments[p.substring(1)] = current;
}
consumedUrlSegments.push(current.value);
current = collection_1.first(current.children);
consumedPaths.push(current);
currentIndex++;
}
if (!lastSegment)
throw 'Cannot be reached';
return { consumedUrlSegments: consumedUrlSegments, lastSegment: lastSegment, lastParent: lastParent, positionalParamSegments: positionalParamSegments };
}
exports.match = match;
function constructNodes(segments, children, secondary) {
var prevChildren = children;
for (var i = segments.length - 1; i >= 0; --i) {
if (i === segments.length - 2) {
prevChildren = [new tree_1.TreeNode(segments[i], prevChildren.concat(secondary))];
}
else {
prevChildren = [new tree_1.TreeNode(segments[i], prevChildren)];
}
if (route.terminal && (Object.keys(segment.children).length > 0 || currentIndex < paths.length)) {
throw new NoMatch();
}
return prevChildren[0];
return { consumedPaths: consumedPaths, lastChild: currentIndex, positionalParamSegments: positionalParamSegments };
}
function applyRedirectCommands(segments, redirectTo, posParams) {
if (!redirectTo)
return segments;
function applyRedirectCommands(paths, redirectTo, posParams) {
if (redirectTo.startsWith('/')) {
var parts = redirectTo.substring(1).split('/');
throw new GlobalRedirect(createSegments(redirectTo, parts, segments, posParams));
return createPaths(redirectTo, parts, paths, posParams);
}
else {
return createSegments(redirectTo, redirectTo.split('/'), segments, posParams);
var parts = redirectTo.split('/');
return createPaths(redirectTo, parts, paths, posParams);
}
}
function createSegments(redirectTo, parts, segments, posParams) {
return parts.map(function (p) { return p.startsWith(':') ? findPosParamSegment(p, posParams, redirectTo) :
findOrCreateSegment(p, segments); });
function createPaths(redirectTo, parts, segments, posParams) {
return parts.map(function (p) { return p.startsWith(':') ? findPosParam(p, posParams, redirectTo) :
findOrCreatePath(p, segments); });
}
function findPosParamSegment(part, posParams, redirectTo) {
function findPosParam(part, posParams, redirectTo) {
var paramName = part.substring(1);

@@ -148,13 +183,13 @@ var pos = posParams[paramName];

}
function findOrCreateSegment(part, segments) {
var matchingIndex = segments.findIndex(function (s) { return s.path === part; });
function findOrCreatePath(part, paths) {
var matchingIndex = paths.findIndex(function (s) { return s.path === part; });
if (matchingIndex > -1) {
var r = segments[matchingIndex];
segments.splice(matchingIndex);
var r = paths[matchingIndex];
paths.splice(matchingIndex);
return r;
}
else {
return new url_tree_1.UrlSegment(part, {}, shared_1.PRIMARY_OUTLET);
return new url_tree_1.UrlPathWithParams(part, {});
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apply_redirects.js","sourceRoot":"","sources":["../src/apply_redirects.ts"],"names":[],"mappings":"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","sourcesContent":["import {Observable} from 'rxjs/Observable';\nimport {of } from 'rxjs/observable/of';\n\nimport {Route, RouterConfig} from './config';\nimport {PRIMARY_OUTLET} from './shared';\nimport {UrlSegment, UrlTree} from './url_tree';\nimport {first} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nclass NoMatch {}\nclass GlobalRedirect {\n  constructor(public segments: UrlSegment[]) {}\n}\n\nexport function applyRedirects(urlTree: UrlTree, config: RouterConfig): Observable<UrlTree> {\n  try {\n    const transformedChildren = urlTree._root.children.map(c => applyNode(config, c));\n    return createUrlTree(urlTree, transformedChildren);\n  } catch (e) {\n    if (e instanceof GlobalRedirect) {\n      return createUrlTree(urlTree, [constructNodes(e.segments, [], [])]);\n    } else if (e instanceof NoMatch) {\n      return new Observable<UrlTree>(obs => obs.error(new Error('Cannot match any routes')));\n    } else {\n      return new Observable<UrlTree>(obs => obs.error(e));\n    }\n  }\n}\n\nfunction createUrlTree(urlTree: UrlTree, children: TreeNode<UrlSegment>[]): Observable<UrlTree> {\n  const transformedRoot = new TreeNode<UrlSegment>(urlTree.root, children);\n  return of (new UrlTree(transformedRoot, urlTree.queryParams, urlTree.fragment));\n}\n\nfunction applyNode(config: Route[], url: TreeNode<UrlSegment>): TreeNode<UrlSegment> {\n  for (let r of config) {\n    try {\n      return matchNode(config, r, url);\n    } catch (e) {\n      if (!(e instanceof NoMatch)) throw e;\n    }\n  }\n  throw new NoMatch();\n}\n\nfunction matchNode(config: Route[], route: Route, url: TreeNode<UrlSegment>): TreeNode<UrlSegment> {\n  if (!route.path) throw new NoMatch();\n  if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== url.value.outlet) {\n    throw new NoMatch();\n  }\n\n  if (route.path === '**') {\n    const newSegments = applyRedirectCommands([], route.redirectTo, {});\n    return constructNodes(newSegments, [], []);\n  }\n\n  const m = match(route, url);\n  if (!m) throw new NoMatch();\n  const {consumedUrlSegments, lastSegment, lastParent, positionalParamSegments} = m;\n\n  const newSegments =\n      applyRedirectCommands(consumedUrlSegments, route.redirectTo, positionalParamSegments);\n\n  const childConfig = route.children ? route.children : [];\n  const transformedChildren = lastSegment.children.map(c => applyNode(childConfig, c));\n\n  const secondarySubtrees = lastParent ? lastParent.children.slice(1) : [];\n  const transformedSecondarySubtrees = secondarySubtrees.map(c => applyNode(config, c));\n\n  return constructNodes(newSegments, transformedChildren, transformedSecondarySubtrees);\n}\n\nexport function match(route: Route, url: TreeNode<UrlSegment>) {\n  const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;\n  const parts = path.split('/');\n  const positionalParamSegments = {};\n  const consumedUrlSegments = [];\n\n  let lastParent: TreeNode<UrlSegment>|null = null;\n  let lastSegment: TreeNode<UrlSegment>|null = null;\n\n  let current: TreeNode<UrlSegment>|null = url;\n  for (let i = 0; i < parts.length; ++i) {\n    if (!current) return null;\n\n    const p = parts[i];\n    const isLastSegment = i === parts.length - 1;\n    const isLastParent = i === parts.length - 2;\n    const isPosParam = p.startsWith(':');\n\n    if (!isPosParam && p != current.value.path) return null;\n    if (isLastSegment) {\n      lastSegment = current;\n    }\n    if (isLastParent) {\n      lastParent = current;\n    }\n    if (isPosParam) {\n      positionalParamSegments[p.substring(1)] = current.value;\n    }\n    consumedUrlSegments.push(current.value);\n    current = first(current.children);\n  }\n  if (!lastSegment) throw 'Cannot be reached';\n  return {consumedUrlSegments, lastSegment, lastParent, positionalParamSegments};\n}\n\nfunction constructNodes(\n    segments: UrlSegment[], children: TreeNode<UrlSegment>[],\n    secondary: TreeNode<UrlSegment>[]): TreeNode<UrlSegment> {\n  let prevChildren = children;\n  for (let i = segments.length - 1; i >= 0; --i) {\n    if (i === segments.length - 2) {\n      prevChildren = [new TreeNode<UrlSegment>(segments[i], prevChildren.concat(secondary))];\n    } else {\n      prevChildren = [new TreeNode<UrlSegment>(segments[i], prevChildren)];\n    }\n  }\n  return prevChildren[0];\n}\n\nfunction applyRedirectCommands(\n    segments: UrlSegment[], redirectTo: string,\n    posParams: {[k: string]: UrlSegment}): UrlSegment[] {\n  if (!redirectTo) return segments;\n\n  if (redirectTo.startsWith('/')) {\n    const parts = redirectTo.substring(1).split('/');\n    throw new GlobalRedirect(createSegments(redirectTo, parts, segments, posParams));\n  } else {\n    return createSegments(redirectTo, redirectTo.split('/'), segments, posParams);\n  }\n}\n\nfunction createSegments(\n    redirectTo: string, parts: string[], segments: UrlSegment[],\n    posParams: {[k: string]: UrlSegment}): UrlSegment[] {\n  return parts.map(\n      p => p.startsWith(':') ? findPosParamSegment(p, posParams, redirectTo) :\n                               findOrCreateSegment(p, segments));\n}\n\nfunction findPosParamSegment(\n    part: string, posParams: {[k: string]: UrlSegment}, redirectTo: string): UrlSegment {\n  const paramName = part.substring(1);\n  const pos = posParams[paramName];\n  if (!pos) throw new Error(`Cannot redirect to '${redirectTo}'. Cannot find '${part}'.`);\n  return pos;\n}\n\nfunction findOrCreateSegment(part: string, segments: UrlSegment[]): UrlSegment {\n  const matchingIndex = segments.findIndex(s => s.path === part);\n  if (matchingIndex > -1) {\n    const r = segments[matchingIndex];\n    segments.splice(matchingIndex);\n    return r;\n  } else {\n    return new UrlSegment(part, {}, PRIMARY_OUTLET);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apply_redirects.js","sourceRoot":"","sources":["../src/apply_redirects.ts"],"names":[],"mappings":"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","sourcesContent":["import {Observable} from 'rxjs/Observable';\nimport {of } from 'rxjs/observable/of';\n\nimport {Route, RouterConfig} from './config';\nimport {PRIMARY_OUTLET} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree, mapChildren} from './url_tree';\n\nclass NoMatch {\n  constructor(public segment: UrlSegment = null) {}\n}\nclass GlobalRedirect {\n  constructor(public paths: UrlPathWithParams[]) {}\n}\n\nexport function applyRedirects(urlTree: UrlTree, config: RouterConfig): Observable<UrlTree> {\n  try {\n    return createUrlTree(urlTree, expandSegment(config, urlTree.root, PRIMARY_OUTLET));\n  } catch (e) {\n    if (e instanceof GlobalRedirect) {\n      return createUrlTree(\n          urlTree, new UrlSegment([], {[PRIMARY_OUTLET]: new UrlSegment(e.paths, {})}));\n    } else if (e instanceof NoMatch) {\n      return new Observable<UrlTree>(\n          obs => obs.error(new Error(`Cannot match any routes: '${e.segment}'`)));\n    } else {\n      return new Observable<UrlTree>(obs => obs.error(e));\n    }\n  }\n}\n\nfunction createUrlTree(urlTree: UrlTree, root: UrlSegment): Observable<UrlTree> {\n  return of (new UrlTree(root, urlTree.queryParams, urlTree.fragment));\n}\n\nfunction expandSegment(routes: Route[], segment: UrlSegment, outlet: string): UrlSegment {\n  if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {\n    return new UrlSegment([], expandSegmentChildren(routes, segment));\n  } else {\n    return expandPathsWithParams(segment, routes, segment.pathsWithParams, outlet, true);\n  }\n}\n\nfunction expandSegmentChildren(routes: Route[], segment: UrlSegment): {[name: string]: UrlSegment} {\n  return mapChildren(segment, (child, childOutlet) => expandSegment(routes, child, childOutlet));\n}\n\nfunction expandPathsWithParams(\n    segment: UrlSegment, routes: Route[], paths: UrlPathWithParams[], outlet: string,\n    allowRedirects: boolean): UrlSegment {\n  for (let r of routes) {\n    try {\n      return expandPathsWithParamsAgainstRoute(segment, routes, r, paths, outlet, allowRedirects);\n    } catch (e) {\n      if (!(e instanceof NoMatch)) throw e;\n    }\n  }\n  throw new NoMatch(segment);\n}\n\nfunction expandPathsWithParamsAgainstRoute(\n    segment: UrlSegment, routes: Route[], route: Route, paths: UrlPathWithParams[], outlet: string,\n    allowRedirects: boolean): UrlSegment {\n  if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== outlet) throw new NoMatch();\n  if (route.redirectTo && !allowRedirects) throw new NoMatch();\n\n  if (route.redirectTo) {\n    return expandPathsWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet);\n  } else {\n    return matchPathsWithParamsAgainstRoute(segment, route, paths);\n  }\n}\n\nfunction expandPathsWithParamsAgainstRouteUsingRedirect(\n    segment: UrlSegment, routes: Route[], route: Route, paths: UrlPathWithParams[],\n    outlet: string): UrlSegment {\n  if (route.path === '**') {\n    return expandWildCardWithParamsAgainstRouteUsingRedirect(route);\n  } else {\n    return expandRegularPathWithParamsAgainstRouteUsingRedirect(\n        segment, routes, route, paths, outlet);\n  }\n}\n\nfunction expandWildCardWithParamsAgainstRouteUsingRedirect(route: Route): UrlSegment {\n  const newPaths = applyRedirectCommands([], route.redirectTo, {});\n  if (route.redirectTo.startsWith('/')) {\n    throw new GlobalRedirect(newPaths);\n  } else {\n    return new UrlSegment(newPaths, {});\n  }\n}\n\nfunction expandRegularPathWithParamsAgainstRouteUsingRedirect(\n    segment: UrlSegment, routes: Route[], route: Route, paths: UrlPathWithParams[],\n    outlet: string): UrlSegment {\n  const {consumedPaths, lastChild, positionalParamSegments} = match(segment, route, paths);\n  const newPaths =\n      applyRedirectCommands(consumedPaths, route.redirectTo, <any>positionalParamSegments);\n  if (route.redirectTo.startsWith('/')) {\n    throw new GlobalRedirect(newPaths);\n  } else {\n    return expandPathsWithParams(\n        segment, routes, newPaths.concat(paths.slice(lastChild)), outlet, false);\n  }\n}\n\nfunction matchPathsWithParamsAgainstRoute(\n    segment: UrlSegment, route: Route, paths: UrlPathWithParams[]): UrlSegment {\n  if (route.path === '**') {\n    return new UrlSegment(paths, {});\n  } else {\n    const {consumedPaths, lastChild} = match(segment, route, paths);\n    const childConfig = route.children ? route.children : [];\n    const slicedPath = paths.slice(lastChild);\n\n    if (childConfig.length === 0 && slicedPath.length === 0) {\n      return new UrlSegment(consumedPaths, {});\n\n      // TODO: check that the right segment is present\n    } else if (slicedPath.length === 0 && Object.keys(segment.children).length > 0) {\n      const children = expandSegmentChildren(childConfig, segment);\n      return new UrlSegment(consumedPaths, children);\n\n    } else {\n      const cs = expandPathsWithParams(segment, childConfig, slicedPath, PRIMARY_OUTLET, true);\n      return new UrlSegment(consumedPaths.concat(cs.pathsWithParams), cs.children);\n    }\n  }\n}\n\nfunction match(segment: UrlSegment, route: Route, paths: UrlPathWithParams[]) {\n  if (route.index || route.path === '' || route.path === '/') {\n    if (route.terminal && (Object.keys(segment.children).length > 0 || paths.length > 0)) {\n      throw new NoMatch();\n    } else {\n      return {consumedPaths: [], lastChild: 0, positionalParamSegments: {}};\n    }\n  }\n\n  const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;\n  const parts = path.split('/');\n  const positionalParamSegments = {};\n  const consumedPaths = [];\n\n  let currentIndex = 0;\n\n  for (let i = 0; i < parts.length; ++i) {\n    if (currentIndex >= paths.length) throw new NoMatch();\n    const current = paths[currentIndex];\n\n    const p = parts[i];\n    const isPosParam = p.startsWith(':');\n\n    if (!isPosParam && p !== current.path) throw new NoMatch();\n    if (isPosParam) {\n      positionalParamSegments[p.substring(1)] = current;\n    }\n    consumedPaths.push(current);\n    currentIndex++;\n  }\n\n  if (route.terminal && (Object.keys(segment.children).length > 0 || currentIndex < paths.length)) {\n    throw new NoMatch();\n  }\n\n  return {consumedPaths, lastChild: currentIndex, positionalParamSegments};\n}\n\nfunction applyRedirectCommands(\n    paths: UrlPathWithParams[], redirectTo: string,\n    posParams: {[k: string]: UrlPathWithParams}): UrlPathWithParams[] {\n  if (redirectTo.startsWith('/')) {\n    const parts = redirectTo.substring(1).split('/');\n    return createPaths(redirectTo, parts, paths, posParams);\n  } else {\n    const parts = redirectTo.split('/');\n    return createPaths(redirectTo, parts, paths, posParams);\n  }\n}\n\nfunction createPaths(\n    redirectTo: string, parts: string[], segments: UrlPathWithParams[],\n    posParams: {[k: string]: UrlPathWithParams}): UrlPathWithParams[] {\n  return parts.map(\n      p => p.startsWith(':') ? findPosParam(p, posParams, redirectTo) :\n                               findOrCreatePath(p, segments));\n}\n\nfunction findPosParam(\n    part: string, posParams: {[k: string]: UrlPathWithParams},\n    redirectTo: string): UrlPathWithParams {\n  const paramName = part.substring(1);\n  const pos = posParams[paramName];\n  if (!pos) throw new Error(`Cannot redirect to '${redirectTo}'. Cannot find '${part}'.`);\n  return pos;\n}\n\nfunction findOrCreatePath(part: string, paths: UrlPathWithParams[]): UrlPathWithParams {\n  const matchingIndex = paths.findIndex(s => s.path === part);\n  if (matchingIndex > -1) {\n    const r = paths[matchingIndex];\n    paths.splice(matchingIndex);\n    return r;\n  } else {\n    return new UrlPathWithParams(part, {});\n  }\n}\n"]}

@@ -0,2 +1,11 @@

import { Injector, OpaqueToken } from '@angular/core';
import { RouterConfig } from './config';
export declare function provideRouter(config: RouterConfig): any[];
import { Router } from './router';
export declare const ROUTER_CONFIG: OpaqueToken;
export declare const ROUTER_OPTIONS: OpaqueToken;
export interface ExtraOptions {
enableTracing?: boolean;
}
export declare function setupRouter(ref: any, resolver: any, urlSerializer: any, outletMap: any, location: any, injector: any, config: any, opts: any): Router;
export declare function setupRouterInitializer(injector: Injector): (_: any) => any;
export declare function provideRouter(_config: RouterConfig, _opts: ExtraOptions): any[];

@@ -8,44 +8,54 @@ "use strict";

var url_serializer_1 = require('./url_serializer');
function provideRouter(config) {
exports.ROUTER_CONFIG = new core_1.OpaqueToken('ROUTER_CONFIG');
exports.ROUTER_OPTIONS = new core_1.OpaqueToken('ROUTER_OPTIONS');
function setupRouter(ref, resolver, urlSerializer, outletMap, location, injector, config, opts) {
if (ref.componentTypes.length == 0) {
throw new Error('Bootstrap at least one component before injecting Router.');
}
var componentType = ref.componentTypes[0];
var r = new router_1.Router(componentType, resolver, urlSerializer, outletMap, location, injector, config);
ref.registerDisposeListener(function () { return r.dispose(); });
if (opts.enableTracing) {
r.events.subscribe(function (e) {
console.group("Router Event: " + e.constructor.name);
console.log(e.toString());
console.log(e);
console.groupEnd();
});
}
return r;
}
exports.setupRouter = setupRouter;
function setupRouterInitializer(injector) {
setTimeout(function (_) {
var appRef = injector.get(core_1.ApplicationRef);
if (appRef.componentTypes.length == 0) {
appRef.registerBootstrapListener(function (_) { injector.get(router_1.Router).initialNavigation(); });
}
else {
injector.get(router_1.Router).initialNavigation();
}
}, 0);
return function (_) { return null; };
}
exports.setupRouterInitializer = setupRouterInitializer;
function provideRouter(_config, _opts) {
return [
common_1.Location,
{ provide: common_1.LocationStrategy, useClass: common_1.PathLocationStrategy },
{ provide: exports.ROUTER_CONFIG, useValue: _config }, { provide: exports.ROUTER_OPTIONS, useValue: _opts },
common_1.Location, { provide: common_1.LocationStrategy, useClass: common_1.PathLocationStrategy },
{ provide: url_serializer_1.UrlSerializer, useClass: url_serializer_1.DefaultUrlSerializer },
{
provide: router_1.Router,
useFactory: function (ref, resolver, urlSerializer, outletMap, location, injector) {
if (ref.componentTypes.length == 0) {
throw new Error('Bootstrap at least one component before injecting Router.');
}
var componentType = ref.componentTypes[0];
var r = new router_1.Router(componentType, resolver, urlSerializer, outletMap, location, injector, config);
ref.registerDisposeListener(function () { return r.dispose(); });
return r;
},
deps: [core_1.ApplicationRef, core_1.ComponentResolver, url_serializer_1.UrlSerializer, router_outlet_map_1.RouterOutletMap, common_1.Location, core_1.Injector]
useFactory: setupRouter,
deps: [
core_1.ApplicationRef, core_1.ComponentResolver, url_serializer_1.UrlSerializer, router_outlet_map_1.RouterOutletMap, common_1.Location, core_1.Injector,
exports.ROUTER_CONFIG, exports.ROUTER_OPTIONS
]
},
router_outlet_map_1.RouterOutletMap,
{ provide: router_state_1.ActivatedRoute, useFactory: function (r) { return r.routerState.root; }, deps: [router_1.Router] },
{
provide: core_1.APP_INITIALIZER,
multi: true,
useFactory: function (injector) {
setTimeout(function (_) {
var appRef = injector.get(core_1.ApplicationRef);
if (appRef.componentTypes.length == 0) {
appRef.registerBootstrapListener(function (_) {
injector.get(router_1.Router).initialNavigation();
});
}
else {
injector.get(router_1.Router).initialNavigation();
}
}, 0);
return function (_) { return null; };
},
deps: [core_1.Injector]
}
{ provide: core_1.APP_INITIALIZER, multi: true, useFactory: setupRouterInitializer, deps: [core_1.Injector] }
];
}
exports.provideRouter = provideRouter;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uX3JvdXRlcl9wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvY29tbW9uX3JvdXRlcl9wcm92aWRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHVCQUErRCxpQkFBaUIsQ0FBQyxDQUFBO0FBQ2pGLHFCQUEyRSxlQUFlLENBQUMsQ0FBQTtBQUczRix1QkFBcUIsVUFBVSxDQUFDLENBQUE7QUFDaEMsa0NBQThCLHFCQUFxQixDQUFDLENBQUE7QUFDcEQsNkJBQTZCLGdCQUFnQixDQUFDLENBQUE7QUFDOUMsK0JBQWtELGtCQUFrQixDQUFDLENBQUE7QUFxQnJFLHVCQUE4QixNQUFvQjtJQUNoRCxNQUFNLENBQUM7UUFDTCxpQkFBUTtRQUNSLEVBQUMsT0FBTyxFQUFFLHlCQUFnQixFQUFFLFFBQVEsRUFBRSw2QkFBb0IsRUFBQztRQUMzRCxFQUFDLE9BQU8sRUFBRSw4QkFBYSxFQUFFLFFBQVEsRUFBRSxxQ0FBb0IsRUFBQztRQUV4RDtZQUNFLE9BQU8sRUFBRSxlQUFNO1lBQ2YsVUFBVSxFQUFFLFVBQUMsR0FBRyxFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxRQUFRO2dCQUN0RSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO29CQUNuQyxNQUFNLElBQUksS0FBSyxDQUFDLDJEQUEyRCxDQUFDLENBQUM7Z0JBQy9FLENBQUM7Z0JBQ0QsSUFBTSxhQUFhLEdBQUcsR0FBRyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDNUMsSUFBTSxDQUFDLEdBQUcsSUFBSSxlQUFNLENBQ2hCLGFBQWEsRUFBRSxRQUFRLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDO2dCQUNuRixHQUFHLENBQUMsdUJBQXVCLENBQUMsY0FBTSxPQUFBLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBWCxDQUFXLENBQUMsQ0FBQztnQkFDL0MsTUFBTSxDQUFDLENBQUMsQ0FBQztZQUNYLENBQUM7WUFDRCxJQUFJLEVBQ0EsQ0FBQyxxQkFBYyxFQUFFLHdCQUFpQixFQUFFLDhCQUFhLEVBQUUsbUNBQWUsRUFBRSxpQkFBUSxFQUFFLGVBQVEsQ0FBQztTQUM1RjtRQUVELG1DQUFlO1FBQ2YsRUFBQyxPQUFPLEVBQUUsNkJBQWMsRUFBRSxVQUFVLEVBQUUsVUFBQyxDQUFDLElBQUssT0FBQSxDQUFDLENBQUMsV0FBVyxDQUFDLElBQUksRUFBbEIsQ0FBa0IsRUFBRSxJQUFJLEVBQUUsQ0FBQyxlQUFNLENBQUMsRUFBQztRQUdoRjtZQUNFLE9BQU8sRUFBRSxzQkFBZTtZQUN4QixLQUFLLEVBQUUsSUFBSTtZQUNYLFVBQVUsRUFBRSxVQUFDLFFBQVE7Z0JBSW5CLFVBQVUsQ0FBQyxVQUFBLENBQUM7b0JBQ1YsSUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxxQkFBYyxDQUFDLENBQUM7b0JBQzVDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7d0JBQ3RDLE1BQU0sQ0FBQyx5QkFBeUIsQ0FBQyxVQUFDLENBQUM7NEJBQ2pDLFFBQVEsQ0FBQyxHQUFHLENBQUMsZUFBTSxDQUFDLENBQUMsaUJBQWlCLEVBQUUsQ0FBQTt3QkFDMUMsQ0FBQyxDQUFDLENBQUM7b0JBQ0wsQ0FBQztvQkFBQyxJQUFJLENBQUMsQ0FBQzt3QkFDTixRQUFRLENBQUMsR0FBRyxDQUFDLGVBQU0sQ0FBQyxDQUFDLGlCQUFpQixFQUFFLENBQUE7b0JBQzFDLENBQUM7Z0JBQ0gsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO2dCQUNOLE1BQU0sQ0FBQyxVQUFBLENBQUMsSUFBSSxPQUFBLElBQUksRUFBSixDQUFJLENBQUM7WUFDbkIsQ0FBQztZQUNELElBQUksRUFBRSxDQUFDLGVBQVEsQ0FBQztTQUNqQjtLQUNGLENBQUM7QUFDSixDQUFDO0FBaERlLHFCQUFhLGdCQWdENUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TG9jYXRpb24sIExvY2F0aW9uU3RyYXRlZ3ksIFBhdGhMb2NhdGlvblN0cmF0ZWd5fSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtBUFBfSU5JVElBTElaRVIsIEFwcGxpY2F0aW9uUmVmLCBDb21wb25lbnRSZXNvbHZlciwgSW5qZWN0b3J9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1JvdXRlckNvbmZpZ30gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHtSb3V0ZXJ9IGZyb20gJy4vcm91dGVyJztcbmltcG9ydCB7Um91dGVyT3V0bGV0TWFwfSBmcm9tICcuL3JvdXRlcl9vdXRsZXRfbWFwJztcbmltcG9ydCB7QWN0aXZhdGVkUm91dGV9IGZyb20gJy4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7RGVmYXVsdFVybFNlcmlhbGl6ZXIsIFVybFNlcmlhbGl6ZXJ9IGZyb20gJy4vdXJsX3NlcmlhbGl6ZXInO1xuXG5cbi8qKlxuICogQSBsaXN0IG9mIHtAbGluayBQcm92aWRlcn1zLiBUbyB1c2UgdGhlIHJvdXRlciwgeW91IG11c3QgYWRkIHRoaXMgdG8geW91ciBhcHBsaWNhdGlvbi5cbiAqXG4gKiAjIyMgRXhhbXBsZVxuICpcbiAqIGBgYFxuICogQENvbXBvbmVudCh7ZGlyZWN0aXZlczogW1JPVVRFUl9ESVJFQ1RJVkVTXX0pXG4gKiBjbGFzcyBBcHBDbXAge1xuICogICAvLyAuLi5cbiAqIH1cbiAqXG4gKiBjb25zdCByb3V0ZXIgPSBbXG4gKiAgIHtwYXRoOiAnL2hvbWUnLCBjb21wb25lbnQ6IEhvbWV9XG4gKiBdO1xuICpcbiAqIGJvb3RzdHJhcChBcHBDbXAsIFtwcm92aWRlUm91dGVyKHJvdXRlcildKTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZVJvdXRlcihjb25maWc6IFJvdXRlckNvbmZpZyk6IGFueVtdIHtcbiAgcmV0dXJuIFtcbiAgICBMb2NhdGlvbixcbiAgICB7cHJvdmlkZTogTG9jYXRpb25TdHJhdGVneSwgdXNlQ2xhc3M6IFBhdGhMb2NhdGlvblN0cmF0ZWd5fSxcbiAgICB7cHJvdmlkZTogVXJsU2VyaWFsaXplciwgdXNlQ2xhc3M6IERlZmF1bHRVcmxTZXJpYWxpemVyfSxcblxuICAgIHtcbiAgICAgIHByb3ZpZGU6IFJvdXRlcixcbiAgICAgIHVzZUZhY3Rvcnk6IChyZWYsIHJlc29sdmVyLCB1cmxTZXJpYWxpemVyLCBvdXRsZXRNYXAsIGxvY2F0aW9uLCBpbmplY3RvcikgPT4ge1xuICAgICAgICBpZiAocmVmLmNvbXBvbmVudFR5cGVzLmxlbmd0aCA9PSAwKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdCb290c3RyYXAgYXQgbGVhc3Qgb25lIGNvbXBvbmVudCBiZWZvcmUgaW5qZWN0aW5nIFJvdXRlci4nKTtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCBjb21wb25lbnRUeXBlID0gcmVmLmNvbXBvbmVudFR5cGVzWzBdO1xuICAgICAgICBjb25zdCByID0gbmV3IFJvdXRlcihcbiAgICAgICAgICAgIGNvbXBvbmVudFR5cGUsIHJlc29sdmVyLCB1cmxTZXJpYWxpemVyLCBvdXRsZXRNYXAsIGxvY2F0aW9uLCBpbmplY3RvciwgY29uZmlnKTtcbiAgICAgICAgcmVmLnJlZ2lzdGVyRGlzcG9zZUxpc3RlbmVyKCgpID0+IHIuZGlzcG9zZSgpKTtcbiAgICAgICAgcmV0dXJuIHI7XG4gICAgICB9LFxuICAgICAgZGVwczpcbiAgICAgICAgICBbQXBwbGljYXRpb25SZWYsIENvbXBvbmVudFJlc29sdmVyLCBVcmxTZXJpYWxpemVyLCBSb3V0ZXJPdXRsZXRNYXAsIExvY2F0aW9uLCBJbmplY3Rvcl1cbiAgICB9LFxuXG4gICAgUm91dGVyT3V0bGV0TWFwLFxuICAgIHtwcm92aWRlOiBBY3RpdmF0ZWRSb3V0ZSwgdXNlRmFjdG9yeTogKHIpID0+IHIucm91dGVyU3RhdGUucm9vdCwgZGVwczogW1JvdXRlcl19LFxuXG4gICAgLy8gVHJpZ2dlciBpbml0aWFsIG5hdmlnYXRpb25cbiAgICB7XG4gICAgICBwcm92aWRlOiBBUFBfSU5JVElBTElaRVIsXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICAgIHVzZUZhY3Rvcnk6IChpbmplY3RvcikgPT4ge1xuICAgICAgICAvLyBodHRwczovL2dpdGh1Yi5jb20vYW5ndWxhci9hbmd1bGFyL2lzc3Vlcy85MTAxXG4gICAgICAgIC8vIERlbGF5IHRoZSByb3V0ZXIgaW5zdGFudGlhdGlvbiB0byBhdm9pZCBjaXJjdWxhciBkZXBlbmRlbmN5IChBcHBsaWNhdGlvblJlZiAtPlxuICAgICAgICAvLyBBUFBfSU5JVElBTElaRVIgLT4gUm91dGVyKVxuICAgICAgICBzZXRUaW1lb3V0KF8gPT4ge1xuICAgICAgICAgIGNvbnN0IGFwcFJlZiA9IGluamVjdG9yLmdldChBcHBsaWNhdGlvblJlZik7XG4gICAgICAgICAgaWYgKGFwcFJlZi5jb21wb25lbnRUeXBlcy5sZW5ndGggPT0gMCkge1xuICAgICAgICAgICAgYXBwUmVmLnJlZ2lzdGVyQm9vdHN0cmFwTGlzdGVuZXIoKF8pID0+IHtcbiAgICAgICAgICAgICAgaW5qZWN0b3IuZ2V0KFJvdXRlcikuaW5pdGlhbE5hdmlnYXRpb24oKVxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGluamVjdG9yLmdldChSb3V0ZXIpLmluaXRpYWxOYXZpZ2F0aW9uKClcbiAgICAgICAgICB9XG4gICAgICAgIH0sIDApO1xuICAgICAgICByZXR1cm4gXyA9PiBudWxsO1xuICAgICAgfSxcbiAgICAgIGRlcHM6IFtJbmplY3Rvcl1cbiAgICB9XG4gIF07XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uX3JvdXRlcl9wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvY29tbW9uX3JvdXRlcl9wcm92aWRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHVCQUErRCxpQkFBaUIsQ0FBQyxDQUFBO0FBQ2pGLHFCQUF3RixlQUFlLENBQUMsQ0FBQTtBQUd4Ryx1QkFBcUIsVUFBVSxDQUFDLENBQUE7QUFDaEMsa0NBQThCLHFCQUFxQixDQUFDLENBQUE7QUFDcEQsNkJBQTZCLGdCQUFnQixDQUFDLENBQUE7QUFDOUMsK0JBQWtELGtCQUFrQixDQUFDLENBQUE7QUFFeEQscUJBQWEsR0FBRyxJQUFJLGtCQUFXLENBQUMsZUFBZSxDQUFDLENBQUM7QUFDakQsc0JBQWMsR0FBRyxJQUFJLGtCQUFXLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztBQUloRSxxQkFDSSxHQUFHLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsSUFBSTtJQUMzRSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ25DLE1BQU0sSUFBSSxLQUFLLENBQUMsMkRBQTJELENBQUMsQ0FBQztJQUMvRSxDQUFDO0lBQ0QsSUFBTSxhQUFhLEdBQUcsR0FBRyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM1QyxJQUFNLENBQUMsR0FDSCxJQUFJLGVBQU0sQ0FBQyxhQUFhLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUM5RixHQUFHLENBQUMsdUJBQXVCLENBQUMsY0FBTSxPQUFBLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBWCxDQUFXLENBQUMsQ0FBQztJQUUvQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztRQUN2QixDQUFDLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxVQUFBLENBQUM7WUFDbEIsT0FBTyxDQUFDLEtBQUssQ0FBQyxtQkFBdUIsQ0FBQyxDQUFDLFdBQVksQ0FBQyxJQUFNLENBQUMsQ0FBQztZQUM1RCxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1lBQzFCLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDZixPQUFPLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDckIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsTUFBTSxDQUFDLENBQUMsQ0FBQztBQUNYLENBQUM7QUFwQmUsbUJBQVcsY0FvQjFCLENBQUE7QUFFRCxnQ0FBdUMsUUFBa0I7SUFJdkQsVUFBVSxDQUFDLFVBQUEsQ0FBQztRQUNWLElBQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxHQUFHLENBQUMscUJBQWMsQ0FBQyxDQUFDO1FBQzVDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdEMsTUFBTSxDQUFDLHlCQUF5QixDQUFDLFVBQUMsQ0FBQyxJQUFPLFFBQVEsQ0FBQyxHQUFHLENBQUMsZUFBTSxDQUFDLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3pGLENBQUM7UUFBQyxJQUFJLENBQUMsQ0FBQztZQUNOLFFBQVEsQ0FBQyxHQUFHLENBQUMsZUFBTSxDQUFDLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUMzQyxDQUFDO0lBQ0gsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ04sTUFBTSxDQUFDLFVBQUEsQ0FBQyxJQUFJLE9BQUEsSUFBSSxFQUFKLENBQUksQ0FBQztBQUNuQixDQUFDO0FBYmUsOEJBQXNCLHlCQWFyQyxDQUFBO0FBb0JELHVCQUE4QixPQUFxQixFQUFFLEtBQW1CO0lBQ3RFLE1BQU0sQ0FBQztRQUNMLEVBQUMsT0FBTyxFQUFFLHFCQUFhLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBQyxFQUFFLEVBQUMsT0FBTyxFQUFFLHNCQUFjLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBQztRQUN2RixpQkFBUSxFQUFFLEVBQUMsT0FBTyxFQUFFLHlCQUFnQixFQUFFLFFBQVEsRUFBRSw2QkFBb0IsRUFBQztRQUNyRSxFQUFDLE9BQU8sRUFBRSw4QkFBYSxFQUFFLFFBQVEsRUFBRSxxQ0FBb0IsRUFBQztRQUV4RDtZQUNFLE9BQU8sRUFBRSxlQUFNO1lBQ2YsVUFBVSxFQUFFLFdBQVc7WUFDdkIsSUFBSSxFQUFFO2dCQUNKLHFCQUFjLEVBQUUsd0JBQWlCLEVBQUUsOEJBQWEsRUFBRSxtQ0FBZSxFQUFFLGlCQUFRLEVBQUUsZUFBUTtnQkFDckYscUJBQWEsRUFBRSxzQkFBYzthQUM5QjtTQUNGO1FBRUQsbUNBQWU7UUFDZixFQUFDLE9BQU8sRUFBRSw2QkFBYyxFQUFFLFVBQVUsRUFBRSxVQUFDLENBQUMsSUFBSyxPQUFBLENBQUMsQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFsQixDQUFrQixFQUFFLElBQUksRUFBRSxDQUFDLGVBQU0sQ0FBQyxFQUFDO1FBR2hGLEVBQUMsT0FBTyxFQUFFLHNCQUFlLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsc0JBQXNCLEVBQUUsSUFBSSxFQUFFLENBQUMsZUFBUSxDQUFDLEVBQUM7S0FDOUYsQ0FBQztBQUNKLENBQUM7QUFyQmUscUJBQWEsZ0JBcUI1QixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtMb2NhdGlvbiwgTG9jYXRpb25TdHJhdGVneSwgUGF0aExvY2F0aW9uU3RyYXRlZ3l9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0FQUF9JTklUSUFMSVpFUiwgQXBwbGljYXRpb25SZWYsIENvbXBvbmVudFJlc29sdmVyLCBJbmplY3RvciwgT3BhcXVlVG9rZW59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1JvdXRlckNvbmZpZ30gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHtSb3V0ZXJ9IGZyb20gJy4vcm91dGVyJztcbmltcG9ydCB7Um91dGVyT3V0bGV0TWFwfSBmcm9tICcuL3JvdXRlcl9vdXRsZXRfbWFwJztcbmltcG9ydCB7QWN0aXZhdGVkUm91dGV9IGZyb20gJy4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7RGVmYXVsdFVybFNlcmlhbGl6ZXIsIFVybFNlcmlhbGl6ZXJ9IGZyb20gJy4vdXJsX3NlcmlhbGl6ZXInO1xuXG5leHBvcnQgY29uc3QgUk9VVEVSX0NPTkZJRyA9IG5ldyBPcGFxdWVUb2tlbignUk9VVEVSX0NPTkZJRycpO1xuZXhwb3J0IGNvbnN0IFJPVVRFUl9PUFRJT05TID0gbmV3IE9wYXF1ZVRva2VuKCdST1VURVJfT1BUSU9OUycpO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV4dHJhT3B0aW9ucyB7IGVuYWJsZVRyYWNpbmc/OiBib29sZWFuOyB9XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXR1cFJvdXRlcihcbiAgICByZWYsIHJlc29sdmVyLCB1cmxTZXJpYWxpemVyLCBvdXRsZXRNYXAsIGxvY2F0aW9uLCBpbmplY3RvciwgY29uZmlnLCBvcHRzKSB7XG4gIGlmIChyZWYuY29tcG9uZW50VHlwZXMubGVuZ3RoID09IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ0Jvb3RzdHJhcCBhdCBsZWFzdCBvbmUgY29tcG9uZW50IGJlZm9yZSBpbmplY3RpbmcgUm91dGVyLicpO1xuICB9XG4gIGNvbnN0IGNvbXBvbmVudFR5cGUgPSByZWYuY29tcG9uZW50VHlwZXNbMF07XG4gIGNvbnN0IHIgPVxuICAgICAgbmV3IFJvdXRlcihjb21wb25lbnRUeXBlLCByZXNvbHZlciwgdXJsU2VyaWFsaXplciwgb3V0bGV0TWFwLCBsb2NhdGlvbiwgaW5qZWN0b3IsIGNvbmZpZyk7XG4gIHJlZi5yZWdpc3RlckRpc3Bvc2VMaXN0ZW5lcigoKSA9PiByLmRpc3Bvc2UoKSk7XG5cbiAgaWYgKG9wdHMuZW5hYmxlVHJhY2luZykge1xuICAgIHIuZXZlbnRzLnN1YnNjcmliZShlID0+IHtcbiAgICAgIGNvbnNvbGUuZ3JvdXAoYFJvdXRlciBFdmVudDogJHsoPGFueT5lLmNvbnN0cnVjdG9yKS5uYW1lfWApO1xuICAgICAgY29uc29sZS5sb2coZS50b1N0cmluZygpKTtcbiAgICAgIGNvbnNvbGUubG9nKGUpO1xuICAgICAgY29uc29sZS5ncm91cEVuZCgpO1xuICAgIH0pO1xuICB9XG5cbiAgcmV0dXJuIHI7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXR1cFJvdXRlckluaXRpYWxpemVyKGluamVjdG9yOiBJbmplY3Rvcikge1xuICAvLyBodHRwczovL2dpdGh1Yi5jb20vYW5ndWxhci9hbmd1bGFyL2lzc3Vlcy85MTAxXG4gIC8vIERlbGF5IHRoZSByb3V0ZXIgaW5zdGFudGlhdGlvbiB0byBhdm9pZCBjaXJjdWxhciBkZXBlbmRlbmN5IChBcHBsaWNhdGlvblJlZiAtPlxuICAvLyBBUFBfSU5JVElBTElaRVIgLT4gUm91dGVyKVxuICBzZXRUaW1lb3V0KF8gPT4ge1xuICAgIGNvbnN0IGFwcFJlZiA9IGluamVjdG9yLmdldChBcHBsaWNhdGlvblJlZik7XG4gICAgaWYgKGFwcFJlZi5jb21wb25lbnRUeXBlcy5sZW5ndGggPT0gMCkge1xuICAgICAgYXBwUmVmLnJlZ2lzdGVyQm9vdHN0cmFwTGlzdGVuZXIoKF8pID0+IHsgaW5qZWN0b3IuZ2V0KFJvdXRlcikuaW5pdGlhbE5hdmlnYXRpb24oKTsgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGluamVjdG9yLmdldChSb3V0ZXIpLmluaXRpYWxOYXZpZ2F0aW9uKCk7XG4gICAgfVxuICB9LCAwKTtcbiAgcmV0dXJuIF8gPT4gbnVsbDtcbn1cblxuLyoqXG4gKiBBIGxpc3Qgb2Yge0BsaW5rIFByb3ZpZGVyfXMuIFRvIHVzZSB0aGUgcm91dGVyLCB5b3UgbXVzdCBhZGQgdGhpcyB0byB5b3VyIGFwcGxpY2F0aW9uLlxuICpcbiAqICMjIyBFeGFtcGxlXG4gKlxuICogYGBgXG4gKiBAQ29tcG9uZW50KHtkaXJlY3RpdmVzOiBbUk9VVEVSX0RJUkVDVElWRVNdfSlcbiAqIGNsYXNzIEFwcENtcCB7XG4gKiAgIC8vIC4uLlxuICogfVxuICpcbiAqIGNvbnN0IHJvdXRlciA9IFtcbiAqICAge3BhdGg6ICcvaG9tZScsIGNvbXBvbmVudDogSG9tZX1cbiAqIF07XG4gKlxuICogYm9vdHN0cmFwKEFwcENtcCwgW3Byb3ZpZGVSb3V0ZXIocm91dGVyKV0pO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlUm91dGVyKF9jb25maWc6IFJvdXRlckNvbmZpZywgX29wdHM6IEV4dHJhT3B0aW9ucyk6IGFueVtdIHtcbiAgcmV0dXJuIFtcbiAgICB7cHJvdmlkZTogUk9VVEVSX0NPTkZJRywgdXNlVmFsdWU6IF9jb25maWd9LCB7cHJvdmlkZTogUk9VVEVSX09QVElPTlMsIHVzZVZhbHVlOiBfb3B0c30sXG4gICAgTG9jYXRpb24sIHtwcm92aWRlOiBMb2NhdGlvblN0cmF0ZWd5LCB1c2VDbGFzczogUGF0aExvY2F0aW9uU3RyYXRlZ3l9LFxuICAgIHtwcm92aWRlOiBVcmxTZXJpYWxpemVyLCB1c2VDbGFzczogRGVmYXVsdFVybFNlcmlhbGl6ZXJ9LFxuXG4gICAge1xuICAgICAgcHJvdmlkZTogUm91dGVyLFxuICAgICAgdXNlRmFjdG9yeTogc2V0dXBSb3V0ZXIsXG4gICAgICBkZXBzOiBbXG4gICAgICAgIEFwcGxpY2F0aW9uUmVmLCBDb21wb25lbnRSZXNvbHZlciwgVXJsU2VyaWFsaXplciwgUm91dGVyT3V0bGV0TWFwLCBMb2NhdGlvbiwgSW5qZWN0b3IsXG4gICAgICAgIFJPVVRFUl9DT05GSUcsIFJPVVRFUl9PUFRJT05TXG4gICAgICBdXG4gICAgfSxcblxuICAgIFJvdXRlck91dGxldE1hcCxcbiAgICB7cHJvdmlkZTogQWN0aXZhdGVkUm91dGUsIHVzZUZhY3Rvcnk6IChyKSA9PiByLnJvdXRlclN0YXRlLnJvb3QsIGRlcHM6IFtSb3V0ZXJdfSxcblxuICAgIC8vIFRyaWdnZXIgaW5pdGlhbCBuYXZpZ2F0aW9uXG4gICAge3Byb3ZpZGU6IEFQUF9JTklUSUFMSVpFUiwgbXVsdGk6IHRydWUsIHVzZUZhY3Rvcnk6IHNldHVwUm91dGVySW5pdGlhbGl6ZXIsIGRlcHM6IFtJbmplY3Rvcl19XG4gIF07XG59XG4iXX0=

@@ -6,2 +6,3 @@ import { Type } from '@angular/core';

path?: string;
terminal?: boolean;
component?: Type | string;

@@ -8,0 +9,0 @@ outlet?: string;

"use strict";
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUeXBlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IHR5cGUgUm91dGVyQ29uZmlnID0gUm91dGVbXTtcblxuZXhwb3J0IGludGVyZmFjZSBSb3V0ZSB7XG4gIGluZGV4PzogYm9vbGVhbjtcbiAgcGF0aD86IHN0cmluZztcbiAgY29tcG9uZW50PzogVHlwZXxzdHJpbmc7XG4gIG91dGxldD86IHN0cmluZztcbiAgY2FuQWN0aXZhdGU/OiBhbnlbXTtcbiAgY2FuRGVhY3RpdmF0ZT86IGFueVtdO1xuICByZWRpcmVjdFRvPzogc3RyaW5nO1xuICBjaGlsZHJlbj86IFJvdXRlW107XG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUeXBlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IHR5cGUgUm91dGVyQ29uZmlnID0gUm91dGVbXTtcblxuZXhwb3J0IGludGVyZmFjZSBSb3V0ZSB7XG4gIC8qKlxuICAgKiBVc2UgYHBhdGg6ICcnYCBpbnN0ZWFkLlxuICAgKiBAZGVwcmVjYXRlZFxuICAgKi9cbiAgaW5kZXg/OiBib29sZWFuO1xuICBwYXRoPzogc3RyaW5nO1xuICB0ZXJtaW5hbD86IGJvb2xlYW47XG4gIGNvbXBvbmVudD86IFR5cGV8c3RyaW5nO1xuICBvdXRsZXQ/OiBzdHJpbmc7XG4gIGNhbkFjdGl2YXRlPzogYW55W107XG4gIGNhbkRlYWN0aXZhdGU/OiBhbnlbXTtcbiAgcmVkaXJlY3RUbz86IHN0cmluZztcbiAgY2hpbGRyZW4/OiBSb3V0ZVtdO1xufSJdfQ==

@@ -37,3 +37,3 @@ "use strict";

function createActivatedRoute(c) {
return new router_state_1.ActivatedRoute(new BehaviorSubject_1.BehaviorSubject(c.urlSegments), new BehaviorSubject_1.BehaviorSubject(c.params), c.outlet, c.component, c);
return new router_state_1.ActivatedRoute(new BehaviorSubject_1.BehaviorSubject(c.url), new BehaviorSubject_1.BehaviorSubject(c.params), c.outlet, c.component, c);
}

@@ -43,2 +43,2 @@ function equalRouteSnapshots(a, b) {

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlX3JvdXRlcl9zdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9jcmVhdGVfcm91dGVyX3N0YXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxnQ0FBOEIsc0JBQXNCLENBQUMsQ0FBQTtBQUVyRCw2QkFBdUYsZ0JBQWdCLENBQUMsQ0FBQTtBQUN4RyxxQkFBdUIsY0FBYyxDQUFDLENBQUE7QUFFdEMsMkJBQWtDLElBQXlCLEVBQUUsU0FBc0I7SUFDakYsSUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsU0FBUyxHQUFHLFNBQVMsQ0FBQyxLQUFLLEdBQUcsU0FBUyxDQUFDLENBQUM7SUFDN0UsSUFBTSxXQUFXLEdBQUcsU0FBUyxHQUFHLFNBQVMsQ0FBQyxXQUFXLEdBQUcsSUFBSSxpQ0FBZSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUM5RixJQUFNLFFBQVEsR0FBRyxTQUFTLEdBQUcsU0FBUyxDQUFDLFFBQVEsR0FBRyxJQUFJLGlDQUFlLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3JGLE1BQU0sQ0FBQyxJQUFJLDBCQUFXLENBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDNUQsQ0FBQztBQUxlLHlCQUFpQixvQkFLaEMsQ0FBQTtBQUVELG9CQUFvQixJQUFzQyxFQUFFLFNBQW9DO0lBRTlGLEVBQUUsQ0FBQyxDQUFDLFNBQVMsSUFBSSxtQkFBbUIsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzNFLElBQU0sS0FBSyxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUM7UUFDOUIsS0FBSyxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1FBRW5DLElBQU0sUUFBUSxHQUFHLHFCQUFxQixDQUFDLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN4RCxNQUFNLENBQUMsSUFBSSxlQUFRLENBQWlCLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQztJQUV2RCxDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDTixJQUFNLEtBQUssR0FBRyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0MsSUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsVUFBQSxDQUFDLElBQUksT0FBQSxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQWIsQ0FBYSxDQUFDLENBQUM7UUFDdkQsTUFBTSxDQUFDLElBQUksZUFBUSxDQUFpQixLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDdkQsQ0FBQztBQUNILENBQUM7QUFFRCwrQkFDSSxJQUFzQyxFQUFFLFNBQW1DO0lBQzdFLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxVQUFBLEtBQUs7UUFDNUIsSUFBTSxLQUFLLEdBQ1AsU0FBUyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsVUFBQSxDQUFDLElBQUksT0FBQSxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLEVBQWxELENBQWtELENBQUMsQ0FBQztRQUMxRixFQUFFLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNmLE1BQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUN0RCxDQUFDO1FBQUMsSUFBSSxDQUFDLENBQUM7WUFDTixNQUFNLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCw4QkFBOEIsQ0FBeUI7SUFDckQsTUFBTSxDQUFDLElBQUksNkJBQWMsQ0FDckIsSUFBSSxpQ0FBZSxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUMsRUFBRSxJQUFJLGlDQUFlLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUNuRyxDQUFDO0FBRUQsNkJBQTZCLENBQXlCLEVBQUUsQ0FBeUI7SUFDL0UsTUFBTSxDQUFDLENBQUMsQ0FBQyxZQUFZLEtBQUssQ0FBQyxDQUFDLFlBQVksQ0FBQztBQUMzQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtCZWhhdmlvclN1YmplY3R9IGZyb20gJ3J4anMvQmVoYXZpb3JTdWJqZWN0JztcblxuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZSwgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgUm91dGVyU3RhdGUsIFJvdXRlclN0YXRlU25hcHNob3R9IGZyb20gJy4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7VHJlZU5vZGV9IGZyb20gJy4vdXRpbHMvdHJlZSc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVSb3V0ZXJTdGF0ZShjdXJyOiBSb3V0ZXJTdGF0ZVNuYXBzaG90LCBwcmV2U3RhdGU6IFJvdXRlclN0YXRlKTogUm91dGVyU3RhdGUge1xuICBjb25zdCByb290ID0gY3JlYXRlTm9kZShjdXJyLl9yb290LCBwcmV2U3RhdGUgPyBwcmV2U3RhdGUuX3Jvb3QgOiB1bmRlZmluZWQpO1xuICBjb25zdCBxdWVyeVBhcmFtcyA9IHByZXZTdGF0ZSA/IHByZXZTdGF0ZS5xdWVyeVBhcmFtcyA6IG5ldyBCZWhhdmlvclN1YmplY3QoY3Vyci5xdWVyeVBhcmFtcyk7XG4gIGNvbnN0IGZyYWdtZW50ID0gcHJldlN0YXRlID8gcHJldlN0YXRlLmZyYWdtZW50IDogbmV3IEJlaGF2aW9yU3ViamVjdChjdXJyLmZyYWdtZW50KTtcbiAgcmV0dXJuIG5ldyBSb3V0ZXJTdGF0ZShyb290LCBxdWVyeVBhcmFtcywgZnJhZ21lbnQsIGN1cnIpO1xufVxuXG5mdW5jdGlvbiBjcmVhdGVOb2RlKGN1cnI6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlU25hcHNob3Q+LCBwcmV2U3RhdGU/OiBUcmVlTm9kZTxBY3RpdmF0ZWRSb3V0ZT4pOlxuICAgIFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlPiB7XG4gIGlmIChwcmV2U3RhdGUgJiYgZXF1YWxSb3V0ZVNuYXBzaG90cyhwcmV2U3RhdGUudmFsdWUuc25hcHNob3QsIGN1cnIudmFsdWUpKSB7XG4gICAgY29uc3QgdmFsdWUgPSBwcmV2U3RhdGUudmFsdWU7XG4gICAgdmFsdWUuX2Z1dHVyZVNuYXBzaG90ID0gY3Vyci52YWx1ZTtcblxuICAgIGNvbnN0IGNoaWxkcmVuID0gY3JlYXRlT3JSZXVzZUNoaWxkcmVuKGN1cnIsIHByZXZTdGF0ZSk7XG4gICAgcmV0dXJuIG5ldyBUcmVlTm9kZTxBY3RpdmF0ZWRSb3V0ZT4odmFsdWUsIGNoaWxkcmVuKTtcblxuICB9IGVsc2Uge1xuICAgIGNvbnN0IHZhbHVlID0gY3JlYXRlQWN0aXZhdGVkUm91dGUoY3Vyci52YWx1ZSk7XG4gICAgY29uc3QgY2hpbGRyZW4gPSBjdXJyLmNoaWxkcmVuLm1hcChjID0+IGNyZWF0ZU5vZGUoYykpO1xuICAgIHJldHVybiBuZXcgVHJlZU5vZGU8QWN0aXZhdGVkUm91dGU+KHZhbHVlLCBjaGlsZHJlbik7XG4gIH1cbn1cblxuZnVuY3Rpb24gY3JlYXRlT3JSZXVzZUNoaWxkcmVuKFxuICAgIGN1cnI6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlU25hcHNob3Q+LCBwcmV2U3RhdGU6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlPikge1xuICByZXR1cm4gY3Vyci5jaGlsZHJlbi5tYXAoY2hpbGQgPT4ge1xuICAgIGNvbnN0IGluZGV4ID1cbiAgICAgICAgcHJldlN0YXRlLmNoaWxkcmVuLmZpbmRJbmRleChwID0+IGVxdWFsUm91dGVTbmFwc2hvdHMocC52YWx1ZS5zbmFwc2hvdCwgY2hpbGQudmFsdWUpKTtcbiAgICBpZiAoaW5kZXggPj0gMCkge1xuICAgICAgcmV0dXJuIGNyZWF0ZU5vZGUoY2hpbGQsIHByZXZTdGF0ZS5jaGlsZHJlbltpbmRleF0pO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gY3JlYXRlTm9kZShjaGlsZCk7XG4gICAgfVxuICB9KTtcbn1cblxuZnVuY3Rpb24gY3JlYXRlQWN0aXZhdGVkUm91dGUoYzogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCkge1xuICByZXR1cm4gbmV3IEFjdGl2YXRlZFJvdXRlKFxuICAgICAgbmV3IEJlaGF2aW9yU3ViamVjdChjLnVybFNlZ21lbnRzKSwgbmV3IEJlaGF2aW9yU3ViamVjdChjLnBhcmFtcyksIGMub3V0bGV0LCBjLmNvbXBvbmVudCwgYyk7XG59XG5cbmZ1bmN0aW9uIGVxdWFsUm91dGVTbmFwc2hvdHMoYTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgYjogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCk6IGJvb2xlYW4ge1xuICByZXR1cm4gYS5fcm91dGVDb25maWcgPT09IGIuX3JvdXRlQ29uZmlnO1xufSJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlX3JvdXRlcl9zdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9jcmVhdGVfcm91dGVyX3N0YXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxnQ0FBOEIsc0JBQXNCLENBQUMsQ0FBQTtBQUVyRCw2QkFBdUYsZ0JBQWdCLENBQUMsQ0FBQTtBQUN4RyxxQkFBdUIsY0FBYyxDQUFDLENBQUE7QUFFdEMsMkJBQWtDLElBQXlCLEVBQUUsU0FBc0I7SUFDakYsSUFBTSxJQUFJLEdBQUcsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsU0FBUyxHQUFHLFNBQVMsQ0FBQyxLQUFLLEdBQUcsU0FBUyxDQUFDLENBQUM7SUFDN0UsSUFBTSxXQUFXLEdBQUcsU0FBUyxHQUFHLFNBQVMsQ0FBQyxXQUFXLEdBQUcsSUFBSSxpQ0FBZSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUM5RixJQUFNLFFBQVEsR0FBRyxTQUFTLEdBQUcsU0FBUyxDQUFDLFFBQVEsR0FBRyxJQUFJLGlDQUFlLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3JGLE1BQU0sQ0FBQyxJQUFJLDBCQUFXLENBQUMsSUFBSSxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDNUQsQ0FBQztBQUxlLHlCQUFpQixvQkFLaEMsQ0FBQTtBQUVELG9CQUFvQixJQUFzQyxFQUFFLFNBQW9DO0lBRTlGLEVBQUUsQ0FBQyxDQUFDLFNBQVMsSUFBSSxtQkFBbUIsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzNFLElBQU0sS0FBSyxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUM7UUFDOUIsS0FBSyxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1FBRW5DLElBQU0sUUFBUSxHQUFHLHFCQUFxQixDQUFDLElBQUksRUFBRSxTQUFTLENBQUMsQ0FBQztRQUN4RCxNQUFNLENBQUMsSUFBSSxlQUFRLENBQWlCLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQztJQUV2RCxDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDTixJQUFNLEtBQUssR0FBRyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDL0MsSUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsVUFBQSxDQUFDLElBQUksT0FBQSxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQWIsQ0FBYSxDQUFDLENBQUM7UUFDdkQsTUFBTSxDQUFDLElBQUksZUFBUSxDQUFpQixLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDdkQsQ0FBQztBQUNILENBQUM7QUFFRCwrQkFDSSxJQUFzQyxFQUFFLFNBQW1DO0lBQzdFLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxVQUFBLEtBQUs7UUFDNUIsSUFBTSxLQUFLLEdBQ1AsU0FBUyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsVUFBQSxDQUFDLElBQUksT0FBQSxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLEVBQWxELENBQWtELENBQUMsQ0FBQztRQUMxRixFQUFFLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNmLE1BQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUN0RCxDQUFDO1FBQUMsSUFBSSxDQUFDLENBQUM7WUFDTixNQUFNLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCw4QkFBOEIsQ0FBeUI7SUFDckQsTUFBTSxDQUFDLElBQUksNkJBQWMsQ0FDckIsSUFBSSxpQ0FBZSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRSxJQUFJLGlDQUFlLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUMzRixDQUFDO0FBRUQsNkJBQTZCLENBQXlCLEVBQUUsQ0FBeUI7SUFDL0UsTUFBTSxDQUFDLENBQUMsQ0FBQyxZQUFZLEtBQUssQ0FBQyxDQUFDLFlBQVksQ0FBQztBQUMzQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtCZWhhdmlvclN1YmplY3R9IGZyb20gJ3J4anMvQmVoYXZpb3JTdWJqZWN0JztcblxuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZSwgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgUm91dGVyU3RhdGUsIFJvdXRlclN0YXRlU25hcHNob3R9IGZyb20gJy4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7VHJlZU5vZGV9IGZyb20gJy4vdXRpbHMvdHJlZSc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVSb3V0ZXJTdGF0ZShjdXJyOiBSb3V0ZXJTdGF0ZVNuYXBzaG90LCBwcmV2U3RhdGU6IFJvdXRlclN0YXRlKTogUm91dGVyU3RhdGUge1xuICBjb25zdCByb290ID0gY3JlYXRlTm9kZShjdXJyLl9yb290LCBwcmV2U3RhdGUgPyBwcmV2U3RhdGUuX3Jvb3QgOiB1bmRlZmluZWQpO1xuICBjb25zdCBxdWVyeVBhcmFtcyA9IHByZXZTdGF0ZSA/IHByZXZTdGF0ZS5xdWVyeVBhcmFtcyA6IG5ldyBCZWhhdmlvclN1YmplY3QoY3Vyci5xdWVyeVBhcmFtcyk7XG4gIGNvbnN0IGZyYWdtZW50ID0gcHJldlN0YXRlID8gcHJldlN0YXRlLmZyYWdtZW50IDogbmV3IEJlaGF2aW9yU3ViamVjdChjdXJyLmZyYWdtZW50KTtcbiAgcmV0dXJuIG5ldyBSb3V0ZXJTdGF0ZShyb290LCBxdWVyeVBhcmFtcywgZnJhZ21lbnQsIGN1cnIpO1xufVxuXG5mdW5jdGlvbiBjcmVhdGVOb2RlKGN1cnI6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlU25hcHNob3Q+LCBwcmV2U3RhdGU/OiBUcmVlTm9kZTxBY3RpdmF0ZWRSb3V0ZT4pOlxuICAgIFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlPiB7XG4gIGlmIChwcmV2U3RhdGUgJiYgZXF1YWxSb3V0ZVNuYXBzaG90cyhwcmV2U3RhdGUudmFsdWUuc25hcHNob3QsIGN1cnIudmFsdWUpKSB7XG4gICAgY29uc3QgdmFsdWUgPSBwcmV2U3RhdGUudmFsdWU7XG4gICAgdmFsdWUuX2Z1dHVyZVNuYXBzaG90ID0gY3Vyci52YWx1ZTtcblxuICAgIGNvbnN0IGNoaWxkcmVuID0gY3JlYXRlT3JSZXVzZUNoaWxkcmVuKGN1cnIsIHByZXZTdGF0ZSk7XG4gICAgcmV0dXJuIG5ldyBUcmVlTm9kZTxBY3RpdmF0ZWRSb3V0ZT4odmFsdWUsIGNoaWxkcmVuKTtcblxuICB9IGVsc2Uge1xuICAgIGNvbnN0IHZhbHVlID0gY3JlYXRlQWN0aXZhdGVkUm91dGUoY3Vyci52YWx1ZSk7XG4gICAgY29uc3QgY2hpbGRyZW4gPSBjdXJyLmNoaWxkcmVuLm1hcChjID0+IGNyZWF0ZU5vZGUoYykpO1xuICAgIHJldHVybiBuZXcgVHJlZU5vZGU8QWN0aXZhdGVkUm91dGU+KHZhbHVlLCBjaGlsZHJlbik7XG4gIH1cbn1cblxuZnVuY3Rpb24gY3JlYXRlT3JSZXVzZUNoaWxkcmVuKFxuICAgIGN1cnI6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlU25hcHNob3Q+LCBwcmV2U3RhdGU6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlPikge1xuICByZXR1cm4gY3Vyci5jaGlsZHJlbi5tYXAoY2hpbGQgPT4ge1xuICAgIGNvbnN0IGluZGV4ID1cbiAgICAgICAgcHJldlN0YXRlLmNoaWxkcmVuLmZpbmRJbmRleChwID0+IGVxdWFsUm91dGVTbmFwc2hvdHMocC52YWx1ZS5zbmFwc2hvdCwgY2hpbGQudmFsdWUpKTtcbiAgICBpZiAoaW5kZXggPj0gMCkge1xuICAgICAgcmV0dXJuIGNyZWF0ZU5vZGUoY2hpbGQsIHByZXZTdGF0ZS5jaGlsZHJlbltpbmRleF0pO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gY3JlYXRlTm9kZShjaGlsZCk7XG4gICAgfVxuICB9KTtcbn1cblxuZnVuY3Rpb24gY3JlYXRlQWN0aXZhdGVkUm91dGUoYzogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCkge1xuICByZXR1cm4gbmV3IEFjdGl2YXRlZFJvdXRlKFxuICAgICAgbmV3IEJlaGF2aW9yU3ViamVjdChjLnVybCksIG5ldyBCZWhhdmlvclN1YmplY3QoYy5wYXJhbXMpLCBjLm91dGxldCwgYy5jb21wb25lbnQsIGMpO1xufVxuXG5mdW5jdGlvbiBlcXVhbFJvdXRlU25hcHNob3RzKGE6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIGI6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QpOiBib29sZWFuIHtcbiAgcmV0dXJuIGEuX3JvdXRlQ29uZmlnID09PSBiLl9yb3V0ZUNvbmZpZztcbn0iXX0=
import { ActivatedRoute } from './router_state';
import { Params } from './shared';
import { UrlTree } from './url_tree';
export declare function createUrlTree(route: ActivatedRoute, urlTree: UrlTree, commands: any[], queryParams: Params | undefined, fragment: string | undefined): UrlTree;
export declare function createUrlTree(route: ActivatedRoute, urlTree: UrlTree, commands: any[], queryParams: Params, fragment: string): UrlTree;

@@ -5,24 +5,39 @@ "use strict";

var collection_1 = require('./utils/collection');
var tree_1 = require('./utils/tree');
function createUrlTree(route, urlTree, commands, queryParams, fragment) {
if (commands.length === 0) {
return tree(urlTree._root, urlTree, queryParams, fragment);
return tree(urlTree.root, urlTree.root, urlTree, queryParams, fragment);
}
var normalizedCommands = normalizeCommands(commands);
if (navigateToRoot(normalizedCommands)) {
return tree(new tree_1.TreeNode(urlTree.root, []), urlTree, queryParams, fragment);
return tree(urlTree.root, new url_tree_1.UrlSegment([], {}), urlTree, queryParams, fragment);
}
var startingNode = findStartingNode(normalizedCommands, urlTree, route);
var updated = normalizedCommands.commands.length > 0 ?
updateMany(startingNode.children.slice(0), normalizedCommands.commands) :
[];
var newRoot = constructNewTree(urlTree._root, startingNode, updated);
return tree(newRoot, urlTree, queryParams, fragment);
var startingPosition = findStartingPosition(normalizedCommands, urlTree, route);
var segment = startingPosition.processChildren ?
updateSegmentChildren(startingPosition.segment, startingPosition.index, normalizedCommands.commands) :
updateSegment(startingPosition.segment, startingPosition.index, normalizedCommands.commands);
return tree(startingPosition.segment, segment, urlTree, queryParams, fragment);
}
exports.createUrlTree = createUrlTree;
function tree(root, urlTree, queryParams, fragment) {
function tree(oldSegment, newSegment, urlTree, queryParams, fragment) {
var q = queryParams ? stringify(queryParams) : urlTree.queryParams;
var f = fragment ? fragment : urlTree.fragment;
return new url_tree_1.UrlTree(root, q, f);
if (urlTree.root === oldSegment) {
return new url_tree_1.UrlTree(newSegment, q, f);
}
else {
return new url_tree_1.UrlTree(replaceSegment(urlTree.root, oldSegment, newSegment), q, f);
}
}
function replaceSegment(current, oldSegment, newSegment) {
var children = {};
collection_1.forEach(current.children, function (c, k) {
if (c === oldSegment) {
children[k] = newSegment;
}
else {
children[k] = replaceSegment(c, oldSegment, newSegment);
}
});
return new url_tree_1.UrlSegment(current.pathsWithParams, children);
}
function navigateToRoot(normalizedChange) {

@@ -78,56 +93,30 @@ return normalizedChange.isAbsolute && normalizedChange.commands.length === 1 &&

}
function findStartingNode(normalizedChange, urlTree, route) {
var Position = (function () {
function Position(segment, processChildren, index) {
this.segment = segment;
this.processChildren = processChildren;
this.index = index;
}
return Position;
}());
function findStartingPosition(normalizedChange, urlTree, route) {
if (normalizedChange.isAbsolute) {
return urlTree._root;
return new Position(urlTree.root, true, 0);
}
else {
var urlSegment = findUrlSegment(route, urlTree, normalizedChange.numberOfDoubleDots);
return findMatchingNode(urlSegment, urlTree._root);
else if (route.snapshot._lastPathIndex === -1) {
return new Position(route.snapshot._urlSegment, true, 0);
}
}
function findUrlSegment(route, urlTree, numberOfDoubleDots) {
var urlSegment = route.snapshot._lastUrlSegment;
var path = urlTree.pathFromRoot(urlSegment);
if (path.length <= numberOfDoubleDots) {
throw new Error('Invalid number of \'../\'');
else if (route.snapshot._lastPathIndex + 1 - normalizedChange.numberOfDoubleDots >= 0) {
return new Position(route.snapshot._urlSegment, false, route.snapshot._lastPathIndex + 1 - normalizedChange.numberOfDoubleDots);
}
return path[path.length - 1 - numberOfDoubleDots];
}
function findMatchingNode(segment, node) {
if (node.value === segment)
return node;
for (var _i = 0, _a = node.children; _i < _a.length; _i++) {
var c = _a[_i];
var r = findMatchingNode(segment, c);
if (r)
return r;
}
throw new Error("Cannot find url segment '" + segment + "'");
}
function constructNewTree(node, original, updated) {
if (node === original) {
return new tree_1.TreeNode(node.value, updated);
}
else {
return new tree_1.TreeNode(node.value, node.children.map(function (c) { return constructNewTree(c, original, updated); }));
throw new Error('Invalid number of \'../\'');
}
}
function updateMany(nodes, commands) {
var outlet = getOutlet(commands);
var nodesInRightOutlet = nodes.filter(function (c) { return c.value.outlet === outlet; });
if (nodesInRightOutlet.length > 0) {
var nodeRightOutlet = nodesInRightOutlet[0];
nodes[nodes.indexOf(nodeRightOutlet)] = update(nodeRightOutlet, commands);
}
else {
nodes.push(update(null, commands));
}
return nodes;
function getPath(command) {
if (!(typeof command === 'string'))
return command;
var parts = command.toString().split(':');
return parts.length > 1 ? parts[1] : command;
}
function getPath(commands) {
if (!(typeof commands[0] === 'string'))
return commands[0];
var parts = commands[0].toString().split(':');
return parts.length > 1 ? parts[1] : commands[0];
}
function getOutlet(commands) {

@@ -139,38 +128,87 @@ if (!(typeof commands[0] === 'string'))

}
function update(node, commands) {
var rest = commands.slice(1);
var next = rest.length === 0 ? null : rest[0];
var outlet = getOutlet(commands);
var path = getPath(commands);
if (!node && !(typeof next === 'object')) {
var urlSegment = new url_tree_1.UrlSegment(path, {}, outlet);
var children = rest.length === 0 ? [] : [update(null, rest)];
return new tree_1.TreeNode(urlSegment, children);
function updateSegment(segment, startIndex, commands) {
if (!segment) {
segment = new url_tree_1.UrlSegment([], {});
}
else if (!node && typeof next === 'object') {
var urlSegment = new url_tree_1.UrlSegment(path, stringify(next), outlet);
return recurse(urlSegment, node, rest.slice(1));
if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {
return updateSegmentChildren(segment, startIndex, commands);
}
else if (node && outlet !== node.value.outlet) {
return node;
var m = prefixedWith(segment, startIndex, commands);
var slicedCommands = commands.slice(m.lastIndex);
if (m.match && slicedCommands.length === 0) {
return new url_tree_1.UrlSegment(segment.pathsWithParams, {});
}
else if (node && typeof path === 'object') {
var newSegment = new url_tree_1.UrlSegment(node.value.path, stringify(path), node.value.outlet);
return recurse(newSegment, node, rest);
else if (m.match && Object.keys(segment.children).length === 0) {
return createNewSegment(segment, startIndex, commands);
}
else if (node && typeof next === 'object' && compare(path, stringify(next), node.value)) {
return recurse(node.value, node, rest.slice(1));
else if (m.match) {
return updateSegmentChildren(segment, 0, slicedCommands);
}
else if (node && typeof next === 'object') {
var urlSegment = new url_tree_1.UrlSegment(path, stringify(next), outlet);
return recurse(urlSegment, node, rest.slice(1));
else {
return createNewSegment(segment, startIndex, commands);
}
else if (node && compare(path, {}, node.value)) {
return recurse(node.value, node, rest);
}
function updateSegmentChildren(segment, startIndex, commands) {
if (commands.length === 0) {
return new url_tree_1.UrlSegment(segment.pathsWithParams, {});
}
else {
var urlSegment = new url_tree_1.UrlSegment(path, {}, outlet);
return recurse(urlSegment, node, rest);
var outlet_1 = getOutlet(commands);
var children_1 = {};
children_1[outlet_1] = updateSegment(segment.children[outlet_1], startIndex, commands);
collection_1.forEach(segment.children, function (child, childOutlet) {
if (childOutlet !== outlet_1) {
children_1[childOutlet] = child;
}
});
return new url_tree_1.UrlSegment(segment.pathsWithParams, children_1);
}
}
function prefixedWith(segment, startIndex, commands) {
var currentCommandIndex = 0;
var currentPathIndex = startIndex;
var noMatch = { match: false, lastIndex: 0 };
while (currentPathIndex < segment.pathsWithParams.length) {
if (currentCommandIndex >= commands.length)
return noMatch;
var path = segment.pathsWithParams[currentPathIndex];
var curr = getPath(commands[currentCommandIndex]);
var next = currentCommandIndex < commands.length - 1 ? commands[currentCommandIndex + 1] : null;
if (curr && next && (typeof next === 'object')) {
if (!compare(curr, next, path))
return noMatch;
currentCommandIndex += 2;
}
else {
if (!compare(curr, {}, path))
return noMatch;
currentCommandIndex++;
}
currentPathIndex++;
}
return { match: true, lastIndex: currentCommandIndex };
}
function createNewSegment(segment, startIndex, commands) {
var paths = segment.pathsWithParams.slice(0, startIndex);
var i = 0;
while (i < commands.length) {
if (i === 0 && (typeof commands[0] === 'object')) {
var p = segment.pathsWithParams[startIndex];
paths.push(new url_tree_1.UrlPathWithParams(p.path, commands[0]));
i++;
continue;
}
var curr = getPath(commands[i]);
var next = (i < commands.length - 1) ? commands[i + 1] : null;
if (curr && next && (typeof next === 'object')) {
paths.push(new url_tree_1.UrlPathWithParams(curr, stringify(next)));
i += 2;
}
else {
paths.push(new url_tree_1.UrlPathWithParams(curr, {}));
i++;
}
}
return new url_tree_1.UrlSegment(paths, {});
}
function stringify(params) {

@@ -181,12 +219,5 @@ var res = {};

}
function compare(path, params, segment) {
return path == segment.path && collection_1.shallowEqual(params, segment.parameters);
function compare(path, params, pathWithParams) {
return path == pathWithParams.path && collection_1.shallowEqual(params, pathWithParams.parameters);
}
function recurse(urlSegment, node, rest) {
if (rest.length === 0) {
return new tree_1.TreeNode(urlSegment, []);
}
var children = node ? node.children.slice(0) : [];
return new tree_1.TreeNode(urlSegment, updateMany(children, rest));
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create_url_tree.js","sourceRoot":"","sources":["../src/create_url_tree.ts"],"names":[],"mappings":"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","sourcesContent":["import {ActivatedRoute} from './router_state';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlSegment, UrlTree} from './url_tree';\nimport {forEach, shallowEqual} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nexport function createUrlTree(\n    route: ActivatedRoute, urlTree: UrlTree, commands: any[], queryParams: Params | undefined,\n    fragment: string | undefined): UrlTree {\n  if (commands.length === 0) {\n    return tree(urlTree._root, urlTree, queryParams, fragment);\n  }\n\n  const normalizedCommands = normalizeCommands(commands);\n  if (navigateToRoot(normalizedCommands)) {\n    return tree(new TreeNode<UrlSegment>(urlTree.root, []), urlTree, queryParams, fragment);\n  }\n\n  const startingNode = findStartingNode(normalizedCommands, urlTree, route);\n  const updated = normalizedCommands.commands.length > 0 ?\n      updateMany(startingNode.children.slice(0), normalizedCommands.commands) :\n      [];\n  const newRoot = constructNewTree(urlTree._root, startingNode, updated);\n\n  return tree(newRoot, urlTree, queryParams, fragment);\n}\n\nfunction tree(\n    root: TreeNode<UrlSegment>, urlTree: UrlTree, queryParams: Params | undefined,\n    fragment: string | undefined): UrlTree {\n  const q = queryParams ? stringify(queryParams) : urlTree.queryParams;\n  const f = fragment ? fragment : urlTree.fragment;\n  return new UrlTree(root, q, f);\n}\n\nfunction navigateToRoot(normalizedChange: NormalizedNavigationCommands): boolean {\n  return normalizedChange.isAbsolute && normalizedChange.commands.length === 1 &&\n      normalizedChange.commands[0] == '/';\n}\n\nclass NormalizedNavigationCommands {\n  constructor(\n      public isAbsolute: boolean, public numberOfDoubleDots: number, public commands: any[]) {}\n}\n\nfunction normalizeCommands(commands: any[]): NormalizedNavigationCommands {\n  if ((typeof commands[0] === 'string') && commands.length === 1 && commands[0] == '/') {\n    return new NormalizedNavigationCommands(true, 0, commands);\n  }\n\n  let numberOfDoubleDots = 0;\n  let isAbsolute = false;\n  const res = [];\n\n  for (let i = 0; i < commands.length; ++i) {\n    const c = commands[i];\n\n    if (!(typeof c === 'string')) {\n      res.push(c);\n      continue;\n    }\n\n    const parts = c.split('/');\n    for (let j = 0; j < parts.length; ++j) {\n      let cc = parts[j];\n\n      // first exp is treated in a special way\n      if (i == 0) {\n        if (j == 0 && cc == '.') {  //  './a'\n          // skip it\n        } else if (j == 0 && cc == '') {  //  '/a'\n          isAbsolute = true;\n        } else if (cc == '..') {  //  '../a'\n          numberOfDoubleDots++;\n        } else if (cc != '') {\n          res.push(cc);\n        }\n\n      } else {\n        if (cc != '') {\n          res.push(cc);\n        }\n      }\n    }\n  }\n\n  return new NormalizedNavigationCommands(isAbsolute, numberOfDoubleDots, res);\n}\n\nfunction findStartingNode(\n    normalizedChange: NormalizedNavigationCommands, urlTree: UrlTree,\n    route: ActivatedRoute): TreeNode<UrlSegment> {\n  if (normalizedChange.isAbsolute) {\n    return urlTree._root;\n  } else {\n    const urlSegment = findUrlSegment(route, urlTree, normalizedChange.numberOfDoubleDots);\n    return findMatchingNode(urlSegment, urlTree._root);\n  }\n}\n\nfunction findUrlSegment(\n    route: ActivatedRoute, urlTree: UrlTree, numberOfDoubleDots: number): UrlSegment {\n  const urlSegment = route.snapshot._lastUrlSegment;\n  const path = urlTree.pathFromRoot(urlSegment);\n  if (path.length <= numberOfDoubleDots) {\n    throw new Error('Invalid number of \\'../\\'');\n  }\n  return path[path.length - 1 - numberOfDoubleDots];\n}\n\nfunction findMatchingNode(segment: UrlSegment, node: TreeNode<UrlSegment>): TreeNode<UrlSegment> {\n  if (node.value === segment) return node;\n  for (let c of node.children) {\n    const r = findMatchingNode(segment, c);\n    if (r) return r;\n  }\n  throw new Error(`Cannot find url segment '${segment}'`);\n}\n\nfunction constructNewTree(\n    node: TreeNode<UrlSegment>, original: TreeNode<UrlSegment>,\n    updated: TreeNode<UrlSegment>[]): TreeNode<UrlSegment> {\n  if (node === original) {\n    return new TreeNode<UrlSegment>(node.value, updated);\n  } else {\n    return new TreeNode<UrlSegment>(\n        node.value, node.children.map(c => constructNewTree(c, original, updated)));\n  }\n}\n\nfunction updateMany(nodes: TreeNode<UrlSegment>[], commands: any[]): TreeNode<UrlSegment>[] {\n  const outlet = getOutlet(commands);\n  const nodesInRightOutlet = nodes.filter(c => c.value.outlet === outlet);\n  if (nodesInRightOutlet.length > 0) {\n    const nodeRightOutlet = nodesInRightOutlet[0];  // there can be only one\n    nodes[nodes.indexOf(nodeRightOutlet)] = update(nodeRightOutlet, commands);\n  } else {\n    nodes.push(update(null, commands));\n  }\n  return nodes;\n}\n\nfunction getPath(commands: any[]): any {\n  if (!(typeof commands[0] === 'string')) return commands[0];\n  const parts = commands[0].toString().split(':');\n  return parts.length > 1 ? parts[1] : commands[0];\n}\n\nfunction getOutlet(commands: any[]): string {\n  if (!(typeof commands[0] === 'string')) return PRIMARY_OUTLET;\n  const parts = commands[0].toString().split(':');\n  return parts.length > 1 ? parts[0] : PRIMARY_OUTLET;\n}\n\nfunction update(node: TreeNode<UrlSegment>| null, commands: any[]): TreeNode<UrlSegment> {\n  const rest = commands.slice(1);\n  const next = rest.length === 0 ? null : rest[0];\n  const outlet = getOutlet(commands);\n  const path = getPath(commands);\n\n  // reach the end of the tree => create new tree nodes.\n  if (!node && !(typeof next === 'object')) {\n    const urlSegment = new UrlSegment(path, {}, outlet);\n    const children = rest.length === 0 ? [] : [update(null, rest)];\n    return new TreeNode<UrlSegment>(urlSegment, children);\n\n  } else if (!node && typeof next === 'object') {\n    const urlSegment = new UrlSegment(path, stringify(next), outlet);\n    return recurse(urlSegment, node, rest.slice(1));\n\n    // different outlet => preserve the subtree\n  } else if (node && outlet !== node.value.outlet) {\n    return node;\n\n    // params command\n  } else if (node && typeof path === 'object') {\n    const newSegment = new UrlSegment(node.value.path, stringify(path), node.value.outlet);\n    return recurse(newSegment, node, rest);\n\n    // next one is a params command && can reuse the node\n  } else if (node && typeof next === 'object' && compare(path, stringify(next), node.value)) {\n    return recurse(node.value, node, rest.slice(1));\n\n    // next one is a params command && cannot reuse the node\n  } else if (node && typeof next === 'object') {\n    const urlSegment = new UrlSegment(path, stringify(next), outlet);\n    return recurse(urlSegment, node, rest.slice(1));\n\n    // next one is not a params command && can reuse the node\n  } else if (node && compare(path, {}, node.value)) {\n    return recurse(node.value, node, rest);\n\n    // next one is not a params command && cannot reuse the node\n  } else {\n    const urlSegment = new UrlSegment(path, {}, outlet);\n    return recurse(urlSegment, node, rest);\n  }\n}\n\nfunction stringify(params: {[key: string]: any}): {[key: string]: string} {\n  const res = {};\n  forEach(params, (v, k) => res[k] = `${v}`);\n  return res;\n}\n\nfunction compare(path: string, params: {[key: string]: any}, segment: UrlSegment): boolean {\n  return path == segment.path && shallowEqual(params, segment.parameters);\n}\n\nfunction recurse(\n    urlSegment: UrlSegment, node: TreeNode<UrlSegment>| null, rest: any[]): TreeNode<UrlSegment> {\n  if (rest.length === 0) {\n    return new TreeNode<UrlSegment>(urlSegment, []);\n  }\n  const children = node ? node.children.slice(0) : [];\n  return new TreeNode<UrlSegment>(urlSegment, updateMany(children, rest));\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create_url_tree.js","sourceRoot":"","sources":["../src/create_url_tree.ts"],"names":[],"mappings":"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","sourcesContent":["import {ActivatedRoute} from './router_state';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree} from './url_tree';\nimport {forEach, shallowEqual} from './utils/collection';\n\nexport function createUrlTree(\n    route: ActivatedRoute, urlTree: UrlTree, commands: any[], queryParams: Params,\n    fragment: string): UrlTree {\n  if (commands.length === 0) {\n    return tree(urlTree.root, urlTree.root, urlTree, queryParams, fragment);\n  }\n\n  const normalizedCommands = normalizeCommands(commands);\n  if (navigateToRoot(normalizedCommands)) {\n    return tree(urlTree.root, new UrlSegment([], {}), urlTree, queryParams, fragment);\n  }\n\n  const startingPosition = findStartingPosition(normalizedCommands, urlTree, route);\n  const segment = startingPosition.processChildren ?\n      updateSegmentChildren(\n          startingPosition.segment, startingPosition.index, normalizedCommands.commands) :\n      updateSegment(startingPosition.segment, startingPosition.index, normalizedCommands.commands);\n  return tree(startingPosition.segment, segment, urlTree, queryParams, fragment);\n}\n\nfunction tree(\n    oldSegment: UrlSegment, newSegment: UrlSegment, urlTree: UrlTree, queryParams: Params,\n    fragment: string): UrlTree {\n  const q = queryParams ? stringify(queryParams) : urlTree.queryParams;\n  const f = fragment ? fragment : urlTree.fragment;\n\n  if (urlTree.root === oldSegment) {\n    return new UrlTree(newSegment, q, f);\n  } else {\n    return new UrlTree(replaceSegment(urlTree.root, oldSegment, newSegment), q, f);\n  }\n}\n\nfunction replaceSegment(\n    current: UrlSegment, oldSegment: UrlSegment, newSegment: UrlSegment): UrlSegment {\n  const children: {[key: string]: UrlSegment} = {};\n  forEach(current.children, (c, k) => {\n    if (c === oldSegment) {\n      children[k] = newSegment;\n    } else {\n      children[k] = replaceSegment(c, oldSegment, newSegment);\n    }\n  });\n  return new UrlSegment(current.pathsWithParams, children);\n}\n\nfunction navigateToRoot(normalizedChange: NormalizedNavigationCommands): boolean {\n  return normalizedChange.isAbsolute && normalizedChange.commands.length === 1 &&\n      normalizedChange.commands[0] == '/';\n}\n\nclass NormalizedNavigationCommands {\n  constructor(\n      public isAbsolute: boolean, public numberOfDoubleDots: number, public commands: any[]) {}\n}\n\nfunction normalizeCommands(commands: any[]): NormalizedNavigationCommands {\n  if ((typeof commands[0] === 'string') && commands.length === 1 && commands[0] == '/') {\n    return new NormalizedNavigationCommands(true, 0, commands);\n  }\n\n  let numberOfDoubleDots = 0;\n  let isAbsolute = false;\n  const res = [];\n\n  for (let i = 0; i < commands.length; ++i) {\n    const c = commands[i];\n\n    if (!(typeof c === 'string')) {\n      res.push(c);\n      continue;\n    }\n\n    const parts = c.split('/');\n    for (let j = 0; j < parts.length; ++j) {\n      let cc = parts[j];\n\n      // first exp is treated in a special way\n      if (i == 0) {\n        if (j == 0 && cc == '.') {  //  './a'\n          // skip it\n        } else if (j == 0 && cc == '') {  //  '/a'\n          isAbsolute = true;\n        } else if (cc == '..') {  //  '../a'\n          numberOfDoubleDots++;\n        } else if (cc != '') {\n          res.push(cc);\n        }\n\n      } else {\n        if (cc != '') {\n          res.push(cc);\n        }\n      }\n    }\n  }\n\n  return new NormalizedNavigationCommands(isAbsolute, numberOfDoubleDots, res);\n}\n\nclass Position {\n  constructor(public segment: UrlSegment, public processChildren: boolean, public index: number) {}\n}\n\nfunction findStartingPosition(\n    normalizedChange: NormalizedNavigationCommands, urlTree: UrlTree,\n    route: ActivatedRoute): Position {\n  if (normalizedChange.isAbsolute) {\n    return new Position(urlTree.root, true, 0);\n  } else if (route.snapshot._lastPathIndex === -1) {\n    return new Position(route.snapshot._urlSegment, true, 0);\n  } else if (route.snapshot._lastPathIndex + 1 - normalizedChange.numberOfDoubleDots >= 0) {\n    return new Position(\n        route.snapshot._urlSegment, false,\n        route.snapshot._lastPathIndex + 1 - normalizedChange.numberOfDoubleDots);\n  } else {\n    throw new Error('Invalid number of \\'../\\'');\n  }\n}\n\nfunction getPath(command: any): any {\n  if (!(typeof command === 'string')) return command;\n  const parts = command.toString().split(':');\n  return parts.length > 1 ? parts[1] : command;\n}\n\nfunction getOutlet(commands: any[]): string {\n  if (!(typeof commands[0] === 'string')) return PRIMARY_OUTLET;\n  const parts = commands[0].toString().split(':');\n  return parts.length > 1 ? parts[0] : PRIMARY_OUTLET;\n}\n\nfunction updateSegment(segment: UrlSegment, startIndex: number, commands: any[]): UrlSegment {\n  if (!segment) {\n    segment = new UrlSegment([], {});\n  }\n  if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {\n    return updateSegmentChildren(segment, startIndex, commands);\n  }\n  const m = prefixedWith(segment, startIndex, commands);\n  const slicedCommands = commands.slice(m.lastIndex);\n\n  if (m.match && slicedCommands.length === 0) {\n    return new UrlSegment(segment.pathsWithParams, {});\n  } else if (m.match && Object.keys(segment.children).length === 0) {\n    return createNewSegment(segment, startIndex, commands);\n  } else if (m.match) {\n    return updateSegmentChildren(segment, 0, slicedCommands);\n  } else {\n    return createNewSegment(segment, startIndex, commands);\n  }\n}\n\nfunction updateSegmentChildren(\n    segment: UrlSegment, startIndex: number, commands: any[]): UrlSegment {\n  if (commands.length === 0) {\n    return new UrlSegment(segment.pathsWithParams, {});\n  } else {\n    const outlet = getOutlet(commands);\n    const children: {[key: string]: UrlSegment} = {};\n    children[outlet] = updateSegment(segment.children[outlet], startIndex, commands);\n    forEach(segment.children, (child, childOutlet) => {\n      if (childOutlet !== outlet) {\n        children[childOutlet] = child;\n      }\n    });\n    return new UrlSegment(segment.pathsWithParams, children);\n  }\n}\n\nfunction prefixedWith(segment: UrlSegment, startIndex: number, commands: any[]) {\n  let currentCommandIndex = 0;\n  let currentPathIndex = startIndex;\n\n  const noMatch = {match: false, lastIndex: 0};\n  while (currentPathIndex < segment.pathsWithParams.length) {\n    if (currentCommandIndex >= commands.length) return noMatch;\n    const path = segment.pathsWithParams[currentPathIndex];\n    const curr = getPath(commands[currentCommandIndex]);\n    const next =\n        currentCommandIndex < commands.length - 1 ? commands[currentCommandIndex + 1] : null;\n\n    if (curr && next && (typeof next === 'object')) {\n      if (!compare(curr, next, path)) return noMatch;\n      currentCommandIndex += 2;\n    } else {\n      if (!compare(curr, {}, path)) return noMatch;\n      currentCommandIndex++;\n    }\n    currentPathIndex++;\n  }\n\n  return {match: true, lastIndex: currentCommandIndex};\n}\n\nfunction createNewSegment(segment: UrlSegment, startIndex: number, commands: any[]): UrlSegment {\n  const paths = segment.pathsWithParams.slice(0, startIndex);\n  let i = 0;\n  while (i < commands.length) {\n    if (i === 0 && (typeof commands[0] === 'object')) {\n      const p = segment.pathsWithParams[startIndex];\n      paths.push(new UrlPathWithParams(p.path, commands[0]));\n      i++;\n      continue;\n    }\n\n    const curr = getPath(commands[i]);\n    const next = (i < commands.length - 1) ? commands[i + 1] : null;\n    if (curr && next && (typeof next === 'object')) {\n      paths.push(new UrlPathWithParams(curr, stringify(next)));\n      i += 2;\n    } else {\n      paths.push(new UrlPathWithParams(curr, {}));\n      i++;\n    }\n  }\n  return new UrlSegment(paths, {});\n}\n\nfunction stringify(params: {[key: string]: any}): {[key: string]: string} {\n  const res: {[key: string]: string} = {};\n  forEach(params, (v, k) => res[k] = `${v}`);\n  return res;\n}\n\nfunction compare(\n    path: string, params: {[key: string]: any}, pathWithParams: UrlPathWithParams): boolean {\n  return path == pathWithParams.path && shallowEqual(params, pathWithParams.parameters);\n}"]}

@@ -10,7 +10,7 @@ import { ComponentFactory, ResolvedReflectiveProvider, ViewContainerRef } from '@angular/core';

constructor(parentOutletMap: RouterOutletMap, location: ViewContainerRef, name: string);
readonly isActivated: boolean;
readonly component: Object;
readonly activatedRoute: ActivatedRoute;
isActivated: boolean;
component: Object;
activatedRoute: ActivatedRoute;
deactivate(): void;
activate(factory: ComponentFactory<any>, activatedRoute: ActivatedRoute, providers: ResolvedReflectiveProvider[], outletMap: RouterOutletMap): void;
}

@@ -65,2 +65,2 @@ "use strict";

exports.RouterOutlet = RouterOutlet;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyX291dGxldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kaXJlY3RpdmVzL3JvdXRlcl9vdXRsZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLHFCQUFxSSxlQUFlLENBQUMsQ0FBQTtBQUNySixrQ0FBOEIsc0JBQXNCLENBQUMsQ0FBQTtBQUVyRCx1QkFBNkIsV0FBVyxDQUFDLENBQUE7QUFHekM7SUFRRSxzQkFDSSxlQUFnQyxFQUFVLFFBQTBCLEVBQ2pELElBQVk7UUFEVyxhQUFRLEdBQVIsUUFBUSxDQUFrQjtRQUV0RSxlQUFlLENBQUMsY0FBYyxDQUFDLElBQUksR0FBRyxJQUFJLEdBQUcsdUJBQWMsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBRUQsc0JBQUkscUNBQVc7YUFBZixjQUE2QixNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDOzs7T0FBQTtJQUN2RCxzQkFBSSxtQ0FBUzthQUFiO1lBQ0UsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO2dCQUFDLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztZQUNoRSxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUM7UUFDakMsQ0FBQzs7O09BQUE7SUFDRCxzQkFBSSx3Q0FBYzthQUFsQjtZQUNFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQztnQkFBQyxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7WUFDaEUsTUFBTSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUM7UUFDOUIsQ0FBQzs7O09BQUE7SUFFRCxpQ0FBVSxHQUFWO1FBQ0UsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7WUFDbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUN6QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUN4QixDQUFDO0lBQ0gsQ0FBQztJQUVELCtCQUFRLEdBQVIsVUFDSSxPQUE4QixFQUFFLGNBQThCLEVBQUUsU0FBdUMsRUFDdkcsU0FBMEI7UUFDNUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDM0IsSUFBSSxDQUFDLGVBQWUsR0FBRyxjQUFjLENBQUM7UUFDdEMsSUFBTSxHQUFHLEdBQUcseUJBQWtCLENBQUMscUJBQXFCLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDOUYsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3pGLENBQUM7SUF2Q0g7UUFBQyxnQkFBUyxDQUFDLEVBQUMsUUFBUSxFQUFFLGVBQWUsRUFBQyxDQUFDO21CQVdoQyxnQkFBUyxDQUFDLE1BQU0sQ0FBQzs7b0JBWGU7SUF3Q3ZDLG1CQUFDO0FBQUQsQ0FBQyxBQXZDRCxJQXVDQztBQXZDWSxvQkFBWSxlQXVDeEIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXR0cmlidXRlLCBDb21wb25lbnRGYWN0b3J5LCBDb21wb25lbnRSZWYsIERpcmVjdGl2ZSwgUmVmbGVjdGl2ZUluamVjdG9yLCBSZXNvbHZlZFJlZmxlY3RpdmVQcm92aWRlciwgVmlld0NvbnRhaW5lclJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1JvdXRlck91dGxldE1hcH0gZnJvbSAnLi4vcm91dGVyX291dGxldF9tYXAnO1xuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZX0gZnJvbSAnLi4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7UFJJTUFSWV9PVVRMRVR9IGZyb20gJy4uL3NoYXJlZCc7XG5cbkBEaXJlY3RpdmUoe3NlbGVjdG9yOiAncm91dGVyLW91dGxldCd9KVxuZXhwb3J0IGNsYXNzIFJvdXRlck91dGxldCB7XG4gIHByaXZhdGUgYWN0aXZhdGVkOiBDb21wb25lbnRSZWY8YW55PnxudWxsO1xuICBwcml2YXRlIF9hY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGV8bnVsbDtcbiAgcHVibGljIG91dGxldE1hcDogUm91dGVyT3V0bGV0TWFwO1xuXG4gIC8qKlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIGNvbnN0cnVjdG9yKFxuICAgICAgcGFyZW50T3V0bGV0TWFwOiBSb3V0ZXJPdXRsZXRNYXAsIHByaXZhdGUgbG9jYXRpb246IFZpZXdDb250YWluZXJSZWYsXG4gICAgICBAQXR0cmlidXRlKCduYW1lJykgbmFtZTogc3RyaW5nKSB7XG4gICAgcGFyZW50T3V0bGV0TWFwLnJlZ2lzdGVyT3V0bGV0KG5hbWUgPyBuYW1lIDogUFJJTUFSWV9PVVRMRVQsIHRoaXMpO1xuICB9XG5cbiAgZ2V0IGlzQWN0aXZhdGVkKCk6IGJvb2xlYW4geyByZXR1cm4gISF0aGlzLmFjdGl2YXRlZDsgfVxuICBnZXQgY29tcG9uZW50KCk6IE9iamVjdCB7XG4gICAgaWYgKCF0aGlzLmFjdGl2YXRlZCkgdGhyb3cgbmV3IEVycm9yKCdPdXRsZXQgaXMgbm90IGFjdGl2YXRlZCcpO1xuICAgIHJldHVybiB0aGlzLmFjdGl2YXRlZC5pbnN0YW5jZTtcbiAgfVxuICBnZXQgYWN0aXZhdGVkUm91dGUoKTogQWN0aXZhdGVkUm91dGUge1xuICAgIGlmICghdGhpcy5hY3RpdmF0ZWQpIHRocm93IG5ldyBFcnJvcignT3V0bGV0IGlzIG5vdCBhY3RpdmF0ZWQnKTtcbiAgICByZXR1cm4gdGhpcy5fYWN0aXZhdGVkUm91dGU7XG4gIH1cblxuICBkZWFjdGl2YXRlKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmFjdGl2YXRlZCkge1xuICAgICAgdGhpcy5hY3RpdmF0ZWQuZGVzdHJveSgpO1xuICAgICAgdGhpcy5hY3RpdmF0ZWQgPSBudWxsO1xuICAgIH1cbiAgfVxuXG4gIGFjdGl2YXRlKFxuICAgICAgZmFjdG9yeTogQ29tcG9uZW50RmFjdG9yeTxhbnk+LCBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGUsIHByb3ZpZGVyczogUmVzb2x2ZWRSZWZsZWN0aXZlUHJvdmlkZXJbXSxcbiAgICAgIG91dGxldE1hcDogUm91dGVyT3V0bGV0TWFwKTogdm9pZCB7XG4gICAgdGhpcy5vdXRsZXRNYXAgPSBvdXRsZXRNYXA7XG4gICAgdGhpcy5fYWN0aXZhdGVkUm91dGUgPSBhY3RpdmF0ZWRSb3V0ZTtcbiAgICBjb25zdCBpbmogPSBSZWZsZWN0aXZlSW5qZWN0b3IuZnJvbVJlc29sdmVkUHJvdmlkZXJzKHByb3ZpZGVycywgdGhpcy5sb2NhdGlvbi5wYXJlbnRJbmplY3Rvcik7XG4gICAgdGhpcy5hY3RpdmF0ZWQgPSB0aGlzLmxvY2F0aW9uLmNyZWF0ZUNvbXBvbmVudChmYWN0b3J5LCB0aGlzLmxvY2F0aW9uLmxlbmd0aCwgaW5qLCBbXSk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyX291dGxldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kaXJlY3RpdmVzL3JvdXRlcl9vdXRsZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLHFCQUFxSSxlQUFlLENBQUMsQ0FBQTtBQUNySixrQ0FBOEIsc0JBQXNCLENBQUMsQ0FBQTtBQUVyRCx1QkFBNkIsV0FBVyxDQUFDLENBQUE7QUFHekM7SUFRRSxzQkFDSSxlQUFnQyxFQUFVLFFBQTBCLEVBQ2pELElBQVk7UUFEVyxhQUFRLEdBQVIsUUFBUSxDQUFrQjtRQUV0RSxlQUFlLENBQUMsY0FBYyxDQUFDLElBQUksR0FBRyxJQUFJLEdBQUcsdUJBQWMsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBRUQsc0JBQUkscUNBQVc7YUFBZixjQUE2QixNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDOzs7T0FBQTtJQUN2RCxzQkFBSSxtQ0FBUzthQUFiO1lBQ0UsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO2dCQUFDLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztZQUNoRSxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUM7UUFDakMsQ0FBQzs7O09BQUE7SUFDRCxzQkFBSSx3Q0FBYzthQUFsQjtZQUNFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQztnQkFBQyxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7WUFDaEUsTUFBTSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUM7UUFDOUIsQ0FBQzs7O09BQUE7SUFFRCxpQ0FBVSxHQUFWO1FBQ0UsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7WUFDbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUN6QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUN4QixDQUFDO0lBQ0gsQ0FBQztJQUVELCtCQUFRLEdBQVIsVUFDSSxPQUE4QixFQUFFLGNBQThCLEVBQzlELFNBQXVDLEVBQUUsU0FBMEI7UUFDckUsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDM0IsSUFBSSxDQUFDLGVBQWUsR0FBRyxjQUFjLENBQUM7UUFDdEMsSUFBTSxHQUFHLEdBQUcseUJBQWtCLENBQUMscUJBQXFCLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDOUYsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3pGLENBQUM7SUF2Q0g7UUFBQyxnQkFBUyxDQUFDLEVBQUMsUUFBUSxFQUFFLGVBQWUsRUFBQyxDQUFDO21CQVdoQyxnQkFBUyxDQUFDLE1BQU0sQ0FBQzs7b0JBWGU7SUF3Q3ZDLG1CQUFDO0FBQUQsQ0FBQyxBQXZDRCxJQXVDQztBQXZDWSxvQkFBWSxlQXVDeEIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXR0cmlidXRlLCBDb21wb25lbnRGYWN0b3J5LCBDb21wb25lbnRSZWYsIERpcmVjdGl2ZSwgUmVmbGVjdGl2ZUluamVjdG9yLCBSZXNvbHZlZFJlZmxlY3RpdmVQcm92aWRlciwgVmlld0NvbnRhaW5lclJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1JvdXRlck91dGxldE1hcH0gZnJvbSAnLi4vcm91dGVyX291dGxldF9tYXAnO1xuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZX0gZnJvbSAnLi4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7UFJJTUFSWV9PVVRMRVR9IGZyb20gJy4uL3NoYXJlZCc7XG5cbkBEaXJlY3RpdmUoe3NlbGVjdG9yOiAncm91dGVyLW91dGxldCd9KVxuZXhwb3J0IGNsYXNzIFJvdXRlck91dGxldCB7XG4gIHByaXZhdGUgYWN0aXZhdGVkOiBDb21wb25lbnRSZWY8YW55PjtcbiAgcHJpdmF0ZSBfYWN0aXZhdGVkUm91dGU6IEFjdGl2YXRlZFJvdXRlO1xuICBwdWJsaWMgb3V0bGV0TWFwOiBSb3V0ZXJPdXRsZXRNYXA7XG5cbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgY29uc3RydWN0b3IoXG4gICAgICBwYXJlbnRPdXRsZXRNYXA6IFJvdXRlck91dGxldE1hcCwgcHJpdmF0ZSBsb2NhdGlvbjogVmlld0NvbnRhaW5lclJlZixcbiAgICAgIEBBdHRyaWJ1dGUoJ25hbWUnKSBuYW1lOiBzdHJpbmcpIHtcbiAgICBwYXJlbnRPdXRsZXRNYXAucmVnaXN0ZXJPdXRsZXQobmFtZSA/IG5hbWUgOiBQUklNQVJZX09VVExFVCwgdGhpcyk7XG4gIH1cblxuICBnZXQgaXNBY3RpdmF0ZWQoKTogYm9vbGVhbiB7IHJldHVybiAhIXRoaXMuYWN0aXZhdGVkOyB9XG4gIGdldCBjb21wb25lbnQoKTogT2JqZWN0IHtcbiAgICBpZiAoIXRoaXMuYWN0aXZhdGVkKSB0aHJvdyBuZXcgRXJyb3IoJ091dGxldCBpcyBub3QgYWN0aXZhdGVkJyk7XG4gICAgcmV0dXJuIHRoaXMuYWN0aXZhdGVkLmluc3RhbmNlO1xuICB9XG4gIGdldCBhY3RpdmF0ZWRSb3V0ZSgpOiBBY3RpdmF0ZWRSb3V0ZSB7XG4gICAgaWYgKCF0aGlzLmFjdGl2YXRlZCkgdGhyb3cgbmV3IEVycm9yKCdPdXRsZXQgaXMgbm90IGFjdGl2YXRlZCcpO1xuICAgIHJldHVybiB0aGlzLl9hY3RpdmF0ZWRSb3V0ZTtcbiAgfVxuXG4gIGRlYWN0aXZhdGUoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuYWN0aXZhdGVkKSB7XG4gICAgICB0aGlzLmFjdGl2YXRlZC5kZXN0cm95KCk7XG4gICAgICB0aGlzLmFjdGl2YXRlZCA9IG51bGw7XG4gICAgfVxuICB9XG5cbiAgYWN0aXZhdGUoXG4gICAgICBmYWN0b3J5OiBDb21wb25lbnRGYWN0b3J5PGFueT4sIGFjdGl2YXRlZFJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSxcbiAgICAgIHByb3ZpZGVyczogUmVzb2x2ZWRSZWZsZWN0aXZlUHJvdmlkZXJbXSwgb3V0bGV0TWFwOiBSb3V0ZXJPdXRsZXRNYXApOiB2b2lkIHtcbiAgICB0aGlzLm91dGxldE1hcCA9IG91dGxldE1hcDtcbiAgICB0aGlzLl9hY3RpdmF0ZWRSb3V0ZSA9IGFjdGl2YXRlZFJvdXRlO1xuICAgIGNvbnN0IGluaiA9IFJlZmxlY3RpdmVJbmplY3Rvci5mcm9tUmVzb2x2ZWRQcm92aWRlcnMocHJvdmlkZXJzLCB0aGlzLmxvY2F0aW9uLnBhcmVudEluamVjdG9yKTtcbiAgICB0aGlzLmFjdGl2YXRlZCA9IHRoaXMubG9jYXRpb24uY3JlYXRlQ29tcG9uZW50KGZhY3RvcnksIHRoaXMubG9jYXRpb24ubGVuZ3RoLCBpbmosIFtdKTtcbiAgfVxufVxuIl19
import { Observable } from 'rxjs/Observable';
import { Route, RouterConfig } from './config';
import { UrlSegment, UrlTree } from './url_tree';
import { TreeNode } from './utils/tree';
import { RouterConfig } from './config';
import { UrlTree } from './url_tree';
export declare function applyRedirects(urlTree: UrlTree, config: RouterConfig): Observable<UrlTree>;
export declare function match(route: Route, url: TreeNode<UrlSegment>): {
consumedUrlSegments: any[];
lastSegment: TreeNode<UrlSegment>;
lastParent: TreeNode<UrlSegment>;
positionalParamSegments: {};
};
import { Observable } from 'rxjs/Observable';
import { of } from 'rxjs/observable/of';
import { PRIMARY_OUTLET } from './shared';
import { UrlSegment, UrlTree } from './url_tree';
import { first } from './utils/collection';
import { TreeNode } from './utils/tree';
import { UrlPathWithParams, UrlSegment, UrlTree, mapChildren } from './url_tree';
class NoMatch {
constructor(segment = null) {
this.segment = segment;
}
}
class GlobalRedirect {
constructor(segments) {
this.segments = segments;
constructor(paths) {
this.paths = paths;
}

@@ -16,11 +17,10 @@ }

try {
const transformedChildren = urlTree._root.children.map(c => applyNode(config, c));
return createUrlTree(urlTree, transformedChildren);
return createUrlTree(urlTree, expandSegment(config, urlTree.root, PRIMARY_OUTLET));
}
catch (e) {
if (e instanceof GlobalRedirect) {
return createUrlTree(urlTree, [constructNodes(e.segments, [], [])]);
return createUrlTree(urlTree, new UrlSegment([], { [PRIMARY_OUTLET]: new UrlSegment(e.paths, {}) }));
}
else if (e instanceof NoMatch) {
return new Observable(obs => obs.error(new Error('Cannot match any routes')));
return new Observable(obs => obs.error(new Error(`Cannot match any routes: '${e.segment}'`)));
}

@@ -32,10 +32,20 @@ else {

}
function createUrlTree(urlTree, children) {
const transformedRoot = new TreeNode(urlTree.root, children);
return of(new UrlTree(transformedRoot, urlTree.queryParams, urlTree.fragment));
function createUrlTree(urlTree, root) {
return of(new UrlTree(root, urlTree.queryParams, urlTree.fragment));
}
function applyNode(config, url) {
for (let r of config) {
function expandSegment(routes, segment, outlet) {
if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {
return new UrlSegment([], expandSegmentChildren(routes, segment));
}
else {
return expandPathsWithParams(segment, routes, segment.pathsWithParams, outlet, true);
}
}
function expandSegmentChildren(routes, segment) {
return mapChildren(segment, (child, childOutlet) => expandSegment(routes, child, childOutlet));
}
function expandPathsWithParams(segment, routes, paths, outlet, allowRedirects) {
for (let r of routes) {
try {
return matchNode(config, r, url);
return expandPathsWithParamsAgainstRoute(segment, routes, r, paths, outlet, allowRedirects);
}

@@ -47,86 +57,112 @@ catch (e) {

}
throw new NoMatch();
throw new NoMatch(segment);
}
function matchNode(config, route, url) {
if (!route.path)
function expandPathsWithParamsAgainstRoute(segment, routes, route, paths, outlet, allowRedirects) {
if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== outlet)
throw new NoMatch();
if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== url.value.outlet) {
if (route.redirectTo && !allowRedirects)
throw new NoMatch();
if (route.redirectTo) {
return expandPathsWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet);
}
else {
return matchPathsWithParamsAgainstRoute(segment, route, paths);
}
}
function expandPathsWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet) {
if (route.path === '**') {
const newSegments = applyRedirectCommands([], route.redirectTo, {});
return constructNodes(newSegments, [], []);
return expandWildCardWithParamsAgainstRouteUsingRedirect(route);
}
const m = match(route, url);
if (!m)
throw new NoMatch();
const { consumedUrlSegments, lastSegment, lastParent, positionalParamSegments } = m;
const newSegments = applyRedirectCommands(consumedUrlSegments, route.redirectTo, positionalParamSegments);
const childConfig = route.children ? route.children : [];
const transformedChildren = lastSegment.children.map(c => applyNode(childConfig, c));
const secondarySubtrees = lastParent ? lastParent.children.slice(1) : [];
const transformedSecondarySubtrees = secondarySubtrees.map(c => applyNode(config, c));
return constructNodes(newSegments, transformedChildren, transformedSecondarySubtrees);
else {
return expandRegularPathWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet);
}
}
export function match(route, url) {
function expandWildCardWithParamsAgainstRouteUsingRedirect(route) {
const newPaths = applyRedirectCommands([], route.redirectTo, {});
if (route.redirectTo.startsWith('/')) {
throw new GlobalRedirect(newPaths);
}
else {
return new UrlSegment(newPaths, {});
}
}
function expandRegularPathWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet) {
const { consumedPaths, lastChild, positionalParamSegments } = match(segment, route, paths);
const newPaths = applyRedirectCommands(consumedPaths, route.redirectTo, positionalParamSegments);
if (route.redirectTo.startsWith('/')) {
throw new GlobalRedirect(newPaths);
}
else {
return expandPathsWithParams(segment, routes, newPaths.concat(paths.slice(lastChild)), outlet, false);
}
}
function matchPathsWithParamsAgainstRoute(segment, route, paths) {
if (route.path === '**') {
return new UrlSegment(paths, {});
}
else {
const { consumedPaths, lastChild } = match(segment, route, paths);
const childConfig = route.children ? route.children : [];
const slicedPath = paths.slice(lastChild);
if (childConfig.length === 0 && slicedPath.length === 0) {
return new UrlSegment(consumedPaths, {});
}
else if (slicedPath.length === 0 && Object.keys(segment.children).length > 0) {
const children = expandSegmentChildren(childConfig, segment);
return new UrlSegment(consumedPaths, children);
}
else {
const cs = expandPathsWithParams(segment, childConfig, slicedPath, PRIMARY_OUTLET, true);
return new UrlSegment(consumedPaths.concat(cs.pathsWithParams), cs.children);
}
}
}
function match(segment, route, paths) {
if (route.index || route.path === '' || route.path === '/') {
if (route.terminal && (Object.keys(segment.children).length > 0 || paths.length > 0)) {
throw new NoMatch();
}
else {
return { consumedPaths: [], lastChild: 0, positionalParamSegments: {} };
}
}
const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;
const parts = path.split('/');
const positionalParamSegments = {};
const consumedUrlSegments = [];
let lastParent = null;
let lastSegment = null;
let current = url;
const consumedPaths = [];
let currentIndex = 0;
for (let i = 0; i < parts.length; ++i) {
if (!current)
return null;
if (currentIndex >= paths.length)
throw new NoMatch();
const current = paths[currentIndex];
const p = parts[i];
const isLastSegment = i === parts.length - 1;
const isLastParent = i === parts.length - 2;
const isPosParam = p.startsWith(':');
if (!isPosParam && p != current.value.path)
return null;
if (isLastSegment) {
lastSegment = current;
}
if (isLastParent) {
lastParent = current;
}
if (!isPosParam && p !== current.path)
throw new NoMatch();
if (isPosParam) {
positionalParamSegments[p.substring(1)] = current.value;
positionalParamSegments[p.substring(1)] = current;
}
consumedUrlSegments.push(current.value);
current = first(current.children);
consumedPaths.push(current);
currentIndex++;
}
if (!lastSegment)
throw 'Cannot be reached';
return { consumedUrlSegments, lastSegment, lastParent, positionalParamSegments };
}
function constructNodes(segments, children, secondary) {
let prevChildren = children;
for (let i = segments.length - 1; i >= 0; --i) {
if (i === segments.length - 2) {
prevChildren = [new TreeNode(segments[i], prevChildren.concat(secondary))];
}
else {
prevChildren = [new TreeNode(segments[i], prevChildren)];
}
if (route.terminal && (Object.keys(segment.children).length > 0 || currentIndex < paths.length)) {
throw new NoMatch();
}
return prevChildren[0];
return { consumedPaths, lastChild: currentIndex, positionalParamSegments };
}
function applyRedirectCommands(segments, redirectTo, posParams) {
if (!redirectTo)
return segments;
function applyRedirectCommands(paths, redirectTo, posParams) {
if (redirectTo.startsWith('/')) {
const parts = redirectTo.substring(1).split('/');
throw new GlobalRedirect(createSegments(redirectTo, parts, segments, posParams));
return createPaths(redirectTo, parts, paths, posParams);
}
else {
return createSegments(redirectTo, redirectTo.split('/'), segments, posParams);
const parts = redirectTo.split('/');
return createPaths(redirectTo, parts, paths, posParams);
}
}
function createSegments(redirectTo, parts, segments, posParams) {
return parts.map(p => p.startsWith(':') ? findPosParamSegment(p, posParams, redirectTo) :
findOrCreateSegment(p, segments));
function createPaths(redirectTo, parts, segments, posParams) {
return parts.map(p => p.startsWith(':') ? findPosParam(p, posParams, redirectTo) :
findOrCreatePath(p, segments));
}
function findPosParamSegment(part, posParams, redirectTo) {
function findPosParam(part, posParams, redirectTo) {
const paramName = part.substring(1);

@@ -138,13 +174,13 @@ const pos = posParams[paramName];

}
function findOrCreateSegment(part, segments) {
const matchingIndex = segments.findIndex(s => s.path === part);
function findOrCreatePath(part, paths) {
const matchingIndex = paths.findIndex(s => s.path === part);
if (matchingIndex > -1) {
const r = segments[matchingIndex];
segments.splice(matchingIndex);
const r = paths[matchingIndex];
paths.splice(matchingIndex);
return r;
}
else {
return new UrlSegment(part, {}, PRIMARY_OUTLET);
return new UrlPathWithParams(part, {});
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apply_redirects.js","sourceRoot":"","sources":["../../src/apply_redirects.ts"],"names":[],"mappings":"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","sourcesContent":["import {Observable} from 'rxjs/Observable';\nimport {of } from 'rxjs/observable/of';\n\nimport {Route, RouterConfig} from './config';\nimport {PRIMARY_OUTLET} from './shared';\nimport {UrlSegment, UrlTree} from './url_tree';\nimport {first} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nclass NoMatch {}\nclass GlobalRedirect {\n  constructor(public segments: UrlSegment[]) {}\n}\n\nexport function applyRedirects(urlTree: UrlTree, config: RouterConfig): Observable<UrlTree> {\n  try {\n    const transformedChildren = urlTree._root.children.map(c => applyNode(config, c));\n    return createUrlTree(urlTree, transformedChildren);\n  } catch (e) {\n    if (e instanceof GlobalRedirect) {\n      return createUrlTree(urlTree, [constructNodes(e.segments, [], [])]);\n    } else if (e instanceof NoMatch) {\n      return new Observable<UrlTree>(obs => obs.error(new Error('Cannot match any routes')));\n    } else {\n      return new Observable<UrlTree>(obs => obs.error(e));\n    }\n  }\n}\n\nfunction createUrlTree(urlTree: UrlTree, children: TreeNode<UrlSegment>[]): Observable<UrlTree> {\n  const transformedRoot = new TreeNode<UrlSegment>(urlTree.root, children);\n  return of (new UrlTree(transformedRoot, urlTree.queryParams, urlTree.fragment));\n}\n\nfunction applyNode(config: Route[], url: TreeNode<UrlSegment>): TreeNode<UrlSegment> {\n  for (let r of config) {\n    try {\n      return matchNode(config, r, url);\n    } catch (e) {\n      if (!(e instanceof NoMatch)) throw e;\n    }\n  }\n  throw new NoMatch();\n}\n\nfunction matchNode(config: Route[], route: Route, url: TreeNode<UrlSegment>): TreeNode<UrlSegment> {\n  if (!route.path) throw new NoMatch();\n  if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== url.value.outlet) {\n    throw new NoMatch();\n  }\n\n  if (route.path === '**') {\n    const newSegments = applyRedirectCommands([], route.redirectTo, {});\n    return constructNodes(newSegments, [], []);\n  }\n\n  const m = match(route, url);\n  if (!m) throw new NoMatch();\n  const {consumedUrlSegments, lastSegment, lastParent, positionalParamSegments} = m;\n\n  const newSegments =\n      applyRedirectCommands(consumedUrlSegments, route.redirectTo, positionalParamSegments);\n\n  const childConfig = route.children ? route.children : [];\n  const transformedChildren = lastSegment.children.map(c => applyNode(childConfig, c));\n\n  const secondarySubtrees = lastParent ? lastParent.children.slice(1) : [];\n  const transformedSecondarySubtrees = secondarySubtrees.map(c => applyNode(config, c));\n\n  return constructNodes(newSegments, transformedChildren, transformedSecondarySubtrees);\n}\n\nexport function match(route: Route, url: TreeNode<UrlSegment>) {\n  const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;\n  const parts = path.split('/');\n  const positionalParamSegments = {};\n  const consumedUrlSegments = [];\n\n  let lastParent: TreeNode<UrlSegment>|null = null;\n  let lastSegment: TreeNode<UrlSegment>|null = null;\n\n  let current: TreeNode<UrlSegment>|null = url;\n  for (let i = 0; i < parts.length; ++i) {\n    if (!current) return null;\n\n    const p = parts[i];\n    const isLastSegment = i === parts.length - 1;\n    const isLastParent = i === parts.length - 2;\n    const isPosParam = p.startsWith(':');\n\n    if (!isPosParam && p != current.value.path) return null;\n    if (isLastSegment) {\n      lastSegment = current;\n    }\n    if (isLastParent) {\n      lastParent = current;\n    }\n    if (isPosParam) {\n      positionalParamSegments[p.substring(1)] = current.value;\n    }\n    consumedUrlSegments.push(current.value);\n    current = first(current.children);\n  }\n  if (!lastSegment) throw 'Cannot be reached';\n  return {consumedUrlSegments, lastSegment, lastParent, positionalParamSegments};\n}\n\nfunction constructNodes(\n    segments: UrlSegment[], children: TreeNode<UrlSegment>[],\n    secondary: TreeNode<UrlSegment>[]): TreeNode<UrlSegment> {\n  let prevChildren = children;\n  for (let i = segments.length - 1; i >= 0; --i) {\n    if (i === segments.length - 2) {\n      prevChildren = [new TreeNode<UrlSegment>(segments[i], prevChildren.concat(secondary))];\n    } else {\n      prevChildren = [new TreeNode<UrlSegment>(segments[i], prevChildren)];\n    }\n  }\n  return prevChildren[0];\n}\n\nfunction applyRedirectCommands(\n    segments: UrlSegment[], redirectTo: string,\n    posParams: {[k: string]: UrlSegment}): UrlSegment[] {\n  if (!redirectTo) return segments;\n\n  if (redirectTo.startsWith('/')) {\n    const parts = redirectTo.substring(1).split('/');\n    throw new GlobalRedirect(createSegments(redirectTo, parts, segments, posParams));\n  } else {\n    return createSegments(redirectTo, redirectTo.split('/'), segments, posParams);\n  }\n}\n\nfunction createSegments(\n    redirectTo: string, parts: string[], segments: UrlSegment[],\n    posParams: {[k: string]: UrlSegment}): UrlSegment[] {\n  return parts.map(\n      p => p.startsWith(':') ? findPosParamSegment(p, posParams, redirectTo) :\n                               findOrCreateSegment(p, segments));\n}\n\nfunction findPosParamSegment(\n    part: string, posParams: {[k: string]: UrlSegment}, redirectTo: string): UrlSegment {\n  const paramName = part.substring(1);\n  const pos = posParams[paramName];\n  if (!pos) throw new Error(`Cannot redirect to '${redirectTo}'. Cannot find '${part}'.`);\n  return pos;\n}\n\nfunction findOrCreateSegment(part: string, segments: UrlSegment[]): UrlSegment {\n  const matchingIndex = segments.findIndex(s => s.path === part);\n  if (matchingIndex > -1) {\n    const r = segments[matchingIndex];\n    segments.splice(matchingIndex);\n    return r;\n  } else {\n    return new UrlSegment(part, {}, PRIMARY_OUTLET);\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"apply_redirects.js","sourceRoot":"","sources":["../../src/apply_redirects.ts"],"names":[],"mappings":"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","sourcesContent":["import {Observable} from 'rxjs/Observable';\nimport {of } from 'rxjs/observable/of';\n\nimport {Route, RouterConfig} from './config';\nimport {PRIMARY_OUTLET} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree, mapChildren} from './url_tree';\n\nclass NoMatch {\n  constructor(public segment: UrlSegment = null) {}\n}\nclass GlobalRedirect {\n  constructor(public paths: UrlPathWithParams[]) {}\n}\n\nexport function applyRedirects(urlTree: UrlTree, config: RouterConfig): Observable<UrlTree> {\n  try {\n    return createUrlTree(urlTree, expandSegment(config, urlTree.root, PRIMARY_OUTLET));\n  } catch (e) {\n    if (e instanceof GlobalRedirect) {\n      return createUrlTree(\n          urlTree, new UrlSegment([], {[PRIMARY_OUTLET]: new UrlSegment(e.paths, {})}));\n    } else if (e instanceof NoMatch) {\n      return new Observable<UrlTree>(\n          obs => obs.error(new Error(`Cannot match any routes: '${e.segment}'`)));\n    } else {\n      return new Observable<UrlTree>(obs => obs.error(e));\n    }\n  }\n}\n\nfunction createUrlTree(urlTree: UrlTree, root: UrlSegment): Observable<UrlTree> {\n  return of (new UrlTree(root, urlTree.queryParams, urlTree.fragment));\n}\n\nfunction expandSegment(routes: Route[], segment: UrlSegment, outlet: string): UrlSegment {\n  if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {\n    return new UrlSegment([], expandSegmentChildren(routes, segment));\n  } else {\n    return expandPathsWithParams(segment, routes, segment.pathsWithParams, outlet, true);\n  }\n}\n\nfunction expandSegmentChildren(routes: Route[], segment: UrlSegment): {[name: string]: UrlSegment} {\n  return mapChildren(segment, (child, childOutlet) => expandSegment(routes, child, childOutlet));\n}\n\nfunction expandPathsWithParams(\n    segment: UrlSegment, routes: Route[], paths: UrlPathWithParams[], outlet: string,\n    allowRedirects: boolean): UrlSegment {\n  for (let r of routes) {\n    try {\n      return expandPathsWithParamsAgainstRoute(segment, routes, r, paths, outlet, allowRedirects);\n    } catch (e) {\n      if (!(e instanceof NoMatch)) throw e;\n    }\n  }\n  throw new NoMatch(segment);\n}\n\nfunction expandPathsWithParamsAgainstRoute(\n    segment: UrlSegment, routes: Route[], route: Route, paths: UrlPathWithParams[], outlet: string,\n    allowRedirects: boolean): UrlSegment {\n  if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== outlet) throw new NoMatch();\n  if (route.redirectTo && !allowRedirects) throw new NoMatch();\n\n  if (route.redirectTo) {\n    return expandPathsWithParamsAgainstRouteUsingRedirect(segment, routes, route, paths, outlet);\n  } else {\n    return matchPathsWithParamsAgainstRoute(segment, route, paths);\n  }\n}\n\nfunction expandPathsWithParamsAgainstRouteUsingRedirect(\n    segment: UrlSegment, routes: Route[], route: Route, paths: UrlPathWithParams[],\n    outlet: string): UrlSegment {\n  if (route.path === '**') {\n    return expandWildCardWithParamsAgainstRouteUsingRedirect(route);\n  } else {\n    return expandRegularPathWithParamsAgainstRouteUsingRedirect(\n        segment, routes, route, paths, outlet);\n  }\n}\n\nfunction expandWildCardWithParamsAgainstRouteUsingRedirect(route: Route): UrlSegment {\n  const newPaths = applyRedirectCommands([], route.redirectTo, {});\n  if (route.redirectTo.startsWith('/')) {\n    throw new GlobalRedirect(newPaths);\n  } else {\n    return new UrlSegment(newPaths, {});\n  }\n}\n\nfunction expandRegularPathWithParamsAgainstRouteUsingRedirect(\n    segment: UrlSegment, routes: Route[], route: Route, paths: UrlPathWithParams[],\n    outlet: string): UrlSegment {\n  const {consumedPaths, lastChild, positionalParamSegments} = match(segment, route, paths);\n  const newPaths =\n      applyRedirectCommands(consumedPaths, route.redirectTo, <any>positionalParamSegments);\n  if (route.redirectTo.startsWith('/')) {\n    throw new GlobalRedirect(newPaths);\n  } else {\n    return expandPathsWithParams(\n        segment, routes, newPaths.concat(paths.slice(lastChild)), outlet, false);\n  }\n}\n\nfunction matchPathsWithParamsAgainstRoute(\n    segment: UrlSegment, route: Route, paths: UrlPathWithParams[]): UrlSegment {\n  if (route.path === '**') {\n    return new UrlSegment(paths, {});\n  } else {\n    const {consumedPaths, lastChild} = match(segment, route, paths);\n    const childConfig = route.children ? route.children : [];\n    const slicedPath = paths.slice(lastChild);\n\n    if (childConfig.length === 0 && slicedPath.length === 0) {\n      return new UrlSegment(consumedPaths, {});\n\n      // TODO: check that the right segment is present\n    } else if (slicedPath.length === 0 && Object.keys(segment.children).length > 0) {\n      const children = expandSegmentChildren(childConfig, segment);\n      return new UrlSegment(consumedPaths, children);\n\n    } else {\n      const cs = expandPathsWithParams(segment, childConfig, slicedPath, PRIMARY_OUTLET, true);\n      return new UrlSegment(consumedPaths.concat(cs.pathsWithParams), cs.children);\n    }\n  }\n}\n\nfunction match(segment: UrlSegment, route: Route, paths: UrlPathWithParams[]) {\n  if (route.index || route.path === '' || route.path === '/') {\n    if (route.terminal && (Object.keys(segment.children).length > 0 || paths.length > 0)) {\n      throw new NoMatch();\n    } else {\n      return {consumedPaths: [], lastChild: 0, positionalParamSegments: {}};\n    }\n  }\n\n  const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;\n  const parts = path.split('/');\n  const positionalParamSegments = {};\n  const consumedPaths = [];\n\n  let currentIndex = 0;\n\n  for (let i = 0; i < parts.length; ++i) {\n    if (currentIndex >= paths.length) throw new NoMatch();\n    const current = paths[currentIndex];\n\n    const p = parts[i];\n    const isPosParam = p.startsWith(':');\n\n    if (!isPosParam && p !== current.path) throw new NoMatch();\n    if (isPosParam) {\n      positionalParamSegments[p.substring(1)] = current;\n    }\n    consumedPaths.push(current);\n    currentIndex++;\n  }\n\n  if (route.terminal && (Object.keys(segment.children).length > 0 || currentIndex < paths.length)) {\n    throw new NoMatch();\n  }\n\n  return {consumedPaths, lastChild: currentIndex, positionalParamSegments};\n}\n\nfunction applyRedirectCommands(\n    paths: UrlPathWithParams[], redirectTo: string,\n    posParams: {[k: string]: UrlPathWithParams}): UrlPathWithParams[] {\n  if (redirectTo.startsWith('/')) {\n    const parts = redirectTo.substring(1).split('/');\n    return createPaths(redirectTo, parts, paths, posParams);\n  } else {\n    const parts = redirectTo.split('/');\n    return createPaths(redirectTo, parts, paths, posParams);\n  }\n}\n\nfunction createPaths(\n    redirectTo: string, parts: string[], segments: UrlPathWithParams[],\n    posParams: {[k: string]: UrlPathWithParams}): UrlPathWithParams[] {\n  return parts.map(\n      p => p.startsWith(':') ? findPosParam(p, posParams, redirectTo) :\n                               findOrCreatePath(p, segments));\n}\n\nfunction findPosParam(\n    part: string, posParams: {[k: string]: UrlPathWithParams},\n    redirectTo: string): UrlPathWithParams {\n  const paramName = part.substring(1);\n  const pos = posParams[paramName];\n  if (!pos) throw new Error(`Cannot redirect to '${redirectTo}'. Cannot find '${part}'.`);\n  return pos;\n}\n\nfunction findOrCreatePath(part: string, paths: UrlPathWithParams[]): UrlPathWithParams {\n  const matchingIndex = paths.findIndex(s => s.path === part);\n  if (matchingIndex > -1) {\n    const r = paths[matchingIndex];\n    paths.splice(matchingIndex);\n    return r;\n  } else {\n    return new UrlPathWithParams(part, {});\n  }\n}\n"]}

@@ -0,2 +1,11 @@

import { Injector, OpaqueToken } from '@angular/core';
import { RouterConfig } from './config';
export declare function provideRouter(config: RouterConfig): any[];
import { Router } from './router';
export declare const ROUTER_CONFIG: OpaqueToken;
export declare const ROUTER_OPTIONS: OpaqueToken;
export interface ExtraOptions {
enableTracing?: boolean;
}
export declare function setupRouter(ref: any, resolver: any, urlSerializer: any, outletMap: any, location: any, injector: any, config: any, opts: any): Router;
export declare function setupRouterInitializer(injector: Injector): (_: any) => any;
export declare function provideRouter(_config: RouterConfig, _opts: ExtraOptions): any[];
import { Location, LocationStrategy, PathLocationStrategy } from '@angular/common';
import { APP_INITIALIZER, ApplicationRef, ComponentResolver, Injector } from '@angular/core';
import { APP_INITIALIZER, ApplicationRef, ComponentResolver, Injector, OpaqueToken } from '@angular/core';
import { Router } from './router';

@@ -7,43 +7,51 @@ import { RouterOutletMap } from './router_outlet_map';

import { DefaultUrlSerializer, UrlSerializer } from './url_serializer';
export function provideRouter(config) {
export const ROUTER_CONFIG = new OpaqueToken('ROUTER_CONFIG');
export const ROUTER_OPTIONS = new OpaqueToken('ROUTER_OPTIONS');
export function setupRouter(ref, resolver, urlSerializer, outletMap, location, injector, config, opts) {
if (ref.componentTypes.length == 0) {
throw new Error('Bootstrap at least one component before injecting Router.');
}
const componentType = ref.componentTypes[0];
const r = new Router(componentType, resolver, urlSerializer, outletMap, location, injector, config);
ref.registerDisposeListener(() => r.dispose());
if (opts.enableTracing) {
r.events.subscribe(e => {
console.group(`Router Event: ${e.constructor.name}`);
console.log(e.toString());
console.log(e);
console.groupEnd();
});
}
return r;
}
export function setupRouterInitializer(injector) {
setTimeout(_ => {
const appRef = injector.get(ApplicationRef);
if (appRef.componentTypes.length == 0) {
appRef.registerBootstrapListener((_) => { injector.get(Router).initialNavigation(); });
}
else {
injector.get(Router).initialNavigation();
}
}, 0);
return _ => null;
}
export function provideRouter(_config, _opts) {
return [
Location,
{ provide: LocationStrategy, useClass: PathLocationStrategy },
{ provide: ROUTER_CONFIG, useValue: _config }, { provide: ROUTER_OPTIONS, useValue: _opts },
Location, { provide: LocationStrategy, useClass: PathLocationStrategy },
{ provide: UrlSerializer, useClass: DefaultUrlSerializer },
{
provide: Router,
useFactory: (ref, resolver, urlSerializer, outletMap, location, injector) => {
if (ref.componentTypes.length == 0) {
throw new Error('Bootstrap at least one component before injecting Router.');
}
const componentType = ref.componentTypes[0];
const r = new Router(componentType, resolver, urlSerializer, outletMap, location, injector, config);
ref.registerDisposeListener(() => r.dispose());
return r;
},
deps: [ApplicationRef, ComponentResolver, UrlSerializer, RouterOutletMap, Location, Injector]
useFactory: setupRouter,
deps: [
ApplicationRef, ComponentResolver, UrlSerializer, RouterOutletMap, Location, Injector,
ROUTER_CONFIG, ROUTER_OPTIONS
]
},
RouterOutletMap,
{ provide: ActivatedRoute, useFactory: (r) => r.routerState.root, deps: [Router] },
{
provide: APP_INITIALIZER,
multi: true,
useFactory: (injector) => {
setTimeout(_ => {
const appRef = injector.get(ApplicationRef);
if (appRef.componentTypes.length == 0) {
appRef.registerBootstrapListener((_) => {
injector.get(Router).initialNavigation();
});
}
else {
injector.get(Router).initialNavigation();
}
}, 0);
return _ => null;
},
deps: [Injector]
}
{ provide: APP_INITIALIZER, multi: true, useFactory: setupRouterInitializer, deps: [Injector] }
];
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uX3JvdXRlcl9wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29tbW9uX3JvdXRlcl9wcm92aWRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ik9BQU8sRUFBQyxRQUFRLEVBQUUsZ0JBQWdCLEVBQUUsb0JBQW9CLEVBQUMsTUFBTSxpQkFBaUI7T0FDekUsRUFBQyxlQUFlLEVBQUUsY0FBYyxFQUFFLGlCQUFpQixFQUFFLFFBQVEsRUFBQyxNQUFNLGVBQWU7T0FHbkYsRUFBQyxNQUFNLEVBQUMsTUFBTSxVQUFVO09BQ3hCLEVBQUMsZUFBZSxFQUFDLE1BQU0scUJBQXFCO09BQzVDLEVBQUMsY0FBYyxFQUFDLE1BQU0sZ0JBQWdCO09BQ3RDLEVBQUMsb0JBQW9CLEVBQUUsYUFBYSxFQUFDLE1BQU0sa0JBQWtCO0FBcUJwRSw4QkFBOEIsTUFBb0I7SUFDaEQsTUFBTSxDQUFDO1FBQ0wsUUFBUTtRQUNSLEVBQUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFFBQVEsRUFBRSxvQkFBb0IsRUFBQztRQUMzRCxFQUFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLG9CQUFvQixFQUFDO1FBRXhEO1lBQ0UsT0FBTyxFQUFFLE1BQU07WUFDZixVQUFVLEVBQUUsQ0FBQyxHQUFHLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLFFBQVE7Z0JBQ3RFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQ25DLE1BQU0sSUFBSSxLQUFLLENBQUMsMkRBQTJELENBQUMsQ0FBQztnQkFDL0UsQ0FBQztnQkFDRCxNQUFNLGFBQWEsR0FBRyxHQUFHLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUM1QyxNQUFNLENBQUMsR0FBRyxJQUFJLE1BQU0sQ0FDaEIsYUFBYSxFQUFFLFFBQVEsRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUM7Z0JBQ25GLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxNQUFNLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO2dCQUMvQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1lBQ1gsQ0FBQztZQUNELElBQUksRUFDQSxDQUFDLGNBQWMsRUFBRSxpQkFBaUIsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLFFBQVEsRUFBRSxRQUFRLENBQUM7U0FDNUY7UUFFRCxlQUFlO1FBQ2YsRUFBQyxPQUFPLEVBQUUsY0FBYyxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsRUFBQztRQUdoRjtZQUNFLE9BQU8sRUFBRSxlQUFlO1lBQ3hCLEtBQUssRUFBRSxJQUFJO1lBQ1gsVUFBVSxFQUFFLENBQUMsUUFBUTtnQkFJbkIsVUFBVSxDQUFDLENBQUM7b0JBQ1YsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQztvQkFDNUMsRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQzt3QkFDdEMsTUFBTSxDQUFDLHlCQUF5QixDQUFDLENBQUMsQ0FBQzs0QkFDakMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxpQkFBaUIsRUFBRSxDQUFBO3dCQUMxQyxDQUFDLENBQUMsQ0FBQztvQkFDTCxDQUFDO29CQUFDLElBQUksQ0FBQyxDQUFDO3dCQUNOLFFBQVEsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsaUJBQWlCLEVBQUUsQ0FBQTtvQkFDMUMsQ0FBQztnQkFDSCxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7Z0JBQ04sTUFBTSxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUM7WUFDbkIsQ0FBQztZQUNELElBQUksRUFBRSxDQUFDLFFBQVEsQ0FBQztTQUNqQjtLQUNGLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtMb2NhdGlvbiwgTG9jYXRpb25TdHJhdGVneSwgUGF0aExvY2F0aW9uU3RyYXRlZ3l9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0FQUF9JTklUSUFMSVpFUiwgQXBwbGljYXRpb25SZWYsIENvbXBvbmVudFJlc29sdmVyLCBJbmplY3Rvcn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7Um91dGVyQ29uZmlnfSBmcm9tICcuL2NvbmZpZyc7XG5pbXBvcnQge1JvdXRlcn0gZnJvbSAnLi9yb3V0ZXInO1xuaW1wb3J0IHtSb3V0ZXJPdXRsZXRNYXB9IGZyb20gJy4vcm91dGVyX291dGxldF9tYXAnO1xuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZX0gZnJvbSAnLi9yb3V0ZXJfc3RhdGUnO1xuaW1wb3J0IHtEZWZhdWx0VXJsU2VyaWFsaXplciwgVXJsU2VyaWFsaXplcn0gZnJvbSAnLi91cmxfc2VyaWFsaXplcic7XG5cblxuLyoqXG4gKiBBIGxpc3Qgb2Yge0BsaW5rIFByb3ZpZGVyfXMuIFRvIHVzZSB0aGUgcm91dGVyLCB5b3UgbXVzdCBhZGQgdGhpcyB0byB5b3VyIGFwcGxpY2F0aW9uLlxuICpcbiAqICMjIyBFeGFtcGxlXG4gKlxuICogYGBgXG4gKiBAQ29tcG9uZW50KHtkaXJlY3RpdmVzOiBbUk9VVEVSX0RJUkVDVElWRVNdfSlcbiAqIGNsYXNzIEFwcENtcCB7XG4gKiAgIC8vIC4uLlxuICogfVxuICpcbiAqIGNvbnN0IHJvdXRlciA9IFtcbiAqICAge3BhdGg6ICcvaG9tZScsIGNvbXBvbmVudDogSG9tZX1cbiAqIF07XG4gKlxuICogYm9vdHN0cmFwKEFwcENtcCwgW3Byb3ZpZGVSb3V0ZXIocm91dGVyKV0pO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlUm91dGVyKGNvbmZpZzogUm91dGVyQ29uZmlnKTogYW55W10ge1xuICByZXR1cm4gW1xuICAgIExvY2F0aW9uLFxuICAgIHtwcm92aWRlOiBMb2NhdGlvblN0cmF0ZWd5LCB1c2VDbGFzczogUGF0aExvY2F0aW9uU3RyYXRlZ3l9LFxuICAgIHtwcm92aWRlOiBVcmxTZXJpYWxpemVyLCB1c2VDbGFzczogRGVmYXVsdFVybFNlcmlhbGl6ZXJ9LFxuXG4gICAge1xuICAgICAgcHJvdmlkZTogUm91dGVyLFxuICAgICAgdXNlRmFjdG9yeTogKHJlZiwgcmVzb2x2ZXIsIHVybFNlcmlhbGl6ZXIsIG91dGxldE1hcCwgbG9jYXRpb24sIGluamVjdG9yKSA9PiB7XG4gICAgICAgIGlmIChyZWYuY29tcG9uZW50VHlwZXMubGVuZ3RoID09IDApIHtcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Jvb3RzdHJhcCBhdCBsZWFzdCBvbmUgY29tcG9uZW50IGJlZm9yZSBpbmplY3RpbmcgUm91dGVyLicpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGNvbXBvbmVudFR5cGUgPSByZWYuY29tcG9uZW50VHlwZXNbMF07XG4gICAgICAgIGNvbnN0IHIgPSBuZXcgUm91dGVyKFxuICAgICAgICAgICAgY29tcG9uZW50VHlwZSwgcmVzb2x2ZXIsIHVybFNlcmlhbGl6ZXIsIG91dGxldE1hcCwgbG9jYXRpb24sIGluamVjdG9yLCBjb25maWcpO1xuICAgICAgICByZWYucmVnaXN0ZXJEaXNwb3NlTGlzdGVuZXIoKCkgPT4gci5kaXNwb3NlKCkpO1xuICAgICAgICByZXR1cm4gcjtcbiAgICAgIH0sXG4gICAgICBkZXBzOlxuICAgICAgICAgIFtBcHBsaWNhdGlvblJlZiwgQ29tcG9uZW50UmVzb2x2ZXIsIFVybFNlcmlhbGl6ZXIsIFJvdXRlck91dGxldE1hcCwgTG9jYXRpb24sIEluamVjdG9yXVxuICAgIH0sXG5cbiAgICBSb3V0ZXJPdXRsZXRNYXAsXG4gICAge3Byb3ZpZGU6IEFjdGl2YXRlZFJvdXRlLCB1c2VGYWN0b3J5OiAocikgPT4gci5yb3V0ZXJTdGF0ZS5yb290LCBkZXBzOiBbUm91dGVyXX0sXG5cbiAgICAvLyBUcmlnZ2VyIGluaXRpYWwgbmF2aWdhdGlvblxuICAgIHtcbiAgICAgIHByb3ZpZGU6IEFQUF9JTklUSUFMSVpFUixcbiAgICAgIG11bHRpOiB0cnVlLFxuICAgICAgdXNlRmFjdG9yeTogKGluamVjdG9yKSA9PiB7XG4gICAgICAgIC8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbmd1bGFyL2FuZ3VsYXIvaXNzdWVzLzkxMDFcbiAgICAgICAgLy8gRGVsYXkgdGhlIHJvdXRlciBpbnN0YW50aWF0aW9uIHRvIGF2b2lkIGNpcmN1bGFyIGRlcGVuZGVuY3kgKEFwcGxpY2F0aW9uUmVmIC0+XG4gICAgICAgIC8vIEFQUF9JTklUSUFMSVpFUiAtPiBSb3V0ZXIpXG4gICAgICAgIHNldFRpbWVvdXQoXyA9PiB7XG4gICAgICAgICAgY29uc3QgYXBwUmVmID0gaW5qZWN0b3IuZ2V0KEFwcGxpY2F0aW9uUmVmKTtcbiAgICAgICAgICBpZiAoYXBwUmVmLmNvbXBvbmVudFR5cGVzLmxlbmd0aCA9PSAwKSB7XG4gICAgICAgICAgICBhcHBSZWYucmVnaXN0ZXJCb290c3RyYXBMaXN0ZW5lcigoXykgPT4ge1xuICAgICAgICAgICAgICBpbmplY3Rvci5nZXQoUm91dGVyKS5pbml0aWFsTmF2aWdhdGlvbigpXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgaW5qZWN0b3IuZ2V0KFJvdXRlcikuaW5pdGlhbE5hdmlnYXRpb24oKVxuICAgICAgICAgIH1cbiAgICAgICAgfSwgMCk7XG4gICAgICAgIHJldHVybiBfID0+IG51bGw7XG4gICAgICB9LFxuICAgICAgZGVwczogW0luamVjdG9yXVxuICAgIH1cbiAgXTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uX3JvdXRlcl9wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29tbW9uX3JvdXRlcl9wcm92aWRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ik9BQU8sRUFBQyxRQUFRLEVBQUUsZ0JBQWdCLEVBQUUsb0JBQW9CLEVBQUMsTUFBTSxpQkFBaUI7T0FDekUsRUFBQyxlQUFlLEVBQUUsY0FBYyxFQUFFLGlCQUFpQixFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUMsTUFBTSxlQUFlO09BR2hHLEVBQUMsTUFBTSxFQUFDLE1BQU0sVUFBVTtPQUN4QixFQUFDLGVBQWUsRUFBQyxNQUFNLHFCQUFxQjtPQUM1QyxFQUFDLGNBQWMsRUFBQyxNQUFNLGdCQUFnQjtPQUN0QyxFQUFDLG9CQUFvQixFQUFFLGFBQWEsRUFBQyxNQUFNLGtCQUFrQjtBQUVwRSxPQUFPLE1BQU0sYUFBYSxHQUFHLElBQUksV0FBVyxDQUFDLGVBQWUsQ0FBQyxDQUFDO0FBQzlELE9BQU8sTUFBTSxjQUFjLEdBQUcsSUFBSSxXQUFXLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztBQUloRSw0QkFDSSxHQUFHLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsSUFBSTtJQUMzRSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ25DLE1BQU0sSUFBSSxLQUFLLENBQUMsMkRBQTJELENBQUMsQ0FBQztJQUMvRSxDQUFDO0lBQ0QsTUFBTSxhQUFhLEdBQUcsR0FBRyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM1QyxNQUFNLENBQUMsR0FDSCxJQUFJLE1BQU0sQ0FBQyxhQUFhLEVBQUUsUUFBUSxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUM5RixHQUFHLENBQUMsdUJBQXVCLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUUvQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztRQUN2QixDQUFDLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ2xCLE9BQU8sQ0FBQyxLQUFLLENBQUMsaUJBQXVCLENBQUMsQ0FBQyxXQUFZLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztZQUM1RCxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1lBQzFCLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDZixPQUFPLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDckIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsTUFBTSxDQUFDLENBQUMsQ0FBQztBQUNYLENBQUM7QUFFRCx1Q0FBdUMsUUFBa0I7SUFJdkQsVUFBVSxDQUFDLENBQUM7UUFDVixNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQzVDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdEMsTUFBTSxDQUFDLHlCQUF5QixDQUFDLENBQUMsQ0FBQyxPQUFPLFFBQVEsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3pGLENBQUM7UUFBQyxJQUFJLENBQUMsQ0FBQztZQUNOLFFBQVEsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUMzQyxDQUFDO0lBQ0gsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ04sTUFBTSxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUM7QUFDbkIsQ0FBQztBQW9CRCw4QkFBOEIsT0FBcUIsRUFBRSxLQUFtQjtJQUN0RSxNQUFNLENBQUM7UUFDTCxFQUFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBQyxFQUFFLEVBQUMsT0FBTyxFQUFFLGNBQWMsRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFDO1FBQ3ZGLFFBQVEsRUFBRSxFQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsb0JBQW9CLEVBQUM7UUFDckUsRUFBQyxPQUFPLEVBQUUsYUFBYSxFQUFFLFFBQVEsRUFBRSxvQkFBb0IsRUFBQztRQUV4RDtZQUNFLE9BQU8sRUFBRSxNQUFNO1lBQ2YsVUFBVSxFQUFFLFdBQVc7WUFDdkIsSUFBSSxFQUFFO2dCQUNKLGNBQWMsRUFBRSxpQkFBaUIsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLFFBQVEsRUFBRSxRQUFRO2dCQUNyRixhQUFhLEVBQUUsY0FBYzthQUM5QjtTQUNGO1FBRUQsZUFBZTtRQUNmLEVBQUMsT0FBTyxFQUFFLGNBQWMsRUFBRSxVQUFVLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDLEVBQUM7UUFHaEYsRUFBQyxPQUFPLEVBQUUsZUFBZSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLHNCQUFzQixFQUFFLElBQUksRUFBRSxDQUFDLFFBQVEsQ0FBQyxFQUFDO0tBQzlGLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtMb2NhdGlvbiwgTG9jYXRpb25TdHJhdGVneSwgUGF0aExvY2F0aW9uU3RyYXRlZ3l9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0FQUF9JTklUSUFMSVpFUiwgQXBwbGljYXRpb25SZWYsIENvbXBvbmVudFJlc29sdmVyLCBJbmplY3RvciwgT3BhcXVlVG9rZW59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1JvdXRlckNvbmZpZ30gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHtSb3V0ZXJ9IGZyb20gJy4vcm91dGVyJztcbmltcG9ydCB7Um91dGVyT3V0bGV0TWFwfSBmcm9tICcuL3JvdXRlcl9vdXRsZXRfbWFwJztcbmltcG9ydCB7QWN0aXZhdGVkUm91dGV9IGZyb20gJy4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7RGVmYXVsdFVybFNlcmlhbGl6ZXIsIFVybFNlcmlhbGl6ZXJ9IGZyb20gJy4vdXJsX3NlcmlhbGl6ZXInO1xuXG5leHBvcnQgY29uc3QgUk9VVEVSX0NPTkZJRyA9IG5ldyBPcGFxdWVUb2tlbignUk9VVEVSX0NPTkZJRycpO1xuZXhwb3J0IGNvbnN0IFJPVVRFUl9PUFRJT05TID0gbmV3IE9wYXF1ZVRva2VuKCdST1VURVJfT1BUSU9OUycpO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV4dHJhT3B0aW9ucyB7IGVuYWJsZVRyYWNpbmc/OiBib29sZWFuOyB9XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXR1cFJvdXRlcihcbiAgICByZWYsIHJlc29sdmVyLCB1cmxTZXJpYWxpemVyLCBvdXRsZXRNYXAsIGxvY2F0aW9uLCBpbmplY3RvciwgY29uZmlnLCBvcHRzKSB7XG4gIGlmIChyZWYuY29tcG9uZW50VHlwZXMubGVuZ3RoID09IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ0Jvb3RzdHJhcCBhdCBsZWFzdCBvbmUgY29tcG9uZW50IGJlZm9yZSBpbmplY3RpbmcgUm91dGVyLicpO1xuICB9XG4gIGNvbnN0IGNvbXBvbmVudFR5cGUgPSByZWYuY29tcG9uZW50VHlwZXNbMF07XG4gIGNvbnN0IHIgPVxuICAgICAgbmV3IFJvdXRlcihjb21wb25lbnRUeXBlLCByZXNvbHZlciwgdXJsU2VyaWFsaXplciwgb3V0bGV0TWFwLCBsb2NhdGlvbiwgaW5qZWN0b3IsIGNvbmZpZyk7XG4gIHJlZi5yZWdpc3RlckRpc3Bvc2VMaXN0ZW5lcigoKSA9PiByLmRpc3Bvc2UoKSk7XG5cbiAgaWYgKG9wdHMuZW5hYmxlVHJhY2luZykge1xuICAgIHIuZXZlbnRzLnN1YnNjcmliZShlID0+IHtcbiAgICAgIGNvbnNvbGUuZ3JvdXAoYFJvdXRlciBFdmVudDogJHsoPGFueT5lLmNvbnN0cnVjdG9yKS5uYW1lfWApO1xuICAgICAgY29uc29sZS5sb2coZS50b1N0cmluZygpKTtcbiAgICAgIGNvbnNvbGUubG9nKGUpO1xuICAgICAgY29uc29sZS5ncm91cEVuZCgpO1xuICAgIH0pO1xuICB9XG5cbiAgcmV0dXJuIHI7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXR1cFJvdXRlckluaXRpYWxpemVyKGluamVjdG9yOiBJbmplY3Rvcikge1xuICAvLyBodHRwczovL2dpdGh1Yi5jb20vYW5ndWxhci9hbmd1bGFyL2lzc3Vlcy85MTAxXG4gIC8vIERlbGF5IHRoZSByb3V0ZXIgaW5zdGFudGlhdGlvbiB0byBhdm9pZCBjaXJjdWxhciBkZXBlbmRlbmN5IChBcHBsaWNhdGlvblJlZiAtPlxuICAvLyBBUFBfSU5JVElBTElaRVIgLT4gUm91dGVyKVxuICBzZXRUaW1lb3V0KF8gPT4ge1xuICAgIGNvbnN0IGFwcFJlZiA9IGluamVjdG9yLmdldChBcHBsaWNhdGlvblJlZik7XG4gICAgaWYgKGFwcFJlZi5jb21wb25lbnRUeXBlcy5sZW5ndGggPT0gMCkge1xuICAgICAgYXBwUmVmLnJlZ2lzdGVyQm9vdHN0cmFwTGlzdGVuZXIoKF8pID0+IHsgaW5qZWN0b3IuZ2V0KFJvdXRlcikuaW5pdGlhbE5hdmlnYXRpb24oKTsgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGluamVjdG9yLmdldChSb3V0ZXIpLmluaXRpYWxOYXZpZ2F0aW9uKCk7XG4gICAgfVxuICB9LCAwKTtcbiAgcmV0dXJuIF8gPT4gbnVsbDtcbn1cblxuLyoqXG4gKiBBIGxpc3Qgb2Yge0BsaW5rIFByb3ZpZGVyfXMuIFRvIHVzZSB0aGUgcm91dGVyLCB5b3UgbXVzdCBhZGQgdGhpcyB0byB5b3VyIGFwcGxpY2F0aW9uLlxuICpcbiAqICMjIyBFeGFtcGxlXG4gKlxuICogYGBgXG4gKiBAQ29tcG9uZW50KHtkaXJlY3RpdmVzOiBbUk9VVEVSX0RJUkVDVElWRVNdfSlcbiAqIGNsYXNzIEFwcENtcCB7XG4gKiAgIC8vIC4uLlxuICogfVxuICpcbiAqIGNvbnN0IHJvdXRlciA9IFtcbiAqICAge3BhdGg6ICcvaG9tZScsIGNvbXBvbmVudDogSG9tZX1cbiAqIF07XG4gKlxuICogYm9vdHN0cmFwKEFwcENtcCwgW3Byb3ZpZGVSb3V0ZXIocm91dGVyKV0pO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlUm91dGVyKF9jb25maWc6IFJvdXRlckNvbmZpZywgX29wdHM6IEV4dHJhT3B0aW9ucyk6IGFueVtdIHtcbiAgcmV0dXJuIFtcbiAgICB7cHJvdmlkZTogUk9VVEVSX0NPTkZJRywgdXNlVmFsdWU6IF9jb25maWd9LCB7cHJvdmlkZTogUk9VVEVSX09QVElPTlMsIHVzZVZhbHVlOiBfb3B0c30sXG4gICAgTG9jYXRpb24sIHtwcm92aWRlOiBMb2NhdGlvblN0cmF0ZWd5LCB1c2VDbGFzczogUGF0aExvY2F0aW9uU3RyYXRlZ3l9LFxuICAgIHtwcm92aWRlOiBVcmxTZXJpYWxpemVyLCB1c2VDbGFzczogRGVmYXVsdFVybFNlcmlhbGl6ZXJ9LFxuXG4gICAge1xuICAgICAgcHJvdmlkZTogUm91dGVyLFxuICAgICAgdXNlRmFjdG9yeTogc2V0dXBSb3V0ZXIsXG4gICAgICBkZXBzOiBbXG4gICAgICAgIEFwcGxpY2F0aW9uUmVmLCBDb21wb25lbnRSZXNvbHZlciwgVXJsU2VyaWFsaXplciwgUm91dGVyT3V0bGV0TWFwLCBMb2NhdGlvbiwgSW5qZWN0b3IsXG4gICAgICAgIFJPVVRFUl9DT05GSUcsIFJPVVRFUl9PUFRJT05TXG4gICAgICBdXG4gICAgfSxcblxuICAgIFJvdXRlck91dGxldE1hcCxcbiAgICB7cHJvdmlkZTogQWN0aXZhdGVkUm91dGUsIHVzZUZhY3Rvcnk6IChyKSA9PiByLnJvdXRlclN0YXRlLnJvb3QsIGRlcHM6IFtSb3V0ZXJdfSxcblxuICAgIC8vIFRyaWdnZXIgaW5pdGlhbCBuYXZpZ2F0aW9uXG4gICAge3Byb3ZpZGU6IEFQUF9JTklUSUFMSVpFUiwgbXVsdGk6IHRydWUsIHVzZUZhY3Rvcnk6IHNldHVwUm91dGVySW5pdGlhbGl6ZXIsIGRlcHM6IFtJbmplY3Rvcl19XG4gIF07XG59XG4iXX0=

@@ -6,2 +6,3 @@ import { Type } from '@angular/core';

path?: string;
terminal?: boolean;
component?: Type | string;

@@ -8,0 +9,0 @@ outlet?: string;

@@ -1,1 +0,1 @@

//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUeXBlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IHR5cGUgUm91dGVyQ29uZmlnID0gUm91dGVbXTtcblxuZXhwb3J0IGludGVyZmFjZSBSb3V0ZSB7XG4gIGluZGV4PzogYm9vbGVhbjtcbiAgcGF0aD86IHN0cmluZztcbiAgY29tcG9uZW50PzogVHlwZXxzdHJpbmc7XG4gIG91dGxldD86IHN0cmluZztcbiAgY2FuQWN0aXZhdGU/OiBhbnlbXTtcbiAgY2FuRGVhY3RpdmF0ZT86IGFueVtdO1xuICByZWRpcmVjdFRvPzogc3RyaW5nO1xuICBjaGlsZHJlbj86IFJvdXRlW107XG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUeXBlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IHR5cGUgUm91dGVyQ29uZmlnID0gUm91dGVbXTtcblxuZXhwb3J0IGludGVyZmFjZSBSb3V0ZSB7XG4gIC8qKlxuICAgKiBVc2UgYHBhdGg6ICcnYCBpbnN0ZWFkLlxuICAgKiBAZGVwcmVjYXRlZFxuICAgKi9cbiAgaW5kZXg/OiBib29sZWFuO1xuICBwYXRoPzogc3RyaW5nO1xuICB0ZXJtaW5hbD86IGJvb2xlYW47XG4gIGNvbXBvbmVudD86IFR5cGV8c3RyaW5nO1xuICBvdXRsZXQ/OiBzdHJpbmc7XG4gIGNhbkFjdGl2YXRlPzogYW55W107XG4gIGNhbkRlYWN0aXZhdGU/OiBhbnlbXTtcbiAgcmVkaXJlY3RUbz86IHN0cmluZztcbiAgY2hpbGRyZW4/OiBSb3V0ZVtdO1xufSJdfQ==

@@ -35,3 +35,3 @@ import { BehaviorSubject } from 'rxjs/BehaviorSubject';

function createActivatedRoute(c) {
return new ActivatedRoute(new BehaviorSubject(c.urlSegments), new BehaviorSubject(c.params), c.outlet, c.component, c);
return new ActivatedRoute(new BehaviorSubject(c.url), new BehaviorSubject(c.params), c.outlet, c.component, c);
}

@@ -41,2 +41,2 @@ function equalRouteSnapshots(a, b) {

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlX3JvdXRlcl9zdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jcmVhdGVfcm91dGVyX3N0YXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sc0JBQXNCO09BRTdDLEVBQUMsY0FBYyxFQUEwQixXQUFXLEVBQXNCLE1BQU0sZ0JBQWdCO09BQ2hHLEVBQUMsUUFBUSxFQUFDLE1BQU0sY0FBYztBQUVyQyxrQ0FBa0MsSUFBeUIsRUFBRSxTQUFzQjtJQUNqRixNQUFNLElBQUksR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxTQUFTLEdBQUcsU0FBUyxDQUFDLEtBQUssR0FBRyxTQUFTLENBQUMsQ0FBQztJQUM3RSxNQUFNLFdBQVcsR0FBRyxTQUFTLEdBQUcsU0FBUyxDQUFDLFdBQVcsR0FBRyxJQUFJLGVBQWUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDOUYsTUFBTSxRQUFRLEdBQUcsU0FBUyxHQUFHLFNBQVMsQ0FBQyxRQUFRLEdBQUcsSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3JGLE1BQU0sQ0FBQyxJQUFJLFdBQVcsQ0FBQyxJQUFJLEVBQUUsV0FBVyxFQUFFLFFBQVEsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUM1RCxDQUFDO0FBRUQsb0JBQW9CLElBQXNDLEVBQUUsU0FBb0M7SUFFOUYsRUFBRSxDQUFDLENBQUMsU0FBUyxJQUFJLG1CQUFtQixDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0UsTUFBTSxLQUFLLEdBQUcsU0FBUyxDQUFDLEtBQUssQ0FBQztRQUM5QixLQUFLLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUM7UUFFbkMsTUFBTSxRQUFRLEdBQUcscUJBQXFCLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3hELE1BQU0sQ0FBQyxJQUFJLFFBQVEsQ0FBaUIsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBRXZELENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNOLE1BQU0sS0FBSyxHQUFHLG9CQUFvQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdkQsTUFBTSxDQUFDLElBQUksUUFBUSxDQUFpQixLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDdkQsQ0FBQztBQUNILENBQUM7QUFFRCwrQkFDSSxJQUFzQyxFQUFFLFNBQW1DO0lBQzdFLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxLQUFLO1FBQzVCLE1BQU0sS0FBSyxHQUNQLFNBQVMsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUMxRixFQUFFLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNmLE1BQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUN0RCxDQUFDO1FBQUMsSUFBSSxDQUFDLENBQUM7WUFDTixNQUFNLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCw4QkFBOEIsQ0FBeUI7SUFDckQsTUFBTSxDQUFDLElBQUksY0FBYyxDQUNyQixJQUFJLGVBQWUsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLEVBQUUsSUFBSSxlQUFlLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUNuRyxDQUFDO0FBRUQsNkJBQTZCLENBQXlCLEVBQUUsQ0FBeUI7SUFDL0UsTUFBTSxDQUFDLENBQUMsQ0FBQyxZQUFZLEtBQUssQ0FBQyxDQUFDLFlBQVksQ0FBQztBQUMzQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtCZWhhdmlvclN1YmplY3R9IGZyb20gJ3J4anMvQmVoYXZpb3JTdWJqZWN0JztcblxuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZSwgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgUm91dGVyU3RhdGUsIFJvdXRlclN0YXRlU25hcHNob3R9IGZyb20gJy4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7VHJlZU5vZGV9IGZyb20gJy4vdXRpbHMvdHJlZSc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVSb3V0ZXJTdGF0ZShjdXJyOiBSb3V0ZXJTdGF0ZVNuYXBzaG90LCBwcmV2U3RhdGU6IFJvdXRlclN0YXRlKTogUm91dGVyU3RhdGUge1xuICBjb25zdCByb290ID0gY3JlYXRlTm9kZShjdXJyLl9yb290LCBwcmV2U3RhdGUgPyBwcmV2U3RhdGUuX3Jvb3QgOiB1bmRlZmluZWQpO1xuICBjb25zdCBxdWVyeVBhcmFtcyA9IHByZXZTdGF0ZSA/IHByZXZTdGF0ZS5xdWVyeVBhcmFtcyA6IG5ldyBCZWhhdmlvclN1YmplY3QoY3Vyci5xdWVyeVBhcmFtcyk7XG4gIGNvbnN0IGZyYWdtZW50ID0gcHJldlN0YXRlID8gcHJldlN0YXRlLmZyYWdtZW50IDogbmV3IEJlaGF2aW9yU3ViamVjdChjdXJyLmZyYWdtZW50KTtcbiAgcmV0dXJuIG5ldyBSb3V0ZXJTdGF0ZShyb290LCBxdWVyeVBhcmFtcywgZnJhZ21lbnQsIGN1cnIpO1xufVxuXG5mdW5jdGlvbiBjcmVhdGVOb2RlKGN1cnI6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlU25hcHNob3Q+LCBwcmV2U3RhdGU/OiBUcmVlTm9kZTxBY3RpdmF0ZWRSb3V0ZT4pOlxuICAgIFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlPiB7XG4gIGlmIChwcmV2U3RhdGUgJiYgZXF1YWxSb3V0ZVNuYXBzaG90cyhwcmV2U3RhdGUudmFsdWUuc25hcHNob3QsIGN1cnIudmFsdWUpKSB7XG4gICAgY29uc3QgdmFsdWUgPSBwcmV2U3RhdGUudmFsdWU7XG4gICAgdmFsdWUuX2Z1dHVyZVNuYXBzaG90ID0gY3Vyci52YWx1ZTtcblxuICAgIGNvbnN0IGNoaWxkcmVuID0gY3JlYXRlT3JSZXVzZUNoaWxkcmVuKGN1cnIsIHByZXZTdGF0ZSk7XG4gICAgcmV0dXJuIG5ldyBUcmVlTm9kZTxBY3RpdmF0ZWRSb3V0ZT4odmFsdWUsIGNoaWxkcmVuKTtcblxuICB9IGVsc2Uge1xuICAgIGNvbnN0IHZhbHVlID0gY3JlYXRlQWN0aXZhdGVkUm91dGUoY3Vyci52YWx1ZSk7XG4gICAgY29uc3QgY2hpbGRyZW4gPSBjdXJyLmNoaWxkcmVuLm1hcChjID0+IGNyZWF0ZU5vZGUoYykpO1xuICAgIHJldHVybiBuZXcgVHJlZU5vZGU8QWN0aXZhdGVkUm91dGU+KHZhbHVlLCBjaGlsZHJlbik7XG4gIH1cbn1cblxuZnVuY3Rpb24gY3JlYXRlT3JSZXVzZUNoaWxkcmVuKFxuICAgIGN1cnI6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlU25hcHNob3Q+LCBwcmV2U3RhdGU6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlPikge1xuICByZXR1cm4gY3Vyci5jaGlsZHJlbi5tYXAoY2hpbGQgPT4ge1xuICAgIGNvbnN0IGluZGV4ID1cbiAgICAgICAgcHJldlN0YXRlLmNoaWxkcmVuLmZpbmRJbmRleChwID0+IGVxdWFsUm91dGVTbmFwc2hvdHMocC52YWx1ZS5zbmFwc2hvdCwgY2hpbGQudmFsdWUpKTtcbiAgICBpZiAoaW5kZXggPj0gMCkge1xuICAgICAgcmV0dXJuIGNyZWF0ZU5vZGUoY2hpbGQsIHByZXZTdGF0ZS5jaGlsZHJlbltpbmRleF0pO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gY3JlYXRlTm9kZShjaGlsZCk7XG4gICAgfVxuICB9KTtcbn1cblxuZnVuY3Rpb24gY3JlYXRlQWN0aXZhdGVkUm91dGUoYzogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCkge1xuICByZXR1cm4gbmV3IEFjdGl2YXRlZFJvdXRlKFxuICAgICAgbmV3IEJlaGF2aW9yU3ViamVjdChjLnVybFNlZ21lbnRzKSwgbmV3IEJlaGF2aW9yU3ViamVjdChjLnBhcmFtcyksIGMub3V0bGV0LCBjLmNvbXBvbmVudCwgYyk7XG59XG5cbmZ1bmN0aW9uIGVxdWFsUm91dGVTbmFwc2hvdHMoYTogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgYjogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCk6IGJvb2xlYW4ge1xuICByZXR1cm4gYS5fcm91dGVDb25maWcgPT09IGIuX3JvdXRlQ29uZmlnO1xufSJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlX3JvdXRlcl9zdGF0ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jcmVhdGVfcm91dGVyX3N0YXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sc0JBQXNCO09BRTdDLEVBQUMsY0FBYyxFQUEwQixXQUFXLEVBQXNCLE1BQU0sZ0JBQWdCO09BQ2hHLEVBQUMsUUFBUSxFQUFDLE1BQU0sY0FBYztBQUVyQyxrQ0FBa0MsSUFBeUIsRUFBRSxTQUFzQjtJQUNqRixNQUFNLElBQUksR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxTQUFTLEdBQUcsU0FBUyxDQUFDLEtBQUssR0FBRyxTQUFTLENBQUMsQ0FBQztJQUM3RSxNQUFNLFdBQVcsR0FBRyxTQUFTLEdBQUcsU0FBUyxDQUFDLFdBQVcsR0FBRyxJQUFJLGVBQWUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDOUYsTUFBTSxRQUFRLEdBQUcsU0FBUyxHQUFHLFNBQVMsQ0FBQyxRQUFRLEdBQUcsSUFBSSxlQUFlLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3JGLE1BQU0sQ0FBQyxJQUFJLFdBQVcsQ0FBQyxJQUFJLEVBQUUsV0FBVyxFQUFFLFFBQVEsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUM1RCxDQUFDO0FBRUQsb0JBQW9CLElBQXNDLEVBQUUsU0FBb0M7SUFFOUYsRUFBRSxDQUFDLENBQUMsU0FBUyxJQUFJLG1CQUFtQixDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0UsTUFBTSxLQUFLLEdBQUcsU0FBUyxDQUFDLEtBQUssQ0FBQztRQUM5QixLQUFLLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUM7UUFFbkMsTUFBTSxRQUFRLEdBQUcscUJBQXFCLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3hELE1BQU0sQ0FBQyxJQUFJLFFBQVEsQ0FBaUIsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0lBRXZELENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNOLE1BQU0sS0FBSyxHQUFHLG9CQUFvQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdkQsTUFBTSxDQUFDLElBQUksUUFBUSxDQUFpQixLQUFLLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDdkQsQ0FBQztBQUNILENBQUM7QUFFRCwrQkFDSSxJQUFzQyxFQUFFLFNBQW1DO0lBQzdFLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxLQUFLO1FBQzVCLE1BQU0sS0FBSyxHQUNQLFNBQVMsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxtQkFBbUIsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUMxRixFQUFFLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNmLE1BQU0sQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztRQUN0RCxDQUFDO1FBQUMsSUFBSSxDQUFDLENBQUM7WUFDTixNQUFNLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzNCLENBQUM7SUFDSCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCw4QkFBOEIsQ0FBeUI7SUFDckQsTUFBTSxDQUFDLElBQUksY0FBYyxDQUNyQixJQUFJLGVBQWUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEVBQUUsSUFBSSxlQUFlLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsQ0FBQztBQUMzRixDQUFDO0FBRUQsNkJBQTZCLENBQXlCLEVBQUUsQ0FBeUI7SUFDL0UsTUFBTSxDQUFDLENBQUMsQ0FBQyxZQUFZLEtBQUssQ0FBQyxDQUFDLFlBQVksQ0FBQztBQUMzQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtCZWhhdmlvclN1YmplY3R9IGZyb20gJ3J4anMvQmVoYXZpb3JTdWJqZWN0JztcblxuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZSwgQWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgUm91dGVyU3RhdGUsIFJvdXRlclN0YXRlU25hcHNob3R9IGZyb20gJy4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7VHJlZU5vZGV9IGZyb20gJy4vdXRpbHMvdHJlZSc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVSb3V0ZXJTdGF0ZShjdXJyOiBSb3V0ZXJTdGF0ZVNuYXBzaG90LCBwcmV2U3RhdGU6IFJvdXRlclN0YXRlKTogUm91dGVyU3RhdGUge1xuICBjb25zdCByb290ID0gY3JlYXRlTm9kZShjdXJyLl9yb290LCBwcmV2U3RhdGUgPyBwcmV2U3RhdGUuX3Jvb3QgOiB1bmRlZmluZWQpO1xuICBjb25zdCBxdWVyeVBhcmFtcyA9IHByZXZTdGF0ZSA/IHByZXZTdGF0ZS5xdWVyeVBhcmFtcyA6IG5ldyBCZWhhdmlvclN1YmplY3QoY3Vyci5xdWVyeVBhcmFtcyk7XG4gIGNvbnN0IGZyYWdtZW50ID0gcHJldlN0YXRlID8gcHJldlN0YXRlLmZyYWdtZW50IDogbmV3IEJlaGF2aW9yU3ViamVjdChjdXJyLmZyYWdtZW50KTtcbiAgcmV0dXJuIG5ldyBSb3V0ZXJTdGF0ZShyb290LCBxdWVyeVBhcmFtcywgZnJhZ21lbnQsIGN1cnIpO1xufVxuXG5mdW5jdGlvbiBjcmVhdGVOb2RlKGN1cnI6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlU25hcHNob3Q+LCBwcmV2U3RhdGU/OiBUcmVlTm9kZTxBY3RpdmF0ZWRSb3V0ZT4pOlxuICAgIFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlPiB7XG4gIGlmIChwcmV2U3RhdGUgJiYgZXF1YWxSb3V0ZVNuYXBzaG90cyhwcmV2U3RhdGUudmFsdWUuc25hcHNob3QsIGN1cnIudmFsdWUpKSB7XG4gICAgY29uc3QgdmFsdWUgPSBwcmV2U3RhdGUudmFsdWU7XG4gICAgdmFsdWUuX2Z1dHVyZVNuYXBzaG90ID0gY3Vyci52YWx1ZTtcblxuICAgIGNvbnN0IGNoaWxkcmVuID0gY3JlYXRlT3JSZXVzZUNoaWxkcmVuKGN1cnIsIHByZXZTdGF0ZSk7XG4gICAgcmV0dXJuIG5ldyBUcmVlTm9kZTxBY3RpdmF0ZWRSb3V0ZT4odmFsdWUsIGNoaWxkcmVuKTtcblxuICB9IGVsc2Uge1xuICAgIGNvbnN0IHZhbHVlID0gY3JlYXRlQWN0aXZhdGVkUm91dGUoY3Vyci52YWx1ZSk7XG4gICAgY29uc3QgY2hpbGRyZW4gPSBjdXJyLmNoaWxkcmVuLm1hcChjID0+IGNyZWF0ZU5vZGUoYykpO1xuICAgIHJldHVybiBuZXcgVHJlZU5vZGU8QWN0aXZhdGVkUm91dGU+KHZhbHVlLCBjaGlsZHJlbik7XG4gIH1cbn1cblxuZnVuY3Rpb24gY3JlYXRlT3JSZXVzZUNoaWxkcmVuKFxuICAgIGN1cnI6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlU25hcHNob3Q+LCBwcmV2U3RhdGU6IFRyZWVOb2RlPEFjdGl2YXRlZFJvdXRlPikge1xuICByZXR1cm4gY3Vyci5jaGlsZHJlbi5tYXAoY2hpbGQgPT4ge1xuICAgIGNvbnN0IGluZGV4ID1cbiAgICAgICAgcHJldlN0YXRlLmNoaWxkcmVuLmZpbmRJbmRleChwID0+IGVxdWFsUm91dGVTbmFwc2hvdHMocC52YWx1ZS5zbmFwc2hvdCwgY2hpbGQudmFsdWUpKTtcbiAgICBpZiAoaW5kZXggPj0gMCkge1xuICAgICAgcmV0dXJuIGNyZWF0ZU5vZGUoY2hpbGQsIHByZXZTdGF0ZS5jaGlsZHJlbltpbmRleF0pO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gY3JlYXRlTm9kZShjaGlsZCk7XG4gICAgfVxuICB9KTtcbn1cblxuZnVuY3Rpb24gY3JlYXRlQWN0aXZhdGVkUm91dGUoYzogQWN0aXZhdGVkUm91dGVTbmFwc2hvdCkge1xuICByZXR1cm4gbmV3IEFjdGl2YXRlZFJvdXRlKFxuICAgICAgbmV3IEJlaGF2aW9yU3ViamVjdChjLnVybCksIG5ldyBCZWhhdmlvclN1YmplY3QoYy5wYXJhbXMpLCBjLm91dGxldCwgYy5jb21wb25lbnQsIGMpO1xufVxuXG5mdW5jdGlvbiBlcXVhbFJvdXRlU25hcHNob3RzKGE6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIGI6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QpOiBib29sZWFuIHtcbiAgcmV0dXJuIGEuX3JvdXRlQ29uZmlnID09PSBiLl9yb3V0ZUNvbmZpZztcbn0iXX0=
import { ActivatedRoute } from './router_state';
import { Params } from './shared';
import { UrlTree } from './url_tree';
export declare function createUrlTree(route: ActivatedRoute, urlTree: UrlTree, commands: any[], queryParams: Params | undefined, fragment: string | undefined): UrlTree;
export declare function createUrlTree(route: ActivatedRoute, urlTree: UrlTree, commands: any[], queryParams: Params, fragment: string): UrlTree;
import { PRIMARY_OUTLET } from './shared';
import { UrlSegment, UrlTree } from './url_tree';
import { UrlPathWithParams, UrlSegment, UrlTree } from './url_tree';
import { forEach, shallowEqual } from './utils/collection';
import { TreeNode } from './utils/tree';
export function createUrlTree(route, urlTree, commands, queryParams, fragment) {
if (commands.length === 0) {
return tree(urlTree._root, urlTree, queryParams, fragment);
return tree(urlTree.root, urlTree.root, urlTree, queryParams, fragment);
}
const normalizedCommands = normalizeCommands(commands);
if (navigateToRoot(normalizedCommands)) {
return tree(new TreeNode(urlTree.root, []), urlTree, queryParams, fragment);
return tree(urlTree.root, new UrlSegment([], {}), urlTree, queryParams, fragment);
}
const startingNode = findStartingNode(normalizedCommands, urlTree, route);
const updated = normalizedCommands.commands.length > 0 ?
updateMany(startingNode.children.slice(0), normalizedCommands.commands) :
[];
const newRoot = constructNewTree(urlTree._root, startingNode, updated);
return tree(newRoot, urlTree, queryParams, fragment);
const startingPosition = findStartingPosition(normalizedCommands, urlTree, route);
const segment = startingPosition.processChildren ?
updateSegmentChildren(startingPosition.segment, startingPosition.index, normalizedCommands.commands) :
updateSegment(startingPosition.segment, startingPosition.index, normalizedCommands.commands);
return tree(startingPosition.segment, segment, urlTree, queryParams, fragment);
}
function tree(root, urlTree, queryParams, fragment) {
function tree(oldSegment, newSegment, urlTree, queryParams, fragment) {
const q = queryParams ? stringify(queryParams) : urlTree.queryParams;
const f = fragment ? fragment : urlTree.fragment;
return new UrlTree(root, q, f);
if (urlTree.root === oldSegment) {
return new UrlTree(newSegment, q, f);
}
else {
return new UrlTree(replaceSegment(urlTree.root, oldSegment, newSegment), q, f);
}
}
function replaceSegment(current, oldSegment, newSegment) {
const children = {};
forEach(current.children, (c, k) => {
if (c === oldSegment) {
children[k] = newSegment;
}
else {
children[k] = replaceSegment(c, oldSegment, newSegment);
}
});
return new UrlSegment(current.pathsWithParams, children);
}
function navigateToRoot(normalizedChange) {

@@ -74,55 +89,29 @@ return normalizedChange.isAbsolute && normalizedChange.commands.length === 1 &&

}
function findStartingNode(normalizedChange, urlTree, route) {
if (normalizedChange.isAbsolute) {
return urlTree._root;
class Position {
constructor(segment, processChildren, index) {
this.segment = segment;
this.processChildren = processChildren;
this.index = index;
}
else {
const urlSegment = findUrlSegment(route, urlTree, normalizedChange.numberOfDoubleDots);
return findMatchingNode(urlSegment, urlTree._root);
}
}
function findUrlSegment(route, urlTree, numberOfDoubleDots) {
const urlSegment = route.snapshot._lastUrlSegment;
const path = urlTree.pathFromRoot(urlSegment);
if (path.length <= numberOfDoubleDots) {
throw new Error('Invalid number of \'../\'');
function findStartingPosition(normalizedChange, urlTree, route) {
if (normalizedChange.isAbsolute) {
return new Position(urlTree.root, true, 0);
}
return path[path.length - 1 - numberOfDoubleDots];
}
function findMatchingNode(segment, node) {
if (node.value === segment)
return node;
for (let c of node.children) {
const r = findMatchingNode(segment, c);
if (r)
return r;
else if (route.snapshot._lastPathIndex === -1) {
return new Position(route.snapshot._urlSegment, true, 0);
}
throw new Error(`Cannot find url segment '${segment}'`);
}
function constructNewTree(node, original, updated) {
if (node === original) {
return new TreeNode(node.value, updated);
else if (route.snapshot._lastPathIndex + 1 - normalizedChange.numberOfDoubleDots >= 0) {
return new Position(route.snapshot._urlSegment, false, route.snapshot._lastPathIndex + 1 - normalizedChange.numberOfDoubleDots);
}
else {
return new TreeNode(node.value, node.children.map(c => constructNewTree(c, original, updated)));
throw new Error('Invalid number of \'../\'');
}
}
function updateMany(nodes, commands) {
const outlet = getOutlet(commands);
const nodesInRightOutlet = nodes.filter(c => c.value.outlet === outlet);
if (nodesInRightOutlet.length > 0) {
const nodeRightOutlet = nodesInRightOutlet[0];
nodes[nodes.indexOf(nodeRightOutlet)] = update(nodeRightOutlet, commands);
}
else {
nodes.push(update(null, commands));
}
return nodes;
function getPath(command) {
if (!(typeof command === 'string'))
return command;
const parts = command.toString().split(':');
return parts.length > 1 ? parts[1] : command;
}
function getPath(commands) {
if (!(typeof commands[0] === 'string'))
return commands[0];
const parts = commands[0].toString().split(':');
return parts.length > 1 ? parts[1] : commands[0];
}
function getOutlet(commands) {

@@ -134,38 +123,87 @@ if (!(typeof commands[0] === 'string'))

}
function update(node, commands) {
const rest = commands.slice(1);
const next = rest.length === 0 ? null : rest[0];
const outlet = getOutlet(commands);
const path = getPath(commands);
if (!node && !(typeof next === 'object')) {
const urlSegment = new UrlSegment(path, {}, outlet);
const children = rest.length === 0 ? [] : [update(null, rest)];
return new TreeNode(urlSegment, children);
function updateSegment(segment, startIndex, commands) {
if (!segment) {
segment = new UrlSegment([], {});
}
else if (!node && typeof next === 'object') {
const urlSegment = new UrlSegment(path, stringify(next), outlet);
return recurse(urlSegment, node, rest.slice(1));
if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {
return updateSegmentChildren(segment, startIndex, commands);
}
else if (node && outlet !== node.value.outlet) {
return node;
const m = prefixedWith(segment, startIndex, commands);
const slicedCommands = commands.slice(m.lastIndex);
if (m.match && slicedCommands.length === 0) {
return new UrlSegment(segment.pathsWithParams, {});
}
else if (node && typeof path === 'object') {
const newSegment = new UrlSegment(node.value.path, stringify(path), node.value.outlet);
return recurse(newSegment, node, rest);
else if (m.match && Object.keys(segment.children).length === 0) {
return createNewSegment(segment, startIndex, commands);
}
else if (node && typeof next === 'object' && compare(path, stringify(next), node.value)) {
return recurse(node.value, node, rest.slice(1));
else if (m.match) {
return updateSegmentChildren(segment, 0, slicedCommands);
}
else if (node && typeof next === 'object') {
const urlSegment = new UrlSegment(path, stringify(next), outlet);
return recurse(urlSegment, node, rest.slice(1));
else {
return createNewSegment(segment, startIndex, commands);
}
else if (node && compare(path, {}, node.value)) {
return recurse(node.value, node, rest);
}
function updateSegmentChildren(segment, startIndex, commands) {
if (commands.length === 0) {
return new UrlSegment(segment.pathsWithParams, {});
}
else {
const urlSegment = new UrlSegment(path, {}, outlet);
return recurse(urlSegment, node, rest);
const outlet = getOutlet(commands);
const children = {};
children[outlet] = updateSegment(segment.children[outlet], startIndex, commands);
forEach(segment.children, (child, childOutlet) => {
if (childOutlet !== outlet) {
children[childOutlet] = child;
}
});
return new UrlSegment(segment.pathsWithParams, children);
}
}
function prefixedWith(segment, startIndex, commands) {
let currentCommandIndex = 0;
let currentPathIndex = startIndex;
const noMatch = { match: false, lastIndex: 0 };
while (currentPathIndex < segment.pathsWithParams.length) {
if (currentCommandIndex >= commands.length)
return noMatch;
const path = segment.pathsWithParams[currentPathIndex];
const curr = getPath(commands[currentCommandIndex]);
const next = currentCommandIndex < commands.length - 1 ? commands[currentCommandIndex + 1] : null;
if (curr && next && (typeof next === 'object')) {
if (!compare(curr, next, path))
return noMatch;
currentCommandIndex += 2;
}
else {
if (!compare(curr, {}, path))
return noMatch;
currentCommandIndex++;
}
currentPathIndex++;
}
return { match: true, lastIndex: currentCommandIndex };
}
function createNewSegment(segment, startIndex, commands) {
const paths = segment.pathsWithParams.slice(0, startIndex);
let i = 0;
while (i < commands.length) {
if (i === 0 && (typeof commands[0] === 'object')) {
const p = segment.pathsWithParams[startIndex];
paths.push(new UrlPathWithParams(p.path, commands[0]));
i++;
continue;
}
const curr = getPath(commands[i]);
const next = (i < commands.length - 1) ? commands[i + 1] : null;
if (curr && next && (typeof next === 'object')) {
paths.push(new UrlPathWithParams(curr, stringify(next)));
i += 2;
}
else {
paths.push(new UrlPathWithParams(curr, {}));
i++;
}
}
return new UrlSegment(paths, {});
}
function stringify(params) {

@@ -176,12 +214,5 @@ const res = {};

}
function compare(path, params, segment) {
return path == segment.path && shallowEqual(params, segment.parameters);
function compare(path, params, pathWithParams) {
return path == pathWithParams.path && shallowEqual(params, pathWithParams.parameters);
}
function recurse(urlSegment, node, rest) {
if (rest.length === 0) {
return new TreeNode(urlSegment, []);
}
const children = node ? node.children.slice(0) : [];
return new TreeNode(urlSegment, updateMany(children, rest));
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create_url_tree.js","sourceRoot":"","sources":["../../src/create_url_tree.ts"],"names":[],"mappings":"OACO,EAAC,cAAc,EAAS,MAAM,UAAU;OACxC,EAAC,UAAU,EAAE,OAAO,EAAC,MAAM,YAAY;OACvC,EAAC,OAAO,EAAE,YAAY,EAAC,MAAM,oBAAoB;OACjD,EAAC,QAAQ,EAAC,MAAM,cAAc;AAErC,8BACI,KAAqB,EAAE,OAAgB,EAAE,QAAe,EAAE,WAA+B,EACzF,QAA4B;IAC9B,EAAE,CAAC,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;IAC7D,CAAC;IAED,MAAM,kBAAkB,GAAG,iBAAiB,CAAC,QAAQ,CAAC,CAAC;IACvD,EAAE,CAAC,CAAC,cAAc,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAa,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;IAC1F,CAAC;IAED,MAAM,YAAY,GAAG,gBAAgB,CAAC,kBAAkB,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IAC1E,MAAM,OAAO,GAAG,kBAAkB,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;QAClD,UAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,kBAAkB,CAAC,QAAQ,CAAC;QACvE,EAAE,CAAC;IACP,MAAM,OAAO,GAAG,gBAAgB,CAAC,OAAO,CAAC,KAAK,EAAE,YAAY,EAAE,OAAO,CAAC,CAAC;IAEvE,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;AACvD,CAAC;AAED,cACI,IAA0B,EAAE,OAAgB,EAAE,WAA+B,EAC7E,QAA4B;IAC9B,MAAM,CAAC,GAAG,WAAW,GAAG,SAAS,CAAC,WAAW,CAAC,GAAG,OAAO,CAAC,WAAW,CAAC;IACrE,MAAM,CAAC,GAAG,QAAQ,GAAG,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;IACjD,MAAM,CAAC,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACjC,CAAC;AAED,wBAAwB,gBAA8C;IACpE,MAAM,CAAC,gBAAgB,CAAC,UAAU,IAAI,gBAAgB,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC;QACxE,gBAAgB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC;AAC1C,CAAC;AAED;IACE,YACW,UAAmB,EAAS,kBAA0B,EAAS,QAAe;QAA9E,eAAU,GAAV,UAAU,CAAS;QAAS,uBAAkB,GAAlB,kBAAkB,CAAQ;QAAS,aAAQ,GAAR,QAAQ,CAAO;IAAG,CAAC;AAC/F,CAAC;AAED,2BAA2B,QAAe;IACxC,EAAE,CAAC,CAAC,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;QACrF,MAAM,CAAC,IAAI,4BAA4B,CAAC,IAAI,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;IAC7D,CAAC;IAED,IAAI,kBAAkB,GAAG,CAAC,CAAC;IAC3B,IAAI,UAAU,GAAG,KAAK,CAAC;IACvB,MAAM,GAAG,GAAG,EAAE,CAAC;IAEf,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC;QACzC,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QAEtB,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC7B,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACZ,QAAQ,CAAC;QACX,CAAC;QAED,MAAM,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC3B,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC;YACtC,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAGlB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACX,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC;gBAE1B,CAAC;gBAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;oBAC9B,UAAU,GAAG,IAAI,CAAC;gBACpB,CAAC;gBAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC;oBACtB,kBAAkB,EAAE,CAAC;gBACvB,CAAC;gBAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;oBACpB,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACf,CAAC;YAEH,CAAC;YAAC,IAAI,CAAC,CAAC;gBACN,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;oBACb,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACf,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,CAAC,IAAI,4BAA4B,CAAC,UAAU,EAAE,kBAAkB,EAAE,GAAG,CAAC,CAAC;AAC/E,CAAC;AAED,0BACI,gBAA8C,EAAE,OAAgB,EAChE,KAAqB;IACvB,EAAE,CAAC,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC;IACvB,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,MAAM,UAAU,GAAG,cAAc,CAAC,KAAK,EAAE,OAAO,EAAE,gBAAgB,CAAC,kBAAkB,CAAC,CAAC;QACvF,MAAM,CAAC,gBAAgB,CAAC,UAAU,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC;AACH,CAAC;AAED,wBACI,KAAqB,EAAE,OAAgB,EAAE,kBAA0B;IACrE,MAAM,UAAU,GAAG,KAAK,CAAC,QAAQ,CAAC,eAAe,CAAC;IAClD,MAAM,IAAI,GAAG,OAAO,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;IAC9C,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,kBAAkB,CAAC,CAAC,CAAC;QACtC,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;IAC/C,CAAC;IACD,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,GAAG,kBAAkB,CAAC,CAAC;AACpD,CAAC;AAED,0BAA0B,OAAmB,EAAE,IAA0B;IACvE,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,KAAK,OAAO,CAAC;QAAC,MAAM,CAAC,IAAI,CAAC;IACxC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC5B,MAAM,CAAC,GAAG,gBAAgB,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QACvC,EAAE,CAAC,CAAC,CAAC,CAAC;YAAC,MAAM,CAAC,CAAC,CAAC;IAClB,CAAC;IACD,MAAM,IAAI,KAAK,CAAC,4BAA4B,OAAO,GAAG,CAAC,CAAC;AAC1D,CAAC;AAED,0BACI,IAA0B,EAAE,QAA8B,EAC1D,OAA+B;IACjC,EAAE,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,IAAI,QAAQ,CAAa,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACvD,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,MAAM,CAAC,IAAI,QAAQ,CACf,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAI,gBAAgB,CAAC,CAAC,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAClF,CAAC;AACH,CAAC;AAED,oBAAoB,KAA6B,EAAE,QAAe;IAChE,MAAM,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;IACnC,MAAM,kBAAkB,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC;IACxE,EAAE,CAAC,CAAC,kBAAkB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,eAAe,GAAG,kBAAkB,CAAC,CAAC,CAAC,CAAC;QAC9C,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,GAAG,MAAM,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;IAC5E,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;IACrC,CAAC;IACD,MAAM,CAAC,KAAK,CAAC;AACf,CAAC;AAED,iBAAiB,QAAe;IAC9B,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC;QAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC3D,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAChD,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;AACnD,CAAC;AAED,mBAAmB,QAAe;IAChC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC;QAAC,MAAM,CAAC,cAAc,CAAC;IAC9D,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAChD,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC;AACtD,CAAC;AAED,gBAAgB,IAAgC,EAAE,QAAe;IAC/D,MAAM,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,GAAG,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;IAChD,MAAM,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;IACnC,MAAM,IAAI,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;IAG/B,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC;QACpD,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;QAC/D,MAAM,CAAC,IAAI,QAAQ,CAAa,UAAU,EAAE,QAAQ,CAAC,CAAC;IAExD,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC;QAC7C,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;QACjE,MAAM,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAGlD,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,MAAM,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;QAChD,MAAM,CAAC,IAAI,CAAC;IAGd,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC;QAC5C,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACvF,MAAM,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IAGzC,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,OAAO,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1F,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAGlD,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC;QAC5C,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,CAAC;QACjE,MAAM,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAGlD,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACjD,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IAGzC,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,IAAI,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC;QACpD,MAAM,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IACzC,CAAC;AACH,CAAC;AAED,mBAAmB,MAA4B;IAC7C,MAAM,GAAG,GAAG,EAAE,CAAC;IACf,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;IAC3C,MAAM,CAAC,GAAG,CAAC;AACb,CAAC;AAED,iBAAiB,IAAY,EAAE,MAA4B,EAAE,OAAmB;IAC9E,MAAM,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,IAAI,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC;AAC1E,CAAC;AAED,iBACI,UAAsB,EAAE,IAAgC,EAAE,IAAW;IACvE,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;QACtB,MAAM,CAAC,IAAI,QAAQ,CAAa,UAAU,EAAE,EAAE,CAAC,CAAC;IAClD,CAAC;IACD,MAAM,QAAQ,GAAG,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;IACpD,MAAM,CAAC,IAAI,QAAQ,CAAa,UAAU,EAAE,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;AAC1E,CAAC","sourcesContent":["import {ActivatedRoute} from './router_state';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlSegment, UrlTree} from './url_tree';\nimport {forEach, shallowEqual} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nexport function createUrlTree(\n    route: ActivatedRoute, urlTree: UrlTree, commands: any[], queryParams: Params | undefined,\n    fragment: string | undefined): UrlTree {\n  if (commands.length === 0) {\n    return tree(urlTree._root, urlTree, queryParams, fragment);\n  }\n\n  const normalizedCommands = normalizeCommands(commands);\n  if (navigateToRoot(normalizedCommands)) {\n    return tree(new TreeNode<UrlSegment>(urlTree.root, []), urlTree, queryParams, fragment);\n  }\n\n  const startingNode = findStartingNode(normalizedCommands, urlTree, route);\n  const updated = normalizedCommands.commands.length > 0 ?\n      updateMany(startingNode.children.slice(0), normalizedCommands.commands) :\n      [];\n  const newRoot = constructNewTree(urlTree._root, startingNode, updated);\n\n  return tree(newRoot, urlTree, queryParams, fragment);\n}\n\nfunction tree(\n    root: TreeNode<UrlSegment>, urlTree: UrlTree, queryParams: Params | undefined,\n    fragment: string | undefined): UrlTree {\n  const q = queryParams ? stringify(queryParams) : urlTree.queryParams;\n  const f = fragment ? fragment : urlTree.fragment;\n  return new UrlTree(root, q, f);\n}\n\nfunction navigateToRoot(normalizedChange: NormalizedNavigationCommands): boolean {\n  return normalizedChange.isAbsolute && normalizedChange.commands.length === 1 &&\n      normalizedChange.commands[0] == '/';\n}\n\nclass NormalizedNavigationCommands {\n  constructor(\n      public isAbsolute: boolean, public numberOfDoubleDots: number, public commands: any[]) {}\n}\n\nfunction normalizeCommands(commands: any[]): NormalizedNavigationCommands {\n  if ((typeof commands[0] === 'string') && commands.length === 1 && commands[0] == '/') {\n    return new NormalizedNavigationCommands(true, 0, commands);\n  }\n\n  let numberOfDoubleDots = 0;\n  let isAbsolute = false;\n  const res = [];\n\n  for (let i = 0; i < commands.length; ++i) {\n    const c = commands[i];\n\n    if (!(typeof c === 'string')) {\n      res.push(c);\n      continue;\n    }\n\n    const parts = c.split('/');\n    for (let j = 0; j < parts.length; ++j) {\n      let cc = parts[j];\n\n      // first exp is treated in a special way\n      if (i == 0) {\n        if (j == 0 && cc == '.') {  //  './a'\n          // skip it\n        } else if (j == 0 && cc == '') {  //  '/a'\n          isAbsolute = true;\n        } else if (cc == '..') {  //  '../a'\n          numberOfDoubleDots++;\n        } else if (cc != '') {\n          res.push(cc);\n        }\n\n      } else {\n        if (cc != '') {\n          res.push(cc);\n        }\n      }\n    }\n  }\n\n  return new NormalizedNavigationCommands(isAbsolute, numberOfDoubleDots, res);\n}\n\nfunction findStartingNode(\n    normalizedChange: NormalizedNavigationCommands, urlTree: UrlTree,\n    route: ActivatedRoute): TreeNode<UrlSegment> {\n  if (normalizedChange.isAbsolute) {\n    return urlTree._root;\n  } else {\n    const urlSegment = findUrlSegment(route, urlTree, normalizedChange.numberOfDoubleDots);\n    return findMatchingNode(urlSegment, urlTree._root);\n  }\n}\n\nfunction findUrlSegment(\n    route: ActivatedRoute, urlTree: UrlTree, numberOfDoubleDots: number): UrlSegment {\n  const urlSegment = route.snapshot._lastUrlSegment;\n  const path = urlTree.pathFromRoot(urlSegment);\n  if (path.length <= numberOfDoubleDots) {\n    throw new Error('Invalid number of \\'../\\'');\n  }\n  return path[path.length - 1 - numberOfDoubleDots];\n}\n\nfunction findMatchingNode(segment: UrlSegment, node: TreeNode<UrlSegment>): TreeNode<UrlSegment> {\n  if (node.value === segment) return node;\n  for (let c of node.children) {\n    const r = findMatchingNode(segment, c);\n    if (r) return r;\n  }\n  throw new Error(`Cannot find url segment '${segment}'`);\n}\n\nfunction constructNewTree(\n    node: TreeNode<UrlSegment>, original: TreeNode<UrlSegment>,\n    updated: TreeNode<UrlSegment>[]): TreeNode<UrlSegment> {\n  if (node === original) {\n    return new TreeNode<UrlSegment>(node.value, updated);\n  } else {\n    return new TreeNode<UrlSegment>(\n        node.value, node.children.map(c => constructNewTree(c, original, updated)));\n  }\n}\n\nfunction updateMany(nodes: TreeNode<UrlSegment>[], commands: any[]): TreeNode<UrlSegment>[] {\n  const outlet = getOutlet(commands);\n  const nodesInRightOutlet = nodes.filter(c => c.value.outlet === outlet);\n  if (nodesInRightOutlet.length > 0) {\n    const nodeRightOutlet = nodesInRightOutlet[0];  // there can be only one\n    nodes[nodes.indexOf(nodeRightOutlet)] = update(nodeRightOutlet, commands);\n  } else {\n    nodes.push(update(null, commands));\n  }\n  return nodes;\n}\n\nfunction getPath(commands: any[]): any {\n  if (!(typeof commands[0] === 'string')) return commands[0];\n  const parts = commands[0].toString().split(':');\n  return parts.length > 1 ? parts[1] : commands[0];\n}\n\nfunction getOutlet(commands: any[]): string {\n  if (!(typeof commands[0] === 'string')) return PRIMARY_OUTLET;\n  const parts = commands[0].toString().split(':');\n  return parts.length > 1 ? parts[0] : PRIMARY_OUTLET;\n}\n\nfunction update(node: TreeNode<UrlSegment>| null, commands: any[]): TreeNode<UrlSegment> {\n  const rest = commands.slice(1);\n  const next = rest.length === 0 ? null : rest[0];\n  const outlet = getOutlet(commands);\n  const path = getPath(commands);\n\n  // reach the end of the tree => create new tree nodes.\n  if (!node && !(typeof next === 'object')) {\n    const urlSegment = new UrlSegment(path, {}, outlet);\n    const children = rest.length === 0 ? [] : [update(null, rest)];\n    return new TreeNode<UrlSegment>(urlSegment, children);\n\n  } else if (!node && typeof next === 'object') {\n    const urlSegment = new UrlSegment(path, stringify(next), outlet);\n    return recurse(urlSegment, node, rest.slice(1));\n\n    // different outlet => preserve the subtree\n  } else if (node && outlet !== node.value.outlet) {\n    return node;\n\n    // params command\n  } else if (node && typeof path === 'object') {\n    const newSegment = new UrlSegment(node.value.path, stringify(path), node.value.outlet);\n    return recurse(newSegment, node, rest);\n\n    // next one is a params command && can reuse the node\n  } else if (node && typeof next === 'object' && compare(path, stringify(next), node.value)) {\n    return recurse(node.value, node, rest.slice(1));\n\n    // next one is a params command && cannot reuse the node\n  } else if (node && typeof next === 'object') {\n    const urlSegment = new UrlSegment(path, stringify(next), outlet);\n    return recurse(urlSegment, node, rest.slice(1));\n\n    // next one is not a params command && can reuse the node\n  } else if (node && compare(path, {}, node.value)) {\n    return recurse(node.value, node, rest);\n\n    // next one is not a params command && cannot reuse the node\n  } else {\n    const urlSegment = new UrlSegment(path, {}, outlet);\n    return recurse(urlSegment, node, rest);\n  }\n}\n\nfunction stringify(params: {[key: string]: any}): {[key: string]: string} {\n  const res = {};\n  forEach(params, (v, k) => res[k] = `${v}`);\n  return res;\n}\n\nfunction compare(path: string, params: {[key: string]: any}, segment: UrlSegment): boolean {\n  return path == segment.path && shallowEqual(params, segment.parameters);\n}\n\nfunction recurse(\n    urlSegment: UrlSegment, node: TreeNode<UrlSegment>| null, rest: any[]): TreeNode<UrlSegment> {\n  if (rest.length === 0) {\n    return new TreeNode<UrlSegment>(urlSegment, []);\n  }\n  const children = node ? node.children.slice(0) : [];\n  return new TreeNode<UrlSegment>(urlSegment, updateMany(children, rest));\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create_url_tree.js","sourceRoot":"","sources":["../../src/create_url_tree.ts"],"names":[],"mappings":"OACO,EAAC,cAAc,EAAS,MAAM,UAAU;OACxC,EAAC,iBAAiB,EAAE,UAAU,EAAE,OAAO,EAAC,MAAM,YAAY;OAC1D,EAAC,OAAO,EAAE,YAAY,EAAC,MAAM,oBAAoB;AAExD,8BACI,KAAqB,EAAE,OAAgB,EAAE,QAAe,EAAE,WAAmB,EAC7E,QAAgB;IAClB,EAAE,CAAC,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;IAC1E,CAAC;IAED,MAAM,kBAAkB,GAAG,iBAAiB,CAAC,QAAQ,CAAC,CAAC;IACvD,EAAE,CAAC,CAAC,cAAc,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAC;QACvC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;IACpF,CAAC;IAED,MAAM,gBAAgB,GAAG,oBAAoB,CAAC,kBAAkB,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IAClF,MAAM,OAAO,GAAG,gBAAgB,CAAC,eAAe;QAC5C,qBAAqB,CACjB,gBAAgB,CAAC,OAAO,EAAE,gBAAgB,CAAC,KAAK,EAAE,kBAAkB,CAAC,QAAQ,CAAC;QAClF,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,gBAAgB,CAAC,KAAK,EAAE,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IACjG,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,CAAC,CAAC;AACjF,CAAC;AAED,cACI,UAAsB,EAAE,UAAsB,EAAE,OAAgB,EAAE,WAAmB,EACrF,QAAgB;IAClB,MAAM,CAAC,GAAG,WAAW,GAAG,SAAS,CAAC,WAAW,CAAC,GAAG,OAAO,CAAC,WAAW,CAAC;IACrE,MAAM,CAAC,GAAG,QAAQ,GAAG,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;IAEjD,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IACvC,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,MAAM,CAAC,IAAI,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IACjF,CAAC;AACH,CAAC;AAED,wBACI,OAAmB,EAAE,UAAsB,EAAE,UAAsB;IACrE,MAAM,QAAQ,GAAgC,EAAE,CAAC;IACjD,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC;QAC7B,EAAE,CAAC,CAAC,CAAC,KAAK,UAAU,CAAC,CAAC,CAAC;YACrB,QAAQ,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC;QAC3B,CAAC;QAAC,IAAI,CAAC,CAAC;YACN,QAAQ,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC,CAAC,CAAC;IACH,MAAM,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;AAC3D,CAAC;AAED,wBAAwB,gBAA8C;IACpE,MAAM,CAAC,gBAAgB,CAAC,UAAU,IAAI,gBAAgB,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC;QACxE,gBAAgB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC;AAC1C,CAAC;AAED;IACE,YACW,UAAmB,EAAS,kBAA0B,EAAS,QAAe;QAA9E,eAAU,GAAV,UAAU,CAAS;QAAS,uBAAkB,GAAlB,kBAAkB,CAAQ;QAAS,aAAQ,GAAR,QAAQ,CAAO;IAAG,CAAC;AAC/F,CAAC;AAED,2BAA2B,QAAe;IACxC,EAAE,CAAC,CAAC,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;QACrF,MAAM,CAAC,IAAI,4BAA4B,CAAC,IAAI,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;IAC7D,CAAC;IAED,IAAI,kBAAkB,GAAG,CAAC,CAAC;IAC3B,IAAI,UAAU,GAAG,KAAK,CAAC;IACvB,MAAM,GAAG,GAAG,EAAE,CAAC;IAEf,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC;QACzC,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QAEtB,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC7B,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACZ,QAAQ,CAAC;QACX,CAAC;QAED,MAAM,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC3B,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC;YACtC,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAGlB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACX,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC;gBAE1B,CAAC;gBAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;oBAC9B,UAAU,GAAG,IAAI,CAAC;gBACpB,CAAC;gBAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC;oBACtB,kBAAkB,EAAE,CAAC;gBACvB,CAAC;gBAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;oBACpB,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACf,CAAC;YAEH,CAAC;YAAC,IAAI,CAAC,CAAC;gBACN,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;oBACb,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBACf,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,CAAC,IAAI,4BAA4B,CAAC,UAAU,EAAE,kBAAkB,EAAE,GAAG,CAAC,CAAC;AAC/E,CAAC;AAED;IACE,YAAmB,OAAmB,EAAS,eAAwB,EAAS,KAAa;QAA1E,YAAO,GAAP,OAAO,CAAY;QAAS,oBAAe,GAAf,eAAe,CAAS;QAAS,UAAK,GAAL,KAAK,CAAQ;IAAG,CAAC;AACnG,CAAC;AAED,8BACI,gBAA8C,EAAE,OAAgB,EAChE,KAAqB;IACvB,EAAE,CAAC,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC,CAAC;QAChC,MAAM,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IAC7C,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,CAAC,IAAI,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IAC3D,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,cAAc,GAAG,CAAC,GAAG,gBAAgB,CAAC,kBAAkB,IAAI,CAAC,CAAC,CAAC,CAAC;QACxF,MAAM,CAAC,IAAI,QAAQ,CACf,KAAK,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,EACjC,KAAK,CAAC,QAAQ,CAAC,cAAc,GAAG,CAAC,GAAG,gBAAgB,CAAC,kBAAkB,CAAC,CAAC;IAC/E,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;IAC/C,CAAC;AACH,CAAC;AAED,iBAAiB,OAAY;IAC3B,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC;QAAC,MAAM,CAAC,OAAO,CAAC;IACnD,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC5C,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;AAC/C,CAAC;AAED,mBAAmB,QAAe;IAChC,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC;QAAC,MAAM,CAAC,cAAc,CAAC;IAC9D,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAChD,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC;AACtD,CAAC;AAED,uBAAuB,OAAmB,EAAE,UAAkB,EAAE,QAAe;IAC7E,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC;QACb,OAAO,GAAG,IAAI,UAAU,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IACnC,CAAC;IACD,EAAE,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;QACrF,MAAM,CAAC,qBAAqB,CAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;IAC9D,CAAC;IACD,MAAM,CAAC,GAAG,YAAY,CAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;IACtD,MAAM,cAAc,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;IAEnD,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;QAC3C,MAAM,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;IACrD,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;QACjE,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;IACzD,CAAC;IAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QACnB,MAAM,CAAC,qBAAqB,CAAC,OAAO,EAAE,CAAC,EAAE,cAAc,CAAC,CAAC;IAC3D,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;IACzD,CAAC;AACH,CAAC;AAED,+BACI,OAAmB,EAAE,UAAkB,EAAE,QAAe;IAC1D,EAAE,CAAC,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC;QAC1B,MAAM,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;IACrD,CAAC;IAAC,IAAI,CAAC,CAAC;QACN,MAAM,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;QACnC,MAAM,QAAQ,GAAgC,EAAE,CAAC;QACjD,QAAQ,CAAC,MAAM,CAAC,GAAG,aAAa,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;QACjF,OAAO,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,WAAW;YAC3C,EAAE,CAAC,CAAC,WAAW,KAAK,MAAM,CAAC,CAAC,CAAC;gBAC3B,QAAQ,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC;YAChC,CAAC;QACH,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;IAC3D,CAAC;AACH,CAAC;AAED,sBAAsB,OAAmB,EAAE,UAAkB,EAAE,QAAe;IAC5E,IAAI,mBAAmB,GAAG,CAAC,CAAC;IAC5B,IAAI,gBAAgB,GAAG,UAAU,CAAC;IAElC,MAAM,OAAO,GAAG,EAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,EAAC,CAAC;IAC7C,OAAO,gBAAgB,GAAG,OAAO,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC;QACzD,EAAE,CAAC,CAAC,mBAAmB,IAAI,QAAQ,CAAC,MAAM,CAAC;YAAC,MAAM,CAAC,OAAO,CAAC;QAC3D,MAAM,IAAI,GAAG,OAAO,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;QACvD,MAAM,IAAI,GAAG,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC,CAAC;QACpD,MAAM,IAAI,GACN,mBAAmB,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,GAAG,QAAQ,CAAC,mBAAmB,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC;QAEzF,EAAE,CAAC,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC/C,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;gBAAC,MAAM,CAAC,OAAO,CAAC;YAC/C,mBAAmB,IAAI,CAAC,CAAC;QAC3B,CAAC;QAAC,IAAI,CAAC,CAAC;YACN,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;gBAAC,MAAM,CAAC,OAAO,CAAC;YAC7C,mBAAmB,EAAE,CAAC;QACxB,CAAC;QACD,gBAAgB,EAAE,CAAC;IACrB,CAAC;IAED,MAAM,CAAC,EAAC,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,mBAAmB,EAAC,CAAC;AACvD,CAAC;AAED,0BAA0B,OAAmB,EAAE,UAAkB,EAAE,QAAe;IAChF,MAAM,KAAK,GAAG,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;IAC3D,IAAI,CAAC,GAAG,CAAC,CAAC;IACV,OAAO,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC;QAC3B,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC;YACjD,MAAM,CAAC,GAAG,OAAO,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YAC9C,KAAK,CAAC,IAAI,CAAC,IAAI,iBAAiB,CAAC,CAAC,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACvD,CAAC,EAAE,CAAC;YACJ,QAAQ,CAAC;QACX,CAAC;QAED,MAAM,IAAI,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC;QAChE,EAAE,CAAC,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC/C,KAAK,CAAC,IAAI,CAAC,IAAI,iBAAiB,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACzD,CAAC,IAAI,CAAC,CAAC;QACT,CAAC;QAAC,IAAI,CAAC,CAAC;YACN,KAAK,CAAC,IAAI,CAAC,IAAI,iBAAiB,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;YAC5C,CAAC,EAAE,CAAC;QACN,CAAC;IACH,CAAC;IACD,MAAM,CAAC,IAAI,UAAU,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;AACnC,CAAC;AAED,mBAAmB,MAA4B;IAC7C,MAAM,GAAG,GAA4B,EAAE,CAAC;IACxC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;IAC3C,MAAM,CAAC,GAAG,CAAC;AACb,CAAC;AAED,iBACI,IAAY,EAAE,MAA4B,EAAE,cAAiC;IAC/E,MAAM,CAAC,IAAI,IAAI,cAAc,CAAC,IAAI,IAAI,YAAY,CAAC,MAAM,EAAE,cAAc,CAAC,UAAU,CAAC,CAAC;AACxF,CAAC","sourcesContent":["import {ActivatedRoute} from './router_state';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree} from './url_tree';\nimport {forEach, shallowEqual} from './utils/collection';\n\nexport function createUrlTree(\n    route: ActivatedRoute, urlTree: UrlTree, commands: any[], queryParams: Params,\n    fragment: string): UrlTree {\n  if (commands.length === 0) {\n    return tree(urlTree.root, urlTree.root, urlTree, queryParams, fragment);\n  }\n\n  const normalizedCommands = normalizeCommands(commands);\n  if (navigateToRoot(normalizedCommands)) {\n    return tree(urlTree.root, new UrlSegment([], {}), urlTree, queryParams, fragment);\n  }\n\n  const startingPosition = findStartingPosition(normalizedCommands, urlTree, route);\n  const segment = startingPosition.processChildren ?\n      updateSegmentChildren(\n          startingPosition.segment, startingPosition.index, normalizedCommands.commands) :\n      updateSegment(startingPosition.segment, startingPosition.index, normalizedCommands.commands);\n  return tree(startingPosition.segment, segment, urlTree, queryParams, fragment);\n}\n\nfunction tree(\n    oldSegment: UrlSegment, newSegment: UrlSegment, urlTree: UrlTree, queryParams: Params,\n    fragment: string): UrlTree {\n  const q = queryParams ? stringify(queryParams) : urlTree.queryParams;\n  const f = fragment ? fragment : urlTree.fragment;\n\n  if (urlTree.root === oldSegment) {\n    return new UrlTree(newSegment, q, f);\n  } else {\n    return new UrlTree(replaceSegment(urlTree.root, oldSegment, newSegment), q, f);\n  }\n}\n\nfunction replaceSegment(\n    current: UrlSegment, oldSegment: UrlSegment, newSegment: UrlSegment): UrlSegment {\n  const children: {[key: string]: UrlSegment} = {};\n  forEach(current.children, (c, k) => {\n    if (c === oldSegment) {\n      children[k] = newSegment;\n    } else {\n      children[k] = replaceSegment(c, oldSegment, newSegment);\n    }\n  });\n  return new UrlSegment(current.pathsWithParams, children);\n}\n\nfunction navigateToRoot(normalizedChange: NormalizedNavigationCommands): boolean {\n  return normalizedChange.isAbsolute && normalizedChange.commands.length === 1 &&\n      normalizedChange.commands[0] == '/';\n}\n\nclass NormalizedNavigationCommands {\n  constructor(\n      public isAbsolute: boolean, public numberOfDoubleDots: number, public commands: any[]) {}\n}\n\nfunction normalizeCommands(commands: any[]): NormalizedNavigationCommands {\n  if ((typeof commands[0] === 'string') && commands.length === 1 && commands[0] == '/') {\n    return new NormalizedNavigationCommands(true, 0, commands);\n  }\n\n  let numberOfDoubleDots = 0;\n  let isAbsolute = false;\n  const res = [];\n\n  for (let i = 0; i < commands.length; ++i) {\n    const c = commands[i];\n\n    if (!(typeof c === 'string')) {\n      res.push(c);\n      continue;\n    }\n\n    const parts = c.split('/');\n    for (let j = 0; j < parts.length; ++j) {\n      let cc = parts[j];\n\n      // first exp is treated in a special way\n      if (i == 0) {\n        if (j == 0 && cc == '.') {  //  './a'\n          // skip it\n        } else if (j == 0 && cc == '') {  //  '/a'\n          isAbsolute = true;\n        } else if (cc == '..') {  //  '../a'\n          numberOfDoubleDots++;\n        } else if (cc != '') {\n          res.push(cc);\n        }\n\n      } else {\n        if (cc != '') {\n          res.push(cc);\n        }\n      }\n    }\n  }\n\n  return new NormalizedNavigationCommands(isAbsolute, numberOfDoubleDots, res);\n}\n\nclass Position {\n  constructor(public segment: UrlSegment, public processChildren: boolean, public index: number) {}\n}\n\nfunction findStartingPosition(\n    normalizedChange: NormalizedNavigationCommands, urlTree: UrlTree,\n    route: ActivatedRoute): Position {\n  if (normalizedChange.isAbsolute) {\n    return new Position(urlTree.root, true, 0);\n  } else if (route.snapshot._lastPathIndex === -1) {\n    return new Position(route.snapshot._urlSegment, true, 0);\n  } else if (route.snapshot._lastPathIndex + 1 - normalizedChange.numberOfDoubleDots >= 0) {\n    return new Position(\n        route.snapshot._urlSegment, false,\n        route.snapshot._lastPathIndex + 1 - normalizedChange.numberOfDoubleDots);\n  } else {\n    throw new Error('Invalid number of \\'../\\'');\n  }\n}\n\nfunction getPath(command: any): any {\n  if (!(typeof command === 'string')) return command;\n  const parts = command.toString().split(':');\n  return parts.length > 1 ? parts[1] : command;\n}\n\nfunction getOutlet(commands: any[]): string {\n  if (!(typeof commands[0] === 'string')) return PRIMARY_OUTLET;\n  const parts = commands[0].toString().split(':');\n  return parts.length > 1 ? parts[0] : PRIMARY_OUTLET;\n}\n\nfunction updateSegment(segment: UrlSegment, startIndex: number, commands: any[]): UrlSegment {\n  if (!segment) {\n    segment = new UrlSegment([], {});\n  }\n  if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {\n    return updateSegmentChildren(segment, startIndex, commands);\n  }\n  const m = prefixedWith(segment, startIndex, commands);\n  const slicedCommands = commands.slice(m.lastIndex);\n\n  if (m.match && slicedCommands.length === 0) {\n    return new UrlSegment(segment.pathsWithParams, {});\n  } else if (m.match && Object.keys(segment.children).length === 0) {\n    return createNewSegment(segment, startIndex, commands);\n  } else if (m.match) {\n    return updateSegmentChildren(segment, 0, slicedCommands);\n  } else {\n    return createNewSegment(segment, startIndex, commands);\n  }\n}\n\nfunction updateSegmentChildren(\n    segment: UrlSegment, startIndex: number, commands: any[]): UrlSegment {\n  if (commands.length === 0) {\n    return new UrlSegment(segment.pathsWithParams, {});\n  } else {\n    const outlet = getOutlet(commands);\n    const children: {[key: string]: UrlSegment} = {};\n    children[outlet] = updateSegment(segment.children[outlet], startIndex, commands);\n    forEach(segment.children, (child, childOutlet) => {\n      if (childOutlet !== outlet) {\n        children[childOutlet] = child;\n      }\n    });\n    return new UrlSegment(segment.pathsWithParams, children);\n  }\n}\n\nfunction prefixedWith(segment: UrlSegment, startIndex: number, commands: any[]) {\n  let currentCommandIndex = 0;\n  let currentPathIndex = startIndex;\n\n  const noMatch = {match: false, lastIndex: 0};\n  while (currentPathIndex < segment.pathsWithParams.length) {\n    if (currentCommandIndex >= commands.length) return noMatch;\n    const path = segment.pathsWithParams[currentPathIndex];\n    const curr = getPath(commands[currentCommandIndex]);\n    const next =\n        currentCommandIndex < commands.length - 1 ? commands[currentCommandIndex + 1] : null;\n\n    if (curr && next && (typeof next === 'object')) {\n      if (!compare(curr, next, path)) return noMatch;\n      currentCommandIndex += 2;\n    } else {\n      if (!compare(curr, {}, path)) return noMatch;\n      currentCommandIndex++;\n    }\n    currentPathIndex++;\n  }\n\n  return {match: true, lastIndex: currentCommandIndex};\n}\n\nfunction createNewSegment(segment: UrlSegment, startIndex: number, commands: any[]): UrlSegment {\n  const paths = segment.pathsWithParams.slice(0, startIndex);\n  let i = 0;\n  while (i < commands.length) {\n    if (i === 0 && (typeof commands[0] === 'object')) {\n      const p = segment.pathsWithParams[startIndex];\n      paths.push(new UrlPathWithParams(p.path, commands[0]));\n      i++;\n      continue;\n    }\n\n    const curr = getPath(commands[i]);\n    const next = (i < commands.length - 1) ? commands[i + 1] : null;\n    if (curr && next && (typeof next === 'object')) {\n      paths.push(new UrlPathWithParams(curr, stringify(next)));\n      i += 2;\n    } else {\n      paths.push(new UrlPathWithParams(curr, {}));\n      i++;\n    }\n  }\n  return new UrlSegment(paths, {});\n}\n\nfunction stringify(params: {[key: string]: any}): {[key: string]: string} {\n  const res: {[key: string]: string} = {};\n  forEach(params, (v, k) => res[k] = `${v}`);\n  return res;\n}\n\nfunction compare(\n    path: string, params: {[key: string]: any}, pathWithParams: UrlPathWithParams): boolean {\n  return path == pathWithParams.path && shallowEqual(params, pathWithParams.parameters);\n}"]}

@@ -10,7 +10,7 @@ import { ComponentFactory, ResolvedReflectiveProvider, ViewContainerRef } from '@angular/core';

constructor(parentOutletMap: RouterOutletMap, location: ViewContainerRef, name: string);
readonly isActivated: boolean;
readonly component: Object;
readonly activatedRoute: ActivatedRoute;
isActivated: boolean;
component: Object;
activatedRoute: ActivatedRoute;
deactivate(): void;
activate(factory: ComponentFactory<any>, activatedRoute: ActivatedRoute, providers: ResolvedReflectiveProvider[], outletMap: RouterOutletMap): void;
}

@@ -50,2 +50,2 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

], RouterOutlet);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyX291dGxldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXJlY3RpdmVzL3JvdXRlcl9vdXRsZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O09BQU8sRUFBQyxTQUFTLEVBQWtDLFNBQVMsRUFBRSxrQkFBa0IsRUFBOEIsZ0JBQWdCLEVBQUMsTUFBTSxlQUFlO09BQzdJLEVBQUMsZUFBZSxFQUFDLE1BQU0sc0JBQXNCO09BRTdDLEVBQUMsY0FBYyxFQUFDLE1BQU0sV0FBVztBQUd4QztJQVFFLFlBQ0ksZUFBZ0MsRUFBVSxRQUEwQixFQUNqRCxJQUFZO1FBRFcsYUFBUSxHQUFSLFFBQVEsQ0FBa0I7UUFFdEUsZUFBZSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEdBQUcsSUFBSSxHQUFHLGNBQWMsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBRUQsSUFBSSxXQUFXLEtBQWMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztJQUN2RCxJQUFJLFNBQVM7UUFDWCxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7WUFBQyxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFDaEUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO0lBQ2pDLENBQUM7SUFDRCxJQUFJLGNBQWM7UUFDaEIsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQUMsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO1FBQ2hFLE1BQU0sQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDO0lBQzlCLENBQUM7SUFFRCxVQUFVO1FBQ1IsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7WUFDbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUN6QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUN4QixDQUFDO0lBQ0gsQ0FBQztJQUVELFFBQVEsQ0FDSixPQUE4QixFQUFFLGNBQThCLEVBQUUsU0FBdUMsRUFDdkcsU0FBMEI7UUFDNUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDM0IsSUFBSSxDQUFDLGVBQWUsR0FBRyxjQUFjLENBQUM7UUFDdEMsTUFBTSxHQUFHLEdBQUcsa0JBQWtCLENBQUMscUJBQXFCLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDOUYsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3pGLENBQUM7QUFDSCxDQUFDO0FBeENEO0lBQUMsU0FBUyxDQUFDLEVBQUMsUUFBUSxFQUFFLGVBQWUsRUFBQyxDQUFDO2VBV2hDLFNBQVMsQ0FBQyxNQUFNLENBQUM7O2dCQVhlO0FBd0N0QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXR0cmlidXRlLCBDb21wb25lbnRGYWN0b3J5LCBDb21wb25lbnRSZWYsIERpcmVjdGl2ZSwgUmVmbGVjdGl2ZUluamVjdG9yLCBSZXNvbHZlZFJlZmxlY3RpdmVQcm92aWRlciwgVmlld0NvbnRhaW5lclJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1JvdXRlck91dGxldE1hcH0gZnJvbSAnLi4vcm91dGVyX291dGxldF9tYXAnO1xuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZX0gZnJvbSAnLi4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7UFJJTUFSWV9PVVRMRVR9IGZyb20gJy4uL3NoYXJlZCc7XG5cbkBEaXJlY3RpdmUoe3NlbGVjdG9yOiAncm91dGVyLW91dGxldCd9KVxuZXhwb3J0IGNsYXNzIFJvdXRlck91dGxldCB7XG4gIHByaXZhdGUgYWN0aXZhdGVkOiBDb21wb25lbnRSZWY8YW55PnxudWxsO1xuICBwcml2YXRlIF9hY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGV8bnVsbDtcbiAgcHVibGljIG91dGxldE1hcDogUm91dGVyT3V0bGV0TWFwO1xuXG4gIC8qKlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIGNvbnN0cnVjdG9yKFxuICAgICAgcGFyZW50T3V0bGV0TWFwOiBSb3V0ZXJPdXRsZXRNYXAsIHByaXZhdGUgbG9jYXRpb246IFZpZXdDb250YWluZXJSZWYsXG4gICAgICBAQXR0cmlidXRlKCduYW1lJykgbmFtZTogc3RyaW5nKSB7XG4gICAgcGFyZW50T3V0bGV0TWFwLnJlZ2lzdGVyT3V0bGV0KG5hbWUgPyBuYW1lIDogUFJJTUFSWV9PVVRMRVQsIHRoaXMpO1xuICB9XG5cbiAgZ2V0IGlzQWN0aXZhdGVkKCk6IGJvb2xlYW4geyByZXR1cm4gISF0aGlzLmFjdGl2YXRlZDsgfVxuICBnZXQgY29tcG9uZW50KCk6IE9iamVjdCB7XG4gICAgaWYgKCF0aGlzLmFjdGl2YXRlZCkgdGhyb3cgbmV3IEVycm9yKCdPdXRsZXQgaXMgbm90IGFjdGl2YXRlZCcpO1xuICAgIHJldHVybiB0aGlzLmFjdGl2YXRlZC5pbnN0YW5jZTtcbiAgfVxuICBnZXQgYWN0aXZhdGVkUm91dGUoKTogQWN0aXZhdGVkUm91dGUge1xuICAgIGlmICghdGhpcy5hY3RpdmF0ZWQpIHRocm93IG5ldyBFcnJvcignT3V0bGV0IGlzIG5vdCBhY3RpdmF0ZWQnKTtcbiAgICByZXR1cm4gdGhpcy5fYWN0aXZhdGVkUm91dGU7XG4gIH1cblxuICBkZWFjdGl2YXRlKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmFjdGl2YXRlZCkge1xuICAgICAgdGhpcy5hY3RpdmF0ZWQuZGVzdHJveSgpO1xuICAgICAgdGhpcy5hY3RpdmF0ZWQgPSBudWxsO1xuICAgIH1cbiAgfVxuXG4gIGFjdGl2YXRlKFxuICAgICAgZmFjdG9yeTogQ29tcG9uZW50RmFjdG9yeTxhbnk+LCBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGUsIHByb3ZpZGVyczogUmVzb2x2ZWRSZWZsZWN0aXZlUHJvdmlkZXJbXSxcbiAgICAgIG91dGxldE1hcDogUm91dGVyT3V0bGV0TWFwKTogdm9pZCB7XG4gICAgdGhpcy5vdXRsZXRNYXAgPSBvdXRsZXRNYXA7XG4gICAgdGhpcy5fYWN0aXZhdGVkUm91dGUgPSBhY3RpdmF0ZWRSb3V0ZTtcbiAgICBjb25zdCBpbmogPSBSZWZsZWN0aXZlSW5qZWN0b3IuZnJvbVJlc29sdmVkUHJvdmlkZXJzKHByb3ZpZGVycywgdGhpcy5sb2NhdGlvbi5wYXJlbnRJbmplY3Rvcik7XG4gICAgdGhpcy5hY3RpdmF0ZWQgPSB0aGlzLmxvY2F0aW9uLmNyZWF0ZUNvbXBvbmVudChmYWN0b3J5LCB0aGlzLmxvY2F0aW9uLmxlbmd0aCwgaW5qLCBbXSk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyX291dGxldC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kaXJlY3RpdmVzL3JvdXRlcl9vdXRsZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O09BQU8sRUFBQyxTQUFTLEVBQWtDLFNBQVMsRUFBRSxrQkFBa0IsRUFBOEIsZ0JBQWdCLEVBQUMsTUFBTSxlQUFlO09BQzdJLEVBQUMsZUFBZSxFQUFDLE1BQU0sc0JBQXNCO09BRTdDLEVBQUMsY0FBYyxFQUFDLE1BQU0sV0FBVztBQUd4QztJQVFFLFlBQ0ksZUFBZ0MsRUFBVSxRQUEwQixFQUNqRCxJQUFZO1FBRFcsYUFBUSxHQUFSLFFBQVEsQ0FBa0I7UUFFdEUsZUFBZSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEdBQUcsSUFBSSxHQUFHLGNBQWMsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBRUQsSUFBSSxXQUFXLEtBQWMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQztJQUN2RCxJQUFJLFNBQVM7UUFDWCxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7WUFBQyxNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFDaEUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO0lBQ2pDLENBQUM7SUFDRCxJQUFJLGNBQWM7UUFDaEIsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQUMsTUFBTSxJQUFJLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO1FBQ2hFLE1BQU0sQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDO0lBQzlCLENBQUM7SUFFRCxVQUFVO1FBQ1IsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7WUFDbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUN6QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztRQUN4QixDQUFDO0lBQ0gsQ0FBQztJQUVELFFBQVEsQ0FDSixPQUE4QixFQUFFLGNBQThCLEVBQzlELFNBQXVDLEVBQUUsU0FBMEI7UUFDckUsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDM0IsSUFBSSxDQUFDLGVBQWUsR0FBRyxjQUFjLENBQUM7UUFDdEMsTUFBTSxHQUFHLEdBQUcsa0JBQWtCLENBQUMscUJBQXFCLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDOUYsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3pGLENBQUM7QUFDSCxDQUFDO0FBeENEO0lBQUMsU0FBUyxDQUFDLEVBQUMsUUFBUSxFQUFFLGVBQWUsRUFBQyxDQUFDO2VBV2hDLFNBQVMsQ0FBQyxNQUFNLENBQUM7O2dCQVhlO0FBd0N0QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXR0cmlidXRlLCBDb21wb25lbnRGYWN0b3J5LCBDb21wb25lbnRSZWYsIERpcmVjdGl2ZSwgUmVmbGVjdGl2ZUluamVjdG9yLCBSZXNvbHZlZFJlZmxlY3RpdmVQcm92aWRlciwgVmlld0NvbnRhaW5lclJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1JvdXRlck91dGxldE1hcH0gZnJvbSAnLi4vcm91dGVyX291dGxldF9tYXAnO1xuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZX0gZnJvbSAnLi4vcm91dGVyX3N0YXRlJztcbmltcG9ydCB7UFJJTUFSWV9PVVRMRVR9IGZyb20gJy4uL3NoYXJlZCc7XG5cbkBEaXJlY3RpdmUoe3NlbGVjdG9yOiAncm91dGVyLW91dGxldCd9KVxuZXhwb3J0IGNsYXNzIFJvdXRlck91dGxldCB7XG4gIHByaXZhdGUgYWN0aXZhdGVkOiBDb21wb25lbnRSZWY8YW55PjtcbiAgcHJpdmF0ZSBfYWN0aXZhdGVkUm91dGU6IEFjdGl2YXRlZFJvdXRlO1xuICBwdWJsaWMgb3V0bGV0TWFwOiBSb3V0ZXJPdXRsZXRNYXA7XG5cbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgY29uc3RydWN0b3IoXG4gICAgICBwYXJlbnRPdXRsZXRNYXA6IFJvdXRlck91dGxldE1hcCwgcHJpdmF0ZSBsb2NhdGlvbjogVmlld0NvbnRhaW5lclJlZixcbiAgICAgIEBBdHRyaWJ1dGUoJ25hbWUnKSBuYW1lOiBzdHJpbmcpIHtcbiAgICBwYXJlbnRPdXRsZXRNYXAucmVnaXN0ZXJPdXRsZXQobmFtZSA/IG5hbWUgOiBQUklNQVJZX09VVExFVCwgdGhpcyk7XG4gIH1cblxuICBnZXQgaXNBY3RpdmF0ZWQoKTogYm9vbGVhbiB7IHJldHVybiAhIXRoaXMuYWN0aXZhdGVkOyB9XG4gIGdldCBjb21wb25lbnQoKTogT2JqZWN0IHtcbiAgICBpZiAoIXRoaXMuYWN0aXZhdGVkKSB0aHJvdyBuZXcgRXJyb3IoJ091dGxldCBpcyBub3QgYWN0aXZhdGVkJyk7XG4gICAgcmV0dXJuIHRoaXMuYWN0aXZhdGVkLmluc3RhbmNlO1xuICB9XG4gIGdldCBhY3RpdmF0ZWRSb3V0ZSgpOiBBY3RpdmF0ZWRSb3V0ZSB7XG4gICAgaWYgKCF0aGlzLmFjdGl2YXRlZCkgdGhyb3cgbmV3IEVycm9yKCdPdXRsZXQgaXMgbm90IGFjdGl2YXRlZCcpO1xuICAgIHJldHVybiB0aGlzLl9hY3RpdmF0ZWRSb3V0ZTtcbiAgfVxuXG4gIGRlYWN0aXZhdGUoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuYWN0aXZhdGVkKSB7XG4gICAgICB0aGlzLmFjdGl2YXRlZC5kZXN0cm95KCk7XG4gICAgICB0aGlzLmFjdGl2YXRlZCA9IG51bGw7XG4gICAgfVxuICB9XG5cbiAgYWN0aXZhdGUoXG4gICAgICBmYWN0b3J5OiBDb21wb25lbnRGYWN0b3J5PGFueT4sIGFjdGl2YXRlZFJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSxcbiAgICAgIHByb3ZpZGVyczogUmVzb2x2ZWRSZWZsZWN0aXZlUHJvdmlkZXJbXSwgb3V0bGV0TWFwOiBSb3V0ZXJPdXRsZXRNYXApOiB2b2lkIHtcbiAgICB0aGlzLm91dGxldE1hcCA9IG91dGxldE1hcDtcbiAgICB0aGlzLl9hY3RpdmF0ZWRSb3V0ZSA9IGFjdGl2YXRlZFJvdXRlO1xuICAgIGNvbnN0IGluaiA9IFJlZmxlY3RpdmVJbmplY3Rvci5mcm9tUmVzb2x2ZWRQcm92aWRlcnMocHJvdmlkZXJzLCB0aGlzLmxvY2F0aW9uLnBhcmVudEluamVjdG9yKTtcbiAgICB0aGlzLmFjdGl2YXRlZCA9IHRoaXMubG9jYXRpb24uY3JlYXRlQ29tcG9uZW50KGZhY3RvcnksIHRoaXMubG9jYXRpb24ubGVuZ3RoLCBpbmosIFtdKTtcbiAgfVxufVxuIl19
import { RouterLink } from './directives/router_link';
import { RouterOutlet } from './directives/router_outlet';
export { ExtraOptions } from './common_router_providers';
export { Route, RouterConfig } from './config';
export { CanActivate, CanDeactivate } from './interfaces';
export { Event, NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router } from './router';
export { Event, NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router, RoutesRecognized } from './router';
export { RouterOutletMap } from './router_outlet_map';

@@ -11,3 +12,3 @@ export { provideRouter } from './router_providers';

export { DefaultUrlSerializer, UrlSerializer } from './url_serializer';
export { UrlSegment, UrlTree } from './url_tree';
export { UrlPathWithParams, UrlTree } from './url_tree';
export declare const ROUTER_DIRECTIVES: (typeof RouterOutlet | typeof RouterLink)[];
import { RouterLink } from './directives/router_link';
import { RouterOutlet } from './directives/router_outlet';
export { NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router } from './router';
export { NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router, RoutesRecognized } from './router';
export { RouterOutletMap } from './router_outlet_map';

@@ -9,4 +9,4 @@ export { provideRouter } from './router_providers';

export { DefaultUrlSerializer, UrlSerializer } from './url_serializer';
export { UrlSegment, UrlTree } from './url_tree';
export { UrlPathWithParams, UrlTree } from './url_tree';
export const ROUTER_DIRECTIVES = [RouterOutlet, RouterLink];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ik9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSwwQkFBMEI7T0FDNUMsRUFBQyxZQUFZLEVBQUMsTUFBTSw0QkFBNEI7QUFJdkQsU0FBZSxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLGVBQWUsRUFBRSxNQUFNLFFBQU8sVUFBVSxDQUFDO0FBQzFHLFNBQVEsZUFBZSxRQUFPLHFCQUFxQixDQUFDO0FBQ3BELFNBQVEsYUFBYSxRQUFPLG9CQUFvQixDQUFDO0FBQ2pELFNBQVEsY0FBYyxFQUFFLHNCQUFzQixFQUFFLFdBQVcsRUFBRSxtQkFBbUIsUUFBTyxnQkFBZ0IsQ0FBQztBQUN4RyxTQUFRLGNBQWMsUUFBZSxVQUFVLENBQUM7QUFDaEQsU0FBUSxvQkFBb0IsRUFBRSxhQUFhLFFBQU8sa0JBQWtCLENBQUM7QUFDckUsU0FBUSxVQUFVLEVBQUUsT0FBTyxRQUFPLFlBQVksQ0FBQztBQUUvQyxPQUFPLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxZQUFZLEVBQUUsVUFBVSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1JvdXRlckxpbmt9IGZyb20gJy4vZGlyZWN0aXZlcy9yb3V0ZXJfbGluayc7XG5pbXBvcnQge1JvdXRlck91dGxldH0gZnJvbSAnLi9kaXJlY3RpdmVzL3JvdXRlcl9vdXRsZXQnO1xuXG5leHBvcnQge1JvdXRlLCBSb3V0ZXJDb25maWd9IGZyb20gJy4vY29uZmlnJztcbmV4cG9ydCB7Q2FuQWN0aXZhdGUsIENhbkRlYWN0aXZhdGV9IGZyb20gJy4vaW50ZXJmYWNlcyc7XG5leHBvcnQge0V2ZW50LCBOYXZpZ2F0aW9uQ2FuY2VsLCBOYXZpZ2F0aW9uRW5kLCBOYXZpZ2F0aW9uRXJyb3IsIE5hdmlnYXRpb25TdGFydCwgUm91dGVyfSBmcm9tICcuL3JvdXRlcic7XG5leHBvcnQge1JvdXRlck91dGxldE1hcH0gZnJvbSAnLi9yb3V0ZXJfb3V0bGV0X21hcCc7XG5leHBvcnQge3Byb3ZpZGVSb3V0ZXJ9IGZyb20gJy4vcm91dGVyX3Byb3ZpZGVycyc7XG5leHBvcnQge0FjdGl2YXRlZFJvdXRlLCBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LCBSb3V0ZXJTdGF0ZSwgUm91dGVyU3RhdGVTbmFwc2hvdH0gZnJvbSAnLi9yb3V0ZXJfc3RhdGUnO1xuZXhwb3J0IHtQUklNQVJZX09VVExFVCwgUGFyYW1zfSBmcm9tICcuL3NoYXJlZCc7XG5leHBvcnQge0RlZmF1bHRVcmxTZXJpYWxpemVyLCBVcmxTZXJpYWxpemVyfSBmcm9tICcuL3VybF9zZXJpYWxpemVyJztcbmV4cG9ydCB7VXJsU2VnbWVudCwgVXJsVHJlZX0gZnJvbSAnLi91cmxfdHJlZSc7XG5cbmV4cG9ydCBjb25zdCBST1VURVJfRElSRUNUSVZFUyA9IFtSb3V0ZXJPdXRsZXQsIFJvdXRlckxpbmtdOyJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ik9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSwwQkFBMEI7T0FDNUMsRUFBQyxZQUFZLEVBQUMsTUFBTSw0QkFBNEI7QUFLdkQsU0FBZSxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLGVBQWUsRUFBRSxNQUFNLEVBQUUsZ0JBQWdCLFFBQU8sVUFBVSxDQUFDO0FBQzVILFNBQVEsZUFBZSxRQUFPLHFCQUFxQixDQUFDO0FBQ3BELFNBQVEsYUFBYSxRQUFPLG9CQUFvQixDQUFDO0FBQ2pELFNBQVEsY0FBYyxFQUFFLHNCQUFzQixFQUFFLFdBQVcsRUFBRSxtQkFBbUIsUUFBTyxnQkFBZ0IsQ0FBQztBQUN4RyxTQUFRLGNBQWMsUUFBZSxVQUFVLENBQUM7QUFDaEQsU0FBUSxvQkFBb0IsRUFBRSxhQUFhLFFBQU8sa0JBQWtCLENBQUM7QUFDckUsU0FBUSxpQkFBaUIsRUFBRSxPQUFPLFFBQU8sWUFBWSxDQUFDO0FBRXRELE9BQU8sTUFBTSxpQkFBaUIsR0FBRyxDQUFDLFlBQVksRUFBRSxVQUFVLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Um91dGVyTGlua30gZnJvbSAnLi9kaXJlY3RpdmVzL3JvdXRlcl9saW5rJztcbmltcG9ydCB7Um91dGVyT3V0bGV0fSBmcm9tICcuL2RpcmVjdGl2ZXMvcm91dGVyX291dGxldCc7XG5cbmV4cG9ydCB7RXh0cmFPcHRpb25zfSBmcm9tICcuL2NvbW1vbl9yb3V0ZXJfcHJvdmlkZXJzJztcbmV4cG9ydCB7Um91dGUsIFJvdXRlckNvbmZpZ30gZnJvbSAnLi9jb25maWcnO1xuZXhwb3J0IHtDYW5BY3RpdmF0ZSwgQ2FuRGVhY3RpdmF0ZX0gZnJvbSAnLi9pbnRlcmZhY2VzJztcbmV4cG9ydCB7RXZlbnQsIE5hdmlnYXRpb25DYW5jZWwsIE5hdmlnYXRpb25FbmQsIE5hdmlnYXRpb25FcnJvciwgTmF2aWdhdGlvblN0YXJ0LCBSb3V0ZXIsIFJvdXRlc1JlY29nbml6ZWR9IGZyb20gJy4vcm91dGVyJztcbmV4cG9ydCB7Um91dGVyT3V0bGV0TWFwfSBmcm9tICcuL3JvdXRlcl9vdXRsZXRfbWFwJztcbmV4cG9ydCB7cHJvdmlkZVJvdXRlcn0gZnJvbSAnLi9yb3V0ZXJfcHJvdmlkZXJzJztcbmV4cG9ydCB7QWN0aXZhdGVkUm91dGUsIEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIFJvdXRlclN0YXRlLCBSb3V0ZXJTdGF0ZVNuYXBzaG90fSBmcm9tICcuL3JvdXRlcl9zdGF0ZSc7XG5leHBvcnQge1BSSU1BUllfT1VUTEVULCBQYXJhbXN9IGZyb20gJy4vc2hhcmVkJztcbmV4cG9ydCB7RGVmYXVsdFVybFNlcmlhbGl6ZXIsIFVybFNlcmlhbGl6ZXJ9IGZyb20gJy4vdXJsX3NlcmlhbGl6ZXInO1xuZXhwb3J0IHtVcmxQYXRoV2l0aFBhcmFtcywgVXJsVHJlZX0gZnJvbSAnLi91cmxfdHJlZSc7XG5cbmV4cG9ydCBjb25zdCBST1VURVJfRElSRUNUSVZFUyA9IFtSb3V0ZXJPdXRsZXQsIFJvdXRlckxpbmtdOyJdfQ==

@@ -6,2 +6,2 @@ import { Type } from '@angular/core';

import { UrlTree } from './url_tree';
export declare function recognize(rootComponentType: Type, config: RouterConfig, url: UrlTree): Observable<RouterStateSnapshot>;
export declare function recognize(rootComponentType: Type, config: RouterConfig, urlTree: UrlTree, url: string): Observable<RouterStateSnapshot>;
import { Observable } from 'rxjs/Observable';
import { of } from 'rxjs/observable/of';
import { match } from './apply_redirects';
import { ActivatedRouteSnapshot, RouterStateSnapshot } from './router_state';
import { PRIMARY_OUTLET } from './shared';
import { first, flatten, forEach, merge } from './utils/collection';
import { mapChildrenIntoArray } from './url_tree';
import { last, merge } from './utils/collection';
import { TreeNode } from './utils/tree';
class CannotRecognize {
class NoMatch {
constructor(segment = null) {
this.segment = segment;
}
}
export function recognize(rootComponentType, config, url) {
export function recognize(rootComponentType, config, urlTree, url) {
try {
const match = new MatchResult(rootComponentType, config, [url.root], {}, url._root.children, [], PRIMARY_OUTLET, null, url.root);
const roots = constructActivatedRoute(match);
return of(new RouterStateSnapshot(roots[0], url.queryParams, url.fragment));
const children = processSegment(config, urlTree.root, PRIMARY_OUTLET);
const root = new ActivatedRouteSnapshot([], {}, PRIMARY_OUTLET, rootComponentType, null, urlTree.root, -1);
const rootNode = new TreeNode(root, children);
return of(new RouterStateSnapshot(url, rootNode, urlTree.queryParams, urlTree.fragment));
}
catch (e) {
if (e instanceof CannotRecognize) {
return new Observable(obs => obs.error(new Error('Cannot match any routes')));
if (e instanceof NoMatch) {
return new Observable(obs => obs.error(new Error(`Cannot match any routes: '${e.segment}'`)));
}

@@ -25,9 +29,18 @@ else {

}
function constructActivatedRoute(match) {
const activatedRoute = createActivatedRouteSnapshot(match);
const children = match.leftOverUrl.length > 0 ?
recognizeMany(match.children, match.leftOverUrl) :
recognizeLeftOvers(match.children, match.lastUrlSegment);
function processSegment(config, segment, outlet) {
if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {
return processSegmentChildren(config, segment);
}
else {
return [processPathsWithParams(config, segment, 0, segment.pathsWithParams, outlet)];
}
}
function processSegmentChildren(config, segment) {
const children = mapChildrenIntoArray(segment, (child, childOutlet) => processSegment(config, child, childOutlet));
checkOutletNameUniqueness(children);
children.sort((a, b) => {
sortActivatedRouteSnapshots(children);
return children;
}
function sortActivatedRouteSnapshots(nodes) {
nodes.sort((a, b) => {
if (a.value.outlet === PRIMARY_OUTLET)

@@ -39,36 +52,77 @@ return -1;

});
return [new TreeNode(activatedRoute, children)];
}
function recognizeLeftOvers(config, lastUrlSegment) {
if (!config)
return [];
const mIndex = matchIndex(config, [], lastUrlSegment);
return mIndex ? constructActivatedRoute(mIndex) : [];
}
function recognizeMany(config, urls) {
return flatten(urls.map(url => recognizeOne(config, url)));
}
function createActivatedRouteSnapshot(match) {
return new ActivatedRouteSnapshot(match.consumedUrlSegments, match.parameters, match.outlet, match.component, match.route, match.lastUrlSegment);
}
function recognizeOne(config, url) {
const matches = matchNode(config, url);
for (let match of matches) {
function processPathsWithParams(config, segment, pathIndex, paths, outlet) {
for (let r of config) {
try {
const primary = constructActivatedRoute(match);
const secondary = recognizeMany(config, match.secondary);
const res = primary.concat(secondary);
checkOutletNameUniqueness(res);
return res;
return processPathsWithParamsAgainstRoute(r, segment, pathIndex, paths, outlet);
}
catch (e) {
if (!(e instanceof CannotRecognize)) {
if (!(e instanceof NoMatch))
throw e;
}
}
}
throw new CannotRecognize();
throw new NoMatch(segment);
}
function processPathsWithParamsAgainstRoute(route, segment, pathIndex, paths, outlet) {
if (route.redirectTo)
throw new NoMatch();
if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== outlet)
throw new NoMatch();
if (route.path === '**') {
const params = paths.length > 0 ? last(paths).parameters : {};
const snapshot = new ActivatedRouteSnapshot(paths, params, outlet, route.component, route, segment, -1);
return new TreeNode(snapshot, []);
}
const { consumedPaths, parameters, lastChild } = match(segment, route, paths);
const snapshot = new ActivatedRouteSnapshot(consumedPaths, parameters, outlet, route.component, route, segment, pathIndex + lastChild - 1);
const slicedPath = paths.slice(lastChild);
const childConfig = route.children ? route.children : [];
if (childConfig.length === 0 && slicedPath.length === 0) {
return new TreeNode(snapshot, []);
}
else if (slicedPath.length === 0 && Object.keys(segment.children).length > 0) {
const children = processSegmentChildren(childConfig, segment);
return new TreeNode(snapshot, children);
}
else {
const child = processPathsWithParams(childConfig, segment, pathIndex + lastChild, slicedPath, PRIMARY_OUTLET);
return new TreeNode(snapshot, [child]);
}
}
function match(segment, route, paths) {
if (route.index || route.path === '' || route.path === '/') {
if (route.terminal && (Object.keys(segment.children).length > 0 || paths.length > 0)) {
throw new NoMatch();
}
else {
return { consumedPaths: [], lastChild: 0, parameters: {} };
}
}
const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;
const parts = path.split('/');
const posParameters = {};
const consumedPaths = [];
let currentIndex = 0;
for (let i = 0; i < parts.length; ++i) {
if (currentIndex >= paths.length)
throw new NoMatch();
const current = paths[currentIndex];
const p = parts[i];
const isPosParam = p.startsWith(':');
if (!isPosParam && p !== current.path)
throw new NoMatch();
if (isPosParam) {
posParameters[p.substring(1)] = current.path;
}
consumedPaths.push(current);
currentIndex++;
}
if (route.terminal && (Object.keys(segment.children).length > 0 || currentIndex < paths.length)) {
throw new NoMatch();
}
const parameters = merge(posParameters, consumedPaths[consumedPaths.length - 1].parameters);
return { consumedPaths, lastChild: currentIndex, parameters };
}
function checkOutletNameUniqueness(nodes) {
let names = {};
const names = {};
nodes.forEach(n => {

@@ -78,3 +132,3 @@ let routeWithSameOutletName = names[n.value.outlet];

const p = routeWithSameOutletName.urlSegments.map(s => s.toString()).join('/');
const c = n.value.urlSegments.map(s => s.toString()).join('/');
const c = n.value.url.map(s => s.toString()).join('/');
throw new Error(`Two segments cannot have the same outlet name: '${p}' and '${c}'.`);

@@ -84,72 +138,3 @@ }

});
return nodes;
}
function matchNode(config, url) {
const res = [];
for (let r of config) {
const m = matchWithParts(r, url);
if (m) {
res.push(m);
}
else if (r.index) {
res.push(createIndexMatch(r, [url], url.value));
}
}
return res;
}
function createIndexMatch(r, leftOverUrls, lastUrlSegment) {
const outlet = r.outlet ? r.outlet : PRIMARY_OUTLET;
const children = r.children ? r.children : [];
return new MatchResult(r.component, children, [], lastUrlSegment.parameters, leftOverUrls, [], outlet, r, lastUrlSegment);
}
function matchIndex(config, leftOverUrls, lastUrlSegment) {
for (let r of config) {
if (r.index) {
return createIndexMatch(r, leftOverUrls, lastUrlSegment);
}
}
return null;
}
function matchWithParts(route, url) {
if (!route.path)
return null;
if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== url.value.outlet)
return null;
const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;
if (path === '**') {
const consumedUrl = [];
let u = url;
while (u) {
consumedUrl.push(u.value);
u = first(u.children);
}
const last = consumedUrl[consumedUrl.length - 1];
return new MatchResult(route.component, [], consumedUrl, last.parameters, [], [], PRIMARY_OUTLET, route, last);
}
const m = match(route, url);
if (!m)
return null;
const { consumedUrlSegments, lastSegment, lastParent, positionalParamSegments } = m;
const p = lastSegment.value.parameters;
const posParams = {};
forEach(positionalParamSegments, (v, k) => { posParams[k] = v.path; });
const parameters = merge(p, posParams);
const secondarySubtrees = lastParent ? lastParent.children.slice(1) : [];
const children = route.children ? route.children : [];
const outlet = route.outlet ? route.outlet : PRIMARY_OUTLET;
return new MatchResult(route.component, children, consumedUrlSegments, parameters, lastSegment.children, secondarySubtrees, outlet, route, lastSegment.value);
}
class MatchResult {
constructor(component, children, consumedUrlSegments, parameters, leftOverUrl, secondary, outlet, route, lastUrlSegment) {
this.component = component;
this.children = children;
this.consumedUrlSegments = consumedUrlSegments;
this.parameters = parameters;
this.leftOverUrl = leftOverUrl;
this.secondary = secondary;
this.outlet = outlet;
this.route = route;
this.lastUrlSegment = lastUrlSegment;
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recognize.js","sourceRoot":"","sources":["../../src/recognize.ts"],"names":[],"mappings":"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","sourcesContent":["import {Type} from '@angular/core';\nimport {Observable} from 'rxjs/Observable';\nimport {of } from 'rxjs/observable/of';\n\nimport {match} from './apply_redirects';\nimport {Route, RouterConfig} from './config';\nimport {ActivatedRouteSnapshot, RouterStateSnapshot} from './router_state';\nimport {PRIMARY_OUTLET} from './shared';\nimport {UrlSegment, UrlTree} from './url_tree';\nimport {first, flatten, forEach, merge} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nclass CannotRecognize {}\n\nexport function recognize(\n    rootComponentType: Type, config: RouterConfig, url: UrlTree): Observable<RouterStateSnapshot> {\n  try {\n    const match = new MatchResult(\n        rootComponentType, config, [url.root], {}, url._root.children, [], PRIMARY_OUTLET, null,\n        url.root);\n    const roots = constructActivatedRoute(match);\n    return of (new RouterStateSnapshot(roots[0], url.queryParams, url.fragment));\n  } catch (e) {\n    if (e instanceof CannotRecognize) {\n      return new Observable<RouterStateSnapshot>(\n          obs => obs.error(new Error('Cannot match any routes')));\n    } else {\n      return new Observable<RouterStateSnapshot>(obs => obs.error(e));\n    }\n  }\n}\n\nfunction constructActivatedRoute(match: MatchResult): TreeNode<ActivatedRouteSnapshot>[] {\n  const activatedRoute = createActivatedRouteSnapshot(match);\n  const children = match.leftOverUrl.length > 0 ?\n      recognizeMany(match.children, match.leftOverUrl) :\n      recognizeLeftOvers(match.children, match.lastUrlSegment);\n  checkOutletNameUniqueness(children);\n  children.sort((a, b) => {\n    if (a.value.outlet === PRIMARY_OUTLET) return -1;\n    if (b.value.outlet === PRIMARY_OUTLET) return 1;\n    return a.value.outlet.localeCompare(b.value.outlet);\n  });\n  return [new TreeNode<ActivatedRouteSnapshot>(activatedRoute, children)];\n}\n\nfunction recognizeLeftOvers(\n    config: Route[], lastUrlSegment: UrlSegment): TreeNode<ActivatedRouteSnapshot>[] {\n  if (!config) return [];\n  const mIndex = matchIndex(config, [], lastUrlSegment);\n  return mIndex ? constructActivatedRoute(mIndex) : [];\n}\n\nfunction recognizeMany(\n    config: Route[], urls: TreeNode<UrlSegment>[]): TreeNode<ActivatedRouteSnapshot>[] {\n  return flatten(urls.map(url => recognizeOne(config, url)));\n}\n\nfunction createActivatedRouteSnapshot(match: MatchResult): ActivatedRouteSnapshot {\n  return new ActivatedRouteSnapshot(\n      match.consumedUrlSegments, match.parameters, match.outlet, match.component, match.route,\n      match.lastUrlSegment);\n}\n\nfunction recognizeOne(\n    config: Route[], url: TreeNode<UrlSegment>): TreeNode<ActivatedRouteSnapshot>[] {\n  const matches = matchNode(config, url);\n  for (let match of matches) {\n    try {\n      const primary = constructActivatedRoute(match);\n      const secondary = recognizeMany(config, match.secondary);\n      const res = primary.concat(secondary);\n      checkOutletNameUniqueness(res);\n      return res;\n    } catch (e) {\n      if (!(e instanceof CannotRecognize)) {\n        throw e;\n      }\n    }\n  }\n  throw new CannotRecognize();\n}\n\nfunction checkOutletNameUniqueness(nodes: TreeNode<ActivatedRouteSnapshot>[]):\n    TreeNode<ActivatedRouteSnapshot>[] {\n  let names = {};\n  nodes.forEach(n => {\n    let routeWithSameOutletName = names[n.value.outlet];\n    if (routeWithSameOutletName) {\n      const p = routeWithSameOutletName.urlSegments.map(s => s.toString()).join('/');\n      const c = n.value.urlSegments.map(s => s.toString()).join('/');\n      throw new Error(`Two segments cannot have the same outlet name: '${p}' and '${c}'.`);\n    }\n    names[n.value.outlet] = n.value;\n  });\n  return nodes;\n}\n\nfunction matchNode(config: Route[], url: TreeNode<UrlSegment>): MatchResult[] {\n  const res = [];\n  for (let r of config) {\n    const m = matchWithParts(r, url);\n    if (m) {\n      res.push(m);\n    } else if (r.index) {\n      res.push(createIndexMatch(r, [url], url.value));\n    }\n  }\n  return res;\n}\n\nfunction createIndexMatch(\n    r: Route, leftOverUrls: TreeNode<UrlSegment>[], lastUrlSegment: UrlSegment): MatchResult {\n  const outlet = r.outlet ? r.outlet : PRIMARY_OUTLET;\n  const children = r.children ? r.children : [];\n  return new MatchResult(\n      r.component, children, [], lastUrlSegment.parameters, leftOverUrls, [], outlet, r,\n      lastUrlSegment);\n}\n\nfunction matchIndex(\n    config: Route[], leftOverUrls: TreeNode<UrlSegment>[], lastUrlSegment: UrlSegment): MatchResult|\n    null {\n  for (let r of config) {\n    if (r.index) {\n      return createIndexMatch(r, leftOverUrls, lastUrlSegment);\n    }\n  }\n  return null;\n}\n\nfunction matchWithParts(route: Route, url: TreeNode<UrlSegment>): MatchResult|null {\n  if (!route.path) return null;\n  if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== url.value.outlet) return null;\n\n  const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;\n  if (path === '**') {\n    const consumedUrl = [];\n    let u: TreeNode<UrlSegment>|null = url;\n    while (u) {\n      consumedUrl.push(u.value);\n      u = first(u.children);\n    }\n    const last = consumedUrl[consumedUrl.length - 1];\n    return new MatchResult(\n        route.component, [], consumedUrl, last.parameters, [], [], PRIMARY_OUTLET, route, last);\n  }\n\n  const m = match(route, url);\n  if (!m) return null;\n  const {consumedUrlSegments, lastSegment, lastParent, positionalParamSegments} = m;\n\n  const p = lastSegment.value.parameters;\n  const posParams = {};\n  forEach(positionalParamSegments, (v, k) => { posParams[k] = v.path; });\n  const parameters = <{[key: string]: string}>merge(p, posParams);\n  const secondarySubtrees = lastParent ? lastParent.children.slice(1) : [];\n  const children = route.children ? route.children : [];\n  const outlet = route.outlet ? route.outlet : PRIMARY_OUTLET;\n\n  return new MatchResult(\n      route.component, children, consumedUrlSegments, parameters, lastSegment.children,\n      secondarySubtrees, outlet, route, lastSegment.value);\n}\n\nclass MatchResult {\n  constructor(\n      public component: Type|string, public children: Route[],\n      public consumedUrlSegments: UrlSegment[], public parameters: {[key: string]: string},\n      public leftOverUrl: TreeNode<UrlSegment>[], public secondary: TreeNode<UrlSegment>[],\n      public outlet: string, public route: Route|null, public lastUrlSegment: UrlSegment) {}\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recognize.js","sourceRoot":"","sources":["../../src/recognize.ts"],"names":[],"mappings":"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","sourcesContent":["import {Type} from '@angular/core';\nimport {Observable} from 'rxjs/Observable';\nimport {of } from 'rxjs/observable/of';\n\nimport {Route, RouterConfig} from './config';\nimport {ActivatedRouteSnapshot, RouterStateSnapshot} from './router_state';\nimport {PRIMARY_OUTLET} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree, mapChildrenIntoArray} from './url_tree';\nimport {last, merge} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nclass NoMatch {\n  constructor(public segment: UrlSegment = null) {}\n}\n\nexport function recognize(\n    rootComponentType: Type, config: RouterConfig, urlTree: UrlTree,\n    url: string): Observable<RouterStateSnapshot> {\n  try {\n    const children = processSegment(config, urlTree.root, PRIMARY_OUTLET);\n    const root = new ActivatedRouteSnapshot(\n        [], {}, PRIMARY_OUTLET, rootComponentType, null, urlTree.root, -1);\n    const rootNode = new TreeNode<ActivatedRouteSnapshot>(root, children);\n    return of (new RouterStateSnapshot(url, rootNode, urlTree.queryParams, urlTree.fragment));\n  } catch (e) {\n    if (e instanceof NoMatch) {\n      return new Observable<RouterStateSnapshot>(\n          obs => obs.error(new Error(`Cannot match any routes: '${e.segment}'`)));\n    } else {\n      return new Observable<RouterStateSnapshot>(obs => obs.error(e));\n    }\n  }\n}\n\nfunction processSegment(\n    config: Route[], segment: UrlSegment, outlet: string): TreeNode<ActivatedRouteSnapshot>[] {\n  if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {\n    return processSegmentChildren(config, segment);\n  } else {\n    return [processPathsWithParams(config, segment, 0, segment.pathsWithParams, outlet)];\n  }\n}\n\nfunction processSegmentChildren(\n    config: Route[], segment: UrlSegment): TreeNode<ActivatedRouteSnapshot>[] {\n  const children = mapChildrenIntoArray(\n      segment, (child, childOutlet) => processSegment(config, child, childOutlet));\n  checkOutletNameUniqueness(children);\n  sortActivatedRouteSnapshots(children);\n  return children;\n}\n\nfunction sortActivatedRouteSnapshots(nodes: TreeNode<ActivatedRouteSnapshot>[]): void {\n  nodes.sort((a, b) => {\n    if (a.value.outlet === PRIMARY_OUTLET) return -1;\n    if (b.value.outlet === PRIMARY_OUTLET) return 1;\n    return a.value.outlet.localeCompare(b.value.outlet);\n  });\n}\n\nfunction processPathsWithParams(\n    config: Route[], segment: UrlSegment, pathIndex: number, paths: UrlPathWithParams[],\n    outlet: string): TreeNode<ActivatedRouteSnapshot> {\n  for (let r of config) {\n    try {\n      return processPathsWithParamsAgainstRoute(r, segment, pathIndex, paths, outlet);\n    } catch (e) {\n      if (!(e instanceof NoMatch)) throw e;\n    }\n  }\n  throw new NoMatch(segment);\n}\n\nfunction processPathsWithParamsAgainstRoute(\n    route: Route, segment: UrlSegment, pathIndex: number, paths: UrlPathWithParams[],\n    outlet: string): TreeNode<ActivatedRouteSnapshot> {\n  if (route.redirectTo) throw new NoMatch();\n  if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== outlet) throw new NoMatch();\n\n  if (route.path === '**') {\n    const params = paths.length > 0 ? last(paths).parameters : {};\n    const snapshot =\n        new ActivatedRouteSnapshot(paths, params, outlet, route.component, route, segment, -1);\n    return new TreeNode<ActivatedRouteSnapshot>(snapshot, []);\n  }\n\n  const {consumedPaths, parameters, lastChild} = match(segment, route, paths);\n\n  const snapshot = new ActivatedRouteSnapshot(\n      consumedPaths, parameters, outlet, route.component, route, segment,\n      pathIndex + lastChild - 1);\n  const slicedPath = paths.slice(lastChild);\n  const childConfig = route.children ? route.children : [];\n\n  if (childConfig.length === 0 && slicedPath.length === 0) {\n    return new TreeNode<ActivatedRouteSnapshot>(snapshot, []);\n\n    // TODO: check that the right segment is present\n  } else if (slicedPath.length === 0 && Object.keys(segment.children).length > 0) {\n    const children = processSegmentChildren(childConfig, segment);\n    return new TreeNode<ActivatedRouteSnapshot>(snapshot, children);\n\n  } else {\n    const child = processPathsWithParams(\n        childConfig, segment, pathIndex + lastChild, slicedPath, PRIMARY_OUTLET);\n    return new TreeNode<ActivatedRouteSnapshot>(snapshot, [child]);\n  }\n}\n\nfunction match(segment: UrlSegment, route: Route, paths: UrlPathWithParams[]) {\n  if (route.index || route.path === '' || route.path === '/') {\n    if (route.terminal && (Object.keys(segment.children).length > 0 || paths.length > 0)) {\n      throw new NoMatch();\n    } else {\n      return {consumedPaths: [], lastChild: 0, parameters: {}};\n    }\n  }\n\n  const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;\n  const parts = path.split('/');\n  const posParameters: {[key: string]: any} = {};\n  const consumedPaths = [];\n\n  let currentIndex = 0;\n\n  for (let i = 0; i < parts.length; ++i) {\n    if (currentIndex >= paths.length) throw new NoMatch();\n    const current = paths[currentIndex];\n\n    const p = parts[i];\n    const isPosParam = p.startsWith(':');\n\n    if (!isPosParam && p !== current.path) throw new NoMatch();\n    if (isPosParam) {\n      posParameters[p.substring(1)] = current.path;\n    }\n    consumedPaths.push(current);\n    currentIndex++;\n  }\n\n  if (route.terminal && (Object.keys(segment.children).length > 0 || currentIndex < paths.length)) {\n    throw new NoMatch();\n  }\n\n  const parameters = merge(posParameters, consumedPaths[consumedPaths.length - 1].parameters);\n  return {consumedPaths, lastChild: currentIndex, parameters};\n}\n\nfunction checkOutletNameUniqueness(nodes: TreeNode<ActivatedRouteSnapshot>[]): void {\n  const names = {};\n  nodes.forEach(n => {\n    let routeWithSameOutletName = names[n.value.outlet];\n    if (routeWithSameOutletName) {\n      const p = routeWithSameOutletName.urlSegments.map(s => s.toString()).join('/');\n      const c = n.value.url.map(s => s.toString()).join('/');\n      throw new Error(`Two segments cannot have the same outlet name: '${p}' and '${c}'.`);\n    }\n    names[n.value.outlet] = n.value;\n  });\n}"]}

@@ -0,2 +1,3 @@

import * as common from './common_router_providers';
import { RouterConfig } from './config';
export declare function provideRouter(config: RouterConfig): any[];
export declare function provideRouter(config: RouterConfig, opts?: common.ExtraOptions): any[];
import { PlatformLocation } from '@angular/common';
import { BrowserPlatformLocation } from '@angular/platform-browser';
import * as common from './common_router_providers';
export function provideRouter(config) {
export function provideRouter(config, opts = {}) {
return [
{ provide: PlatformLocation, useClass: BrowserPlatformLocation }, ...common.provideRouter(config)
{ provide: PlatformLocation, useClass: BrowserPlatformLocation },
...common.provideRouter(config, opts)
];
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyX3Byb3ZpZGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yb3V0ZXJfcHJvdmlkZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxpQkFBaUI7T0FDekMsRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDJCQUEyQjtPQUUxRCxLQUFLLE1BQU0sTUFBTSwyQkFBMkI7QUFzQm5ELDhCQUE4QixNQUFvQjtJQUNoRCxNQUFNLENBQUM7UUFDTCxFQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsdUJBQXVCLEVBQUMsRUFBRSxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDO0tBQ2hHLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtQbGF0Zm9ybUxvY2F0aW9ufSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtCcm93c2VyUGxhdGZvcm1Mb2NhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5cbmltcG9ydCAqIGFzIGNvbW1vbiBmcm9tICcuL2NvbW1vbl9yb3V0ZXJfcHJvdmlkZXJzJztcbmltcG9ydCB7Um91dGVyQ29uZmlnfSBmcm9tICcuL2NvbmZpZyc7XG5cblxuLyoqXG4gKiBBIGxpc3Qgb2Yge0BsaW5rIFByb3ZpZGVyfXMuIFRvIHVzZSB0aGUgcm91dGVyLCB5b3UgbXVzdCBhZGQgdGhpcyB0byB5b3VyIGFwcGxpY2F0aW9uLlxuICpcbiAqICMjIyBFeGFtcGxlXG4gKlxuICogYGBgXG4gKiBAQ29tcG9uZW50KHtkaXJlY3RpdmVzOiBbUk9VVEVSX0RJUkVDVElWRVNdfSlcbiAqIGNsYXNzIEFwcENtcCB7XG4gKiAgIC8vIC4uLlxuICogfVxuICpcbiAqIGNvbnN0IHJvdXRlciA9IFtcbiAqICAge3BhdGg6ICcvaG9tZScsIGNvbXBvbmVudDogSG9tZX1cbiAqIF07XG4gKlxuICogYm9vdHN0cmFwKEFwcENtcCwgW3Byb3ZpZGVSb3V0ZXIocm91dGVyKV0pO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlUm91dGVyKGNvbmZpZzogUm91dGVyQ29uZmlnKTogYW55W10ge1xuICByZXR1cm4gW1xuICAgIHtwcm92aWRlOiBQbGF0Zm9ybUxvY2F0aW9uLCB1c2VDbGFzczogQnJvd3NlclBsYXRmb3JtTG9jYXRpb259LCAuLi5jb21tb24ucHJvdmlkZVJvdXRlcihjb25maWcpXG4gIF07XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyX3Byb3ZpZGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yb3V0ZXJfcHJvdmlkZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxpQkFBaUI7T0FDekMsRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDJCQUEyQjtPQUUxRCxLQUFLLE1BQU0sTUFBTSwyQkFBMkI7QUFzQm5ELDhCQUE4QixNQUFvQixFQUFFLElBQUksR0FBd0IsRUFBRTtJQUNoRixNQUFNLENBQUM7UUFDTCxFQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsdUJBQXVCLEVBQUM7UUFDOUQsR0FBRyxNQUFNLENBQUMsYUFBYSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUM7S0FDdEMsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1BsYXRmb3JtTG9jYXRpb259IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0Jyb3dzZXJQbGF0Zm9ybUxvY2F0aW9ufSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcblxuaW1wb3J0ICogYXMgY29tbW9uIGZyb20gJy4vY29tbW9uX3JvdXRlcl9wcm92aWRlcnMnO1xuaW1wb3J0IHtSb3V0ZXJDb25maWd9IGZyb20gJy4vY29uZmlnJztcblxuXG4vKipcbiAqIEEgbGlzdCBvZiB7QGxpbmsgUHJvdmlkZXJ9cy4gVG8gdXNlIHRoZSByb3V0ZXIsIHlvdSBtdXN0IGFkZCB0aGlzIHRvIHlvdXIgYXBwbGljYXRpb24uXG4gKlxuICogIyMjIEV4YW1wbGVcbiAqXG4gKiBgYGBcbiAqIEBDb21wb25lbnQoe2RpcmVjdGl2ZXM6IFtST1VURVJfRElSRUNUSVZFU119KVxuICogY2xhc3MgQXBwQ21wIHtcbiAqICAgLy8gLi4uXG4gKiB9XG4gKlxuICogY29uc3Qgcm91dGVyID0gW1xuICogICB7cGF0aDogJy9ob21lJywgY29tcG9uZW50OiBIb21lfVxuICogXTtcbiAqXG4gKiBib290c3RyYXAoQXBwQ21wLCBbcHJvdmlkZVJvdXRlcihyb3V0ZXIpXSk7XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVSb3V0ZXIoY29uZmlnOiBSb3V0ZXJDb25maWcsIG9wdHM6IGNvbW1vbi5FeHRyYU9wdGlvbnMgPSB7fSk6IGFueVtdIHtcbiAgcmV0dXJuIFtcbiAgICB7cHJvdmlkZTogUGxhdGZvcm1Mb2NhdGlvbiwgdXNlQ2xhc3M6IEJyb3dzZXJQbGF0Zm9ybUxvY2F0aW9ufSxcbiAgICAuLi5jb21tb24ucHJvdmlkZVJvdXRlcihjb25maWcsIG9wdHMpXG4gIF07XG59XG4iXX0=

@@ -5,3 +5,3 @@ import { ComponentFactory, Type } from '@angular/core';

import { Params } from './shared';
import { UrlSegment } from './url_tree';
import { UrlPathWithParams, UrlSegment, UrlTree } from './url_tree';
import { Tree, TreeNode } from './utils/tree';

@@ -13,6 +13,7 @@ export declare class RouterState extends Tree<ActivatedRoute> {

constructor(root: TreeNode<ActivatedRoute>, queryParams: Observable<Params>, fragment: Observable<string>, snapshot: RouterStateSnapshot);
toString(): string;
}
export declare function createEmptyState(rootComponent: Type): RouterState;
export declare function createEmptyState(urlTree: UrlTree, rootComponent: Type): RouterState;
export declare class ActivatedRoute {
urlSegments: Observable<UrlSegment[]>;
url: Observable<UrlPathWithParams[]>;
params: Observable<Params>;

@@ -23,6 +24,7 @@ outlet: string;

snapshot: ActivatedRouteSnapshot;
constructor(urlSegments: Observable<UrlSegment[]>, params: Observable<Params>, outlet: string, component: Type | string, futureSnapshot: ActivatedRouteSnapshot);
constructor(url: Observable<UrlPathWithParams[]>, params: Observable<Params>, outlet: string, component: Type | string, futureSnapshot: ActivatedRouteSnapshot);
toString(): string;
}
export declare class ActivatedRouteSnapshot {
urlSegments: UrlSegment[];
url: UrlPathWithParams[];
params: Params;

@@ -32,11 +34,15 @@ outlet: string;

_resolvedComponentFactory: ComponentFactory<any>;
_routeConfig: Route | null;
_lastUrlSegment: UrlSegment;
constructor(urlSegments: UrlSegment[], params: Params, outlet: string, component: Type | string, routeConfig: Route | null, lastUrlSegment: UrlSegment);
_routeConfig: Route;
_urlSegment: UrlSegment;
_lastPathIndex: number;
constructor(url: UrlPathWithParams[], params: Params, outlet: string, component: Type | string, routeConfig: Route, urlSegment: UrlSegment, lastPathIndex: number);
toString(): string;
}
export declare class RouterStateSnapshot extends Tree<ActivatedRouteSnapshot> {
url: string;
queryParams: Params;
fragment: string | null;
constructor(root: TreeNode<ActivatedRouteSnapshot>, queryParams: Params, fragment: string | null);
fragment: string;
constructor(url: string, root: TreeNode<ActivatedRouteSnapshot>, queryParams: Params, fragment: string);
toString(): string;
}
export declare function advanceActivatedRoute(route: ActivatedRoute): void;
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
import { PRIMARY_OUTLET } from './shared';
import { UrlSegment } from './url_tree';
import { UrlPathWithParams } from './url_tree';
import { shallowEqual } from './utils/collection';

@@ -13,6 +13,7 @@ import { Tree, TreeNode } from './utils/tree';

}
toString() { return this.snapshot.toString(); }
}
export function createEmptyState(rootComponent) {
const snapshot = createEmptyStateSnapshot(rootComponent);
const emptyUrl = new BehaviorSubject([new UrlSegment('', {}, PRIMARY_OUTLET)]);
export function createEmptyState(urlTree, rootComponent) {
const snapshot = createEmptyStateSnapshot(urlTree, rootComponent);
const emptyUrl = new BehaviorSubject([new UrlPathWithParams('', {})]);
const emptyParams = new BehaviorSubject({});

@@ -25,14 +26,12 @@ const emptyQueryParams = new BehaviorSubject({});

}
function createEmptyStateSnapshot(rootComponent) {
const rootUrlSegment = new UrlSegment('', {}, PRIMARY_OUTLET);
const emptyUrl = [rootUrlSegment];
function createEmptyStateSnapshot(urlTree, rootComponent) {
const emptyParams = {};
const emptyQueryParams = {};
const fragment = '';
const activated = new ActivatedRouteSnapshot(emptyUrl, emptyParams, PRIMARY_OUTLET, rootComponent, null, rootUrlSegment);
return new RouterStateSnapshot(new TreeNode(activated, []), emptyQueryParams, fragment);
const activated = new ActivatedRouteSnapshot([], emptyParams, PRIMARY_OUTLET, rootComponent, null, urlTree.root, -1);
return new RouterStateSnapshot('', new TreeNode(activated, []), emptyQueryParams, fragment);
}
export class ActivatedRoute {
constructor(urlSegments, params, outlet, component, futureSnapshot) {
this.urlSegments = urlSegments;
constructor(url, params, outlet, component, futureSnapshot) {
this.url = url;
this.params = params;

@@ -43,6 +42,9 @@ this.outlet = outlet;

}
toString() {
return this.snapshot ? this.snapshot.toString() : `Future(${this._futureSnapshot})`;
}
}
export class ActivatedRouteSnapshot {
constructor(urlSegments, params, outlet, component, routeConfig, lastUrlSegment) {
this.urlSegments = urlSegments;
constructor(url, params, outlet, component, routeConfig, urlSegment, lastPathIndex) {
this.url = url;
this.params = params;

@@ -52,16 +54,28 @@ this.outlet = outlet;

this._routeConfig = routeConfig;
this._lastUrlSegment = lastUrlSegment;
this._urlSegment = urlSegment;
this._lastPathIndex = lastPathIndex;
}
toString() {
const url = this.url.map(s => s.toString()).join('/');
const matched = this._routeConfig ? this._routeConfig.path : '';
return `Route(url:'${url}', path:'${matched}')`;
}
}
export class RouterStateSnapshot extends Tree {
constructor(root, queryParams, fragment) {
constructor(url, root, queryParams, fragment) {
super(root);
this.url = url;
this.queryParams = queryParams;
this.fragment = fragment;
}
toString() { return serializeNode(this._root); }
}
function serializeNode(node) {
const c = node.children.length > 0 ? ` { ${node.children.map(serializeNode).join(", ")} } ` : '';
return `${node.value}${c}`;
}
export function advanceActivatedRoute(route) {
if (route.snapshot && !shallowEqual(route.snapshot.params, route._futureSnapshot.params)) {
route.snapshot = route._futureSnapshot;
route.urlSegments.next(route.snapshot.urlSegments);
route.url.next(route.snapshot.url);
route.params.next(route.snapshot.params);

@@ -73,2 +87,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_state.js","sourceRoot":"","sources":["../../src/router_state.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentFactory, Type} from '@angular/core';\nimport {BehaviorSubject} from 'rxjs/BehaviorSubject';\nimport {Observable} from 'rxjs/Observable';\n\nimport {Route} from './config';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlSegment} from './url_tree';\nimport {shallowEqual} from './utils/collection';\nimport {Tree, TreeNode} from './utils/tree';\n\n\n/**\n * The state of the router.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(router: Router) {\n *     const state = router.routerState;\n *     const id: Observable<string> = state.firstChild(state.root).params.map(p => p.id);\n *     const isDebug: Observable<string> = state.queryParams.map(q => q.debug);\n *   }\n * }\n * ```\n */\nexport class RouterState extends Tree<ActivatedRoute> {\n  /**\n   * @internal\n   */\n  constructor(\n      root: TreeNode<ActivatedRoute>, public queryParams: Observable<Params>,\n      public fragment: Observable<string>, public snapshot: RouterStateSnapshot) {\n    super(root);\n  }\n}\n\nexport function createEmptyState(rootComponent: Type): RouterState {\n  const snapshot = createEmptyStateSnapshot(rootComponent);\n  const emptyUrl = new BehaviorSubject([new UrlSegment('', {}, PRIMARY_OUTLET)]);\n  const emptyParams = new BehaviorSubject({});\n  const emptyQueryParams = new BehaviorSubject({});\n  const fragment = new BehaviorSubject('');\n  const activated =\n      new ActivatedRoute(emptyUrl, emptyParams, PRIMARY_OUTLET, rootComponent, snapshot.root);\n  activated.snapshot = snapshot.root;\n  return new RouterState(\n      new TreeNode<ActivatedRoute>(activated, []), emptyQueryParams, fragment, snapshot);\n}\n\nfunction createEmptyStateSnapshot(rootComponent: Type): RouterStateSnapshot {\n  const rootUrlSegment = new UrlSegment('', {}, PRIMARY_OUTLET);\n  const emptyUrl = [rootUrlSegment];\n  const emptyParams = {};\n  const emptyQueryParams = {};\n  const fragment = '';\n  const activated = new ActivatedRouteSnapshot(\n      emptyUrl, emptyParams, PRIMARY_OUTLET, rootComponent, null, rootUrlSegment);\n  return new RouterStateSnapshot(\n      new TreeNode<ActivatedRouteSnapshot>(activated, []), emptyQueryParams, fragment);\n}\n\n/**\n * Contains the information about a component loaded in an outlet. The information is provided\n * through\n * the params and urlSegments observables.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: Observable<string> = route.params.map(p => p.id);\n *   }\n * }\n * ```\n */\nexport class ActivatedRoute {\n  /** @internal */\n  _futureSnapshot: ActivatedRouteSnapshot;\n  snapshot: ActivatedRouteSnapshot;\n\n  /**\n   * @internal\n   */\n  constructor(\n      public urlSegments: Observable<UrlSegment[]>, public params: Observable<Params>,\n      public outlet: string, public component: Type|string,\n      futureSnapshot: ActivatedRouteSnapshot) {\n    this._futureSnapshot = futureSnapshot;\n  }\n}\n\n/**\n * Contains the information about a component loaded in an outlet at a particular moment in time.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: string = route.snapshot.params.id;\n *   }\n * }\n * ```\n */\nexport class ActivatedRouteSnapshot {\n  /**\n   * @internal\n   */\n  _resolvedComponentFactory: ComponentFactory<any>;\n\n  /** @internal **/\n  _routeConfig: Route|null;\n\n  /** @internal **/\n  _lastUrlSegment: UrlSegment;\n\n  /**\n   * @internal\n   */\n  constructor(\n      public urlSegments: UrlSegment[], public params: Params, public outlet: string,\n      public component: Type|string, routeConfig: Route|null, lastUrlSegment: UrlSegment) {\n    this._routeConfig = routeConfig;\n    this._lastUrlSegment = lastUrlSegment;\n  }\n}\n\n/**\n * The state of the router at a particular moment in time.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(router: Router) {\n *     const snapshot = router.routerState.snapshot;\n *   }\n * }\n * ```\n */\nexport class RouterStateSnapshot extends Tree<ActivatedRouteSnapshot> {\n  /**\n   * @internal\n   */\n  constructor(\n      root: TreeNode<ActivatedRouteSnapshot>, public queryParams: Params,\n      public fragment: string|null) {\n    super(root);\n  }\n}\n\n/**\n * The expectation is that the activate route is created with the right set of parameters.\n * So we push new values into the observables only when they are not the initial values.\n * And we detect that by checking if the snapshot field is set.\n */\nexport function advanceActivatedRoute(route: ActivatedRoute): void {\n  if (route.snapshot && !shallowEqual(route.snapshot.params, route._futureSnapshot.params)) {\n    route.snapshot = route._futureSnapshot;\n    (<any>route.urlSegments).next(route.snapshot.urlSegments);\n    (<any>route.params).next(route.snapshot.params);\n  } else {\n    route.snapshot = route._futureSnapshot;\n  }\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_state.js","sourceRoot":"","sources":["../../src/router_state.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentFactory, Type} from '@angular/core';\nimport {BehaviorSubject} from 'rxjs/BehaviorSubject';\nimport {Observable} from 'rxjs/Observable';\n\nimport {Route} from './config';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree} from './url_tree';\nimport {shallowEqual} from './utils/collection';\nimport {Tree, TreeNode} from './utils/tree';\n\n\n/**\n * The state of the router.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(router: Router) {\n *     const state = router.routerState;\n *     const id: Observable<string> = state.firstChild(state.root).params.map(p => p.id);\n *     const isDebug: Observable<string> = state.queryParams.map(q => q.debug);\n *   }\n * }\n * ```\n */\nexport class RouterState extends Tree<ActivatedRoute> {\n  /**\n   * @internal\n   */\n  constructor(\n      root: TreeNode<ActivatedRoute>, public queryParams: Observable<Params>,\n      public fragment: Observable<string>, public snapshot: RouterStateSnapshot) {\n    super(root);\n  }\n\n  toString(): string { return this.snapshot.toString(); }\n}\n\nexport function createEmptyState(urlTree: UrlTree, rootComponent: Type): RouterState {\n  const snapshot = createEmptyStateSnapshot(urlTree, rootComponent);\n  const emptyUrl = new BehaviorSubject([new UrlPathWithParams('', {})]);\n  const emptyParams = new BehaviorSubject({});\n  const emptyQueryParams = new BehaviorSubject({});\n  const fragment = new BehaviorSubject('');\n  const activated =\n      new ActivatedRoute(emptyUrl, emptyParams, PRIMARY_OUTLET, rootComponent, snapshot.root);\n  activated.snapshot = snapshot.root;\n  return new RouterState(\n      new TreeNode<ActivatedRoute>(activated, []), emptyQueryParams, fragment, snapshot);\n}\n\nfunction createEmptyStateSnapshot(urlTree: UrlTree, rootComponent: Type): RouterStateSnapshot {\n  const emptyParams = {};\n  const emptyQueryParams = {};\n  const fragment = '';\n  const activated = new ActivatedRouteSnapshot(\n      [], emptyParams, PRIMARY_OUTLET, rootComponent, null, urlTree.root, -1);\n  return new RouterStateSnapshot(\n      '', new TreeNode<ActivatedRouteSnapshot>(activated, []), emptyQueryParams, fragment);\n}\n\n/**\n * Contains the information about a component loaded in an outlet. The information is provided\n * through\n * the params and urlSegments observables.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: Observable<string> = route.params.map(p => p.id);\n *   }\n * }\n * ```\n */\nexport class ActivatedRoute {\n  /** @internal */\n  _futureSnapshot: ActivatedRouteSnapshot;\n  snapshot: ActivatedRouteSnapshot;\n\n  /**\n   * @internal\n   */\n  constructor(\n      public url: Observable<UrlPathWithParams[]>, public params: Observable<Params>,\n      public outlet: string, public component: Type|string,\n      futureSnapshot: ActivatedRouteSnapshot) {\n    this._futureSnapshot = futureSnapshot;\n  }\n\n  toString(): string {\n    return this.snapshot ? this.snapshot.toString() : `Future(${this._futureSnapshot})`;\n  }\n}\n\n/**\n * Contains the information about a component loaded in an outlet at a particular moment in time.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: string = route.snapshot.params.id;\n *   }\n * }\n * ```\n */\nexport class ActivatedRouteSnapshot {\n  /**\n   * @internal\n   */\n  _resolvedComponentFactory: ComponentFactory<any>;\n\n  /** @internal **/\n  _routeConfig: Route;\n\n  /** @internal **/\n  _urlSegment: UrlSegment;\n\n  _lastPathIndex: number;\n\n  /**\n   * @internal\n   */\n  constructor(\n      public url: UrlPathWithParams[], public params: Params, public outlet: string,\n      public component: Type|string, routeConfig: Route, urlSegment: UrlSegment,\n      lastPathIndex: number) {\n    this._routeConfig = routeConfig;\n    this._urlSegment = urlSegment;\n    this._lastPathIndex = lastPathIndex;\n  }\n\n  toString(): string {\n    const url = this.url.map(s => s.toString()).join('/');\n    const matched = this._routeConfig ? this._routeConfig.path : '';\n    return `Route(url:'${url}', path:'${matched}')`;\n  }\n}\n\n/**\n * The state of the router at a particular moment in time.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(router: Router) {\n *     const snapshot = router.routerState.snapshot;\n *   }\n * }\n * ```\n */\nexport class RouterStateSnapshot extends Tree<ActivatedRouteSnapshot> {\n  /**\n   * @internal\n   */\n  constructor(\n      public url: string, root: TreeNode<ActivatedRouteSnapshot>, public queryParams: Params,\n      public fragment: string) {\n    super(root);\n  }\n\n  toString(): string { return serializeNode(this._root); }\n}\n\nfunction serializeNode(node: TreeNode<ActivatedRouteSnapshot>): string {\n  const c = node.children.length > 0 ? ` { ${node.children.map(serializeNode).join(\", \")} } ` : '';\n  return `${node.value}${c}`;\n}\n\n\n/**\n * The expectation is that the activate route is created with the right set of parameters.\n * So we push new values into the observables only when they are not the initial values.\n * And we detect that by checking if the snapshot field is set.\n */\nexport function advanceActivatedRoute(route: ActivatedRoute): void {\n  if (route.snapshot && !shallowEqual(route.snapshot.params, route._futureSnapshot.params)) {\n    route.snapshot = route._futureSnapshot;\n    (<any>route.url).next(route.snapshot.url);\n    (<any>route.params).next(route.snapshot.params);\n  } else {\n    route.snapshot = route._futureSnapshot;\n  }\n}"]}

@@ -14,3 +14,3 @@ import 'rxjs/add/operator/map';

import { RouterOutletMap } from './router_outlet_map';
import { ActivatedRoute, RouterState } from './router_state';
import { ActivatedRoute, RouterState, RouterStateSnapshot } from './router_state';
import { Params } from './shared';

@@ -26,21 +26,34 @@ import { UrlSerializer } from './url_serializer';

id: number;
url: UrlTree;
constructor(id: number, url: UrlTree);
url: string;
constructor(id: number, url: string);
toString(): string;
}
export declare class NavigationEnd {
id: number;
url: UrlTree;
constructor(id: number, url: UrlTree);
url: string;
urlAfterRedirects: string;
constructor(id: number, url: string, urlAfterRedirects: string);
toString(): string;
}
export declare class NavigationCancel {
id: number;
url: UrlTree;
constructor(id: number, url: UrlTree);
url: string;
constructor(id: number, url: string);
toString(): string;
}
export declare class NavigationError {
id: number;
url: UrlTree;
url: string;
error: any;
constructor(id: number, url: UrlTree, error: any);
constructor(id: number, url: string, error: any);
toString(): string;
}
export declare class RoutesRecognized {
id: number;
url: string;
urlAfterRedirects: string;
state: RouterStateSnapshot;
constructor(id: number, url: string, urlAfterRedirects: string, state: RouterStateSnapshot);
toString(): string;
}
export declare type Event = NavigationStart | NavigationEnd | NavigationCancel | NavigationError;

@@ -62,5 +75,5 @@ export declare class Router {

initialNavigation(): void;
readonly routerState: RouterState;
readonly urlTree: UrlTree;
readonly events: Observable<Event>;
routerState: RouterState;
url: string;
events: Observable<Event>;
navigateByUrl(url: string): Promise<boolean>;

@@ -67,0 +80,0 @@ resetConfig(config: RouterConfig): void;

@@ -28,8 +28,13 @@ import 'rxjs/add/operator/map';

}
toString() { return `NavigationStart(id: ${this.id}, url: '${this.url}')`; }
}
export class NavigationEnd {
constructor(id, url) {
constructor(id, url, urlAfterRedirects) {
this.id = id;
this.url = url;
this.urlAfterRedirects = urlAfterRedirects;
}
toString() {
return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}')`;
}
}

@@ -41,2 +46,3 @@ export class NavigationCancel {

}
toString() { return `NavigationCancel(id: ${this.id}, url: '${this.url}')`; }
}

@@ -49,3 +55,17 @@ export class NavigationError {

}
toString() {
return `NavigationError(id: ${this.id}, url: '${this.url}', error: ${this.error})`;
}
}
export class RoutesRecognized {
constructor(id, url, urlAfterRedirects, state) {
this.id = id;
this.url = url;
this.urlAfterRedirects = urlAfterRedirects;
this.state = state;
}
toString() {
return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;
}
}
export class Router {

@@ -63,3 +83,3 @@ constructor(rootComponentType, resolver, urlSerializer, outletMap, location, injector, config) {

this.currentUrlTree = createEmptyUrlTree();
this.currentRouterState = createEmptyState(this.rootComponentType);
this.currentRouterState = createEmptyState(this.currentUrlTree, this.rootComponentType);
}

@@ -71,3 +91,3 @@ initialNavigation() {

get routerState() { return this.currentRouterState; }
get urlTree() { return this.currentUrlTree; }
get url() { return this.serializeUrl(this.currentUrlTree); }
get events() { return this.routerEvents; }

@@ -91,3 +111,3 @@ navigateByUrl(url) {

const id = ++this.navigationId;
this.routerEvents.next(new NavigationStart(id, url));
this.routerEvents.next(new NavigationStart(id, this.serializeUrl(url)));
return Promise.resolve().then((_) => this.runNavigate(url, false, id));

@@ -103,3 +123,3 @@ }

this.location.go(this.urlSerializer.serialize(this.currentUrlTree));
this.routerEvents.next(new NavigationCancel(id, url));
this.routerEvents.next(new NavigationCancel(id, this.serializeUrl(url)));
return Promise.resolve(false);

@@ -113,5 +133,6 @@ }

updatedUrl = u;
return recognize(this.rootComponentType, this.config, updatedUrl);
return recognize(this.rootComponentType, this.config, updatedUrl, this.serializeUrl(updatedUrl));
})
.mergeMap((newRouterStateSnapshot) => {
this.routerEvents.next(new RoutesRecognized(id, this.serializeUrl(url), this.serializeUrl(updatedUrl), newRouterStateSnapshot));
return resolve(this.resolver, newRouterStateSnapshot);

@@ -132,7 +153,7 @@ })

this.location.go(this.urlSerializer.serialize(this.currentUrlTree));
this.routerEvents.next(new NavigationCancel(id, url));
this.routerEvents.next(new NavigationCancel(id, this.serializeUrl(url)));
return Promise.resolve(false);
}
new ActivateRoutes(state, this.currentRouterState).activate(this.outletMap);
this.currentUrlTree = url;
this.currentUrlTree = updatedUrl;
this.currentRouterState = state;

@@ -144,6 +165,6 @@ if (!pop) {

.then(() => {
this.routerEvents.next(new NavigationEnd(id, url));
this.routerEvents.next(new NavigationEnd(id, this.serializeUrl(url), this.serializeUrl(updatedUrl)));
resolvePromise(true);
}, e => {
this.routerEvents.next(new NavigationError(id, url, e));
this.routerEvents.next(new NavigationError(id, this.serializeUrl(url), e));
rejectPromise(e);

@@ -219,3 +240,7 @@ });

if (outlet && outlet.isActivated) {
forEach(outlet.outletMap._outlets, (v, k) => this.deactivateOutletAndItChildren(v.activatedRoute.snapshot, v));
forEach(outlet.outletMap._outlets, (v, k) => {
if (v.isActivated) {
this.deactivateOutletAndItChildren(v.activatedRoute.snapshot, v);
}
});
this.checks.push(new CanDeactivate(outlet.component, route));

@@ -333,7 +358,8 @@ }

if (!outlet) {
const componentName = route.component.name;
if (route.outlet === PRIMARY_OUTLET) {
throw new Error(`Cannot find primary outlet`);
throw new Error(`Cannot find primary outlet to load '${componentName}'`);
}
else {
throw new Error(`Cannot find the outlet ${route.outlet}`);
throw new Error(`Cannot find the outlet ${route.outlet} to load '${componentName}'`);
}

@@ -343,2 +369,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router.js","sourceRoot":"","sources":["../../src/router.ts"],"names":[],"mappings":"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","sourcesContent":["import 'rxjs/add/operator/map';\nimport 'rxjs/add/operator/scan';\nimport 'rxjs/add/operator/mergeMap';\nimport 'rxjs/add/operator/concat';\nimport 'rxjs/add/operator/concatMap';\nimport 'rxjs/add/operator/every';\nimport 'rxjs/add/operator/mergeAll';\nimport 'rxjs/add/observable/from';\n\nimport {Location} from '@angular/common';\nimport {ComponentResolver, Injector, ReflectiveInjector, Type} from '@angular/core';\nimport {Observable} from 'rxjs/Observable';\nimport {Subject} from 'rxjs/Subject';\nimport {Subscription} from 'rxjs/Subscription';\nimport {of } from 'rxjs/observable/of';\n\nimport {applyRedirects} from './apply_redirects';\nimport {RouterConfig} from './config';\nimport {createRouterState} from './create_router_state';\nimport {createUrlTree} from './create_url_tree';\nimport {RouterOutlet} from './directives/router_outlet';\nimport {recognize} from './recognize';\nimport {resolve} from './resolve';\nimport {RouterOutletMap} from './router_outlet_map';\nimport {ActivatedRoute, ActivatedRouteSnapshot, RouterState, RouterStateSnapshot, advanceActivatedRoute, createEmptyState} from './router_state';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlSerializer} from './url_serializer';\nimport {UrlTree, createEmptyUrlTree} from './url_tree';\nimport {forEach, shallowEqual} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nexport interface NavigationExtras {\n  relativeTo?: ActivatedRoute;\n  queryParams?: Params;\n  fragment?: string;\n}\n\n/**\n * An event triggered when a navigation starts\n */\nexport class NavigationStart {\n  constructor(public id: number, public url: UrlTree) {}\n}\n\n/**\n * An event triggered when a navigation ends successfully\n */\nexport class NavigationEnd {\n  constructor(public id: number, public url: UrlTree) {}\n}\n\n/**\n * An event triggered when a navigation is canceled\n */\nexport class NavigationCancel {\n  constructor(public id: number, public url: UrlTree) {}\n}\n\n/**\n * An event triggered when a navigation fails due to unexpected error\n */\nexport class NavigationError {\n  constructor(public id: number, public url: UrlTree, public error: any) {}\n}\n\nexport type Event = NavigationStart | NavigationEnd | NavigationCancel | NavigationError;\n\n/**\n * The `Router` is responsible for mapping URLs to components.\n */\nexport class Router {\n  private currentUrlTree: UrlTree;\n  private currentRouterState: RouterState;\n  private locationSubscription: Subscription;\n  private routerEvents: Subject<Event>;\n  private navigationId: number = 0;\n\n  /**\n   * @internal\n   */\n  constructor(\n      private rootComponentType: Type, private resolver: ComponentResolver,\n      private urlSerializer: UrlSerializer, private outletMap: RouterOutletMap,\n      private location: Location, private injector: Injector, private config: RouterConfig) {\n    this.routerEvents = new Subject<Event>();\n    this.currentUrlTree = createEmptyUrlTree();\n    this.currentRouterState = createEmptyState(this.rootComponentType);\n  }\n\n  /**\n   * @internal\n   */\n  initialNavigation(): void {\n    this.setUpLocationChangeListener();\n    this.navigateByUrl(this.location.path());\n  }\n\n  /**\n   * Returns the current route state.\n   */\n  get routerState(): RouterState { return this.currentRouterState; }\n\n  /**\n   * Returns the current url tree.\n   */\n  get urlTree(): UrlTree { return this.currentUrlTree; }\n\n  /**\n   * Returns an observable of route events\n   */\n  get events(): Observable<Event> { return this.routerEvents; }\n\n  /**\n   * Navigate based on the provided url. This navigation is always absolute.\n   *\n   * Returns a promise that:\n   * - is resolved with 'true' when navigation succeeds\n   * - is resolved with 'false' when navigation fails\n   * - is rejected when an error happens\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigateByUrl(\"/team/33/user/11\");\n   * ```\n   */\n  navigateByUrl(url: string): Promise<boolean> {\n    const urlTree = this.urlSerializer.parse(url);\n    return this.scheduleNavigation(urlTree, false);\n  }\n\n  /**\n   * Resets the configuration used for navigation and generating links.\n   *\n   * ### Usage\n   *\n   * ```\n   * router.resetConfig([\n   *  { path: 'team/:id', component: TeamCmp, children: [\n   *    { path: 'simple', component: SimpleCmp },\n   *    { path: 'user/:name', component: UserCmp }\n   *  ] }\n   * ]);\n   * ```\n   */\n  resetConfig(config: RouterConfig): void { this.config = config; }\n\n  /**\n   * @internal\n   */\n  dispose(): void { this.locationSubscription.unsubscribe(); }\n\n  /**\n   * Applies an array of commands to the current url tree and creates\n   * a new url tree.\n   *\n   * When given an activate route, applies the given commands starting from the route.\n   * When not given a route, applies the given command starting from the root.\n   *\n   * ### Usage\n   *\n   * ```\n   * // create /team/33/user/11\n   * router.createUrlTree(['/team', 33, 'user', 11]);\n   *\n   * // create /team/33;expand=true/user/11\n   * router.createUrlTree(['/team', 33, {expand: true}, 'user', 11]);\n   *\n   * // you can collapse static fragments like this\n   * router.createUrlTree(['/team/33/user', userId]);\n   *\n   * // assuming the current url is `/team/33/user/11` and the route points to `user/11`\n   *\n   * // navigate to /team/33/user/11/details\n   * router.createUrlTree(['details'], {relativeTo: route});\n   *\n   * // navigate to /team/33/user/22\n   * router.createUrlTree(['../22'], {relativeTo: route});\n   *\n   * // navigate to /team/44/user/22\n   * router.createUrlTree(['../../team/44/user/22'], {relativeTo: route});\n   * ```\n   */\n  createUrlTree(commands: any[], {relativeTo, queryParams, fragment}: NavigationExtras = {}):\n      UrlTree {\n    const a = relativeTo ? relativeTo : this.routerState.root;\n    return createUrlTree(a, this.currentUrlTree, commands, queryParams, fragment);\n  }\n\n\n  /**\n   * Navigate based on the provided array of commands and a starting point.\n   * If no starting route is provided, the navigation is absolute.\n   *\n   * Returns a promise that:\n   * - is resolved with 'true' when navigation succeeds\n   * - is resolved with 'false' when navigation fails\n   * - is rejected when an error happens\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigate(['team', 33, 'team', '11], {relativeTo: route});\n   * ```\n   */\n  navigate(commands: any[], extras: NavigationExtras = {}): Promise<boolean> {\n    return this.scheduleNavigation(this.createUrlTree(commands, extras), false);\n  }\n\n  /**\n   * Serializes a {@link UrlTree} into a string.\n   */\n  serializeUrl(url: UrlTree): string { return this.urlSerializer.serialize(url); }\n\n  /**\n   * Parse a string into a {@link UrlTree}.\n   */\n  parseUrl(url: string): UrlTree { return this.urlSerializer.parse(url); }\n\n  private scheduleNavigation(url: UrlTree, pop: boolean): Promise<boolean> {\n    const id = ++this.navigationId;\n    this.routerEvents.next(new NavigationStart(id, url));\n    return Promise.resolve().then((_) => this.runNavigate(url, false, id));\n  }\n\n  private setUpLocationChangeListener(): void {\n    this.locationSubscription = <any>this.location.subscribe((change) => {\n      return this.scheduleNavigation(this.urlSerializer.parse(change['url']), change['pop']);\n    });\n  }\n\n  private runNavigate(url: UrlTree, pop: boolean, id: number): Promise<boolean> {\n    if (id !== this.navigationId) {\n      this.location.go(this.urlSerializer.serialize(this.currentUrlTree));\n      this.routerEvents.next(new NavigationCancel(id, url));\n      return Promise.resolve(false);\n    }\n\n    return new Promise((resolvePromise, rejectPromise) => {\n      let updatedUrl;\n      let state;\n      applyRedirects(url, this.config)\n          .mergeMap(u => {\n            updatedUrl = u;\n            return recognize(this.rootComponentType, this.config, updatedUrl);\n          })\n\n          .mergeMap((newRouterStateSnapshot) => {\n            return resolve(this.resolver, newRouterStateSnapshot);\n\n          })\n          .map((routerStateSnapshot) => {\n            return createRouterState(routerStateSnapshot, this.currentRouterState);\n\n          })\n          .map((newState: RouterState) => {\n            state = newState;\n\n          })\n          .mergeMap(_ => {\n            return new GuardChecks(state.snapshot, this.currentRouterState.snapshot, this.injector)\n                .check(this.outletMap);\n\n          })\n          .forEach((shouldActivate) => {\n            if (!shouldActivate || id !== this.navigationId) {\n              this.location.go(this.urlSerializer.serialize(this.currentUrlTree));\n              this.routerEvents.next(new NavigationCancel(id, url));\n              return Promise.resolve(false);\n            }\n\n            new ActivateRoutes(state, this.currentRouterState).activate(this.outletMap);\n\n            this.currentUrlTree = url;\n            this.currentRouterState = state;\n            if (!pop) {\n              this.location.go(this.urlSerializer.serialize(updatedUrl));\n            }\n          })\n          .then(\n              () => {\n                this.routerEvents.next(new NavigationEnd(id, url));\n                resolvePromise(true);\n\n              },\n              e => {\n                this.routerEvents.next(new NavigationError(id, url, e));\n                rejectPromise(e);\n              });\n    });\n  }\n}\n\nclass CanActivate {\n  constructor(public route: ActivatedRouteSnapshot) {}\n}\nclass CanDeactivate {\n  constructor(public component: Object, public route: ActivatedRouteSnapshot) {}\n}\n\nclass GuardChecks {\n  private checks = [];\n  constructor(\n      private future: RouterStateSnapshot, private curr: RouterStateSnapshot,\n      private injector: Injector) {}\n\n  check(parentOutletMap: RouterOutletMap): Observable<boolean> {\n    const futureRoot = this.future._root;\n    const currRoot = this.curr ? this.curr._root : null;\n    this.traverseChildRoutes(futureRoot, currRoot, parentOutletMap);\n    if (this.checks.length === 0) return of (true);\n    return Observable.from(this.checks)\n        .map(s => {\n          if (s instanceof CanActivate) {\n            return this.runCanActivate(s.route);\n          } else if (s instanceof CanDeactivate) {\n            return this.runCanDeactivate(s.component, s.route);\n          } else {\n            throw new Error('Cannot be reached');\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n\n  private traverseChildRoutes(\n      futureNode: TreeNode<ActivatedRouteSnapshot>, currNode: TreeNode<ActivatedRouteSnapshot>|null,\n      outletMap: RouterOutletMap|null): void {\n    const prevChildren = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.traverseRoutes(c, prevChildren[c.value.outlet], outletMap);\n      delete prevChildren[c.value.outlet];\n    });\n    forEach(prevChildren, (v, k) => this.deactivateOutletAndItChildren(v, outletMap._outlets[k]));\n  }\n\n  traverseRoutes(\n      futureNode: TreeNode<ActivatedRouteSnapshot>, currNode: TreeNode<ActivatedRouteSnapshot>|null,\n      parentOutletMap: RouterOutletMap|null): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n    const outlet = parentOutletMap ? parentOutletMap._outlets[futureNode.value.outlet] : null;\n\n    if (curr && future._routeConfig === curr._routeConfig) {\n      if (!shallowEqual(future.params, curr.params)) {\n        this.checks.push(new CanDeactivate(outlet.component, curr), new CanActivate(future));\n      }\n      this.traverseChildRoutes(futureNode, currNode, outlet ? outlet.outletMap : null);\n    } else {\n      this.deactivateOutletAndItChildren(curr, outlet);\n      this.checks.push(new CanActivate(future));\n      this.traverseChildRoutes(futureNode, null, outlet ? outlet.outletMap : null);\n    }\n  }\n\n  private deactivateOutletAndItChildren(route: ActivatedRouteSnapshot, outlet: RouterOutlet): void {\n    if (outlet && outlet.isActivated) {\n      forEach(\n          outlet.outletMap._outlets,\n          (v, k) => this.deactivateOutletAndItChildren(v.activatedRoute.snapshot, v));\n      this.checks.push(new CanDeactivate(outlet.component, route));\n    }\n  }\n\n  private runCanActivate(future: ActivatedRouteSnapshot): Observable<boolean> {\n    const canActivate = future._routeConfig ? future._routeConfig.canActivate : null;\n    if (!canActivate || canActivate.length === 0) return of (true);\n    return Observable.from(canActivate)\n        .map(c => {\n          const guard = this.injector.get(c);\n          if (guard.canActivate) {\n            return wrapIntoObservable(guard.canActivate(future, this.future));\n          } else {\n            return wrapIntoObservable(guard(future, this.future));\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n\n  private runCanDeactivate(component: Object, curr: ActivatedRouteSnapshot): Observable<boolean> {\n    const canDeactivate = curr._routeConfig ? curr._routeConfig.canDeactivate : null;\n    if (!canDeactivate || canDeactivate.length === 0) return of (true);\n    return Observable.from(canDeactivate)\n        .map(c => {\n          const guard = this.injector.get(c);\n          if (guard.canDeactivate) {\n            return wrapIntoObservable(guard.canDeactivate(component, curr, this.curr));\n          } else {\n            return wrapIntoObservable(guard(component, curr, this.curr));\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n}\n\nfunction wrapIntoObservable<T>(value: T | Observable<T>): Observable<T> {\n  if (value instanceof Observable) {\n    return value;\n  } else {\n    return of (value);\n  }\n}\n\nclass ActivateRoutes {\n  constructor(private futureState: RouterState, private currState: RouterState) {}\n\n  activate(parentOutletMap: RouterOutletMap): void {\n    const futureRoot = this.futureState._root;\n    const currRoot = this.currState ? this.currState._root : null;\n\n    pushQueryParamsAndFragment(this.futureState);\n    this.activateChildRoutes(futureRoot, currRoot, parentOutletMap);\n  }\n\n  private activateChildRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>|null,\n      outletMap: RouterOutletMap): void {\n    const prevChildren = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.activateRoutes(c, prevChildren[c.value.outlet], outletMap);\n      delete prevChildren[c.value.outlet];\n    });\n    forEach(prevChildren, (v, k) => this.deactivateOutletAndItChildren(outletMap._outlets[k]));\n  }\n\n  activateRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>|null,\n      parentOutletMap: RouterOutletMap): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n    const outlet = getOutlet(parentOutletMap, futureNode.value);\n\n    if (future === curr) {\n      advanceActivatedRoute(future);\n      this.activateChildRoutes(futureNode, currNode, outlet.outletMap);\n    } else {\n      this.deactivateOutletAndItChildren(outlet);\n      const outletMap = new RouterOutletMap();\n      this.activateNewRoutes(outletMap, future, outlet);\n      this.activateChildRoutes(futureNode, null, outletMap);\n    }\n  }\n\n  private activateNewRoutes(\n      outletMap: RouterOutletMap, future: ActivatedRoute, outlet: RouterOutlet): void {\n    const resolved = ReflectiveInjector.resolve([\n      {provide: ActivatedRoute, useValue: future},\n      {provide: RouterOutletMap, useValue: outletMap}\n    ]);\n    outlet.activate(future._futureSnapshot._resolvedComponentFactory, future, resolved, outletMap);\n    advanceActivatedRoute(future);\n  }\n\n  private deactivateOutletAndItChildren(outlet: RouterOutlet): void {\n    if (outlet && outlet.isActivated) {\n      forEach(outlet.outletMap._outlets, (v, k) => this.deactivateOutletAndItChildren(v));\n      outlet.deactivate();\n    }\n  }\n}\n\nfunction pushQueryParamsAndFragment(state: RouterState): void {\n  if (!shallowEqual(state.snapshot.queryParams, (<any>state.queryParams).value)) {\n    (<any>state.queryParams).next(state.snapshot.queryParams);\n  }\n\n  if (state.snapshot.fragment !== (<any>state.fragment).value) {\n    (<any>state.fragment).next(state.snapshot.fragment);\n  }\n}\n\nfunction nodeChildrenAsMap(node: TreeNode<any>| null) {\n  return node ? node.children.reduce((m, c) => {\n    m[c.value.outlet] = c;\n    return m;\n  }, {}) : {};\n}\n\nfunction getOutlet(outletMap: RouterOutletMap, route: ActivatedRoute): RouterOutlet {\n  let outlet = outletMap._outlets[route.outlet];\n  if (!outlet) {\n    if (route.outlet === PRIMARY_OUTLET) {\n      throw new Error(`Cannot find primary outlet`);\n    } else {\n      throw new Error(`Cannot find the outlet ${route.outlet}`);\n    }\n  }\n  return outlet;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router.js","sourceRoot":"","sources":["../../src/router.ts"],"names":[],"mappings":"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","sourcesContent":["import 'rxjs/add/operator/map';\nimport 'rxjs/add/operator/scan';\nimport 'rxjs/add/operator/mergeMap';\nimport 'rxjs/add/operator/concat';\nimport 'rxjs/add/operator/concatMap';\nimport 'rxjs/add/operator/every';\nimport 'rxjs/add/operator/mergeAll';\nimport 'rxjs/add/observable/from';\n\nimport {Location} from '@angular/common';\nimport {ComponentResolver, Injector, ReflectiveInjector, Type} from '@angular/core';\nimport {Observable} from 'rxjs/Observable';\nimport {Subject} from 'rxjs/Subject';\nimport {Subscription} from 'rxjs/Subscription';\nimport {of } from 'rxjs/observable/of';\n\nimport {applyRedirects} from './apply_redirects';\nimport {RouterConfig} from './config';\nimport {createRouterState} from './create_router_state';\nimport {createUrlTree} from './create_url_tree';\nimport {RouterOutlet} from './directives/router_outlet';\nimport {recognize} from './recognize';\nimport {resolve} from './resolve';\nimport {RouterOutletMap} from './router_outlet_map';\nimport {ActivatedRoute, ActivatedRouteSnapshot, RouterState, RouterStateSnapshot, advanceActivatedRoute, createEmptyState} from './router_state';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlSerializer} from './url_serializer';\nimport {UrlTree, createEmptyUrlTree} from './url_tree';\nimport {forEach, shallowEqual} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nexport interface NavigationExtras {\n  relativeTo?: ActivatedRoute;\n  queryParams?: Params;\n  fragment?: string;\n}\n\n/**\n * An event triggered when a navigation starts\n */\nexport class NavigationStart {\n  constructor(public id: number, public url: string) {}\n\n  toString(): string { return `NavigationStart(id: ${this.id}, url: '${this.url}')`; }\n}\n\n/**\n * An event triggered when a navigation ends successfully\n */\nexport class NavigationEnd {\n  constructor(public id: number, public url: string, public urlAfterRedirects: string) {}\n\n  toString(): string {\n    return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}')`;\n  }\n}\n\n/**\n * An event triggered when a navigation is canceled\n */\nexport class NavigationCancel {\n  constructor(public id: number, public url: string) {}\n\n  toString(): string { return `NavigationCancel(id: ${this.id}, url: '${this.url}')`; }\n}\n\n/**\n * An event triggered when a navigation fails due to unexpected error\n */\nexport class NavigationError {\n  constructor(public id: number, public url: string, public error: any) {}\n\n  toString(): string {\n    return `NavigationError(id: ${this.id}, url: '${this.url}', error: ${this.error})`;\n  }\n}\n\n/**\n * An event triggered when routes are recognized\n */\nexport class RoutesRecognized {\n  constructor(\n      public id: number, public url: string, public urlAfterRedirects: string,\n      public state: RouterStateSnapshot) {}\n\n  toString(): string {\n    return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\nexport type Event = NavigationStart | NavigationEnd | NavigationCancel | NavigationError;\n\n/**\n * The `Router` is responsible for mapping URLs to components.\n */\nexport class Router {\n  private currentUrlTree: UrlTree;\n  private currentRouterState: RouterState;\n  private locationSubscription: Subscription;\n  private routerEvents: Subject<Event>;\n  private navigationId: number = 0;\n\n  /**\n   * @internal\n   */\n  constructor(\n      private rootComponentType: Type, private resolver: ComponentResolver,\n      private urlSerializer: UrlSerializer, private outletMap: RouterOutletMap,\n      private location: Location, private injector: Injector, private config: RouterConfig) {\n    this.routerEvents = new Subject<Event>();\n    this.currentUrlTree = createEmptyUrlTree();\n    this.currentRouterState = createEmptyState(this.currentUrlTree, this.rootComponentType);\n  }\n\n  /**\n   * @internal\n   */\n  initialNavigation(): void {\n    this.setUpLocationChangeListener();\n    this.navigateByUrl(this.location.path());\n  }\n\n  /**\n   * Returns the current route state.\n   */\n  get routerState(): RouterState { return this.currentRouterState; }\n\n  /**\n   * Returns the current url.\n   */\n  get url(): string { return this.serializeUrl(this.currentUrlTree); }\n\n  /**\n   * Returns an observable of route events\n   */\n  get events(): Observable<Event> { return this.routerEvents; }\n\n  /**\n   * Navigate based on the provided url. This navigation is always absolute.\n   *\n   * Returns a promise that:\n   * - is resolved with 'true' when navigation succeeds\n   * - is resolved with 'false' when navigation fails\n   * - is rejected when an error happens\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigateByUrl(\"/team/33/user/11\");\n   * ```\n   */\n  navigateByUrl(url: string): Promise<boolean> {\n    const urlTree = this.urlSerializer.parse(url);\n    return this.scheduleNavigation(urlTree, false);\n  }\n\n  /**\n   * Resets the configuration used for navigation and generating links.\n   *\n   * ### Usage\n   *\n   * ```\n   * router.resetConfig([\n   *  { path: 'team/:id', component: TeamCmp, children: [\n   *    { path: 'simple', component: SimpleCmp },\n   *    { path: 'user/:name', component: UserCmp }\n   *  ] }\n   * ]);\n   * ```\n   */\n  resetConfig(config: RouterConfig): void { this.config = config; }\n\n  /**\n   * @internal\n   */\n  dispose(): void { this.locationSubscription.unsubscribe(); }\n\n  /**\n   * Applies an array of commands to the current url tree and creates\n   * a new url tree.\n   *\n   * When given an activate route, applies the given commands starting from the route.\n   * When not given a route, applies the given command starting from the root.\n   *\n   * ### Usage\n   *\n   * ```\n   * // create /team/33/user/11\n   * router.createUrlTree(['/team', 33, 'user', 11]);\n   *\n   * // create /team/33;expand=true/user/11\n   * router.createUrlTree(['/team', 33, {expand: true}, 'user', 11]);\n   *\n   * // you can collapse static fragments like this\n   * router.createUrlTree(['/team/33/user', userId]);\n   *\n   * // assuming the current url is `/team/33/user/11` and the route points to `user/11`\n   *\n   * // navigate to /team/33/user/11/details\n   * router.createUrlTree(['details'], {relativeTo: route});\n   *\n   * // navigate to /team/33/user/22\n   * router.createUrlTree(['../22'], {relativeTo: route});\n   *\n   * // navigate to /team/44/user/22\n   * router.createUrlTree(['../../team/44/user/22'], {relativeTo: route});\n   * ```\n   */\n  createUrlTree(commands: any[], {relativeTo, queryParams, fragment}: NavigationExtras = {}):\n      UrlTree {\n    const a = relativeTo ? relativeTo : this.routerState.root;\n    return createUrlTree(a, this.currentUrlTree, commands, queryParams, fragment);\n  }\n\n  /**\n   * Navigate based on the provided array of commands and a starting point.\n   * If no starting route is provided, the navigation is absolute.\n   *\n   * Returns a promise that:\n   * - is resolved with 'true' when navigation succeeds\n   * - is resolved with 'false' when navigation fails\n   * - is rejected when an error happens\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigate(['team', 33, 'team', '11], {relativeTo: route});\n   * ```\n   */\n  navigate(commands: any[], extras: NavigationExtras = {}): Promise<boolean> {\n    return this.scheduleNavigation(this.createUrlTree(commands, extras), false);\n  }\n\n  /**\n   * Serializes a {@link UrlTree} into a string.\n   */\n  serializeUrl(url: UrlTree): string { return this.urlSerializer.serialize(url); }\n\n  /**\n   * Parse a string into a {@link UrlTree}.\n   */\n  parseUrl(url: string): UrlTree { return this.urlSerializer.parse(url); }\n\n  private scheduleNavigation(url: UrlTree, pop: boolean): Promise<boolean> {\n    const id = ++this.navigationId;\n    this.routerEvents.next(new NavigationStart(id, this.serializeUrl(url)));\n    return Promise.resolve().then((_) => this.runNavigate(url, false, id));\n  }\n\n  private setUpLocationChangeListener(): void {\n    this.locationSubscription = <any>this.location.subscribe((change) => {\n      return this.scheduleNavigation(this.urlSerializer.parse(change['url']), change['pop']);\n    });\n  }\n\n  private runNavigate(url: UrlTree, pop: boolean, id: number): Promise<boolean> {\n    if (id !== this.navigationId) {\n      this.location.go(this.urlSerializer.serialize(this.currentUrlTree));\n      this.routerEvents.next(new NavigationCancel(id, this.serializeUrl(url)));\n      return Promise.resolve(false);\n    }\n\n    return new Promise((resolvePromise, rejectPromise) => {\n      let updatedUrl;\n      let state;\n      applyRedirects(url, this.config)\n          .mergeMap(u => {\n            updatedUrl = u;\n            return recognize(\n                this.rootComponentType, this.config, updatedUrl, this.serializeUrl(updatedUrl));\n          })\n\n          .mergeMap((newRouterStateSnapshot) => {\n            this.routerEvents.next(new RoutesRecognized(\n                id, this.serializeUrl(url), this.serializeUrl(updatedUrl), newRouterStateSnapshot));\n            return resolve(this.resolver, newRouterStateSnapshot);\n\n          })\n          .map((routerStateSnapshot) => {\n            return createRouterState(routerStateSnapshot, this.currentRouterState);\n\n          })\n          .map((newState: RouterState) => {\n            state = newState;\n\n          })\n          .mergeMap(_ => {\n            return new GuardChecks(state.snapshot, this.currentRouterState.snapshot, this.injector)\n                .check(this.outletMap);\n\n          })\n          .forEach((shouldActivate) => {\n            if (!shouldActivate || id !== this.navigationId) {\n              this.location.go(this.urlSerializer.serialize(this.currentUrlTree));\n              this.routerEvents.next(new NavigationCancel(id, this.serializeUrl(url)));\n              return Promise.resolve(false);\n            }\n\n            new ActivateRoutes(state, this.currentRouterState).activate(this.outletMap);\n\n            this.currentUrlTree = updatedUrl;\n            this.currentRouterState = state;\n            if (!pop) {\n              this.location.go(this.urlSerializer.serialize(updatedUrl));\n            }\n          })\n          .then(\n              () => {\n                this.routerEvents.next(\n                    new NavigationEnd(id, this.serializeUrl(url), this.serializeUrl(updatedUrl)));\n                resolvePromise(true);\n\n              },\n              e => {\n                this.routerEvents.next(new NavigationError(id, this.serializeUrl(url), e));\n                rejectPromise(e);\n              });\n    });\n  }\n}\n\nclass CanActivate {\n  constructor(public route: ActivatedRouteSnapshot) {}\n}\nclass CanDeactivate {\n  constructor(public component: Object, public route: ActivatedRouteSnapshot) {}\n}\n\nclass GuardChecks {\n  private checks = [];\n  constructor(\n      private future: RouterStateSnapshot, private curr: RouterStateSnapshot,\n      private injector: Injector) {}\n\n  check(parentOutletMap: RouterOutletMap): Observable<boolean> {\n    const futureRoot = this.future._root;\n    const currRoot = this.curr ? this.curr._root : null;\n    this.traverseChildRoutes(futureRoot, currRoot, parentOutletMap);\n    if (this.checks.length === 0) return of (true);\n    return Observable.from(this.checks)\n        .map(s => {\n          if (s instanceof CanActivate) {\n            return this.runCanActivate(s.route);\n          } else if (s instanceof CanDeactivate) {\n            return this.runCanDeactivate(s.component, s.route);\n          } else {\n            throw new Error('Cannot be reached');\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n\n  private traverseChildRoutes(\n      futureNode: TreeNode<ActivatedRouteSnapshot>, currNode: TreeNode<ActivatedRouteSnapshot>,\n      outletMap: RouterOutletMap): void {\n    const prevChildren: {[key: string]: any} = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.traverseRoutes(c, prevChildren[c.value.outlet], outletMap);\n      delete prevChildren[c.value.outlet];\n    });\n    forEach(prevChildren, (v, k) => this.deactivateOutletAndItChildren(v, outletMap._outlets[k]));\n  }\n\n  traverseRoutes(\n      futureNode: TreeNode<ActivatedRouteSnapshot>, currNode: TreeNode<ActivatedRouteSnapshot>,\n      parentOutletMap: RouterOutletMap): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n    const outlet = parentOutletMap ? parentOutletMap._outlets[futureNode.value.outlet] : null;\n\n    if (curr && future._routeConfig === curr._routeConfig) {\n      if (!shallowEqual(future.params, curr.params)) {\n        this.checks.push(new CanDeactivate(outlet.component, curr), new CanActivate(future));\n      }\n      this.traverseChildRoutes(futureNode, currNode, outlet ? outlet.outletMap : null);\n    } else {\n      this.deactivateOutletAndItChildren(curr, outlet);\n      this.checks.push(new CanActivate(future));\n      this.traverseChildRoutes(futureNode, null, outlet ? outlet.outletMap : null);\n    }\n  }\n\n  private deactivateOutletAndItChildren(route: ActivatedRouteSnapshot, outlet: RouterOutlet): void {\n    if (outlet && outlet.isActivated) {\n      forEach(outlet.outletMap._outlets, (v, k) => {\n        if (v.isActivated) {\n          this.deactivateOutletAndItChildren(v.activatedRoute.snapshot, v);\n        }\n      });\n      this.checks.push(new CanDeactivate(outlet.component, route));\n    }\n  }\n\n  private runCanActivate(future: ActivatedRouteSnapshot): Observable<boolean> {\n    const canActivate = future._routeConfig ? future._routeConfig.canActivate : null;\n    if (!canActivate || canActivate.length === 0) return of (true);\n    return Observable.from(canActivate)\n        .map(c => {\n          const guard = this.injector.get(c);\n          if (guard.canActivate) {\n            return wrapIntoObservable(guard.canActivate(future, this.future));\n          } else {\n            return wrapIntoObservable(guard(future, this.future));\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n\n  private runCanDeactivate(component: Object, curr: ActivatedRouteSnapshot): Observable<boolean> {\n    const canDeactivate = curr._routeConfig ? curr._routeConfig.canDeactivate : null;\n    if (!canDeactivate || canDeactivate.length === 0) return of (true);\n    return Observable.from(canDeactivate)\n        .map(c => {\n          const guard = this.injector.get(c);\n          if (guard.canDeactivate) {\n            return wrapIntoObservable(guard.canDeactivate(component, curr, this.curr));\n          } else {\n            return wrapIntoObservable(guard(component, curr, this.curr));\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n}\n\nfunction wrapIntoObservable<T>(value: T | Observable<T>): Observable<T> {\n  if (value instanceof Observable) {\n    return value;\n  } else {\n    return of (value);\n  }\n}\n\nclass ActivateRoutes {\n  constructor(private futureState: RouterState, private currState: RouterState) {}\n\n  activate(parentOutletMap: RouterOutletMap): void {\n    const futureRoot = this.futureState._root;\n    const currRoot = this.currState ? this.currState._root : null;\n\n    pushQueryParamsAndFragment(this.futureState);\n    this.activateChildRoutes(futureRoot, currRoot, parentOutletMap);\n  }\n\n  private activateChildRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>,\n      outletMap: RouterOutletMap): void {\n    const prevChildren: {[key: string]: any} = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.activateRoutes(c, prevChildren[c.value.outlet], outletMap);\n      delete prevChildren[c.value.outlet];\n    });\n    forEach(prevChildren, (v, k) => this.deactivateOutletAndItChildren(outletMap._outlets[k]));\n  }\n\n  activateRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>,\n      parentOutletMap: RouterOutletMap): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n\n    const outlet = getOutlet(parentOutletMap, futureNode.value);\n\n    if (future === curr) {\n      advanceActivatedRoute(future);\n      this.activateChildRoutes(futureNode, currNode, outlet.outletMap);\n    } else {\n      this.deactivateOutletAndItChildren(outlet);\n      const outletMap = new RouterOutletMap();\n      this.activateNewRoutes(outletMap, future, outlet);\n      this.activateChildRoutes(futureNode, null, outletMap);\n    }\n  }\n\n  private activateNewRoutes(\n      outletMap: RouterOutletMap, future: ActivatedRoute, outlet: RouterOutlet): void {\n    const resolved = ReflectiveInjector.resolve([\n      {provide: ActivatedRoute, useValue: future},\n      {provide: RouterOutletMap, useValue: outletMap}\n    ]);\n    outlet.activate(future._futureSnapshot._resolvedComponentFactory, future, resolved, outletMap);\n    advanceActivatedRoute(future);\n  }\n\n  private deactivateOutletAndItChildren(outlet: RouterOutlet): void {\n    if (outlet && outlet.isActivated) {\n      forEach(outlet.outletMap._outlets, (v, k) => this.deactivateOutletAndItChildren(v));\n      outlet.deactivate();\n    }\n  }\n}\n\nfunction pushQueryParamsAndFragment(state: RouterState): void {\n  if (!shallowEqual(state.snapshot.queryParams, (<any>state.queryParams).value)) {\n    (<any>state.queryParams).next(state.snapshot.queryParams);\n  }\n\n  if (state.snapshot.fragment !== (<any>state.fragment).value) {\n    (<any>state.fragment).next(state.snapshot.fragment);\n  }\n}\n\nfunction nodeChildrenAsMap(node: TreeNode<any>) {\n  return node ? node.children.reduce((m, c) => {\n    m[c.value.outlet] = c;\n    return m;\n  }, {}) : {};\n}\n\nfunction getOutlet(outletMap: RouterOutletMap, route: ActivatedRoute): RouterOutlet {\n  let outlet = outletMap._outlets[route.outlet];\n  if (!outlet) {\n    const componentName = (<any>route.component).name;\n    if (route.outlet === PRIMARY_OUTLET) {\n      throw new Error(`Cannot find primary outlet to load '${componentName}'`);\n    } else {\n      throw new Error(`Cannot find the outlet ${route.outlet} to load '${componentName}'`);\n    }\n  }\n  return outlet;\n}\n"]}
export declare const PRIMARY_OUTLET: string;
export declare type Params = {
[key: string]: string;
[key: string]: any;
};
export const PRIMARY_OUTLET = 'PRIMARY_OUTLET';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NoYXJlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxPQUFPLE1BQU0sY0FBYyxHQUFHLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBOYW1lIG9mIHRoZSBwcmltYXJ5IG91dGxldC5cbiAqIEB0eXBlIHtzdHJpbmd9XG4gKi9cbmV4cG9ydCBjb25zdCBQUklNQVJZX09VVExFVCA9ICdQUklNQVJZX09VVExFVCc7XG5cbi8qKlxuICogQSBjb2xsZWN0aW9uIG9mIHBhcmFtZXRlcnMuXG4gKi9cbmV4cG9ydCB0eXBlIFBhcmFtcyA9IHtcbiAgW2tleTogc3RyaW5nXTogc3RyaW5nXG59O1xuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NoYXJlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxPQUFPLE1BQU0sY0FBYyxHQUFHLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBOYW1lIG9mIHRoZSBwcmltYXJ5IG91dGxldC5cbiAqIEB0eXBlIHtzdHJpbmd9XG4gKi9cbmV4cG9ydCBjb25zdCBQUklNQVJZX09VVExFVCA9ICdQUklNQVJZX09VVExFVCc7XG5cbi8qKlxuICogQSBjb2xsZWN0aW9uIG9mIHBhcmFtZXRlcnMuXG4gKi9cbmV4cG9ydCB0eXBlIFBhcmFtcyA9IHtcbiAgW2tleTogc3RyaW5nXTogYW55XG59O1xuIl19

@@ -1,2 +0,2 @@

import { UrlSegment, UrlTree } from './url_tree';
import { UrlPathWithParams, UrlSegment, UrlTree } from './url_tree';
export declare abstract class UrlSerializer {

@@ -10,2 +10,3 @@ abstract parse(url: string): UrlTree;

}
export declare function serializeSegment(segment: UrlSegment): string;
export declare function serializePaths(segment: UrlSegment): string;
export declare function serializePath(path: UrlPathWithParams): string;
import { PRIMARY_OUTLET } from './shared';
import { UrlSegment, UrlTree } from './url_tree';
import { TreeNode } from './utils/tree';
import { UrlPathWithParams, UrlSegment, UrlTree } from './url_tree';
import { forEach } from './utils/collection';
export class UrlSerializer {

@@ -12,21 +12,53 @@ }

serialize(tree) {
const node = serializeUrlTreeNode(tree._root);
const segment = `/${serializeSegment(tree.root, true)}`;
const query = serializeQueryParams(tree.queryParams);
const fragment = tree.fragment !== null ? `#${tree.fragment}` : '';
return `${node}${query}${fragment}`;
return `${segment}${query}${fragment}`;
}
}
function serializeUrlTreeNode(node) {
return `${serializeSegment(node.value)}${serializeChildren(node)}`;
export function serializePaths(segment) {
return segment.pathsWithParams.map(p => serializePath(p)).join('/');
}
function serializeUrlTreeNodes(nodes) {
const primary = serializeSegment(nodes[0].value);
const secondaryNodes = nodes.slice(1);
const secondary = secondaryNodes.length > 0 ? `(${secondaryNodes.map(serializeUrlTreeNode).join("//")})` : '';
const children = serializeChildren(nodes[0]);
return `${primary}${secondary}${children}`;
function serializeSegment(segment, root) {
if (segment.children[PRIMARY_OUTLET] && root) {
const primary = serializeSegment(segment.children[PRIMARY_OUTLET], false);
const children = [];
forEach(segment.children, (v, k) => {
if (k !== PRIMARY_OUTLET) {
children.push(`${k}:${serializeSegment(v, false)}`);
}
});
if (children.length > 0) {
return `${primary}(${children.join('//')})`;
}
else {
return `${primary}`;
}
}
else if (segment.children[PRIMARY_OUTLET] && !root) {
const children = [serializeSegment(segment.children[PRIMARY_OUTLET], false)];
forEach(segment.children, (v, k) => {
if (k !== PRIMARY_OUTLET) {
children.push(`${k}:${serializeSegment(v, false)}`);
}
});
return `${serializePaths(segment)}/(${children.join('//')})`;
}
else {
return serializePaths(segment);
}
}
function serializeChildren(node) {
if (node.children.length > 0) {
return `/${serializeUrlTreeNodes(node.children)}`;
function serializeChildren(segment) {
if (segment.children[PRIMARY_OUTLET]) {
const primary = serializePaths(segment.children[PRIMARY_OUTLET]);
const secondary = [];
forEach(segment.children, (v, k) => {
if (k !== PRIMARY_OUTLET) {
secondary.push(`${k}:${serializePaths(v)}${serializeChildren(v)}`);
}
});
const secondaryStr = secondary.length > 0 ? `(${secondary.join('//')})` : '';
const primaryChildren = serializeChildren(segment.children[PRIMARY_OUTLET]);
const primaryChildrenStr = primaryChildren ? `/${primaryChildren}` : '';
return `${primary}${secondaryStr}${primaryChildrenStr}`;
}

@@ -37,5 +69,4 @@ else {

}
export function serializeSegment(segment) {
const outlet = segment.outlet === PRIMARY_OUTLET ? '' : `${segment.outlet}:`;
return `${outlet}${segment.path}${serializeParams(segment.parameters)}`;
export function serializePath(path) {
return `${path.path}${serializeParams(path.parameters)}`;
}

@@ -65,3 +96,3 @@ function serializeParams(params) {

const SEGMENT_RE = /^[^\/\(\)\?;=&#]+/;
function matchUrlSegment(str) {
function matchPathWithParams(str) {
SEGMENT_RE.lastIndex = 0;

@@ -89,13 +120,12 @@ var match = SEGMENT_RE.exec(str);

parseRootSegment() {
if (this.remaining == '' || this.remaining == '/') {
return new TreeNode(new UrlSegment('', {}, PRIMARY_OUTLET), []);
if (this.remaining === '' || this.remaining === '/') {
return new UrlSegment([], {});
}
else {
const segments = this.parseSegments(false);
return new TreeNode(new UrlSegment('', {}, PRIMARY_OUTLET), segments);
return new UrlSegment([], this.parseSegmentChildren());
}
}
parseSegments(hasOutletName) {
parseSegmentChildren() {
if (this.remaining.length == 0) {
return [];
return {};
}

@@ -105,21 +135,22 @@ if (this.peekStartsWith('/')) {

}
let path = matchUrlSegment(this.remaining);
this.capture(path);
let outletName;
if (hasOutletName) {
if (path.indexOf(':') === -1) {
throw new Error('Not outlet name is provided');
}
if (path.indexOf(':') > -1 && hasOutletName) {
let parts = path.split(':');
outletName = parts[0];
path = parts[1];
}
const paths = [this.parsePathWithParams()];
while (this.peekStartsWith('/') && !this.peekStartsWith('//') && !this.peekStartsWith('/(')) {
this.capture('/');
paths.push(this.parsePathWithParams());
}
else {
if (path.indexOf(':') > -1) {
throw new Error('Not outlet name is allowed');
}
outletName = PRIMARY_OUTLET;
let children = {};
if (this.peekStartsWith('/(')) {
this.capture('/');
children = this.parseParens(true);
}
let res = {};
if (this.peekStartsWith('(')) {
res = this.parseParens(false);
}
res[PRIMARY_OUTLET] = new UrlSegment(paths, children);
return res;
}
parsePathWithParams() {
let path = matchPathWithParams(this.remaining);
this.capture(path);
let matrixParams = {};

@@ -129,14 +160,3 @@ if (this.peekStartsWith(';')) {

}
let secondary = [];
if (this.peekStartsWith('(')) {
secondary = this.parseSecondarySegments();
}
let children = [];
if (this.peekStartsWith('/') && !this.peekStartsWith('//')) {
this.capture('/');
children = this.parseSegments(false);
}
const segment = new UrlSegment(path, matrixParams, outletName);
const node = new TreeNode(segment, children);
return [node].concat(secondary);
return new UrlPathWithParams(path, matrixParams);
}

@@ -172,3 +192,3 @@ parseQueryParams() {

parseParam(params) {
var key = matchUrlSegment(this.remaining);
var key = matchPathWithParams(this.remaining);
if (!key) {

@@ -181,3 +201,3 @@ return;

this.capture('=');
var valueMatch = matchUrlSegment(this.remaining);
var valueMatch = matchPathWithParams(this.remaining);
if (valueMatch) {

@@ -191,3 +211,3 @@ value = valueMatch;

parseQueryParam(params) {
var key = matchUrlSegment(this.remaining);
var key = matchPathWithParams(this.remaining);
if (!key) {

@@ -208,7 +228,19 @@ return;

}
parseSecondarySegments() {
var segments = [];
parseParens(allowPrimary) {
const segments = {};
this.capture('(');
while (!this.peekStartsWith(')') && this.remaining.length > 0) {
segments = segments.concat(this.parseSegments(true));
let path = matchPathWithParams(this.remaining);
let outletName;
if (path.indexOf(':') > -1) {
outletName = path.substr(0, path.indexOf(':'));
this.capture(outletName);
this.capture(':');
}
else if (allowPrimary) {
outletName = PRIMARY_OUTLET;
}
const children = this.parseSegmentChildren();
segments[outletName] = Object.keys(children).length === 1 ? children[PRIMARY_OUTLET] :
new UrlSegment([], children);
if (this.peekStartsWith('//')) {

@@ -222,2 +254,2 @@ this.capture('//');

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"url_serializer.js","sourceRoot":"","sources":["../../src/url_serializer.ts"],"names":[],"mappings":"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","sourcesContent":["import {PRIMARY_OUTLET} from './shared';\nimport {UrlSegment, UrlTree} from './url_tree';\nimport {TreeNode} from './utils/tree';\n\n\n/**\n * Defines a way to serialize/deserialize a url tree.\n */\nexport abstract class UrlSerializer {\n  /**\n   * Parse a url into a {@Link UrlTree}\n   */\n  abstract parse(url: string): UrlTree;\n\n  /**\n   * Converts a {@Link UrlTree} into a url\n   */\n  abstract serialize(tree: UrlTree): string;\n}\n\n/**\n * A default implementation of the serialization.\n */\nexport class DefaultUrlSerializer implements UrlSerializer {\n  parse(url: string): UrlTree {\n    const p = new UrlParser(url);\n    return new UrlTree(p.parseRootSegment(), p.parseQueryParams(), p.parseFragment());\n  }\n\n  serialize(tree: UrlTree): string {\n    const node = serializeUrlTreeNode(tree._root);\n    const query = serializeQueryParams(tree.queryParams);\n    const fragment = tree.fragment !== null ? `#${tree.fragment}` : '';\n    return `${node}${query}${fragment}`;\n  }\n}\n\nfunction serializeUrlTreeNode(node: TreeNode<UrlSegment>): string {\n  return `${serializeSegment(node.value)}${serializeChildren(node)}`;\n}\n\nfunction serializeUrlTreeNodes(nodes: TreeNode<UrlSegment>[]): string {\n  const primary = serializeSegment(nodes[0].value);\n  const secondaryNodes = nodes.slice(1);\n  const secondary =\n      secondaryNodes.length > 0 ? `(${secondaryNodes.map(serializeUrlTreeNode).join(\"//\")})` : '';\n  const children = serializeChildren(nodes[0]);\n  return `${primary}${secondary}${children}`;\n}\n\nfunction serializeChildren(node: TreeNode<UrlSegment>): string {\n  if (node.children.length > 0) {\n    return `/${serializeUrlTreeNodes(node.children)}`;\n  } else {\n    return '';\n  }\n}\n\nexport function serializeSegment(segment: UrlSegment): string {\n  const outlet = segment.outlet === PRIMARY_OUTLET ? '' : `${segment.outlet}:`;\n  return `${outlet}${segment.path}${serializeParams(segment.parameters)}`;\n}\n\nfunction serializeParams(params: {[key: string]: string}): string {\n  return pairs(params).map(p => `;${p.first}=${p.second}`).join('');\n}\n\nfunction serializeQueryParams(params: {[key: string]: string}): string {\n  const strs = pairs(params).map(p => `${p.first}=${p.second}`);\n  return strs.length > 0 ? `?${strs.join(\"&\")}` : '';\n}\n\nclass Pair<A, B> {\n  constructor(public first: A, public second: B) {}\n}\nfunction pairs<T>(obj: {[key: string]: T}): Pair<string, T>[] {\n  const res = [];\n  for (let prop in obj) {\n    if (obj.hasOwnProperty(prop)) {\n      res.push(new Pair<string, T>(prop, obj[prop]));\n    }\n  }\n  return res;\n}\n\nconst SEGMENT_RE = /^[^\\/\\(\\)\\?;=&#]+/;\nfunction matchUrlSegment(str: string): string {\n  SEGMENT_RE.lastIndex = 0;\n  var match = SEGMENT_RE.exec(str);\n  return match ? match[0] : '';\n}\n\nconst QUERY_PARAM_VALUE_RE = /^[^\\(\\)\\?;&#]+/;\nfunction matchUrlQueryParamValue(str: string): string {\n  QUERY_PARAM_VALUE_RE.lastIndex = 0;\n  const match = QUERY_PARAM_VALUE_RE.exec(str);\n  return match ? match[0] : '';\n}\n\nclass UrlParser {\n  constructor(private remaining: string) {}\n\n  peekStartsWith(str: string): boolean { return this.remaining.startsWith(str); }\n\n  capture(str: string): void {\n    if (!this.remaining.startsWith(str)) {\n      throw new Error(`Expected \"${str}\".`);\n    }\n    this.remaining = this.remaining.substring(str.length);\n  }\n\n  parseRootSegment(): TreeNode<UrlSegment> {\n    if (this.remaining == '' || this.remaining == '/') {\n      return new TreeNode<UrlSegment>(new UrlSegment('', {}, PRIMARY_OUTLET), []);\n    } else {\n      const segments = this.parseSegments(false);\n      return new TreeNode<UrlSegment>(new UrlSegment('', {}, PRIMARY_OUTLET), segments);\n    }\n  }\n\n  parseSegments(hasOutletName: boolean): TreeNode<UrlSegment>[] {\n    if (this.remaining.length == 0) {\n      return [];\n    }\n    if (this.peekStartsWith('/')) {\n      this.capture('/');\n    }\n    let path = matchUrlSegment(this.remaining);\n    this.capture(path);\n\n    let outletName;\n    if (hasOutletName) {\n      if (path.indexOf(':') === -1) {\n        throw new Error('Not outlet name is provided');\n      }\n      if (path.indexOf(':') > -1 && hasOutletName) {\n        let parts = path.split(':');\n        outletName = parts[0];\n        path = parts[1];\n      }\n    } else {\n      if (path.indexOf(':') > -1) {\n        throw new Error('Not outlet name is allowed');\n      }\n      outletName = PRIMARY_OUTLET;\n    }\n\n    let matrixParams: {[key: string]: any} = {};\n    if (this.peekStartsWith(';')) {\n      matrixParams = this.parseMatrixParams();\n    }\n\n    let secondary = [];\n    if (this.peekStartsWith('(')) {\n      secondary = this.parseSecondarySegments();\n    }\n\n    let children: TreeNode<UrlSegment>[] = [];\n    if (this.peekStartsWith('/') && !this.peekStartsWith('//')) {\n      this.capture('/');\n      children = this.parseSegments(false);\n    }\n\n    const segment = new UrlSegment(path, matrixParams, outletName);\n    const node = new TreeNode<UrlSegment>(segment, children);\n    return [node].concat(secondary);\n  }\n\n  parseQueryParams(): {[key: string]: any} {\n    var params: {[key: string]: any} = {};\n    if (this.peekStartsWith('?')) {\n      this.capture('?');\n      this.parseQueryParam(params);\n      while (this.remaining.length > 0 && this.peekStartsWith('&')) {\n        this.capture('&');\n        this.parseQueryParam(params);\n      }\n    }\n    return params;\n  }\n\n  parseFragment(): string|null {\n    if (this.peekStartsWith('#')) {\n      return this.remaining.substring(1);\n    } else {\n      return null;\n    }\n  }\n\n  parseMatrixParams(): {[key: string]: any} {\n    var params: {[key: string]: any} = {};\n    while (this.remaining.length > 0 && this.peekStartsWith(';')) {\n      this.capture(';');\n      this.parseParam(params);\n    }\n    return params;\n  }\n\n  parseParam(params: {[key: string]: any}): void {\n    var key = matchUrlSegment(this.remaining);\n    if (!key) {\n      return;\n    }\n    this.capture(key);\n    var value: any = 'true';\n    if (this.peekStartsWith('=')) {\n      this.capture('=');\n      var valueMatch = matchUrlSegment(this.remaining);\n      if (valueMatch) {\n        value = valueMatch;\n        this.capture(value);\n      }\n    }\n\n    params[key] = value;\n  }\n\n  parseQueryParam(params: {[key: string]: any}): void {\n    var key = matchUrlSegment(this.remaining);\n    if (!key) {\n      return;\n    }\n    this.capture(key);\n    var value: any = 'true';\n    if (this.peekStartsWith('=')) {\n      this.capture('=');\n      var valueMatch = matchUrlQueryParamValue(this.remaining);\n      if (valueMatch) {\n        value = valueMatch;\n        this.capture(value);\n      }\n    }\n    params[key] = value;\n  }\n\n  parseSecondarySegments(): TreeNode<UrlSegment>[] {\n    var segments = [];\n    this.capture('(');\n\n    while (!this.peekStartsWith(')') && this.remaining.length > 0) {\n      segments = segments.concat(this.parseSegments(true));\n      if (this.peekStartsWith('//')) {\n        this.capture('//');\n      }\n    }\n    this.capture(')');\n\n    return segments;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"url_serializer.js","sourceRoot":"","sources":["../../src/url_serializer.ts"],"names":[],"mappings":"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","sourcesContent":["import {PRIMARY_OUTLET} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree} from './url_tree';\nimport {forEach} from './utils/collection';\n\n\n\n/**\n * Defines a way to serialize/deserialize a url tree.\n */\nexport abstract class UrlSerializer {\n  /**\n   * Parse a url into a {@Link UrlTree}\n   */\n  abstract parse(url: string): UrlTree;\n\n  /**\n   * Converts a {@Link UrlTree} into a url\n   */\n  abstract serialize(tree: UrlTree): string;\n}\n\n/**\n * A default implementation of the serialization.\n */\nexport class DefaultUrlSerializer implements UrlSerializer {\n  parse(url: string): UrlTree {\n    const p = new UrlParser(url);\n    return new UrlTree(p.parseRootSegment(), p.parseQueryParams(), p.parseFragment());\n  }\n\n  serialize(tree: UrlTree): string {\n    const segment = `/${serializeSegment(tree.root, true)}`;\n    const query = serializeQueryParams(tree.queryParams);\n    const fragment = tree.fragment !== null ? `#${tree.fragment}` : '';\n    return `${segment}${query}${fragment}`;\n  }\n}\n\nexport function serializePaths(segment: UrlSegment): string {\n  return segment.pathsWithParams.map(p => serializePath(p)).join('/');\n}\n\nfunction serializeSegment(segment: UrlSegment, root: boolean): string {\n  if (segment.children[PRIMARY_OUTLET] && root) {\n    const primary = serializeSegment(segment.children[PRIMARY_OUTLET], false);\n    const children = [];\n    forEach(segment.children, (v, k) => {\n      if (k !== PRIMARY_OUTLET) {\n        children.push(`${k}:${serializeSegment(v, false)}`);\n      }\n    });\n    if (children.length > 0) {\n      return `${primary}(${children.join('//')})`;\n    } else {\n      return `${primary}`;\n    }\n  } else if (segment.children[PRIMARY_OUTLET] && !root) {\n    const children = [serializeSegment(segment.children[PRIMARY_OUTLET], false)];\n    forEach(segment.children, (v, k) => {\n      if (k !== PRIMARY_OUTLET) {\n        children.push(`${k}:${serializeSegment(v, false)}`);\n      }\n    });\n    return `${serializePaths(segment)}/(${children.join('//')})`;\n  } else {\n    return serializePaths(segment);\n  }\n}\n\nfunction serializeChildren(segment: UrlSegment) {\n  if (segment.children[PRIMARY_OUTLET]) {\n    const primary = serializePaths(segment.children[PRIMARY_OUTLET]);\n\n    const secondary = [];\n    forEach(segment.children, (v, k) => {\n      if (k !== PRIMARY_OUTLET) {\n        secondary.push(`${k}:${serializePaths(v)}${serializeChildren(v)}`);\n      }\n    });\n    const secondaryStr = secondary.length > 0 ? `(${secondary.join('//')})` : '';\n    const primaryChildren = serializeChildren(segment.children[PRIMARY_OUTLET]);\n    const primaryChildrenStr = primaryChildren ? `/${primaryChildren}` : '';\n    return `${primary}${secondaryStr}${primaryChildrenStr}`;\n  } else {\n    return '';\n  }\n}\n\nexport function serializePath(path: UrlPathWithParams): string {\n  return `${path.path}${serializeParams(path.parameters)}`;\n}\n\nfunction serializeParams(params: {[key: string]: string}): string {\n  return pairs(params).map(p => `;${p.first}=${p.second}`).join('');\n}\n\nfunction serializeQueryParams(params: {[key: string]: string}): string {\n  const strs = pairs(params).map(p => `${p.first}=${p.second}`);\n  return strs.length > 0 ? `?${strs.join(\"&\")}` : '';\n}\n\nclass Pair<A, B> {\n  constructor(public first: A, public second: B) {}\n}\nfunction pairs<T>(obj: {[key: string]: T}): Pair<string, T>[] {\n  const res = [];\n  for (let prop in obj) {\n    if (obj.hasOwnProperty(prop)) {\n      res.push(new Pair<string, T>(prop, obj[prop]));\n    }\n  }\n  return res;\n}\n\nconst SEGMENT_RE = /^[^\\/\\(\\)\\?;=&#]+/;\nfunction matchPathWithParams(str: string): string {\n  SEGMENT_RE.lastIndex = 0;\n  var match = SEGMENT_RE.exec(str);\n  return match ? match[0] : '';\n}\n\nconst QUERY_PARAM_VALUE_RE = /^[^\\(\\)\\?;&#]+/;\nfunction matchUrlQueryParamValue(str: string): string {\n  QUERY_PARAM_VALUE_RE.lastIndex = 0;\n  const match = QUERY_PARAM_VALUE_RE.exec(str);\n  return match ? match[0] : '';\n}\n\nclass UrlParser {\n  constructor(private remaining: string) {}\n\n  peekStartsWith(str: string): boolean { return this.remaining.startsWith(str); }\n\n  capture(str: string): void {\n    if (!this.remaining.startsWith(str)) {\n      throw new Error(`Expected \"${str}\".`);\n    }\n    this.remaining = this.remaining.substring(str.length);\n  }\n\n  parseRootSegment(): UrlSegment {\n    if (this.remaining === '' || this.remaining === '/') {\n      return new UrlSegment([], {});\n    } else {\n      return new UrlSegment([], this.parseSegmentChildren());\n    }\n  }\n\n  parseSegmentChildren(): {[key: string]: UrlSegment} {\n    if (this.remaining.length == 0) {\n      return {};\n    }\n\n    if (this.peekStartsWith('/')) {\n      this.capture('/');\n    }\n\n    const paths = [this.parsePathWithParams()];\n\n    while (this.peekStartsWith('/') && !this.peekStartsWith('//') && !this.peekStartsWith('/(')) {\n      this.capture('/');\n      paths.push(this.parsePathWithParams());\n    }\n\n    let children: {[key: string]: UrlSegment} = {};\n    if (this.peekStartsWith('/(')) {\n      this.capture('/');\n      children = this.parseParens(true);\n    }\n\n    let res: {[key: string]: UrlSegment} = {};\n    if (this.peekStartsWith('(')) {\n      res = this.parseParens(false);\n    }\n\n    res[PRIMARY_OUTLET] = new UrlSegment(paths, children);\n    return res;\n  }\n\n  parsePathWithParams(): UrlPathWithParams {\n    let path = matchPathWithParams(this.remaining);\n    this.capture(path);\n    let matrixParams: {[key: string]: any} = {};\n    if (this.peekStartsWith(';')) {\n      matrixParams = this.parseMatrixParams();\n    }\n    return new UrlPathWithParams(path, matrixParams);\n  }\n\n  parseQueryParams(): {[key: string]: any} {\n    var params: {[key: string]: any} = {};\n    if (this.peekStartsWith('?')) {\n      this.capture('?');\n      this.parseQueryParam(params);\n      while (this.remaining.length > 0 && this.peekStartsWith('&')) {\n        this.capture('&');\n        this.parseQueryParam(params);\n      }\n    }\n    return params;\n  }\n\n  parseFragment(): string {\n    if (this.peekStartsWith('#')) {\n      return this.remaining.substring(1);\n    } else {\n      return null;\n    }\n  }\n\n  parseMatrixParams(): {[key: string]: any} {\n    var params: {[key: string]: any} = {};\n    while (this.remaining.length > 0 && this.peekStartsWith(';')) {\n      this.capture(';');\n      this.parseParam(params);\n    }\n    return params;\n  }\n\n  parseParam(params: {[key: string]: any}): void {\n    var key = matchPathWithParams(this.remaining);\n    if (!key) {\n      return;\n    }\n    this.capture(key);\n    var value: any = 'true';\n    if (this.peekStartsWith('=')) {\n      this.capture('=');\n      var valueMatch = matchPathWithParams(this.remaining);\n      if (valueMatch) {\n        value = valueMatch;\n        this.capture(value);\n      }\n    }\n\n    params[key] = value;\n  }\n\n  parseQueryParam(params: {[key: string]: any}): void {\n    var key = matchPathWithParams(this.remaining);\n    if (!key) {\n      return;\n    }\n    this.capture(key);\n    var value: any = 'true';\n    if (this.peekStartsWith('=')) {\n      this.capture('=');\n      var valueMatch = matchUrlQueryParamValue(this.remaining);\n      if (valueMatch) {\n        value = valueMatch;\n        this.capture(value);\n      }\n    }\n    params[key] = value;\n  }\n\n  parseParens(allowPrimary: boolean): {[key: string]: UrlSegment} {\n    const segments: {[key: string]: UrlSegment} = {};\n    this.capture('(');\n\n    while (!this.peekStartsWith(')') && this.remaining.length > 0) {\n      let path = matchPathWithParams(this.remaining);\n      let outletName;\n      if (path.indexOf(':') > -1) {\n        outletName = path.substr(0, path.indexOf(':'));\n        this.capture(outletName);\n        this.capture(':');\n      } else if (allowPrimary) {\n        outletName = PRIMARY_OUTLET;\n      }\n\n      const children = this.parseSegmentChildren();\n      segments[outletName] = Object.keys(children).length === 1 ? children[PRIMARY_OUTLET] :\n                                                                  new UrlSegment([], children);\n\n      if (this.peekStartsWith('//')) {\n        this.capture('//');\n      }\n    }\n    this.capture(')');\n\n    return segments;\n  }\n}\n"]}

@@ -1,13 +0,25 @@

import { Tree, TreeNode } from './utils/tree';
export declare function createEmptyUrlTree(): UrlTree;
export declare class UrlTree extends Tree<UrlSegment> {
export declare class UrlTree {
root: UrlSegment;
queryParams: {
[key: string]: string;
};
fragment: string | null;
constructor(root: TreeNode<UrlSegment>, queryParams: {
fragment: string;
constructor(root: UrlSegment, queryParams: {
[key: string]: string;
}, fragment: string | null);
}, fragment: string);
toString(): string;
}
export declare class UrlSegment {
pathsWithParams: UrlPathWithParams[];
children: {
[key: string]: UrlSegment;
};
parent: UrlSegment;
constructor(pathsWithParams: UrlPathWithParams[], children: {
[key: string]: UrlSegment;
});
toString(): string;
}
export declare class UrlPathWithParams {
path: string;

@@ -17,8 +29,11 @@ parameters: {

};
outlet: string;
constructor(path: string, parameters: {
[key: string]: string;
}, outlet: string);
});
toString(): string;
}
export declare function equalUrlSegments(a: UrlSegment[], b: UrlSegment[]): boolean;
export declare function equalPathsWithParams(a: UrlPathWithParams[], b: UrlPathWithParams[]): boolean;
export declare function mapChildren(segment: UrlSegment, fn: (v: UrlSegment, k: string) => UrlSegment): {
[name: string]: UrlSegment;
};
export declare function mapChildrenIntoArray<T>(segment: UrlSegment, fn: (v: UrlSegment, k: string) => T[]): T[];
import { PRIMARY_OUTLET } from './shared';
import { shallowEqual } from './utils/collection';
import { Tree, TreeNode } from './utils/tree';
import { DefaultUrlSerializer, serializePath, serializePaths } from './url_serializer';
import { forEach, shallowEqual } from './utils/collection';
export function createEmptyUrlTree() {
return new UrlTree(new TreeNode(new UrlSegment('', {}, PRIMARY_OUTLET), []), {}, null);
return new UrlTree(new UrlSegment([], {}), {}, null);
}
export class UrlTree extends Tree {
export class UrlTree {
constructor(root, queryParams, fragment) {
super(root);
this.root = root;
this.queryParams = queryParams;
this.fragment = fragment;
}
toString() { return new DefaultUrlSerializer().serialize(this); }
}
export class UrlSegment {
constructor(path, parameters, outlet) {
constructor(pathsWithParams, children) {
this.pathsWithParams = pathsWithParams;
this.children = children;
this.parent = null;
forEach(children, (v, k) => v.parent = this);
}
toString() { return serializePaths(this); }
}
export class UrlPathWithParams {
constructor(path, parameters) {
this.path = path;
this.parameters = parameters;
this.outlet = outlet;
}
toString() {
const params = [];
for (let prop in this.parameters) {
if (this.parameters.hasOwnProperty(prop)) {
params.push(`${prop}=${this.parameters[prop]}`);
}
}
const paramsString = params.length > 0 ? `(${params.join(',')})` : '';
const outlet = this.outlet === PRIMARY_OUTLET ? '' : `${this.outlet}:`;
return `${outlet}${this.path}${paramsString}`;
}
toString() { return serializePath(this); }
}
export function equalUrlSegments(a, b) {
export function equalPathsWithParams(a, b) {
if (a.length !== b.length)

@@ -43,2 +42,30 @@ return false;

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXJsX3RyZWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXJsX3RyZWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ik9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxVQUFVO09BQ2hDLEVBQUMsWUFBWSxFQUFDLE1BQU0sb0JBQW9CO09BQ3hDLEVBQUMsSUFBSSxFQUFFLFFBQVEsRUFBQyxNQUFNLGNBQWM7QUFFM0M7SUFDRSxNQUFNLENBQUMsSUFBSSxPQUFPLENBQ2QsSUFBSSxRQUFRLENBQWEsSUFBSSxVQUFVLENBQUMsRUFBRSxFQUFFLEVBQUUsRUFBRSxjQUFjLENBQUMsRUFBRSxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDdEYsQ0FBQztBQUtELDZCQUE2QixJQUFJO0lBSS9CLFlBQ0ksSUFBMEIsRUFBUyxXQUFvQyxFQUNoRSxRQUFxQjtRQUM5QixNQUFNLElBQUksQ0FBQyxDQUFDO1FBRnlCLGdCQUFXLEdBQVgsV0FBVyxDQUF5QjtRQUNoRSxhQUFRLEdBQVIsUUFBUSxDQUFhO0lBRWhDLENBQUM7QUFDSCxDQUFDO0FBRUQ7SUFJRSxZQUNXLElBQVksRUFBUyxVQUFtQyxFQUFTLE1BQWM7UUFBL0UsU0FBSSxHQUFKLElBQUksQ0FBUTtRQUFTLGVBQVUsR0FBVixVQUFVLENBQXlCO1FBQVMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtJQUFHLENBQUM7SUFFOUYsUUFBUTtRQUNOLE1BQU0sTUFBTSxHQUFHLEVBQUUsQ0FBQztRQUNsQixHQUFHLENBQUMsQ0FBQyxJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztZQUNqQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3pDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDbEQsQ0FBQztRQUNILENBQUM7UUFDRCxNQUFNLFlBQVksR0FBRyxNQUFNLENBQUMsTUFBTSxHQUFHLENBQUMsR0FBRyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsR0FBRyxFQUFFLENBQUM7UUFDdEUsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sS0FBSyxjQUFjLEdBQUcsRUFBRSxHQUFHLEdBQUcsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDO1FBQ3ZFLE1BQU0sQ0FBQyxHQUFHLE1BQU0sR0FBRyxJQUFJLENBQUMsSUFBSSxHQUFHLFlBQVksRUFBRSxDQUFDO0lBQ2hELENBQUM7QUFDSCxDQUFDO0FBRUQsaUNBQWlDLENBQWUsRUFBRSxDQUFlO0lBQy9ELEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLE1BQU0sQ0FBQztRQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUM7SUFDeEMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7UUFDbEMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO1lBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUMxQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUM7SUFDcEUsQ0FBQztJQUNELE1BQU0sQ0FBQyxJQUFJLENBQUM7QUFDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtQUklNQVJZX09VVExFVH0gZnJvbSAnLi9zaGFyZWQnO1xuaW1wb3J0IHtzaGFsbG93RXF1YWx9IGZyb20gJy4vdXRpbHMvY29sbGVjdGlvbic7XG5pbXBvcnQge1RyZWUsIFRyZWVOb2RlfSBmcm9tICcuL3V0aWxzL3RyZWUnO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRW1wdHlVcmxUcmVlKCkge1xuICByZXR1cm4gbmV3IFVybFRyZWUoXG4gICAgICBuZXcgVHJlZU5vZGU8VXJsU2VnbWVudD4obmV3IFVybFNlZ21lbnQoJycsIHt9LCBQUklNQVJZX09VVExFVCksIFtdKSwge30sIG51bGwpO1xufVxuXG4vKipcbiAqIEEgVVJMIGluIHRoZSB0cmVlIGZvcm0uXG4gKi9cbmV4cG9ydCBjbGFzcyBVcmxUcmVlIGV4dGVuZHMgVHJlZTxVcmxTZWdtZW50PiB7XG4gIC8qKlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIGNvbnN0cnVjdG9yKFxuICAgICAgcm9vdDogVHJlZU5vZGU8VXJsU2VnbWVudD4sIHB1YmxpYyBxdWVyeVBhcmFtczoge1trZXk6IHN0cmluZ106IHN0cmluZ30sXG4gICAgICBwdWJsaWMgZnJhZ21lbnQ6IHN0cmluZ3xudWxsKSB7XG4gICAgc3VwZXIocm9vdCk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIFVybFNlZ21lbnQge1xuICAvKipcbiAgICogQGludGVybmFsXG4gICAqL1xuICBjb25zdHJ1Y3RvcihcbiAgICAgIHB1YmxpYyBwYXRoOiBzdHJpbmcsIHB1YmxpYyBwYXJhbWV0ZXJzOiB7W2tleTogc3RyaW5nXTogc3RyaW5nfSwgcHVibGljIG91dGxldDogc3RyaW5nKSB7fVxuXG4gIHRvU3RyaW5nKCkge1xuICAgIGNvbnN0IHBhcmFtcyA9IFtdO1xuICAgIGZvciAobGV0IHByb3AgaW4gdGhpcy5wYXJhbWV0ZXJzKSB7XG4gICAgICBpZiAodGhpcy5wYXJhbWV0ZXJzLmhhc093blByb3BlcnR5KHByb3ApKSB7XG4gICAgICAgIHBhcmFtcy5wdXNoKGAke3Byb3B9PSR7dGhpcy5wYXJhbWV0ZXJzW3Byb3BdfWApO1xuICAgICAgfVxuICAgIH1cbiAgICBjb25zdCBwYXJhbXNTdHJpbmcgPSBwYXJhbXMubGVuZ3RoID4gMCA/IGAoJHtwYXJhbXMuam9pbignLCcpfSlgIDogJyc7XG4gICAgY29uc3Qgb3V0bGV0ID0gdGhpcy5vdXRsZXQgPT09IFBSSU1BUllfT1VUTEVUID8gJycgOiBgJHt0aGlzLm91dGxldH06YDtcbiAgICByZXR1cm4gYCR7b3V0bGV0fSR7dGhpcy5wYXRofSR7cGFyYW1zU3RyaW5nfWA7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGVxdWFsVXJsU2VnbWVudHMoYTogVXJsU2VnbWVudFtdLCBiOiBVcmxTZWdtZW50W10pOiBib29sZWFuIHtcbiAgaWYgKGEubGVuZ3RoICE9PSBiLmxlbmd0aCkgcmV0dXJuIGZhbHNlO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IGEubGVuZ3RoOyArK2kpIHtcbiAgICBpZiAoYVtpXS5wYXRoICE9PSBiW2ldLnBhdGgpIHJldHVybiBmYWxzZTtcbiAgICBpZiAoIXNoYWxsb3dFcXVhbChhW2ldLnBhcmFtZXRlcnMsIGJbaV0ucGFyYW1ldGVycykpIHJldHVybiBmYWxzZTtcbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cbiJdfQ==
export function mapChildren(segment, fn) {
const newChildren = {};
forEach(segment.children, (child, childOutlet) => {
if (childOutlet === PRIMARY_OUTLET) {
newChildren[childOutlet] = fn(child, childOutlet);
}
});
forEach(segment.children, (child, childOutlet) => {
if (childOutlet !== PRIMARY_OUTLET) {
newChildren[childOutlet] = fn(child, childOutlet);
}
});
return newChildren;
}
export function mapChildrenIntoArray(segment, fn) {
let res = [];
forEach(segment.children, (child, childOutlet) => {
if (childOutlet === PRIMARY_OUTLET) {
res = res.concat(fn(child, childOutlet));
}
});
forEach(segment.children, (child, childOutlet) => {
if (childOutlet !== PRIMARY_OUTLET) {
res = res.concat(fn(child, childOutlet));
}
});
return res;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXJsX3RyZWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXJsX3RyZWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ik9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxVQUFVO09BQ2hDLEVBQUMsb0JBQW9CLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBQyxNQUFNLGtCQUFrQjtPQUM3RSxFQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUMsTUFBTSxvQkFBb0I7QUFFeEQ7SUFDRSxNQUFNLENBQUMsSUFBSSxPQUFPLENBQUMsSUFBSSxVQUFVLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUN2RCxDQUFDO0FBS0Q7SUFJRSxZQUNXLElBQWdCLEVBQVMsV0FBb0MsRUFDN0QsUUFBZ0I7UUFEaEIsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUFTLGdCQUFXLEdBQVgsV0FBVyxDQUF5QjtRQUM3RCxhQUFRLEdBQVIsUUFBUSxDQUFRO0lBQUcsQ0FBQztJQUUvQixRQUFRLEtBQWEsTUFBTSxDQUFDLElBQUksb0JBQW9CLEVBQUUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQzNFLENBQUM7QUFFRDtJQUVFLFlBQ1csZUFBb0MsRUFBUyxRQUFxQztRQUFsRixvQkFBZSxHQUFmLGVBQWUsQ0FBcUI7UUFBUyxhQUFRLEdBQVIsUUFBUSxDQUE2QjtRQUZ0RixXQUFNLEdBQWUsSUFBSSxDQUFDO1FBRy9CLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUVELFFBQVEsS0FBYSxNQUFNLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNyRCxDQUFDO0FBRUQ7SUFDRSxZQUFtQixJQUFZLEVBQVMsVUFBbUM7UUFBeEQsU0FBSSxHQUFKLElBQUksQ0FBUTtRQUFTLGVBQVUsR0FBVixVQUFVLENBQXlCO0lBQUcsQ0FBQztJQUMvRSxRQUFRLEtBQWEsTUFBTSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDcEQsQ0FBQztBQUVELHFDQUFxQyxDQUFzQixFQUFFLENBQXNCO0lBQ2pGLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLE1BQU0sQ0FBQztRQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUM7SUFDeEMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7UUFDbEMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO1lBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUMxQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUM7SUFDcEUsQ0FBQztJQUNELE1BQU0sQ0FBQyxJQUFJLENBQUM7QUFDZCxDQUFDO0FBRUQsNEJBQTRCLE9BQW1CLEVBQUUsRUFBNEM7SUFFM0YsTUFBTSxXQUFXLEdBQWlDLEVBQUUsQ0FBQztJQUNyRCxPQUFPLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLEtBQUssRUFBRSxXQUFXO1FBQzNDLEVBQUUsQ0FBQyxDQUFDLFdBQVcsS0FBSyxjQUFjLENBQUMsQ0FBQyxDQUFDO1lBQ25DLFdBQVcsQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBQ3BELENBQUM7SUFDSCxDQUFDLENBQUMsQ0FBQztJQUNILE9BQU8sQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsS0FBSyxFQUFFLFdBQVc7UUFDM0MsRUFBRSxDQUFDLENBQUMsV0FBVyxLQUFLLGNBQWMsQ0FBQyxDQUFDLENBQUM7WUFDbkMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLENBQUM7UUFDcEQsQ0FBQztJQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0gsTUFBTSxDQUFDLFdBQVcsQ0FBQztBQUNyQixDQUFDO0FBRUQscUNBQ0ksT0FBbUIsRUFBRSxFQUFxQztJQUM1RCxJQUFJLEdBQUcsR0FBRyxFQUFFLENBQUM7SUFDYixPQUFPLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLEtBQUssRUFBRSxXQUFXO1FBQzNDLEVBQUUsQ0FBQyxDQUFDLFdBQVcsS0FBSyxjQUFjLENBQUMsQ0FBQyxDQUFDO1lBQ25DLEdBQUcsR0FBRyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQztRQUMzQyxDQUFDO0lBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDSCxPQUFPLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDLEtBQUssRUFBRSxXQUFXO1FBQzNDLEVBQUUsQ0FBQyxDQUFDLFdBQVcsS0FBSyxjQUFjLENBQUMsQ0FBQyxDQUFDO1lBQ25DLEdBQUcsR0FBRyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQztRQUMzQyxDQUFDO0lBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDSCxNQUFNLENBQUMsR0FBRyxDQUFDO0FBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7UFJJTUFSWV9PVVRMRVR9IGZyb20gJy4vc2hhcmVkJztcbmltcG9ydCB7RGVmYXVsdFVybFNlcmlhbGl6ZXIsIHNlcmlhbGl6ZVBhdGgsIHNlcmlhbGl6ZVBhdGhzfSBmcm9tICcuL3VybF9zZXJpYWxpemVyJztcbmltcG9ydCB7Zm9yRWFjaCwgc2hhbGxvd0VxdWFsfSBmcm9tICcuL3V0aWxzL2NvbGxlY3Rpb24nO1xuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRW1wdHlVcmxUcmVlKCkge1xuICByZXR1cm4gbmV3IFVybFRyZWUobmV3IFVybFNlZ21lbnQoW10sIHt9KSwge30sIG51bGwpO1xufVxuXG4vKipcbiAqIEEgVVJMIGluIHRoZSB0cmVlIGZvcm0uXG4gKi9cbmV4cG9ydCBjbGFzcyBVcmxUcmVlIHtcbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgY29uc3RydWN0b3IoXG4gICAgICBwdWJsaWMgcm9vdDogVXJsU2VnbWVudCwgcHVibGljIHF1ZXJ5UGFyYW1zOiB7W2tleTogc3RyaW5nXTogc3RyaW5nfSxcbiAgICAgIHB1YmxpYyBmcmFnbWVudDogc3RyaW5nKSB7fVxuXG4gIHRvU3RyaW5nKCk6IHN0cmluZyB7IHJldHVybiBuZXcgRGVmYXVsdFVybFNlcmlhbGl6ZXIoKS5zZXJpYWxpemUodGhpcyk7IH1cbn1cblxuZXhwb3J0IGNsYXNzIFVybFNlZ21lbnQge1xuICBwdWJsaWMgcGFyZW50OiBVcmxTZWdtZW50ID0gbnVsbDtcbiAgY29uc3RydWN0b3IoXG4gICAgICBwdWJsaWMgcGF0aHNXaXRoUGFyYW1zOiBVcmxQYXRoV2l0aFBhcmFtc1tdLCBwdWJsaWMgY2hpbGRyZW46IHtba2V5OiBzdHJpbmddOiBVcmxTZWdtZW50fSkge1xuICAgIGZvckVhY2goY2hpbGRyZW4sICh2LCBrKSA9PiB2LnBhcmVudCA9IHRoaXMpO1xuICB9XG5cbiAgdG9TdHJpbmcoKTogc3RyaW5nIHsgcmV0dXJuIHNlcmlhbGl6ZVBhdGhzKHRoaXMpOyB9XG59XG5cbmV4cG9ydCBjbGFzcyBVcmxQYXRoV2l0aFBhcmFtcyB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBwYXRoOiBzdHJpbmcsIHB1YmxpYyBwYXJhbWV0ZXJzOiB7W2tleTogc3RyaW5nXTogc3RyaW5nfSkge31cbiAgdG9TdHJpbmcoKTogc3RyaW5nIHsgcmV0dXJuIHNlcmlhbGl6ZVBhdGgodGhpcyk7IH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGVxdWFsUGF0aHNXaXRoUGFyYW1zKGE6IFVybFBhdGhXaXRoUGFyYW1zW10sIGI6IFVybFBhdGhXaXRoUGFyYW1zW10pOiBib29sZWFuIHtcbiAgaWYgKGEubGVuZ3RoICE9PSBiLmxlbmd0aCkgcmV0dXJuIGZhbHNlO1xuICBmb3IgKGxldCBpID0gMDsgaSA8IGEubGVuZ3RoOyArK2kpIHtcbiAgICBpZiAoYVtpXS5wYXRoICE9PSBiW2ldLnBhdGgpIHJldHVybiBmYWxzZTtcbiAgICBpZiAoIXNoYWxsb3dFcXVhbChhW2ldLnBhcmFtZXRlcnMsIGJbaV0ucGFyYW1ldGVycykpIHJldHVybiBmYWxzZTtcbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG1hcENoaWxkcmVuKHNlZ21lbnQ6IFVybFNlZ21lbnQsIGZuOiAodjogVXJsU2VnbWVudCwgazogc3RyaW5nKSA9PiBVcmxTZWdtZW50KTpcbiAgICB7W25hbWU6IHN0cmluZ106IFVybFNlZ21lbnR9IHtcbiAgY29uc3QgbmV3Q2hpbGRyZW46IHtbbmFtZTogc3RyaW5nXTogVXJsU2VnbWVudH0gPSB7fTtcbiAgZm9yRWFjaChzZWdtZW50LmNoaWxkcmVuLCAoY2hpbGQsIGNoaWxkT3V0bGV0KSA9PiB7XG4gICAgaWYgKGNoaWxkT3V0bGV0ID09PSBQUklNQVJZX09VVExFVCkge1xuICAgICAgbmV3Q2hpbGRyZW5bY2hpbGRPdXRsZXRdID0gZm4oY2hpbGQsIGNoaWxkT3V0bGV0KTtcbiAgICB9XG4gIH0pO1xuICBmb3JFYWNoKHNlZ21lbnQuY2hpbGRyZW4sIChjaGlsZCwgY2hpbGRPdXRsZXQpID0+IHtcbiAgICBpZiAoY2hpbGRPdXRsZXQgIT09IFBSSU1BUllfT1VUTEVUKSB7XG4gICAgICBuZXdDaGlsZHJlbltjaGlsZE91dGxldF0gPSBmbihjaGlsZCwgY2hpbGRPdXRsZXQpO1xuICAgIH1cbiAgfSk7XG4gIHJldHVybiBuZXdDaGlsZHJlbjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG1hcENoaWxkcmVuSW50b0FycmF5PFQ+KFxuICAgIHNlZ21lbnQ6IFVybFNlZ21lbnQsIGZuOiAodjogVXJsU2VnbWVudCwgazogc3RyaW5nKSA9PiBUW10pOiBUW10ge1xuICBsZXQgcmVzID0gW107XG4gIGZvckVhY2goc2VnbWVudC5jaGlsZHJlbiwgKGNoaWxkLCBjaGlsZE91dGxldCkgPT4ge1xuICAgIGlmIChjaGlsZE91dGxldCA9PT0gUFJJTUFSWV9PVVRMRVQpIHtcbiAgICAgIHJlcyA9IHJlcy5jb25jYXQoZm4oY2hpbGQsIGNoaWxkT3V0bGV0KSk7XG4gICAgfVxuICB9KTtcbiAgZm9yRWFjaChzZWdtZW50LmNoaWxkcmVuLCAoY2hpbGQsIGNoaWxkT3V0bGV0KSA9PiB7XG4gICAgaWYgKGNoaWxkT3V0bGV0ICE9PSBQUklNQVJZX09VVExFVCkge1xuICAgICAgcmVzID0gcmVzLmNvbmNhdChmbihjaGlsZCwgY2hpbGRPdXRsZXQpKTtcbiAgICB9XG4gIH0pO1xuICByZXR1cm4gcmVzO1xufVxuIl19

@@ -7,4 +7,4 @@ export declare function shallowEqual(a: {

export declare function flatten<T>(a: T[][]): T[];
export declare function first<T>(a: T[]): T | null;
export declare function last<T>(a: T[]): T | null;
export declare function first<T>(a: T[]): T;
export declare function last<T>(a: T[]): T;
export declare function and(bools: boolean[]): boolean;

@@ -11,0 +11,0 @@ export declare function merge<V>(m1: {

@@ -55,2 +55,2 @@ export function shallowEqual(a, b) {

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9jb2xsZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDZCQUE2QixDQUFxQixFQUFFLENBQXFCO0lBQ3ZFLElBQUksRUFBRSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDeEIsSUFBSSxFQUFFLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN4QixFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsTUFBTSxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBQzNCLE1BQU0sQ0FBQyxLQUFLLENBQUM7SUFDZixDQUFDO0lBQ0QsSUFBSSxHQUFHLENBQUM7SUFDUixHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUNuQyxHQUFHLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ1osRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdEIsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUNmLENBQUM7SUFDSCxDQUFDO0lBQ0QsTUFBTSxDQUFDLElBQUksQ0FBQztBQUNkLENBQUM7QUFFRCx3QkFBMkIsQ0FBUTtJQUNqQyxNQUFNLE1BQU0sR0FBRyxFQUFFLENBQUM7SUFDbEIsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7UUFDbEMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7WUFDckMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN2QixDQUFDO0lBQ0gsQ0FBQztJQUNELE1BQU0sQ0FBQyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVELHNCQUF5QixDQUFNO0lBQzdCLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0FBQ3BDLENBQUM7QUFFRCxxQkFBd0IsQ0FBTTtJQUM1QixNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0FBQy9DLENBQUM7QUFFRCxvQkFBb0IsS0FBZ0I7SUFDbEMsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDOUMsQ0FBQztBQUVELHNCQUF5QixFQUFzQixFQUFFLEVBQXNCO0lBQ3JFLElBQUksQ0FBQyxHQUF1QixFQUFFLENBQUM7SUFFL0IsR0FBRyxDQUFDLENBQUMsSUFBSSxJQUFJLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNwQixFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM1QixDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLENBQUM7SUFDSCxDQUFDO0lBRUQsR0FBRyxDQUFDLENBQUMsSUFBSSxJQUFJLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNwQixFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM1QixDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLENBQUM7SUFDSCxDQUFDO0lBRUQsTUFBTSxDQUFDLENBQUMsQ0FBQztBQUNYLENBQUM7QUFFRCx3QkFDSSxHQUF1QixFQUFFLFFBQXFDO0lBQ2hFLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDckIsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDN0IsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUM1QixDQUFDO0lBQ0gsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gc2hhbGxvd0VxdWFsKGE6IHtbeDogc3RyaW5nXTogYW55fSwgYjoge1t4OiBzdHJpbmddOiBhbnl9KTogYm9vbGVhbiB7XG4gIHZhciBrMSA9IE9iamVjdC5rZXlzKGEpO1xuICB2YXIgazIgPSBPYmplY3Qua2V5cyhiKTtcbiAgaWYgKGsxLmxlbmd0aCAhPSBrMi5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgdmFyIGtleTtcbiAgZm9yICh2YXIgaSA9IDA7IGkgPCBrMS5sZW5ndGg7IGkrKykge1xuICAgIGtleSA9IGsxW2ldO1xuICAgIGlmIChhW2tleV0gIT09IGJba2V5XSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZsYXR0ZW48VD4oYTogVFtdW10pOiBUW10ge1xuICBjb25zdCB0YXJnZXQgPSBbXTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgKytpKSB7XG4gICAgZm9yIChsZXQgaiA9IDA7IGogPCBhW2ldLmxlbmd0aDsgKytqKSB7XG4gICAgICB0YXJnZXQucHVzaChhW2ldW2pdKTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHRhcmdldDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZpcnN0PFQ+KGE6IFRbXSk6IFR8bnVsbCB7XG4gIHJldHVybiBhLmxlbmd0aCA+IDAgPyBhWzBdIDogbnVsbDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGxhc3Q8VD4oYTogVFtdKTogVHxudWxsIHtcbiAgcmV0dXJuIGEubGVuZ3RoID4gMCA/IGFbYS5sZW5ndGggLSAxXSA6IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhbmQoYm9vbHM6IGJvb2xlYW5bXSk6IGJvb2xlYW4ge1xuICByZXR1cm4gYm9vbHMucmVkdWNlKChhLCBiKSA9PiBhICYmIGIsIHRydWUpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWVyZ2U8Vj4obTE6IHtba2V5OiBzdHJpbmddOiBWfSwgbTI6IHtba2V5OiBzdHJpbmddOiBWfSk6IHtba2V5OiBzdHJpbmddOiBWfSB7XG4gIHZhciBtOiB7W2tleTogc3RyaW5nXTogVn0gPSB7fTtcblxuICBmb3IgKHZhciBhdHRyIGluIG0xKSB7XG4gICAgaWYgKG0xLmhhc093blByb3BlcnR5KGF0dHIpKSB7XG4gICAgICBtW2F0dHJdID0gbTFbYXR0cl07XG4gICAgfVxuICB9XG5cbiAgZm9yICh2YXIgYXR0ciBpbiBtMikge1xuICAgIGlmIChtMi5oYXNPd25Qcm9wZXJ0eShhdHRyKSkge1xuICAgICAgbVthdHRyXSA9IG0yW2F0dHJdO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBtO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZm9yRWFjaDxLLCBWPihcbiAgICBtYXA6IHtba2V5OiBzdHJpbmddOiBWfSwgY2FsbGJhY2s6IC8qKFYsIEspID0+IHZvaWQqLyBGdW5jdGlvbik6IHZvaWQge1xuICBmb3IgKHZhciBwcm9wIGluIG1hcCkge1xuICAgIGlmIChtYXAuaGFzT3duUHJvcGVydHkocHJvcCkpIHtcbiAgICAgIGNhbGxiYWNrKG1hcFtwcm9wXSwgcHJvcCk7XG4gICAgfVxuICB9XG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9jb2xsZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDZCQUE2QixDQUFxQixFQUFFLENBQXFCO0lBQ3ZFLElBQUksRUFBRSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDeEIsSUFBSSxFQUFFLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN4QixFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsTUFBTSxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO1FBQzNCLE1BQU0sQ0FBQyxLQUFLLENBQUM7SUFDZixDQUFDO0lBQ0QsSUFBSSxHQUFHLENBQUM7SUFDUixHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUNuQyxHQUFHLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ1osRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdEIsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUNmLENBQUM7SUFDSCxDQUFDO0lBQ0QsTUFBTSxDQUFDLElBQUksQ0FBQztBQUNkLENBQUM7QUFFRCx3QkFBMkIsQ0FBUTtJQUNqQyxNQUFNLE1BQU0sR0FBRyxFQUFFLENBQUM7SUFDbEIsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7UUFDbEMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUM7WUFDckMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN2QixDQUFDO0lBQ0gsQ0FBQztJQUNELE1BQU0sQ0FBQyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVELHNCQUF5QixDQUFNO0lBQzdCLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0FBQ3BDLENBQUM7QUFFRCxxQkFBd0IsQ0FBTTtJQUM1QixNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0FBQy9DLENBQUM7QUFFRCxvQkFBb0IsS0FBZ0I7SUFDbEMsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDOUMsQ0FBQztBQUVELHNCQUF5QixFQUFzQixFQUFFLEVBQXNCO0lBQ3JFLElBQUksQ0FBQyxHQUF1QixFQUFFLENBQUM7SUFFL0IsR0FBRyxDQUFDLENBQUMsSUFBSSxJQUFJLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNwQixFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM1QixDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLENBQUM7SUFDSCxDQUFDO0lBRUQsR0FBRyxDQUFDLENBQUMsSUFBSSxJQUFJLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNwQixFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM1QixDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JCLENBQUM7SUFDSCxDQUFDO0lBRUQsTUFBTSxDQUFDLENBQUMsQ0FBQztBQUNYLENBQUM7QUFFRCx3QkFDSSxHQUF1QixFQUFFLFFBQXFDO0lBQ2hFLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDckIsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDN0IsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUM1QixDQUFDO0lBQ0gsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gc2hhbGxvd0VxdWFsKGE6IHtbeDogc3RyaW5nXTogYW55fSwgYjoge1t4OiBzdHJpbmddOiBhbnl9KTogYm9vbGVhbiB7XG4gIHZhciBrMSA9IE9iamVjdC5rZXlzKGEpO1xuICB2YXIgazIgPSBPYmplY3Qua2V5cyhiKTtcbiAgaWYgKGsxLmxlbmd0aCAhPSBrMi5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgdmFyIGtleTtcbiAgZm9yICh2YXIgaSA9IDA7IGkgPCBrMS5sZW5ndGg7IGkrKykge1xuICAgIGtleSA9IGsxW2ldO1xuICAgIGlmIChhW2tleV0gIT09IGJba2V5XSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZsYXR0ZW48VD4oYTogVFtdW10pOiBUW10ge1xuICBjb25zdCB0YXJnZXQgPSBbXTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgKytpKSB7XG4gICAgZm9yIChsZXQgaiA9IDA7IGogPCBhW2ldLmxlbmd0aDsgKytqKSB7XG4gICAgICB0YXJnZXQucHVzaChhW2ldW2pdKTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHRhcmdldDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZpcnN0PFQ+KGE6IFRbXSk6IFQge1xuICByZXR1cm4gYS5sZW5ndGggPiAwID8gYVswXSA6IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBsYXN0PFQ+KGE6IFRbXSk6IFQge1xuICByZXR1cm4gYS5sZW5ndGggPiAwID8gYVthLmxlbmd0aCAtIDFdIDogbnVsbDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFuZChib29sczogYm9vbGVhbltdKTogYm9vbGVhbiB7XG4gIHJldHVybiBib29scy5yZWR1Y2UoKGEsIGIpID0+IGEgJiYgYiwgdHJ1ZSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBtZXJnZTxWPihtMToge1trZXk6IHN0cmluZ106IFZ9LCBtMjoge1trZXk6IHN0cmluZ106IFZ9KToge1trZXk6IHN0cmluZ106IFZ9IHtcbiAgdmFyIG06IHtba2V5OiBzdHJpbmddOiBWfSA9IHt9O1xuXG4gIGZvciAodmFyIGF0dHIgaW4gbTEpIHtcbiAgICBpZiAobTEuaGFzT3duUHJvcGVydHkoYXR0cikpIHtcbiAgICAgIG1bYXR0cl0gPSBtMVthdHRyXTtcbiAgICB9XG4gIH1cblxuICBmb3IgKHZhciBhdHRyIGluIG0yKSB7XG4gICAgaWYgKG0yLmhhc093blByb3BlcnR5KGF0dHIpKSB7XG4gICAgICBtW2F0dHJdID0gbTJbYXR0cl07XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmb3JFYWNoPEssIFY+KFxuICAgIG1hcDoge1trZXk6IHN0cmluZ106IFZ9LCBjYWxsYmFjazogLyooViwgSykgPT4gdm9pZCovIEZ1bmN0aW9uKTogdm9pZCB7XG4gIGZvciAodmFyIHByb3AgaW4gbWFwKSB7XG4gICAgaWYgKG1hcC5oYXNPd25Qcm9wZXJ0eShwcm9wKSkge1xuICAgICAgY2FsbGJhY2sobWFwW3Byb3BdLCBwcm9wKTtcbiAgICB9XG4gIH1cbn0iXX0=
export declare class Tree<T> {
_root: TreeNode<T>;
constructor(root: TreeNode<T>);
readonly root: T;
parent(t: T): T | null;
root: T;
parent(t: T): T;
children(t: T): T[];
firstChild(t: T): T | null;
firstChild(t: T): T;
siblings(t: T): T[];

@@ -16,2 +16,3 @@ pathFromRoot(t: T): T[];

constructor(value: T, children: TreeNode<T>[]);
toString(): string;
}

@@ -67,3 +67,4 @@ export class Tree {

}
toString() { return `TreeNode(${this.value})`; }
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy90cmVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0lBSUUsWUFBWSxJQUFpQjtRQUFJLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO0lBQUMsQ0FBQztJQUVyRCxJQUFJLElBQUksS0FBUSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBRTFDLE1BQU0sQ0FBQyxDQUFJO1FBQ1QsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMvQixNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0lBQy9DLENBQUM7SUFFRCxRQUFRLENBQUMsQ0FBSTtRQUNYLE1BQU0sQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2xDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDL0MsQ0FBQztJQUVELFVBQVUsQ0FBQyxDQUFJO1FBQ2IsTUFBTSxDQUFDLEdBQUcsUUFBUSxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO0lBQ2pFLENBQUM7SUFFRCxRQUFRLENBQUMsQ0FBSTtRQUNYLE1BQU0sQ0FBQyxHQUFHLFFBQVEsQ0FBQyxD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LENBQUMsS0FBSyxDQUFDO0lBQ2pELENBQUM7SUFFRCxNQUFNLENBQUMsSUFBSSxDQUFDO0FBQ2QsQ0FBQztBQUVEO0lBQ0UsWUFBbUIsS0FBUSxFQUFTLFFBQXVCO1FBQXhDLFVBQUssR0FBTCxLQUFLLENBQUc7UUFBUyxhQUFRLEdBQVIsUUFBUSxDQUFlO0lBQUcsQ0FBQztBQUNqRSxDQUFDO0FBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgVHJlZTxUPiB7XG4gIC8qKiBAaW50ZXJuYWwgKi9cbiAgX3Jvb3Q6IFRyZWVOb2RlPFQ+O1xuXG4gIGNvbnN0cnVjdG9yKHJvb3Q6IFRyZWVOb2RlPFQ+KSB7IHRoaXMuX3Jvb3QgPSByb290OyB9XG5cbiAgZ2V0IHJvb3QoKTogVCB7IHJldHVybiB0aGlzLl9yb290LnZhbHVlOyB9XG5cbiAgcGFyZW50KHQ6IFQpOiBUfG51bGwge1xuICAgIGNvbnN0IHAgPSB0aGlzLnBhdGhGcm9tUm9vdCh0KTtcbiAgICByZXR1cm4gcC5sZW5ndGggPiAxID8gcFtwLmxlbmd0aCAtIDJdIDogbnVsbDtcbiAgfVxuXG4gIGNoaWxkcmVuKHQ6IFQpOiBUW10ge1xuICAgIGNvbnN0IG4gPSBmaW5kTm9kZSh0LCB0aGlzLl9yb290KTtcbiAgICByZXR1cm4gbiA/IG4uY2hpbGRyZW4ubWFwKHQgPT4gdC52YWx1ZSkgOiBbXTtcbiAgfVxuXG4gIGZpcnN0Q2hpbGQodDogVCk6IFR8bnVsbCB7XG4gICAgY29uc3QgbiA9IGZpbmROb2RlKHQsIHRoaXMuX3Jvb3QpO1xuICAgIHJldHVybiBuICYmIG4uY2hpbGRyZW4ubGVuZ3RoID4gMCA/IG4uY2hpbGRyZW5bMF0udmFsdWUgOiBudWxsO1xuICB9XG5cbiAgc2libGluZ3ModDogVCk6IFRbXSB7XG4gICAgY29uc3QgcCA9IGZpbmRQYXRoKHQsIHRoaXMuX3Jvb3QsIFtdKTtcbiAgICBpZiAocC5sZW5ndGggPCAyKSByZXR1cm4gW107XG5cbiAgICBjb25zdCBjID0gcFtwLmxlbmd0aCAtIDJdLmNoaWxkcmVuLm1hcChjID0+IGMudmFsdWUpO1xuICAgIHJldHVybiBjLmZpbHRlcihjYyA9PiBjYyAhPT0gdCk7XG4gIH1cblxuICBwYXRoRnJvbVJvb3QodDogVCk6IFRbXSB7IHJldHVybiBmaW5kUGF0aCh0LCB0aGlzLl9yb290LCBbXSkubWFwKHMgPT4gcy52YWx1ZSk7IH1cblxuICBjb250YWlucyh0cmVlOiBUcmVlPFQ+KTogYm9vbGVhbiB7IHJldHVybiBjb250YWlucyh0aGlzLl9yb290LCB0cmVlLl9yb290KTsgfVxufVxuXG5mdW5jdGlvbiBmaW5kTm9kZTxUPihleHBlY3RlZDogVCwgYzogVHJlZU5vZGU8VD4pOiBUcmVlTm9kZTxUPnxudWxsIHtcbiAgaWYgKGV4cGVjdGVkID09PSBjLnZhbHVlKSByZXR1cm4gYztcbiAgZm9yIChsZXQgY2Mgb2YgYy5jaGlsZHJlbikge1xuICAgIGNvbnN0IHIgPSBmaW5kTm9kZShleHBlY3RlZCwgY2MpO1xuICAgIGlmIChyKSByZXR1cm4gcjtcbiAgfVxuICByZXR1cm4gbnVsbDtcbn1cblxuZnVuY3Rpb24gZmluZFBhdGg8VD4oZXhwZWN0ZWQ6IFQsIGM6IFRyZWVOb2RlPFQ+LCBjb2xsZWN0ZWQ6IFRyZWVOb2RlPFQ+W10pOiBUcmVlTm9kZTxUPltdIHtcbiAgY29sbGVjdGVkLnB1c2goYyk7XG4gIGlmIChleHBlY3RlZCA9PT0gYy52YWx1ZSkgcmV0dXJuIGNvbGxlY3RlZDtcblxuICBmb3IgKGxldCBjYyBvZiBjLmNoaWxkcmVuKSB7XG4gICAgY29uc3QgY2xvbmVkID0gY29sbGVjdGVkLnNsaWNlKDApO1xuICAgIGNvbnN0IHIgPSBmaW5kUGF0aChleHBlY3RlZCwgY2MsIGNsb25lZCk7XG4gICAgaWYgKHIpIHJldHVybiByO1xuICB9XG5cbiAgcmV0dXJuIFtdO1xufVxuXG5mdW5jdGlvbiBjb250YWluczxUPih0cmVlOiBUcmVlTm9kZTxUPiwgc3VidHJlZTogVHJlZU5vZGU8VD4pOiBib29sZWFuIHtcbiAgaWYgKHRyZWUudmFsdWUgIT09IHN1YnRyZWUudmFsdWUpIHJldHVybiBmYWxzZTtcblxuICBmb3IgKGxldCBzdWJ0cmVlTm9kZSBvZiBzdWJ0cmVlLmNoaWxkcmVuKSB7XG4gICAgY29uc3QgcyA9IHRyZWUuY2hpbGRyZW4uZmlsdGVyKGNoaWxkID0+IGNoaWxkLnZhbHVlID09PSBzdWJ0cmVlTm9kZS52YWx1ZSk7XG4gICAgaWYgKHMubGVuZ3RoID09PSAwKSByZXR1cm4gZmFsc2U7XG4gICAgaWYgKCFjb250YWlucyhzWzBdLCBzdWJ0cmVlTm9kZSkpIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG5leHBvcnQgY2xhc3MgVHJlZU5vZGU8VD4ge1xuICBjb25zdHJ1Y3RvcihwdWJsaWMgdmFsdWU6IFQsIHB1YmxpYyBjaGlsZHJlbjogVHJlZU5vZGU8VD5bXSkge31cbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy90cmVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0lBSUUsWUFBWSxJQUFpQjtRQUFJLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO0lBQUMsQ0FBQztJQUVyRCxJQUFJLElBQUksS0FBUSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBRTFDLE1BQU0sQ0FBQyxDQUFJO1FBQ1QsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMvQixNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0lBQy9DLENBQUM7SUFFRCxRQUFRLENBQUMsQ0FBSTtRQUNYLE1BQU0sQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2xDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDL0MsQ0FBQztJQUVELFVBQVUsQ0FBQyxDQUFJO1FBQ2IsTUFBTSxDQUFDLEdBQUcsUUFBUSxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO0lBQ2pFLENBQUM7SUFFRCxRQUFRLENBQUMsQ0FBSTtRQUNYLE1BQU0sQ0FBQyxHQUFHLFFBQVEsQ0FBQyxD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LENBQUMsS0FBSyxDQUFDO0lBQ2pELENBQUM7SUFFRCxNQUFNLENBQUMsSUFBSSxDQUFDO0FBQ2QsQ0FBQztBQUVEO0lBQ0UsWUFBbUIsS0FBUSxFQUFTLFFBQXVCO1FBQXhDLFVBQUssR0FBTCxLQUFLLENBQUc7UUFBUyxhQUFRLEdBQVIsUUFBUSxDQUFlO0lBQUcsQ0FBQztJQUUvRCxRQUFRLEtBQWEsTUFBTSxDQUFDLFlBQVksSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQztBQUMxRCxDQUFDO0FBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgVHJlZTxUPiB7XG4gIC8qKiBAaW50ZXJuYWwgKi9cbiAgX3Jvb3Q6IFRyZWVOb2RlPFQ+O1xuXG4gIGNvbnN0cnVjdG9yKHJvb3Q6IFRyZWVOb2RlPFQ+KSB7IHRoaXMuX3Jvb3QgPSByb290OyB9XG5cbiAgZ2V0IHJvb3QoKTogVCB7IHJldHVybiB0aGlzLl9yb290LnZhbHVlOyB9XG5cbiAgcGFyZW50KHQ6IFQpOiBUIHtcbiAgICBjb25zdCBwID0gdGhpcy5wYXRoRnJvbVJvb3QodCk7XG4gICAgcmV0dXJuIHAubGVuZ3RoID4gMSA/IHBbcC5sZW5ndGggLSAyXSA6IG51bGw7XG4gIH1cblxuICBjaGlsZHJlbih0OiBUKTogVFtdIHtcbiAgICBjb25zdCBuID0gZmluZE5vZGUodCwgdGhpcy5fcm9vdCk7XG4gICAgcmV0dXJuIG4gPyBuLmNoaWxkcmVuLm1hcCh0ID0+IHQudmFsdWUpIDogW107XG4gIH1cblxuICBmaXJzdENoaWxkKHQ6IFQpOiBUIHtcbiAgICBjb25zdCBuID0gZmluZE5vZGUodCwgdGhpcy5fcm9vdCk7XG4gICAgcmV0dXJuIG4gJiYgbi5jaGlsZHJlbi5sZW5ndGggPiAwID8gbi5jaGlsZHJlblswXS52YWx1ZSA6IG51bGw7XG4gIH1cblxuICBzaWJsaW5ncyh0OiBUKTogVFtdIHtcbiAgICBjb25zdCBwID0gZmluZFBhdGgodCwgdGhpcy5fcm9vdCwgW10pO1xuICAgIGlmIChwLmxlbmd0aCA8IDIpIHJldHVybiBbXTtcblxuICAgIGNvbnN0IGMgPSBwW3AubGVuZ3RoIC0gMl0uY2hpbGRyZW4ubWFwKGMgPT4gYy52YWx1ZSk7XG4gICAgcmV0dXJuIGMuZmlsdGVyKGNjID0+IGNjICE9PSB0KTtcbiAgfVxuXG4gIHBhdGhGcm9tUm9vdCh0OiBUKTogVFtdIHsgcmV0dXJuIGZpbmRQYXRoKHQsIHRoaXMuX3Jvb3QsIFtdKS5tYXAocyA9PiBzLnZhbHVlKTsgfVxuXG4gIGNvbnRhaW5zKHRyZWU6IFRyZWU8VD4pOiBib29sZWFuIHsgcmV0dXJuIGNvbnRhaW5zKHRoaXMuX3Jvb3QsIHRyZWUuX3Jvb3QpOyB9XG59XG5cbmZ1bmN0aW9uIGZpbmROb2RlPFQ+KGV4cGVjdGVkOiBULCBjOiBUcmVlTm9kZTxUPik6IFRyZWVOb2RlPFQ+IHtcbiAgaWYgKGV4cGVjdGVkID09PSBjLnZhbHVlKSByZXR1cm4gYztcbiAgZm9yIChsZXQgY2Mgb2YgYy5jaGlsZHJlbikge1xuICAgIGNvbnN0IHIgPSBmaW5kTm9kZShleHBlY3RlZCwgY2MpO1xuICAgIGlmIChyKSByZXR1cm4gcjtcbiAgfVxuICByZXR1cm4gbnVsbDtcbn1cblxuZnVuY3Rpb24gZmluZFBhdGg8VD4oZXhwZWN0ZWQ6IFQsIGM6IFRyZWVOb2RlPFQ+LCBjb2xsZWN0ZWQ6IFRyZWVOb2RlPFQ+W10pOiBUcmVlTm9kZTxUPltdIHtcbiAgY29sbGVjdGVkLnB1c2goYyk7XG4gIGlmIChleHBlY3RlZCA9PT0gYy52YWx1ZSkgcmV0dXJuIGNvbGxlY3RlZDtcblxuICBmb3IgKGxldCBjYyBvZiBjLmNoaWxkcmVuKSB7XG4gICAgY29uc3QgY2xvbmVkID0gY29sbGVjdGVkLnNsaWNlKDApO1xuICAgIGNvbnN0IHIgPSBmaW5kUGF0aChleHBlY3RlZCwgY2MsIGNsb25lZCk7XG4gICAgaWYgKHIpIHJldHVybiByO1xuICB9XG5cbiAgcmV0dXJuIFtdO1xufVxuXG5mdW5jdGlvbiBjb250YWluczxUPih0cmVlOiBUcmVlTm9kZTxUPiwgc3VidHJlZTogVHJlZU5vZGU8VD4pOiBib29sZWFuIHtcbiAgaWYgKHRyZWUudmFsdWUgIT09IHN1YnRyZWUudmFsdWUpIHJldHVybiBmYWxzZTtcblxuICBmb3IgKGxldCBzdWJ0cmVlTm9kZSBvZiBzdWJ0cmVlLmNoaWxkcmVuKSB7XG4gICAgY29uc3QgcyA9IHRyZWUuY2hpbGRyZW4uZmlsdGVyKGNoaWxkID0+IGNoaWxkLnZhbHVlID09PSBzdWJ0cmVlTm9kZS52YWx1ZSk7XG4gICAgaWYgKHMubGVuZ3RoID09PSAwKSByZXR1cm4gZmFsc2U7XG4gICAgaWYgKCFjb250YWlucyhzWzBdLCBzdWJ0cmVlTm9kZSkpIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG5leHBvcnQgY2xhc3MgVHJlZU5vZGU8VD4ge1xuICBjb25zdHJ1Y3RvcihwdWJsaWMgdmFsdWU6IFQsIHB1YmxpYyBjaGlsZHJlbjogVHJlZU5vZGU8VD5bXSkge31cblxuICB0b1N0cmluZygpOiBzdHJpbmcgeyByZXR1cm4gYFRyZWVOb2RlKCR7dGhpcy52YWx1ZX0pYDsgfVxufSJdfQ==
import { RouterLink } from './directives/router_link';
import { RouterOutlet } from './directives/router_outlet';
export { ExtraOptions } from './common_router_providers';
export { Route, RouterConfig } from './config';
export { CanActivate, CanDeactivate } from './interfaces';
export { Event, NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router } from './router';
export { Event, NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router, RoutesRecognized } from './router';
export { RouterOutletMap } from './router_outlet_map';

@@ -11,3 +12,3 @@ export { provideRouter } from './router_providers';

export { DefaultUrlSerializer, UrlSerializer } from './url_serializer';
export { UrlSegment, UrlTree } from './url_tree';
export { UrlPathWithParams, UrlTree } from './url_tree';
export declare const ROUTER_DIRECTIVES: (typeof RouterOutlet | typeof RouterLink)[];

@@ -10,2 +10,3 @@ "use strict";

exports.Router = router_1.Router;
exports.RoutesRecognized = router_1.RoutesRecognized;
var router_outlet_map_1 = require('./router_outlet_map');

@@ -26,5 +27,5 @@ exports.RouterOutletMap = router_outlet_map_1.RouterOutletMap;

var url_tree_1 = require('./url_tree');
exports.UrlSegment = url_tree_1.UrlSegment;
exports.UrlPathWithParams = url_tree_1.UrlPathWithParams;
exports.UrlTree = url_tree_1.UrlTree;
exports.ROUTER_DIRECTIVES = [router_outlet_1.RouterOutlet, router_link_1.RouterLink];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDRCQUF5QiwwQkFBMEIsQ0FBQyxDQUFBO0FBQ3BELDhCQUEyQiw0QkFBNEIsQ0FBQyxDQUFBO0FBSXhELHVCQUErRixVQUFVLENBQUM7QUFBM0YscURBQWdCO0FBQUUsK0NBQWE7QUFBRSxtREFBZTtBQUFFLG1EQUFlO0FBQUUsaUNBQXdCO0FBQzFHLGtDQUE4QixxQkFBcUIsQ0FBQztBQUE1Qyw4REFBNEM7QUFDcEQsaUNBQTRCLG9CQUFvQixDQUFDO0FBQXpDLHlEQUF5QztBQUNqRCw2QkFBdUYsZ0JBQWdCLENBQUM7QUFBaEcsdURBQWM7QUFBRSx1RUFBc0I7QUFBRSxpREFBVztBQUFFLGlFQUEyQztBQUN4Ryx1QkFBcUMsVUFBVSxDQUFDO0FBQXhDLGlEQUF3QztBQUNoRCwrQkFBa0Qsa0JBQWtCLENBQUM7QUFBN0QscUVBQW9CO0FBQUUsdURBQXVDO0FBQ3JFLHlCQUFrQyxZQUFZLENBQUM7QUFBdkMsMkNBQVU7QUFBRSxxQ0FBMkI7QUFFbEMseUJBQWlCLEdBQUcsQ0FBQyw0QkFBWSxFQUFFLHdCQUFVLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Um91dGVyTGlua30gZnJvbSAnLi9kaXJlY3RpdmVzL3JvdXRlcl9saW5rJztcbmltcG9ydCB7Um91dGVyT3V0bGV0fSBmcm9tICcuL2RpcmVjdGl2ZXMvcm91dGVyX291dGxldCc7XG5cbmV4cG9ydCB7Um91dGUsIFJvdXRlckNvbmZpZ30gZnJvbSAnLi9jb25maWcnO1xuZXhwb3J0IHtDYW5BY3RpdmF0ZSwgQ2FuRGVhY3RpdmF0ZX0gZnJvbSAnLi9pbnRlcmZhY2VzJztcbmV4cG9ydCB7RXZlbnQsIE5hdmlnYXRpb25DYW5jZWwsIE5hdmlnYXRpb25FbmQsIE5hdmlnYXRpb25FcnJvciwgTmF2aWdhdGlvblN0YXJ0LCBSb3V0ZXJ9IGZyb20gJy4vcm91dGVyJztcbmV4cG9ydCB7Um91dGVyT3V0bGV0TWFwfSBmcm9tICcuL3JvdXRlcl9vdXRsZXRfbWFwJztcbmV4cG9ydCB7cHJvdmlkZVJvdXRlcn0gZnJvbSAnLi9yb3V0ZXJfcHJvdmlkZXJzJztcbmV4cG9ydCB7QWN0aXZhdGVkUm91dGUsIEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIFJvdXRlclN0YXRlLCBSb3V0ZXJTdGF0ZVNuYXBzaG90fSBmcm9tICcuL3JvdXRlcl9zdGF0ZSc7XG5leHBvcnQge1BSSU1BUllfT1VUTEVULCBQYXJhbXN9IGZyb20gJy4vc2hhcmVkJztcbmV4cG9ydCB7RGVmYXVsdFVybFNlcmlhbGl6ZXIsIFVybFNlcmlhbGl6ZXJ9IGZyb20gJy4vdXJsX3NlcmlhbGl6ZXInO1xuZXhwb3J0IHtVcmxTZWdtZW50LCBVcmxUcmVlfSBmcm9tICcuL3VybF90cmVlJztcblxuZXhwb3J0IGNvbnN0IFJPVVRFUl9ESVJFQ1RJVkVTID0gW1JvdXRlck91dGxldCwgUm91dGVyTGlua107Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDRCQUF5QiwwQkFBMEIsQ0FBQyxDQUFBO0FBQ3BELDhCQUEyQiw0QkFBNEIsQ0FBQyxDQUFBO0FBS3hELHVCQUFpSCxVQUFVLENBQUM7QUFBN0cscURBQWdCO0FBQUUsK0NBQWE7QUFBRSxtREFBZTtBQUFFLG1EQUFlO0FBQUUsaUNBQU07QUFBRSxxREFBa0M7QUFDNUgsa0NBQThCLHFCQUFxQixDQUFDO0FBQTVDLDhEQUE0QztBQUNwRCxpQ0FBNEIsb0JBQW9CLENBQUM7QUFBekMseURBQXlDO0FBQ2pELDZCQUF1RixnQkFBZ0IsQ0FBQztBQUFoRyx1REFBYztBQUFFLHVFQUFzQjtBQUFFLGlEQUFXO0FBQUUsaUVBQTJDO0FBQ3hHLHVCQUFxQyxVQUFVLENBQUM7QUFBeEMsaURBQXdDO0FBQ2hELCtCQUFrRCxrQkFBa0IsQ0FBQztBQUE3RCxxRUFBb0I7QUFBRSx1REFBdUM7QUFDckUseUJBQXlDLFlBQVksQ0FBQztBQUE5Qyx5REFBaUI7QUFBRSxxQ0FBMkI7QUFFekMseUJBQWlCLEdBQUcsQ0FBQyw0QkFBWSxFQUFFLHdCQUFVLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Um91dGVyTGlua30gZnJvbSAnLi9kaXJlY3RpdmVzL3JvdXRlcl9saW5rJztcbmltcG9ydCB7Um91dGVyT3V0bGV0fSBmcm9tICcuL2RpcmVjdGl2ZXMvcm91dGVyX291dGxldCc7XG5cbmV4cG9ydCB7RXh0cmFPcHRpb25zfSBmcm9tICcuL2NvbW1vbl9yb3V0ZXJfcHJvdmlkZXJzJztcbmV4cG9ydCB7Um91dGUsIFJvdXRlckNvbmZpZ30gZnJvbSAnLi9jb25maWcnO1xuZXhwb3J0IHtDYW5BY3RpdmF0ZSwgQ2FuRGVhY3RpdmF0ZX0gZnJvbSAnLi9pbnRlcmZhY2VzJztcbmV4cG9ydCB7RXZlbnQsIE5hdmlnYXRpb25DYW5jZWwsIE5hdmlnYXRpb25FbmQsIE5hdmlnYXRpb25FcnJvciwgTmF2aWdhdGlvblN0YXJ0LCBSb3V0ZXIsIFJvdXRlc1JlY29nbml6ZWR9IGZyb20gJy4vcm91dGVyJztcbmV4cG9ydCB7Um91dGVyT3V0bGV0TWFwfSBmcm9tICcuL3JvdXRlcl9vdXRsZXRfbWFwJztcbmV4cG9ydCB7cHJvdmlkZVJvdXRlcn0gZnJvbSAnLi9yb3V0ZXJfcHJvdmlkZXJzJztcbmV4cG9ydCB7QWN0aXZhdGVkUm91dGUsIEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIFJvdXRlclN0YXRlLCBSb3V0ZXJTdGF0ZVNuYXBzaG90fSBmcm9tICcuL3JvdXRlcl9zdGF0ZSc7XG5leHBvcnQge1BSSU1BUllfT1VUTEVULCBQYXJhbXN9IGZyb20gJy4vc2hhcmVkJztcbmV4cG9ydCB7RGVmYXVsdFVybFNlcmlhbGl6ZXIsIFVybFNlcmlhbGl6ZXJ9IGZyb20gJy4vdXJsX3NlcmlhbGl6ZXInO1xuZXhwb3J0IHtVcmxQYXRoV2l0aFBhcmFtcywgVXJsVHJlZX0gZnJvbSAnLi91cmxfdHJlZSc7XG5cbmV4cG9ydCBjb25zdCBST1VURVJfRElSRUNUSVZFUyA9IFtSb3V0ZXJPdXRsZXQsIFJvdXRlckxpbmtdOyJdfQ==
{
"name": "@angular/router",
"version": "3.0.0-alpha.3",
"version": "3.0.0-alpha.4",
"description": "",

@@ -58,3 +58,3 @@ "main": "./index.js",

"tsd": "^0.6.5",
"typescript": "^1.9.0-dev.20160409",
"typescript": "^1.8.10",
"typings": "^1.0.4",

@@ -61,0 +61,0 @@ "zone.js": "^0.6.6",

# Router
Managing state transitions is one of the hardest parts of building applications. This is especially true on the web, where you also need to ensure that the state is reflected in the URL. In addition, we often want to split applications into multiple bundles and load them on demand. Doing this transparently isn’t trivial.
The Angular router is designed to solve these problems. Using the router, you can declaratively specify application state, manage state transitions while taking care of the URL, and load components on demand. In this article I will discuss the API of the router, as well as the mental model and the design principles behind it.
Read the in-depth overview of the Router [here](http://victorsavkin.com/post/145672529346/angular-router).

@@ -6,2 +6,2 @@ import { Type } from '@angular/core';

import { UrlTree } from './url_tree';
export declare function recognize(rootComponentType: Type, config: RouterConfig, url: UrlTree): Observable<RouterStateSnapshot>;
export declare function recognize(rootComponentType: Type, config: RouterConfig, urlTree: UrlTree, url: string): Observable<RouterStateSnapshot>;
"use strict";
var Observable_1 = require('rxjs/Observable');
var of_1 = require('rxjs/observable/of');
var apply_redirects_1 = require('./apply_redirects');
var router_state_1 = require('./router_state');
var shared_1 = require('./shared');
var url_tree_1 = require('./url_tree');
var collection_1 = require('./utils/collection');
var tree_1 = require('./utils/tree');
var CannotRecognize = (function () {
function CannotRecognize() {
var NoMatch = (function () {
function NoMatch(segment) {
if (segment === void 0) { segment = null; }
this.segment = segment;
}
return CannotRecognize;
return NoMatch;
}());
function recognize(rootComponentType, config, url) {
function recognize(rootComponentType, config, urlTree, url) {
try {
var match_1 = new MatchResult(rootComponentType, config, [url.root], {}, url._root.children, [], shared_1.PRIMARY_OUTLET, null, url.root);
var roots = constructActivatedRoute(match_1);
return of_1.of(new router_state_1.RouterStateSnapshot(roots[0], url.queryParams, url.fragment));
var children = processSegment(config, urlTree.root, shared_1.PRIMARY_OUTLET);
var root = new router_state_1.ActivatedRouteSnapshot([], {}, shared_1.PRIMARY_OUTLET, rootComponentType, null, urlTree.root, -1);
var rootNode = new tree_1.TreeNode(root, children);
return of_1.of(new router_state_1.RouterStateSnapshot(url, rootNode, urlTree.queryParams, urlTree.fragment));
}
catch (e) {
if (e instanceof CannotRecognize) {
return new Observable_1.Observable(function (obs) { return obs.error(new Error('Cannot match any routes')); });
if (e instanceof NoMatch) {
return new Observable_1.Observable(function (obs) { return obs.error(new Error("Cannot match any routes: '" + e.segment + "'")); });
}

@@ -30,9 +33,18 @@ else {

exports.recognize = recognize;
function constructActivatedRoute(match) {
var activatedRoute = createActivatedRouteSnapshot(match);
var children = match.leftOverUrl.length > 0 ?
recognizeMany(match.children, match.leftOverUrl) :
recognizeLeftOvers(match.children, match.lastUrlSegment);
function processSegment(config, segment, outlet) {
if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {
return processSegmentChildren(config, segment);
}
else {
return [processPathsWithParams(config, segment, 0, segment.pathsWithParams, outlet)];
}
}
function processSegmentChildren(config, segment) {
var children = url_tree_1.mapChildrenIntoArray(segment, function (child, childOutlet) { return processSegment(config, child, childOutlet); });
checkOutletNameUniqueness(children);
children.sort(function (a, b) {
sortActivatedRouteSnapshots(children);
return children;
}
function sortActivatedRouteSnapshots(nodes) {
nodes.sort(function (a, b) {
if (a.value.outlet === shared_1.PRIMARY_OUTLET)

@@ -44,35 +56,76 @@ return -1;

});
return [new tree_1.TreeNode(activatedRoute, children)];
}
function recognizeLeftOvers(config, lastUrlSegment) {
if (!config)
return [];
var mIndex = matchIndex(config, [], lastUrlSegment);
return mIndex ? constructActivatedRoute(mIndex) : [];
}
function recognizeMany(config, urls) {
return collection_1.flatten(urls.map(function (url) { return recognizeOne(config, url); }));
}
function createActivatedRouteSnapshot(match) {
return new router_state_1.ActivatedRouteSnapshot(match.consumedUrlSegments, match.parameters, match.outlet, match.component, match.route, match.lastUrlSegment);
}
function recognizeOne(config, url) {
var matches = matchNode(config, url);
for (var _i = 0, matches_1 = matches; _i < matches_1.length; _i++) {
var match_2 = matches_1[_i];
function processPathsWithParams(config, segment, pathIndex, paths, outlet) {
for (var _i = 0, config_1 = config; _i < config_1.length; _i++) {
var r = config_1[_i];
try {
var primary = constructActivatedRoute(match_2);
var secondary = recognizeMany(config, match_2.secondary);
var res = primary.concat(secondary);
checkOutletNameUniqueness(res);
return res;
return processPathsWithParamsAgainstRoute(r, segment, pathIndex, paths, outlet);
}
catch (e) {
if (!(e instanceof CannotRecognize)) {
if (!(e instanceof NoMatch))
throw e;
}
}
}
throw new CannotRecognize();
throw new NoMatch(segment);
}
function processPathsWithParamsAgainstRoute(route, segment, pathIndex, paths, outlet) {
if (route.redirectTo)
throw new NoMatch();
if ((route.outlet ? route.outlet : shared_1.PRIMARY_OUTLET) !== outlet)
throw new NoMatch();
if (route.path === '**') {
var params = paths.length > 0 ? collection_1.last(paths).parameters : {};
var snapshot_1 = new router_state_1.ActivatedRouteSnapshot(paths, params, outlet, route.component, route, segment, -1);
return new tree_1.TreeNode(snapshot_1, []);
}
var _a = match(segment, route, paths), consumedPaths = _a.consumedPaths, parameters = _a.parameters, lastChild = _a.lastChild;
var snapshot = new router_state_1.ActivatedRouteSnapshot(consumedPaths, parameters, outlet, route.component, route, segment, pathIndex + lastChild - 1);
var slicedPath = paths.slice(lastChild);
var childConfig = route.children ? route.children : [];
if (childConfig.length === 0 && slicedPath.length === 0) {
return new tree_1.TreeNode(snapshot, []);
}
else if (slicedPath.length === 0 && Object.keys(segment.children).length > 0) {
var children = processSegmentChildren(childConfig, segment);
return new tree_1.TreeNode(snapshot, children);
}
else {
var child = processPathsWithParams(childConfig, segment, pathIndex + lastChild, slicedPath, shared_1.PRIMARY_OUTLET);
return new tree_1.TreeNode(snapshot, [child]);
}
}
function match(segment, route, paths) {
if (route.index || route.path === '' || route.path === '/') {
if (route.terminal && (Object.keys(segment.children).length > 0 || paths.length > 0)) {
throw new NoMatch();
}
else {
return { consumedPaths: [], lastChild: 0, parameters: {} };
}
}
var path = route.path.startsWith('/') ? route.path.substring(1) : route.path;
var parts = path.split('/');
var posParameters = {};
var consumedPaths = [];
var currentIndex = 0;
for (var i = 0; i < parts.length; ++i) {
if (currentIndex >= paths.length)
throw new NoMatch();
var current = paths[currentIndex];
var p = parts[i];
var isPosParam = p.startsWith(':');
if (!isPosParam && p !== current.path)
throw new NoMatch();
if (isPosParam) {
posParameters[p.substring(1)] = current.path;
}
consumedPaths.push(current);
currentIndex++;
}
if (route.terminal && (Object.keys(segment.children).length > 0 || currentIndex < paths.length)) {
throw new NoMatch();
}
var parameters = collection_1.merge(posParameters, consumedPaths[consumedPaths.length - 1].parameters);
return { consumedPaths: consumedPaths, lastChild: currentIndex, parameters: parameters };
}
function checkOutletNameUniqueness(nodes) {

@@ -84,3 +137,3 @@ var names = {};

var p = routeWithSameOutletName.urlSegments.map(function (s) { return s.toString(); }).join('/');
var c = n.value.urlSegments.map(function (s) { return s.toString(); }).join('/');
var c = n.value.url.map(function (s) { return s.toString(); }).join('/');
throw new Error("Two segments cannot have the same outlet name: '" + p + "' and '" + c + "'.");

@@ -90,75 +143,3 @@ }

});
return nodes;
}
function matchNode(config, url) {
var res = [];
for (var _i = 0, config_1 = config; _i < config_1.length; _i++) {
var r = config_1[_i];
var m = matchWithParts(r, url);
if (m) {
res.push(m);
}
else if (r.index) {
res.push(createIndexMatch(r, [url], url.value));
}
}
return res;
}
function createIndexMatch(r, leftOverUrls, lastUrlSegment) {
var outlet = r.outlet ? r.outlet : shared_1.PRIMARY_OUTLET;
var children = r.children ? r.children : [];
return new MatchResult(r.component, children, [], lastUrlSegment.parameters, leftOverUrls, [], outlet, r, lastUrlSegment);
}
function matchIndex(config, leftOverUrls, lastUrlSegment) {
for (var _i = 0, config_2 = config; _i < config_2.length; _i++) {
var r = config_2[_i];
if (r.index) {
return createIndexMatch(r, leftOverUrls, lastUrlSegment);
}
}
return null;
}
function matchWithParts(route, url) {
if (!route.path)
return null;
if ((route.outlet ? route.outlet : shared_1.PRIMARY_OUTLET) !== url.value.outlet)
return null;
var path = route.path.startsWith('/') ? route.path.substring(1) : route.path;
if (path === '**') {
var consumedUrl = [];
var u = url;
while (u) {
consumedUrl.push(u.value);
u = collection_1.first(u.children);
}
var last = consumedUrl[consumedUrl.length - 1];
return new MatchResult(route.component, [], consumedUrl, last.parameters, [], [], shared_1.PRIMARY_OUTLET, route, last);
}
var m = apply_redirects_1.match(route, url);
if (!m)
return null;
var consumedUrlSegments = m.consumedUrlSegments, lastSegment = m.lastSegment, lastParent = m.lastParent, positionalParamSegments = m.positionalParamSegments;
var p = lastSegment.value.parameters;
var posParams = {};
collection_1.forEach(positionalParamSegments, function (v, k) { posParams[k] = v.path; });
var parameters = collection_1.merge(p, posParams);
var secondarySubtrees = lastParent ? lastParent.children.slice(1) : [];
var children = route.children ? route.children : [];
var outlet = route.outlet ? route.outlet : shared_1.PRIMARY_OUTLET;
return new MatchResult(route.component, children, consumedUrlSegments, parameters, lastSegment.children, secondarySubtrees, outlet, route, lastSegment.value);
}
var MatchResult = (function () {
function MatchResult(component, children, consumedUrlSegments, parameters, leftOverUrl, secondary, outlet, route, lastUrlSegment) {
this.component = component;
this.children = children;
this.consumedUrlSegments = consumedUrlSegments;
this.parameters = parameters;
this.leftOverUrl = leftOverUrl;
this.secondary = secondary;
this.outlet = outlet;
this.route = route;
this.lastUrlSegment = lastUrlSegment;
}
return MatchResult;
}());
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recognize.js","sourceRoot":"","sources":["../src/recognize.ts"],"names":[],"mappings":"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","sourcesContent":["import {Type} from '@angular/core';\nimport {Observable} from 'rxjs/Observable';\nimport {of } from 'rxjs/observable/of';\n\nimport {match} from './apply_redirects';\nimport {Route, RouterConfig} from './config';\nimport {ActivatedRouteSnapshot, RouterStateSnapshot} from './router_state';\nimport {PRIMARY_OUTLET} from './shared';\nimport {UrlSegment, UrlTree} from './url_tree';\nimport {first, flatten, forEach, merge} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nclass CannotRecognize {}\n\nexport function recognize(\n    rootComponentType: Type, config: RouterConfig, url: UrlTree): Observable<RouterStateSnapshot> {\n  try {\n    const match = new MatchResult(\n        rootComponentType, config, [url.root], {}, url._root.children, [], PRIMARY_OUTLET, null,\n        url.root);\n    const roots = constructActivatedRoute(match);\n    return of (new RouterStateSnapshot(roots[0], url.queryParams, url.fragment));\n  } catch (e) {\n    if (e instanceof CannotRecognize) {\n      return new Observable<RouterStateSnapshot>(\n          obs => obs.error(new Error('Cannot match any routes')));\n    } else {\n      return new Observable<RouterStateSnapshot>(obs => obs.error(e));\n    }\n  }\n}\n\nfunction constructActivatedRoute(match: MatchResult): TreeNode<ActivatedRouteSnapshot>[] {\n  const activatedRoute = createActivatedRouteSnapshot(match);\n  const children = match.leftOverUrl.length > 0 ?\n      recognizeMany(match.children, match.leftOverUrl) :\n      recognizeLeftOvers(match.children, match.lastUrlSegment);\n  checkOutletNameUniqueness(children);\n  children.sort((a, b) => {\n    if (a.value.outlet === PRIMARY_OUTLET) return -1;\n    if (b.value.outlet === PRIMARY_OUTLET) return 1;\n    return a.value.outlet.localeCompare(b.value.outlet);\n  });\n  return [new TreeNode<ActivatedRouteSnapshot>(activatedRoute, children)];\n}\n\nfunction recognizeLeftOvers(\n    config: Route[], lastUrlSegment: UrlSegment): TreeNode<ActivatedRouteSnapshot>[] {\n  if (!config) return [];\n  const mIndex = matchIndex(config, [], lastUrlSegment);\n  return mIndex ? constructActivatedRoute(mIndex) : [];\n}\n\nfunction recognizeMany(\n    config: Route[], urls: TreeNode<UrlSegment>[]): TreeNode<ActivatedRouteSnapshot>[] {\n  return flatten(urls.map(url => recognizeOne(config, url)));\n}\n\nfunction createActivatedRouteSnapshot(match: MatchResult): ActivatedRouteSnapshot {\n  return new ActivatedRouteSnapshot(\n      match.consumedUrlSegments, match.parameters, match.outlet, match.component, match.route,\n      match.lastUrlSegment);\n}\n\nfunction recognizeOne(\n    config: Route[], url: TreeNode<UrlSegment>): TreeNode<ActivatedRouteSnapshot>[] {\n  const matches = matchNode(config, url);\n  for (let match of matches) {\n    try {\n      const primary = constructActivatedRoute(match);\n      const secondary = recognizeMany(config, match.secondary);\n      const res = primary.concat(secondary);\n      checkOutletNameUniqueness(res);\n      return res;\n    } catch (e) {\n      if (!(e instanceof CannotRecognize)) {\n        throw e;\n      }\n    }\n  }\n  throw new CannotRecognize();\n}\n\nfunction checkOutletNameUniqueness(nodes: TreeNode<ActivatedRouteSnapshot>[]):\n    TreeNode<ActivatedRouteSnapshot>[] {\n  let names = {};\n  nodes.forEach(n => {\n    let routeWithSameOutletName = names[n.value.outlet];\n    if (routeWithSameOutletName) {\n      const p = routeWithSameOutletName.urlSegments.map(s => s.toString()).join('/');\n      const c = n.value.urlSegments.map(s => s.toString()).join('/');\n      throw new Error(`Two segments cannot have the same outlet name: '${p}' and '${c}'.`);\n    }\n    names[n.value.outlet] = n.value;\n  });\n  return nodes;\n}\n\nfunction matchNode(config: Route[], url: TreeNode<UrlSegment>): MatchResult[] {\n  const res = [];\n  for (let r of config) {\n    const m = matchWithParts(r, url);\n    if (m) {\n      res.push(m);\n    } else if (r.index) {\n      res.push(createIndexMatch(r, [url], url.value));\n    }\n  }\n  return res;\n}\n\nfunction createIndexMatch(\n    r: Route, leftOverUrls: TreeNode<UrlSegment>[], lastUrlSegment: UrlSegment): MatchResult {\n  const outlet = r.outlet ? r.outlet : PRIMARY_OUTLET;\n  const children = r.children ? r.children : [];\n  return new MatchResult(\n      r.component, children, [], lastUrlSegment.parameters, leftOverUrls, [], outlet, r,\n      lastUrlSegment);\n}\n\nfunction matchIndex(\n    config: Route[], leftOverUrls: TreeNode<UrlSegment>[], lastUrlSegment: UrlSegment): MatchResult|\n    null {\n  for (let r of config) {\n    if (r.index) {\n      return createIndexMatch(r, leftOverUrls, lastUrlSegment);\n    }\n  }\n  return null;\n}\n\nfunction matchWithParts(route: Route, url: TreeNode<UrlSegment>): MatchResult|null {\n  if (!route.path) return null;\n  if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== url.value.outlet) return null;\n\n  const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;\n  if (path === '**') {\n    const consumedUrl = [];\n    let u: TreeNode<UrlSegment>|null = url;\n    while (u) {\n      consumedUrl.push(u.value);\n      u = first(u.children);\n    }\n    const last = consumedUrl[consumedUrl.length - 1];\n    return new MatchResult(\n        route.component, [], consumedUrl, last.parameters, [], [], PRIMARY_OUTLET, route, last);\n  }\n\n  const m = match(route, url);\n  if (!m) return null;\n  const {consumedUrlSegments, lastSegment, lastParent, positionalParamSegments} = m;\n\n  const p = lastSegment.value.parameters;\n  const posParams = {};\n  forEach(positionalParamSegments, (v, k) => { posParams[k] = v.path; });\n  const parameters = <{[key: string]: string}>merge(p, posParams);\n  const secondarySubtrees = lastParent ? lastParent.children.slice(1) : [];\n  const children = route.children ? route.children : [];\n  const outlet = route.outlet ? route.outlet : PRIMARY_OUTLET;\n\n  return new MatchResult(\n      route.component, children, consumedUrlSegments, parameters, lastSegment.children,\n      secondarySubtrees, outlet, route, lastSegment.value);\n}\n\nclass MatchResult {\n  constructor(\n      public component: Type|string, public children: Route[],\n      public consumedUrlSegments: UrlSegment[], public parameters: {[key: string]: string},\n      public leftOverUrl: TreeNode<UrlSegment>[], public secondary: TreeNode<UrlSegment>[],\n      public outlet: string, public route: Route|null, public lastUrlSegment: UrlSegment) {}\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recognize.js","sourceRoot":"","sources":["../src/recognize.ts"],"names":[],"mappings":"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","sourcesContent":["import {Type} from '@angular/core';\nimport {Observable} from 'rxjs/Observable';\nimport {of } from 'rxjs/observable/of';\n\nimport {Route, RouterConfig} from './config';\nimport {ActivatedRouteSnapshot, RouterStateSnapshot} from './router_state';\nimport {PRIMARY_OUTLET} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree, mapChildrenIntoArray} from './url_tree';\nimport {last, merge} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nclass NoMatch {\n  constructor(public segment: UrlSegment = null) {}\n}\n\nexport function recognize(\n    rootComponentType: Type, config: RouterConfig, urlTree: UrlTree,\n    url: string): Observable<RouterStateSnapshot> {\n  try {\n    const children = processSegment(config, urlTree.root, PRIMARY_OUTLET);\n    const root = new ActivatedRouteSnapshot(\n        [], {}, PRIMARY_OUTLET, rootComponentType, null, urlTree.root, -1);\n    const rootNode = new TreeNode<ActivatedRouteSnapshot>(root, children);\n    return of (new RouterStateSnapshot(url, rootNode, urlTree.queryParams, urlTree.fragment));\n  } catch (e) {\n    if (e instanceof NoMatch) {\n      return new Observable<RouterStateSnapshot>(\n          obs => obs.error(new Error(`Cannot match any routes: '${e.segment}'`)));\n    } else {\n      return new Observable<RouterStateSnapshot>(obs => obs.error(e));\n    }\n  }\n}\n\nfunction processSegment(\n    config: Route[], segment: UrlSegment, outlet: string): TreeNode<ActivatedRouteSnapshot>[] {\n  if (segment.pathsWithParams.length === 0 && Object.keys(segment.children).length > 0) {\n    return processSegmentChildren(config, segment);\n  } else {\n    return [processPathsWithParams(config, segment, 0, segment.pathsWithParams, outlet)];\n  }\n}\n\nfunction processSegmentChildren(\n    config: Route[], segment: UrlSegment): TreeNode<ActivatedRouteSnapshot>[] {\n  const children = mapChildrenIntoArray(\n      segment, (child, childOutlet) => processSegment(config, child, childOutlet));\n  checkOutletNameUniqueness(children);\n  sortActivatedRouteSnapshots(children);\n  return children;\n}\n\nfunction sortActivatedRouteSnapshots(nodes: TreeNode<ActivatedRouteSnapshot>[]): void {\n  nodes.sort((a, b) => {\n    if (a.value.outlet === PRIMARY_OUTLET) return -1;\n    if (b.value.outlet === PRIMARY_OUTLET) return 1;\n    return a.value.outlet.localeCompare(b.value.outlet);\n  });\n}\n\nfunction processPathsWithParams(\n    config: Route[], segment: UrlSegment, pathIndex: number, paths: UrlPathWithParams[],\n    outlet: string): TreeNode<ActivatedRouteSnapshot> {\n  for (let r of config) {\n    try {\n      return processPathsWithParamsAgainstRoute(r, segment, pathIndex, paths, outlet);\n    } catch (e) {\n      if (!(e instanceof NoMatch)) throw e;\n    }\n  }\n  throw new NoMatch(segment);\n}\n\nfunction processPathsWithParamsAgainstRoute(\n    route: Route, segment: UrlSegment, pathIndex: number, paths: UrlPathWithParams[],\n    outlet: string): TreeNode<ActivatedRouteSnapshot> {\n  if (route.redirectTo) throw new NoMatch();\n  if ((route.outlet ? route.outlet : PRIMARY_OUTLET) !== outlet) throw new NoMatch();\n\n  if (route.path === '**') {\n    const params = paths.length > 0 ? last(paths).parameters : {};\n    const snapshot =\n        new ActivatedRouteSnapshot(paths, params, outlet, route.component, route, segment, -1);\n    return new TreeNode<ActivatedRouteSnapshot>(snapshot, []);\n  }\n\n  const {consumedPaths, parameters, lastChild} = match(segment, route, paths);\n\n  const snapshot = new ActivatedRouteSnapshot(\n      consumedPaths, parameters, outlet, route.component, route, segment,\n      pathIndex + lastChild - 1);\n  const slicedPath = paths.slice(lastChild);\n  const childConfig = route.children ? route.children : [];\n\n  if (childConfig.length === 0 && slicedPath.length === 0) {\n    return new TreeNode<ActivatedRouteSnapshot>(snapshot, []);\n\n    // TODO: check that the right segment is present\n  } else if (slicedPath.length === 0 && Object.keys(segment.children).length > 0) {\n    const children = processSegmentChildren(childConfig, segment);\n    return new TreeNode<ActivatedRouteSnapshot>(snapshot, children);\n\n  } else {\n    const child = processPathsWithParams(\n        childConfig, segment, pathIndex + lastChild, slicedPath, PRIMARY_OUTLET);\n    return new TreeNode<ActivatedRouteSnapshot>(snapshot, [child]);\n  }\n}\n\nfunction match(segment: UrlSegment, route: Route, paths: UrlPathWithParams[]) {\n  if (route.index || route.path === '' || route.path === '/') {\n    if (route.terminal && (Object.keys(segment.children).length > 0 || paths.length > 0)) {\n      throw new NoMatch();\n    } else {\n      return {consumedPaths: [], lastChild: 0, parameters: {}};\n    }\n  }\n\n  const path = route.path.startsWith('/') ? route.path.substring(1) : route.path;\n  const parts = path.split('/');\n  const posParameters: {[key: string]: any} = {};\n  const consumedPaths = [];\n\n  let currentIndex = 0;\n\n  for (let i = 0; i < parts.length; ++i) {\n    if (currentIndex >= paths.length) throw new NoMatch();\n    const current = paths[currentIndex];\n\n    const p = parts[i];\n    const isPosParam = p.startsWith(':');\n\n    if (!isPosParam && p !== current.path) throw new NoMatch();\n    if (isPosParam) {\n      posParameters[p.substring(1)] = current.path;\n    }\n    consumedPaths.push(current);\n    currentIndex++;\n  }\n\n  if (route.terminal && (Object.keys(segment.children).length > 0 || currentIndex < paths.length)) {\n    throw new NoMatch();\n  }\n\n  const parameters = merge(posParameters, consumedPaths[consumedPaths.length - 1].parameters);\n  return {consumedPaths, lastChild: currentIndex, parameters};\n}\n\nfunction checkOutletNameUniqueness(nodes: TreeNode<ActivatedRouteSnapshot>[]): void {\n  const names = {};\n  nodes.forEach(n => {\n    let routeWithSameOutletName = names[n.value.outlet];\n    if (routeWithSameOutletName) {\n      const p = routeWithSameOutletName.urlSegments.map(s => s.toString()).join('/');\n      const c = n.value.url.map(s => s.toString()).join('/');\n      throw new Error(`Two segments cannot have the same outlet name: '${p}' and '${c}'.`);\n    }\n    names[n.value.outlet] = n.value;\n  });\n}"]}

@@ -0,2 +1,3 @@

import * as common from './common_router_providers';
import { RouterConfig } from './config';
export declare function provideRouter(config: RouterConfig): any[];
export declare function provideRouter(config: RouterConfig, opts?: common.ExtraOptions): any[];

@@ -5,8 +5,9 @@ "use strict";

var common = require('./common_router_providers');
function provideRouter(config) {
function provideRouter(config, opts) {
if (opts === void 0) { opts = {}; }
return [
{ provide: common_1.PlatformLocation, useClass: platform_browser_1.BrowserPlatformLocation }
].concat(common.provideRouter(config));
].concat(common.provideRouter(config, opts));
}
exports.provideRouter = provideRouter;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyX3Byb3ZpZGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9yb3V0ZXJfcHJvdmlkZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSx1QkFBK0IsaUJBQWlCLENBQUMsQ0FBQTtBQUNqRCxpQ0FBc0MsMkJBQTJCLENBQUMsQ0FBQTtBQUVsRSxJQUFZLE1BQU0sV0FBTSwyQkFBMkIsQ0FBQyxDQUFBO0FBc0JwRCx1QkFBOEIsTUFBb0I7SUFDaEQsTUFBTSxDQUFDO1FBQ0wsRUFBQyxPQUFPLEVBQUUseUJBQWdCLEVBQUUsUUFBUSxFQUFFLDBDQUF1QixFQUFDO2FBQUssTUFBTSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FDaEcsQ0FBQztBQUNKLENBQUM7QUFKZSxxQkFBYSxnQkFJNUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7UGxhdGZvcm1Mb2NhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7QnJvd3NlclBsYXRmb3JtTG9jYXRpb259IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuXG5pbXBvcnQgKiBhcyBjb21tb24gZnJvbSAnLi9jb21tb25fcm91dGVyX3Byb3ZpZGVycyc7XG5pbXBvcnQge1JvdXRlckNvbmZpZ30gZnJvbSAnLi9jb25maWcnO1xuXG5cbi8qKlxuICogQSBsaXN0IG9mIHtAbGluayBQcm92aWRlcn1zLiBUbyB1c2UgdGhlIHJvdXRlciwgeW91IG11c3QgYWRkIHRoaXMgdG8geW91ciBhcHBsaWNhdGlvbi5cbiAqXG4gKiAjIyMgRXhhbXBsZVxuICpcbiAqIGBgYFxuICogQENvbXBvbmVudCh7ZGlyZWN0aXZlczogW1JPVVRFUl9ESVJFQ1RJVkVTXX0pXG4gKiBjbGFzcyBBcHBDbXAge1xuICogICAvLyAuLi5cbiAqIH1cbiAqXG4gKiBjb25zdCByb3V0ZXIgPSBbXG4gKiAgIHtwYXRoOiAnL2hvbWUnLCBjb21wb25lbnQ6IEhvbWV9XG4gKiBdO1xuICpcbiAqIGJvb3RzdHJhcChBcHBDbXAsIFtwcm92aWRlUm91dGVyKHJvdXRlcildKTtcbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZVJvdXRlcihjb25maWc6IFJvdXRlckNvbmZpZyk6IGFueVtdIHtcbiAgcmV0dXJuIFtcbiAgICB7cHJvdmlkZTogUGxhdGZvcm1Mb2NhdGlvbiwgdXNlQ2xhc3M6IEJyb3dzZXJQbGF0Zm9ybUxvY2F0aW9ufSwgLi4uY29tbW9uLnByb3ZpZGVSb3V0ZXIoY29uZmlnKVxuICBdO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm91dGVyX3Byb3ZpZGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9yb3V0ZXJfcHJvdmlkZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSx1QkFBK0IsaUJBQWlCLENBQUMsQ0FBQTtBQUNqRCxpQ0FBc0MsMkJBQTJCLENBQUMsQ0FBQTtBQUVsRSxJQUFZLE1BQU0sV0FBTSwyQkFBMkIsQ0FBQyxDQUFBO0FBc0JwRCx1QkFBOEIsTUFBb0IsRUFBRSxJQUE4QjtJQUE5QixvQkFBOEIsR0FBOUIsU0FBOEI7SUFDaEYsTUFBTSxDQUFDO1FBQ0wsRUFBQyxPQUFPLEVBQUUseUJBQWdCLEVBQUUsUUFBUSxFQUFFLDBDQUF1QixFQUFDO2FBQzNELE1BQU0sQ0FBQyxhQUFhLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUN0QyxDQUFDO0FBQ0osQ0FBQztBQUxlLHFCQUFhLGdCQUs1QixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtQbGF0Zm9ybUxvY2F0aW9ufSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtCcm93c2VyUGxhdGZvcm1Mb2NhdGlvbn0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5cbmltcG9ydCAqIGFzIGNvbW1vbiBmcm9tICcuL2NvbW1vbl9yb3V0ZXJfcHJvdmlkZXJzJztcbmltcG9ydCB7Um91dGVyQ29uZmlnfSBmcm9tICcuL2NvbmZpZyc7XG5cblxuLyoqXG4gKiBBIGxpc3Qgb2Yge0BsaW5rIFByb3ZpZGVyfXMuIFRvIHVzZSB0aGUgcm91dGVyLCB5b3UgbXVzdCBhZGQgdGhpcyB0byB5b3VyIGFwcGxpY2F0aW9uLlxuICpcbiAqICMjIyBFeGFtcGxlXG4gKlxuICogYGBgXG4gKiBAQ29tcG9uZW50KHtkaXJlY3RpdmVzOiBbUk9VVEVSX0RJUkVDVElWRVNdfSlcbiAqIGNsYXNzIEFwcENtcCB7XG4gKiAgIC8vIC4uLlxuICogfVxuICpcbiAqIGNvbnN0IHJvdXRlciA9IFtcbiAqICAge3BhdGg6ICcvaG9tZScsIGNvbXBvbmVudDogSG9tZX1cbiAqIF07XG4gKlxuICogYm9vdHN0cmFwKEFwcENtcCwgW3Byb3ZpZGVSb3V0ZXIocm91dGVyKV0pO1xuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlUm91dGVyKGNvbmZpZzogUm91dGVyQ29uZmlnLCBvcHRzOiBjb21tb24uRXh0cmFPcHRpb25zID0ge30pOiBhbnlbXSB7XG4gIHJldHVybiBbXG4gICAge3Byb3ZpZGU6IFBsYXRmb3JtTG9jYXRpb24sIHVzZUNsYXNzOiBCcm93c2VyUGxhdGZvcm1Mb2NhdGlvbn0sXG4gICAgLi4uY29tbW9uLnByb3ZpZGVSb3V0ZXIoY29uZmlnLCBvcHRzKVxuICBdO1xufVxuIl19

@@ -5,3 +5,3 @@ import { ComponentFactory, Type } from '@angular/core';

import { Params } from './shared';
import { UrlSegment } from './url_tree';
import { UrlPathWithParams, UrlSegment, UrlTree } from './url_tree';
import { Tree, TreeNode } from './utils/tree';

@@ -13,6 +13,7 @@ export declare class RouterState extends Tree<ActivatedRoute> {

constructor(root: TreeNode<ActivatedRoute>, queryParams: Observable<Params>, fragment: Observable<string>, snapshot: RouterStateSnapshot);
toString(): string;
}
export declare function createEmptyState(rootComponent: Type): RouterState;
export declare function createEmptyState(urlTree: UrlTree, rootComponent: Type): RouterState;
export declare class ActivatedRoute {
urlSegments: Observable<UrlSegment[]>;
url: Observable<UrlPathWithParams[]>;
params: Observable<Params>;

@@ -23,6 +24,7 @@ outlet: string;

snapshot: ActivatedRouteSnapshot;
constructor(urlSegments: Observable<UrlSegment[]>, params: Observable<Params>, outlet: string, component: Type | string, futureSnapshot: ActivatedRouteSnapshot);
constructor(url: Observable<UrlPathWithParams[]>, params: Observable<Params>, outlet: string, component: Type | string, futureSnapshot: ActivatedRouteSnapshot);
toString(): string;
}
export declare class ActivatedRouteSnapshot {
urlSegments: UrlSegment[];
url: UrlPathWithParams[];
params: Params;

@@ -32,11 +34,15 @@ outlet: string;

_resolvedComponentFactory: ComponentFactory<any>;
_routeConfig: Route | null;
_lastUrlSegment: UrlSegment;
constructor(urlSegments: UrlSegment[], params: Params, outlet: string, component: Type | string, routeConfig: Route | null, lastUrlSegment: UrlSegment);
_routeConfig: Route;
_urlSegment: UrlSegment;
_lastPathIndex: number;
constructor(url: UrlPathWithParams[], params: Params, outlet: string, component: Type | string, routeConfig: Route, urlSegment: UrlSegment, lastPathIndex: number);
toString(): string;
}
export declare class RouterStateSnapshot extends Tree<ActivatedRouteSnapshot> {
url: string;
queryParams: Params;
fragment: string | null;
constructor(root: TreeNode<ActivatedRouteSnapshot>, queryParams: Params, fragment: string | null);
fragment: string;
constructor(url: string, root: TreeNode<ActivatedRouteSnapshot>, queryParams: Params, fragment: string);
toString(): string;
}
export declare function advanceActivatedRoute(route: ActivatedRoute): void;

@@ -20,8 +20,9 @@ "use strict";

}
RouterState.prototype.toString = function () { return this.snapshot.toString(); };
return RouterState;
}(tree_1.Tree));
exports.RouterState = RouterState;
function createEmptyState(rootComponent) {
var snapshot = createEmptyStateSnapshot(rootComponent);
var emptyUrl = new BehaviorSubject_1.BehaviorSubject([new url_tree_1.UrlSegment('', {}, shared_1.PRIMARY_OUTLET)]);
function createEmptyState(urlTree, rootComponent) {
var snapshot = createEmptyStateSnapshot(urlTree, rootComponent);
var emptyUrl = new BehaviorSubject_1.BehaviorSubject([new url_tree_1.UrlPathWithParams('', {})]);
var emptyParams = new BehaviorSubject_1.BehaviorSubject({});

@@ -35,14 +36,12 @@ var emptyQueryParams = new BehaviorSubject_1.BehaviorSubject({});

exports.createEmptyState = createEmptyState;
function createEmptyStateSnapshot(rootComponent) {
var rootUrlSegment = new url_tree_1.UrlSegment('', {}, shared_1.PRIMARY_OUTLET);
var emptyUrl = [rootUrlSegment];
function createEmptyStateSnapshot(urlTree, rootComponent) {
var emptyParams = {};
var emptyQueryParams = {};
var fragment = '';
var activated = new ActivatedRouteSnapshot(emptyUrl, emptyParams, shared_1.PRIMARY_OUTLET, rootComponent, null, rootUrlSegment);
return new RouterStateSnapshot(new tree_1.TreeNode(activated, []), emptyQueryParams, fragment);
var activated = new ActivatedRouteSnapshot([], emptyParams, shared_1.PRIMARY_OUTLET, rootComponent, null, urlTree.root, -1);
return new RouterStateSnapshot('', new tree_1.TreeNode(activated, []), emptyQueryParams, fragment);
}
var ActivatedRoute = (function () {
function ActivatedRoute(urlSegments, params, outlet, component, futureSnapshot) {
this.urlSegments = urlSegments;
function ActivatedRoute(url, params, outlet, component, futureSnapshot) {
this.url = url;
this.params = params;

@@ -53,2 +52,5 @@ this.outlet = outlet;

}
ActivatedRoute.prototype.toString = function () {
return this.snapshot ? this.snapshot.toString() : "Future(" + this._futureSnapshot + ")";
};
return ActivatedRoute;

@@ -58,4 +60,4 @@ }());

var ActivatedRouteSnapshot = (function () {
function ActivatedRouteSnapshot(urlSegments, params, outlet, component, routeConfig, lastUrlSegment) {
this.urlSegments = urlSegments;
function ActivatedRouteSnapshot(url, params, outlet, component, routeConfig, urlSegment, lastPathIndex) {
this.url = url;
this.params = params;

@@ -65,4 +67,10 @@ this.outlet = outlet;

this._routeConfig = routeConfig;
this._lastUrlSegment = lastUrlSegment;
this._urlSegment = urlSegment;
this._lastPathIndex = lastPathIndex;
}
ActivatedRouteSnapshot.prototype.toString = function () {
var url = this.url.map(function (s) { return s.toString(); }).join('/');
var matched = this._routeConfig ? this._routeConfig.path : '';
return "Route(url:'" + url + "', path:'" + matched + "')";
};
return ActivatedRouteSnapshot;

@@ -73,14 +81,20 @@ }());

__extends(RouterStateSnapshot, _super);
function RouterStateSnapshot(root, queryParams, fragment) {
function RouterStateSnapshot(url, root, queryParams, fragment) {
_super.call(this, root);
this.url = url;
this.queryParams = queryParams;
this.fragment = fragment;
}
RouterStateSnapshot.prototype.toString = function () { return serializeNode(this._root); };
return RouterStateSnapshot;
}(tree_1.Tree));
exports.RouterStateSnapshot = RouterStateSnapshot;
function serializeNode(node) {
var c = node.children.length > 0 ? " { " + node.children.map(serializeNode).join(", ") + " } " : '';
return "" + node.value + c;
}
function advanceActivatedRoute(route) {
if (route.snapshot && !collection_1.shallowEqual(route.snapshot.params, route._futureSnapshot.params)) {
route.snapshot = route._futureSnapshot;
route.urlSegments.next(route.snapshot.urlSegments);
route.url.next(route.snapshot.url);
route.params.next(route.snapshot.params);

@@ -93,2 +107,2 @@ }

exports.advanceActivatedRoute = advanceActivatedRoute;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_state.js","sourceRoot":"","sources":["../src/router_state.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentFactory, Type} from '@angular/core';\nimport {BehaviorSubject} from 'rxjs/BehaviorSubject';\nimport {Observable} from 'rxjs/Observable';\n\nimport {Route} from './config';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlSegment} from './url_tree';\nimport {shallowEqual} from './utils/collection';\nimport {Tree, TreeNode} from './utils/tree';\n\n\n/**\n * The state of the router.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(router: Router) {\n *     const state = router.routerState;\n *     const id: Observable<string> = state.firstChild(state.root).params.map(p => p.id);\n *     const isDebug: Observable<string> = state.queryParams.map(q => q.debug);\n *   }\n * }\n * ```\n */\nexport class RouterState extends Tree<ActivatedRoute> {\n  /**\n   * @internal\n   */\n  constructor(\n      root: TreeNode<ActivatedRoute>, public queryParams: Observable<Params>,\n      public fragment: Observable<string>, public snapshot: RouterStateSnapshot) {\n    super(root);\n  }\n}\n\nexport function createEmptyState(rootComponent: Type): RouterState {\n  const snapshot = createEmptyStateSnapshot(rootComponent);\n  const emptyUrl = new BehaviorSubject([new UrlSegment('', {}, PRIMARY_OUTLET)]);\n  const emptyParams = new BehaviorSubject({});\n  const emptyQueryParams = new BehaviorSubject({});\n  const fragment = new BehaviorSubject('');\n  const activated =\n      new ActivatedRoute(emptyUrl, emptyParams, PRIMARY_OUTLET, rootComponent, snapshot.root);\n  activated.snapshot = snapshot.root;\n  return new RouterState(\n      new TreeNode<ActivatedRoute>(activated, []), emptyQueryParams, fragment, snapshot);\n}\n\nfunction createEmptyStateSnapshot(rootComponent: Type): RouterStateSnapshot {\n  const rootUrlSegment = new UrlSegment('', {}, PRIMARY_OUTLET);\n  const emptyUrl = [rootUrlSegment];\n  const emptyParams = {};\n  const emptyQueryParams = {};\n  const fragment = '';\n  const activated = new ActivatedRouteSnapshot(\n      emptyUrl, emptyParams, PRIMARY_OUTLET, rootComponent, null, rootUrlSegment);\n  return new RouterStateSnapshot(\n      new TreeNode<ActivatedRouteSnapshot>(activated, []), emptyQueryParams, fragment);\n}\n\n/**\n * Contains the information about a component loaded in an outlet. The information is provided\n * through\n * the params and urlSegments observables.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: Observable<string> = route.params.map(p => p.id);\n *   }\n * }\n * ```\n */\nexport class ActivatedRoute {\n  /** @internal */\n  _futureSnapshot: ActivatedRouteSnapshot;\n  snapshot: ActivatedRouteSnapshot;\n\n  /**\n   * @internal\n   */\n  constructor(\n      public urlSegments: Observable<UrlSegment[]>, public params: Observable<Params>,\n      public outlet: string, public component: Type|string,\n      futureSnapshot: ActivatedRouteSnapshot) {\n    this._futureSnapshot = futureSnapshot;\n  }\n}\n\n/**\n * Contains the information about a component loaded in an outlet at a particular moment in time.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: string = route.snapshot.params.id;\n *   }\n * }\n * ```\n */\nexport class ActivatedRouteSnapshot {\n  /**\n   * @internal\n   */\n  _resolvedComponentFactory: ComponentFactory<any>;\n\n  /** @internal **/\n  _routeConfig: Route|null;\n\n  /** @internal **/\n  _lastUrlSegment: UrlSegment;\n\n  /**\n   * @internal\n   */\n  constructor(\n      public urlSegments: UrlSegment[], public params: Params, public outlet: string,\n      public component: Type|string, routeConfig: Route|null, lastUrlSegment: UrlSegment) {\n    this._routeConfig = routeConfig;\n    this._lastUrlSegment = lastUrlSegment;\n  }\n}\n\n/**\n * The state of the router at a particular moment in time.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(router: Router) {\n *     const snapshot = router.routerState.snapshot;\n *   }\n * }\n * ```\n */\nexport class RouterStateSnapshot extends Tree<ActivatedRouteSnapshot> {\n  /**\n   * @internal\n   */\n  constructor(\n      root: TreeNode<ActivatedRouteSnapshot>, public queryParams: Params,\n      public fragment: string|null) {\n    super(root);\n  }\n}\n\n/**\n * The expectation is that the activate route is created with the right set of parameters.\n * So we push new values into the observables only when they are not the initial values.\n * And we detect that by checking if the snapshot field is set.\n */\nexport function advanceActivatedRoute(route: ActivatedRoute): void {\n  if (route.snapshot && !shallowEqual(route.snapshot.params, route._futureSnapshot.params)) {\n    route.snapshot = route._futureSnapshot;\n    (<any>route.urlSegments).next(route.snapshot.urlSegments);\n    (<any>route.params).next(route.snapshot.params);\n  } else {\n    route.snapshot = route._futureSnapshot;\n  }\n}"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router_state.js","sourceRoot":"","sources":["../src/router_state.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentFactory, Type} from '@angular/core';\nimport {BehaviorSubject} from 'rxjs/BehaviorSubject';\nimport {Observable} from 'rxjs/Observable';\n\nimport {Route} from './config';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree} from './url_tree';\nimport {shallowEqual} from './utils/collection';\nimport {Tree, TreeNode} from './utils/tree';\n\n\n/**\n * The state of the router.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(router: Router) {\n *     const state = router.routerState;\n *     const id: Observable<string> = state.firstChild(state.root).params.map(p => p.id);\n *     const isDebug: Observable<string> = state.queryParams.map(q => q.debug);\n *   }\n * }\n * ```\n */\nexport class RouterState extends Tree<ActivatedRoute> {\n  /**\n   * @internal\n   */\n  constructor(\n      root: TreeNode<ActivatedRoute>, public queryParams: Observable<Params>,\n      public fragment: Observable<string>, public snapshot: RouterStateSnapshot) {\n    super(root);\n  }\n\n  toString(): string { return this.snapshot.toString(); }\n}\n\nexport function createEmptyState(urlTree: UrlTree, rootComponent: Type): RouterState {\n  const snapshot = createEmptyStateSnapshot(urlTree, rootComponent);\n  const emptyUrl = new BehaviorSubject([new UrlPathWithParams('', {})]);\n  const emptyParams = new BehaviorSubject({});\n  const emptyQueryParams = new BehaviorSubject({});\n  const fragment = new BehaviorSubject('');\n  const activated =\n      new ActivatedRoute(emptyUrl, emptyParams, PRIMARY_OUTLET, rootComponent, snapshot.root);\n  activated.snapshot = snapshot.root;\n  return new RouterState(\n      new TreeNode<ActivatedRoute>(activated, []), emptyQueryParams, fragment, snapshot);\n}\n\nfunction createEmptyStateSnapshot(urlTree: UrlTree, rootComponent: Type): RouterStateSnapshot {\n  const emptyParams = {};\n  const emptyQueryParams = {};\n  const fragment = '';\n  const activated = new ActivatedRouteSnapshot(\n      [], emptyParams, PRIMARY_OUTLET, rootComponent, null, urlTree.root, -1);\n  return new RouterStateSnapshot(\n      '', new TreeNode<ActivatedRouteSnapshot>(activated, []), emptyQueryParams, fragment);\n}\n\n/**\n * Contains the information about a component loaded in an outlet. The information is provided\n * through\n * the params and urlSegments observables.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: Observable<string> = route.params.map(p => p.id);\n *   }\n * }\n * ```\n */\nexport class ActivatedRoute {\n  /** @internal */\n  _futureSnapshot: ActivatedRouteSnapshot;\n  snapshot: ActivatedRouteSnapshot;\n\n  /**\n   * @internal\n   */\n  constructor(\n      public url: Observable<UrlPathWithParams[]>, public params: Observable<Params>,\n      public outlet: string, public component: Type|string,\n      futureSnapshot: ActivatedRouteSnapshot) {\n    this._futureSnapshot = futureSnapshot;\n  }\n\n  toString(): string {\n    return this.snapshot ? this.snapshot.toString() : `Future(${this._futureSnapshot})`;\n  }\n}\n\n/**\n * Contains the information about a component loaded in an outlet at a particular moment in time.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(route: ActivatedRoute) {\n *     const id: string = route.snapshot.params.id;\n *   }\n * }\n * ```\n */\nexport class ActivatedRouteSnapshot {\n  /**\n   * @internal\n   */\n  _resolvedComponentFactory: ComponentFactory<any>;\n\n  /** @internal **/\n  _routeConfig: Route;\n\n  /** @internal **/\n  _urlSegment: UrlSegment;\n\n  _lastPathIndex: number;\n\n  /**\n   * @internal\n   */\n  constructor(\n      public url: UrlPathWithParams[], public params: Params, public outlet: string,\n      public component: Type|string, routeConfig: Route, urlSegment: UrlSegment,\n      lastPathIndex: number) {\n    this._routeConfig = routeConfig;\n    this._urlSegment = urlSegment;\n    this._lastPathIndex = lastPathIndex;\n  }\n\n  toString(): string {\n    const url = this.url.map(s => s.toString()).join('/');\n    const matched = this._routeConfig ? this._routeConfig.path : '';\n    return `Route(url:'${url}', path:'${matched}')`;\n  }\n}\n\n/**\n * The state of the router at a particular moment in time.\n *\n * ### Usage\n *\n * ```\n * class MyComponent {\n *   constructor(router: Router) {\n *     const snapshot = router.routerState.snapshot;\n *   }\n * }\n * ```\n */\nexport class RouterStateSnapshot extends Tree<ActivatedRouteSnapshot> {\n  /**\n   * @internal\n   */\n  constructor(\n      public url: string, root: TreeNode<ActivatedRouteSnapshot>, public queryParams: Params,\n      public fragment: string) {\n    super(root);\n  }\n\n  toString(): string { return serializeNode(this._root); }\n}\n\nfunction serializeNode(node: TreeNode<ActivatedRouteSnapshot>): string {\n  const c = node.children.length > 0 ? ` { ${node.children.map(serializeNode).join(\", \")} } ` : '';\n  return `${node.value}${c}`;\n}\n\n\n/**\n * The expectation is that the activate route is created with the right set of parameters.\n * So we push new values into the observables only when they are not the initial values.\n * And we detect that by checking if the snapshot field is set.\n */\nexport function advanceActivatedRoute(route: ActivatedRoute): void {\n  if (route.snapshot && !shallowEqual(route.snapshot.params, route._futureSnapshot.params)) {\n    route.snapshot = route._futureSnapshot;\n    (<any>route.url).next(route.snapshot.url);\n    (<any>route.params).next(route.snapshot.params);\n  } else {\n    route.snapshot = route._futureSnapshot;\n  }\n}"]}

@@ -14,3 +14,3 @@ import 'rxjs/add/operator/map';

import { RouterOutletMap } from './router_outlet_map';
import { ActivatedRoute, RouterState } from './router_state';
import { ActivatedRoute, RouterState, RouterStateSnapshot } from './router_state';
import { Params } from './shared';

@@ -26,21 +26,34 @@ import { UrlSerializer } from './url_serializer';

id: number;
url: UrlTree;
constructor(id: number, url: UrlTree);
url: string;
constructor(id: number, url: string);
toString(): string;
}
export declare class NavigationEnd {
id: number;
url: UrlTree;
constructor(id: number, url: UrlTree);
url: string;
urlAfterRedirects: string;
constructor(id: number, url: string, urlAfterRedirects: string);
toString(): string;
}
export declare class NavigationCancel {
id: number;
url: UrlTree;
constructor(id: number, url: UrlTree);
url: string;
constructor(id: number, url: string);
toString(): string;
}
export declare class NavigationError {
id: number;
url: UrlTree;
url: string;
error: any;
constructor(id: number, url: UrlTree, error: any);
constructor(id: number, url: string, error: any);
toString(): string;
}
export declare class RoutesRecognized {
id: number;
url: string;
urlAfterRedirects: string;
state: RouterStateSnapshot;
constructor(id: number, url: string, urlAfterRedirects: string, state: RouterStateSnapshot);
toString(): string;
}
export declare type Event = NavigationStart | NavigationEnd | NavigationCancel | NavigationError;

@@ -62,5 +75,5 @@ export declare class Router {

initialNavigation(): void;
readonly routerState: RouterState;
readonly urlTree: UrlTree;
readonly events: Observable<Event>;
routerState: RouterState;
url: string;
events: Observable<Event>;
navigateByUrl(url: string): Promise<boolean>;

@@ -67,0 +80,0 @@ resetConfig(config: RouterConfig): void;

@@ -29,2 +29,3 @@ "use strict";

}
NavigationStart.prototype.toString = function () { return "NavigationStart(id: " + this.id + ", url: '" + this.url + "')"; };
return NavigationStart;

@@ -34,6 +35,10 @@ }());

var NavigationEnd = (function () {
function NavigationEnd(id, url) {
function NavigationEnd(id, url, urlAfterRedirects) {
this.id = id;
this.url = url;
this.urlAfterRedirects = urlAfterRedirects;
}
NavigationEnd.prototype.toString = function () {
return "NavigationEnd(id: " + this.id + ", url: '" + this.url + "', urlAfterRedirects: '" + this.urlAfterRedirects + "')";
};
return NavigationEnd;

@@ -47,2 +52,3 @@ }());

}
NavigationCancel.prototype.toString = function () { return "NavigationCancel(id: " + this.id + ", url: '" + this.url + "')"; };
return NavigationCancel;

@@ -57,5 +63,21 @@ }());

}
NavigationError.prototype.toString = function () {
return "NavigationError(id: " + this.id + ", url: '" + this.url + "', error: " + this.error + ")";
};
return NavigationError;
}());
exports.NavigationError = NavigationError;
var RoutesRecognized = (function () {
function RoutesRecognized(id, url, urlAfterRedirects, state) {
this.id = id;
this.url = url;
this.urlAfterRedirects = urlAfterRedirects;
this.state = state;
}
RoutesRecognized.prototype.toString = function () {
return "RoutesRecognized(id: " + this.id + ", url: '" + this.url + "', urlAfterRedirects: '" + this.urlAfterRedirects + "', state: " + this.state + ")";
};
return RoutesRecognized;
}());
exports.RoutesRecognized = RoutesRecognized;
var Router = (function () {

@@ -73,3 +95,3 @@ function Router(rootComponentType, resolver, urlSerializer, outletMap, location, injector, config) {

this.currentUrlTree = url_tree_1.createEmptyUrlTree();
this.currentRouterState = router_state_1.createEmptyState(this.rootComponentType);
this.currentRouterState = router_state_1.createEmptyState(this.currentUrlTree, this.rootComponentType);
}

@@ -85,4 +107,4 @@ Router.prototype.initialNavigation = function () {

});
Object.defineProperty(Router.prototype, "urlTree", {
get: function () { return this.currentUrlTree; },
Object.defineProperty(Router.prototype, "url", {
get: function () { return this.serializeUrl(this.currentUrlTree); },
enumerable: true,

@@ -116,3 +138,3 @@ configurable: true

var id = ++this.navigationId;
this.routerEvents.next(new NavigationStart(id, url));
this.routerEvents.next(new NavigationStart(id, this.serializeUrl(url)));
return Promise.resolve().then(function (_) { return _this.runNavigate(url, false, id); });

@@ -130,3 +152,3 @@ };

this.location.go(this.urlSerializer.serialize(this.currentUrlTree));
this.routerEvents.next(new NavigationCancel(id, url));
this.routerEvents.next(new NavigationCancel(id, this.serializeUrl(url)));
return Promise.resolve(false);

@@ -140,5 +162,6 @@ }

updatedUrl = u;
return recognize_1.recognize(_this.rootComponentType, _this.config, updatedUrl);
return recognize_1.recognize(_this.rootComponentType, _this.config, updatedUrl, _this.serializeUrl(updatedUrl));
})
.mergeMap(function (newRouterStateSnapshot) {
_this.routerEvents.next(new RoutesRecognized(id, _this.serializeUrl(url), _this.serializeUrl(updatedUrl), newRouterStateSnapshot));
return resolve_1.resolve(_this.resolver, newRouterStateSnapshot);

@@ -159,7 +182,7 @@ })

_this.location.go(_this.urlSerializer.serialize(_this.currentUrlTree));
_this.routerEvents.next(new NavigationCancel(id, url));
_this.routerEvents.next(new NavigationCancel(id, _this.serializeUrl(url)));
return Promise.resolve(false);
}
new ActivateRoutes(state, _this.currentRouterState).activate(_this.outletMap);
_this.currentUrlTree = url;
_this.currentUrlTree = updatedUrl;
_this.currentRouterState = state;

@@ -171,6 +194,6 @@ if (!pop) {

.then(function () {
_this.routerEvents.next(new NavigationEnd(id, url));
_this.routerEvents.next(new NavigationEnd(id, _this.serializeUrl(url), _this.serializeUrl(updatedUrl)));
resolvePromise(true);
}, function (e) {
_this.routerEvents.next(new NavigationError(id, url, e));
_this.routerEvents.next(new NavigationError(id, _this.serializeUrl(url), e));
rejectPromise(e);

@@ -253,3 +276,7 @@ });

if (outlet && outlet.isActivated) {
collection_1.forEach(outlet.outletMap._outlets, function (v, k) { return _this.deactivateOutletAndItChildren(v.activatedRoute.snapshot, v); });
collection_1.forEach(outlet.outletMap._outlets, function (v, k) {
if (v.isActivated) {
_this.deactivateOutletAndItChildren(v.activatedRoute.snapshot, v);
}
});
this.checks.push(new CanDeactivate(outlet.component, route));

@@ -373,7 +400,8 @@ }

if (!outlet) {
var componentName = route.component.name;
if (route.outlet === shared_1.PRIMARY_OUTLET) {
throw new Error("Cannot find primary outlet");
throw new Error("Cannot find primary outlet to load '" + componentName + "'");
}
else {
throw new Error("Cannot find the outlet " + route.outlet);
throw new Error("Cannot find the outlet " + route.outlet + " to load '" + componentName + "'");
}

@@ -383,2 +411,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router.js","sourceRoot":"","sources":["../src/router.ts"],"names":[],"mappings":"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","sourcesContent":["import 'rxjs/add/operator/map';\nimport 'rxjs/add/operator/scan';\nimport 'rxjs/add/operator/mergeMap';\nimport 'rxjs/add/operator/concat';\nimport 'rxjs/add/operator/concatMap';\nimport 'rxjs/add/operator/every';\nimport 'rxjs/add/operator/mergeAll';\nimport 'rxjs/add/observable/from';\n\nimport {Location} from '@angular/common';\nimport {ComponentResolver, Injector, ReflectiveInjector, Type} from '@angular/core';\nimport {Observable} from 'rxjs/Observable';\nimport {Subject} from 'rxjs/Subject';\nimport {Subscription} from 'rxjs/Subscription';\nimport {of } from 'rxjs/observable/of';\n\nimport {applyRedirects} from './apply_redirects';\nimport {RouterConfig} from './config';\nimport {createRouterState} from './create_router_state';\nimport {createUrlTree} from './create_url_tree';\nimport {RouterOutlet} from './directives/router_outlet';\nimport {recognize} from './recognize';\nimport {resolve} from './resolve';\nimport {RouterOutletMap} from './router_outlet_map';\nimport {ActivatedRoute, ActivatedRouteSnapshot, RouterState, RouterStateSnapshot, advanceActivatedRoute, createEmptyState} from './router_state';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlSerializer} from './url_serializer';\nimport {UrlTree, createEmptyUrlTree} from './url_tree';\nimport {forEach, shallowEqual} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nexport interface NavigationExtras {\n  relativeTo?: ActivatedRoute;\n  queryParams?: Params;\n  fragment?: string;\n}\n\n/**\n * An event triggered when a navigation starts\n */\nexport class NavigationStart {\n  constructor(public id: number, public url: UrlTree) {}\n}\n\n/**\n * An event triggered when a navigation ends successfully\n */\nexport class NavigationEnd {\n  constructor(public id: number, public url: UrlTree) {}\n}\n\n/**\n * An event triggered when a navigation is canceled\n */\nexport class NavigationCancel {\n  constructor(public id: number, public url: UrlTree) {}\n}\n\n/**\n * An event triggered when a navigation fails due to unexpected error\n */\nexport class NavigationError {\n  constructor(public id: number, public url: UrlTree, public error: any) {}\n}\n\nexport type Event = NavigationStart | NavigationEnd | NavigationCancel | NavigationError;\n\n/**\n * The `Router` is responsible for mapping URLs to components.\n */\nexport class Router {\n  private currentUrlTree: UrlTree;\n  private currentRouterState: RouterState;\n  private locationSubscription: Subscription;\n  private routerEvents: Subject<Event>;\n  private navigationId: number = 0;\n\n  /**\n   * @internal\n   */\n  constructor(\n      private rootComponentType: Type, private resolver: ComponentResolver,\n      private urlSerializer: UrlSerializer, private outletMap: RouterOutletMap,\n      private location: Location, private injector: Injector, private config: RouterConfig) {\n    this.routerEvents = new Subject<Event>();\n    this.currentUrlTree = createEmptyUrlTree();\n    this.currentRouterState = createEmptyState(this.rootComponentType);\n  }\n\n  /**\n   * @internal\n   */\n  initialNavigation(): void {\n    this.setUpLocationChangeListener();\n    this.navigateByUrl(this.location.path());\n  }\n\n  /**\n   * Returns the current route state.\n   */\n  get routerState(): RouterState { return this.currentRouterState; }\n\n  /**\n   * Returns the current url tree.\n   */\n  get urlTree(): UrlTree { return this.currentUrlTree; }\n\n  /**\n   * Returns an observable of route events\n   */\n  get events(): Observable<Event> { return this.routerEvents; }\n\n  /**\n   * Navigate based on the provided url. This navigation is always absolute.\n   *\n   * Returns a promise that:\n   * - is resolved with 'true' when navigation succeeds\n   * - is resolved with 'false' when navigation fails\n   * - is rejected when an error happens\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigateByUrl(\"/team/33/user/11\");\n   * ```\n   */\n  navigateByUrl(url: string): Promise<boolean> {\n    const urlTree = this.urlSerializer.parse(url);\n    return this.scheduleNavigation(urlTree, false);\n  }\n\n  /**\n   * Resets the configuration used for navigation and generating links.\n   *\n   * ### Usage\n   *\n   * ```\n   * router.resetConfig([\n   *  { path: 'team/:id', component: TeamCmp, children: [\n   *    { path: 'simple', component: SimpleCmp },\n   *    { path: 'user/:name', component: UserCmp }\n   *  ] }\n   * ]);\n   * ```\n   */\n  resetConfig(config: RouterConfig): void { this.config = config; }\n\n  /**\n   * @internal\n   */\n  dispose(): void { this.locationSubscription.unsubscribe(); }\n\n  /**\n   * Applies an array of commands to the current url tree and creates\n   * a new url tree.\n   *\n   * When given an activate route, applies the given commands starting from the route.\n   * When not given a route, applies the given command starting from the root.\n   *\n   * ### Usage\n   *\n   * ```\n   * // create /team/33/user/11\n   * router.createUrlTree(['/team', 33, 'user', 11]);\n   *\n   * // create /team/33;expand=true/user/11\n   * router.createUrlTree(['/team', 33, {expand: true}, 'user', 11]);\n   *\n   * // you can collapse static fragments like this\n   * router.createUrlTree(['/team/33/user', userId]);\n   *\n   * // assuming the current url is `/team/33/user/11` and the route points to `user/11`\n   *\n   * // navigate to /team/33/user/11/details\n   * router.createUrlTree(['details'], {relativeTo: route});\n   *\n   * // navigate to /team/33/user/22\n   * router.createUrlTree(['../22'], {relativeTo: route});\n   *\n   * // navigate to /team/44/user/22\n   * router.createUrlTree(['../../team/44/user/22'], {relativeTo: route});\n   * ```\n   */\n  createUrlTree(commands: any[], {relativeTo, queryParams, fragment}: NavigationExtras = {}):\n      UrlTree {\n    const a = relativeTo ? relativeTo : this.routerState.root;\n    return createUrlTree(a, this.currentUrlTree, commands, queryParams, fragment);\n  }\n\n\n  /**\n   * Navigate based on the provided array of commands and a starting point.\n   * If no starting route is provided, the navigation is absolute.\n   *\n   * Returns a promise that:\n   * - is resolved with 'true' when navigation succeeds\n   * - is resolved with 'false' when navigation fails\n   * - is rejected when an error happens\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigate(['team', 33, 'team', '11], {relativeTo: route});\n   * ```\n   */\n  navigate(commands: any[], extras: NavigationExtras = {}): Promise<boolean> {\n    return this.scheduleNavigation(this.createUrlTree(commands, extras), false);\n  }\n\n  /**\n   * Serializes a {@link UrlTree} into a string.\n   */\n  serializeUrl(url: UrlTree): string { return this.urlSerializer.serialize(url); }\n\n  /**\n   * Parse a string into a {@link UrlTree}.\n   */\n  parseUrl(url: string): UrlTree { return this.urlSerializer.parse(url); }\n\n  private scheduleNavigation(url: UrlTree, pop: boolean): Promise<boolean> {\n    const id = ++this.navigationId;\n    this.routerEvents.next(new NavigationStart(id, url));\n    return Promise.resolve().then((_) => this.runNavigate(url, false, id));\n  }\n\n  private setUpLocationChangeListener(): void {\n    this.locationSubscription = <any>this.location.subscribe((change) => {\n      return this.scheduleNavigation(this.urlSerializer.parse(change['url']), change['pop']);\n    });\n  }\n\n  private runNavigate(url: UrlTree, pop: boolean, id: number): Promise<boolean> {\n    if (id !== this.navigationId) {\n      this.location.go(this.urlSerializer.serialize(this.currentUrlTree));\n      this.routerEvents.next(new NavigationCancel(id, url));\n      return Promise.resolve(false);\n    }\n\n    return new Promise((resolvePromise, rejectPromise) => {\n      let updatedUrl;\n      let state;\n      applyRedirects(url, this.config)\n          .mergeMap(u => {\n            updatedUrl = u;\n            return recognize(this.rootComponentType, this.config, updatedUrl);\n          })\n\n          .mergeMap((newRouterStateSnapshot) => {\n            return resolve(this.resolver, newRouterStateSnapshot);\n\n          })\n          .map((routerStateSnapshot) => {\n            return createRouterState(routerStateSnapshot, this.currentRouterState);\n\n          })\n          .map((newState: RouterState) => {\n            state = newState;\n\n          })\n          .mergeMap(_ => {\n            return new GuardChecks(state.snapshot, this.currentRouterState.snapshot, this.injector)\n                .check(this.outletMap);\n\n          })\n          .forEach((shouldActivate) => {\n            if (!shouldActivate || id !== this.navigationId) {\n              this.location.go(this.urlSerializer.serialize(this.currentUrlTree));\n              this.routerEvents.next(new NavigationCancel(id, url));\n              return Promise.resolve(false);\n            }\n\n            new ActivateRoutes(state, this.currentRouterState).activate(this.outletMap);\n\n            this.currentUrlTree = url;\n            this.currentRouterState = state;\n            if (!pop) {\n              this.location.go(this.urlSerializer.serialize(updatedUrl));\n            }\n          })\n          .then(\n              () => {\n                this.routerEvents.next(new NavigationEnd(id, url));\n                resolvePromise(true);\n\n              },\n              e => {\n                this.routerEvents.next(new NavigationError(id, url, e));\n                rejectPromise(e);\n              });\n    });\n  }\n}\n\nclass CanActivate {\n  constructor(public route: ActivatedRouteSnapshot) {}\n}\nclass CanDeactivate {\n  constructor(public component: Object, public route: ActivatedRouteSnapshot) {}\n}\n\nclass GuardChecks {\n  private checks = [];\n  constructor(\n      private future: RouterStateSnapshot, private curr: RouterStateSnapshot,\n      private injector: Injector) {}\n\n  check(parentOutletMap: RouterOutletMap): Observable<boolean> {\n    const futureRoot = this.future._root;\n    const currRoot = this.curr ? this.curr._root : null;\n    this.traverseChildRoutes(futureRoot, currRoot, parentOutletMap);\n    if (this.checks.length === 0) return of (true);\n    return Observable.from(this.checks)\n        .map(s => {\n          if (s instanceof CanActivate) {\n            return this.runCanActivate(s.route);\n          } else if (s instanceof CanDeactivate) {\n            return this.runCanDeactivate(s.component, s.route);\n          } else {\n            throw new Error('Cannot be reached');\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n\n  private traverseChildRoutes(\n      futureNode: TreeNode<ActivatedRouteSnapshot>, currNode: TreeNode<ActivatedRouteSnapshot>|null,\n      outletMap: RouterOutletMap|null): void {\n    const prevChildren = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.traverseRoutes(c, prevChildren[c.value.outlet], outletMap);\n      delete prevChildren[c.value.outlet];\n    });\n    forEach(prevChildren, (v, k) => this.deactivateOutletAndItChildren(v, outletMap._outlets[k]));\n  }\n\n  traverseRoutes(\n      futureNode: TreeNode<ActivatedRouteSnapshot>, currNode: TreeNode<ActivatedRouteSnapshot>|null,\n      parentOutletMap: RouterOutletMap|null): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n    const outlet = parentOutletMap ? parentOutletMap._outlets[futureNode.value.outlet] : null;\n\n    if (curr && future._routeConfig === curr._routeConfig) {\n      if (!shallowEqual(future.params, curr.params)) {\n        this.checks.push(new CanDeactivate(outlet.component, curr), new CanActivate(future));\n      }\n      this.traverseChildRoutes(futureNode, currNode, outlet ? outlet.outletMap : null);\n    } else {\n      this.deactivateOutletAndItChildren(curr, outlet);\n      this.checks.push(new CanActivate(future));\n      this.traverseChildRoutes(futureNode, null, outlet ? outlet.outletMap : null);\n    }\n  }\n\n  private deactivateOutletAndItChildren(route: ActivatedRouteSnapshot, outlet: RouterOutlet): void {\n    if (outlet && outlet.isActivated) {\n      forEach(\n          outlet.outletMap._outlets,\n          (v, k) => this.deactivateOutletAndItChildren(v.activatedRoute.snapshot, v));\n      this.checks.push(new CanDeactivate(outlet.component, route));\n    }\n  }\n\n  private runCanActivate(future: ActivatedRouteSnapshot): Observable<boolean> {\n    const canActivate = future._routeConfig ? future._routeConfig.canActivate : null;\n    if (!canActivate || canActivate.length === 0) return of (true);\n    return Observable.from(canActivate)\n        .map(c => {\n          const guard = this.injector.get(c);\n          if (guard.canActivate) {\n            return wrapIntoObservable(guard.canActivate(future, this.future));\n          } else {\n            return wrapIntoObservable(guard(future, this.future));\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n\n  private runCanDeactivate(component: Object, curr: ActivatedRouteSnapshot): Observable<boolean> {\n    const canDeactivate = curr._routeConfig ? curr._routeConfig.canDeactivate : null;\n    if (!canDeactivate || canDeactivate.length === 0) return of (true);\n    return Observable.from(canDeactivate)\n        .map(c => {\n          const guard = this.injector.get(c);\n          if (guard.canDeactivate) {\n            return wrapIntoObservable(guard.canDeactivate(component, curr, this.curr));\n          } else {\n            return wrapIntoObservable(guard(component, curr, this.curr));\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n}\n\nfunction wrapIntoObservable<T>(value: T | Observable<T>): Observable<T> {\n  if (value instanceof Observable) {\n    return value;\n  } else {\n    return of (value);\n  }\n}\n\nclass ActivateRoutes {\n  constructor(private futureState: RouterState, private currState: RouterState) {}\n\n  activate(parentOutletMap: RouterOutletMap): void {\n    const futureRoot = this.futureState._root;\n    const currRoot = this.currState ? this.currState._root : null;\n\n    pushQueryParamsAndFragment(this.futureState);\n    this.activateChildRoutes(futureRoot, currRoot, parentOutletMap);\n  }\n\n  private activateChildRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>|null,\n      outletMap: RouterOutletMap): void {\n    const prevChildren = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.activateRoutes(c, prevChildren[c.value.outlet], outletMap);\n      delete prevChildren[c.value.outlet];\n    });\n    forEach(prevChildren, (v, k) => this.deactivateOutletAndItChildren(outletMap._outlets[k]));\n  }\n\n  activateRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>|null,\n      parentOutletMap: RouterOutletMap): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n    const outlet = getOutlet(parentOutletMap, futureNode.value);\n\n    if (future === curr) {\n      advanceActivatedRoute(future);\n      this.activateChildRoutes(futureNode, currNode, outlet.outletMap);\n    } else {\n      this.deactivateOutletAndItChildren(outlet);\n      const outletMap = new RouterOutletMap();\n      this.activateNewRoutes(outletMap, future, outlet);\n      this.activateChildRoutes(futureNode, null, outletMap);\n    }\n  }\n\n  private activateNewRoutes(\n      outletMap: RouterOutletMap, future: ActivatedRoute, outlet: RouterOutlet): void {\n    const resolved = ReflectiveInjector.resolve([\n      {provide: ActivatedRoute, useValue: future},\n      {provide: RouterOutletMap, useValue: outletMap}\n    ]);\n    outlet.activate(future._futureSnapshot._resolvedComponentFactory, future, resolved, outletMap);\n    advanceActivatedRoute(future);\n  }\n\n  private deactivateOutletAndItChildren(outlet: RouterOutlet): void {\n    if (outlet && outlet.isActivated) {\n      forEach(outlet.outletMap._outlets, (v, k) => this.deactivateOutletAndItChildren(v));\n      outlet.deactivate();\n    }\n  }\n}\n\nfunction pushQueryParamsAndFragment(state: RouterState): void {\n  if (!shallowEqual(state.snapshot.queryParams, (<any>state.queryParams).value)) {\n    (<any>state.queryParams).next(state.snapshot.queryParams);\n  }\n\n  if (state.snapshot.fragment !== (<any>state.fragment).value) {\n    (<any>state.fragment).next(state.snapshot.fragment);\n  }\n}\n\nfunction nodeChildrenAsMap(node: TreeNode<any>| null) {\n  return node ? node.children.reduce((m, c) => {\n    m[c.value.outlet] = c;\n    return m;\n  }, {}) : {};\n}\n\nfunction getOutlet(outletMap: RouterOutletMap, route: ActivatedRoute): RouterOutlet {\n  let outlet = outletMap._outlets[route.outlet];\n  if (!outlet) {\n    if (route.outlet === PRIMARY_OUTLET) {\n      throw new Error(`Cannot find primary outlet`);\n    } else {\n      throw new Error(`Cannot find the outlet ${route.outlet}`);\n    }\n  }\n  return outlet;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"router.js","sourceRoot":"","sources":["../src/router.ts"],"names":[],"mappings":"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","sourcesContent":["import 'rxjs/add/operator/map';\nimport 'rxjs/add/operator/scan';\nimport 'rxjs/add/operator/mergeMap';\nimport 'rxjs/add/operator/concat';\nimport 'rxjs/add/operator/concatMap';\nimport 'rxjs/add/operator/every';\nimport 'rxjs/add/operator/mergeAll';\nimport 'rxjs/add/observable/from';\n\nimport {Location} from '@angular/common';\nimport {ComponentResolver, Injector, ReflectiveInjector, Type} from '@angular/core';\nimport {Observable} from 'rxjs/Observable';\nimport {Subject} from 'rxjs/Subject';\nimport {Subscription} from 'rxjs/Subscription';\nimport {of } from 'rxjs/observable/of';\n\nimport {applyRedirects} from './apply_redirects';\nimport {RouterConfig} from './config';\nimport {createRouterState} from './create_router_state';\nimport {createUrlTree} from './create_url_tree';\nimport {RouterOutlet} from './directives/router_outlet';\nimport {recognize} from './recognize';\nimport {resolve} from './resolve';\nimport {RouterOutletMap} from './router_outlet_map';\nimport {ActivatedRoute, ActivatedRouteSnapshot, RouterState, RouterStateSnapshot, advanceActivatedRoute, createEmptyState} from './router_state';\nimport {PRIMARY_OUTLET, Params} from './shared';\nimport {UrlSerializer} from './url_serializer';\nimport {UrlTree, createEmptyUrlTree} from './url_tree';\nimport {forEach, shallowEqual} from './utils/collection';\nimport {TreeNode} from './utils/tree';\n\nexport interface NavigationExtras {\n  relativeTo?: ActivatedRoute;\n  queryParams?: Params;\n  fragment?: string;\n}\n\n/**\n * An event triggered when a navigation starts\n */\nexport class NavigationStart {\n  constructor(public id: number, public url: string) {}\n\n  toString(): string { return `NavigationStart(id: ${this.id}, url: '${this.url}')`; }\n}\n\n/**\n * An event triggered when a navigation ends successfully\n */\nexport class NavigationEnd {\n  constructor(public id: number, public url: string, public urlAfterRedirects: string) {}\n\n  toString(): string {\n    return `NavigationEnd(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}')`;\n  }\n}\n\n/**\n * An event triggered when a navigation is canceled\n */\nexport class NavigationCancel {\n  constructor(public id: number, public url: string) {}\n\n  toString(): string { return `NavigationCancel(id: ${this.id}, url: '${this.url}')`; }\n}\n\n/**\n * An event triggered when a navigation fails due to unexpected error\n */\nexport class NavigationError {\n  constructor(public id: number, public url: string, public error: any) {}\n\n  toString(): string {\n    return `NavigationError(id: ${this.id}, url: '${this.url}', error: ${this.error})`;\n  }\n}\n\n/**\n * An event triggered when routes are recognized\n */\nexport class RoutesRecognized {\n  constructor(\n      public id: number, public url: string, public urlAfterRedirects: string,\n      public state: RouterStateSnapshot) {}\n\n  toString(): string {\n    return `RoutesRecognized(id: ${this.id}, url: '${this.url}', urlAfterRedirects: '${this.urlAfterRedirects}', state: ${this.state})`;\n  }\n}\n\nexport type Event = NavigationStart | NavigationEnd | NavigationCancel | NavigationError;\n\n/**\n * The `Router` is responsible for mapping URLs to components.\n */\nexport class Router {\n  private currentUrlTree: UrlTree;\n  private currentRouterState: RouterState;\n  private locationSubscription: Subscription;\n  private routerEvents: Subject<Event>;\n  private navigationId: number = 0;\n\n  /**\n   * @internal\n   */\n  constructor(\n      private rootComponentType: Type, private resolver: ComponentResolver,\n      private urlSerializer: UrlSerializer, private outletMap: RouterOutletMap,\n      private location: Location, private injector: Injector, private config: RouterConfig) {\n    this.routerEvents = new Subject<Event>();\n    this.currentUrlTree = createEmptyUrlTree();\n    this.currentRouterState = createEmptyState(this.currentUrlTree, this.rootComponentType);\n  }\n\n  /**\n   * @internal\n   */\n  initialNavigation(): void {\n    this.setUpLocationChangeListener();\n    this.navigateByUrl(this.location.path());\n  }\n\n  /**\n   * Returns the current route state.\n   */\n  get routerState(): RouterState { return this.currentRouterState; }\n\n  /**\n   * Returns the current url.\n   */\n  get url(): string { return this.serializeUrl(this.currentUrlTree); }\n\n  /**\n   * Returns an observable of route events\n   */\n  get events(): Observable<Event> { return this.routerEvents; }\n\n  /**\n   * Navigate based on the provided url. This navigation is always absolute.\n   *\n   * Returns a promise that:\n   * - is resolved with 'true' when navigation succeeds\n   * - is resolved with 'false' when navigation fails\n   * - is rejected when an error happens\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigateByUrl(\"/team/33/user/11\");\n   * ```\n   */\n  navigateByUrl(url: string): Promise<boolean> {\n    const urlTree = this.urlSerializer.parse(url);\n    return this.scheduleNavigation(urlTree, false);\n  }\n\n  /**\n   * Resets the configuration used for navigation and generating links.\n   *\n   * ### Usage\n   *\n   * ```\n   * router.resetConfig([\n   *  { path: 'team/:id', component: TeamCmp, children: [\n   *    { path: 'simple', component: SimpleCmp },\n   *    { path: 'user/:name', component: UserCmp }\n   *  ] }\n   * ]);\n   * ```\n   */\n  resetConfig(config: RouterConfig): void { this.config = config; }\n\n  /**\n   * @internal\n   */\n  dispose(): void { this.locationSubscription.unsubscribe(); }\n\n  /**\n   * Applies an array of commands to the current url tree and creates\n   * a new url tree.\n   *\n   * When given an activate route, applies the given commands starting from the route.\n   * When not given a route, applies the given command starting from the root.\n   *\n   * ### Usage\n   *\n   * ```\n   * // create /team/33/user/11\n   * router.createUrlTree(['/team', 33, 'user', 11]);\n   *\n   * // create /team/33;expand=true/user/11\n   * router.createUrlTree(['/team', 33, {expand: true}, 'user', 11]);\n   *\n   * // you can collapse static fragments like this\n   * router.createUrlTree(['/team/33/user', userId]);\n   *\n   * // assuming the current url is `/team/33/user/11` and the route points to `user/11`\n   *\n   * // navigate to /team/33/user/11/details\n   * router.createUrlTree(['details'], {relativeTo: route});\n   *\n   * // navigate to /team/33/user/22\n   * router.createUrlTree(['../22'], {relativeTo: route});\n   *\n   * // navigate to /team/44/user/22\n   * router.createUrlTree(['../../team/44/user/22'], {relativeTo: route});\n   * ```\n   */\n  createUrlTree(commands: any[], {relativeTo, queryParams, fragment}: NavigationExtras = {}):\n      UrlTree {\n    const a = relativeTo ? relativeTo : this.routerState.root;\n    return createUrlTree(a, this.currentUrlTree, commands, queryParams, fragment);\n  }\n\n  /**\n   * Navigate based on the provided array of commands and a starting point.\n   * If no starting route is provided, the navigation is absolute.\n   *\n   * Returns a promise that:\n   * - is resolved with 'true' when navigation succeeds\n   * - is resolved with 'false' when navigation fails\n   * - is rejected when an error happens\n   *\n   * ### Usage\n   *\n   * ```\n   * router.navigate(['team', 33, 'team', '11], {relativeTo: route});\n   * ```\n   */\n  navigate(commands: any[], extras: NavigationExtras = {}): Promise<boolean> {\n    return this.scheduleNavigation(this.createUrlTree(commands, extras), false);\n  }\n\n  /**\n   * Serializes a {@link UrlTree} into a string.\n   */\n  serializeUrl(url: UrlTree): string { return this.urlSerializer.serialize(url); }\n\n  /**\n   * Parse a string into a {@link UrlTree}.\n   */\n  parseUrl(url: string): UrlTree { return this.urlSerializer.parse(url); }\n\n  private scheduleNavigation(url: UrlTree, pop: boolean): Promise<boolean> {\n    const id = ++this.navigationId;\n    this.routerEvents.next(new NavigationStart(id, this.serializeUrl(url)));\n    return Promise.resolve().then((_) => this.runNavigate(url, false, id));\n  }\n\n  private setUpLocationChangeListener(): void {\n    this.locationSubscription = <any>this.location.subscribe((change) => {\n      return this.scheduleNavigation(this.urlSerializer.parse(change['url']), change['pop']);\n    });\n  }\n\n  private runNavigate(url: UrlTree, pop: boolean, id: number): Promise<boolean> {\n    if (id !== this.navigationId) {\n      this.location.go(this.urlSerializer.serialize(this.currentUrlTree));\n      this.routerEvents.next(new NavigationCancel(id, this.serializeUrl(url)));\n      return Promise.resolve(false);\n    }\n\n    return new Promise((resolvePromise, rejectPromise) => {\n      let updatedUrl;\n      let state;\n      applyRedirects(url, this.config)\n          .mergeMap(u => {\n            updatedUrl = u;\n            return recognize(\n                this.rootComponentType, this.config, updatedUrl, this.serializeUrl(updatedUrl));\n          })\n\n          .mergeMap((newRouterStateSnapshot) => {\n            this.routerEvents.next(new RoutesRecognized(\n                id, this.serializeUrl(url), this.serializeUrl(updatedUrl), newRouterStateSnapshot));\n            return resolve(this.resolver, newRouterStateSnapshot);\n\n          })\n          .map((routerStateSnapshot) => {\n            return createRouterState(routerStateSnapshot, this.currentRouterState);\n\n          })\n          .map((newState: RouterState) => {\n            state = newState;\n\n          })\n          .mergeMap(_ => {\n            return new GuardChecks(state.snapshot, this.currentRouterState.snapshot, this.injector)\n                .check(this.outletMap);\n\n          })\n          .forEach((shouldActivate) => {\n            if (!shouldActivate || id !== this.navigationId) {\n              this.location.go(this.urlSerializer.serialize(this.currentUrlTree));\n              this.routerEvents.next(new NavigationCancel(id, this.serializeUrl(url)));\n              return Promise.resolve(false);\n            }\n\n            new ActivateRoutes(state, this.currentRouterState).activate(this.outletMap);\n\n            this.currentUrlTree = updatedUrl;\n            this.currentRouterState = state;\n            if (!pop) {\n              this.location.go(this.urlSerializer.serialize(updatedUrl));\n            }\n          })\n          .then(\n              () => {\n                this.routerEvents.next(\n                    new NavigationEnd(id, this.serializeUrl(url), this.serializeUrl(updatedUrl)));\n                resolvePromise(true);\n\n              },\n              e => {\n                this.routerEvents.next(new NavigationError(id, this.serializeUrl(url), e));\n                rejectPromise(e);\n              });\n    });\n  }\n}\n\nclass CanActivate {\n  constructor(public route: ActivatedRouteSnapshot) {}\n}\nclass CanDeactivate {\n  constructor(public component: Object, public route: ActivatedRouteSnapshot) {}\n}\n\nclass GuardChecks {\n  private checks = [];\n  constructor(\n      private future: RouterStateSnapshot, private curr: RouterStateSnapshot,\n      private injector: Injector) {}\n\n  check(parentOutletMap: RouterOutletMap): Observable<boolean> {\n    const futureRoot = this.future._root;\n    const currRoot = this.curr ? this.curr._root : null;\n    this.traverseChildRoutes(futureRoot, currRoot, parentOutletMap);\n    if (this.checks.length === 0) return of (true);\n    return Observable.from(this.checks)\n        .map(s => {\n          if (s instanceof CanActivate) {\n            return this.runCanActivate(s.route);\n          } else if (s instanceof CanDeactivate) {\n            return this.runCanDeactivate(s.component, s.route);\n          } else {\n            throw new Error('Cannot be reached');\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n\n  private traverseChildRoutes(\n      futureNode: TreeNode<ActivatedRouteSnapshot>, currNode: TreeNode<ActivatedRouteSnapshot>,\n      outletMap: RouterOutletMap): void {\n    const prevChildren: {[key: string]: any} = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.traverseRoutes(c, prevChildren[c.value.outlet], outletMap);\n      delete prevChildren[c.value.outlet];\n    });\n    forEach(prevChildren, (v, k) => this.deactivateOutletAndItChildren(v, outletMap._outlets[k]));\n  }\n\n  traverseRoutes(\n      futureNode: TreeNode<ActivatedRouteSnapshot>, currNode: TreeNode<ActivatedRouteSnapshot>,\n      parentOutletMap: RouterOutletMap): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n    const outlet = parentOutletMap ? parentOutletMap._outlets[futureNode.value.outlet] : null;\n\n    if (curr && future._routeConfig === curr._routeConfig) {\n      if (!shallowEqual(future.params, curr.params)) {\n        this.checks.push(new CanDeactivate(outlet.component, curr), new CanActivate(future));\n      }\n      this.traverseChildRoutes(futureNode, currNode, outlet ? outlet.outletMap : null);\n    } else {\n      this.deactivateOutletAndItChildren(curr, outlet);\n      this.checks.push(new CanActivate(future));\n      this.traverseChildRoutes(futureNode, null, outlet ? outlet.outletMap : null);\n    }\n  }\n\n  private deactivateOutletAndItChildren(route: ActivatedRouteSnapshot, outlet: RouterOutlet): void {\n    if (outlet && outlet.isActivated) {\n      forEach(outlet.outletMap._outlets, (v, k) => {\n        if (v.isActivated) {\n          this.deactivateOutletAndItChildren(v.activatedRoute.snapshot, v);\n        }\n      });\n      this.checks.push(new CanDeactivate(outlet.component, route));\n    }\n  }\n\n  private runCanActivate(future: ActivatedRouteSnapshot): Observable<boolean> {\n    const canActivate = future._routeConfig ? future._routeConfig.canActivate : null;\n    if (!canActivate || canActivate.length === 0) return of (true);\n    return Observable.from(canActivate)\n        .map(c => {\n          const guard = this.injector.get(c);\n          if (guard.canActivate) {\n            return wrapIntoObservable(guard.canActivate(future, this.future));\n          } else {\n            return wrapIntoObservable(guard(future, this.future));\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n\n  private runCanDeactivate(component: Object, curr: ActivatedRouteSnapshot): Observable<boolean> {\n    const canDeactivate = curr._routeConfig ? curr._routeConfig.canDeactivate : null;\n    if (!canDeactivate || canDeactivate.length === 0) return of (true);\n    return Observable.from(canDeactivate)\n        .map(c => {\n          const guard = this.injector.get(c);\n          if (guard.canDeactivate) {\n            return wrapIntoObservable(guard.canDeactivate(component, curr, this.curr));\n          } else {\n            return wrapIntoObservable(guard(component, curr, this.curr));\n          }\n        })\n        .mergeAll()\n        .every(result => result === true);\n  }\n}\n\nfunction wrapIntoObservable<T>(value: T | Observable<T>): Observable<T> {\n  if (value instanceof Observable) {\n    return value;\n  } else {\n    return of (value);\n  }\n}\n\nclass ActivateRoutes {\n  constructor(private futureState: RouterState, private currState: RouterState) {}\n\n  activate(parentOutletMap: RouterOutletMap): void {\n    const futureRoot = this.futureState._root;\n    const currRoot = this.currState ? this.currState._root : null;\n\n    pushQueryParamsAndFragment(this.futureState);\n    this.activateChildRoutes(futureRoot, currRoot, parentOutletMap);\n  }\n\n  private activateChildRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>,\n      outletMap: RouterOutletMap): void {\n    const prevChildren: {[key: string]: any} = nodeChildrenAsMap(currNode);\n    futureNode.children.forEach(c => {\n      this.activateRoutes(c, prevChildren[c.value.outlet], outletMap);\n      delete prevChildren[c.value.outlet];\n    });\n    forEach(prevChildren, (v, k) => this.deactivateOutletAndItChildren(outletMap._outlets[k]));\n  }\n\n  activateRoutes(\n      futureNode: TreeNode<ActivatedRoute>, currNode: TreeNode<ActivatedRoute>,\n      parentOutletMap: RouterOutletMap): void {\n    const future = futureNode.value;\n    const curr = currNode ? currNode.value : null;\n\n    const outlet = getOutlet(parentOutletMap, futureNode.value);\n\n    if (future === curr) {\n      advanceActivatedRoute(future);\n      this.activateChildRoutes(futureNode, currNode, outlet.outletMap);\n    } else {\n      this.deactivateOutletAndItChildren(outlet);\n      const outletMap = new RouterOutletMap();\n      this.activateNewRoutes(outletMap, future, outlet);\n      this.activateChildRoutes(futureNode, null, outletMap);\n    }\n  }\n\n  private activateNewRoutes(\n      outletMap: RouterOutletMap, future: ActivatedRoute, outlet: RouterOutlet): void {\n    const resolved = ReflectiveInjector.resolve([\n      {provide: ActivatedRoute, useValue: future},\n      {provide: RouterOutletMap, useValue: outletMap}\n    ]);\n    outlet.activate(future._futureSnapshot._resolvedComponentFactory, future, resolved, outletMap);\n    advanceActivatedRoute(future);\n  }\n\n  private deactivateOutletAndItChildren(outlet: RouterOutlet): void {\n    if (outlet && outlet.isActivated) {\n      forEach(outlet.outletMap._outlets, (v, k) => this.deactivateOutletAndItChildren(v));\n      outlet.deactivate();\n    }\n  }\n}\n\nfunction pushQueryParamsAndFragment(state: RouterState): void {\n  if (!shallowEqual(state.snapshot.queryParams, (<any>state.queryParams).value)) {\n    (<any>state.queryParams).next(state.snapshot.queryParams);\n  }\n\n  if (state.snapshot.fragment !== (<any>state.fragment).value) {\n    (<any>state.fragment).next(state.snapshot.fragment);\n  }\n}\n\nfunction nodeChildrenAsMap(node: TreeNode<any>) {\n  return node ? node.children.reduce((m, c) => {\n    m[c.value.outlet] = c;\n    return m;\n  }, {}) : {};\n}\n\nfunction getOutlet(outletMap: RouterOutletMap, route: ActivatedRoute): RouterOutlet {\n  let outlet = outletMap._outlets[route.outlet];\n  if (!outlet) {\n    const componentName = (<any>route.component).name;\n    if (route.outlet === PRIMARY_OUTLET) {\n      throw new Error(`Cannot find primary outlet to load '${componentName}'`);\n    } else {\n      throw new Error(`Cannot find the outlet ${route.outlet} to load '${componentName}'`);\n    }\n  }\n  return outlet;\n}\n"]}
export declare const PRIMARY_OUTLET: string;
export declare type Params = {
[key: string]: string;
[key: string]: any;
};
"use strict";
exports.PRIMARY_OUTLET = 'PRIMARY_OUTLET';
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3NoYXJlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBSWEsc0JBQWMsR0FBRyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTmFtZSBvZiB0aGUgcHJpbWFyeSBvdXRsZXQuXG4gKiBAdHlwZSB7c3RyaW5nfVxuICovXG5leHBvcnQgY29uc3QgUFJJTUFSWV9PVVRMRVQgPSAnUFJJTUFSWV9PVVRMRVQnO1xuXG4vKipcbiAqIEEgY29sbGVjdGlvbiBvZiBwYXJhbWV0ZXJzLlxuICovXG5leHBvcnQgdHlwZSBQYXJhbXMgPSB7XG4gIFtrZXk6IHN0cmluZ106IHN0cmluZ1xufTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3NoYXJlZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBSWEsc0JBQWMsR0FBRyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogTmFtZSBvZiB0aGUgcHJpbWFyeSBvdXRsZXQuXG4gKiBAdHlwZSB7c3RyaW5nfVxuICovXG5leHBvcnQgY29uc3QgUFJJTUFSWV9PVVRMRVQgPSAnUFJJTUFSWV9PVVRMRVQnO1xuXG4vKipcbiAqIEEgY29sbGVjdGlvbiBvZiBwYXJhbWV0ZXJzLlxuICovXG5leHBvcnQgdHlwZSBQYXJhbXMgPSB7XG4gIFtrZXk6IHN0cmluZ106IGFueVxufTtcbiJdfQ==

@@ -1,2 +0,2 @@

import { UrlSegment, UrlTree } from './url_tree';
import { UrlPathWithParams, UrlSegment, UrlTree } from './url_tree';
export declare abstract class UrlSerializer {

@@ -10,2 +10,3 @@ abstract parse(url: string): UrlTree;

}
export declare function serializeSegment(segment: UrlSegment): string;
export declare function serializePaths(segment: UrlSegment): string;
export declare function serializePath(path: UrlPathWithParams): string;
"use strict";
var shared_1 = require('./shared');
var url_tree_1 = require('./url_tree');
var tree_1 = require('./utils/tree');
var collection_1 = require('./utils/collection');
var UrlSerializer = (function () {

@@ -19,6 +19,6 @@ function UrlSerializer() {

DefaultUrlSerializer.prototype.serialize = function (tree) {
var node = serializeUrlTreeNode(tree._root);
var segment = "/" + serializeSegment(tree.root, true);
var query = serializeQueryParams(tree.queryParams);
var fragment = tree.fragment !== null ? "#" + tree.fragment : '';
return "" + node + query + fragment;
return "" + segment + query + fragment;
};

@@ -28,15 +28,48 @@ return DefaultUrlSerializer;

exports.DefaultUrlSerializer = DefaultUrlSerializer;
function serializeUrlTreeNode(node) {
return "" + serializeSegment(node.value) + serializeChildren(node);
function serializePaths(segment) {
return segment.pathsWithParams.map(function (p) { return serializePath(p); }).join('/');
}
function serializeUrlTreeNodes(nodes) {
var primary = serializeSegment(nodes[0].value);
var secondaryNodes = nodes.slice(1);
var secondary = secondaryNodes.length > 0 ? "(" + secondaryNodes.map(serializeUrlTreeNode).join("//") + ")" : '';
var children = serializeChildren(nodes[0]);
return "" + primary + secondary + children;
exports.serializePaths = serializePaths;
function serializeSegment(segment, root) {
if (segment.children[shared_1.PRIMARY_OUTLET] && root) {
var primary = serializeSegment(segment.children[shared_1.PRIMARY_OUTLET], false);
var children_1 = [];
collection_1.forEach(segment.children, function (v, k) {
if (k !== shared_1.PRIMARY_OUTLET) {
children_1.push(k + ":" + serializeSegment(v, false));
}
});
if (children_1.length > 0) {
return primary + "(" + children_1.join('//') + ")";
}
else {
return "" + primary;
}
}
else if (segment.children[shared_1.PRIMARY_OUTLET] && !root) {
var children_2 = [serializeSegment(segment.children[shared_1.PRIMARY_OUTLET], false)];
collection_1.forEach(segment.children, function (v, k) {
if (k !== shared_1.PRIMARY_OUTLET) {
children_2.push(k + ":" + serializeSegment(v, false));
}
});
return serializePaths(segment) + "/(" + children_2.join('//') + ")";
}
else {
return serializePaths(segment);
}
}
function serializeChildren(node) {
if (node.children.length > 0) {
return "/" + serializeUrlTreeNodes(node.children);
function serializeChildren(segment) {
if (segment.children[shared_1.PRIMARY_OUTLET]) {
var primary = serializePaths(segment.children[shared_1.PRIMARY_OUTLET]);
var secondary_1 = [];
collection_1.forEach(segment.children, function (v, k) {
if (k !== shared_1.PRIMARY_OUTLET) {
secondary_1.push(k + ":" + serializePaths(v) + serializeChildren(v));
}
});
var secondaryStr = secondary_1.length > 0 ? "(" + secondary_1.join('//') + ")" : '';
var primaryChildren = serializeChildren(segment.children[shared_1.PRIMARY_OUTLET]);
var primaryChildrenStr = primaryChildren ? "/" + primaryChildren : '';
return "" + primary + secondaryStr + primaryChildrenStr;
}

@@ -47,7 +80,6 @@ else {

}
function serializeSegment(segment) {
var outlet = segment.outlet === shared_1.PRIMARY_OUTLET ? '' : segment.outlet + ":";
return "" + outlet + segment.path + serializeParams(segment.parameters);
function serializePath(path) {
return "" + path.path + serializeParams(path.parameters);
}
exports.serializeSegment = serializeSegment;
exports.serializePath = serializePath;
function serializeParams(params) {

@@ -77,3 +109,3 @@ return pairs(params).map(function (p) { return (";" + p.first + "=" + p.second); }).join('');

var SEGMENT_RE = /^[^\/\(\)\?;=&#]+/;
function matchUrlSegment(str) {
function matchPathWithParams(str) {
SEGMENT_RE.lastIndex = 0;

@@ -101,13 +133,12 @@ var match = SEGMENT_RE.exec(str);

UrlParser.prototype.parseRootSegment = function () {
if (this.remaining == '' || this.remaining == '/') {
return new tree_1.TreeNode(new url_tree_1.UrlSegment('', {}, shared_1.PRIMARY_OUTLET), []);
if (this.remaining === '' || this.remaining === '/') {
return new url_tree_1.UrlSegment([], {});
}
else {
var segments = this.parseSegments(false);
return new tree_1.TreeNode(new url_tree_1.UrlSegment('', {}, shared_1.PRIMARY_OUTLET), segments);
return new url_tree_1.UrlSegment([], this.parseSegmentChildren());
}
};
UrlParser.prototype.parseSegments = function (hasOutletName) {
UrlParser.prototype.parseSegmentChildren = function () {
if (this.remaining.length == 0) {
return [];
return {};
}

@@ -117,21 +148,22 @@ if (this.peekStartsWith('/')) {

}
var path = matchUrlSegment(this.remaining);
this.capture(path);
var outletName;
if (hasOutletName) {
if (path.indexOf(':') === -1) {
throw new Error('Not outlet name is provided');
}
if (path.indexOf(':') > -1 && hasOutletName) {
var parts = path.split(':');
outletName = parts[0];
path = parts[1];
}
var paths = [this.parsePathWithParams()];
while (this.peekStartsWith('/') && !this.peekStartsWith('//') && !this.peekStartsWith('/(')) {
this.capture('/');
paths.push(this.parsePathWithParams());
}
else {
if (path.indexOf(':') > -1) {
throw new Error('Not outlet name is allowed');
}
outletName = shared_1.PRIMARY_OUTLET;
var children = {};
if (this.peekStartsWith('/(')) {
this.capture('/');
children = this.parseParens(true);
}
var res = {};
if (this.peekStartsWith('(')) {
res = this.parseParens(false);
}
res[shared_1.PRIMARY_OUTLET] = new url_tree_1.UrlSegment(paths, children);
return res;
};
UrlParser.prototype.parsePathWithParams = function () {
var path = matchPathWithParams(this.remaining);
this.capture(path);
var matrixParams = {};

@@ -141,14 +173,3 @@ if (this.peekStartsWith(';')) {

}
var secondary = [];
if (this.peekStartsWith('(')) {
secondary = this.parseSecondarySegments();
}
var children = [];
if (this.peekStartsWith('/') && !this.peekStartsWith('//')) {
this.capture('/');
children = this.parseSegments(false);
}
var segment = new url_tree_1.UrlSegment(path, matrixParams, outletName);
var node = new tree_1.TreeNode(segment, children);
return [node].concat(secondary);
return new url_tree_1.UrlPathWithParams(path, matrixParams);
};

@@ -184,3 +205,3 @@ UrlParser.prototype.parseQueryParams = function () {

UrlParser.prototype.parseParam = function (params) {
var key = matchUrlSegment(this.remaining);
var key = matchPathWithParams(this.remaining);
if (!key) {

@@ -193,3 +214,3 @@ return;

this.capture('=');
var valueMatch = matchUrlSegment(this.remaining);
var valueMatch = matchPathWithParams(this.remaining);
if (valueMatch) {

@@ -203,3 +224,3 @@ value = valueMatch;

UrlParser.prototype.parseQueryParam = function (params) {
var key = matchUrlSegment(this.remaining);
var key = matchPathWithParams(this.remaining);
if (!key) {

@@ -220,7 +241,19 @@ return;

};
UrlParser.prototype.parseSecondarySegments = function () {
var segments = [];
UrlParser.prototype.parseParens = function (allowPrimary) {
var segments = {};
this.capture('(');
while (!this.peekStartsWith(')') && this.remaining.length > 0) {
segments = segments.concat(this.parseSegments(true));
var path = matchPathWithParams(this.remaining);
var outletName = void 0;
if (path.indexOf(':') > -1) {
outletName = path.substr(0, path.indexOf(':'));
this.capture(outletName);
this.capture(':');
}
else if (allowPrimary) {
outletName = shared_1.PRIMARY_OUTLET;
}
var children = this.parseSegmentChildren();
segments[outletName] = Object.keys(children).length === 1 ? children[shared_1.PRIMARY_OUTLET] :
new url_tree_1.UrlSegment([], children);
if (this.peekStartsWith('//')) {

@@ -235,2 +268,2 @@ this.capture('//');

}());
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"url_serializer.js","sourceRoot":"","sources":["../src/url_serializer.ts"],"names":[],"mappings":"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","sourcesContent":["import {PRIMARY_OUTLET} from './shared';\nimport {UrlSegment, UrlTree} from './url_tree';\nimport {TreeNode} from './utils/tree';\n\n\n/**\n * Defines a way to serialize/deserialize a url tree.\n */\nexport abstract class UrlSerializer {\n  /**\n   * Parse a url into a {@Link UrlTree}\n   */\n  abstract parse(url: string): UrlTree;\n\n  /**\n   * Converts a {@Link UrlTree} into a url\n   */\n  abstract serialize(tree: UrlTree): string;\n}\n\n/**\n * A default implementation of the serialization.\n */\nexport class DefaultUrlSerializer implements UrlSerializer {\n  parse(url: string): UrlTree {\n    const p = new UrlParser(url);\n    return new UrlTree(p.parseRootSegment(), p.parseQueryParams(), p.parseFragment());\n  }\n\n  serialize(tree: UrlTree): string {\n    const node = serializeUrlTreeNode(tree._root);\n    const query = serializeQueryParams(tree.queryParams);\n    const fragment = tree.fragment !== null ? `#${tree.fragment}` : '';\n    return `${node}${query}${fragment}`;\n  }\n}\n\nfunction serializeUrlTreeNode(node: TreeNode<UrlSegment>): string {\n  return `${serializeSegment(node.value)}${serializeChildren(node)}`;\n}\n\nfunction serializeUrlTreeNodes(nodes: TreeNode<UrlSegment>[]): string {\n  const primary = serializeSegment(nodes[0].value);\n  const secondaryNodes = nodes.slice(1);\n  const secondary =\n      secondaryNodes.length > 0 ? `(${secondaryNodes.map(serializeUrlTreeNode).join(\"//\")})` : '';\n  const children = serializeChildren(nodes[0]);\n  return `${primary}${secondary}${children}`;\n}\n\nfunction serializeChildren(node: TreeNode<UrlSegment>): string {\n  if (node.children.length > 0) {\n    return `/${serializeUrlTreeNodes(node.children)}`;\n  } else {\n    return '';\n  }\n}\n\nexport function serializeSegment(segment: UrlSegment): string {\n  const outlet = segment.outlet === PRIMARY_OUTLET ? '' : `${segment.outlet}:`;\n  return `${outlet}${segment.path}${serializeParams(segment.parameters)}`;\n}\n\nfunction serializeParams(params: {[key: string]: string}): string {\n  return pairs(params).map(p => `;${p.first}=${p.second}`).join('');\n}\n\nfunction serializeQueryParams(params: {[key: string]: string}): string {\n  const strs = pairs(params).map(p => `${p.first}=${p.second}`);\n  return strs.length > 0 ? `?${strs.join(\"&\")}` : '';\n}\n\nclass Pair<A, B> {\n  constructor(public first: A, public second: B) {}\n}\nfunction pairs<T>(obj: {[key: string]: T}): Pair<string, T>[] {\n  const res = [];\n  for (let prop in obj) {\n    if (obj.hasOwnProperty(prop)) {\n      res.push(new Pair<string, T>(prop, obj[prop]));\n    }\n  }\n  return res;\n}\n\nconst SEGMENT_RE = /^[^\\/\\(\\)\\?;=&#]+/;\nfunction matchUrlSegment(str: string): string {\n  SEGMENT_RE.lastIndex = 0;\n  var match = SEGMENT_RE.exec(str);\n  return match ? match[0] : '';\n}\n\nconst QUERY_PARAM_VALUE_RE = /^[^\\(\\)\\?;&#]+/;\nfunction matchUrlQueryParamValue(str: string): string {\n  QUERY_PARAM_VALUE_RE.lastIndex = 0;\n  const match = QUERY_PARAM_VALUE_RE.exec(str);\n  return match ? match[0] : '';\n}\n\nclass UrlParser {\n  constructor(private remaining: string) {}\n\n  peekStartsWith(str: string): boolean { return this.remaining.startsWith(str); }\n\n  capture(str: string): void {\n    if (!this.remaining.startsWith(str)) {\n      throw new Error(`Expected \"${str}\".`);\n    }\n    this.remaining = this.remaining.substring(str.length);\n  }\n\n  parseRootSegment(): TreeNode<UrlSegment> {\n    if (this.remaining == '' || this.remaining == '/') {\n      return new TreeNode<UrlSegment>(new UrlSegment('', {}, PRIMARY_OUTLET), []);\n    } else {\n      const segments = this.parseSegments(false);\n      return new TreeNode<UrlSegment>(new UrlSegment('', {}, PRIMARY_OUTLET), segments);\n    }\n  }\n\n  parseSegments(hasOutletName: boolean): TreeNode<UrlSegment>[] {\n    if (this.remaining.length == 0) {\n      return [];\n    }\n    if (this.peekStartsWith('/')) {\n      this.capture('/');\n    }\n    let path = matchUrlSegment(this.remaining);\n    this.capture(path);\n\n    let outletName;\n    if (hasOutletName) {\n      if (path.indexOf(':') === -1) {\n        throw new Error('Not outlet name is provided');\n      }\n      if (path.indexOf(':') > -1 && hasOutletName) {\n        let parts = path.split(':');\n        outletName = parts[0];\n        path = parts[1];\n      }\n    } else {\n      if (path.indexOf(':') > -1) {\n        throw new Error('Not outlet name is allowed');\n      }\n      outletName = PRIMARY_OUTLET;\n    }\n\n    let matrixParams: {[key: string]: any} = {};\n    if (this.peekStartsWith(';')) {\n      matrixParams = this.parseMatrixParams();\n    }\n\n    let secondary = [];\n    if (this.peekStartsWith('(')) {\n      secondary = this.parseSecondarySegments();\n    }\n\n    let children: TreeNode<UrlSegment>[] = [];\n    if (this.peekStartsWith('/') && !this.peekStartsWith('//')) {\n      this.capture('/');\n      children = this.parseSegments(false);\n    }\n\n    const segment = new UrlSegment(path, matrixParams, outletName);\n    const node = new TreeNode<UrlSegment>(segment, children);\n    return [node].concat(secondary);\n  }\n\n  parseQueryParams(): {[key: string]: any} {\n    var params: {[key: string]: any} = {};\n    if (this.peekStartsWith('?')) {\n      this.capture('?');\n      this.parseQueryParam(params);\n      while (this.remaining.length > 0 && this.peekStartsWith('&')) {\n        this.capture('&');\n        this.parseQueryParam(params);\n      }\n    }\n    return params;\n  }\n\n  parseFragment(): string|null {\n    if (this.peekStartsWith('#')) {\n      return this.remaining.substring(1);\n    } else {\n      return null;\n    }\n  }\n\n  parseMatrixParams(): {[key: string]: any} {\n    var params: {[key: string]: any} = {};\n    while (this.remaining.length > 0 && this.peekStartsWith(';')) {\n      this.capture(';');\n      this.parseParam(params);\n    }\n    return params;\n  }\n\n  parseParam(params: {[key: string]: any}): void {\n    var key = matchUrlSegment(this.remaining);\n    if (!key) {\n      return;\n    }\n    this.capture(key);\n    var value: any = 'true';\n    if (this.peekStartsWith('=')) {\n      this.capture('=');\n      var valueMatch = matchUrlSegment(this.remaining);\n      if (valueMatch) {\n        value = valueMatch;\n        this.capture(value);\n      }\n    }\n\n    params[key] = value;\n  }\n\n  parseQueryParam(params: {[key: string]: any}): void {\n    var key = matchUrlSegment(this.remaining);\n    if (!key) {\n      return;\n    }\n    this.capture(key);\n    var value: any = 'true';\n    if (this.peekStartsWith('=')) {\n      this.capture('=');\n      var valueMatch = matchUrlQueryParamValue(this.remaining);\n      if (valueMatch) {\n        value = valueMatch;\n        this.capture(value);\n      }\n    }\n    params[key] = value;\n  }\n\n  parseSecondarySegments(): TreeNode<UrlSegment>[] {\n    var segments = [];\n    this.capture('(');\n\n    while (!this.peekStartsWith(')') && this.remaining.length > 0) {\n      segments = segments.concat(this.parseSegments(true));\n      if (this.peekStartsWith('//')) {\n        this.capture('//');\n      }\n    }\n    this.capture(')');\n\n    return segments;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"url_serializer.js","sourceRoot":"","sources":["../src/url_serializer.ts"],"names":[],"mappings":"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","sourcesContent":["import {PRIMARY_OUTLET} from './shared';\nimport {UrlPathWithParams, UrlSegment, UrlTree} from './url_tree';\nimport {forEach} from './utils/collection';\n\n\n\n/**\n * Defines a way to serialize/deserialize a url tree.\n */\nexport abstract class UrlSerializer {\n  /**\n   * Parse a url into a {@Link UrlTree}\n   */\n  abstract parse(url: string): UrlTree;\n\n  /**\n   * Converts a {@Link UrlTree} into a url\n   */\n  abstract serialize(tree: UrlTree): string;\n}\n\n/**\n * A default implementation of the serialization.\n */\nexport class DefaultUrlSerializer implements UrlSerializer {\n  parse(url: string): UrlTree {\n    const p = new UrlParser(url);\n    return new UrlTree(p.parseRootSegment(), p.parseQueryParams(), p.parseFragment());\n  }\n\n  serialize(tree: UrlTree): string {\n    const segment = `/${serializeSegment(tree.root, true)}`;\n    const query = serializeQueryParams(tree.queryParams);\n    const fragment = tree.fragment !== null ? `#${tree.fragment}` : '';\n    return `${segment}${query}${fragment}`;\n  }\n}\n\nexport function serializePaths(segment: UrlSegment): string {\n  return segment.pathsWithParams.map(p => serializePath(p)).join('/');\n}\n\nfunction serializeSegment(segment: UrlSegment, root: boolean): string {\n  if (segment.children[PRIMARY_OUTLET] && root) {\n    const primary = serializeSegment(segment.children[PRIMARY_OUTLET], false);\n    const children = [];\n    forEach(segment.children, (v, k) => {\n      if (k !== PRIMARY_OUTLET) {\n        children.push(`${k}:${serializeSegment(v, false)}`);\n      }\n    });\n    if (children.length > 0) {\n      return `${primary}(${children.join('//')})`;\n    } else {\n      return `${primary}`;\n    }\n  } else if (segment.children[PRIMARY_OUTLET] && !root) {\n    const children = [serializeSegment(segment.children[PRIMARY_OUTLET], false)];\n    forEach(segment.children, (v, k) => {\n      if (k !== PRIMARY_OUTLET) {\n        children.push(`${k}:${serializeSegment(v, false)}`);\n      }\n    });\n    return `${serializePaths(segment)}/(${children.join('//')})`;\n  } else {\n    return serializePaths(segment);\n  }\n}\n\nfunction serializeChildren(segment: UrlSegment) {\n  if (segment.children[PRIMARY_OUTLET]) {\n    const primary = serializePaths(segment.children[PRIMARY_OUTLET]);\n\n    const secondary = [];\n    forEach(segment.children, (v, k) => {\n      if (k !== PRIMARY_OUTLET) {\n        secondary.push(`${k}:${serializePaths(v)}${serializeChildren(v)}`);\n      }\n    });\n    const secondaryStr = secondary.length > 0 ? `(${secondary.join('//')})` : '';\n    const primaryChildren = serializeChildren(segment.children[PRIMARY_OUTLET]);\n    const primaryChildrenStr = primaryChildren ? `/${primaryChildren}` : '';\n    return `${primary}${secondaryStr}${primaryChildrenStr}`;\n  } else {\n    return '';\n  }\n}\n\nexport function serializePath(path: UrlPathWithParams): string {\n  return `${path.path}${serializeParams(path.parameters)}`;\n}\n\nfunction serializeParams(params: {[key: string]: string}): string {\n  return pairs(params).map(p => `;${p.first}=${p.second}`).join('');\n}\n\nfunction serializeQueryParams(params: {[key: string]: string}): string {\n  const strs = pairs(params).map(p => `${p.first}=${p.second}`);\n  return strs.length > 0 ? `?${strs.join(\"&\")}` : '';\n}\n\nclass Pair<A, B> {\n  constructor(public first: A, public second: B) {}\n}\nfunction pairs<T>(obj: {[key: string]: T}): Pair<string, T>[] {\n  const res = [];\n  for (let prop in obj) {\n    if (obj.hasOwnProperty(prop)) {\n      res.push(new Pair<string, T>(prop, obj[prop]));\n    }\n  }\n  return res;\n}\n\nconst SEGMENT_RE = /^[^\\/\\(\\)\\?;=&#]+/;\nfunction matchPathWithParams(str: string): string {\n  SEGMENT_RE.lastIndex = 0;\n  var match = SEGMENT_RE.exec(str);\n  return match ? match[0] : '';\n}\n\nconst QUERY_PARAM_VALUE_RE = /^[^\\(\\)\\?;&#]+/;\nfunction matchUrlQueryParamValue(str: string): string {\n  QUERY_PARAM_VALUE_RE.lastIndex = 0;\n  const match = QUERY_PARAM_VALUE_RE.exec(str);\n  return match ? match[0] : '';\n}\n\nclass UrlParser {\n  constructor(private remaining: string) {}\n\n  peekStartsWith(str: string): boolean { return this.remaining.startsWith(str); }\n\n  capture(str: string): void {\n    if (!this.remaining.startsWith(str)) {\n      throw new Error(`Expected \"${str}\".`);\n    }\n    this.remaining = this.remaining.substring(str.length);\n  }\n\n  parseRootSegment(): UrlSegment {\n    if (this.remaining === '' || this.remaining === '/') {\n      return new UrlSegment([], {});\n    } else {\n      return new UrlSegment([], this.parseSegmentChildren());\n    }\n  }\n\n  parseSegmentChildren(): {[key: string]: UrlSegment} {\n    if (this.remaining.length == 0) {\n      return {};\n    }\n\n    if (this.peekStartsWith('/')) {\n      this.capture('/');\n    }\n\n    const paths = [this.parsePathWithParams()];\n\n    while (this.peekStartsWith('/') && !this.peekStartsWith('//') && !this.peekStartsWith('/(')) {\n      this.capture('/');\n      paths.push(this.parsePathWithParams());\n    }\n\n    let children: {[key: string]: UrlSegment} = {};\n    if (this.peekStartsWith('/(')) {\n      this.capture('/');\n      children = this.parseParens(true);\n    }\n\n    let res: {[key: string]: UrlSegment} = {};\n    if (this.peekStartsWith('(')) {\n      res = this.parseParens(false);\n    }\n\n    res[PRIMARY_OUTLET] = new UrlSegment(paths, children);\n    return res;\n  }\n\n  parsePathWithParams(): UrlPathWithParams {\n    let path = matchPathWithParams(this.remaining);\n    this.capture(path);\n    let matrixParams: {[key: string]: any} = {};\n    if (this.peekStartsWith(';')) {\n      matrixParams = this.parseMatrixParams();\n    }\n    return new UrlPathWithParams(path, matrixParams);\n  }\n\n  parseQueryParams(): {[key: string]: any} {\n    var params: {[key: string]: any} = {};\n    if (this.peekStartsWith('?')) {\n      this.capture('?');\n      this.parseQueryParam(params);\n      while (this.remaining.length > 0 && this.peekStartsWith('&')) {\n        this.capture('&');\n        this.parseQueryParam(params);\n      }\n    }\n    return params;\n  }\n\n  parseFragment(): string {\n    if (this.peekStartsWith('#')) {\n      return this.remaining.substring(1);\n    } else {\n      return null;\n    }\n  }\n\n  parseMatrixParams(): {[key: string]: any} {\n    var params: {[key: string]: any} = {};\n    while (this.remaining.length > 0 && this.peekStartsWith(';')) {\n      this.capture(';');\n      this.parseParam(params);\n    }\n    return params;\n  }\n\n  parseParam(params: {[key: string]: any}): void {\n    var key = matchPathWithParams(this.remaining);\n    if (!key) {\n      return;\n    }\n    this.capture(key);\n    var value: any = 'true';\n    if (this.peekStartsWith('=')) {\n      this.capture('=');\n      var valueMatch = matchPathWithParams(this.remaining);\n      if (valueMatch) {\n        value = valueMatch;\n        this.capture(value);\n      }\n    }\n\n    params[key] = value;\n  }\n\n  parseQueryParam(params: {[key: string]: any}): void {\n    var key = matchPathWithParams(this.remaining);\n    if (!key) {\n      return;\n    }\n    this.capture(key);\n    var value: any = 'true';\n    if (this.peekStartsWith('=')) {\n      this.capture('=');\n      var valueMatch = matchUrlQueryParamValue(this.remaining);\n      if (valueMatch) {\n        value = valueMatch;\n        this.capture(value);\n      }\n    }\n    params[key] = value;\n  }\n\n  parseParens(allowPrimary: boolean): {[key: string]: UrlSegment} {\n    const segments: {[key: string]: UrlSegment} = {};\n    this.capture('(');\n\n    while (!this.peekStartsWith(')') && this.remaining.length > 0) {\n      let path = matchPathWithParams(this.remaining);\n      let outletName;\n      if (path.indexOf(':') > -1) {\n        outletName = path.substr(0, path.indexOf(':'));\n        this.capture(outletName);\n        this.capture(':');\n      } else if (allowPrimary) {\n        outletName = PRIMARY_OUTLET;\n      }\n\n      const children = this.parseSegmentChildren();\n      segments[outletName] = Object.keys(children).length === 1 ? children[PRIMARY_OUTLET] :\n                                                                  new UrlSegment([], children);\n\n      if (this.peekStartsWith('//')) {\n        this.capture('//');\n      }\n    }\n    this.capture(')');\n\n    return segments;\n  }\n}\n"]}

@@ -1,13 +0,25 @@

import { Tree, TreeNode } from './utils/tree';
export declare function createEmptyUrlTree(): UrlTree;
export declare class UrlTree extends Tree<UrlSegment> {
export declare class UrlTree {
root: UrlSegment;
queryParams: {
[key: string]: string;
};
fragment: string | null;
constructor(root: TreeNode<UrlSegment>, queryParams: {
fragment: string;
constructor(root: UrlSegment, queryParams: {
[key: string]: string;
}, fragment: string | null);
}, fragment: string);
toString(): string;
}
export declare class UrlSegment {
pathsWithParams: UrlPathWithParams[];
children: {
[key: string]: UrlSegment;
};
parent: UrlSegment;
constructor(pathsWithParams: UrlPathWithParams[], children: {
[key: string]: UrlSegment;
});
toString(): string;
}
export declare class UrlPathWithParams {
path: string;

@@ -17,8 +29,11 @@ parameters: {

};
outlet: string;
constructor(path: string, parameters: {
[key: string]: string;
}, outlet: string);
});
toString(): string;
}
export declare function equalUrlSegments(a: UrlSegment[], b: UrlSegment[]): boolean;
export declare function equalPathsWithParams(a: UrlPathWithParams[], b: UrlPathWithParams[]): boolean;
export declare function mapChildren(segment: UrlSegment, fn: (v: UrlSegment, k: string) => UrlSegment): {
[name: string]: UrlSegment;
};
export declare function mapChildrenIntoArray<T>(segment: UrlSegment, fn: (v: UrlSegment, k: string) => T[]): T[];
"use strict";
var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var shared_1 = require('./shared');
var url_serializer_1 = require('./url_serializer');
var collection_1 = require('./utils/collection');
var tree_1 = require('./utils/tree');
function createEmptyUrlTree() {
return new UrlTree(new tree_1.TreeNode(new UrlSegment('', {}, shared_1.PRIMARY_OUTLET), []), {}, null);
return new UrlTree(new UrlSegment([], {}), {}, null);
}
exports.createEmptyUrlTree = createEmptyUrlTree;
var UrlTree = (function (_super) {
__extends(UrlTree, _super);
var UrlTree = (function () {
function UrlTree(root, queryParams, fragment) {
_super.call(this, root);
this.root = root;
this.queryParams = queryParams;
this.fragment = fragment;
}
UrlTree.prototype.toString = function () { return new url_serializer_1.DefaultUrlSerializer().serialize(this); };
return UrlTree;
}(tree_1.Tree));
}());
exports.UrlTree = UrlTree;
var UrlSegment = (function () {
function UrlSegment(path, parameters, outlet) {
function UrlSegment(pathsWithParams, children) {
var _this = this;
this.pathsWithParams = pathsWithParams;
this.children = children;
this.parent = null;
collection_1.forEach(children, function (v, k) { return v.parent = _this; });
}
UrlSegment.prototype.toString = function () { return url_serializer_1.serializePaths(this); };
return UrlSegment;
}());
exports.UrlSegment = UrlSegment;
var UrlPathWithParams = (function () {
function UrlPathWithParams(path, parameters) {
this.path = path;
this.parameters = parameters;
this.outlet = outlet;
}
UrlSegment.prototype.toString = function () {
var params = [];
for (var prop in this.parameters) {
if (this.parameters.hasOwnProperty(prop)) {
params.push(prop + "=" + this.parameters[prop]);
}
}
var paramsString = params.length > 0 ? "(" + params.join(',') + ")" : '';
var outlet = this.outlet === shared_1.PRIMARY_OUTLET ? '' : this.outlet + ":";
return "" + outlet + this.path + paramsString;
};
return UrlSegment;
UrlPathWithParams.prototype.toString = function () { return url_serializer_1.serializePath(this); };
return UrlPathWithParams;
}());
exports.UrlSegment = UrlSegment;
function equalUrlSegments(a, b) {
exports.UrlPathWithParams = UrlPathWithParams;
function equalPathsWithParams(a, b) {
if (a.length !== b.length)

@@ -55,3 +51,33 @@ return false;

}
exports.equalUrlSegments = equalUrlSegments;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXJsX3RyZWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXJsX3RyZWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsdUJBQTZCLFVBQVUsQ0FBQyxDQUFBO0FBQ3hDLDJCQUEyQixvQkFBb0IsQ0FBQyxDQUFBO0FBQ2hELHFCQUE2QixjQUFjLENBQUMsQ0FBQTtBQUU1QztJQUNFLE1BQU0sQ0FBQyxJQUFJLE9BQU8sQ0FDZCxJQUFJLGVBQVEsQ0FBYSxJQUFJLFVBQVUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLHVCQUFjLENBQUMsRUFBRSxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDdEYsQ0FBQztBQUhlLDBCQUFrQixxQkFHakMsQ0FBQTtBQUtEO0lBQTZCLDJCQUFnQjtJQUkzQyxpQkFDSSxJQUEwQixFQUFTLFdBQW9DLEVBQ2hFLFFBQXFCO1FBQzlCLGtCQUFNLElBQUksQ0FBQyxDQUFDO1FBRnlCLGdCQUFXLEdBQVgsV0FBVyxDQUF5QjtRQUNoRSxhQUFRLEdBQVIsUUFBUSxDQUFhO0lBRWhDLENBQUM7SUFDSCxjQUFDO0FBQUQsQ0FBQyxBQVRELENBQTZCLFdBQUksR0FTaEM7QUFUWSxlQUFPLFVBU25CLENBQUE7QUFFRDtJQUlFLG9CQUNXLElBQVksRUFBUyxVQUFtQyxFQUFTLE1BQWM7UUFBL0UsU0FBSSxHQUFKLElBQUksQ0FBUTtRQUFTLGVBQVUsR0FBVixVQUFVLENBQXlCO1FBQVMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtJQUFHLENBQUM7SUFFOUYsNkJBQVEsR0FBUjtRQUNFLElBQU0sTUFBTSxHQUFHLEVBQUUsQ0FBQztRQUNsQixHQUFHLENBQUMsQ0FBQyxJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztZQUNqQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7Z0JBQ3pDLE1BQU0sQ0FBQyxJQUFJLENBQUksSUFBSSxTQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFHLENBQUMsQ0FBQztZQUNsRCxDQUFDO1FBQ0gsQ0FBQztRQUNELElBQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxHQUFHLE1BQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsTUFBRyxHQUFHLEVBQUUsQ0FBQztRQUN0RSxJQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxLQUFLLHVCQUFjLEdBQUcsRUFBRSxHQUFNLElBQUksQ0FBQyxNQUFNLE1BQUcsQ0FBQztRQUN2RSxNQUFNLENBQUMsS0FBRyxNQUFNLEdBQUcsSUFBSSxDQUFDLElBQUksR0FBRyxZQUFjLENBQUM7SUFDaEQsQ0FBQztJQUNILGlCQUFDO0FBQUQsQ0FBQyxBQWxCRCxJQWtCQztBQWxCWSxrQkFBVSxhQWtCdEIsQ0FBQTtBQUVELDBCQUFpQyxDQUFlLEVBQUUsQ0FBZTtJQUMvRCxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUM7UUFBQyxNQUFNLENBQUMsS0FBSyxDQUFDO0lBQ3hDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDO1FBQ2xDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztZQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUM7UUFDMUMsRUFBRSxDQUFDLENBQUMsQ0FBQyx5QkFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQztJQUNwRSxDQUFDO0lBQ0QsTUFBTSxDQUFDLElBQUksQ0FBQztBQUNkLENBQUM7QUFQZSx3QkFBZ0IsbUJBTy9CLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1BSSU1BUllfT1VUTEVUfSBmcm9tICcuL3NoYXJlZCc7XG5pbXBvcnQge3NoYWxsb3dFcXVhbH0gZnJvbSAnLi91dGlscy9jb2xsZWN0aW9uJztcbmltcG9ydCB7VHJlZSwgVHJlZU5vZGV9IGZyb20gJy4vdXRpbHMvdHJlZSc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFbXB0eVVybFRyZWUoKSB7XG4gIHJldHVybiBuZXcgVXJsVHJlZShcbiAgICAgIG5ldyBUcmVlTm9kZTxVcmxTZWdtZW50PihuZXcgVXJsU2VnbWVudCgnJywge30sIFBSSU1BUllfT1VUTEVUKSwgW10pLCB7fSwgbnVsbCk7XG59XG5cbi8qKlxuICogQSBVUkwgaW4gdGhlIHRyZWUgZm9ybS5cbiAqL1xuZXhwb3J0IGNsYXNzIFVybFRyZWUgZXh0ZW5kcyBUcmVlPFVybFNlZ21lbnQ+IHtcbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgY29uc3RydWN0b3IoXG4gICAgICByb290OiBUcmVlTm9kZTxVcmxTZWdtZW50PiwgcHVibGljIHF1ZXJ5UGFyYW1zOiB7W2tleTogc3RyaW5nXTogc3RyaW5nfSxcbiAgICAgIHB1YmxpYyBmcmFnbWVudDogc3RyaW5nfG51bGwpIHtcbiAgICBzdXBlcihyb290KTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgVXJsU2VnbWVudCB7XG4gIC8qKlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIGNvbnN0cnVjdG9yKFxuICAgICAgcHVibGljIHBhdGg6IHN0cmluZywgcHVibGljIHBhcmFtZXRlcnM6IHtba2V5OiBzdHJpbmddOiBzdHJpbmd9LCBwdWJsaWMgb3V0bGV0OiBzdHJpbmcpIHt9XG5cbiAgdG9TdHJpbmcoKSB7XG4gICAgY29uc3QgcGFyYW1zID0gW107XG4gICAgZm9yIChsZXQgcHJvcCBpbiB0aGlzLnBhcmFtZXRlcnMpIHtcbiAgICAgIGlmICh0aGlzLnBhcmFtZXRlcnMuaGFzT3duUHJvcGVydHkocHJvcCkpIHtcbiAgICAgICAgcGFyYW1zLnB1c2goYCR7cHJvcH09JHt0aGlzLnBhcmFtZXRlcnNbcHJvcF19YCk7XG4gICAgICB9XG4gICAgfVxuICAgIGNvbnN0IHBhcmFtc1N0cmluZyA9IHBhcmFtcy5sZW5ndGggPiAwID8gYCgke3BhcmFtcy5qb2luKCcsJyl9KWAgOiAnJztcbiAgICBjb25zdCBvdXRsZXQgPSB0aGlzLm91dGxldCA9PT0gUFJJTUFSWV9PVVRMRVQgPyAnJyA6IGAke3RoaXMub3V0bGV0fTpgO1xuICAgIHJldHVybiBgJHtvdXRsZXR9JHt0aGlzLnBhdGh9JHtwYXJhbXNTdHJpbmd9YDtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZXF1YWxVcmxTZWdtZW50cyhhOiBVcmxTZWdtZW50W10sIGI6IFVybFNlZ21lbnRbXSk6IGJvb2xlYW4ge1xuICBpZiAoYS5sZW5ndGggIT09IGIubGVuZ3RoKSByZXR1cm4gZmFsc2U7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgYS5sZW5ndGg7ICsraSkge1xuICAgIGlmIChhW2ldLnBhdGggIT09IGJbaV0ucGF0aCkgcmV0dXJuIGZhbHNlO1xuICAgIGlmICghc2hhbGxvd0VxdWFsKGFbaV0ucGFyYW1ldGVycywgYltpXS5wYXJhbWV0ZXJzKSkgcmV0dXJuIGZhbHNlO1xuICB9XG4gIHJldHVybiB0cnVlO1xufVxuIl19
exports.equalPathsWithParams = equalPathsWithParams;
function mapChildren(segment, fn) {
var newChildren = {};
collection_1.forEach(segment.children, function (child, childOutlet) {
if (childOutlet === shared_1.PRIMARY_OUTLET) {
newChildren[childOutlet] = fn(child, childOutlet);
}
});
collection_1.forEach(segment.children, function (child, childOutlet) {
if (childOutlet !== shared_1.PRIMARY_OUTLET) {
newChildren[childOutlet] = fn(child, childOutlet);
}
});
return newChildren;
}
exports.mapChildren = mapChildren;
function mapChildrenIntoArray(segment, fn) {
var res = [];
collection_1.forEach(segment.children, function (child, childOutlet) {
if (childOutlet === shared_1.PRIMARY_OUTLET) {
res = res.concat(fn(child, childOutlet));
}
});
collection_1.forEach(segment.children, function (child, childOutlet) {
if (childOutlet !== shared_1.PRIMARY_OUTLET) {
res = res.concat(fn(child, childOutlet));
}
});
return res;
}
exports.mapChildrenIntoArray = mapChildrenIntoArray;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXJsX3RyZWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXJsX3RyZWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHVCQUE2QixVQUFVLENBQUMsQ0FBQTtBQUN4QywrQkFBa0Usa0JBQWtCLENBQUMsQ0FBQTtBQUNyRiwyQkFBb0Msb0JBQW9CLENBQUMsQ0FBQTtBQUV6RDtJQUNFLE1BQU0sQ0FBQyxJQUFJLE9BQU8sQ0FBQyxJQUFJLFVBQVUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLEVBQUUsRUFBRSxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ3ZELENBQUM7QUFGZSwwQkFBa0IscUJBRWpDLENBQUE7QUFLRDtJQUlFLGlCQUNXLElBQWdCLEVBQVMsV0FBb0MsRUFDN0QsUUFBZ0I7UUFEaEIsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUFTLGdCQUFXLEdBQVgsV0FBVyxDQUF5QjtRQUM3RCxhQUFRLEdBQVIsUUFBUSxDQUFRO0lBQUcsQ0FBQztJQUUvQiwwQkFBUSxHQUFSLGNBQXFCLE1BQU0sQ0FBQyxJQUFJLHFDQUFvQixFQUFFLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMzRSxjQUFDO0FBQUQsQ0FBQyxBQVRELElBU0M7QUFUWSxlQUFPLFVBU25CLENBQUE7QUFFRDtJQUVFLG9CQUNXLGVBQW9DLEVBQVMsUUFBcUM7UUFIL0YsaUJBUUM7UUFMWSxvQkFBZSxHQUFmLGVBQWUsQ0FBcUI7UUFBUyxhQUFRLEdBQVIsUUFBUSxDQUE2QjtRQUZ0RixXQUFNLEdBQWUsSUFBSSxDQUFDO1FBRy9CLG9CQUFPLENBQUMsUUFBUSxFQUFFLFVBQUMsQ0FBQyxFQUFFLENBQUMsSUFBSyxPQUFBLENBQUMsQ0FBQyxNQUFNLEdBQUcsS0FBSSxFQUFmLENBQWUsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRCw2QkFBUSxHQUFSLGNBQXFCLE1BQU0sQ0FBQywrQkFBYyxDQUFDLElBQUksQ0FBQyxDQUFD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QyxDQUFDO1FBQzNDLENBQUM7SUFDSCxDQUFDLENBQUMsQ0FBQztJQUNILE1BQU0sQ0FBQyxHQUFHLENBQUM7QUFDYixDQUFDO0FBZGUsNEJBQW9CLHVCQWNuQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtQUklNQVJZX09VVExFVH0gZnJvbSAnLi9zaGFyZWQnO1xuaW1wb3J0IHtEZWZhdWx0VXJsU2VyaWFsaXplciwgc2VyaWFsaXplUGF0aCwgc2VyaWFsaXplUGF0aHN9IGZyb20gJy4vdXJsX3NlcmlhbGl6ZXInO1xuaW1wb3J0IHtmb3JFYWNoLCBzaGFsbG93RXF1YWx9IGZyb20gJy4vdXRpbHMvY29sbGVjdGlvbic7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFbXB0eVVybFRyZWUoKSB7XG4gIHJldHVybiBuZXcgVXJsVHJlZShuZXcgVXJsU2VnbWVudChbXSwge30pLCB7fSwgbnVsbCk7XG59XG5cbi8qKlxuICogQSBVUkwgaW4gdGhlIHRyZWUgZm9ybS5cbiAqL1xuZXhwb3J0IGNsYXNzIFVybFRyZWUge1xuICAvKipcbiAgICogQGludGVybmFsXG4gICAqL1xuICBjb25zdHJ1Y3RvcihcbiAgICAgIHB1YmxpYyByb290OiBVcmxTZWdtZW50LCBwdWJsaWMgcXVlcnlQYXJhbXM6IHtba2V5OiBzdHJpbmddOiBzdHJpbmd9LFxuICAgICAgcHVibGljIGZyYWdtZW50OiBzdHJpbmcpIHt9XG5cbiAgdG9TdHJpbmcoKTogc3RyaW5nIHsgcmV0dXJuIG5ldyBEZWZhdWx0VXJsU2VyaWFsaXplcigpLnNlcmlhbGl6ZSh0aGlzKTsgfVxufVxuXG5leHBvcnQgY2xhc3MgVXJsU2VnbWVudCB7XG4gIHB1YmxpYyBwYXJlbnQ6IFVybFNlZ21lbnQgPSBudWxsO1xuICBjb25zdHJ1Y3RvcihcbiAgICAgIHB1YmxpYyBwYXRoc1dpdGhQYXJhbXM6IFVybFBhdGhXaXRoUGFyYW1zW10sIHB1YmxpYyBjaGlsZHJlbjoge1trZXk6IHN0cmluZ106IFVybFNlZ21lbnR9KSB7XG4gICAgZm9yRWFjaChjaGlsZHJlbiwgKHYsIGspID0+IHYucGFyZW50ID0gdGhpcyk7XG4gIH1cblxuICB0b1N0cmluZygpOiBzdHJpbmcgeyByZXR1cm4gc2VyaWFsaXplUGF0aHModGhpcyk7IH1cbn1cblxuZXhwb3J0IGNsYXNzIFVybFBhdGhXaXRoUGFyYW1zIHtcbiAgY29uc3RydWN0b3IocHVibGljIHBhdGg6IHN0cmluZywgcHVibGljIHBhcmFtZXRlcnM6IHtba2V5OiBzdHJpbmddOiBzdHJpbmd9KSB7fVxuICB0b1N0cmluZygpOiBzdHJpbmcgeyByZXR1cm4gc2VyaWFsaXplUGF0aCh0aGlzKTsgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gZXF1YWxQYXRoc1dpdGhQYXJhbXMoYTogVXJsUGF0aFdpdGhQYXJhbXNbXSwgYjogVXJsUGF0aFdpdGhQYXJhbXNbXSk6IGJvb2xlYW4ge1xuICBpZiAoYS5sZW5ndGggIT09IGIubGVuZ3RoKSByZXR1cm4gZmFsc2U7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgYS5sZW5ndGg7ICsraSkge1xuICAgIGlmIChhW2ldLnBhdGggIT09IGJbaV0ucGF0aCkgcmV0dXJuIGZhbHNlO1xuICAgIGlmICghc2hhbGxvd0VxdWFsKGFbaV0ucGFyYW1ldGVycywgYltpXS5wYXJhbWV0ZXJzKSkgcmV0dXJuIGZhbHNlO1xuICB9XG4gIHJldHVybiB0cnVlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwQ2hpbGRyZW4oc2VnbWVudDogVXJsU2VnbWVudCwgZm46ICh2OiBVcmxTZWdtZW50LCBrOiBzdHJpbmcpID0+IFVybFNlZ21lbnQpOlxuICAgIHtbbmFtZTogc3RyaW5nXTogVXJsU2VnbWVudH0ge1xuICBjb25zdCBuZXdDaGlsZHJlbjoge1tuYW1lOiBzdHJpbmddOiBVcmxTZWdtZW50fSA9IHt9O1xuICBmb3JFYWNoKHNlZ21lbnQuY2hpbGRyZW4sIChjaGlsZCwgY2hpbGRPdXRsZXQpID0+IHtcbiAgICBpZiAoY2hpbGRPdXRsZXQgPT09IFBSSU1BUllfT1VUTEVUKSB7XG4gICAgICBuZXdDaGlsZHJlbltjaGlsZE91dGxldF0gPSBmbihjaGlsZCwgY2hpbGRPdXRsZXQpO1xuICAgIH1cbiAgfSk7XG4gIGZvckVhY2goc2VnbWVudC5jaGlsZHJlbiwgKGNoaWxkLCBjaGlsZE91dGxldCkgPT4ge1xuICAgIGlmIChjaGlsZE91dGxldCAhPT0gUFJJTUFSWV9PVVRMRVQpIHtcbiAgICAgIG5ld0NoaWxkcmVuW2NoaWxkT3V0bGV0XSA9IGZuKGNoaWxkLCBjaGlsZE91dGxldCk7XG4gICAgfVxuICB9KTtcbiAgcmV0dXJuIG5ld0NoaWxkcmVuO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWFwQ2hpbGRyZW5JbnRvQXJyYXk8VD4oXG4gICAgc2VnbWVudDogVXJsU2VnbWVudCwgZm46ICh2OiBVcmxTZWdtZW50LCBrOiBzdHJpbmcpID0+IFRbXSk6IFRbXSB7XG4gIGxldCByZXMgPSBbXTtcbiAgZm9yRWFjaChzZWdtZW50LmNoaWxkcmVuLCAoY2hpbGQsIGNoaWxkT3V0bGV0KSA9PiB7XG4gICAgaWYgKGNoaWxkT3V0bGV0ID09PSBQUklNQVJZX09VVExFVCkge1xuICAgICAgcmVzID0gcmVzLmNvbmNhdChmbihjaGlsZCwgY2hpbGRPdXRsZXQpKTtcbiAgICB9XG4gIH0pO1xuICBmb3JFYWNoKHNlZ21lbnQuY2hpbGRyZW4sIChjaGlsZCwgY2hpbGRPdXRsZXQpID0+IHtcbiAgICBpZiAoY2hpbGRPdXRsZXQgIT09IFBSSU1BUllfT1VUTEVUKSB7XG4gICAgICByZXMgPSByZXMuY29uY2F0KGZuKGNoaWxkLCBjaGlsZE91dGxldCkpO1xuICAgIH1cbiAgfSk7XG4gIHJldHVybiByZXM7XG59XG4iXX0=

@@ -7,4 +7,4 @@ export declare function shallowEqual(a: {

export declare function flatten<T>(a: T[][]): T[];
export declare function first<T>(a: T[]): T | null;
export declare function last<T>(a: T[]): T | null;
export declare function first<T>(a: T[]): T;
export declare function last<T>(a: T[]): T;
export declare function and(bools: boolean[]): boolean;

@@ -11,0 +11,0 @@ export declare function merge<V>(m1: {

@@ -63,2 +63,2 @@ "use strict";

exports.forEach = forEach;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jb2xsZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxzQkFBNkIsQ0FBcUIsRUFBRSxDQUFxQjtJQUN2RSxJQUFJLEVBQUUsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3hCLElBQUksRUFBRSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDeEIsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLE1BQU0sSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUMzQixNQUFNLENBQUMsS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUNELElBQUksR0FBRyxDQUFDO0lBQ1IsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7UUFDbkMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNaLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3RCLE1BQU0sQ0FBQyxLQUFLLENBQUM7UUFDZixDQUFDO0lBQ0gsQ0FBQztJQUNELE1BQU0sQ0FBQyxJQUFJLENBQUM7QUFDZCxDQUFDO0FBZGUsb0JBQVksZUFjM0IsQ0FBQTtBQUVELGlCQUEyQixDQUFRO0lBQ2pDLElBQU0sTUFBTSxHQUFHLEVBQUUsQ0FBQztJQUNsQixHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQztRQUNsQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQztZQUNyQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3ZCLENBQUM7SUFDSCxDQUFDO0lBQ0QsTUFBTSxDQUFDLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBUmUsZUFBTyxVQVF0QixDQUFBO0FBRUQsZUFBeUIsQ0FBTTtJQUM3QixNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztBQUNwQyxDQUFDO0FBRmUsYUFBSyxRQUVwQixDQUFBO0FBRUQsY0FBd0IsQ0FBTTtJQUM1QixNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0FBQy9DLENBQUM7QUFGZSxZQUFJLE9BRW5CLENBQUE7QUFFRCxhQUFvQixLQUFnQjtJQUNsQyxNQUFNLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxVQUFDLENBQUMsRUFBRSxDQUFDLElBQUssT0FBQSxDQUFDLElBQUksQ0FBQyxFQUFOLENBQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztBQUM5QyxDQUFDO0FBRmUsV0FBRyxNQUVsQixDQUFBO0FBRUQsZUFBeUIsRUFBc0IsRUFBRSxFQUFzQjtJQUNyRSxJQUFJLENBQUMsR0FBdUIsRUFBRSxDQUFDO0lBRS9CLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDcEIsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDNUIsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQixDQUFDO0lBQ0gsQ0FBQztJQUVELEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDcEIsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDNUIsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQixDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxDQUFDLENBQUM7QUFDWCxDQUFDO0FBaEJlLGFBQUssUUFnQnBCLENBQUE7QUFFRCxpQkFDSSxHQUF1QixFQUFFLFFBQXFDO0lBQ2hFLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDckIsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDN0IsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUM1QixDQUFDO0lBQ0gsQ0FBQztBQUNILENBQUM7QUFQZSxlQUFPLFVBT3RCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gc2hhbGxvd0VxdWFsKGE6IHtbeDogc3RyaW5nXTogYW55fSwgYjoge1t4OiBzdHJpbmddOiBhbnl9KTogYm9vbGVhbiB7XG4gIHZhciBrMSA9IE9iamVjdC5rZXlzKGEpO1xuICB2YXIgazIgPSBPYmplY3Qua2V5cyhiKTtcbiAgaWYgKGsxLmxlbmd0aCAhPSBrMi5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgdmFyIGtleTtcbiAgZm9yICh2YXIgaSA9IDA7IGkgPCBrMS5sZW5ndGg7IGkrKykge1xuICAgIGtleSA9IGsxW2ldO1xuICAgIGlmIChhW2tleV0gIT09IGJba2V5XSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZsYXR0ZW48VD4oYTogVFtdW10pOiBUW10ge1xuICBjb25zdCB0YXJnZXQgPSBbXTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgKytpKSB7XG4gICAgZm9yIChsZXQgaiA9IDA7IGogPCBhW2ldLmxlbmd0aDsgKytqKSB7XG4gICAgICB0YXJnZXQucHVzaChhW2ldW2pdKTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHRhcmdldDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZpcnN0PFQ+KGE6IFRbXSk6IFR8bnVsbCB7XG4gIHJldHVybiBhLmxlbmd0aCA+IDAgPyBhWzBdIDogbnVsbDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGxhc3Q8VD4oYTogVFtdKTogVHxudWxsIHtcbiAgcmV0dXJuIGEubGVuZ3RoID4gMCA/IGFbYS5sZW5ndGggLSAxXSA6IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhbmQoYm9vbHM6IGJvb2xlYW5bXSk6IGJvb2xlYW4ge1xuICByZXR1cm4gYm9vbHMucmVkdWNlKChhLCBiKSA9PiBhICYmIGIsIHRydWUpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbWVyZ2U8Vj4obTE6IHtba2V5OiBzdHJpbmddOiBWfSwgbTI6IHtba2V5OiBzdHJpbmddOiBWfSk6IHtba2V5OiBzdHJpbmddOiBWfSB7XG4gIHZhciBtOiB7W2tleTogc3RyaW5nXTogVn0gPSB7fTtcblxuICBmb3IgKHZhciBhdHRyIGluIG0xKSB7XG4gICAgaWYgKG0xLmhhc093blByb3BlcnR5KGF0dHIpKSB7XG4gICAgICBtW2F0dHJdID0gbTFbYXR0cl07XG4gICAgfVxuICB9XG5cbiAgZm9yICh2YXIgYXR0ciBpbiBtMikge1xuICAgIGlmIChtMi5oYXNPd25Qcm9wZXJ0eShhdHRyKSkge1xuICAgICAgbVthdHRyXSA9IG0yW2F0dHJdO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiBtO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZm9yRWFjaDxLLCBWPihcbiAgICBtYXA6IHtba2V5OiBzdHJpbmddOiBWfSwgY2FsbGJhY2s6IC8qKFYsIEspID0+IHZvaWQqLyBGdW5jdGlvbik6IHZvaWQge1xuICBmb3IgKHZhciBwcm9wIGluIG1hcCkge1xuICAgIGlmIChtYXAuaGFzT3duUHJvcGVydHkocHJvcCkpIHtcbiAgICAgIGNhbGxiYWNrKG1hcFtwcm9wXSwgcHJvcCk7XG4gICAgfVxuICB9XG59Il19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9jb2xsZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxzQkFBNkIsQ0FBcUIsRUFBRSxDQUFxQjtJQUN2RSxJQUFJLEVBQUUsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3hCLElBQUksRUFBRSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDeEIsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLE1BQU0sSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUMzQixNQUFNLENBQUMsS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUNELElBQUksR0FBRyxDQUFDO0lBQ1IsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7UUFDbkMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNaLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3RCLE1BQU0sQ0FBQyxLQUFLLENBQUM7UUFDZixDQUFDO0lBQ0gsQ0FBQztJQUNELE1BQU0sQ0FBQyxJQUFJLENBQUM7QUFDZCxDQUFDO0FBZGUsb0JBQVksZUFjM0IsQ0FBQTtBQUVELGlCQUEyQixDQUFRO0lBQ2pDLElBQU0sTUFBTSxHQUFHLEVBQUUsQ0FBQztJQUNsQixHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQztRQUNsQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQztZQUNyQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3ZCLENBQUM7SUFDSCxDQUFDO0lBQ0QsTUFBTSxDQUFDLE1BQU0sQ0FBQztBQUNoQixDQUFDO0FBUmUsZUFBTyxVQVF0QixDQUFBO0FBRUQsZUFBeUIsQ0FBTTtJQUM3QixNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztBQUNwQyxDQUFDO0FBRmUsYUFBSyxRQUVwQixDQUFBO0FBRUQsY0FBd0IsQ0FBTTtJQUM1QixNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO0FBQy9DLENBQUM7QUFGZSxZQUFJLE9BRW5CLENBQUE7QUFFRCxhQUFvQixLQUFnQjtJQUNsQyxNQUFNLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxVQUFDLENBQUMsRUFBRSxDQUFDLElBQUssT0FBQSxDQUFDLElBQUksQ0FBQyxFQUFOLENBQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztBQUM5QyxDQUFDO0FBRmUsV0FBRyxNQUVsQixDQUFBO0FBRUQsZUFBeUIsRUFBc0IsRUFBRSxFQUFzQjtJQUNyRSxJQUFJLENBQUMsR0FBdUIsRUFBRSxDQUFDO0lBRS9CLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDcEIsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDNUIsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQixDQUFDO0lBQ0gsQ0FBQztJQUVELEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDcEIsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDNUIsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQixDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxDQUFDLENBQUM7QUFDWCxDQUFDO0FBaEJlLGFBQUssUUFnQnBCLENBQUE7QUFFRCxpQkFDSSxHQUF1QixFQUFFLFFBQXFDO0lBQ2hFLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDckIsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDN0IsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUM1QixDQUFDO0lBQ0gsQ0FBQztBQUNILENBQUM7QUFQZSxlQUFPLFVBT3RCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gc2hhbGxvd0VxdWFsKGE6IHtbeDogc3RyaW5nXTogYW55fSwgYjoge1t4OiBzdHJpbmddOiBhbnl9KTogYm9vbGVhbiB7XG4gIHZhciBrMSA9IE9iamVjdC5rZXlzKGEpO1xuICB2YXIgazIgPSBPYmplY3Qua2V5cyhiKTtcbiAgaWYgKGsxLmxlbmd0aCAhPSBrMi5sZW5ndGgpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbiAgdmFyIGtleTtcbiAgZm9yICh2YXIgaSA9IDA7IGkgPCBrMS5sZW5ndGg7IGkrKykge1xuICAgIGtleSA9IGsxW2ldO1xuICAgIGlmIChhW2tleV0gIT09IGJba2V5XSkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZsYXR0ZW48VD4oYTogVFtdW10pOiBUW10ge1xuICBjb25zdCB0YXJnZXQgPSBbXTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgKytpKSB7XG4gICAgZm9yIChsZXQgaiA9IDA7IGogPCBhW2ldLmxlbmd0aDsgKytqKSB7XG4gICAgICB0YXJnZXQucHVzaChhW2ldW2pdKTtcbiAgICB9XG4gIH1cbiAgcmV0dXJuIHRhcmdldDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZpcnN0PFQ+KGE6IFRbXSk6IFQge1xuICByZXR1cm4gYS5sZW5ndGggPiAwID8gYVswXSA6IG51bGw7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBsYXN0PFQ+KGE6IFRbXSk6IFQge1xuICByZXR1cm4gYS5sZW5ndGggPiAwID8gYVthLmxlbmd0aCAtIDFdIDogbnVsbDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGFuZChib29sczogYm9vbGVhbltdKTogYm9vbGVhbiB7XG4gIHJldHVybiBib29scy5yZWR1Y2UoKGEsIGIpID0+IGEgJiYgYiwgdHJ1ZSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBtZXJnZTxWPihtMToge1trZXk6IHN0cmluZ106IFZ9LCBtMjoge1trZXk6IHN0cmluZ106IFZ9KToge1trZXk6IHN0cmluZ106IFZ9IHtcbiAgdmFyIG06IHtba2V5OiBzdHJpbmddOiBWfSA9IHt9O1xuXG4gIGZvciAodmFyIGF0dHIgaW4gbTEpIHtcbiAgICBpZiAobTEuaGFzT3duUHJvcGVydHkoYXR0cikpIHtcbiAgICAgIG1bYXR0cl0gPSBtMVthdHRyXTtcbiAgICB9XG4gIH1cblxuICBmb3IgKHZhciBhdHRyIGluIG0yKSB7XG4gICAgaWYgKG0yLmhhc093blByb3BlcnR5KGF0dHIpKSB7XG4gICAgICBtW2F0dHJdID0gbTJbYXR0cl07XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIG07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmb3JFYWNoPEssIFY+KFxuICAgIG1hcDoge1trZXk6IHN0cmluZ106IFZ9LCBjYWxsYmFjazogLyooViwgSykgPT4gdm9pZCovIEZ1bmN0aW9uKTogdm9pZCB7XG4gIGZvciAodmFyIHByb3AgaW4gbWFwKSB7XG4gICAgaWYgKG1hcC5oYXNPd25Qcm9wZXJ0eShwcm9wKSkge1xuICAgICAgY2FsbGJhY2sobWFwW3Byb3BdLCBwcm9wKTtcbiAgICB9XG4gIH1cbn0iXX0=
export declare class Tree<T> {
_root: TreeNode<T>;
constructor(root: TreeNode<T>);
readonly root: T;
parent(t: T): T | null;
root: T;
parent(t: T): T;
children(t: T): T[];
firstChild(t: T): T | null;
firstChild(t: T): T;
siblings(t: T): T[];

@@ -16,2 +16,3 @@ pathFromRoot(t: T): T[];

constructor(value: T, children: TreeNode<T>[]);
toString(): string;
}

@@ -81,5 +81,6 @@ "use strict";

}
TreeNode.prototype.toString = function () { return "TreeNode(" + this.value + ")"; };
return TreeNode;
}());
exports.TreeNode = TreeNode;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy90cmVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtJQUlFLGNBQVksSUFBaUI7UUFBSSxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztJQUFDLENBQUM7SUFFckQsc0JBQUksc0JBQUk7YUFBUixjQUFnQixNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDOzs7T0FBQTtJQUUxQyxxQkFBTSxHQUFOLFVBQU8sQ0FBSTtRQUNULElBQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDL0IsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztJQUMvQyxDQUFDO0lBRUQsdUJBQVEsR0FBUixVQUFTLENBQUk7UUFDWCxJQUFNLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNsQyxNQUFNLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFVBQUEsQ0FBQyxJQUFJLE9BQUEsQ0FBQyxDQUFDLEtBQUssRUFBUCxDQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDL0MsQ0FBQztJQUVELHlCQUFVLEdBQVYsVUFBVyxDQUFJO1FBQ2IsSUFBTSxDQUFDLEdBQUcsUUFBUSxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO0lBQ2pFLENBQUM7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SyxFQUFqQyxDQUFpQyxDQUFDLENBQUM7UUFDM0UsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUM7WUFBQyxnQkFBTyxLQUFLLEdBQUM7UUFDakMsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxDQUFDO1lBQUMsZ0JBQU8sS0FBSyxHQUFDOztJQUhqRCxHQUFHLENBQUMsQ0FBb0IsVUFBZ0IsRUFBaEIsS0FBQSxPQUFPLENBQUMsUUFBUSxFQUFoQixjQUFnQixFQUFoQixJQUFnQixDQUFDO1FBQXBDLElBQUksV0FBVyxTQUFBOzs7S0FJbkI7SUFFRCxNQUFNLENBQUMsSUFBSSxDQUFDO0FBQ2QsQ0FBQztBQUVEO0lBQ0Usa0JBQW1CLEtBQVEsRUFBUyxRQUF1QjtRQUF4QyxVQUFLLEdBQUwsS0FBSyxDQUFHO1FBQVMsYUFBUSxHQUFSLFFBQVEsQ0FBZTtJQUFHLENBQUM7SUFDakUsZUFBQztBQUFELENBQUMsQUFGRCxJQUVDO0FBRlksZ0JBQVEsV0FFcEIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBUcmVlPFQ+IHtcbiAgLyoqIEBpbnRlcm5hbCAqL1xuICBfcm9vdDogVHJlZU5vZGU8VD47XG5cbiAgY29uc3RydWN0b3Iocm9vdDogVHJlZU5vZGU8VD4pIHsgdGhpcy5fcm9vdCA9IHJvb3Q7IH1cblxuICBnZXQgcm9vdCgpOiBUIHsgcmV0dXJuIHRoaXMuX3Jvb3QudmFsdWU7IH1cblxuICBwYXJlbnQodDogVCk6IFR8bnVsbCB7XG4gICAgY29uc3QgcCA9IHRoaXMucGF0aEZyb21Sb290KHQpO1xuICAgIHJldHVybiBwLmxlbmd0aCA+IDEgPyBwW3AubGVuZ3RoIC0gMl0gOiBudWxsO1xuICB9XG5cbiAgY2hpbGRyZW4odDogVCk6IFRbXSB7XG4gICAgY29uc3QgbiA9IGZpbmROb2RlKHQsIHRoaXMuX3Jvb3QpO1xuICAgIHJldHVybiBuID8gbi5jaGlsZHJlbi5tYXAodCA9PiB0LnZhbHVlKSA6IFtdO1xuICB9XG5cbiAgZmlyc3RDaGlsZCh0OiBUKTogVHxudWxsIHtcbiAgICBjb25zdCBuID0gZmluZE5vZGUodCwgdGhpcy5fcm9vdCk7XG4gICAgcmV0dXJuIG4gJiYgbi5jaGlsZHJlbi5sZW5ndGggPiAwID8gbi5jaGlsZHJlblswXS52YWx1ZSA6IG51bGw7XG4gIH1cblxuICBzaWJsaW5ncyh0OiBUKTogVFtdIHtcbiAgICBjb25zdCBwID0gZmluZFBhdGgodCwgdGhpcy5fcm9vdCwgW10pO1xuICAgIGlmIChwLmxlbmd0aCA8IDIpIHJldHVybiBbXTtcblxuICAgIGNvbnN0IGMgPSBwW3AubGVuZ3RoIC0gMl0uY2hpbGRyZW4ubWFwKGMgPT4gYy52YWx1ZSk7XG4gICAgcmV0dXJuIGMuZmlsdGVyKGNjID0+IGNjICE9PSB0KTtcbiAgfVxuXG4gIHBhdGhGcm9tUm9vdCh0OiBUKTogVFtdIHsgcmV0dXJuIGZpbmRQYXRoKHQsIHRoaXMuX3Jvb3QsIFtdKS5tYXAocyA9PiBzLnZhbHVlKTsgfVxuXG4gIGNvbnRhaW5zKHRyZWU6IFRyZWU8VD4pOiBib29sZWFuIHsgcmV0dXJuIGNvbnRhaW5zKHRoaXMuX3Jvb3QsIHRyZWUuX3Jvb3QpOyB9XG59XG5cbmZ1bmN0aW9uIGZpbmROb2RlPFQ+KGV4cGVjdGVkOiBULCBjOiBUcmVlTm9kZTxUPik6IFRyZWVOb2RlPFQ+fG51bGwge1xuICBpZiAoZXhwZWN0ZWQgPT09IGMudmFsdWUpIHJldHVybiBjO1xuICBmb3IgKGxldCBjYyBvZiBjLmNoaWxkcmVuKSB7XG4gICAgY29uc3QgciA9IGZpbmROb2RlKGV4cGVjdGVkLCBjYyk7XG4gICAgaWYgKHIpIHJldHVybiByO1xuICB9XG4gIHJldHVybiBudWxsO1xufVxuXG5mdW5jdGlvbiBmaW5kUGF0aDxUPihleHBlY3RlZDogVCwgYzogVHJlZU5vZGU8VD4sIGNvbGxlY3RlZDogVHJlZU5vZGU8VD5bXSk6IFRyZWVOb2RlPFQ+W10ge1xuICBjb2xsZWN0ZWQucHVzaChjKTtcbiAgaWYgKGV4cGVjdGVkID09PSBjLnZhbHVlKSByZXR1cm4gY29sbGVjdGVkO1xuXG4gIGZvciAobGV0IGNjIG9mIGMuY2hpbGRyZW4pIHtcbiAgICBjb25zdCBjbG9uZWQgPSBjb2xsZWN0ZWQuc2xpY2UoMCk7XG4gICAgY29uc3QgciA9IGZpbmRQYXRoKGV4cGVjdGVkLCBjYywgY2xvbmVkKTtcbiAgICBpZiAocikgcmV0dXJuIHI7XG4gIH1cblxuICByZXR1cm4gW107XG59XG5cbmZ1bmN0aW9uIGNvbnRhaW5zPFQ+KHRyZWU6IFRyZWVOb2RlPFQ+LCBzdWJ0cmVlOiBUcmVlTm9kZTxUPik6IGJvb2xlYW4ge1xuICBpZiAodHJlZS52YWx1ZSAhPT0gc3VidHJlZS52YWx1ZSkgcmV0dXJuIGZhbHNlO1xuXG4gIGZvciAobGV0IHN1YnRyZWVOb2RlIG9mIHN1YnRyZWUuY2hpbGRyZW4pIHtcbiAgICBjb25zdCBzID0gdHJlZS5jaGlsZHJlbi5maWx0ZXIoY2hpbGQgPT4gY2hpbGQudmFsdWUgPT09IHN1YnRyZWVOb2RlLnZhbHVlKTtcbiAgICBpZiAocy5sZW5ndGggPT09IDApIHJldHVybiBmYWxzZTtcbiAgICBpZiAoIWNvbnRhaW5zKHNbMF0sIHN1YnRyZWVOb2RlKSkgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmV0dXJuIHRydWU7XG59XG5cbmV4cG9ydCBjbGFzcyBUcmVlTm9kZTxUPiB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyB2YWx1ZTogVCwgcHVibGljIGNoaWxkcmVuOiBUcmVlTm9kZTxUPltdKSB7fVxufSJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJlZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy90cmVlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtJQUlFLGNBQVksSUFBaUI7UUFBSSxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztJQUFDLENBQUM7SUFFckQsc0JBQUksc0JBQUk7YUFBUixjQUFnQixNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDOzs7T0FBQTtJQUUxQyxxQkFBTSxHQUFOLFVBQU8sQ0FBSTtRQUNULElBQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDL0IsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztJQUMvQyxDQUFDO0lBRUQsdUJBQVEsR0FBUixVQUFTLENBQUk7UUFDWCxJQUFNLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNsQyxNQUFNLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFVBQUEsQ0FBQyxJQUFJLE9BQUEsQ0FBQyxDQUFDLEtBQUssRUFBUCxDQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDL0MsQ0FBQztJQUVELHlCQUFVLEdBQVYsVUFBVyxDQUFJO1FBQ2IsSUFBTSxDQUFDLEdBQUcsUUFBUSxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO0lBQ2pFLENBQUM7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SyxFQUFqQyxDQUFpQyxDQUFDLENBQUM7UUFDM0UsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUM7WUFBQyxnQkFBTyxLQUFLLEdBQUM7UUFDakMsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxDQUFDO1lBQUMsZ0JBQU8sS0FBSyxHQUFDOztJQUhqRCxHQUFHLENBQUMsQ0FBb0IsVUFBZ0IsRUFBaEIsS0FBQSxPQUFPLENBQUMsUUFBUSxFQUFoQixjQUFnQixFQUFoQixJQUFnQixDQUFDO1FBQXBDLElBQUksV0FBVyxTQUFBOzs7S0FJbkI7SUFFRCxNQUFNLENBQUMsSUFBSSxDQUFDO0FBQ2QsQ0FBQztBQUVEO0lBQ0Usa0JBQW1CLEtBQVEsRUFBUyxRQUF1QjtRQUF4QyxVQUFLLEdBQUwsS0FBSyxDQUFHO1FBQVMsYUFBUSxHQUFSLFFBQVEsQ0FBZTtJQUFHLENBQUM7SUFFL0QsMkJBQVEsR0FBUixjQUFxQixNQUFNLENBQUMsY0FBWSxJQUFJLENBQUMsS0FBSyxNQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzFELGVBQUM7QUFBRCxDQUFDLEFBSkQsSUFJQztBQUpZLGdCQUFRLFdBSXBCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgVHJlZTxUPiB7XG4gIC8qKiBAaW50ZXJuYWwgKi9cbiAgX3Jvb3Q6IFRyZWVOb2RlPFQ+O1xuXG4gIGNvbnN0cnVjdG9yKHJvb3Q6IFRyZWVOb2RlPFQ+KSB7IHRoaXMuX3Jvb3QgPSByb290OyB9XG5cbiAgZ2V0IHJvb3QoKTogVCB7IHJldHVybiB0aGlzLl9yb290LnZhbHVlOyB9XG5cbiAgcGFyZW50KHQ6IFQpOiBUIHtcbiAgICBjb25zdCBwID0gdGhpcy5wYXRoRnJvbVJvb3QodCk7XG4gICAgcmV0dXJuIHAubGVuZ3RoID4gMSA/IHBbcC5sZW5ndGggLSAyXSA6IG51bGw7XG4gIH1cblxuICBjaGlsZHJlbih0OiBUKTogVFtdIHtcbiAgICBjb25zdCBuID0gZmluZE5vZGUodCwgdGhpcy5fcm9vdCk7XG4gICAgcmV0dXJuIG4gPyBuLmNoaWxkcmVuLm1hcCh0ID0+IHQudmFsdWUpIDogW107XG4gIH1cblxuICBmaXJzdENoaWxkKHQ6IFQpOiBUIHtcbiAgICBjb25zdCBuID0gZmluZE5vZGUodCwgdGhpcy5fcm9vdCk7XG4gICAgcmV0dXJuIG4gJiYgbi5jaGlsZHJlbi5sZW5ndGggPiAwID8gbi5jaGlsZHJlblswXS52YWx1ZSA6IG51bGw7XG4gIH1cblxuICBzaWJsaW5ncyh0OiBUKTogVFtdIHtcbiAgICBjb25zdCBwID0gZmluZFBhdGgodCwgdGhpcy5fcm9vdCwgW10pO1xuICAgIGlmIChwLmxlbmd0aCA8IDIpIHJldHVybiBbXTtcblxuICAgIGNvbnN0IGMgPSBwW3AubGVuZ3RoIC0gMl0uY2hpbGRyZW4ubWFwKGMgPT4gYy52YWx1ZSk7XG4gICAgcmV0dXJuIGMuZmlsdGVyKGNjID0+IGNjICE9PSB0KTtcbiAgfVxuXG4gIHBhdGhGcm9tUm9vdCh0OiBUKTogVFtdIHsgcmV0dXJuIGZpbmRQYXRoKHQsIHRoaXMuX3Jvb3QsIFtdKS5tYXAocyA9PiBzLnZhbHVlKTsgfVxuXG4gIGNvbnRhaW5zKHRyZWU6IFRyZWU8VD4pOiBib29sZWFuIHsgcmV0dXJuIGNvbnRhaW5zKHRoaXMuX3Jvb3QsIHRyZWUuX3Jvb3QpOyB9XG59XG5cbmZ1bmN0aW9uIGZpbmROb2RlPFQ+KGV4cGVjdGVkOiBULCBjOiBUcmVlTm9kZTxUPik6IFRyZWVOb2RlPFQ+IHtcbiAgaWYgKGV4cGVjdGVkID09PSBjLnZhbHVlKSByZXR1cm4gYztcbiAgZm9yIChsZXQgY2Mgb2YgYy5jaGlsZHJlbikge1xuICAgIGNvbnN0IHIgPSBmaW5kTm9kZShleHBlY3RlZCwgY2MpO1xuICAgIGlmIChyKSByZXR1cm4gcjtcbiAgfVxuICByZXR1cm4gbnVsbDtcbn1cblxuZnVuY3Rpb24gZmluZFBhdGg8VD4oZXhwZWN0ZWQ6IFQsIGM6IFRyZWVOb2RlPFQ+LCBjb2xsZWN0ZWQ6IFRyZWVOb2RlPFQ+W10pOiBUcmVlTm9kZTxUPltdIHtcbiAgY29sbGVjdGVkLnB1c2goYyk7XG4gIGlmIChleHBlY3RlZCA9PT0gYy52YWx1ZSkgcmV0dXJuIGNvbGxlY3RlZDtcblxuICBmb3IgKGxldCBjYyBvZiBjLmNoaWxkcmVuKSB7XG4gICAgY29uc3QgY2xvbmVkID0gY29sbGVjdGVkLnNsaWNlKDApO1xuICAgIGNvbnN0IHIgPSBmaW5kUGF0aChleHBlY3RlZCwgY2MsIGNsb25lZCk7XG4gICAgaWYgKHIpIHJldHVybiByO1xuICB9XG5cbiAgcmV0dXJuIFtdO1xufVxuXG5mdW5jdGlvbiBjb250YWluczxUPih0cmVlOiBUcmVlTm9kZTxUPiwgc3VidHJlZTogVHJlZU5vZGU8VD4pOiBib29sZWFuIHtcbiAgaWYgKHRyZWUudmFsdWUgIT09IHN1YnRyZWUudmFsdWUpIHJldHVybiBmYWxzZTtcblxuICBmb3IgKGxldCBzdWJ0cmVlTm9kZSBvZiBzdWJ0cmVlLmNoaWxkcmVuKSB7XG4gICAgY29uc3QgcyA9IHRyZWUuY2hpbGRyZW4uZmlsdGVyKGNoaWxkID0+IGNoaWxkLnZhbHVlID09PSBzdWJ0cmVlTm9kZS52YWx1ZSk7XG4gICAgaWYgKHMubGVuZ3RoID09PSAwKSByZXR1cm4gZmFsc2U7XG4gICAgaWYgKCFjb250YWlucyhzWzBdLCBzdWJ0cmVlTm9kZSkpIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiB0cnVlO1xufVxuXG5leHBvcnQgY2xhc3MgVHJlZU5vZGU8VD4ge1xuICBjb25zdHJ1Y3RvcihwdWJsaWMgdmFsdWU6IFQsIHB1YmxpYyBjaGlsZHJlbjogVHJlZU5vZGU8VD5bXSkge31cblxuICB0b1N0cmluZygpOiBzdHJpbmcgeyByZXR1cm4gYFRyZWVOb2RlKCR7dGhpcy52YWx1ZX0pYDsgfVxufSJdfQ==
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc