fix(ivy): fix generated code for style bindings with units (#26397)

PR Close #26397
This commit is contained in:
Pawel Kozlowski 2018-10-11 14:06:23 +02:00 committed by Miško Hevery
parent bd186c7ef9
commit 4b494f23f5
3 changed files with 50 additions and 12 deletions

View File

@ -383,6 +383,47 @@ describe('compiler compliance: styling', () => {
const result = compile(files, angularFiles); const result = compile(files, angularFiles);
expectEmit(result.source, template, 'Incorrect template'); expectEmit(result.source, template, 'Incorrect template');
}); });
it('should support [style.foo.suffix] style bindings with a suffix', () => {
const files = {
app: {
'spec.ts': `
import {Component, NgModule} from '@angular/core';
@Component({
selector: 'my-component',
template: \`<div [style.font-size.px]="12">\`
})
export class MyComponent {
}
@NgModule({declarations: [MyComponent]})
export class MyModule {}
`
}
};
const template = `
const $e0_styles$= ["font-size"];
template: function MyComponent_Template(rf, ctx) {
if (rf & 1) {
$r3$.ɵelementStart(0, "div");
$r3$.ɵelementStyling(null, _c0);
$r3$.ɵelementEnd();
}
if (rf & 2) {
$r3$.ɵelementStyleProp(0, 0, 12, "px");
$r3$.ɵelementStylingApply(0);
}
}
`;
const result = compile(files, angularFiles);
expectEmit(result.source, template, 'Incorrect template');
});
}); });
describe('[class]', () => { describe('[class]', () => {

View File

@ -613,19 +613,18 @@ export class TemplateDefinitionBuilder implements t.Visitor<void>, LocalResolver
let i = mapBasedStyleInput ? 1 : 0; let i = mapBasedStyleInput ? 1 : 0;
for (i; i < styleInputs.length; i++) { for (i; i < styleInputs.length; i++) {
const input = styleInputs[i]; const input = styleInputs[i];
const params: any[] = [];
const sanitizationRef = resolveSanitizationFn(input, input.securityContext);
if (sanitizationRef) params.push(sanitizationRef);
const key = input.name; const key = input.name;
const styleIndex: number = stylesIndexMap[key] !; const styleIndex: number = stylesIndexMap[key] !;
const value = input.value.visit(this._valueConverter); const value = input.value.visit(this._valueConverter);
this.updateInstruction(input.sourceSpan, R3.elementStyleProp, () => { const params: o.Expression[] = [
return [ indexLiteral, o.literal(styleIndex), this.convertPropertyBinding(implicit, value, true)
indexLiteral, o.literal(styleIndex),
this.convertPropertyBinding(implicit, value, true), ...params
]; ];
});
if (input.unit != null) {
params.push(o.literal(input.unit));
}
this.updateInstruction(input.sourceSpan, R3.elementStyleProp, params);
} }
lastInputCommand = styleInputs[styleInputs.length - 1]; lastInputCommand = styleInputs[styleInputs.length - 1];

View File

@ -1687,8 +1687,6 @@ export function elementStylingApply<T>(index: number): void {
* specifically for element styling--the index must be the next index after the element * specifically for element styling--the index must be the next index after the element
* index.) * index.)
* @param styleIndex Index of the style property on this element. (Monotonically increasing.) * @param styleIndex Index of the style property on this element. (Monotonically increasing.)
* @param styleName Name of property. Because it is going to DOM this is not subject to
* renaming as part of minification.
* @param value New value to write (null to remove). * @param value New value to write (null to remove).
* @param suffix Optional suffix. Used with scalar values to add unit such as `px`. * @param suffix Optional suffix. Used with scalar values to add unit such as `px`.
* Note that when a suffix is provided then the underlying sanitizer will * Note that when a suffix is provided then the underlying sanitizer will