/** * @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 {Injector, OpaqueToken} from '../di'; import {BaseException} from '../facade/exceptions'; import {ConcreteType, Type, stringify} from '../facade/lang'; import {ViewEncapsulation} from '../metadata'; import {NgModuleMetadata} from '../metadata/ng_module'; import {ComponentFactory} from './component_factory'; import {ComponentResolver} from './component_resolver'; import {NgModuleFactory} from './ng_module_factory'; /** * Indicates that a component is still being loaded in a synchronous compile. * * @stable */ export class ComponentStillLoadingError extends BaseException { constructor(public compType: Type) { super(`Can't compile synchronously as ${stringify(compType)} is still being loaded!`); } } /** * Low-level service for running the angular compiler duirng runtime * to create {@link ComponentFactory}s, which * can later be used to create and render a Component instance. * * Each `@NgModule` provides an own `Compiler` to its injector, * that will use the directives/pipes of the ng module for compilation * of components. * @stable */ export class Compiler { /** * Returns the injector with which the compiler has been created. * * @internal */ get injector(): Injector { throw new BaseException(`Runtime compiler is not loaded. Tried to read the injector.`); } /** * Loads the template and styles of a component and returns the associated `ComponentFactory`. */ compileComponentAsync(component: ConcreteType, ngModule: Type = null): Promise> { throw new BaseException( `Runtime compiler is not loaded. Tried to compile ${stringify(component)}`); } /** * Compiles the given component. All templates have to be either inline or compiled via * `compileComponentAsync` before. Otherwise throws a {@link ComponentStillLoadingError}. */ compileComponentSync(component: ConcreteType, ngModule: Type = null): ComponentFactory { throw new BaseException( `Runtime compiler is not loaded. Tried to compile ${stringify(component)}`); } /** * Compiles the given NgModule. All templates of the components listed in `precompile` * have to be either inline or compiled before via `compileComponentAsync` / * `compileModuleAsync`. Otherwise throws a {@link ComponentStillLoadingError}. */ compileModuleSync(moduleType: ConcreteType): NgModuleFactory { throw new BaseException( `Runtime compiler is not loaded. Tried to compile ${stringify(moduleType)}`); } compileModuleAsync(moduleType: ConcreteType): Promise> { throw new BaseException( `Runtime compiler is not loaded. Tried to compile ${stringify(moduleType)}`); } /** * Clears all caches */ clearCache(): void {} /** * Clears the cache for the given component/ngModule. */ clearCacheFor(type: Type) {} } /** * Options for creating a compiler * * @experimental */ export type CompilerOptions = { useDebug?: boolean, useJit?: boolean, defaultEncapsulation?: ViewEncapsulation, providers?: any[], }; /** * Token to provide CompilerOptions in the platform injector. * * @experimental */ export const CompilerOptions = new OpaqueToken('compilerOptions'); /** * A factory for creating a Compiler * * @experimental */ export abstract class CompilerFactory { abstract createCompiler(options?: CompilerOptions[]): Compiler; }