source: trip-planner-front/node_modules/@angular/compiler/src/render3/view/styling_builder.js

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

initial commit

  • Property mode set to 100644
File size: 70.9 KB
Line 
1(function (factory) {
2 if (typeof module === "object" && typeof module.exports === "object") {
3 var v = factory(require, exports);
4 if (v !== undefined) module.exports = v;
5 }
6 else if (typeof define === "function" && define.amd) {
7 define("@angular/compiler/src/render3/view/styling_builder", ["require", "exports", "tslib", "@angular/compiler/src/expression_parser/ast", "@angular/compiler/src/output/output_ast", "@angular/compiler/src/template_parser/template_parser", "@angular/compiler/src/render3/r3_identifiers", "@angular/compiler/src/render3/view/style_parser", "@angular/compiler/src/render3/view/util"], factory);
8 }
9})(function (require, exports) {
10 "use strict";
11 Object.defineProperty(exports, "__esModule", { value: true });
12 exports.parseProperty = exports.StylingBuilder = exports.MIN_STYLING_BINDING_SLOTS_REQUIRED = void 0;
13 var tslib_1 = require("tslib");
14 var ast_1 = require("@angular/compiler/src/expression_parser/ast");
15 var o = require("@angular/compiler/src/output/output_ast");
16 var template_parser_1 = require("@angular/compiler/src/template_parser/template_parser");
17 var r3_identifiers_1 = require("@angular/compiler/src/render3/r3_identifiers");
18 var style_parser_1 = require("@angular/compiler/src/render3/view/style_parser");
19 var util_1 = require("@angular/compiler/src/render3/view/util");
20 var IMPORTANT_FLAG = '!important';
21 /**
22 * Minimum amount of binding slots required in the runtime for style/class bindings.
23 *
24 * Styling in Angular uses up two slots in the runtime LView/TData data structures to
25 * record binding data, property information and metadata.
26 *
27 * When a binding is registered it will place the following information in the `LView`:
28 *
29 * slot 1) binding value
30 * slot 2) cached value (all other values collected before it in string form)
31 *
32 * When a binding is registered it will place the following information in the `TData`:
33 *
34 * slot 1) prop name
35 * slot 2) binding index that points to the previous style/class binding (and some extra config
36 * values)
37 *
38 * Let's imagine we have a binding that looks like so:
39 *
40 * ```
41 * <div [style.width]="x" [style.height]="y">
42 * ```
43 *
44 * Our `LView` and `TData` data-structures look like so:
45 *
46 * ```typescript
47 * LView = [
48 * // ...
49 * x, // value of x
50 * "width: x",
51 *
52 * y, // value of y
53 * "width: x; height: y",
54 * // ...
55 * ];
56 *
57 * TData = [
58 * // ...
59 * "width", // binding slot 20
60 * 0,
61 *
62 * "height",
63 * 20,
64 * // ...
65 * ];
66 * ```
67 *
68 * */
69 exports.MIN_STYLING_BINDING_SLOTS_REQUIRED = 2;
70 /**
71 * Produces creation/update instructions for all styling bindings (class and style)
72 *
73 * It also produces the creation instruction to register all initial styling values
74 * (which are all the static class="..." and style="..." attribute values that exist
75 * on an element within a template).
76 *
77 * The builder class below handles producing instructions for the following cases:
78 *
79 * - Static style/class attributes (style="..." and class="...")
80 * - Dynamic style/class map bindings ([style]="map" and [class]="map|string")
81 * - Dynamic style/class property bindings ([style.prop]="exp" and [class.name]="exp")
82 *
83 * Due to the complex relationship of all of these cases, the instructions generated
84 * for these attributes/properties/bindings must be done so in the correct order. The
85 * order which these must be generated is as follows:
86 *
87 * if (createMode) {
88 * styling(...)
89 * }
90 * if (updateMode) {
91 * styleMap(...)
92 * classMap(...)
93 * styleProp(...)
94 * classProp(...)
95 * }
96 *
97 * The creation/update methods within the builder class produce these instructions.
98 */
99 var StylingBuilder = /** @class */ (function () {
100 function StylingBuilder(_directiveExpr) {
101 this._directiveExpr = _directiveExpr;
102 /** Whether or not there are any static styling values present */
103 this._hasInitialValues = false;
104 /**
105 * Whether or not there are any styling bindings present
106 * (i.e. `[style]`, `[class]`, `[style.prop]` or `[class.name]`)
107 */
108 this.hasBindings = false;
109 this.hasBindingsWithPipes = false;
110 /** the input for [class] (if it exists) */
111 this._classMapInput = null;
112 /** the input for [style] (if it exists) */
113 this._styleMapInput = null;
114 /** an array of each [style.prop] input */
115 this._singleStyleInputs = null;
116 /** an array of each [class.name] input */
117 this._singleClassInputs = null;
118 this._lastStylingInput = null;
119 this._firstStylingInput = null;
120 // maps are used instead of hash maps because a Map will
121 // retain the ordering of the keys
122 /**
123 * Represents the location of each style binding in the template
124 * (e.g. `<div [style.width]="w" [style.height]="h">` implies
125 * that `width=0` and `height=1`)
126 */
127 this._stylesIndex = new Map();
128 /**
129 * Represents the location of each class binding in the template
130 * (e.g. `<div [class.big]="b" [class.hidden]="h">` implies
131 * that `big=0` and `hidden=1`)
132 */
133 this._classesIndex = new Map();
134 this._initialStyleValues = [];
135 this._initialClassValues = [];
136 }
137 /**
138 * Registers a given input to the styling builder to be later used when producing AOT code.
139 *
140 * The code below will only accept the input if it is somehow tied to styling (whether it be
141 * style/class bindings or static style/class attributes).
142 */
143 StylingBuilder.prototype.registerBoundInput = function (input) {
144 // [attr.style] or [attr.class] are skipped in the code below,
145 // they should not be treated as styling-based bindings since
146 // they are intended to be written directly to the attr and
147 // will therefore skip all style/class resolution that is present
148 // with style="", [style]="" and [style.prop]="", class="",
149 // [class.prop]="". [class]="" assignments
150 var binding = null;
151 var name = input.name;
152 switch (input.type) {
153 case 0 /* Property */:
154 binding = this.registerInputBasedOnName(name, input.value, input.sourceSpan);
155 break;
156 case 3 /* Style */:
157 binding = this.registerStyleInput(name, false, input.value, input.sourceSpan, input.unit);
158 break;
159 case 2 /* Class */:
160 binding = this.registerClassInput(name, false, input.value, input.sourceSpan);
161 break;
162 }
163 return binding ? true : false;
164 };
165 StylingBuilder.prototype.registerInputBasedOnName = function (name, expression, sourceSpan) {
166 var binding = null;
167 var prefix = name.substring(0, 6);
168 var isStyle = name === 'style' || prefix === 'style.' || prefix === 'style!';
169 var isClass = !isStyle && (name === 'class' || prefix === 'class.' || prefix === 'class!');
170 if (isStyle || isClass) {
171 var isMapBased = name.charAt(5) !== '.'; // style.prop or class.prop makes this a no
172 var property = name.substr(isMapBased ? 5 : 6); // the dot explains why there's a +1
173 if (isStyle) {
174 binding = this.registerStyleInput(property, isMapBased, expression, sourceSpan);
175 }
176 else {
177 binding = this.registerClassInput(property, isMapBased, expression, sourceSpan);
178 }
179 }
180 return binding;
181 };
182 StylingBuilder.prototype.registerStyleInput = function (name, isMapBased, value, sourceSpan, suffix) {
183 if (template_parser_1.isEmptyExpression(value)) {
184 return null;
185 }
186 // CSS custom properties are case-sensitive so we shouldn't normalize them.
187 // See: https://www.w3.org/TR/css-variables-1/#defining-variables
188 if (!isCssCustomProperty(name)) {
189 name = style_parser_1.hyphenate(name);
190 }
191 var _a = parseProperty(name), property = _a.property, hasOverrideFlag = _a.hasOverrideFlag, bindingSuffix = _a.suffix;
192 suffix = typeof suffix === 'string' && suffix.length !== 0 ? suffix : bindingSuffix;
193 var entry = { name: property, suffix: suffix, value: value, sourceSpan: sourceSpan, hasOverrideFlag: hasOverrideFlag };
194 if (isMapBased) {
195 this._styleMapInput = entry;
196 }
197 else {
198 (this._singleStyleInputs = this._singleStyleInputs || []).push(entry);
199 registerIntoMap(this._stylesIndex, property);
200 }
201 this._lastStylingInput = entry;
202 this._firstStylingInput = this._firstStylingInput || entry;
203 this._checkForPipes(value);
204 this.hasBindings = true;
205 return entry;
206 };
207 StylingBuilder.prototype.registerClassInput = function (name, isMapBased, value, sourceSpan) {
208 if (template_parser_1.isEmptyExpression(value)) {
209 return null;
210 }
211 var _a = parseProperty(name), property = _a.property, hasOverrideFlag = _a.hasOverrideFlag;
212 var entry = { name: property, value: value, sourceSpan: sourceSpan, hasOverrideFlag: hasOverrideFlag, suffix: null };
213 if (isMapBased) {
214 this._classMapInput = entry;
215 }
216 else {
217 (this._singleClassInputs = this._singleClassInputs || []).push(entry);
218 registerIntoMap(this._classesIndex, property);
219 }
220 this._lastStylingInput = entry;
221 this._firstStylingInput = this._firstStylingInput || entry;
222 this._checkForPipes(value);
223 this.hasBindings = true;
224 return entry;
225 };
226 StylingBuilder.prototype._checkForPipes = function (value) {
227 if ((value instanceof ast_1.ASTWithSource) && (value.ast instanceof ast_1.BindingPipe)) {
228 this.hasBindingsWithPipes = true;
229 }
230 };
231 /**
232 * Registers the element's static style string value to the builder.
233 *
234 * @param value the style string (e.g. `width:100px; height:200px;`)
235 */
236 StylingBuilder.prototype.registerStyleAttr = function (value) {
237 this._initialStyleValues = style_parser_1.parse(value);
238 this._hasInitialValues = true;
239 };
240 /**
241 * Registers the element's static class string value to the builder.
242 *
243 * @param value the className string (e.g. `disabled gold zoom`)
244 */
245 StylingBuilder.prototype.registerClassAttr = function (value) {
246 this._initialClassValues = value.trim().split(/\s+/g);
247 this._hasInitialValues = true;
248 };
249 /**
250 * Appends all styling-related expressions to the provided attrs array.
251 *
252 * @param attrs an existing array where each of the styling expressions
253 * will be inserted into.
254 */
255 StylingBuilder.prototype.populateInitialStylingAttrs = function (attrs) {
256 // [CLASS_MARKER, 'foo', 'bar', 'baz' ...]
257 if (this._initialClassValues.length) {
258 attrs.push(o.literal(1 /* Classes */));
259 for (var i = 0; i < this._initialClassValues.length; i++) {
260 attrs.push(o.literal(this._initialClassValues[i]));
261 }
262 }
263 // [STYLE_MARKER, 'width', '200px', 'height', '100px', ...]
264 if (this._initialStyleValues.length) {
265 attrs.push(o.literal(2 /* Styles */));
266 for (var i = 0; i < this._initialStyleValues.length; i += 2) {
267 attrs.push(o.literal(this._initialStyleValues[i]), o.literal(this._initialStyleValues[i + 1]));
268 }
269 }
270 };
271 /**
272 * Builds an instruction with all the expressions and parameters for `elementHostAttrs`.
273 *
274 * The instruction generation code below is used for producing the AOT statement code which is
275 * responsible for registering initial styles (within a directive hostBindings' creation block),
276 * as well as any of the provided attribute values, to the directive host element.
277 */
278 StylingBuilder.prototype.assignHostAttrs = function (attrs, definitionMap) {
279 if (this._directiveExpr && (attrs.length || this._hasInitialValues)) {
280 this.populateInitialStylingAttrs(attrs);
281 definitionMap.set('hostAttrs', o.literalArr(attrs));
282 }
283 };
284 /**
285 * Builds an instruction with all the expressions and parameters for `classMap`.
286 *
287 * The instruction data will contain all expressions for `classMap` to function
288 * which includes the `[class]` expression params.
289 */
290 StylingBuilder.prototype.buildClassMapInstruction = function (valueConverter) {
291 if (this._classMapInput) {
292 return this._buildMapBasedInstruction(valueConverter, true, this._classMapInput);
293 }
294 return null;
295 };
296 /**
297 * Builds an instruction with all the expressions and parameters for `styleMap`.
298 *
299 * The instruction data will contain all expressions for `styleMap` to function
300 * which includes the `[style]` expression params.
301 */
302 StylingBuilder.prototype.buildStyleMapInstruction = function (valueConverter) {
303 if (this._styleMapInput) {
304 return this._buildMapBasedInstruction(valueConverter, false, this._styleMapInput);
305 }
306 return null;
307 };
308 StylingBuilder.prototype._buildMapBasedInstruction = function (valueConverter, isClassBased, stylingInput) {
309 // each styling binding value is stored in the LView
310 // map-based bindings allocate two slots: one for the
311 // previous binding value and another for the previous
312 // className or style attribute value.
313 var totalBindingSlotsRequired = exports.MIN_STYLING_BINDING_SLOTS_REQUIRED;
314 // these values must be outside of the update block so that they can
315 // be evaluated (the AST visit call) during creation time so that any
316 // pipes can be picked up in time before the template is built
317 var mapValue = stylingInput.value.visit(valueConverter);
318 var reference;
319 if (mapValue instanceof ast_1.Interpolation) {
320 totalBindingSlotsRequired += mapValue.expressions.length;
321 reference = isClassBased ? getClassMapInterpolationExpression(mapValue) :
322 getStyleMapInterpolationExpression(mapValue);
323 }
324 else {
325 reference = isClassBased ? r3_identifiers_1.Identifiers.classMap : r3_identifiers_1.Identifiers.styleMap;
326 }
327 return {
328 reference: reference,
329 calls: [{
330 supportsInterpolation: true,
331 sourceSpan: stylingInput.sourceSpan,
332 allocateBindingSlots: totalBindingSlotsRequired,
333 params: function (convertFn) {
334 var convertResult = convertFn(mapValue);
335 var params = Array.isArray(convertResult) ? convertResult : [convertResult];
336 return params;
337 }
338 }]
339 };
340 };
341 StylingBuilder.prototype._buildSingleInputs = function (reference, inputs, valueConverter, getInterpolationExpressionFn, isClassBased) {
342 var instructions = [];
343 inputs.forEach(function (input) {
344 var previousInstruction = instructions[instructions.length - 1];
345 var value = input.value.visit(valueConverter);
346 var referenceForCall = reference;
347 // each styling binding value is stored in the LView
348 // but there are two values stored for each binding:
349 // 1) the value itself
350 // 2) an intermediate value (concatenation of style up to this point).
351 // We need to store the intermediate value so that we don't allocate
352 // the strings on each CD.
353 var totalBindingSlotsRequired = exports.MIN_STYLING_BINDING_SLOTS_REQUIRED;
354 if (value instanceof ast_1.Interpolation) {
355 totalBindingSlotsRequired += value.expressions.length;
356 if (getInterpolationExpressionFn) {
357 referenceForCall = getInterpolationExpressionFn(value);
358 }
359 }
360 var call = {
361 sourceSpan: input.sourceSpan,
362 allocateBindingSlots: totalBindingSlotsRequired,
363 supportsInterpolation: !!getInterpolationExpressionFn,
364 params: function (convertFn) {
365 // params => stylingProp(propName, value, suffix)
366 var params = [];
367 params.push(o.literal(input.name));
368 var convertResult = convertFn(value);
369 if (Array.isArray(convertResult)) {
370 params.push.apply(params, tslib_1.__spreadArray([], tslib_1.__read(convertResult)));
371 }
372 else {
373 params.push(convertResult);
374 }
375 // [style.prop] bindings may use suffix values (e.g. px, em, etc...), therefore,
376 // if that is detected then we need to pass that in as an optional param.
377 if (!isClassBased && input.suffix !== null) {
378 params.push(o.literal(input.suffix));
379 }
380 return params;
381 }
382 };
383 // If we ended up generating a call to the same instruction as the previous styling property
384 // we can chain the calls together safely to save some bytes, otherwise we have to generate
385 // a separate instruction call. This is primarily a concern with interpolation instructions
386 // where we may start off with one `reference`, but end up using another based on the
387 // number of interpolations.
388 if (previousInstruction && previousInstruction.reference === referenceForCall) {
389 previousInstruction.calls.push(call);
390 }
391 else {
392 instructions.push({ reference: referenceForCall, calls: [call] });
393 }
394 });
395 return instructions;
396 };
397 StylingBuilder.prototype._buildClassInputs = function (valueConverter) {
398 if (this._singleClassInputs) {
399 return this._buildSingleInputs(r3_identifiers_1.Identifiers.classProp, this._singleClassInputs, valueConverter, null, true);
400 }
401 return [];
402 };
403 StylingBuilder.prototype._buildStyleInputs = function (valueConverter) {
404 if (this._singleStyleInputs) {
405 return this._buildSingleInputs(r3_identifiers_1.Identifiers.styleProp, this._singleStyleInputs, valueConverter, getStylePropInterpolationExpression, false);
406 }
407 return [];
408 };
409 /**
410 * Constructs all instructions which contain the expressions that will be placed
411 * into the update block of a template function or a directive hostBindings function.
412 */
413 StylingBuilder.prototype.buildUpdateLevelInstructions = function (valueConverter) {
414 var instructions = [];
415 if (this.hasBindings) {
416 var styleMapInstruction = this.buildStyleMapInstruction(valueConverter);
417 if (styleMapInstruction) {
418 instructions.push(styleMapInstruction);
419 }
420 var classMapInstruction = this.buildClassMapInstruction(valueConverter);
421 if (classMapInstruction) {
422 instructions.push(classMapInstruction);
423 }
424 instructions.push.apply(instructions, tslib_1.__spreadArray([], tslib_1.__read(this._buildStyleInputs(valueConverter))));
425 instructions.push.apply(instructions, tslib_1.__spreadArray([], tslib_1.__read(this._buildClassInputs(valueConverter))));
426 }
427 return instructions;
428 };
429 return StylingBuilder;
430 }());
431 exports.StylingBuilder = StylingBuilder;
432 function registerIntoMap(map, key) {
433 if (!map.has(key)) {
434 map.set(key, map.size);
435 }
436 }
437 function parseProperty(name) {
438 var hasOverrideFlag = false;
439 var overrideIndex = name.indexOf(IMPORTANT_FLAG);
440 if (overrideIndex !== -1) {
441 name = overrideIndex > 0 ? name.substring(0, overrideIndex) : '';
442 hasOverrideFlag = true;
443 }
444 var suffix = null;
445 var property = name;
446 var unitIndex = name.lastIndexOf('.');
447 if (unitIndex > 0) {
448 suffix = name.substr(unitIndex + 1);
449 property = name.substring(0, unitIndex);
450 }
451 return { property: property, suffix: suffix, hasOverrideFlag: hasOverrideFlag };
452 }
453 exports.parseProperty = parseProperty;
454 /**
455 * Gets the instruction to generate for an interpolated class map.
456 * @param interpolation An Interpolation AST
457 */
458 function getClassMapInterpolationExpression(interpolation) {
459 switch (util_1.getInterpolationArgsLength(interpolation)) {
460 case 1:
461 return r3_identifiers_1.Identifiers.classMap;
462 case 3:
463 return r3_identifiers_1.Identifiers.classMapInterpolate1;
464 case 5:
465 return r3_identifiers_1.Identifiers.classMapInterpolate2;
466 case 7:
467 return r3_identifiers_1.Identifiers.classMapInterpolate3;
468 case 9:
469 return r3_identifiers_1.Identifiers.classMapInterpolate4;
470 case 11:
471 return r3_identifiers_1.Identifiers.classMapInterpolate5;
472 case 13:
473 return r3_identifiers_1.Identifiers.classMapInterpolate6;
474 case 15:
475 return r3_identifiers_1.Identifiers.classMapInterpolate7;
476 case 17:
477 return r3_identifiers_1.Identifiers.classMapInterpolate8;
478 default:
479 return r3_identifiers_1.Identifiers.classMapInterpolateV;
480 }
481 }
482 /**
483 * Gets the instruction to generate for an interpolated style map.
484 * @param interpolation An Interpolation AST
485 */
486 function getStyleMapInterpolationExpression(interpolation) {
487 switch (util_1.getInterpolationArgsLength(interpolation)) {
488 case 1:
489 return r3_identifiers_1.Identifiers.styleMap;
490 case 3:
491 return r3_identifiers_1.Identifiers.styleMapInterpolate1;
492 case 5:
493 return r3_identifiers_1.Identifiers.styleMapInterpolate2;
494 case 7:
495 return r3_identifiers_1.Identifiers.styleMapInterpolate3;
496 case 9:
497 return r3_identifiers_1.Identifiers.styleMapInterpolate4;
498 case 11:
499 return r3_identifiers_1.Identifiers.styleMapInterpolate5;
500 case 13:
501 return r3_identifiers_1.Identifiers.styleMapInterpolate6;
502 case 15:
503 return r3_identifiers_1.Identifiers.styleMapInterpolate7;
504 case 17:
505 return r3_identifiers_1.Identifiers.styleMapInterpolate8;
506 default:
507 return r3_identifiers_1.Identifiers.styleMapInterpolateV;
508 }
509 }
510 /**
511 * Gets the instruction to generate for an interpolated style prop.
512 * @param interpolation An Interpolation AST
513 */
514 function getStylePropInterpolationExpression(interpolation) {
515 switch (util_1.getInterpolationArgsLength(interpolation)) {
516 case 1:
517 return r3_identifiers_1.Identifiers.styleProp;
518 case 3:
519 return r3_identifiers_1.Identifiers.stylePropInterpolate1;
520 case 5:
521 return r3_identifiers_1.Identifiers.stylePropInterpolate2;
522 case 7:
523 return r3_identifiers_1.Identifiers.stylePropInterpolate3;
524 case 9:
525 return r3_identifiers_1.Identifiers.stylePropInterpolate4;
526 case 11:
527 return r3_identifiers_1.Identifiers.stylePropInterpolate5;
528 case 13:
529 return r3_identifiers_1.Identifiers.stylePropInterpolate6;
530 case 15:
531 return r3_identifiers_1.Identifiers.stylePropInterpolate7;
532 case 17:
533 return r3_identifiers_1.Identifiers.stylePropInterpolate8;
534 default:
535 return r3_identifiers_1.Identifiers.stylePropInterpolateV;
536 }
537 }
538 /**
539 * Checks whether property name is a custom CSS property.
540 * See: https://www.w3.org/TR/css-variables-1
541 */
542 function isCssCustomProperty(name) {
543 return name.startsWith('--');
544 }
545});
546//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling_builder.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler/src/render3/view/styling_builder.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 */\nimport {AttributeMarker} from '../../core';\nimport {AST, ASTWithSource, BindingPipe, BindingType, Interpolation} from '../../expression_parser/ast';\nimport * as o from '../../output/output_ast';\nimport {ParseSourceSpan} from '../../parse_util';\nimport {isEmptyExpression} from '../../template_parser/template_parser';\nimport * as t from '../r3_ast';\nimport {Identifiers as R3} from '../r3_identifiers';\n\nimport {hyphenate, parse as parseStyle} from './style_parser';\nimport {ValueConverter} from './template';\nimport {DefinitionMap, getInterpolationArgsLength} from './util';\n\nconst IMPORTANT_FLAG = '!important';\n\n/**\n * Minimum amount of binding slots required in the runtime for style/class bindings.\n *\n * Styling in Angular uses up two slots in the runtime LView/TData data structures to\n * record binding data, property information and metadata.\n *\n * When a binding is registered it will place the following information in the `LView`:\n *\n * slot 1) binding value\n * slot 2) cached value (all other values collected before it in string form)\n *\n * When a binding is registered it will place the following information in the `TData`:\n *\n * slot 1) prop name\n * slot 2) binding index that points to the previous style/class binding (and some extra config\n * values)\n *\n * Let's imagine we have a binding that looks like so:\n *\n * ```\n * <div [style.width]=\"x\" [style.height]=\"y\">\n * ```\n *\n * Our `LView` and `TData` data-structures look like so:\n *\n * ```typescript\n * LView = [\n *   // ...\n *   x, // value of x\n *   \"width: x\",\n *\n *   y, // value of y\n *   \"width: x; height: y\",\n *   // ...\n * ];\n *\n * TData = [\n *   // ...\n *   \"width\", // binding slot 20\n *   0,\n *\n *   \"height\",\n *   20,\n *   // ...\n * ];\n * ```\n *\n * */\nexport const MIN_STYLING_BINDING_SLOTS_REQUIRED = 2;\n\n/**\n * A styling expression summary that is to be processed by the compiler\n */\nexport interface StylingInstruction {\n  reference: o.ExternalReference;\n  /** Calls to individual styling instructions. Used when chaining calls to the same instruction. */\n  calls: StylingInstructionCall[];\n}\n\nexport interface StylingInstructionCall {\n  sourceSpan: ParseSourceSpan|null;\n  supportsInterpolation: boolean;\n  allocateBindingSlots: number;\n  params: ((convertFn: (value: any) => o.Expression | o.Expression[]) => o.Expression[]);\n}\n\n/**\n * An internal record of the input data for a styling binding\n */\ninterface BoundStylingEntry {\n  hasOverrideFlag: boolean;\n  name: string|null;\n  suffix: string|null;\n  sourceSpan: ParseSourceSpan;\n  value: AST;\n}\n\n/**\n * Produces creation/update instructions for all styling bindings (class and style)\n *\n * It also produces the creation instruction to register all initial styling values\n * (which are all the static class=\"...\" and style=\"...\" attribute values that exist\n * on an element within a template).\n *\n * The builder class below handles producing instructions for the following cases:\n *\n * - Static style/class attributes (style=\"...\" and class=\"...\")\n * - Dynamic style/class map bindings ([style]=\"map\" and [class]=\"map|string\")\n * - Dynamic style/class property bindings ([style.prop]=\"exp\" and [class.name]=\"exp\")\n *\n * Due to the complex relationship of all of these cases, the instructions generated\n * for these attributes/properties/bindings must be done so in the correct order. The\n * order which these must be generated is as follows:\n *\n * if (createMode) {\n *   styling(...)\n * }\n * if (updateMode) {\n *   styleMap(...)\n *   classMap(...)\n *   styleProp(...)\n *   classProp(...)\n * }\n *\n * The creation/update methods within the builder class produce these instructions.\n */\nexport class StylingBuilder {\n  /** Whether or not there are any static styling values present */\n  private _hasInitialValues = false;\n  /**\n   *  Whether or not there are any styling bindings present\n   *  (i.e. `[style]`, `[class]`, `[style.prop]` or `[class.name]`)\n   */\n  public hasBindings = false;\n  public hasBindingsWithPipes = false;\n\n  /** the input for [class] (if it exists) */\n  private _classMapInput: BoundStylingEntry|null = null;\n  /** the input for [style] (if it exists) */\n  private _styleMapInput: BoundStylingEntry|null = null;\n  /** an array of each [style.prop] input */\n  private _singleStyleInputs: BoundStylingEntry[]|null = null;\n  /** an array of each [class.name] input */\n  private _singleClassInputs: BoundStylingEntry[]|null = null;\n  private _lastStylingInput: BoundStylingEntry|null = null;\n  private _firstStylingInput: BoundStylingEntry|null = null;\n\n  // maps are used instead of hash maps because a Map will\n  // retain the ordering of the keys\n\n  /**\n   * Represents the location of each style binding in the template\n   * (e.g. `<div [style.width]=\"w\" [style.height]=\"h\">` implies\n   * that `width=0` and `height=1`)\n   */\n  private _stylesIndex = new Map<string, number>();\n\n  /**\n   * Represents the location of each class binding in the template\n   * (e.g. `<div [class.big]=\"b\" [class.hidden]=\"h\">` implies\n   * that `big=0` and `hidden=1`)\n   */\n  private _classesIndex = new Map<string, number>();\n  private _initialStyleValues: string[] = [];\n  private _initialClassValues: string[] = [];\n\n  constructor(private _directiveExpr: o.Expression|null) {}\n\n  /**\n   * Registers a given input to the styling builder to be later used when producing AOT code.\n   *\n   * The code below will only accept the input if it is somehow tied to styling (whether it be\n   * style/class bindings or static style/class attributes).\n   */\n  registerBoundInput(input: t.BoundAttribute): boolean {\n    // [attr.style] or [attr.class] are skipped in the code below,\n    // they should not be treated as styling-based bindings since\n    // they are intended to be written directly to the attr and\n    // will therefore skip all style/class resolution that is present\n    // with style=\"\", [style]=\"\" and [style.prop]=\"\", class=\"\",\n    // [class.prop]=\"\". [class]=\"\" assignments\n    let binding: BoundStylingEntry|null = null;\n    let name = input.name;\n    switch (input.type) {\n      case BindingType.Property:\n        binding = this.registerInputBasedOnName(name, input.value, input.sourceSpan);\n        break;\n      case BindingType.Style:\n        binding = this.registerStyleInput(name, false, input.value, input.sourceSpan, input.unit);\n        break;\n      case BindingType.Class:\n        binding = this.registerClassInput(name, false, input.value, input.sourceSpan);\n        break;\n    }\n    return binding ? true : false;\n  }\n\n  registerInputBasedOnName(name: string, expression: AST, sourceSpan: ParseSourceSpan) {\n    let binding: BoundStylingEntry|null = null;\n    const prefix = name.substring(0, 6);\n    const isStyle = name === 'style' || prefix === 'style.' || prefix === 'style!';\n    const isClass = !isStyle && (name === 'class' || prefix === 'class.' || prefix === 'class!');\n    if (isStyle || isClass) {\n      const isMapBased = name.charAt(5) !== '.';         // style.prop or class.prop makes this a no\n      const property = name.substr(isMapBased ? 5 : 6);  // the dot explains why there's a +1\n      if (isStyle) {\n        binding = this.registerStyleInput(property, isMapBased, expression, sourceSpan);\n      } else {\n        binding = this.registerClassInput(property, isMapBased, expression, sourceSpan);\n      }\n    }\n    return binding;\n  }\n\n  registerStyleInput(\n      name: string, isMapBased: boolean, value: AST, sourceSpan: ParseSourceSpan,\n      suffix?: string|null): BoundStylingEntry|null {\n    if (isEmptyExpression(value)) {\n      return null;\n    }\n    // CSS custom properties are case-sensitive so we shouldn't normalize them.\n    // See: https://www.w3.org/TR/css-variables-1/#defining-variables\n    if (!isCssCustomProperty(name)) {\n      name = hyphenate(name);\n    }\n    const {property, hasOverrideFlag, suffix: bindingSuffix} = parseProperty(name);\n    suffix = typeof suffix === 'string' && suffix.length !== 0 ? suffix : bindingSuffix;\n    const entry:\n        BoundStylingEntry = {name: property, suffix: suffix, value, sourceSpan, hasOverrideFlag};\n    if (isMapBased) {\n      this._styleMapInput = entry;\n    } else {\n      (this._singleStyleInputs = this._singleStyleInputs || []).push(entry);\n      registerIntoMap(this._stylesIndex, property);\n    }\n    this._lastStylingInput = entry;\n    this._firstStylingInput = this._firstStylingInput || entry;\n    this._checkForPipes(value);\n    this.hasBindings = true;\n    return entry;\n  }\n\n  registerClassInput(name: string, isMapBased: boolean, value: AST, sourceSpan: ParseSourceSpan):\n      BoundStylingEntry|null {\n    if (isEmptyExpression(value)) {\n      return null;\n    }\n    const {property, hasOverrideFlag} = parseProperty(name);\n    const entry:\n        BoundStylingEntry = {name: property, value, sourceSpan, hasOverrideFlag, suffix: null};\n    if (isMapBased) {\n      this._classMapInput = entry;\n    } else {\n      (this._singleClassInputs = this._singleClassInputs || []).push(entry);\n      registerIntoMap(this._classesIndex, property);\n    }\n    this._lastStylingInput = entry;\n    this._firstStylingInput = this._firstStylingInput || entry;\n    this._checkForPipes(value);\n    this.hasBindings = true;\n    return entry;\n  }\n\n  private _checkForPipes(value: AST) {\n    if ((value instanceof ASTWithSource) && (value.ast instanceof BindingPipe)) {\n      this.hasBindingsWithPipes = true;\n    }\n  }\n\n  /**\n   * Registers the element's static style string value to the builder.\n   *\n   * @param value the style string (e.g. `width:100px; height:200px;`)\n   */\n  registerStyleAttr(value: string) {\n    this._initialStyleValues = parseStyle(value);\n    this._hasInitialValues = true;\n  }\n\n  /**\n   * Registers the element's static class string value to the builder.\n   *\n   * @param value the className string (e.g. `disabled gold zoom`)\n   */\n  registerClassAttr(value: string) {\n    this._initialClassValues = value.trim().split(/\\s+/g);\n    this._hasInitialValues = true;\n  }\n\n  /**\n   * Appends all styling-related expressions to the provided attrs array.\n   *\n   * @param attrs an existing array where each of the styling expressions\n   * will be inserted into.\n   */\n  populateInitialStylingAttrs(attrs: o.Expression[]): void {\n    // [CLASS_MARKER, 'foo', 'bar', 'baz' ...]\n    if (this._initialClassValues.length) {\n      attrs.push(o.literal(AttributeMarker.Classes));\n      for (let i = 0; i < this._initialClassValues.length; i++) {\n        attrs.push(o.literal(this._initialClassValues[i]));\n      }\n    }\n\n    // [STYLE_MARKER, 'width', '200px', 'height', '100px', ...]\n    if (this._initialStyleValues.length) {\n      attrs.push(o.literal(AttributeMarker.Styles));\n      for (let i = 0; i < this._initialStyleValues.length; i += 2) {\n        attrs.push(\n            o.literal(this._initialStyleValues[i]), o.literal(this._initialStyleValues[i + 1]));\n      }\n    }\n  }\n\n  /**\n   * Builds an instruction with all the expressions and parameters for `elementHostAttrs`.\n   *\n   * The instruction generation code below is used for producing the AOT statement code which is\n   * responsible for registering initial styles (within a directive hostBindings' creation block),\n   * as well as any of the provided attribute values, to the directive host element.\n   */\n  assignHostAttrs(attrs: o.Expression[], definitionMap: DefinitionMap): void {\n    if (this._directiveExpr && (attrs.length || this._hasInitialValues)) {\n      this.populateInitialStylingAttrs(attrs);\n      definitionMap.set('hostAttrs', o.literalArr(attrs));\n    }\n  }\n\n  /**\n   * Builds an instruction with all the expressions and parameters for `classMap`.\n   *\n   * The instruction data will contain all expressions for `classMap` to function\n   * which includes the `[class]` expression params.\n   */\n  buildClassMapInstruction(valueConverter: ValueConverter): StylingInstruction|null {\n    if (this._classMapInput) {\n      return this._buildMapBasedInstruction(valueConverter, true, this._classMapInput);\n    }\n    return null;\n  }\n\n  /**\n   * Builds an instruction with all the expressions and parameters for `styleMap`.\n   *\n   * The instruction data will contain all expressions for `styleMap` to function\n   * which includes the `[style]` expression params.\n   */\n  buildStyleMapInstruction(valueConverter: ValueConverter): StylingInstruction|null {\n    if (this._styleMapInput) {\n      return this._buildMapBasedInstruction(valueConverter, false, this._styleMapInput);\n    }\n    return null;\n  }\n\n  private _buildMapBasedInstruction(\n      valueConverter: ValueConverter, isClassBased: boolean,\n      stylingInput: BoundStylingEntry): StylingInstruction {\n    // each styling binding value is stored in the LView\n    // map-based bindings allocate two slots: one for the\n    // previous binding value and another for the previous\n    // className or style attribute value.\n    let totalBindingSlotsRequired = MIN_STYLING_BINDING_SLOTS_REQUIRED;\n\n    // these values must be outside of the update block so that they can\n    // be evaluated (the AST visit call) during creation time so that any\n    // pipes can be picked up in time before the template is built\n    const mapValue = stylingInput.value.visit(valueConverter);\n    let reference: o.ExternalReference;\n    if (mapValue instanceof Interpolation) {\n      totalBindingSlotsRequired += mapValue.expressions.length;\n      reference = isClassBased ? getClassMapInterpolationExpression(mapValue) :\n                                 getStyleMapInterpolationExpression(mapValue);\n    } else {\n      reference = isClassBased ? R3.classMap : R3.styleMap;\n    }\n\n    return {\n      reference,\n      calls: [{\n        supportsInterpolation: true,\n        sourceSpan: stylingInput.sourceSpan,\n        allocateBindingSlots: totalBindingSlotsRequired,\n        params: (convertFn: (value: any) => o.Expression|o.Expression[]) => {\n          const convertResult = convertFn(mapValue);\n          const params = Array.isArray(convertResult) ? convertResult : [convertResult];\n          return params;\n        }\n      }]\n    };\n  }\n\n  private _buildSingleInputs(\n      reference: o.ExternalReference, inputs: BoundStylingEntry[], valueConverter: ValueConverter,\n      getInterpolationExpressionFn: ((value: Interpolation) => o.ExternalReference)|null,\n      isClassBased: boolean): StylingInstruction[] {\n    const instructions: StylingInstruction[] = [];\n\n    inputs.forEach(input => {\n      const previousInstruction: StylingInstruction|undefined =\n          instructions[instructions.length - 1];\n      const value = input.value.visit(valueConverter);\n      let referenceForCall = reference;\n\n      // each styling binding value is stored in the LView\n      // but there are two values stored for each binding:\n      //   1) the value itself\n      //   2) an intermediate value (concatenation of style up to this point).\n      //      We need to store the intermediate value so that we don't allocate\n      //      the strings on each CD.\n      let totalBindingSlotsRequired = MIN_STYLING_BINDING_SLOTS_REQUIRED;\n\n      if (value instanceof Interpolation) {\n        totalBindingSlotsRequired += value.expressions.length;\n\n        if (getInterpolationExpressionFn) {\n          referenceForCall = getInterpolationExpressionFn(value);\n        }\n      }\n\n      const call = {\n        sourceSpan: input.sourceSpan,\n        allocateBindingSlots: totalBindingSlotsRequired,\n        supportsInterpolation: !!getInterpolationExpressionFn,\n        params: (convertFn: (value: any) => o.Expression | o.Expression[]) => {\n          // params => stylingProp(propName, value, suffix)\n          const params: o.Expression[] = [];\n          params.push(o.literal(input.name));\n\n          const convertResult = convertFn(value);\n          if (Array.isArray(convertResult)) {\n            params.push(...convertResult);\n          } else {\n            params.push(convertResult);\n          }\n\n          // [style.prop] bindings may use suffix values (e.g. px, em, etc...), therefore,\n          // if that is detected then we need to pass that in as an optional param.\n          if (!isClassBased && input.suffix !== null) {\n            params.push(o.literal(input.suffix));\n          }\n\n          return params;\n        }\n      };\n\n      // If we ended up generating a call to the same instruction as the previous styling property\n      // we can chain the calls together safely to save some bytes, otherwise we have to generate\n      // a separate instruction call. This is primarily a concern with interpolation instructions\n      // where we may start off with one `reference`, but end up using another based on the\n      // number of interpolations.\n      if (previousInstruction && previousInstruction.reference === referenceForCall) {\n        previousInstruction.calls.push(call);\n      } else {\n        instructions.push({reference: referenceForCall, calls: [call]});\n      }\n    });\n\n    return instructions;\n  }\n\n  private _buildClassInputs(valueConverter: ValueConverter): StylingInstruction[] {\n    if (this._singleClassInputs) {\n      return this._buildSingleInputs(\n          R3.classProp, this._singleClassInputs, valueConverter, null, true);\n    }\n    return [];\n  }\n\n  private _buildStyleInputs(valueConverter: ValueConverter): StylingInstruction[] {\n    if (this._singleStyleInputs) {\n      return this._buildSingleInputs(\n          R3.styleProp, this._singleStyleInputs, valueConverter,\n          getStylePropInterpolationExpression, false);\n    }\n    return [];\n  }\n\n  /**\n   * Constructs all instructions which contain the expressions that will be placed\n   * into the update block of a template function or a directive hostBindings function.\n   */\n  buildUpdateLevelInstructions(valueConverter: ValueConverter) {\n    const instructions: StylingInstruction[] = [];\n    if (this.hasBindings) {\n      const styleMapInstruction = this.buildStyleMapInstruction(valueConverter);\n      if (styleMapInstruction) {\n        instructions.push(styleMapInstruction);\n      }\n      const classMapInstruction = this.buildClassMapInstruction(valueConverter);\n      if (classMapInstruction) {\n        instructions.push(classMapInstruction);\n      }\n      instructions.push(...this._buildStyleInputs(valueConverter));\n      instructions.push(...this._buildClassInputs(valueConverter));\n    }\n    return instructions;\n  }\n}\n\nfunction registerIntoMap(map: Map<string, number>, key: string) {\n  if (!map.has(key)) {\n    map.set(key, map.size);\n  }\n}\n\nexport function parseProperty(name: string):\n    {property: string, suffix: string|null, hasOverrideFlag: boolean} {\n  let hasOverrideFlag = false;\n  const overrideIndex = name.indexOf(IMPORTANT_FLAG);\n  if (overrideIndex !== -1) {\n    name = overrideIndex > 0 ? name.substring(0, overrideIndex) : '';\n    hasOverrideFlag = true;\n  }\n\n  let suffix: string|null = null;\n  let property = name;\n  const unitIndex = name.lastIndexOf('.');\n  if (unitIndex > 0) {\n    suffix = name.substr(unitIndex + 1);\n    property = name.substring(0, unitIndex);\n  }\n\n  return {property, suffix, hasOverrideFlag};\n}\n\n/**\n * Gets the instruction to generate for an interpolated class map.\n * @param interpolation An Interpolation AST\n */\nfunction getClassMapInterpolationExpression(interpolation: Interpolation): o.ExternalReference {\n  switch (getInterpolationArgsLength(interpolation)) {\n    case 1:\n      return R3.classMap;\n    case 3:\n      return R3.classMapInterpolate1;\n    case 5:\n      return R3.classMapInterpolate2;\n    case 7:\n      return R3.classMapInterpolate3;\n    case 9:\n      return R3.classMapInterpolate4;\n    case 11:\n      return R3.classMapInterpolate5;\n    case 13:\n      return R3.classMapInterpolate6;\n    case 15:\n      return R3.classMapInterpolate7;\n    case 17:\n      return R3.classMapInterpolate8;\n    default:\n      return R3.classMapInterpolateV;\n  }\n}\n\n/**\n * Gets the instruction to generate for an interpolated style map.\n * @param interpolation An Interpolation AST\n */\nfunction getStyleMapInterpolationExpression(interpolation: Interpolation): o.ExternalReference {\n  switch (getInterpolationArgsLength(interpolation)) {\n    case 1:\n      return R3.styleMap;\n    case 3:\n      return R3.styleMapInterpolate1;\n    case 5:\n      return R3.styleMapInterpolate2;\n    case 7:\n      return R3.styleMapInterpolate3;\n    case 9:\n      return R3.styleMapInterpolate4;\n    case 11:\n      return R3.styleMapInterpolate5;\n    case 13:\n      return R3.styleMapInterpolate6;\n    case 15:\n      return R3.styleMapInterpolate7;\n    case 17:\n      return R3.styleMapInterpolate8;\n    default:\n      return R3.styleMapInterpolateV;\n  }\n}\n\n/**\n * Gets the instruction to generate for an interpolated style prop.\n * @param interpolation An Interpolation AST\n */\nfunction getStylePropInterpolationExpression(interpolation: Interpolation) {\n  switch (getInterpolationArgsLength(interpolation)) {\n    case 1:\n      return R3.styleProp;\n    case 3:\n      return R3.stylePropInterpolate1;\n    case 5:\n      return R3.stylePropInterpolate2;\n    case 7:\n      return R3.stylePropInterpolate3;\n    case 9:\n      return R3.stylePropInterpolate4;\n    case 11:\n      return R3.stylePropInterpolate5;\n    case 13:\n      return R3.stylePropInterpolate6;\n    case 15:\n      return R3.stylePropInterpolate7;\n    case 17:\n      return R3.stylePropInterpolate8;\n    default:\n      return R3.stylePropInterpolateV;\n  }\n}\n\n/**\n * Checks whether property name is a custom CSS property.\n * See: https://www.w3.org/TR/css-variables-1\n */\nfunction isCssCustomProperty(name: string): boolean {\n  return name.startsWith('--');\n}\n"]}
Note: See TracBrowser for help on using the repository browser.