UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

410 lines 32.1 kB
'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 di_1 = require('angular2/src/core/di'); var metadata_1 = require('angular2/src/core/di/metadata'); /** * Specifies that a constant attribute value should be injected. * * The directive can inject constant string literals of host element attributes. * * ### Example * * Suppose we have an `<input>` element and want to know its `type`. * * ```html * <input type="text"> * ``` * * A decorator can inject string literal `text` like so: * * {@example core/ts/metadata/metadata.ts region='attributeMetadata'} */ var AttributeMetadata = (function (_super) { __extends(AttributeMetadata, _super); function AttributeMetadata(attributeName) { _super.call(this); this.attributeName = attributeName; } Object.defineProperty(AttributeMetadata.prototype, "token", { get: function () { // Normally one would default a token to a type of an injected value but here // the type of a variable is "string" and we can't use primitive type as a return value // so we use instance of Attribute instead. This doesn't matter much in practice as arguments // with @Attribute annotation are injected by ElementInjector that doesn't take tokens into // account. return this; }, enumerable: true, configurable: true }); AttributeMetadata.prototype.toString = function () { return "@Attribute(" + lang_1.stringify(this.attributeName) + ")"; }; AttributeMetadata = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [String]) ], AttributeMetadata); return AttributeMetadata; })(metadata_1.DependencyMetadata); exports.AttributeMetadata = AttributeMetadata; /** * Declares an injectable parameter to be a live list of directives or variable * bindings from the content children of a directive. * * ### Example ([live demo](http://plnkr.co/edit/lY9m8HLy7z06vDoUaSN2?p=preview)) * * Assume that `<tabs>` component would like to get a list its children `<pane>` * components as shown in this example: * * ```html * <tabs> * <pane title="Overview">...</pane> * <pane *ngFor="#o of objects" [title]="o.title">{{o.text}}</pane> * </tabs> * ``` * * The preferred solution is to query for `Pane` directives using this decorator. * * ```javascript * @Component({ * selector: 'pane', * inputs: ['title'] * }) * class Pane { * title:string; * } * * @Component({ * selector: 'tabs', * template: ` * <ul> * <li *ngFor="#pane of panes">{{pane.title}}</li> * </ul> * <content></content> * ` * }) * class Tabs { * panes: QueryList<Pane>; * constructor(@Query(Pane) panes:QueryList<Pane>) { * this.panes = panes; * } * } * ``` * * A query can look for variable bindings by passing in a string with desired binding symbol. * * ### Example ([live demo](http://plnkr.co/edit/sT2j25cH1dURAyBRCKx1?p=preview)) * ```html * <seeker> * <div #findme>...</div> * </seeker> * * @Component({ selector: 'seeker' }) * class Seeker { * constructor(@Query('findme') elList: QueryList<ElementRef>) {...} * } * ``` * * In this case the object that is injected depend on the type of the variable * binding. It can be an ElementRef, a directive or a component. * * Passing in a comma separated list of variable bindings will query for all of them. * * ```html * <seeker> * <div #find-me>...</div> * <div #find-me-too>...</div> * </seeker> * * @Component({ * selector: 'seeker' * }) * class Seeker { * constructor(@Query('findMe, findMeToo') elList: QueryList<ElementRef>) {...} * } * ``` * * Configure whether query looks for direct children or all descendants * of the querying element, by using the `descendants` parameter. * It is set to `false` by default. * * ### Example ([live demo](http://plnkr.co/edit/wtGeB977bv7qvA5FTYl9?p=preview)) * ```html * <container #first> * <item>a</item> * <item>b</item> * <container #second> * <item>c</item> * </container> * </container> * ``` * * When querying for items, the first container will see only `a` and `b` by default, * but with `Query(TextDirective, {descendants: true})` it will see `c` too. * * The queried directives are kept in a depth-first pre-order with respect to their * positions in the DOM. * * Query does not look deep into any subcomponent views. * * Query is updated as part of the change-detection cycle. Since change detection * happens after construction of a directive, QueryList will always be empty when observed in the * constructor. * * The injected object is an unmodifiable live list. * See {@link QueryList} for more details. */ var QueryMetadata = (function (_super) { __extends(QueryMetadata, _super); function QueryMetadata(_selector, _a) { var _b = _a === void 0 ? {} : _a, _c = _b.descendants, descendants = _c === void 0 ? false : _c, _d = _b.first, first = _d === void 0 ? false : _d; _super.call(this); this._selector = _selector; this.descendants = descendants; this.first = first; } Object.defineProperty(QueryMetadata.prototype, "isViewQuery", { /** * always `false` to differentiate it with {@link ViewQueryMetadata}. */ get: function () { return false; }, enumerable: true, configurable: true }); Object.defineProperty(QueryMetadata.prototype, "selector", { /** * what this is querying for. */ get: function () { return di_1.resolveForwardRef(this._selector); }, enumerable: true, configurable: true }); Object.defineProperty(QueryMetadata.prototype, "isVarBindingQuery", { /** * whether this is querying for a variable binding or a directive. */ get: function () { return lang_1.isString(this.selector); }, enumerable: true, configurable: true }); Object.defineProperty(QueryMetadata.prototype, "varBindings", { /** * returns a list of variable bindings this is querying for. * Only applicable if this is a variable bindings query. */ get: function () { return this.selector.split(','); }, enumerable: true, configurable: true }); QueryMetadata.prototype.toString = function () { return "@Query(" + lang_1.stringify(this.selector) + ")"; }; QueryMetadata = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object, Object]) ], QueryMetadata); return QueryMetadata; })(metadata_1.DependencyMetadata); exports.QueryMetadata = QueryMetadata; // TODO: add an example after ContentChildren and ViewChildren are in master /** * Configures a content query. * * Content queries are set before the `ngAfterContentInit` callback is called. * * ### Example * * ``` * @Directive({ * selector: 'someDir' * }) * class SomeDir { * @ContentChildren(ChildDirective) contentChildren: QueryList<ChildDirective>; * * ngAfterContentInit() { * // contentChildren is set * } * } * ``` */ var ContentChildrenMetadata = (function (_super) { __extends(ContentChildrenMetadata, _super); function ContentChildrenMetadata(_selector, _a) { var _b = (_a === void 0 ? {} : _a).descendants, descendants = _b === void 0 ? false : _b; _super.call(this, _selector, { descendants: descendants }); } ContentChildrenMetadata = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object, Object]) ], ContentChildrenMetadata); return ContentChildrenMetadata; })(QueryMetadata); exports.ContentChildrenMetadata = ContentChildrenMetadata; // TODO: add an example after ContentChild and ViewChild are in master /** * Configures a content query. * * Content queries are set before the `ngAfterContentInit` callback is called. * * ### Example * * ``` * @Directive({ * selector: 'someDir' * }) * class SomeDir { * @ContentChild(ChildDirective) contentChild; * * ngAfterContentInit() { * // contentChild is set * } * } * ``` */ var ContentChildMetadata = (function (_super) { __extends(ContentChildMetadata, _super); function ContentChildMetadata(_selector) { _super.call(this, _selector, { descendants: true, first: true }); } ContentChildMetadata = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object]) ], ContentChildMetadata); return ContentChildMetadata; })(QueryMetadata); exports.ContentChildMetadata = ContentChildMetadata; /** * Similar to {@link QueryMetadata}, but querying the component view, instead of * the content children. * * ### Example ([live demo](http://plnkr.co/edit/eNsFHDf7YjyM6IzKxM1j?p=preview)) * * ```javascript * @Component({...}) * @View({ * template: ` * <item> a </item> * <item> b </item> * <item> c </item> * ` * }) * class MyComponent { * shown: boolean; * * constructor(private @Query(Item) items:QueryList<Item>) { * items.changes.subscribe(() => console.log(items.length)); * } * } * ``` * * Supports the same querying parameters as {@link QueryMetadata}, except * `descendants`. This always queries the whole view. * * As `shown` is flipped between true and false, items will contain zero of one * items. * * Specifies that a {@link QueryList} should be injected. * * The injected object is an iterable and observable live list. * See {@link QueryList} for more details. */ var ViewQueryMetadata = (function (_super) { __extends(ViewQueryMetadata, _super); function ViewQueryMetadata(_selector, _a) { var _b = _a === void 0 ? {} : _a, _c = _b.descendants, descendants = _c === void 0 ? false : _c, _d = _b.first, first = _d === void 0 ? false : _d; _super.call(this, _selector, { descendants: descendants, first: first }); } Object.defineProperty(ViewQueryMetadata.prototype, "isViewQuery", { /** * always `true` to differentiate it with {@link QueryMetadata}. */ get: function () { return true; }, enumerable: true, configurable: true }); ViewQueryMetadata.prototype.toString = function () { return "@ViewQuery(" + lang_1.stringify(this.selector) + ")"; }; ViewQueryMetadata = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object, Object]) ], ViewQueryMetadata); return ViewQueryMetadata; })(QueryMetadata); exports.ViewQueryMetadata = ViewQueryMetadata; /** * Configures a view query. * * View queries are set before the `ngAfterViewInit` callback is called. * * ### Example * * ``` * @Component({ * selector: 'someDir', * templateUrl: 'someTemplate', * directives: [ItemDirective] * }) * class SomeDir { * @ViewChildren(ItemDirective) viewChildren: QueryList<ItemDirective>; * * ngAfterViewInit() { * // viewChildren is set * } * } * ``` */ var ViewChildrenMetadata = (function (_super) { __extends(ViewChildrenMetadata, _super); function ViewChildrenMetadata(_selector) { _super.call(this, _selector, { descendants: true }); } ViewChildrenMetadata = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object]) ], ViewChildrenMetadata); return ViewChildrenMetadata; })(ViewQueryMetadata); exports.ViewChildrenMetadata = ViewChildrenMetadata; /** * Configures a view query. * * View queries are set before the `ngAfterViewInit` callback is called. * * ### Example * * ``` * @Component({ * selector: 'someDir', * templateUrl: 'someTemplate', * directives: [ItemDirective] * }) * class SomeDir { * @ViewChild(ItemDirective) viewChild:ItemDirective; * * ngAfterViewInit() { * // viewChild is set * } * } * ``` */ var ViewChildMetadata = (function (_super) { __extends(ViewChildMetadata, _super); function ViewChildMetadata(_selector) { _super.call(this, _selector, { descendants: true, first: true }); } ViewChildMetadata = __decorate([ lang_1.CONST(), __metadata('design:paramtypes', [Object]) ], ViewChildMetadata); return ViewChildMetadata; })(ViewQueryMetadata); exports.ViewChildMetadata = ViewChildMetadata; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"di.js","sourceRoot":"","sources":["angular2/src/core/metadata/di.ts"],"names":["AttributeMetadata","AttributeMetadata.constructor","AttributeMetadata.token","AttributeMetadata.toString","QueryMetadata","QueryMetadata.constructor","QueryMetadata.isViewQuery","QueryMetadata.selector","QueryMetadata.isVarBindingQuery","QueryMetadata.varBindings","QueryMetadata.toString","ContentChildrenMetadata","ContentChildrenMetadata.constructor","ContentChildMetadata","ContentChildMetadata.constructor","ViewQueryMetadata","ViewQueryMetadata.constructor","ViewQueryMetadata.isViewQuery","ViewQueryMetadata.toString","ViewChildrenMetadata","ViewChildrenMetadata.constructor","ViewChildMetadata","ViewChildMetadata.constructor"],"mappings":"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","sourcesContent":["import {CONST, Type, stringify, isPresent, isString} from 'angular2/src/facade/lang';\nimport {resolveForwardRef} from 'angular2/src/core/di';\nimport {DependencyMetadata} from 'angular2/src/core/di/metadata';\n\n/**\n * Specifies that a constant attribute value should be injected.\n *\n * The directive can inject constant string literals of host element attributes.\n *\n * ### Example\n *\n * Suppose we have an `<input>` element and want to know its `type`.\n *\n * ```html\n * <input type=\"text\">\n * ```\n *\n * A decorator can inject string literal `text` like so:\n *\n * {@example core/ts/metadata/metadata.ts region='attributeMetadata'}\n */\n@CONST()\nexport class AttributeMetadata extends DependencyMetadata {\n  constructor(public attributeName: string) { super(); }\n\n  get token(): AttributeMetadata {\n    // Normally one would default a token to a type of an injected value but here\n    // the type of a variable is \"string\" and we can't use primitive type as a return value\n    // so we use instance of Attribute instead. This doesn't matter much in practice as arguments\n    // with @Attribute annotation are injected by ElementInjector that doesn't take tokens into\n    // account.\n    return this;\n  }\n  toString(): string { return `@Attribute(${stringify(this.attributeName)})`; }\n}\n\n/**\n * Declares an injectable parameter to be a live list of directives or variable\n * bindings from the content children of a directive.\n *\n * ### Example ([live demo](http://plnkr.co/edit/lY9m8HLy7z06vDoUaSN2?p=preview))\n *\n * Assume that `<tabs>` component would like to get a list its children `<pane>`\n * components as shown in this example:\n *\n * ```html\n * <tabs>\n *   <pane title=\"Overview\">...</pane>\n *   <pane *ngFor=\"#o of objects\" [title]=\"o.title\">{{o.text}}</pane>\n * </tabs>\n * ```\n *\n * The preferred solution is to query for `Pane` directives using this decorator.\n *\n * ```javascript\n * @Component({\n *   selector: 'pane',\n *   inputs: ['title']\n * })\n * class Pane {\n *   title:string;\n * }\n *\n * @Component({\n *  selector: 'tabs',\n *  template: `\n *    <ul>\n *      <li *ngFor=\"#pane of panes\">{{pane.title}}</li>\n *    </ul>\n *    <content></content>\n *  `\n * })\n * class Tabs {\n *   panes: QueryList<Pane>;\n *   constructor(@Query(Pane) panes:QueryList<Pane>) {\n  *    this.panes = panes;\n  *  }\n * }\n * ```\n *\n * A query can look for variable bindings by passing in a string with desired binding symbol.\n *\n * ### Example ([live demo](http://plnkr.co/edit/sT2j25cH1dURAyBRCKx1?p=preview))\n * ```html\n * <seeker>\n *   <div #findme>...</div>\n * </seeker>\n *\n * @Component({ selector: 'seeker' })\n * class Seeker {\n *   constructor(@Query('findme') elList: QueryList<ElementRef>) {...}\n * }\n * ```\n *\n * In this case the object that is injected depend on the type of the variable\n * binding. It can be an ElementRef, a directive or a component.\n *\n * Passing in a comma separated list of variable bindings will query for all of them.\n *\n * ```html\n * <seeker>\n *   <div #find-me>...</div>\n *   <div #find-me-too>...</div>\n * </seeker>\n *\n *  @Component({\n *   selector: 'seeker'\n * })\n * class Seeker {\n *   constructor(@Query('findMe, findMeToo') elList: QueryList<ElementRef>) {...}\n * }\n * ```\n *\n * Configure whether query looks for direct children or all descendants\n * of the querying element, by using the `descendants` parameter.\n * It is set to `false` by default.\n *\n * ### Example ([live demo](http://plnkr.co/edit/wtGeB977bv7qvA5FTYl9?p=preview))\n * ```html\n * <container #first>\n *   <item>a</item>\n *   <item>b</item>\n *   <container #second>\n *     <item>c</item>\n *   </container>\n * </container>\n * ```\n *\n * When querying for items, the first container will see only `a` and `b` by default,\n * but with `Query(TextDirective, {descendants: true})` it will see `c` too.\n *\n * The queried directives are kept in a depth-first pre-order with respect to their\n * positions in the DOM.\n *\n * Query does not look deep into any subcomponent views.\n *\n * Query is updated as part of the change-detection cycle. Since change detection\n * happens after construction of a directive, QueryList will always be empty when observed in the\n * constructor.\n *\n * The injected object is an unmodifiable live list.\n * See {@link QueryList} for more details.\n */\n@CONST()\nexport class QueryMetadata extends DependencyMetadata {\n  /**\n   * whether we want to query only direct children (false) or all\n   * children (true).\n   */\n  descendants: boolean;\n  first: boolean;\n\n  constructor(private _selector: Type | string,\n              {descendants = false, first = false}: {descendants?: boolean, first?: boolean} = {}) {\n    super();\n    this.descendants = descendants;\n    this.first = first;\n  }\n\n  /**\n   * always `false` to differentiate it with {@link ViewQueryMetadata}.\n   */\n  get isViewQuery(): boolean { return false; }\n\n  /**\n   * what this is querying for.\n   */\n  get selector() { return resolveForwardRef(this._selector); }\n\n  /**\n   * whether this is querying for a variable binding or a directive.\n   */\n  get isVarBindingQuery(): boolean { return isString(this.selector); }\n\n  /**\n   * returns a list of variable bindings this is querying for.\n   * Only applicable if this is a variable bindings query.\n   */\n  get varBindings(): string[] { return this.selector.split(','); }\n\n  toString(): string { return `@Query(${stringify(this.selector)})`; }\n}\n\n// TODO: add an example after ContentChildren and ViewChildren are in master\n/**\n * Configures a content query.\n *\n * Content queries are set before the `ngAfterContentInit` callback is called.\n *\n * ### Example\n *\n * ```\n * @Directive({\n *   selector: 'someDir'\n * })\n * class SomeDir {\n *   @ContentChildren(ChildDirective) contentChildren: QueryList<ChildDirective>;\n *\n *   ngAfterContentInit() {\n *     // contentChildren is set\n *   }\n * }\n * ```\n */\n@CONST()\nexport class ContentChildrenMetadata extends QueryMetadata {\n  constructor(_selector: Type | string, {descendants = false}: {descendants?: boolean} = {}) {\n    super(_selector, {descendants: descendants});\n  }\n}\n\n// TODO: add an example after ContentChild and ViewChild are in master\n/**\n * Configures a content query.\n *\n * Content queries are set before the `ngAfterContentInit` callback is called.\n *\n * ### Example\n *\n * ```\n * @Directive({\n *   selector: 'someDir'\n * })\n * class SomeDir {\n *   @ContentChild(ChildDirective) contentChild;\n *\n *   ngAfterContentInit() {\n *     // contentChild is set\n *   }\n * }\n * ```\n */\n@CONST()\nexport class ContentChildMetadata extends QueryMetadata {\n  constructor(_selector: Type | string) { super(_selector, {descendants: true, first: true}); }\n}\n\n/**\n * Similar to {@link QueryMetadata}, but querying the component view, instead of\n * the content children.\n *\n * ### Example ([live demo](http://plnkr.co/edit/eNsFHDf7YjyM6IzKxM1j?p=preview))\n *\n * ```javascript\n * @Component({...})\n * @View({\n *   template: `\n *     <item> a </item>\n *     <item> b </item>\n *     <item> c </item>\n *   `\n * })\n * class MyComponent {\n *   shown: boolean;\n *\n *   constructor(private @Query(Item) items:QueryList<Item>) {\n *     items.changes.subscribe(() => console.log(items.length));\n *   }\n * }\n * ```\n *\n * Supports the same querying parameters as {@link QueryMetadata}, except\n * `descendants`. This always queries the whole view.\n *\n * As `shown` is flipped between true and false, items will contain zero of one\n * items.\n *\n * Specifies that a {@link QueryList} should be injected.\n *\n * The injected object is an iterable and observable live list.\n * See {@link QueryList} for more details.\n */\n@CONST()\nexport class ViewQueryMetadata extends QueryMetadata {\n  constructor(_selector: Type | string,\n              {descendants = false, first = false}: {descendants?: boolean, first?: boolean} = {}) {\n    super(_selector, {descendants: descendants, first: first});\n  }\n\n  /**\n   * always `true` to differentiate it with {@link QueryMetadata}.\n   */\n  get isViewQuery() { return true; }\n  toString(): string { return `@ViewQuery(${stringify(this.selector)})`; }\n}\n\n/**\n * Configures a view query.\n *\n * View queries are set before the `ngAfterViewInit` callback is called.\n *\n * ### Example\n *\n * ```\n * @Component({\n *   selector: 'someDir',\n *   templateUrl: 'someTemplate',\n *   directives: [ItemDirective]\n * })\n * class SomeDir {\n *   @ViewChildren(ItemDirective) viewChildren: QueryList<ItemDirective>;\n *\n *   ngAfterViewInit() {\n *     // viewChildren is set\n *   }\n * }\n * ```\n */\n@CONST()\nexport class ViewChildrenMetadata extends ViewQueryMetadata {\n  constructor(_selector: Type | string) { super(_selector, {descendants: true}); }\n}\n\n/**\n * Configures a view query.\n *\n * View queries are set before the `ngAfterViewInit` callback is called.\n *\n * ### Example\n *\n * ```\n * @Component({\n *   selector: 'someDir',\n *   templateUrl: 'someTemplate',\n *   directives: [ItemDirective]\n * })\n * class SomeDir {\n *   @ViewChild(ItemDirective) viewChild:ItemDirective;\n *\n *   ngAfterViewInit() {\n *     // viewChild is set\n *   }\n * }\n * ```\n */\n@CONST()\nexport class ViewChildMetadata extends ViewQueryMetadata {\n  constructor(_selector: Type | string) { super(_selector, {descendants: true, first: true}); }\n}\n"]}