UNPKG

aurelia-form

Version:

Makes working with forms just a tad more pleasant.

186 lines (151 loc) 6.7 kB
var _dec, _dec2, _dec3, _dec4, _class, _desc, _value, _class2, _descriptor, _descriptor2, _descriptor3, _descriptor4, _descriptor5, _descriptor6, _descriptor7, _descriptor8, _descriptor9, _descriptor10, _descriptor11, _descriptor12, _descriptor13, _descriptor14, _descriptor15; function _initDefineProp(target, property, descriptor, context) { if (!descriptor) return; Object.defineProperty(target, property, { enumerable: descriptor.enumerable, configurable: descriptor.configurable, writable: descriptor.writable, value: descriptor.initializer ? descriptor.initializer.call(context) : void 0 }); } function _applyDecoratedDescriptor(target, property, decorators, descriptor, context) { var desc = {}; Object['ke' + 'ys'](descriptor).forEach(function (key) { desc[key] = descriptor[key]; }); desc.enumerable = !!desc.enumerable; desc.configurable = !!desc.configurable; if ('value' in desc || desc.initializer) { desc.writable = true; } desc = decorators.slice().reverse().reduce(function (desc, decorator) { return decorator(target, property, desc) || desc; }, desc); if (context && desc.initializer !== void 0) { desc.value = desc.initializer ? desc.initializer.call(context) : void 0; desc.initializer = undefined; } if (desc.initializer === void 0) { Object['define' + 'Property'](target, property, desc); desc = null; } return desc; } function _initializerWarningHelper(descriptor, context) { throw new Error('Decorating class property failed. Please ensure that transform-class-properties is enabled.'); } import { Configuration } from 'aurelia-config'; import { inject, bindable, customElement, bindingMode, TemplatingEngine } from 'aurelia-framework'; import { resolvedView } from 'aurelia-view-manager'; import { logger } from '../aurelia-form'; import { DOM } from 'aurelia-pal'; export let FormElement = (_dec = resolvedView('spoonx/form', 'form-element'), _dec2 = customElement('form-element'), _dec3 = inject(Configuration.of('aurelia-form'), DOM.Element, TemplatingEngine), _dec4 = bindable({ defaultBindingMode: bindingMode.twoWay }), _dec(_class = _dec2(_class = _dec3(_class = (_class2 = class FormElement { constructor(config, DOMElement, templatingEngine) { _initDefineProp(this, 'type', _descriptor, this); _initDefineProp(this, 'element', _descriptor2, this); _initDefineProp(this, 'DOMElement', _descriptor3, this); _initDefineProp(this, 'value', _descriptor4, this); _initDefineProp(this, 'name', _descriptor5, this); _initDefineProp(this, 'classes', _descriptor6, this); _initDefineProp(this, 'placeholder', _descriptor7, this); _initDefineProp(this, 'readonly', _descriptor8, this); _initDefineProp(this, 'disabled', _descriptor9, this); _initDefineProp(this, 'multiple', _descriptor10, this); _initDefineProp(this, 'options', _descriptor11, this); _initDefineProp(this, 'selectOptions', _descriptor12, this); _initDefineProp(this, 'optionLabel', _descriptor13, this); _initDefineProp(this, 'autofocus', _descriptor14, this); _initDefineProp(this, 'required', _descriptor15, this); this.proxyAttributes = ['value', 'name', 'classes', 'placeholder', 'readonly', 'disabled', 'options', 'type', 'multiple', 'selectOptions', 'optionLabel', 'autofocus', 'required']; this.config = config; this.DOMElement = DOMElement; this.templatingEngine = templatingEngine; } attached() { let element = DOM.createElement(this.getElementName()); this.setAttributes(element); this.DOMElement.appendChild(element); this.templatingEngine.enhance({ element: element, bindingContext: this }).attached(); } setAttributes(DOMElement) { this.proxyAttributes.forEach(attribute => { let attributeName = attribute.replace(/[A-Z]/g, (match, offset) => { return (offset ? '-' : '') + match.toLowerCase(); }); DOMElement.setAttribute(`${attributeName}.bind`, attribute); }); } getElementName() { let elementName = this.config.elements[this.config.aliases[this.element] || this.element]; if (!elementName) { logger.warn(`Unable to find element for element '${this.element}'. Falling back to default '${this.config.defaultElement}'.`); elementName = this.config.elements[this.config.defaultElement]; } return elementName; } }, (_descriptor = _applyDecoratedDescriptor(_class2.prototype, 'type', [bindable], { enumerable: true, initializer: function () { return 'text'; } }), _descriptor2 = _applyDecoratedDescriptor(_class2.prototype, 'element', [bindable], { enumerable: true, initializer: function () { return 'input'; } }), _descriptor3 = _applyDecoratedDescriptor(_class2.prototype, 'DOMElement', [bindable], { enumerable: true, initializer: null }), _descriptor4 = _applyDecoratedDescriptor(_class2.prototype, 'value', [_dec4], { enumerable: true, initializer: null }), _descriptor5 = _applyDecoratedDescriptor(_class2.prototype, 'name', [bindable], { enumerable: true, initializer: function () { return ''; } }), _descriptor6 = _applyDecoratedDescriptor(_class2.prototype, 'classes', [bindable], { enumerable: true, initializer: function () { return ''; } }), _descriptor7 = _applyDecoratedDescriptor(_class2.prototype, 'placeholder', [bindable], { enumerable: true, initializer: function () { return ''; } }), _descriptor8 = _applyDecoratedDescriptor(_class2.prototype, 'readonly', [bindable], { enumerable: true, initializer: function () { return false; } }), _descriptor9 = _applyDecoratedDescriptor(_class2.prototype, 'disabled', [bindable], { enumerable: true, initializer: function () { return false; } }), _descriptor10 = _applyDecoratedDescriptor(_class2.prototype, 'multiple', [bindable], { enumerable: true, initializer: function () { return false; } }), _descriptor11 = _applyDecoratedDescriptor(_class2.prototype, 'options', [bindable], { enumerable: true, initializer: function () { return {}; } }), _descriptor12 = _applyDecoratedDescriptor(_class2.prototype, 'selectOptions', [bindable], { enumerable: true, initializer: function () { return []; } }), _descriptor13 = _applyDecoratedDescriptor(_class2.prototype, 'optionLabel', [bindable], { enumerable: true, initializer: null }), _descriptor14 = _applyDecoratedDescriptor(_class2.prototype, 'autofocus', [bindable], { enumerable: true, initializer: null }), _descriptor15 = _applyDecoratedDescriptor(_class2.prototype, 'required', [bindable], { enumerable: true, initializer: null })), _class2)) || _class) || _class) || _class);