UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

126 lines (110 loc) 4.55 kB
import {StringWrapper, RegExpWrapper, BaseException, isPresent, isBlank, isString, stringify} from 'angular2/src/facade/lang'; import {ListWrapper, StringMapWrapper} from 'angular2/src/facade/collection'; import {DOM} from 'angular2/src/dom/dom_adapter'; import {camelCaseToDashCase, dashCaseToCamelCase} from '../util'; import {reflector} from 'angular2/src/reflection/reflection'; const STYLE_SEPARATOR = '.'; var propertySettersCache = StringMapWrapper.create(); var innerHTMLSetterCache; export function setterFactory(property: string): Function { var setterFn, styleParts, styleSuffix; if (StringWrapper.startsWith(property, ATTRIBUTE_PREFIX)) { setterFn = attributeSetterFactory(StringWrapper.substring(property, ATTRIBUTE_PREFIX.length)); } else if (StringWrapper.startsWith(property, CLASS_PREFIX)) { setterFn = classSetterFactory(StringWrapper.substring(property, CLASS_PREFIX.length)); } else if (StringWrapper.startsWith(property, STYLE_PREFIX)) { styleParts = property.split(STYLE_SEPARATOR); styleSuffix = styleParts.length > 2 ? ListWrapper.get(styleParts, 2) : ''; setterFn = styleSetterFactory(ListWrapper.get(styleParts, 1), styleSuffix); } else if (StringWrapper.equals(property, 'innerHtml')) { if (isBlank(innerHTMLSetterCache)) { innerHTMLSetterCache = (el, value) => DOM.setInnerHTML(el, value); } setterFn = innerHTMLSetterCache; } else { property = resolvePropertyName(property); setterFn = StringMapWrapper.get(propertySettersCache, property); if (isBlank(setterFn)) { var propertySetterFn = reflector.setter(property); setterFn = function(receiver, value) { if (DOM.hasProperty(receiver, property)) { return propertySetterFn(receiver, value); } }; StringMapWrapper.set(propertySettersCache, property, setterFn); } } return setterFn; } const ATTRIBUTE_PREFIX = 'attr.'; var attributeSettersCache = StringMapWrapper.create(); function _isValidAttributeValue(attrName:string, value: any): boolean { if (attrName == "role") { return isString(value); } else { return isPresent(value); } } function attributeSetterFactory(attrName:string): Function { var setterFn = StringMapWrapper.get(attributeSettersCache, attrName); var dashCasedAttributeName; if (isBlank(setterFn)) { dashCasedAttributeName = camelCaseToDashCase(attrName); setterFn = function(element, value) { if (_isValidAttributeValue(dashCasedAttributeName, value)) { DOM.setAttribute(element, dashCasedAttributeName, stringify(value)); } else { if (isPresent(value)) { throw new BaseException("Invalid " + dashCasedAttributeName + " attribute, only string values are allowed, got '" + stringify(value) + "'"); } DOM.removeAttribute(element, dashCasedAttributeName); } }; StringMapWrapper.set(attributeSettersCache, attrName, setterFn); } return setterFn; } const CLASS_PREFIX = 'class.'; var classSettersCache = StringMapWrapper.create(); function classSetterFactory(className:string): Function { var setterFn = StringMapWrapper.get(classSettersCache, className); var dashCasedClassName; if (isBlank(setterFn)) { dashCasedClassName = camelCaseToDashCase(className); setterFn = function(element, value) { if (value) { DOM.addClass(element, dashCasedClassName); } else { DOM.removeClass(element, dashCasedClassName); } }; StringMapWrapper.set(classSettersCache, className, setterFn); } return setterFn; } const STYLE_PREFIX = 'style.'; var styleSettersCache = StringMapWrapper.create(); function styleSetterFactory(styleName:string, styleSuffix:string): Function { var cacheKey = styleName + styleSuffix; var setterFn = StringMapWrapper.get(styleSettersCache, cacheKey); var dashCasedStyleName; if (isBlank(setterFn)) { dashCasedStyleName = camelCaseToDashCase(styleName); setterFn = function(element, value) { var valAsStr; if (isPresent(value)) { valAsStr = stringify(value); DOM.setStyle(element, dashCasedStyleName, valAsStr + styleSuffix); } else { DOM.removeStyle(element, dashCasedStyleName); } }; StringMapWrapper.set(styleSettersCache, cacheKey, setterFn); } return setterFn; } function resolvePropertyName(attrName:string): string { var mappedPropName = StringMapWrapper.get(DOM.attrToPropMap, attrName); return isPresent(mappedPropName) ? mappedPropName : attrName; }