angular2
Version:
Angular 2 - a web framework for modern web apps
190 lines • 17.9 kB
JavaScript
'use strict';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');
/**
* 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;
/**
* `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 () {
function Route(_a) {
var path = _a.path, component = _a.component, name = _a.name, data = _a.data, useAsDefault = _a.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([
lang_1.CONST(),
__metadata('design:paramtypes', [Object])
], Route);
return Route;
})();
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 () {
function AuxRoute(_a) {
var path = _a.path, component = _a.component, name = _a.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([
lang_1.CONST(),
__metadata('design:paramtypes', [Object])
], AuxRoute);
return AuxRoute;
})();
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 () {
function AsyncRoute(_a) {
var path = _a.path, loader = _a.loader, name = _a.name, data = _a.data, useAsDefault = _a.useAsDefault;
this.aux = null;
this.path = path;
this.loader = loader;
this.name = name;
this.data = data;
this.useAsDefault = useAsDefault;
}
AsyncRoute = __decorate([
lang_1.CONST(),
__metadata('design:paramtypes', [Object])
], AsyncRoute);
return AsyncRoute;
})();
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 () {
function Redirect(_a) {
var path = _a.path, redirectTo = _a.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([
lang_1.CONST(),
__metadata('design:paramtypes', [Object])
], Redirect);
return Redirect;
})();
exports.Redirect = 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":"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","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, 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 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, 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 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, 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 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"]}