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 | import { ViewEncapsulation } from '../metadata/view';
|
9 | import { SecurityContext } from '../sanitization/security';
|
10 | import { asElementData } from './types';
|
11 | import { calcBindingFlags, checkAndUpdateBinding, dispatchEvent, elementEventFullName, getParentRenderElement, NOOP, resolveDefinition, resolveRendererType2, splitMatchedQueriesDsl, splitNamespace } from './util';
|
12 | export function anchorDef(flags, matchedQueriesDsl, ngContentIndex, childCount, handleEvent, templateFactory) {
|
13 | flags |= 1 /* TypeElement */;
|
14 | const { matchedQueries, references, matchedQueryIds } = splitMatchedQueriesDsl(matchedQueriesDsl);
|
15 | const template = templateFactory ? resolveDefinition(templateFactory) : null;
|
16 | return {
|
17 | // will bet set by the view definition
|
18 | nodeIndex: -1,
|
19 | parent: null,
|
20 | renderParent: null,
|
21 | bindingIndex: -1,
|
22 | outputIndex: -1,
|
23 | // regular values
|
24 | flags,
|
25 | checkIndex: -1,
|
26 | childFlags: 0,
|
27 | directChildFlags: 0,
|
28 | childMatchedQueries: 0,
|
29 | matchedQueries,
|
30 | matchedQueryIds,
|
31 | references,
|
32 | ngContentIndex,
|
33 | childCount,
|
34 | bindings: [],
|
35 | bindingFlags: 0,
|
36 | outputs: [],
|
37 | element: {
|
38 | ns: null,
|
39 | name: null,
|
40 | attrs: null,
|
41 | template,
|
42 | componentProvider: null,
|
43 | componentView: null,
|
44 | componentRendererType: null,
|
45 | publicProviders: null,
|
46 | allProviders: null,
|
47 | handleEvent: handleEvent || NOOP
|
48 | },
|
49 | provider: null,
|
50 | text: null,
|
51 | query: null,
|
52 | ngContent: null
|
53 | };
|
54 | }
|
55 | export function elementDef(checkIndex, flags, matchedQueriesDsl, ngContentIndex, childCount, namespaceAndName, fixedAttrs = [], bindings, outputs, handleEvent, componentView, componentRendererType) {
|
56 | if (!handleEvent) {
|
57 | handleEvent = NOOP;
|
58 | }
|
59 | const { matchedQueries, references, matchedQueryIds } = splitMatchedQueriesDsl(matchedQueriesDsl);
|
60 | let ns = null;
|
61 | let name = null;
|
62 | if (namespaceAndName) {
|
63 | [ns, name] = splitNamespace(namespaceAndName);
|
64 | }
|
65 | bindings = bindings || [];
|
66 | const bindingDefs = [];
|
67 | for (let i = 0; i < bindings.length; i++) {
|
68 | const [bindingFlags, namespaceAndName, suffixOrSecurityContext] = bindings[i];
|
69 | const [ns, name] = splitNamespace(namespaceAndName);
|
70 | let securityContext = undefined;
|
71 | let suffix = undefined;
|
72 | switch (bindingFlags & 15 /* Types */) {
|
73 | case 4 /* TypeElementStyle */:
|
74 | suffix = suffixOrSecurityContext;
|
75 | break;
|
76 | case 1 /* TypeElementAttribute */:
|
77 | case 8 /* TypeProperty */:
|
78 | securityContext = suffixOrSecurityContext;
|
79 | break;
|
80 | }
|
81 | bindingDefs[i] =
|
82 | { flags: bindingFlags, ns, name, nonMinifiedName: name, securityContext, suffix };
|
83 | }
|
84 | outputs = outputs || [];
|
85 | const outputDefs = [];
|
86 | for (let i = 0; i < outputs.length; i++) {
|
87 | const [target, eventName] = outputs[i];
|
88 | outputDefs[i] =
|
89 | { type: 0 /* ElementOutput */, target: target, eventName, propName: null };
|
90 | }
|
91 | fixedAttrs = fixedAttrs || [];
|
92 | const attrs = fixedAttrs.map(([namespaceAndName, value]) => {
|
93 | const [ns, name] = splitNamespace(namespaceAndName);
|
94 | return [ns, name, value];
|
95 | });
|
96 | componentRendererType = resolveRendererType2(componentRendererType);
|
97 | if (componentView) {
|
98 | flags |= 33554432 /* ComponentView */;
|
99 | }
|
100 | flags |= 1 /* TypeElement */;
|
101 | return {
|
102 | // will bet set by the view definition
|
103 | nodeIndex: -1,
|
104 | parent: null,
|
105 | renderParent: null,
|
106 | bindingIndex: -1,
|
107 | outputIndex: -1,
|
108 | // regular values
|
109 | checkIndex,
|
110 | flags,
|
111 | childFlags: 0,
|
112 | directChildFlags: 0,
|
113 | childMatchedQueries: 0,
|
114 | matchedQueries,
|
115 | matchedQueryIds,
|
116 | references,
|
117 | ngContentIndex,
|
118 | childCount,
|
119 | bindings: bindingDefs,
|
120 | bindingFlags: calcBindingFlags(bindingDefs),
|
121 | outputs: outputDefs,
|
122 | element: {
|
123 | ns,
|
124 | name,
|
125 | attrs,
|
126 | template: null,
|
127 | // will bet set by the view definition
|
128 | componentProvider: null,
|
129 | componentView: componentView || null,
|
130 | componentRendererType: componentRendererType,
|
131 | publicProviders: null,
|
132 | allProviders: null,
|
133 | handleEvent: handleEvent || NOOP,
|
134 | },
|
135 | provider: null,
|
136 | text: null,
|
137 | query: null,
|
138 | ngContent: null
|
139 | };
|
140 | }
|
141 | export function createElement(view, renderHost, def) {
|
142 | const elDef = def.element;
|
143 | const rootSelectorOrNode = view.root.selectorOrNode;
|
144 | const renderer = view.renderer;
|
145 | let el;
|
146 | if (view.parent || !rootSelectorOrNode) {
|
147 | if (elDef.name) {
|
148 | el = renderer.createElement(elDef.name, elDef.ns);
|
149 | }
|
150 | else {
|
151 | el = renderer.createComment('');
|
152 | }
|
153 | const parentEl = getParentRenderElement(view, renderHost, def);
|
154 | if (parentEl) {
|
155 | renderer.appendChild(parentEl, el);
|
156 | }
|
157 | }
|
158 | else {
|
159 | // when using native Shadow DOM, do not clear the root element contents to allow slot projection
|
160 | const preserveContent = (!!elDef.componentRendererType &&
|
161 | elDef.componentRendererType.encapsulation === ViewEncapsulation.ShadowDom);
|
162 | el = renderer.selectRootElement(rootSelectorOrNode, preserveContent);
|
163 | }
|
164 | if (elDef.attrs) {
|
165 | for (let i = 0; i < elDef.attrs.length; i++) {
|
166 | const [ns, name, value] = elDef.attrs[i];
|
167 | renderer.setAttribute(el, name, value, ns);
|
168 | }
|
169 | }
|
170 | return el;
|
171 | }
|
172 | export function listenToElementOutputs(view, compView, def, el) {
|
173 | for (let i = 0; i < def.outputs.length; i++) {
|
174 | const output = def.outputs[i];
|
175 | const handleEventClosure = renderEventHandlerClosure(view, def.nodeIndex, elementEventFullName(output.target, output.eventName));
|
176 | let listenTarget = output.target;
|
177 | let listenerView = view;
|
178 | if (output.target === 'component') {
|
179 | listenTarget = null;
|
180 | listenerView = compView;
|
181 | }
|
182 | const disposable = listenerView.renderer.listen(listenTarget || el, output.eventName, handleEventClosure);
|
183 | view.disposables[def.outputIndex + i] = disposable;
|
184 | }
|
185 | }
|
186 | function renderEventHandlerClosure(view, index, eventName) {
|
187 | return (event) => dispatchEvent(view, index, eventName, event);
|
188 | }
|
189 | export function checkAndUpdateElementInline(view, def, v0, v1, v2, v3, v4, v5, v6, v7, v8, v9) {
|
190 | const bindLen = def.bindings.length;
|
191 | let changed = false;
|
192 | if (bindLen > 0 && checkAndUpdateElementValue(view, def, 0, v0))
|
193 | changed = true;
|
194 | if (bindLen > 1 && checkAndUpdateElementValue(view, def, 1, v1))
|
195 | changed = true;
|
196 | if (bindLen > 2 && checkAndUpdateElementValue(view, def, 2, v2))
|
197 | changed = true;
|
198 | if (bindLen > 3 && checkAndUpdateElementValue(view, def, 3, v3))
|
199 | changed = true;
|
200 | if (bindLen > 4 && checkAndUpdateElementValue(view, def, 4, v4))
|
201 | changed = true;
|
202 | if (bindLen > 5 && checkAndUpdateElementValue(view, def, 5, v5))
|
203 | changed = true;
|
204 | if (bindLen > 6 && checkAndUpdateElementValue(view, def, 6, v6))
|
205 | changed = true;
|
206 | if (bindLen > 7 && checkAndUpdateElementValue(view, def, 7, v7))
|
207 | changed = true;
|
208 | if (bindLen > 8 && checkAndUpdateElementValue(view, def, 8, v8))
|
209 | changed = true;
|
210 | if (bindLen > 9 && checkAndUpdateElementValue(view, def, 9, v9))
|
211 | changed = true;
|
212 | return changed;
|
213 | }
|
214 | export function checkAndUpdateElementDynamic(view, def, values) {
|
215 | let changed = false;
|
216 | for (let i = 0; i < values.length; i++) {
|
217 | if (checkAndUpdateElementValue(view, def, i, values[i]))
|
218 | changed = true;
|
219 | }
|
220 | return changed;
|
221 | }
|
222 | function checkAndUpdateElementValue(view, def, bindingIdx, value) {
|
223 | if (!checkAndUpdateBinding(view, def, bindingIdx, value)) {
|
224 | return false;
|
225 | }
|
226 | const binding = def.bindings[bindingIdx];
|
227 | const elData = asElementData(view, def.nodeIndex);
|
228 | const renderNode = elData.renderElement;
|
229 | const name = binding.name;
|
230 | switch (binding.flags & 15 /* Types */) {
|
231 | case 1 /* TypeElementAttribute */:
|
232 | setElementAttribute(view, binding, renderNode, binding.ns, name, value);
|
233 | break;
|
234 | case 2 /* TypeElementClass */:
|
235 | setElementClass(view, renderNode, name, value);
|
236 | break;
|
237 | case 4 /* TypeElementStyle */:
|
238 | setElementStyle(view, binding, renderNode, name, value);
|
239 | break;
|
240 | case 8 /* TypeProperty */:
|
241 | const bindView = (def.flags & 33554432 /* ComponentView */ &&
|
242 | binding.flags & 32 /* SyntheticHostProperty */) ?
|
243 | elData.componentView :
|
244 | view;
|
245 | setElementProperty(bindView, binding, renderNode, name, value);
|
246 | break;
|
247 | }
|
248 | return true;
|
249 | }
|
250 | function setElementAttribute(view, binding, renderNode, ns, name, value) {
|
251 | const securityContext = binding.securityContext;
|
252 | let renderValue = securityContext ? view.root.sanitizer.sanitize(securityContext, value) : value;
|
253 | renderValue = renderValue != null ? renderValue.toString() : null;
|
254 | const renderer = view.renderer;
|
255 | if (value != null) {
|
256 | renderer.setAttribute(renderNode, name, renderValue, ns);
|
257 | }
|
258 | else {
|
259 | renderer.removeAttribute(renderNode, name, ns);
|
260 | }
|
261 | }
|
262 | function setElementClass(view, renderNode, name, value) {
|
263 | const renderer = view.renderer;
|
264 | if (value) {
|
265 | renderer.addClass(renderNode, name);
|
266 | }
|
267 | else {
|
268 | renderer.removeClass(renderNode, name);
|
269 | }
|
270 | }
|
271 | function setElementStyle(view, binding, renderNode, name, value) {
|
272 | let renderValue = view.root.sanitizer.sanitize(SecurityContext.STYLE, value);
|
273 | if (renderValue != null) {
|
274 | renderValue = renderValue.toString();
|
275 | const unit = binding.suffix;
|
276 | if (unit != null) {
|
277 | renderValue = renderValue + unit;
|
278 | }
|
279 | }
|
280 | else {
|
281 | renderValue = null;
|
282 | }
|
283 | const renderer = view.renderer;
|
284 | if (renderValue != null) {
|
285 | renderer.setStyle(renderNode, name, renderValue);
|
286 | }
|
287 | else {
|
288 | renderer.removeStyle(renderNode, name);
|
289 | }
|
290 | }
|
291 | function setElementProperty(view, binding, renderNode, name, value) {
|
292 | const securityContext = binding.securityContext;
|
293 | let renderValue = securityContext ? view.root.sanitizer.sanitize(securityContext, value) : value;
|
294 | view.renderer.setProperty(renderNode, name, renderValue);
|
295 | }
|
296 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element.js","sourceRoot":"","sources":["../../../../../../../packages/core/src/view/element.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 {ViewEncapsulation} from '../metadata/view';\nimport {RendererType2} from '../render/api_flags';\nimport {SecurityContext} from '../sanitization/security';\n\nimport {asElementData, BindingDef, BindingFlags, ElementData, ElementHandleEventFn, NodeDef, NodeFlags, OutputDef, OutputType, QueryValueType, ViewData, ViewDefinitionFactory} from './types';\nimport {calcBindingFlags, checkAndUpdateBinding, dispatchEvent, elementEventFullName, getParentRenderElement, NOOP, resolveDefinition, resolveRendererType2, splitMatchedQueriesDsl, splitNamespace} from './util';\n\nexport function anchorDef(\n    flags: NodeFlags, matchedQueriesDsl: null|[string | number, QueryValueType][],\n    ngContentIndex: null|number, childCount: number, handleEvent?: null|ElementHandleEventFn,\n    templateFactory?: ViewDefinitionFactory): NodeDef {\n  flags |= NodeFlags.TypeElement;\n  const {matchedQueries, references, matchedQueryIds} = splitMatchedQueriesDsl(matchedQueriesDsl);\n  const template = templateFactory ? resolveDefinition(templateFactory) : null;\n\n  return {\n    // will bet set by the view definition\n    nodeIndex: -1,\n    parent: null,\n    renderParent: null,\n    bindingIndex: -1,\n    outputIndex: -1,\n    // regular values\n    flags,\n    checkIndex: -1,\n    childFlags: 0,\n    directChildFlags: 0,\n    childMatchedQueries: 0,\n    matchedQueries,\n    matchedQueryIds,\n    references,\n    ngContentIndex,\n    childCount,\n    bindings: [],\n    bindingFlags: 0,\n    outputs: [],\n    element: {\n      ns: null,\n      name: null,\n      attrs: null,\n      template,\n      componentProvider: null,\n      componentView: null,\n      componentRendererType: null,\n      publicProviders: null,\n      allProviders: null,\n      handleEvent: handleEvent || NOOP\n    },\n    provider: null,\n    text: null,\n    query: null,\n    ngContent: null\n  };\n}\n\nexport function elementDef(\n    checkIndex: number, flags: NodeFlags,\n    matchedQueriesDsl: null|[string | number, QueryValueType][], ngContentIndex: null|number,\n    childCount: number, namespaceAndName: string|null, fixedAttrs: null|[string, string][] = [],\n    bindings?: null|[BindingFlags, string, string | SecurityContext | null][],\n    outputs?: null|([string, string])[], handleEvent?: null|ElementHandleEventFn,\n    componentView?: null|ViewDefinitionFactory,\n    componentRendererType?: RendererType2|null): NodeDef {\n  if (!handleEvent) {\n    handleEvent = NOOP;\n  }\n  const {matchedQueries, references, matchedQueryIds} = splitMatchedQueriesDsl(matchedQueriesDsl);\n  let ns: string = null!;\n  let name: string = null!;\n  if (namespaceAndName) {\n    [ns, name] = splitNamespace(namespaceAndName);\n  }\n  bindings = bindings || [];\n  const bindingDefs: BindingDef[] = [];\n  for (let i = 0; i < bindings.length; i++) {\n    const [bindingFlags, namespaceAndName, suffixOrSecurityContext] = bindings[i];\n\n    const [ns, name] = splitNamespace(namespaceAndName);\n    let securityContext: SecurityContext = undefined!;\n    let suffix: string = undefined!;\n    switch (bindingFlags & BindingFlags.Types) {\n      case BindingFlags.TypeElementStyle:\n        suffix = <string>suffixOrSecurityContext;\n        break;\n      case BindingFlags.TypeElementAttribute:\n      case BindingFlags.TypeProperty:\n        securityContext = <SecurityContext>suffixOrSecurityContext;\n        break;\n    }\n    bindingDefs[i] =\n        {flags: bindingFlags, ns, name, nonMinifiedName: name, securityContext, suffix};\n  }\n  outputs = outputs || [];\n  const outputDefs: OutputDef[] = [];\n  for (let i = 0; i < outputs.length; i++) {\n    const [target, eventName] = outputs[i];\n    outputDefs[i] =\n        {type: OutputType.ElementOutput, target: <any>target, eventName, propName: null};\n  }\n  fixedAttrs = fixedAttrs || [];\n  const attrs = <[string, string, string][]>fixedAttrs.map(([namespaceAndName, value]) => {\n    const [ns, name] = splitNamespace(namespaceAndName);\n    return [ns, name, value];\n  });\n  componentRendererType = resolveRendererType2(componentRendererType);\n  if (componentView) {\n    flags |= NodeFlags.ComponentView;\n  }\n  flags |= NodeFlags.TypeElement;\n  return {\n    // will bet set by the view definition\n    nodeIndex: -1,\n    parent: null,\n    renderParent: null,\n    bindingIndex: -1,\n    outputIndex: -1,\n    // regular values\n    checkIndex,\n    flags,\n    childFlags: 0,\n    directChildFlags: 0,\n    childMatchedQueries: 0,\n    matchedQueries,\n    matchedQueryIds,\n    references,\n    ngContentIndex,\n    childCount,\n    bindings: bindingDefs,\n    bindingFlags: calcBindingFlags(bindingDefs),\n    outputs: outputDefs,\n    element: {\n      ns,\n      name,\n      attrs,\n      template: null,\n      // will bet set by the view definition\n      componentProvider: null,\n      componentView: componentView || null,\n      componentRendererType: componentRendererType,\n      publicProviders: null,\n      allProviders: null,\n      handleEvent: handleEvent || NOOP,\n    },\n    provider: null,\n    text: null,\n    query: null,\n    ngContent: null\n  };\n}\n\nexport function createElement(view: ViewData, renderHost: any, def: NodeDef): ElementData {\n  const elDef = def.element!;\n  const rootSelectorOrNode = view.root.selectorOrNode;\n  const renderer = view.renderer;\n  let el: any;\n  if (view.parent || !rootSelectorOrNode) {\n    if (elDef.name) {\n      el = renderer.createElement(elDef.name, elDef.ns);\n    } else {\n      el = renderer.createComment('');\n    }\n    const parentEl = getParentRenderElement(view, renderHost, def);\n    if (parentEl) {\n      renderer.appendChild(parentEl, el);\n    }\n  } else {\n    // when using native Shadow DOM, do not clear the root element contents to allow slot projection\n    const preserveContent =\n        (!!elDef.componentRendererType &&\n         elDef.componentRendererType.encapsulation === ViewEncapsulation.ShadowDom);\n    el = renderer.selectRootElement(rootSelectorOrNode, preserveContent);\n  }\n  if (elDef.attrs) {\n    for (let i = 0; i < elDef.attrs.length; i++) {\n      const [ns, name, value] = elDef.attrs[i];\n      renderer.setAttribute(el, name, value, ns);\n    }\n  }\n  return el;\n}\n\nexport function listenToElementOutputs(view: ViewData, compView: ViewData, def: NodeDef, el: any) {\n  for (let i = 0; i < def.outputs.length; i++) {\n    const output = def.outputs[i];\n    const handleEventClosure = renderEventHandlerClosure(\n        view, def.nodeIndex, elementEventFullName(output.target, output.eventName));\n    let listenTarget: 'window'|'document'|'body'|'component'|null = output.target;\n    let listenerView = view;\n    if (output.target === 'component') {\n      listenTarget = null;\n      listenerView = compView;\n    }\n    const disposable =\n        <any>listenerView.renderer.listen(listenTarget || el, output.eventName, handleEventClosure);\n    view.disposables![def.outputIndex + i] = disposable;\n  }\n}\n\nfunction renderEventHandlerClosure(view: ViewData, index: number, eventName: string) {\n  return (event: any) => dispatchEvent(view, index, eventName, event);\n}\n\n\nexport function checkAndUpdateElementInline(\n    view: ViewData, def: NodeDef, v0: any, v1: any, v2: any, v3: any, v4: any, v5: any, v6: any,\n    v7: any, v8: any, v9: any): boolean {\n  const bindLen = def.bindings.length;\n  let changed = false;\n  if (bindLen > 0 && checkAndUpdateElementValue(view, def, 0, v0)) changed = true;\n  if (bindLen > 1 && checkAndUpdateElementValue(view, def, 1, v1)) changed = true;\n  if (bindLen > 2 && checkAndUpdateElementValue(view, def, 2, v2)) changed = true;\n  if (bindLen > 3 && checkAndUpdateElementValue(view, def, 3, v3)) changed = true;\n  if (bindLen > 4 && checkAndUpdateElementValue(view, def, 4, v4)) changed = true;\n  if (bindLen > 5 && checkAndUpdateElementValue(view, def, 5, v5)) changed = true;\n  if (bindLen > 6 && checkAndUpdateElementValue(view, def, 6, v6)) changed = true;\n  if (bindLen > 7 && checkAndUpdateElementValue(view, def, 7, v7)) changed = true;\n  if (bindLen > 8 && checkAndUpdateElementValue(view, def, 8, v8)) changed = true;\n  if (bindLen > 9 && checkAndUpdateElementValue(view, def, 9, v9)) changed = true;\n  return changed;\n}\n\nexport function checkAndUpdateElementDynamic(view: ViewData, def: NodeDef, values: any[]): boolean {\n  let changed = false;\n  for (let i = 0; i < values.length; i++) {\n    if (checkAndUpdateElementValue(view, def, i, values[i])) changed = true;\n  }\n  return changed;\n}\n\nfunction checkAndUpdateElementValue(view: ViewData, def: NodeDef, bindingIdx: number, value: any) {\n  if (!checkAndUpdateBinding(view, def, bindingIdx, value)) {\n    return false;\n  }\n  const binding = def.bindings[bindingIdx];\n  const elData = asElementData(view, def.nodeIndex);\n  const renderNode = elData.renderElement;\n  const name = binding.name!;\n  switch (binding.flags & BindingFlags.Types) {\n    case BindingFlags.TypeElementAttribute:\n      setElementAttribute(view, binding, renderNode, binding.ns, name, value);\n      break;\n    case BindingFlags.TypeElementClass:\n      setElementClass(view, renderNode, name, value);\n      break;\n    case BindingFlags.TypeElementStyle:\n      setElementStyle(view, binding, renderNode, name, value);\n      break;\n    case BindingFlags.TypeProperty:\n      const bindView = (def.flags & NodeFlags.ComponentView &&\n                        binding.flags & BindingFlags.SyntheticHostProperty) ?\n          elData.componentView :\n          view;\n      setElementProperty(bindView, binding, renderNode, name, value);\n      break;\n  }\n  return true;\n}\n\nfunction setElementAttribute(\n    view: ViewData, binding: BindingDef, renderNode: any, ns: string|null, name: string,\n    value: any) {\n  const securityContext = binding.securityContext;\n  let renderValue = securityContext ? view.root.sanitizer.sanitize(securityContext, value) : value;\n  renderValue = renderValue != null ? renderValue.toString() : null;\n  const renderer = view.renderer;\n  if (value != null) {\n    renderer.setAttribute(renderNode, name, renderValue, ns);\n  } else {\n    renderer.removeAttribute(renderNode, name, ns);\n  }\n}\n\nfunction setElementClass(view: ViewData, renderNode: any, name: string, value: boolean) {\n  const renderer = view.renderer;\n  if (value) {\n    renderer.addClass(renderNode, name);\n  } else {\n    renderer.removeClass(renderNode, name);\n  }\n}\n\nfunction setElementStyle(\n    view: ViewData, binding: BindingDef, renderNode: any, name: string, value: any) {\n  let renderValue: string|null =\n      view.root.sanitizer.sanitize(SecurityContext.STYLE, value as {} | string);\n  if (renderValue != null) {\n    renderValue = renderValue.toString();\n    const unit = binding.suffix;\n    if (unit != null) {\n      renderValue = renderValue + unit;\n    }\n  } else {\n    renderValue = null;\n  }\n  const renderer = view.renderer;\n  if (renderValue != null) {\n    renderer.setStyle(renderNode, name, renderValue);\n  } else {\n    renderer.removeStyle(renderNode, name);\n  }\n}\n\nfunction setElementProperty(\n    view: ViewData, binding: BindingDef, renderNode: any, name: string, value: any) {\n  const securityContext = binding.securityContext;\n  let renderValue = securityContext ? view.root.sanitizer.sanitize(securityContext, value) : value;\n  view.renderer.setProperty(renderNode, name, renderValue);\n}\n"]} |
\ | No newline at end of file |