/** * @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 { Type } from './facade/type'; /** * An interface that a function passed into {@link forwardRef} has to implement. * * ### Example * * {@example core/di/ts/forward_ref/forward_ref_spec.ts region='forward_ref_fn'} * @experimental */ export interface ForwardRefFn { (): any; } /** * Allows to refer to references which are not yet defined. * * For instance, `forwardRef` is used when the `token` which we need to refer to for the purposes of * DI is declared, * but not yet defined. It is also used when the `token` which we use when creating a query is not * yet defined. * * ### Example * {@example core/di/ts/forward_ref/forward_ref_spec.ts region='forward_ref'} * @experimental */ export declare function forwardRef(forwardRefFn: ForwardRefFn): Type; /** * Lazily retrieves the reference value from a forwardRef. * * Acts as the identity function when given a non-forward-ref value. * * ### Example ([live demo](http://plnkr.co/edit/GU72mJrk1fiodChcmiDR?p=preview)) * * {@example core/di/ts/forward_ref/forward_ref_spec.ts region='resolve_forward_ref'} * * See: {@link forwardRef} * @experimental */ export declare function resolveForwardRef(type: any): any;