/
component.js
310 lines (310 loc) · 51.6 KB
/
component.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
/**
* @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
*/
(function (factory) {
if (typeof module === "object" && typeof module.exports === "object") {
var v = factory(require, exports);
if (v !== undefined) module.exports = v;
}
else if (typeof define === "function" && define.amd) {
define("@angular/compiler-cli/src/ngtsc/annotations/src/component", ["require", "exports", "tslib", "@angular/compiler", "path", "typescript", "@angular/compiler-cli/src/ngtsc/diagnostics", "@angular/compiler-cli/src/ngtsc/metadata", "@angular/compiler-cli/src/ngtsc/annotations/src/directive", "@angular/compiler-cli/src/ngtsc/annotations/src/metadata", "@angular/compiler-cli/src/ngtsc/annotations/src/util"], factory);
}
})(function (require, exports) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var tslib_1 = require("tslib");
var compiler_1 = require("@angular/compiler");
var path = require("path");
var ts = require("typescript");
var diagnostics_1 = require("@angular/compiler-cli/src/ngtsc/diagnostics");
var metadata_1 = require("@angular/compiler-cli/src/ngtsc/metadata");
var directive_1 = require("@angular/compiler-cli/src/ngtsc/annotations/src/directive");
var metadata_2 = require("@angular/compiler-cli/src/ngtsc/annotations/src/metadata");
var util_1 = require("@angular/compiler-cli/src/ngtsc/annotations/src/util");
var EMPTY_MAP = new Map();
var EMPTY_ARRAY = [];
/**
* `DecoratorHandler` which handles the `@Component` annotation.
*/
var ComponentDecoratorHandler = /** @class */ (function () {
function ComponentDecoratorHandler(checker, reflector, scopeRegistry, isCore, resourceLoader, rootDirs, defaultPreserveWhitespaces, i18nUseExternalIds) {
this.checker = checker;
this.reflector = reflector;
this.scopeRegistry = scopeRegistry;
this.isCore = isCore;
this.resourceLoader = resourceLoader;
this.rootDirs = rootDirs;
this.defaultPreserveWhitespaces = defaultPreserveWhitespaces;
this.i18nUseExternalIds = i18nUseExternalIds;
this.literalCache = new Map();
this.elementSchemaRegistry = new compiler_1.DomElementSchemaRegistry();
}
ComponentDecoratorHandler.prototype.detect = function (node, decorators) {
var _this = this;
if (!decorators) {
return undefined;
}
return decorators.find(function (decorator) { return decorator.name === 'Component' && (_this.isCore || util_1.isAngularCore(decorator)); });
};
ComponentDecoratorHandler.prototype.preanalyze = function (node, decorator) {
var e_1, _a;
var meta = this._resolveLiteral(decorator);
var component = metadata_1.reflectObjectLiteral(meta);
var promises = [];
var containingFile = node.getSourceFile().fileName;
if (this.resourceLoader.preload !== undefined && component.has('templateUrl')) {
var templateUrlExpr = component.get('templateUrl');
var templateUrl = metadata_1.staticallyResolve(templateUrlExpr, this.reflector, this.checker);
if (typeof templateUrl !== 'string') {
throw new diagnostics_1.FatalDiagnosticError(diagnostics_1.ErrorCode.VALUE_HAS_WRONG_TYPE, templateUrlExpr, 'templateUrl must be a string');
}
var promise = this.resourceLoader.preload(templateUrl, containingFile);
if (promise !== undefined) {
promises.push(promise);
}
}
var styleUrls = this._extractStyleUrls(component);
if (this.resourceLoader.preload !== undefined && styleUrls !== null) {
try {
for (var styleUrls_1 = tslib_1.__values(styleUrls), styleUrls_1_1 = styleUrls_1.next(); !styleUrls_1_1.done; styleUrls_1_1 = styleUrls_1.next()) {
var styleUrl = styleUrls_1_1.value;
var promise = this.resourceLoader.preload(styleUrl, containingFile);
if (promise !== undefined) {
promises.push(promise);
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (styleUrls_1_1 && !styleUrls_1_1.done && (_a = styleUrls_1.return)) _a.call(styleUrls_1);
}
finally { if (e_1) throw e_1.error; }
}
}
if (promises.length !== 0) {
return Promise.all(promises).then(function () { return undefined; });
}
else {
return undefined;
}
};
ComponentDecoratorHandler.prototype.analyze = function (node, decorator) {
var _this = this;
var containingFile = node.getSourceFile().fileName;
var meta = this._resolveLiteral(decorator);
this.literalCache.delete(decorator);
// @Component inherits @Directive, so begin by extracting the @Directive metadata and building
// on it.
var directiveResult = directive_1.extractDirectiveMetadata(node, decorator, this.checker, this.reflector, this.isCore, this.elementSchemaRegistry.getDefaultComponentElementName());
if (directiveResult === undefined) {
// `extractDirectiveMetadata` returns undefined when the @Directive has `jit: true`. In this
// case, compilation of the decorator is skipped. Returning an empty object signifies
// that no analysis was produced.
return {};
}
// Next, read the `@Component`-specific fields.
var decoratedElements = directiveResult.decoratedElements, component = directiveResult.decorator, metadata = directiveResult.metadata;
var templateStr = null;
if (component.has('templateUrl')) {
var templateUrlExpr = component.get('templateUrl');
var templateUrl = metadata_1.staticallyResolve(templateUrlExpr, this.reflector, this.checker);
if (typeof templateUrl !== 'string') {
throw new diagnostics_1.FatalDiagnosticError(diagnostics_1.ErrorCode.VALUE_HAS_WRONG_TYPE, templateUrlExpr, 'templateUrl must be a string');
}
templateStr = this.resourceLoader.load(templateUrl, containingFile);
}
else if (component.has('template')) {
var templateExpr = component.get('template');
var resolvedTemplate = metadata_1.staticallyResolve(templateExpr, this.reflector, this.checker);
if (typeof resolvedTemplate !== 'string') {
throw new diagnostics_1.FatalDiagnosticError(diagnostics_1.ErrorCode.VALUE_HAS_WRONG_TYPE, templateExpr, 'template must be a string');
}
templateStr = resolvedTemplate;
}
else {
throw new diagnostics_1.FatalDiagnosticError(diagnostics_1.ErrorCode.COMPONENT_MISSING_TEMPLATE, decorator.node, 'component is missing a template');
}
var preserveWhitespaces = this.defaultPreserveWhitespaces;
if (component.has('preserveWhitespaces')) {
var expr = component.get('preserveWhitespaces');
var value = metadata_1.staticallyResolve(expr, this.reflector, this.checker);
if (typeof value !== 'boolean') {
throw new diagnostics_1.FatalDiagnosticError(diagnostics_1.ErrorCode.VALUE_HAS_WRONG_TYPE, expr, 'preserveWhitespaces must be a boolean');
}
preserveWhitespaces = value;
}
var viewProviders = component.has('viewProviders') ?
new compiler_1.WrappedNodeExpr(component.get('viewProviders')) :
null;
// Go through the root directories for this project, and select the one with the smallest
// relative path representation.
var filePath = node.getSourceFile().fileName;
var relativeContextFilePath = this.rootDirs.reduce(function (previous, rootDir) {
var candidate = path.posix.relative(rootDir, filePath);
if (previous === undefined || candidate.length < previous.length) {
return candidate;
}
else {
return previous;
}
}, undefined);
var interpolation = compiler_1.DEFAULT_INTERPOLATION_CONFIG;
if (component.has('interpolation')) {
var expr = component.get('interpolation');
var value = metadata_1.staticallyResolve(expr, this.reflector, this.checker);
if (!Array.isArray(value) || value.length !== 2 ||
!value.every(function (element) { return typeof element === 'string'; })) {
throw new diagnostics_1.FatalDiagnosticError(diagnostics_1.ErrorCode.VALUE_HAS_WRONG_TYPE, expr, 'interpolation must be an array with 2 elements of string type');
}
interpolation = compiler_1.InterpolationConfig.fromArray(value);
}
var template = compiler_1.parseTemplate(templateStr, node.getSourceFile().fileName + "#" + node.name.text + "/template.html", { preserveWhitespaces: preserveWhitespaces, interpolationConfig: interpolation });
if (template.errors !== undefined) {
throw new Error("Errors parsing template: " + template.errors.map(function (e) { return e.toString(); }).join(', '));
}
// If the component has a selector, it should be registered with the `SelectorScopeRegistry` so
// when this component appears in an `@NgModule` scope, its selector can be determined.
if (metadata.selector !== null) {
var ref = new metadata_1.ResolvedReference(node, node.name);
this.scopeRegistry.registerDirective(node, tslib_1.__assign({ ref: ref, name: node.name.text, directive: ref, selector: metadata.selector, exportAs: metadata.exportAs, inputs: metadata.inputs, outputs: metadata.outputs, queries: metadata.queries.map(function (query) { return query.propertyName; }), isComponent: true }, util_1.extractDirectiveGuards(node, this.reflector)));
}
// Construct the list of view queries.
var coreModule = this.isCore ? undefined : '@angular/core';
var viewChildFromFields = directive_1.queriesFromFields(metadata_1.filterToMembersWithDecorator(decoratedElements, 'ViewChild', coreModule), this.reflector, this.checker);
var viewChildrenFromFields = directive_1.queriesFromFields(metadata_1.filterToMembersWithDecorator(decoratedElements, 'ViewChildren', coreModule), this.reflector, this.checker);
var viewQueries = tslib_1.__spread(viewChildFromFields, viewChildrenFromFields);
if (component.has('queries')) {
var queriesFromDecorator = directive_1.extractQueriesFromDecorator(component.get('queries'), this.reflector, this.checker, this.isCore);
viewQueries.push.apply(viewQueries, tslib_1.__spread(queriesFromDecorator.view));
}
var styles = null;
if (component.has('styles')) {
styles = directive_1.parseFieldArrayValue(component, 'styles', this.reflector, this.checker);
}
var styleUrls = this._extractStyleUrls(component);
if (styleUrls !== null) {
if (styles === null) {
styles = [];
}
styles.push.apply(styles, tslib_1.__spread(styleUrls.map(function (styleUrl) { return _this.resourceLoader.load(styleUrl, containingFile); })));
}
var encapsulation = 0;
if (component.has('encapsulation')) {
encapsulation = parseInt(metadata_1.staticallyResolve(component.get('encapsulation'), this.reflector, this.checker));
}
var animations = null;
if (component.has('animations')) {
animations = new compiler_1.WrappedNodeExpr(component.get('animations'));
}
return {
analysis: {
meta: tslib_1.__assign({}, metadata, { template: template,
viewQueries: viewQueries,
encapsulation: encapsulation,
interpolation: interpolation, styles: styles || [],
// These will be replaced during the compilation step, after all `NgModule`s have been
// analyzed and the full compilation scope for the component can be realized.
pipes: EMPTY_MAP, directives: EMPTY_ARRAY, wrapDirectivesAndPipesInClosure: false, //
animations: animations,
viewProviders: viewProviders, i18nUseExternalIds: this.i18nUseExternalIds, relativeContextFilePath: relativeContextFilePath }),
metadataStmt: metadata_2.generateSetClassMetadataCall(node, this.reflector, this.isCore),
parsedTemplate: template.nodes,
},
typeCheck: true,
};
};
ComponentDecoratorHandler.prototype.typeCheck = function (ctx, node, meta) {
var e_2, _a;
var scope = this.scopeRegistry.lookupCompilationScopeAsRefs(node);
var matcher = new compiler_1.SelectorMatcher();
if (scope !== null) {
try {
for (var _b = tslib_1.__values(scope.directives), _c = _b.next(); !_c.done; _c = _b.next()) {
var meta_1 = _c.value;
matcher.addSelectables(compiler_1.CssSelector.parse(meta_1.selector), meta_1);
}
}
catch (e_2_1) { e_2 = { error: e_2_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_2) throw e_2.error; }
}
ctx.addTemplate(node, meta.parsedTemplate, matcher);
}
};
ComponentDecoratorHandler.prototype.compile = function (node, analysis, pool) {
var e_3, _a;
// Check whether this component was registered with an NgModule. If so, it should be compiled
// under that module's compilation scope.
var scope = this.scopeRegistry.lookupCompilationScope(node);
var metadata = analysis.meta;
if (scope !== null) {
// Replace the empty components and directives from the analyze() step with a fully expanded
// scope. This is possible now because during compile() the whole compilation unit has been
// fully analyzed.
var pipes = scope.pipes, containsForwardDecls = scope.containsForwardDecls;
var directives = [];
try {
for (var _b = tslib_1.__values(scope.directives), _c = _b.next(); !_c.done; _c = _b.next()) {
var meta = _c.value;
directives.push({ selector: meta.selector, expression: meta.directive });
}
}
catch (e_3_1) { e_3 = { error: e_3_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_3) throw e_3.error; }
}
var wrapDirectivesAndPipesInClosure = !!containsForwardDecls;
metadata = tslib_1.__assign({}, metadata, { directives: directives, pipes: pipes, wrapDirectivesAndPipesInClosure: wrapDirectivesAndPipesInClosure });
}
var res = compiler_1.compileComponentFromMetadata(metadata, pool, compiler_1.makeBindingParser(metadata.interpolation));
var statements = res.statements;
if (analysis.metadataStmt !== null) {
statements.push(analysis.metadataStmt);
}
return {
name: 'ngComponentDef',
initializer: res.expression, statements: statements,
type: res.type,
};
};
ComponentDecoratorHandler.prototype._resolveLiteral = function (decorator) {
if (this.literalCache.has(decorator)) {
return this.literalCache.get(decorator);
}
if (decorator.args === null || decorator.args.length !== 1) {
throw new diagnostics_1.FatalDiagnosticError(diagnostics_1.ErrorCode.DECORATOR_ARITY_WRONG, decorator.node, "Incorrect number of arguments to @Component decorator");
}
var meta = util_1.unwrapExpression(decorator.args[0]);
if (!ts.isObjectLiteralExpression(meta)) {
throw new diagnostics_1.FatalDiagnosticError(diagnostics_1.ErrorCode.DECORATOR_ARG_NOT_LITERAL, meta, "Decorator argument must be literal.");
}
this.literalCache.set(decorator, meta);
return meta;
};
ComponentDecoratorHandler.prototype._extractStyleUrls = function (component) {
if (!component.has('styleUrls')) {
return null;
}
var styleUrlsExpr = component.get('styleUrls');
var styleUrls = metadata_1.staticallyResolve(styleUrlsExpr, this.reflector, this.checker);
if (!Array.isArray(styleUrls) || !styleUrls.every(function (url) { return typeof url === 'string'; })) {
throw new diagnostics_1.FatalDiagnosticError(diagnostics_1.ErrorCode.VALUE_HAS_WRONG_TYPE, styleUrlsExpr, 'styleUrls must be an array of strings');
}
return styleUrls;
};
return ComponentDecoratorHandler;
}());
exports.ComponentDecoratorHandler = ComponentDecoratorHandler;
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"../../../../../","sources":["packages/compiler-cli/src/ngtsc/annotations/src/component.ts"],"names":[],"mappings":"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","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 {ConstantPool, CssSelector, DEFAULT_INTERPOLATION_CONFIG, DomElementSchemaRegistry, ElementSchemaRegistry, Expression, InterpolationConfig, R3ComponentMetadata, R3DirectiveMetadata, SelectorMatcher, Statement, TmplAstNode, WrappedNodeExpr, compileComponentFromMetadata, makeBindingParser, parseTemplate} from '@angular/compiler';\nimport * as path from 'path';\nimport * as ts from 'typescript';\n\nimport {ErrorCode, FatalDiagnosticError} from '../../diagnostics';\nimport {Decorator, ReflectionHost} from '../../host';\nimport {AbsoluteReference, Reference, ResolvedReference, filterToMembersWithDecorator, reflectObjectLiteral, staticallyResolve} from '../../metadata';\nimport {AnalysisOutput, CompileResult, DecoratorHandler} from '../../transform';\nimport {TypeCheckContext, TypeCheckableDirectiveMeta} from '../../typecheck';\n\nimport {ResourceLoader} from './api';\nimport {extractDirectiveMetadata, extractQueriesFromDecorator, parseFieldArrayValue, queriesFromFields} from './directive';\nimport {generateSetClassMetadataCall} from './metadata';\nimport {ScopeDirective, SelectorScopeRegistry} from './selector_scope';\nimport {extractDirectiveGuards, isAngularCore, unwrapExpression} from './util';\n\nconst EMPTY_MAP = new Map<string, Expression>();\nconst EMPTY_ARRAY: any[] = [];\n\nexport interface ComponentHandlerData {\n  meta: R3ComponentMetadata;\n  parsedTemplate: TmplAstNode[];\n  metadataStmt: Statement|null;\n}\n\n/**\n * `DecoratorHandler` which handles the `@Component` annotation.\n */\nexport class ComponentDecoratorHandler implements\n    DecoratorHandler<ComponentHandlerData, Decorator> {\n  constructor(\n      private checker: ts.TypeChecker, private reflector: ReflectionHost,\n      private scopeRegistry: SelectorScopeRegistry, private isCore: boolean,\n      private resourceLoader: ResourceLoader, private rootDirs: string[],\n      private defaultPreserveWhitespaces: boolean, private i18nUseExternalIds: boolean) {}\n\n  private literalCache = new Map<Decorator, ts.ObjectLiteralExpression>();\n  private elementSchemaRegistry = new DomElementSchemaRegistry();\n\n\n  detect(node: ts.Declaration, decorators: Decorator[]|null): Decorator|undefined {\n    if (!decorators) {\n      return undefined;\n    }\n    return decorators.find(\n        decorator => decorator.name === 'Component' && (this.isCore || isAngularCore(decorator)));\n  }\n\n  preanalyze(node: ts.ClassDeclaration, decorator: Decorator): Promise<void>|undefined {\n    const meta = this._resolveLiteral(decorator);\n    const component = reflectObjectLiteral(meta);\n    const promises: Promise<void>[] = [];\n    const containingFile = node.getSourceFile().fileName;\n\n    if (this.resourceLoader.preload !== undefined && component.has('templateUrl')) {\n      const templateUrlExpr = component.get('templateUrl') !;\n      const templateUrl = staticallyResolve(templateUrlExpr, this.reflector, this.checker);\n      if (typeof templateUrl !== 'string') {\n        throw new FatalDiagnosticError(\n            ErrorCode.VALUE_HAS_WRONG_TYPE, templateUrlExpr, 'templateUrl must be a string');\n      }\n      const promise = this.resourceLoader.preload(templateUrl, containingFile);\n      if (promise !== undefined) {\n        promises.push(promise);\n      }\n    }\n\n    const styleUrls = this._extractStyleUrls(component);\n    if (this.resourceLoader.preload !== undefined && styleUrls !== null) {\n      for (const styleUrl of styleUrls) {\n        const promise = this.resourceLoader.preload(styleUrl, containingFile);\n        if (promise !== undefined) {\n          promises.push(promise);\n        }\n      }\n    }\n    if (promises.length !== 0) {\n      return Promise.all(promises).then(() => undefined);\n    } else {\n      return undefined;\n    }\n  }\n\n  analyze(node: ts.ClassDeclaration, decorator: Decorator): AnalysisOutput<ComponentHandlerData> {\n    const containingFile = node.getSourceFile().fileName;\n    const meta = this._resolveLiteral(decorator);\n    this.literalCache.delete(decorator);\n\n    // @Component inherits @Directive, so begin by extracting the @Directive metadata and building\n    // on it.\n    const directiveResult = extractDirectiveMetadata(\n        node, decorator, this.checker, this.reflector, this.isCore,\n        this.elementSchemaRegistry.getDefaultComponentElementName());\n    if (directiveResult === undefined) {\n      // `extractDirectiveMetadata` returns undefined when the @Directive has `jit: true`. In this\n      // case, compilation of the decorator is skipped. Returning an empty object signifies\n      // that no analysis was produced.\n      return {};\n    }\n\n    // Next, read the `@Component`-specific fields.\n    const {decoratedElements, decorator: component, metadata} = directiveResult;\n\n    let templateStr: string|null = null;\n    if (component.has('templateUrl')) {\n      const templateUrlExpr = component.get('templateUrl') !;\n      const templateUrl = staticallyResolve(templateUrlExpr, this.reflector, this.checker);\n      if (typeof templateUrl !== 'string') {\n        throw new FatalDiagnosticError(\n            ErrorCode.VALUE_HAS_WRONG_TYPE, templateUrlExpr, 'templateUrl must be a string');\n      }\n      templateStr = this.resourceLoader.load(templateUrl, containingFile);\n    } else if (component.has('template')) {\n      const templateExpr = component.get('template') !;\n      const resolvedTemplate = staticallyResolve(templateExpr, this.reflector, this.checker);\n      if (typeof resolvedTemplate !== 'string') {\n        throw new FatalDiagnosticError(\n            ErrorCode.VALUE_HAS_WRONG_TYPE, templateExpr, 'template must be a string');\n      }\n      templateStr = resolvedTemplate;\n    } else {\n      throw new FatalDiagnosticError(\n          ErrorCode.COMPONENT_MISSING_TEMPLATE, decorator.node, 'component is missing a template');\n    }\n\n    let preserveWhitespaces: boolean = this.defaultPreserveWhitespaces;\n    if (component.has('preserveWhitespaces')) {\n      const expr = component.get('preserveWhitespaces') !;\n      const value = staticallyResolve(expr, this.reflector, this.checker);\n      if (typeof value !== 'boolean') {\n        throw new FatalDiagnosticError(\n            ErrorCode.VALUE_HAS_WRONG_TYPE, expr, 'preserveWhitespaces must be a boolean');\n      }\n      preserveWhitespaces = value;\n    }\n\n    const viewProviders: Expression|null = component.has('viewProviders') ?\n        new WrappedNodeExpr(component.get('viewProviders') !) :\n        null;\n\n    // Go through the root directories for this project, and select the one with the smallest\n    // relative path representation.\n    const filePath = node.getSourceFile().fileName;\n    const relativeContextFilePath = this.rootDirs.reduce<string|undefined>((previous, rootDir) => {\n      const candidate = path.posix.relative(rootDir, filePath);\n      if (previous === undefined || candidate.length < previous.length) {\n        return candidate;\n      } else {\n        return previous;\n      }\n    }, undefined) !;\n\n    let interpolation: InterpolationConfig = DEFAULT_INTERPOLATION_CONFIG;\n    if (component.has('interpolation')) {\n      const expr = component.get('interpolation') !;\n      const value = staticallyResolve(expr, this.reflector, this.checker);\n      if (!Array.isArray(value) || value.length !== 2 ||\n          !value.every(element => typeof element === 'string')) {\n        throw new FatalDiagnosticError(\n            ErrorCode.VALUE_HAS_WRONG_TYPE, expr,\n            'interpolation must be an array with 2 elements of string type');\n      }\n      interpolation = InterpolationConfig.fromArray(value as[string, string]);\n    }\n\n    const template = parseTemplate(\n        templateStr, `${node.getSourceFile().fileName}#${node.name!.text}/template.html`,\n        {preserveWhitespaces, interpolationConfig: interpolation});\n    if (template.errors !== undefined) {\n      throw new Error(\n          `Errors parsing template: ${template.errors.map(e => e.toString()).join(', ')}`);\n    }\n\n    // If the component has a selector, it should be registered with the `SelectorScopeRegistry` so\n    // when this component appears in an `@NgModule` scope, its selector can be determined.\n    if (metadata.selector !== null) {\n      const ref = new ResolvedReference(node, node.name !);\n      this.scopeRegistry.registerDirective(node, {\n        ref,\n        name: node.name !.text,\n        directive: ref,\n        selector: metadata.selector,\n        exportAs: metadata.exportAs,\n        inputs: metadata.inputs,\n        outputs: metadata.outputs,\n        queries: metadata.queries.map(query => query.propertyName),\n        isComponent: true, ...extractDirectiveGuards(node, this.reflector),\n      });\n    }\n\n    // Construct the list of view queries.\n    const coreModule = this.isCore ? undefined : '@angular/core';\n    const viewChildFromFields = queriesFromFields(\n        filterToMembersWithDecorator(decoratedElements, 'ViewChild', coreModule), this.reflector,\n        this.checker);\n    const viewChildrenFromFields = queriesFromFields(\n        filterToMembersWithDecorator(decoratedElements, 'ViewChildren', coreModule), this.reflector,\n        this.checker);\n    const viewQueries = [...viewChildFromFields, ...viewChildrenFromFields];\n\n    if (component.has('queries')) {\n      const queriesFromDecorator = extractQueriesFromDecorator(\n          component.get('queries') !, this.reflector, this.checker, this.isCore);\n      viewQueries.push(...queriesFromDecorator.view);\n    }\n\n    let styles: string[]|null = null;\n    if (component.has('styles')) {\n      styles = parseFieldArrayValue(component, 'styles', this.reflector, this.checker);\n    }\n\n    let styleUrls = this._extractStyleUrls(component);\n    if (styleUrls !== null) {\n      if (styles === null) {\n        styles = [];\n      }\n      styles.push(...styleUrls.map(styleUrl => this.resourceLoader.load(styleUrl, containingFile)));\n    }\n\n    let encapsulation: number = 0;\n    if (component.has('encapsulation')) {\n      encapsulation = parseInt(staticallyResolve(\n          component.get('encapsulation') !, this.reflector, this.checker) as string);\n    }\n\n    let animations: Expression|null = null;\n    if (component.has('animations')) {\n      animations = new WrappedNodeExpr(component.get('animations') !);\n    }\n\n    return {\n      analysis: {\n        meta: {\n          ...metadata,\n          template,\n          viewQueries,\n          encapsulation,\n          interpolation,\n          styles: styles || [],\n\n          // These will be replaced during the compilation step, after all `NgModule`s have been\n          // analyzed and the full compilation scope for the component can be realized.\n          pipes: EMPTY_MAP,\n          directives: EMPTY_ARRAY,\n          wrapDirectivesAndPipesInClosure: false,  //\n          animations,\n          viewProviders,\n          i18nUseExternalIds: this.i18nUseExternalIds, relativeContextFilePath\n        },\n        metadataStmt: generateSetClassMetadataCall(node, this.reflector, this.isCore),\n        parsedTemplate: template.nodes,\n      },\n      typeCheck: true,\n    };\n  }\n\n  typeCheck(ctx: TypeCheckContext, node: ts.Declaration, meta: ComponentHandlerData): void {\n    const scope = this.scopeRegistry.lookupCompilationScopeAsRefs(node);\n    const matcher = new SelectorMatcher<ScopeDirective<any>>();\n    if (scope !== null) {\n      for (const meta of scope.directives) {\n        matcher.addSelectables(CssSelector.parse(meta.selector), meta);\n      }\n      ctx.addTemplate(node as ts.ClassDeclaration, meta.parsedTemplate, matcher);\n    }\n  }\n\n  compile(node: ts.ClassDeclaration, analysis: ComponentHandlerData, pool: ConstantPool):\n      CompileResult {\n    // Check whether this component was registered with an NgModule. If so, it should be compiled\n    // under that module's compilation scope.\n    const scope = this.scopeRegistry.lookupCompilationScope(node);\n    let metadata = analysis.meta;\n    if (scope !== null) {\n      // Replace the empty components and directives from the analyze() step with a fully expanded\n      // scope. This is possible now because during compile() the whole compilation unit has been\n      // fully analyzed.\n      const {pipes, containsForwardDecls} = scope;\n      const directives: {selector: string, expression: Expression}[] = [];\n\n      for (const meta of scope.directives) {\n        directives.push({selector: meta.selector, expression: meta.directive});\n      }\n      const wrapDirectivesAndPipesInClosure: boolean = !!containsForwardDecls;\n      metadata = {...metadata, directives, pipes, wrapDirectivesAndPipesInClosure};\n    }\n\n    const res =\n        compileComponentFromMetadata(metadata, pool, makeBindingParser(metadata.interpolation));\n\n    const statements = res.statements;\n    if (analysis.metadataStmt !== null) {\n      statements.push(analysis.metadataStmt);\n    }\n    return {\n      name: 'ngComponentDef',\n      initializer: res.expression, statements,\n      type: res.type,\n    };\n  }\n\n  private _resolveLiteral(decorator: Decorator): ts.ObjectLiteralExpression {\n    if (this.literalCache.has(decorator)) {\n      return this.literalCache.get(decorator) !;\n    }\n    if (decorator.args === null || decorator.args.length !== 1) {\n      throw new FatalDiagnosticError(\n          ErrorCode.DECORATOR_ARITY_WRONG, decorator.node,\n          `Incorrect number of arguments to @Component decorator`);\n    }\n    const meta = unwrapExpression(decorator.args[0]);\n\n    if (!ts.isObjectLiteralExpression(meta)) {\n      throw new FatalDiagnosticError(\n          ErrorCode.DECORATOR_ARG_NOT_LITERAL, meta, `Decorator argument must be literal.`);\n    }\n\n    this.literalCache.set(decorator, meta);\n    return meta;\n  }\n\n  private _extractStyleUrls(component: Map<string, ts.Expression>): string[]|null {\n    if (!component.has('styleUrls')) {\n      return null;\n    }\n\n    const styleUrlsExpr = component.get('styleUrls') !;\n    const styleUrls = staticallyResolve(styleUrlsExpr, this.reflector, this.checker);\n    if (!Array.isArray(styleUrls) || !styleUrls.every(url => typeof url === 'string')) {\n      throw new FatalDiagnosticError(\n          ErrorCode.VALUE_HAS_WRONG_TYPE, styleUrlsExpr, 'styleUrls must be an array of strings');\n    }\n    return styleUrls as string[];\n  }\n}\n"]}