UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

177 lines 16.7 kB
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { if (typeof Reflect === "object" && typeof Reflect.decorate === "function") return Reflect.decorate(decorators, target, key, desc); switch (arguments.length) { case 2: return decorators.reduceRight(function(o, d) { return (d && d(o)) || o; }, target); case 3: return decorators.reduceRight(function(o, d) { return (d && d(target, key)), void 0; }, void 0); case 4: return decorators.reduceRight(function(o, d) { return (d && d(target, key, o)) || o; }, desc); } }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; import { CONST } from 'angular2/src/facade/lang'; /** * The `RouteConfig` decorator defines routes for a given component. * * It takes an array of {@link RouteDefinition}s. */ export let RouteConfig = class { constructor(configs) { this.configs = configs; } }; RouteConfig = __decorate([ CONST(), __metadata('design:paramtypes', [Array]) ], RouteConfig); /** * `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} from 'angular2/router'; * * @RouteConfig([ * {path: '/home', component: HomeCmp, name: 'HomeCmp' } * ]) * class MyApp {} * ``` */ export let Route = class { constructor({ path, component, name, data, useAsDefault }) { // added next three properties to work around https://github.com/Microsoft/TypeScript/issues/4107 this.aux = null; this.loader = null; this.redirectTo = null; this.path = path; this.component = component; this.name = name; this.data = data; this.useAsDefault = useAsDefault; } }; Route = __decorate([ CONST(), __metadata('design:paramtypes', [Object]) ], 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 {} * ``` */ export let AuxRoute = class { constructor({ path, component, name }) { this.data = null; // added next three properties to work around https://github.com/Microsoft/TypeScript/issues/4107 this.aux = null; this.loader = null; this.redirectTo = null; this.useAsDefault = false; this.path = path; this.component = component; this.name = name; } }; AuxRoute = __decorate([ CONST(), __metadata('design:paramtypes', [Object]) ], 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} from 'angular2/router'; * * @RouteConfig([ * {path: '/home', loader: () => Promise.resolve(MyLoadedCmp), name: 'MyLoadedCmp'} * ]) * class MyApp {} * ``` */ export let AsyncRoute = class { constructor({ path, loader, name, data, useAsDefault }) { this.aux = null; this.path = path; this.loader = loader; this.name = name; this.data = data; this.useAsDefault = useAsDefault; } }; AsyncRoute = __decorate([ CONST(), __metadata('design:paramtypes', [Object]) ], 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} from 'angular2/router'; * * @RouteConfig([ * {path: '/', redirectTo: ['/Home'] }, * {path: '/home', component: HomeCmp, name: 'Home'} * ]) * class MyApp {} * ``` */ export let Redirect = class { constructor({ path, redirectTo }) { this.name = null; // added next three properties to work around https://github.com/Microsoft/TypeScript/issues/4107 this.loader = null; this.data = null; this.aux = null; this.useAsDefault = false; this.path = path; this.redirectTo = redirectTo; } }; Redirect = __decorate([ CONST(), __metadata('design:paramtypes', [Object]) ], Redirect); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"route_config_impl.js","sourceRoot":"","sources":["angular2/src/router/route_config_impl.ts"],"names":["RouteConfig","RouteConfig.constructor","Route","Route.constructor","AuxRoute","AuxRoute.constructor","AsyncRoute","AsyncRoute.constructor","Redirect","Redirect.constructor"],"mappings":";;;;;;;;;;;OAAO,EAAC,KAAK,EAAkB,MAAM,0BAA0B;AAI/D;;;;GAIG;AACH;IAEEA,YAAmBA,OAA0BA;QAA1BC,YAAOA,GAAPA,OAAOA,CAAmBA;IAAGA,CAACA;AACnDD,CAACA;AAHD;IAAC,KAAK,EAAE;;gBAGP;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH;IAWEE,YAAYA,EAACA,IAAIA,EAAEA,SAASA,EAAEA,IAAIA,EAAEA,IAAIA,EAAEA,YAAYA,EAGrDA;QAPDC,iGAAiGA;QACjGA,QAAGA,GAAWA,IAAIA,CAACA;QACnBA,WAAMA,GAAaA,IAAIA,CAACA;QACxBA,eAAUA,GAAUA,IAAIA,CAACA;QAKvBA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;QACjBA,IAAIA,CAACA,SAASA,GAAGA,SAASA,CAACA;QAC3BA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;QACjBA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;QACjBA,IAAIA,CAACA,YAAYA,GAAGA,YAAYA,CAACA;IACnCA,CAACA;AACHD,CAACA;AArBD;IAAC,KAAK,EAAE;;UAqBP;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH;IAWEE,YAAYA,EAACA,IAAIA,EAAEA,SAASA,EAAEA,IAAIA,EAAiDA;QATnFC,SAAIA,GAAyBA,IAAIA,CAACA;QAIlCA,iGAAiGA;QACjGA,QAAGA,GAAWA,IAAIA,CAACA;QACnBA,WAAMA,GAAaA,IAAIA,CAACA;QACxBA,eAAUA,GAAUA,IAAIA,CAACA;QACzBA,iBAAYA,GAAYA,KAAKA,CAACA;QAE5BA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;QACjBA,IAAIA,CAACA,SAASA,GAAGA,SAASA,CAACA;QAC3BA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;IACnBA,CAACA;AACHD,CAACA;AAhBD;IAAC,KAAK,EAAE;;aAgBP;AAED;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH;IAQEE,YAAYA,EAACA,IAAIA,EAAEA,MAAMA,EAAEA,IAAIA,EAAEA,IAAIA,EAAEA,YAAYA,EAGlDA;QAJDC,QAAGA,GAAWA,IAAIA,CAACA;QAKjBA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;QACjBA,IAAIA,CAACA,MAAMA,GAAGA,MAAMA,CAACA;QACrBA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;QACjBA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;QACjBA,IAAIA,CAACA,YAAYA,GAAGA,YAAYA,CAACA;IACnCA,CAACA;AACHD,CAACA;AAlBD;IAAC,KAAK,EAAE;;eAkBP;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH;IAUEE,YAAYA,EAACA,IAAIA,EAAEA,UAAUA,EAAoCA;QANjEC,SAAIA,GAAWA,IAAIA,CAACA;QACpBA,iGAAiGA;QACjGA,WAAMA,GAAaA,IAAIA,CAACA;QACxBA,SAAIA,GAAQA,IAAIA,CAACA;QACjBA,QAAGA,GAAWA,IAAIA,CAACA;QACnBA,iBAAYA,GAAYA,KAAKA,CAACA;QAE5BA,IAAIA,CAACA,IAAIA,GAAGA,IAAIA,CAACA;QACjBA,IAAIA,CAACA,UAAUA,GAAGA,UAAUA,CAACA;IAC/BA,CAACA;AACHD,CAACA;AAdD;IAAC,KAAK,EAAE;;aAcP;AAAA","sourcesContent":["import {CONST, Type, isPresent} from 'angular2/src/facade/lang';\nimport {RouteDefinition} from './route_definition';\nexport {RouteDefinition} from './route_definition';\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/**\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} from 'angular2/router';\n *\n * @RouteConfig([\n *   {path: '/home', component: HomeCmp, name: 'HomeCmp' }\n * ])\n * class MyApp {}\n * ```\n */\n@CONST()\nexport class Route implements RouteDefinition {\n  data: {[key: string]: any};\n  path: string;\n  component: Type;\n  name: string;\n  useAsDefault: boolean;\n  // added next three properties to work around https://github.com/Microsoft/TypeScript/issues/4107\n  aux: string = null;\n  loader: Function = null;\n  redirectTo: any[] = null;\n  constructor({path, component, name, data, useAsDefault}: {\n    path: string,\n    component: Type, name?: string, data?: {[key: string]: any}, useAsDefault?: boolean\n  }) {\n    this.path = path;\n    this.component = component;\n    this.name = name;\n    this.data = data;\n    this.useAsDefault = useAsDefault;\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 implements RouteDefinition {\n  data: {[key: string]: any} = null;\n  path: string;\n  component: Type;\n  name: string;\n  // added next three properties to work around https://github.com/Microsoft/TypeScript/issues/4107\n  aux: string = null;\n  loader: Function = null;\n  redirectTo: any[] = null;\n  useAsDefault: boolean = false;\n  constructor({path, component, name}: {path: string, component: Type, name?: string}) {\n    this.path = path;\n    this.component = component;\n    this.name = name;\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} from 'angular2/router';\n *\n * @RouteConfig([\n *   {path: '/home', loader: () => Promise.resolve(MyLoadedCmp), name: 'MyLoadedCmp'}\n * ])\n * class MyApp {}\n * ```\n */\n@CONST()\nexport class AsyncRoute implements RouteDefinition {\n  data: {[key: string]: any};\n  path: string;\n  loader: Function;\n  name: string;\n  useAsDefault: boolean;\n  aux: string = null;\n  constructor({path, loader, name, data, useAsDefault}: {\n    path: string,\n    loader: Function, name?: string, data?: {[key: string]: any}, useAsDefault?: boolean\n  }) {\n    this.path = path;\n    this.loader = loader;\n    this.name = name;\n    this.data = data;\n    this.useAsDefault = useAsDefault;\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} from 'angular2/router';\n *\n * @RouteConfig([\n *   {path: '/', redirectTo: ['/Home'] },\n *   {path: '/home', component: HomeCmp, name: 'Home'}\n * ])\n * class MyApp {}\n * ```\n */\n@CONST()\nexport class Redirect implements RouteDefinition {\n  path: string;\n  redirectTo: any[];\n  name: string = null;\n  // added next three properties to work around https://github.com/Microsoft/TypeScript/issues/4107\n  loader: Function = null;\n  data: any = null;\n  aux: string = null;\n  useAsDefault: boolean = false;\n  constructor({path, redirectTo}: {path: string, redirectTo: any[]}) {\n    this.path = path;\n    this.redirectTo = redirectTo;\n  }\n}\n"]}