UNPKG

@angular/core

Version:

Angular - the core framework

120 lines 13.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Google Inc. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ import { makeParamDecorator } from '../util/decorators'; /** * Type of the Inject decorator / constructor function. * * \@publicApi * @record */ export function InjectDecorator() { } // WARNING: interface has both a type and a value, skipping emit const ɵ0 = /** * @param {?} token * @return {?} */ (token) => ({ token }); /** * Inject decorator and metadata. * * \@Annotation * \@publicApi * @type {?} */ export const Inject = makeParamDecorator('Inject', (ɵ0)); /** * Type of the Optional decorator / constructor function. * * \@publicApi * @record */ export function OptionalDecorator() { } // WARNING: interface has both a type and a value, skipping emit /** * Optional decorator and metadata. * * \@Annotation * \@publicApi * @type {?} */ export const Optional = makeParamDecorator('Optional'); /** * Type of the Self decorator / constructor function. * * \@publicApi * @record */ export function SelfDecorator() { } // WARNING: interface has both a type and a value, skipping emit /** * Self decorator and metadata. * * \@Annotation * \@publicApi * @type {?} */ export const Self = makeParamDecorator('Self'); /** * Type of the SkipSelf decorator / constructor function. * * \@publicApi * @record */ export function SkipSelfDecorator() { } // WARNING: interface has both a type and a value, skipping emit /** * SkipSelf decorator and metadata. * * \@Annotation * \@publicApi * @type {?} */ export const SkipSelf = makeParamDecorator('SkipSelf'); /** * Type of the Host decorator / constructor function. * * \@publicApi * @record */ export function HostDecorator() { } // WARNING: interface has both a type and a value, skipping emit /** * Host decorator and metadata. * * \@Annotation * \@publicApi * @type {?} */ export const Host = makeParamDecorator('Host'); /** * Type of the Attribute decorator / constructor function. * * \@publicApi * @record */ export function AttributeDecorator() { } // WARNING: interface has both a type and a value, skipping emit const ɵ1 = /** * @param {?=} attributeName * @return {?} */ (attributeName) => ({ attributeName }); /** * Attribute decorator and metadata. * * \@Annotation * \@publicApi * @type {?} */ export const Attribute = makeParamDecorator('Attribute', (ɵ1)); export { ɵ0, ɵ1 }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/di/metadata.ts"],"names":[],"mappings":";;;;;;;;;;;AAQA,OAAO,EAAC,kBAAkB,EAAC,MAAM,oBAAoB,CAAC;;;;;;;AAStD,qCAmBC;;;;;;AAoBmE,CAAC,KAAU,EAAE,EAAE,CAAC,CAAC,EAAC,KAAK,EAAC,CAAC;;;;;;;;AAA7F,MAAM,OAAO,MAAM,GAAoB,kBAAkB,CAAC,QAAQ,OAA4B;;;;;;;AAQ9F,uCAqBC;;;;;;;;;AAeD,MAAM,OAAO,QAAQ,GAAsB,kBAAkB,CAAC,UAAU,CAAC;;;;;;;AAOzE,mCAwBC;;;;;;;;;AAeD,MAAM,OAAO,IAAI,GAAkB,kBAAkB,CAAC,MAAM,CAAC;;;;;;;AAQ7D,uCAwBC;;;;;;;;;AAeD,MAAM,OAAO,QAAQ,GAAsB,kBAAkB,CAAC,UAAU,CAAC;;;;;;;AAOzE,mCAkBC;;;;;;;;;AAeD,MAAM,OAAO,IAAI,GAAkB,kBAAkB,CAAC,MAAM,CAAC;;;;;;;AAQ7D,wCAwBC;;;;;;AAqBmC,CAAC,aAAsB,EAAE,EAAE,CAAC,CAAC,EAAC,aAAa,EAAC,CAAC;;;;;;;;AADjF,MAAM,OAAO,SAAS,GAClB,kBAAkB,CAAC,WAAW,OAAgD","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {makeParamDecorator} from '../util/decorators';\n\n\n\n/**\n * Type of the Inject decorator / constructor function.\n *\n * @publicApi\n */\nexport interface InjectDecorator {\n  /**\n   * Parameter decorator on a dependency parameter of a class constructor\n   * that specifies a custom provider of the dependency.\n   *\n   * Learn more in the [\"Dependency Injection Guide\"](guide/dependency-injection).\n   *\n   * @usageNotes\n   * The following example shows a class constructor that specifies a\n   * custom provider of a dependency using the parameter decorator.\n   *\n   * When `@Inject()` is not present, the injector uses the type annotation of the\n   * parameter as the provider.\n   *\n   * <code-example path=\"core/di/ts/metadata_spec.ts\"\n   * region=\"InjectWithoutDecorator\"  linenums=\"false\"></code-example>\n   */\n  (token: any): any;\n  new (token: any): Inject;\n}\n\n/**\n * Type of the Inject metadata.\n *\n * @publicApi\n */\nexport interface Inject {\n  /**\n   * A [DI token](guide/glossary#di-token) that maps to the dependency to be injected.\n   */\n  token: any;\n}\n\n/**\n * Inject decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nexport const Inject: InjectDecorator = makeParamDecorator('Inject', (token: any) => ({token}));\n\n\n/**\n * Type of the Optional decorator / constructor function.\n *\n * @publicApi\n */\nexport interface OptionalDecorator {\n  /**\n   * Parameter decorator to be used on constructor parameters,\n   * which marks the parameter as being an optional dependency.\n   * The DI framework provides null if the dependency is not found.\n   *\n   * Can be used together with other parameter decorators\n   * that modify how dependency injection operates.\n   *\n   * Learn more in the [\"Dependency Injection Guide\"](guide/dependency-injection).\n   *\n   * @usageNotes\n   *\n   * The following code allows the possibility of a null result:\n   *\n   * <code-example path=\"core/di/ts/metadata_spec.ts\" region=\"Optional\"\n   *  linenums=\"false\"></code-example>\n   *\n   */\n  (): any;\n  new (): Optional;\n}\n\n/**\n * Type of the Optional metadata.\n *\n * @publicApi\n */\nexport interface Optional {}\n\n/**\n * Optional decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nexport const Optional: OptionalDecorator = makeParamDecorator('Optional');\n\n/**\n * Type of the Self decorator / constructor function.\n *\n * @publicApi\n */\nexport interface SelfDecorator {\n  /**\n   * Parameter decorator to be used on constructor parameters,\n   * which tells the DI framework to start dependency resolution from the local injector.\n   *\n   * Resolution works upward through the injector hierarchy, so the children\n   * of this class must configure their own providers or be prepared for a null result.\n   *\n   * @usageNotes\n   *\n   * In the following example, the dependency can be resolved\n   * by the local injector when instantiating the class itself, but not\n   * when instantiating a child.\n   *\n   * <code-example path=\"core/di/ts/metadata_spec.ts\" region=\"Self\"\n   *  linenums=\"false\"></code-example>\n   *\n   *\n   * @see `SkipSelf`\n   * @see `Optional`\n   *\n   */\n  (): any;\n  new (): Self;\n}\n\n/**\n * Type of the Self metadata.\n *\n * @publicApi\n */\nexport interface Self {}\n\n/**\n * Self decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nexport const Self: SelfDecorator = makeParamDecorator('Self');\n\n\n/**\n * Type of the SkipSelf decorator / constructor function.\n *\n * @publicApi\n */\nexport interface SkipSelfDecorator {\n  /**\n   * Parameter decorator to be used on constructor parameters,\n   * which tells the DI framework to start dependency resolution from the parent injector.\n   * Resolution works upward through the injector hierarchy, so the local injector\n   * is not checked for a provider.\n   *\n   * @usageNotes\n   *\n   * In the following example, the dependency can be resolved when\n   * instantiating a child, but not when instantiating the class itself.\n   *\n   * <code-example path=\"core/di/ts/metadata_spec.ts\" region=\"SkipSelf\"\n   *  linenums=\"false\"></code-example>\n   *\n   * Learn more in the\n   * [Dependency Injection guide](guide/dependency-injection-in-action#skip).\n   *\n   * @see `Self`\n   * @see `Optional`\n   *\n   */\n  (): any;\n  new (): SkipSelf;\n}\n\n/**\n * Type of the SkipSelf metadata.\n *\n * @publicApi\n */\nexport interface SkipSelf {}\n\n/**\n * SkipSelf decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nexport const SkipSelf: SkipSelfDecorator = makeParamDecorator('SkipSelf');\n\n/**\n * Type of the Host decorator / constructor function.\n *\n * @publicApi\n */\nexport interface HostDecorator {\n  /**\n   * Parameter decorator on a view-provider parameter of a class constructor\n   * that tells the DI framework to resolve the view by checking injectors of child\n   * elements, and stop when reaching the host element of the current component.\n   *\n   * For an extended example, see\n   * [\"Dependency Injection Guide\"](guide/dependency-injection-in-action#optional).\n   *\n   * @usageNotes\n   *\n   * The following shows use with the `@Optional` decorator, and allows for a null result.\n   *\n   * <code-example path=\"core/di/ts/metadata_spec.ts\" region=\"Host\"\n   *  linenums=\"false\"></code-example>\n   */\n  (): any;\n  new (): Host;\n}\n\n/**\n * Type of the Host metadata.\n *\n * @publicApi\n */\nexport interface Host {}\n\n/**\n * Host decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nexport const Host: HostDecorator = makeParamDecorator('Host');\n\n\n/**\n * Type of the Attribute decorator / constructor function.\n *\n * @publicApi\n */\nexport interface AttributeDecorator {\n  /**\n   * Parameter decorator for a directive constructor that designates\n   * a host-element attribute whose value is injected as a constant string literal.\n   *\n   * @usageNotes\n   *\n   * Suppose we have an `<input>` element and want to know its `type`.\n   *\n   * ```html\n   * <input type=\"text\">\n   * ```\n   *\n   * The following example uses the decorator to inject the string literal `text`.\n   *\n   * {@example core/ts/metadata/metadata.ts region='attributeMetadata' linenums=\"false\"}\n   *\n   * ### Example as TypeScript Decorator\n   *\n   * {@example core/ts/metadata/metadata.ts region='attributeFactory' linenums=\"false\"}\n   *\n   */\n  (name: string): any;\n  new (name: string): Attribute;\n}\n\n/**\n * Type of the Attribute metadata.\n *\n * @publicApi\n */\nexport interface Attribute {\n  /**\n   * The name of the attribute whose value can be injected.\n   */\n  attributeName?: string;\n}\n\n/**\n * Attribute decorator and metadata.\n *\n * @Annotation\n * @publicApi\n */\nexport const Attribute: AttributeDecorator =\n    makeParamDecorator('Attribute', (attributeName?: string) => ({attributeName}));\n"]}