UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

224 lines 19.4 kB
'use strict';"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 __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var lang_1 = require('angular2/src/facade/lang'); var __make_dart_analyzer_happy = null; /** * The `RouteConfig` decorator defines routes for a given component. * * It takes an array of {@link RouteDefinition}s. */ var RouteConfig = (function () { function RouteConfig(configs) { this.configs = configs; } RouteConfig = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Array]) ], RouteConfig); return RouteConfig; }()); exports.RouteConfig = RouteConfig; var AbstractRoute = (function () { function AbstractRoute(_a) { var name = _a.name, useAsDefault = _a.useAsDefault, path = _a.path, regex = _a.regex, serializer = _a.serializer, data = _a.data; this.name = name; this.useAsDefault = useAsDefault; this.path = path; this.regex = regex; this.serializer = serializer; this.data = data; } AbstractRoute = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object]) ], AbstractRoute); return AbstractRoute; }()); exports.AbstractRoute = AbstractRoute; /** * `Route` is a type of {@link RouteDefinition} used to route a path to a component. * * It has the following properties: * - `path` is a string that uses the route matcher DSL. * - `component` a component type. * - `name` is an optional `CamelCase` string representing the name of the route. * - `data` is an optional property of any type representing arbitrary route metadata for the given * route. It is injectable via {@link RouteData}. * - `useAsDefault` is a boolean value. If `true`, the child route will be navigated to if no child * route is specified during the navigation. * * ### Example * ``` * import {RouteConfig, Route} from 'angular2/router'; * * @RouteConfig([ * new Route({path: '/home', component: HomeCmp, name: 'HomeCmp' }) * ]) * class MyApp {} * ``` */ var Route = (function (_super) { __extends(Route, _super); function Route(_a) { var name = _a.name, useAsDefault = _a.useAsDefault, path = _a.path, regex = _a.regex, serializer = _a.serializer, data = _a.data, component = _a.component; _super.call(this, { name: name, useAsDefault: useAsDefault, path: path, regex: regex, serializer: serializer, data: data }); this.aux = null; this.component = component; } Route = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object]) ], Route); return Route; }(AbstractRoute)); exports.Route = Route; /** * `AuxRoute` is a type of {@link RouteDefinition} used to define an auxiliary route. * * It takes an object with the following properties: * - `path` is a string that uses the route matcher DSL. * - `component` a component type. * - `name` is an optional `CamelCase` string representing the name of the route. * - `data` is an optional property of any type representing arbitrary route metadata for the given * route. It is injectable via {@link RouteData}. * * ### Example * ``` * import {RouteConfig, AuxRoute} from 'angular2/router'; * * @RouteConfig([ * new AuxRoute({path: '/home', component: HomeCmp}) * ]) * class MyApp {} * ``` */ var AuxRoute = (function (_super) { __extends(AuxRoute, _super); function AuxRoute(_a) { var name = _a.name, useAsDefault = _a.useAsDefault, path = _a.path, regex = _a.regex, serializer = _a.serializer, data = _a.data, component = _a.component; _super.call(this, { name: name, useAsDefault: useAsDefault, path: path, regex: regex, serializer: serializer, data: data }); this.component = component; } AuxRoute = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object]) ], AuxRoute); return AuxRoute; }(AbstractRoute)); exports.AuxRoute = AuxRoute; /** * `AsyncRoute` is a type of {@link RouteDefinition} used to route a path to an asynchronously * loaded component. * * It has the following properties: * - `path` is a string that uses the route matcher DSL. * - `loader` is a function that returns a promise that resolves to a component. * - `name` is an optional `CamelCase` string representing the name of the route. * - `data` is an optional property of any type representing arbitrary route metadata for the given * route. It is injectable via {@link RouteData}. * - `useAsDefault` is a boolean value. If `true`, the child route will be navigated to if no child * route is specified during the navigation. * * ### Example * ``` * import {RouteConfig, AsyncRoute} from 'angular2/router'; * * @RouteConfig([ * new AsyncRoute({path: '/home', loader: () => Promise.resolve(MyLoadedCmp), name: * 'MyLoadedCmp'}) * ]) * class MyApp {} * ``` */ var AsyncRoute = (function (_super) { __extends(AsyncRoute, _super); function AsyncRoute(_a) { var name = _a.name, useAsDefault = _a.useAsDefault, path = _a.path, regex = _a.regex, serializer = _a.serializer, data = _a.data, loader = _a.loader; _super.call(this, { name: name, useAsDefault: useAsDefault, path: path, regex: regex, serializer: serializer, data: data }); this.aux = null; this.loader = loader; } AsyncRoute = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object]) ], AsyncRoute); return AsyncRoute; }(AbstractRoute)); exports.AsyncRoute = AsyncRoute; /** * `Redirect` is a type of {@link RouteDefinition} used to route a path to a canonical route. * * It has the following properties: * - `path` is a string that uses the route matcher DSL. * - `redirectTo` is an array representing the link DSL. * * Note that redirects **do not** affect how links are generated. For that, see the `useAsDefault` * option. * * ### Example * ``` * import {RouteConfig, Route, Redirect} from 'angular2/router'; * * @RouteConfig([ * new Redirect({path: '/', redirectTo: ['/Home'] }), * new Route({path: '/home', component: HomeCmp, name: 'Home'}) * ]) * class MyApp {} * ``` */ var Redirect = (function (_super) { __extends(Redirect, _super); function Redirect(_a) { var name = _a.name, useAsDefault = _a.useAsDefault, path = _a.path, regex = _a.regex, serializer = _a.serializer, data = _a.data, redirectTo = _a.redirectTo; _super.call(this, { name: name, useAsDefault: useAsDefault, path: path, regex: regex, serializer: serializer, data: data }); this.redirectTo = redirectTo; } Redirect = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object]) ], Redirect); return Redirect; }(AbstractRoute)); exports.Redirect = Redirect; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"route_config_impl.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-BRJer1J9.tmp/angular2/src/router/route_config/route_config_impl.ts"],"names":[],"mappings":"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","sourcesContent":["import {CONST, Type, isPresent} from 'angular2/src/facade/lang';\nimport {RouteDefinition} from '../route_definition';\nimport {RegexSerializer} from '../rules/route_paths/regex_route_path';\n\nexport {RouteDefinition} from '../route_definition';\n\nvar __make_dart_analyzer_happy: Promise<any> = null;\n\n/**\n * The `RouteConfig` decorator defines routes for a given component.\n *\n * It takes an array of {@link RouteDefinition}s.\n */\n@CONST()\nexport class RouteConfig {\n  constructor(public configs: RouteDefinition[]) {}\n}\n\n@CONST()\nexport abstract class AbstractRoute implements RouteDefinition {\n  name: string;\n  useAsDefault: boolean;\n  path: string;\n  regex: string;\n  serializer: RegexSerializer;\n  data: {[key: string]: any};\n\n  constructor({name, useAsDefault, path, regex, serializer, data}: RouteDefinition) {\n    this.name = name;\n    this.useAsDefault = useAsDefault;\n    this.path = path;\n    this.regex = regex;\n    this.serializer = serializer;\n    this.data = data;\n  }\n}\n\n/**\n * `Route` is a type of {@link RouteDefinition} used to route a path to a component.\n *\n * It has the following properties:\n * - `path` is a string that uses the route matcher DSL.\n * - `component` a component type.\n * - `name` is an optional `CamelCase` string representing the name of the route.\n * - `data` is an optional property of any type representing arbitrary route metadata for the given\n * route. It is injectable via {@link RouteData}.\n * - `useAsDefault` is a boolean value. If `true`, the child route will be navigated to if no child\n * route is specified during the navigation.\n *\n * ### Example\n * ```\n * import {RouteConfig, Route} from 'angular2/router';\n *\n * @RouteConfig([\n *   new Route({path: '/home', component: HomeCmp, name: 'HomeCmp' })\n * ])\n * class MyApp {}\n * ```\n */\n@CONST()\nexport class Route extends AbstractRoute {\n  component: any;\n  aux: string = null;\n\n  constructor({name, useAsDefault, path, regex, serializer, data, component}: RouteDefinition) {\n    super({\n      name: name,\n      useAsDefault: useAsDefault,\n      path: path,\n      regex: regex,\n      serializer: serializer,\n      data: data\n    });\n    this.component = component;\n  }\n}\n\n/**\n * `AuxRoute` is a type of {@link RouteDefinition} used to define an auxiliary route.\n *\n * It takes an object with the following properties:\n * - `path` is a string that uses the route matcher DSL.\n * - `component` a component type.\n * - `name` is an optional `CamelCase` string representing the name of the route.\n * - `data` is an optional property of any type representing arbitrary route metadata for the given\n * route. It is injectable via {@link RouteData}.\n *\n * ### Example\n * ```\n * import {RouteConfig, AuxRoute} from 'angular2/router';\n *\n * @RouteConfig([\n *   new AuxRoute({path: '/home', component: HomeCmp})\n * ])\n * class MyApp {}\n * ```\n */\n@CONST()\nexport class AuxRoute extends AbstractRoute {\n  component: any;\n\n  constructor({name, useAsDefault, path, regex, serializer, data, component}: RouteDefinition) {\n    super({\n      name: name,\n      useAsDefault: useAsDefault,\n      path: path,\n      regex: regex,\n      serializer: serializer,\n      data: data\n    });\n    this.component = component;\n  }\n}\n\n/**\n * `AsyncRoute` is a type of {@link RouteDefinition} used to route a path to an asynchronously\n * loaded component.\n *\n * It has the following properties:\n * - `path` is a string that uses the route matcher DSL.\n * - `loader` is a function that returns a promise that resolves to a component.\n * - `name` is an optional `CamelCase` string representing the name of the route.\n * - `data` is an optional property of any type representing arbitrary route metadata for the given\n * route. It is injectable via {@link RouteData}.\n * - `useAsDefault` is a boolean value. If `true`, the child route will be navigated to if no child\n * route is specified during the navigation.\n *\n * ### Example\n * ```\n * import {RouteConfig, AsyncRoute} from 'angular2/router';\n *\n * @RouteConfig([\n *   new AsyncRoute({path: '/home', loader: () => Promise.resolve(MyLoadedCmp), name:\n * 'MyLoadedCmp'})\n * ])\n * class MyApp {}\n * ```\n */\n@CONST()\nexport class AsyncRoute extends AbstractRoute {\n  loader: () => Promise<Type>;\n  aux: string = null;\n\n  constructor({name, useAsDefault, path, regex, serializer, data, loader}: RouteDefinition) {\n    super({\n      name: name,\n      useAsDefault: useAsDefault,\n      path: path,\n      regex: regex,\n      serializer: serializer,\n      data: data\n    });\n    this.loader = loader;\n  }\n}\n\n/**\n * `Redirect` is a type of {@link RouteDefinition} used to route a path to a canonical route.\n *\n * It has the following properties:\n * - `path` is a string that uses the route matcher DSL.\n * - `redirectTo` is an array representing the link DSL.\n *\n * Note that redirects **do not** affect how links are generated. For that, see the `useAsDefault`\n * option.\n *\n * ### Example\n * ```\n * import {RouteConfig, Route, Redirect} from 'angular2/router';\n *\n * @RouteConfig([\n *   new Redirect({path: '/', redirectTo: ['/Home'] }),\n *   new Route({path: '/home', component: HomeCmp, name: 'Home'})\n * ])\n * class MyApp {}\n * ```\n */\n@CONST()\nexport class Redirect extends AbstractRoute {\n  redirectTo: any[];\n\n  constructor({name, useAsDefault, path, regex, serializer, data, redirectTo}: RouteDefinition) {\n    super({\n      name: name,\n      useAsDefault: useAsDefault,\n      path: path,\n      regex: regex,\n      serializer: serializer,\n      data: data\n    });\n    this.redirectTo = redirectTo;\n  }\n}\n"]}