source: trip-planner-front/node_modules/@angular/compiler/src/render3/r3_template_transform.js@ 6a3a178

Last change on this file since 6a3a178 was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 83.1 KB
Line 
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8(function (factory) {
9 if (typeof module === "object" && typeof module.exports === "object") {
10 var v = factory(require, exports);
11 if (v !== undefined) module.exports = v;
12 }
13 else if (typeof define === "function" && define.amd) {
14 define("@angular/compiler/src/render3/r3_template_transform", ["require", "exports", "tslib", "@angular/compiler/src/ml_parser/ast", "@angular/compiler/src/ml_parser/html_whitespaces", "@angular/compiler/src/ml_parser/tags", "@angular/compiler/src/parse_util", "@angular/compiler/src/style_url_resolver", "@angular/compiler/src/template_parser/template_preparser", "@angular/compiler/src/render3/r3_ast", "@angular/compiler/src/render3/view/i18n/util"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.htmlAstToRender3Ast = void 0;
20 var tslib_1 = require("tslib");
21 var html = require("@angular/compiler/src/ml_parser/ast");
22 var html_whitespaces_1 = require("@angular/compiler/src/ml_parser/html_whitespaces");
23 var tags_1 = require("@angular/compiler/src/ml_parser/tags");
24 var parse_util_1 = require("@angular/compiler/src/parse_util");
25 var style_url_resolver_1 = require("@angular/compiler/src/style_url_resolver");
26 var template_preparser_1 = require("@angular/compiler/src/template_parser/template_preparser");
27 var t = require("@angular/compiler/src/render3/r3_ast");
28 var util_1 = require("@angular/compiler/src/render3/view/i18n/util");
29 var BIND_NAME_REGEXP = /^(?:(bind-)|(let-)|(ref-|#)|(on-)|(bindon-)|(@))(.*)$/;
30 // Group 1 = "bind-"
31 var KW_BIND_IDX = 1;
32 // Group 2 = "let-"
33 var KW_LET_IDX = 2;
34 // Group 3 = "ref-/#"
35 var KW_REF_IDX = 3;
36 // Group 4 = "on-"
37 var KW_ON_IDX = 4;
38 // Group 5 = "bindon-"
39 var KW_BINDON_IDX = 5;
40 // Group 6 = "@"
41 var KW_AT_IDX = 6;
42 // Group 7 = the identifier after "bind-", "let-", "ref-/#", "on-", "bindon-" or "@"
43 var IDENT_KW_IDX = 7;
44 var BINDING_DELIMS = {
45 BANANA_BOX: { start: '[(', end: ')]' },
46 PROPERTY: { start: '[', end: ']' },
47 EVENT: { start: '(', end: ')' },
48 };
49 var TEMPLATE_ATTR_PREFIX = '*';
50 function htmlAstToRender3Ast(htmlNodes, bindingParser, options) {
51 var transformer = new HtmlAstToIvyAst(bindingParser, options);
52 var ivyNodes = html.visitAll(transformer, htmlNodes);
53 // Errors might originate in either the binding parser or the html to ivy transformer
54 var allErrors = bindingParser.errors.concat(transformer.errors);
55 var result = {
56 nodes: ivyNodes,
57 errors: allErrors,
58 styleUrls: transformer.styleUrls,
59 styles: transformer.styles,
60 ngContentSelectors: transformer.ngContentSelectors
61 };
62 if (options.collectCommentNodes) {
63 result.commentNodes = transformer.commentNodes;
64 }
65 return result;
66 }
67 exports.htmlAstToRender3Ast = htmlAstToRender3Ast;
68 var HtmlAstToIvyAst = /** @class */ (function () {
69 function HtmlAstToIvyAst(bindingParser, options) {
70 this.bindingParser = bindingParser;
71 this.options = options;
72 this.errors = [];
73 this.styles = [];
74 this.styleUrls = [];
75 this.ngContentSelectors = [];
76 // This array will be populated if `Render3ParseOptions['collectCommentNodes']` is true
77 this.commentNodes = [];
78 this.inI18nBlock = false;
79 }
80 // HTML visitor
81 HtmlAstToIvyAst.prototype.visitElement = function (element) {
82 var e_1, _a;
83 var _this = this;
84 var isI18nRootElement = util_1.isI18nRootNode(element.i18n);
85 if (isI18nRootElement) {
86 if (this.inI18nBlock) {
87 this.reportError('Cannot mark an element as translatable inside of a translatable section. Please remove the nested i18n marker.', element.sourceSpan);
88 }
89 this.inI18nBlock = true;
90 }
91 var preparsedElement = template_preparser_1.preparseElement(element);
92 if (preparsedElement.type === template_preparser_1.PreparsedElementType.SCRIPT) {
93 return null;
94 }
95 else if (preparsedElement.type === template_preparser_1.PreparsedElementType.STYLE) {
96 var contents = textContents(element);
97 if (contents !== null) {
98 this.styles.push(contents);
99 }
100 return null;
101 }
102 else if (preparsedElement.type === template_preparser_1.PreparsedElementType.STYLESHEET &&
103 style_url_resolver_1.isStyleUrlResolvable(preparsedElement.hrefAttr)) {
104 this.styleUrls.push(preparsedElement.hrefAttr);
105 return null;
106 }
107 // Whether the element is a `<ng-template>`
108 var isTemplateElement = tags_1.isNgTemplate(element.name);
109 var parsedProperties = [];
110 var boundEvents = [];
111 var variables = [];
112 var references = [];
113 var attributes = [];
114 var i18nAttrsMeta = {};
115 var templateParsedProperties = [];
116 var templateVariables = [];
117 // Whether the element has any *-attribute
118 var elementHasInlineTemplate = false;
119 try {
120 for (var _b = tslib_1.__values(element.attrs), _c = _b.next(); !_c.done; _c = _b.next()) {
121 var attribute = _c.value;
122 var hasBinding = false;
123 var normalizedName = normalizeAttributeName(attribute.name);
124 // `*attr` defines template bindings
125 var isTemplateBinding = false;
126 if (attribute.i18n) {
127 i18nAttrsMeta[attribute.name] = attribute.i18n;
128 }
129 if (normalizedName.startsWith(TEMPLATE_ATTR_PREFIX)) {
130 // *-attributes
131 if (elementHasInlineTemplate) {
132 this.reportError("Can't have multiple template bindings on one element. Use only one attribute prefixed with *", attribute.sourceSpan);
133 }
134 isTemplateBinding = true;
135 elementHasInlineTemplate = true;
136 var templateValue = attribute.value;
137 var templateKey = normalizedName.substring(TEMPLATE_ATTR_PREFIX.length);
138 var parsedVariables = [];
139 var absoluteValueOffset = attribute.valueSpan ?
140 attribute.valueSpan.start.offset :
141 // If there is no value span the attribute does not have a value, like `attr` in
142 //`<div attr></div>`. In this case, point to one character beyond the last character of
143 // the attribute name.
144 attribute.sourceSpan.start.offset + attribute.name.length;
145 this.bindingParser.parseInlineTemplateBinding(templateKey, templateValue, attribute.sourceSpan, absoluteValueOffset, [], templateParsedProperties, parsedVariables, true /* isIvyAst */);
146 templateVariables.push.apply(templateVariables, tslib_1.__spreadArray([], tslib_1.__read(parsedVariables.map(function (v) { return new t.Variable(v.name, v.value, v.sourceSpan, v.keySpan, v.valueSpan); }))));
147 }
148 else {
149 // Check for variables, events, property bindings, interpolation
150 hasBinding = this.parseAttribute(isTemplateElement, attribute, [], parsedProperties, boundEvents, variables, references);
151 }
152 if (!hasBinding && !isTemplateBinding) {
153 // don't include the bindings as attributes as well in the AST
154 attributes.push(this.visitAttribute(attribute));
155 }
156 }
157 }
158 catch (e_1_1) { e_1 = { error: e_1_1 }; }
159 finally {
160 try {
161 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
162 }
163 finally { if (e_1) throw e_1.error; }
164 }
165 var children = html.visitAll(preparsedElement.nonBindable ? NON_BINDABLE_VISITOR : this, element.children);
166 var parsedElement;
167 if (preparsedElement.type === template_preparser_1.PreparsedElementType.NG_CONTENT) {
168 // `<ng-content>`
169 if (element.children &&
170 !element.children.every(function (node) { return isEmptyTextNode(node) || isCommentNode(node); })) {
171 this.reportError("<ng-content> element cannot have content.", element.sourceSpan);
172 }
173 var selector = preparsedElement.selectAttr;
174 var attrs = element.attrs.map(function (attr) { return _this.visitAttribute(attr); });
175 parsedElement = new t.Content(selector, attrs, element.sourceSpan, element.i18n);
176 this.ngContentSelectors.push(selector);
177 }
178 else if (isTemplateElement) {
179 // `<ng-template>`
180 var attrs = this.extractAttributes(element.name, parsedProperties, i18nAttrsMeta);
181 parsedElement = new t.Template(element.name, attributes, attrs.bound, boundEvents, [ /* no template attributes */], children, references, variables, element.sourceSpan, element.startSourceSpan, element.endSourceSpan, element.i18n);
182 }
183 else {
184 var attrs = this.extractAttributes(element.name, parsedProperties, i18nAttrsMeta);
185 parsedElement = new t.Element(element.name, attributes, attrs.bound, boundEvents, children, references, element.sourceSpan, element.startSourceSpan, element.endSourceSpan, element.i18n);
186 }
187 if (elementHasInlineTemplate) {
188 // If this node is an inline-template (e.g. has *ngFor) then we need to create a template
189 // node that contains this node.
190 // Moreover, if the node is an element, then we need to hoist its attributes to the template
191 // node for matching against content projection selectors.
192 var attrs = this.extractAttributes('ng-template', templateParsedProperties, i18nAttrsMeta);
193 var templateAttrs_1 = [];
194 attrs.literal.forEach(function (attr) { return templateAttrs_1.push(attr); });
195 attrs.bound.forEach(function (attr) { return templateAttrs_1.push(attr); });
196 var hoistedAttrs = parsedElement instanceof t.Element ?
197 {
198 attributes: parsedElement.attributes,
199 inputs: parsedElement.inputs,
200 outputs: parsedElement.outputs,
201 } :
202 { attributes: [], inputs: [], outputs: [] };
203 // For <ng-template>s with structural directives on them, avoid passing i18n information to
204 // the wrapping template to prevent unnecessary i18n instructions from being generated. The
205 // necessary i18n meta information will be extracted from child elements.
206 var i18n_1 = isTemplateElement && isI18nRootElement ? undefined : element.i18n;
207 // TODO(pk): test for this case
208 parsedElement = new t.Template(parsedElement.name, hoistedAttrs.attributes, hoistedAttrs.inputs, hoistedAttrs.outputs, templateAttrs_1, [parsedElement], [ /* no references */], templateVariables, element.sourceSpan, element.startSourceSpan, element.endSourceSpan, i18n_1);
209 }
210 if (isI18nRootElement) {
211 this.inI18nBlock = false;
212 }
213 return parsedElement;
214 };
215 HtmlAstToIvyAst.prototype.visitAttribute = function (attribute) {
216 return new t.TextAttribute(attribute.name, attribute.value, attribute.sourceSpan, attribute.keySpan, attribute.valueSpan, attribute.i18n);
217 };
218 HtmlAstToIvyAst.prototype.visitText = function (text) {
219 return this._visitTextWithInterpolation(text.value, text.sourceSpan, text.i18n);
220 };
221 HtmlAstToIvyAst.prototype.visitExpansion = function (expansion) {
222 var _this = this;
223 if (!expansion.i18n) {
224 // do not generate Icu in case it was created
225 // outside of i18n block in a template
226 return null;
227 }
228 if (!util_1.isI18nRootNode(expansion.i18n)) {
229 throw new Error("Invalid type \"" + expansion.i18n.constructor + "\" for \"i18n\" property of " + expansion.sourceSpan.toString() + ". Expected a \"Message\"");
230 }
231 var message = expansion.i18n;
232 var vars = {};
233 var placeholders = {};
234 // extract VARs from ICUs - we process them separately while
235 // assembling resulting message via goog.getMsg function, since
236 // we need to pass them to top-level goog.getMsg call
237 Object.keys(message.placeholders).forEach(function (key) {
238 var value = message.placeholders[key];
239 if (key.startsWith(util_1.I18N_ICU_VAR_PREFIX)) {
240 // Currently when the `plural` or `select` keywords in an ICU contain trailing spaces (e.g.
241 // `{count, select , ...}`), these spaces are also included into the key names in ICU vars
242 // (e.g. "VAR_SELECT "). These trailing spaces are not desirable, since they will later be
243 // converted into `_` symbols while normalizing placeholder names, which might lead to
244 // mismatches at runtime (i.e. placeholder will not be replaced with the correct value).
245 var formattedKey = key.trim();
246 var ast = _this.bindingParser.parseInterpolationExpression(value.text, value.sourceSpan);
247 vars[formattedKey] = new t.BoundText(ast, value.sourceSpan);
248 }
249 else {
250 placeholders[key] = _this._visitTextWithInterpolation(value.text, value.sourceSpan);
251 }
252 });
253 return new t.Icu(vars, placeholders, expansion.sourceSpan, message);
254 };
255 HtmlAstToIvyAst.prototype.visitExpansionCase = function (expansionCase) {
256 return null;
257 };
258 HtmlAstToIvyAst.prototype.visitComment = function (comment) {
259 if (this.options.collectCommentNodes) {
260 this.commentNodes.push(new t.Comment(comment.value || '', comment.sourceSpan));
261 }
262 return null;
263 };
264 // convert view engine `ParsedProperty` to a format suitable for IVY
265 HtmlAstToIvyAst.prototype.extractAttributes = function (elementName, properties, i18nPropsMeta) {
266 var _this = this;
267 var bound = [];
268 var literal = [];
269 properties.forEach(function (prop) {
270 var i18n = i18nPropsMeta[prop.name];
271 if (prop.isLiteral) {
272 literal.push(new t.TextAttribute(prop.name, prop.expression.source || '', prop.sourceSpan, prop.keySpan, prop.valueSpan, i18n));
273 }
274 else {
275 // Note that validation is skipped and property mapping is disabled
276 // due to the fact that we need to make sure a given prop is not an
277 // input of a directive and directive matching happens at runtime.
278 var bep = _this.bindingParser.createBoundElementProperty(elementName, prop, /* skipValidation */ true, /* mapPropertyName */ false);
279 bound.push(t.BoundAttribute.fromBoundElementProperty(bep, i18n));
280 }
281 });
282 return { bound: bound, literal: literal };
283 };
284 HtmlAstToIvyAst.prototype.parseAttribute = function (isTemplateElement, attribute, matchableAttributes, parsedProperties, boundEvents, variables, references) {
285 var name = normalizeAttributeName(attribute.name);
286 var value = attribute.value;
287 var srcSpan = attribute.sourceSpan;
288 var absoluteOffset = attribute.valueSpan ? attribute.valueSpan.start.offset : srcSpan.start.offset;
289 function createKeySpan(srcSpan, prefix, identifier) {
290 // We need to adjust the start location for the keySpan to account for the removed 'data-'
291 // prefix from `normalizeAttributeName`.
292 var normalizationAdjustment = attribute.name.length - name.length;
293 var keySpanStart = srcSpan.start.moveBy(prefix.length + normalizationAdjustment);
294 var keySpanEnd = keySpanStart.moveBy(identifier.length);
295 return new parse_util_1.ParseSourceSpan(keySpanStart, keySpanEnd, keySpanStart, identifier);
296 }
297 var bindParts = name.match(BIND_NAME_REGEXP);
298 if (bindParts) {
299 if (bindParts[KW_BIND_IDX] != null) {
300 var identifier = bindParts[IDENT_KW_IDX];
301 var keySpan_1 = createKeySpan(srcSpan, bindParts[KW_BIND_IDX], identifier);
302 this.bindingParser.parsePropertyBinding(identifier, value, false, srcSpan, absoluteOffset, attribute.valueSpan, matchableAttributes, parsedProperties, keySpan_1);
303 }
304 else if (bindParts[KW_LET_IDX]) {
305 if (isTemplateElement) {
306 var identifier = bindParts[IDENT_KW_IDX];
307 var keySpan_2 = createKeySpan(srcSpan, bindParts[KW_LET_IDX], identifier);
308 this.parseVariable(identifier, value, srcSpan, keySpan_2, attribute.valueSpan, variables);
309 }
310 else {
311 this.reportError("\"let-\" is only supported on ng-template elements.", srcSpan);
312 }
313 }
314 else if (bindParts[KW_REF_IDX]) {
315 var identifier = bindParts[IDENT_KW_IDX];
316 var keySpan_3 = createKeySpan(srcSpan, bindParts[KW_REF_IDX], identifier);
317 this.parseReference(identifier, value, srcSpan, keySpan_3, attribute.valueSpan, references);
318 }
319 else if (bindParts[KW_ON_IDX]) {
320 var events = [];
321 var identifier = bindParts[IDENT_KW_IDX];
322 var keySpan_4 = createKeySpan(srcSpan, bindParts[KW_ON_IDX], identifier);
323 this.bindingParser.parseEvent(identifier, value, srcSpan, attribute.valueSpan || srcSpan, matchableAttributes, events, keySpan_4);
324 addEvents(events, boundEvents);
325 }
326 else if (bindParts[KW_BINDON_IDX]) {
327 var identifier = bindParts[IDENT_KW_IDX];
328 var keySpan_5 = createKeySpan(srcSpan, bindParts[KW_BINDON_IDX], identifier);
329 this.bindingParser.parsePropertyBinding(identifier, value, false, srcSpan, absoluteOffset, attribute.valueSpan, matchableAttributes, parsedProperties, keySpan_5);
330 this.parseAssignmentEvent(identifier, value, srcSpan, attribute.valueSpan, matchableAttributes, boundEvents, keySpan_5);
331 }
332 else if (bindParts[KW_AT_IDX]) {
333 var keySpan_6 = createKeySpan(srcSpan, '', name);
334 this.bindingParser.parseLiteralAttr(name, value, srcSpan, absoluteOffset, attribute.valueSpan, matchableAttributes, parsedProperties, keySpan_6);
335 }
336 return true;
337 }
338 // We didn't see a kw-prefixed property binding, but we have not yet checked
339 // for the []/()/[()] syntax.
340 var delims = null;
341 if (name.startsWith(BINDING_DELIMS.BANANA_BOX.start)) {
342 delims = BINDING_DELIMS.BANANA_BOX;
343 }
344 else if (name.startsWith(BINDING_DELIMS.PROPERTY.start)) {
345 delims = BINDING_DELIMS.PROPERTY;
346 }
347 else if (name.startsWith(BINDING_DELIMS.EVENT.start)) {
348 delims = BINDING_DELIMS.EVENT;
349 }
350 if (delims !== null &&
351 // NOTE: older versions of the parser would match a start/end delimited
352 // binding iff the property name was terminated by the ending delimiter
353 // and the identifier in the binding was non-empty.
354 // TODO(ayazhafiz): update this to handle malformed bindings.
355 name.endsWith(delims.end) && name.length > delims.start.length + delims.end.length) {
356 var identifier = name.substring(delims.start.length, name.length - delims.end.length);
357 var keySpan_7 = createKeySpan(srcSpan, delims.start, identifier);
358 if (delims.start === BINDING_DELIMS.BANANA_BOX.start) {
359 this.bindingParser.parsePropertyBinding(identifier, value, false, srcSpan, absoluteOffset, attribute.valueSpan, matchableAttributes, parsedProperties, keySpan_7);
360 this.parseAssignmentEvent(identifier, value, srcSpan, attribute.valueSpan, matchableAttributes, boundEvents, keySpan_7);
361 }
362 else if (delims.start === BINDING_DELIMS.PROPERTY.start) {
363 this.bindingParser.parsePropertyBinding(identifier, value, false, srcSpan, absoluteOffset, attribute.valueSpan, matchableAttributes, parsedProperties, keySpan_7);
364 }
365 else {
366 var events = [];
367 this.bindingParser.parseEvent(identifier, value, srcSpan, attribute.valueSpan || srcSpan, matchableAttributes, events, keySpan_7);
368 addEvents(events, boundEvents);
369 }
370 return true;
371 }
372 // No explicit binding found.
373 var keySpan = createKeySpan(srcSpan, '' /* prefix */, name);
374 var hasBinding = this.bindingParser.parsePropertyInterpolation(name, value, srcSpan, attribute.valueSpan, matchableAttributes, parsedProperties, keySpan);
375 return hasBinding;
376 };
377 HtmlAstToIvyAst.prototype._visitTextWithInterpolation = function (value, sourceSpan, i18n) {
378 var valueNoNgsp = html_whitespaces_1.replaceNgsp(value);
379 var expr = this.bindingParser.parseInterpolation(valueNoNgsp, sourceSpan);
380 return expr ? new t.BoundText(expr, sourceSpan, i18n) : new t.Text(valueNoNgsp, sourceSpan);
381 };
382 HtmlAstToIvyAst.prototype.parseVariable = function (identifier, value, sourceSpan, keySpan, valueSpan, variables) {
383 if (identifier.indexOf('-') > -1) {
384 this.reportError("\"-\" is not allowed in variable names", sourceSpan);
385 }
386 else if (identifier.length === 0) {
387 this.reportError("Variable does not have a name", sourceSpan);
388 }
389 variables.push(new t.Variable(identifier, value, sourceSpan, keySpan, valueSpan));
390 };
391 HtmlAstToIvyAst.prototype.parseReference = function (identifier, value, sourceSpan, keySpan, valueSpan, references) {
392 if (identifier.indexOf('-') > -1) {
393 this.reportError("\"-\" is not allowed in reference names", sourceSpan);
394 }
395 else if (identifier.length === 0) {
396 this.reportError("Reference does not have a name", sourceSpan);
397 }
398 else if (references.some(function (reference) { return reference.name === identifier; })) {
399 this.reportError("Reference \"#" + identifier + "\" is defined more than once", sourceSpan);
400 }
401 references.push(new t.Reference(identifier, value, sourceSpan, keySpan, valueSpan));
402 };
403 HtmlAstToIvyAst.prototype.parseAssignmentEvent = function (name, expression, sourceSpan, valueSpan, targetMatchableAttrs, boundEvents, keySpan) {
404 var events = [];
405 this.bindingParser.parseEvent(name + "Change", expression + "=$event", sourceSpan, valueSpan || sourceSpan, targetMatchableAttrs, events, keySpan);
406 addEvents(events, boundEvents);
407 };
408 HtmlAstToIvyAst.prototype.reportError = function (message, sourceSpan, level) {
409 if (level === void 0) { level = parse_util_1.ParseErrorLevel.ERROR; }
410 this.errors.push(new parse_util_1.ParseError(sourceSpan, message, level));
411 };
412 return HtmlAstToIvyAst;
413 }());
414 var NonBindableVisitor = /** @class */ (function () {
415 function NonBindableVisitor() {
416 }
417 NonBindableVisitor.prototype.visitElement = function (ast) {
418 var preparsedElement = template_preparser_1.preparseElement(ast);
419 if (preparsedElement.type === template_preparser_1.PreparsedElementType.SCRIPT ||
420 preparsedElement.type === template_preparser_1.PreparsedElementType.STYLE ||
421 preparsedElement.type === template_preparser_1.PreparsedElementType.STYLESHEET) {
422 // Skipping <script> for security reasons
423 // Skipping <style> and stylesheets as we already processed them
424 // in the StyleCompiler
425 return null;
426 }
427 var children = html.visitAll(this, ast.children, null);
428 return new t.Element(ast.name, html.visitAll(this, ast.attrs),
429 /* inputs */ [], /* outputs */ [], children, /* references */ [], ast.sourceSpan, ast.startSourceSpan, ast.endSourceSpan);
430 };
431 NonBindableVisitor.prototype.visitComment = function (comment) {
432 return null;
433 };
434 NonBindableVisitor.prototype.visitAttribute = function (attribute) {
435 return new t.TextAttribute(attribute.name, attribute.value, attribute.sourceSpan, attribute.keySpan, attribute.valueSpan, attribute.i18n);
436 };
437 NonBindableVisitor.prototype.visitText = function (text) {
438 return new t.Text(text.value, text.sourceSpan);
439 };
440 NonBindableVisitor.prototype.visitExpansion = function (expansion) {
441 return null;
442 };
443 NonBindableVisitor.prototype.visitExpansionCase = function (expansionCase) {
444 return null;
445 };
446 return NonBindableVisitor;
447 }());
448 var NON_BINDABLE_VISITOR = new NonBindableVisitor();
449 function normalizeAttributeName(attrName) {
450 return /^data-/i.test(attrName) ? attrName.substring(5) : attrName;
451 }
452 function addEvents(events, boundEvents) {
453 boundEvents.push.apply(boundEvents, tslib_1.__spreadArray([], tslib_1.__read(events.map(function (e) { return t.BoundEvent.fromParsedEvent(e); }))));
454 }
455 function isEmptyTextNode(node) {
456 return node instanceof html.Text && node.value.trim().length == 0;
457 }
458 function isCommentNode(node) {
459 return node instanceof html.Comment;
460 }
461 function textContents(node) {
462 if (node.children.length !== 1 || !(node.children[0] instanceof html.Text)) {
463 return null;
464 }
465 else {
466 return node.children[0].value;
467 }
468 }
469});
470//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"r3_template_transform.js","sourceRoot":"","sources":["../../../../../../../packages/compiler/src/render3/r3_template_transform.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 {ParsedEvent, ParsedProperty, ParsedVariable} from '../expression_parser/ast';\nimport * as i18n from '../i18n/i18n_ast';\nimport * as html from '../ml_parser/ast';\nimport {replaceNgsp} from '../ml_parser/html_whitespaces';\nimport {isNgTemplate} from '../ml_parser/tags';\nimport {ParseError, ParseErrorLevel, ParseSourceSpan} from '../parse_util';\nimport {isStyleUrlResolvable} from '../style_url_resolver';\nimport {BindingParser} from '../template_parser/binding_parser';\nimport {PreparsedElementType, preparseElement} from '../template_parser/template_preparser';\n\nimport * as t from './r3_ast';\nimport {I18N_ICU_VAR_PREFIX, isI18nRootNode} from './view/i18n/util';\n\nconst BIND_NAME_REGEXP = /^(?:(bind-)|(let-)|(ref-|#)|(on-)|(bindon-)|(@))(.*)$/;\n\n// Group 1 = \"bind-\"\nconst KW_BIND_IDX = 1;\n// Group 2 = \"let-\"\nconst KW_LET_IDX = 2;\n// Group 3 = \"ref-/#\"\nconst KW_REF_IDX = 3;\n// Group 4 = \"on-\"\nconst KW_ON_IDX = 4;\n// Group 5 = \"bindon-\"\nconst KW_BINDON_IDX = 5;\n// Group 6 = \"@\"\nconst KW_AT_IDX = 6;\n// Group 7 = the identifier after \"bind-\", \"let-\", \"ref-/#\", \"on-\", \"bindon-\" or \"@\"\nconst IDENT_KW_IDX = 7;\n\nconst BINDING_DELIMS = {\n  BANANA_BOX: {start: '[(', end: ')]'},\n  PROPERTY: {start: '[', end: ']'},\n  EVENT: {start: '(', end: ')'},\n};\n\nconst TEMPLATE_ATTR_PREFIX = '*';\n\n// Result of the html AST to Ivy AST transformation\nexport interface Render3ParseResult {\n  nodes: t.Node[];\n  errors: ParseError[];\n  styles: string[];\n  styleUrls: string[];\n  ngContentSelectors: string[];\n  // Will be defined if `Render3ParseOptions['collectCommentNodes']` is true\n  commentNodes?: t.Comment[];\n}\n\ninterface Render3ParseOptions {\n  collectCommentNodes: boolean;\n}\n\nexport function htmlAstToRender3Ast(\n    htmlNodes: html.Node[], bindingParser: BindingParser,\n    options: Render3ParseOptions): Render3ParseResult {\n  const transformer = new HtmlAstToIvyAst(bindingParser, options);\n  const ivyNodes = html.visitAll(transformer, htmlNodes);\n\n  // Errors might originate in either the binding parser or the html to ivy transformer\n  const allErrors = bindingParser.errors.concat(transformer.errors);\n\n  const result: Render3ParseResult = {\n    nodes: ivyNodes,\n    errors: allErrors,\n    styleUrls: transformer.styleUrls,\n    styles: transformer.styles,\n    ngContentSelectors: transformer.ngContentSelectors\n  };\n  if (options.collectCommentNodes) {\n    result.commentNodes = transformer.commentNodes;\n  }\n  return result;\n}\n\nclass HtmlAstToIvyAst implements html.Visitor {\n  errors: ParseError[] = [];\n  styles: string[] = [];\n  styleUrls: string[] = [];\n  ngContentSelectors: string[] = [];\n  // This array will be populated if `Render3ParseOptions['collectCommentNodes']` is true\n  commentNodes: t.Comment[] = [];\n  private inI18nBlock: boolean = false;\n\n  constructor(private bindingParser: BindingParser, private options: Render3ParseOptions) {}\n\n  // HTML visitor\n  visitElement(element: html.Element): t.Node|null {\n    const isI18nRootElement = isI18nRootNode(element.i18n);\n    if (isI18nRootElement) {\n      if (this.inI18nBlock) {\n        this.reportError(\n            'Cannot mark an element as translatable inside of a translatable section. Please remove the nested i18n marker.',\n            element.sourceSpan);\n      }\n      this.inI18nBlock = true;\n    }\n    const preparsedElement = preparseElement(element);\n    if (preparsedElement.type === PreparsedElementType.SCRIPT) {\n      return null;\n    } else if (preparsedElement.type === PreparsedElementType.STYLE) {\n      const contents = textContents(element);\n      if (contents !== null) {\n        this.styles.push(contents);\n      }\n      return null;\n    } else if (\n        preparsedElement.type === PreparsedElementType.STYLESHEET &&\n        isStyleUrlResolvable(preparsedElement.hrefAttr)) {\n      this.styleUrls.push(preparsedElement.hrefAttr);\n      return null;\n    }\n\n    // Whether the element is a `<ng-template>`\n    const isTemplateElement = isNgTemplate(element.name);\n\n    const parsedProperties: ParsedProperty[] = [];\n    const boundEvents: t.BoundEvent[] = [];\n    const variables: t.Variable[] = [];\n    const references: t.Reference[] = [];\n    const attributes: t.TextAttribute[] = [];\n    const i18nAttrsMeta: {[key: string]: i18n.I18nMeta} = {};\n\n    const templateParsedProperties: ParsedProperty[] = [];\n    const templateVariables: t.Variable[] = [];\n\n    // Whether the element has any *-attribute\n    let elementHasInlineTemplate = false;\n\n    for (const attribute of element.attrs) {\n      let hasBinding = false;\n      const normalizedName = normalizeAttributeName(attribute.name);\n\n      // `*attr` defines template bindings\n      let isTemplateBinding = false;\n\n      if (attribute.i18n) {\n        i18nAttrsMeta[attribute.name] = attribute.i18n;\n      }\n\n      if (normalizedName.startsWith(TEMPLATE_ATTR_PREFIX)) {\n        // *-attributes\n        if (elementHasInlineTemplate) {\n          this.reportError(\n              `Can't have multiple template bindings on one element. Use only one attribute prefixed with *`,\n              attribute.sourceSpan);\n        }\n        isTemplateBinding = true;\n        elementHasInlineTemplate = true;\n        const templateValue = attribute.value;\n        const templateKey = normalizedName.substring(TEMPLATE_ATTR_PREFIX.length);\n\n        const parsedVariables: ParsedVariable[] = [];\n        const absoluteValueOffset = attribute.valueSpan ?\n            attribute.valueSpan.start.offset :\n            // If there is no value span the attribute does not have a value, like `attr` in\n            //`<div attr></div>`. In this case, point to one character beyond the last character of\n            // the attribute name.\n            attribute.sourceSpan.start.offset + attribute.name.length;\n\n        this.bindingParser.parseInlineTemplateBinding(\n            templateKey, templateValue, attribute.sourceSpan, absoluteValueOffset, [],\n            templateParsedProperties, parsedVariables, true /* isIvyAst */);\n        templateVariables.push(...parsedVariables.map(\n            v => new t.Variable(v.name, v.value, v.sourceSpan, v.keySpan, v.valueSpan)));\n      } else {\n        // Check for variables, events, property bindings, interpolation\n        hasBinding = this.parseAttribute(\n            isTemplateElement, attribute, [], parsedProperties, boundEvents, variables, references);\n      }\n\n      if (!hasBinding && !isTemplateBinding) {\n        // don't include the bindings as attributes as well in the AST\n        attributes.push(this.visitAttribute(attribute));\n      }\n    }\n\n    const children: t.Node[] =\n        html.visitAll(preparsedElement.nonBindable ? NON_BINDABLE_VISITOR : this, element.children);\n\n    let parsedElement: t.Node|undefined;\n    if (preparsedElement.type === PreparsedElementType.NG_CONTENT) {\n      // `<ng-content>`\n      if (element.children &&\n          !element.children.every(\n              (node: html.Node) => isEmptyTextNode(node) || isCommentNode(node))) {\n        this.reportError(`<ng-content> element cannot have content.`, element.sourceSpan);\n      }\n      const selector = preparsedElement.selectAttr;\n      const attrs: t.TextAttribute[] = element.attrs.map(attr => this.visitAttribute(attr));\n      parsedElement = new t.Content(selector, attrs, element.sourceSpan, element.i18n);\n\n      this.ngContentSelectors.push(selector);\n    } else if (isTemplateElement) {\n      // `<ng-template>`\n      const attrs = this.extractAttributes(element.name, parsedProperties, i18nAttrsMeta);\n\n      parsedElement = new t.Template(\n          element.name, attributes, attrs.bound, boundEvents, [/* no template attributes */],\n          children, references, variables, element.sourceSpan, element.startSourceSpan,\n          element.endSourceSpan, element.i18n);\n    } else {\n      const attrs = this.extractAttributes(element.name, parsedProperties, i18nAttrsMeta);\n      parsedElement = new t.Element(\n          element.name, attributes, attrs.bound, boundEvents, children, references,\n          element.sourceSpan, element.startSourceSpan, element.endSourceSpan, element.i18n);\n    }\n\n    if (elementHasInlineTemplate) {\n      // If this node is an inline-template (e.g. has *ngFor) then we need to create a template\n      // node that contains this node.\n      // Moreover, if the node is an element, then we need to hoist its attributes to the template\n      // node for matching against content projection selectors.\n      const attrs = this.extractAttributes('ng-template', templateParsedProperties, i18nAttrsMeta);\n      const templateAttrs: (t.TextAttribute|t.BoundAttribute)[] = [];\n      attrs.literal.forEach(attr => templateAttrs.push(attr));\n      attrs.bound.forEach(attr => templateAttrs.push(attr));\n      const hoistedAttrs = parsedElement instanceof t.Element ?\n          {\n            attributes: parsedElement.attributes,\n            inputs: parsedElement.inputs,\n            outputs: parsedElement.outputs,\n          } :\n          {attributes: [], inputs: [], outputs: []};\n\n      // For <ng-template>s with structural directives on them, avoid passing i18n information to\n      // the wrapping template to prevent unnecessary i18n instructions from being generated. The\n      // necessary i18n meta information will be extracted from child elements.\n      const i18n = isTemplateElement && isI18nRootElement ? undefined : element.i18n;\n\n      // TODO(pk): test for this case\n      parsedElement = new t.Template(\n          (parsedElement as t.Element | t.Content).name, hoistedAttrs.attributes,\n          hoistedAttrs.inputs, hoistedAttrs.outputs, templateAttrs, [parsedElement],\n          [/* no references */], templateVariables, element.sourceSpan, element.startSourceSpan,\n          element.endSourceSpan, i18n);\n    }\n    if (isI18nRootElement) {\n      this.inI18nBlock = false;\n    }\n    return parsedElement;\n  }\n\n  visitAttribute(attribute: html.Attribute): t.TextAttribute {\n    return new t.TextAttribute(\n        attribute.name, attribute.value, attribute.sourceSpan, attribute.keySpan,\n        attribute.valueSpan, attribute.i18n);\n  }\n\n  visitText(text: html.Text): t.Node {\n    return this._visitTextWithInterpolation(text.value, text.sourceSpan, text.i18n);\n  }\n\n  visitExpansion(expansion: html.Expansion): t.Icu|null {\n    if (!expansion.i18n) {\n      // do not generate Icu in case it was created\n      // outside of i18n block in a template\n      return null;\n    }\n    if (!isI18nRootNode(expansion.i18n)) {\n      throw new Error(`Invalid type \"${expansion.i18n.constructor}\" for \"i18n\" property of ${\n          expansion.sourceSpan.toString()}. Expected a \"Message\"`);\n    }\n    const message = expansion.i18n;\n    const vars: {[name: string]: t.BoundText} = {};\n    const placeholders: {[name: string]: t.Text|t.BoundText} = {};\n    // extract VARs from ICUs - we process them separately while\n    // assembling resulting message via goog.getMsg function, since\n    // we need to pass them to top-level goog.getMsg call\n    Object.keys(message.placeholders).forEach(key => {\n      const value = message.placeholders[key];\n      if (key.startsWith(I18N_ICU_VAR_PREFIX)) {\n        // Currently when the `plural` or `select` keywords in an ICU contain trailing spaces (e.g.\n        // `{count, select , ...}`), these spaces are also included into the key names in ICU vars\n        // (e.g. \"VAR_SELECT \"). These trailing spaces are not desirable, since they will later be\n        // converted into `_` symbols while normalizing placeholder names, which might lead to\n        // mismatches at runtime (i.e. placeholder will not be replaced with the correct value).\n        const formattedKey = key.trim();\n\n        const ast = this.bindingParser.parseInterpolationExpression(value.text, value.sourceSpan);\n\n        vars[formattedKey] = new t.BoundText(ast, value.sourceSpan);\n      } else {\n        placeholders[key] = this._visitTextWithInterpolation(value.text, value.sourceSpan);\n      }\n    });\n    return new t.Icu(vars, placeholders, expansion.sourceSpan, message);\n  }\n\n  visitExpansionCase(expansionCase: html.ExpansionCase): null {\n    return null;\n  }\n\n  visitComment(comment: html.Comment): null {\n    if (this.options.collectCommentNodes) {\n      this.commentNodes.push(new t.Comment(comment.value || '', comment.sourceSpan));\n    }\n    return null;\n  }\n\n  // convert view engine `ParsedProperty` to a format suitable for IVY\n  private extractAttributes(\n      elementName: string, properties: ParsedProperty[],\n      i18nPropsMeta: {[key: string]: i18n.I18nMeta}):\n      {bound: t.BoundAttribute[], literal: t.TextAttribute[]} {\n    const bound: t.BoundAttribute[] = [];\n    const literal: t.TextAttribute[] = [];\n\n    properties.forEach(prop => {\n      const i18n = i18nPropsMeta[prop.name];\n      if (prop.isLiteral) {\n        literal.push(new t.TextAttribute(\n            prop.name, prop.expression.source || '', prop.sourceSpan, prop.keySpan, prop.valueSpan,\n            i18n));\n      } else {\n        // Note that validation is skipped and property mapping is disabled\n        // due to the fact that we need to make sure a given prop is not an\n        // input of a directive and directive matching happens at runtime.\n        const bep = this.bindingParser.createBoundElementProperty(\n            elementName, prop, /* skipValidation */ true, /* mapPropertyName */ false);\n        bound.push(t.BoundAttribute.fromBoundElementProperty(bep, i18n));\n      }\n    });\n\n    return {bound, literal};\n  }\n\n  private parseAttribute(\n      isTemplateElement: boolean, attribute: html.Attribute, matchableAttributes: string[][],\n      parsedProperties: ParsedProperty[], boundEvents: t.BoundEvent[], variables: t.Variable[],\n      references: t.Reference[]) {\n    const name = normalizeAttributeName(attribute.name);\n    const value = attribute.value;\n    const srcSpan = attribute.sourceSpan;\n    const absoluteOffset =\n        attribute.valueSpan ? attribute.valueSpan.start.offset : srcSpan.start.offset;\n\n    function createKeySpan(srcSpan: ParseSourceSpan, prefix: string, identifier: string) {\n      // We need to adjust the start location for the keySpan to account for the removed 'data-'\n      // prefix from `normalizeAttributeName`.\n      const normalizationAdjustment = attribute.name.length - name.length;\n      const keySpanStart = srcSpan.start.moveBy(prefix.length + normalizationAdjustment);\n      const keySpanEnd = keySpanStart.moveBy(identifier.length);\n      return new ParseSourceSpan(keySpanStart, keySpanEnd, keySpanStart, identifier);\n    }\n\n    const bindParts = name.match(BIND_NAME_REGEXP);\n\n    if (bindParts) {\n      if (bindParts[KW_BIND_IDX] != null) {\n        const identifier = bindParts[IDENT_KW_IDX];\n        const keySpan = createKeySpan(srcSpan, bindParts[KW_BIND_IDX], identifier);\n        this.bindingParser.parsePropertyBinding(\n            identifier, value, false, srcSpan, absoluteOffset, attribute.valueSpan,\n            matchableAttributes, parsedProperties, keySpan);\n\n      } else if (bindParts[KW_LET_IDX]) {\n        if (isTemplateElement) {\n          const identifier = bindParts[IDENT_KW_IDX];\n          const keySpan = createKeySpan(srcSpan, bindParts[KW_LET_IDX], identifier);\n          this.parseVariable(identifier, value, srcSpan, keySpan, attribute.valueSpan, variables);\n        } else {\n          this.reportError(`\"let-\" is only supported on ng-template elements.`, srcSpan);\n        }\n\n      } else if (bindParts[KW_REF_IDX]) {\n        const identifier = bindParts[IDENT_KW_IDX];\n        const keySpan = createKeySpan(srcSpan, bindParts[KW_REF_IDX], identifier);\n        this.parseReference(identifier, value, srcSpan, keySpan, attribute.valueSpan, references);\n      } else if (bindParts[KW_ON_IDX]) {\n        const events: ParsedEvent[] = [];\n        const identifier = bindParts[IDENT_KW_IDX];\n        const keySpan = createKeySpan(srcSpan, bindParts[KW_ON_IDX], identifier);\n        this.bindingParser.parseEvent(\n            identifier, value, srcSpan, attribute.valueSpan || srcSpan, matchableAttributes, events,\n            keySpan);\n        addEvents(events, boundEvents);\n      } else if (bindParts[KW_BINDON_IDX]) {\n        const identifier = bindParts[IDENT_KW_IDX];\n        const keySpan = createKeySpan(srcSpan, bindParts[KW_BINDON_IDX], identifier);\n        this.bindingParser.parsePropertyBinding(\n            identifier, value, false, srcSpan, absoluteOffset, attribute.valueSpan,\n            matchableAttributes, parsedProperties, keySpan);\n        this.parseAssignmentEvent(\n            identifier, value, srcSpan, attribute.valueSpan, matchableAttributes, boundEvents,\n            keySpan);\n      } else if (bindParts[KW_AT_IDX]) {\n        const keySpan = createKeySpan(srcSpan, '', name);\n        this.bindingParser.parseLiteralAttr(\n            name, value, srcSpan, absoluteOffset, attribute.valueSpan, matchableAttributes,\n            parsedProperties, keySpan);\n      }\n      return true;\n    }\n\n    // We didn't see a kw-prefixed property binding, but we have not yet checked\n    // for the []/()/[()] syntax.\n    let delims: {start: string, end: string}|null = null;\n    if (name.startsWith(BINDING_DELIMS.BANANA_BOX.start)) {\n      delims = BINDING_DELIMS.BANANA_BOX;\n    } else if (name.startsWith(BINDING_DELIMS.PROPERTY.start)) {\n      delims = BINDING_DELIMS.PROPERTY;\n    } else if (name.startsWith(BINDING_DELIMS.EVENT.start)) {\n      delims = BINDING_DELIMS.EVENT;\n    }\n    if (delims !== null &&\n        // NOTE: older versions of the parser would match a start/end delimited\n        // binding iff the property name was terminated by the ending delimiter\n        // and the identifier in the binding was non-empty.\n        // TODO(ayazhafiz): update this to handle malformed bindings.\n        name.endsWith(delims.end) && name.length > delims.start.length + delims.end.length) {\n      const identifier = name.substring(delims.start.length, name.length - delims.end.length);\n      const keySpan = createKeySpan(srcSpan, delims.start, identifier);\n      if (delims.start === BINDING_DELIMS.BANANA_BOX.start) {\n        this.bindingParser.parsePropertyBinding(\n            identifier, value, false, srcSpan, absoluteOffset, attribute.valueSpan,\n            matchableAttributes, parsedProperties, keySpan);\n        this.parseAssignmentEvent(\n            identifier, value, srcSpan, attribute.valueSpan, matchableAttributes, boundEvents,\n            keySpan);\n      } else if (delims.start === BINDING_DELIMS.PROPERTY.start) {\n        this.bindingParser.parsePropertyBinding(\n            identifier, value, false, srcSpan, absoluteOffset, attribute.valueSpan,\n            matchableAttributes, parsedProperties, keySpan);\n      } else {\n        const events: ParsedEvent[] = [];\n        this.bindingParser.parseEvent(\n            identifier, value, srcSpan, attribute.valueSpan || srcSpan, matchableAttributes, events,\n            keySpan);\n        addEvents(events, boundEvents);\n      }\n\n      return true;\n    }\n\n    // No explicit binding found.\n    const keySpan = createKeySpan(srcSpan, '' /* prefix */, name);\n    const hasBinding = this.bindingParser.parsePropertyInterpolation(\n        name, value, srcSpan, attribute.valueSpan, matchableAttributes, parsedProperties, keySpan);\n    return hasBinding;\n  }\n\n  private _visitTextWithInterpolation(\n      value: string, sourceSpan: ParseSourceSpan, i18n?: i18n.I18nMeta): t.Text|t.BoundText {\n    const valueNoNgsp = replaceNgsp(value);\n    const expr = this.bindingParser.parseInterpolation(valueNoNgsp, sourceSpan);\n    return expr ? new t.BoundText(expr, sourceSpan, i18n) : new t.Text(valueNoNgsp, sourceSpan);\n  }\n\n  private parseVariable(\n      identifier: string, value: string, sourceSpan: ParseSourceSpan, keySpan: ParseSourceSpan,\n      valueSpan: ParseSourceSpan|undefined, variables: t.Variable[]) {\n    if (identifier.indexOf('-') > -1) {\n      this.reportError(`\"-\" is not allowed in variable names`, sourceSpan);\n    } else if (identifier.length === 0) {\n      this.reportError(`Variable does not have a name`, sourceSpan);\n    }\n\n    variables.push(new t.Variable(identifier, value, sourceSpan, keySpan, valueSpan));\n  }\n\n  private parseReference(\n      identifier: string, value: string, sourceSpan: ParseSourceSpan, keySpan: ParseSourceSpan,\n      valueSpan: ParseSourceSpan|undefined, references: t.Reference[]) {\n    if (identifier.indexOf('-') > -1) {\n      this.reportError(`\"-\" is not allowed in reference names`, sourceSpan);\n    } else if (identifier.length === 0) {\n      this.reportError(`Reference does not have a name`, sourceSpan);\n    } else if (references.some(reference => reference.name === identifier)) {\n      this.reportError(`Reference \"#${identifier}\" is defined more than once`, sourceSpan);\n    }\n\n    references.push(new t.Reference(identifier, value, sourceSpan, keySpan, valueSpan));\n  }\n\n  private parseAssignmentEvent(\n      name: string, expression: string, sourceSpan: ParseSourceSpan,\n      valueSpan: ParseSourceSpan|undefined, targetMatchableAttrs: string[][],\n      boundEvents: t.BoundEvent[], keySpan: ParseSourceSpan) {\n    const events: ParsedEvent[] = [];\n    this.bindingParser.parseEvent(\n        `${name}Change`, `${expression}=$event`, sourceSpan, valueSpan || sourceSpan,\n        targetMatchableAttrs, events, keySpan);\n    addEvents(events, boundEvents);\n  }\n\n  private reportError(\n      message: string, sourceSpan: ParseSourceSpan,\n      level: ParseErrorLevel = ParseErrorLevel.ERROR) {\n    this.errors.push(new ParseError(sourceSpan, message, level));\n  }\n}\n\nclass NonBindableVisitor implements html.Visitor {\n  visitElement(ast: html.Element): t.Element|null {\n    const preparsedElement = preparseElement(ast);\n    if (preparsedElement.type === PreparsedElementType.SCRIPT ||\n        preparsedElement.type === PreparsedElementType.STYLE ||\n        preparsedElement.type === PreparsedElementType.STYLESHEET) {\n      // Skipping <script> for security reasons\n      // Skipping <style> and stylesheets as we already processed them\n      // in the StyleCompiler\n      return null;\n    }\n\n    const children: t.Node[] = html.visitAll(this, ast.children, null);\n    return new t.Element(\n        ast.name, html.visitAll(this, ast.attrs) as t.TextAttribute[],\n        /* inputs */[], /* outputs */[], children,  /* references */[], ast.sourceSpan,\n        ast.startSourceSpan, ast.endSourceSpan);\n  }\n\n  visitComment(comment: html.Comment): any {\n    return null;\n  }\n\n  visitAttribute(attribute: html.Attribute): t.TextAttribute {\n    return new t.TextAttribute(\n        attribute.name, attribute.value, attribute.sourceSpan, attribute.keySpan,\n        attribute.valueSpan, attribute.i18n);\n  }\n\n  visitText(text: html.Text): t.Text {\n    return new t.Text(text.value, text.sourceSpan);\n  }\n\n  visitExpansion(expansion: html.Expansion): any {\n    return null;\n  }\n\n  visitExpansionCase(expansionCase: html.ExpansionCase): any {\n    return null;\n  }\n}\n\nconst NON_BINDABLE_VISITOR = new NonBindableVisitor();\n\nfunction normalizeAttributeName(attrName: string): string {\n  return /^data-/i.test(attrName) ? attrName.substring(5) : attrName;\n}\n\nfunction addEvents(events: ParsedEvent[], boundEvents: t.BoundEvent[]) {\n  boundEvents.push(...events.map(e => t.BoundEvent.fromParsedEvent(e)));\n}\n\nfunction isEmptyTextNode(node: html.Node): boolean {\n  return node instanceof html.Text && node.value.trim().length == 0;\n}\n\nfunction isCommentNode(node: html.Node): boolean {\n  return node instanceof html.Comment;\n}\n\nfunction textContents(node: html.Element): string|null {\n  if (node.children.length !== 1 || !(node.children[0] instanceof html.Text)) {\n    return null;\n  } else {\n    return (node.children[0] as html.Text).value;\n  }\n}\n"]}
Note: See TracBrowser for help on using the repository browser.