UNPKG

@stratio/egeo

Version:
474 lines 36.7 kB
/** * @fileoverview added by tsickle * Generated from: lib/st-form/st-form-field/st-form-field.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /* * © 2017 Stratio Big Data Inc., Sucursal en España. * * This software is licensed under the Apache License, Version 2.0. * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the terms of the License for more details. * * SPDX-License-Identifier: Apache-2.0. */ import { Component, Input, Output, forwardRef, ChangeDetectionStrategy, EventEmitter, ViewChild, HostBinding } from '@angular/core'; import { NG_VALUE_ACCESSOR, NG_VALIDATORS, NgModel } from '@angular/forms'; import { StEgeo, StRequired } from '../../decorators/require-decorators'; var StFormFieldComponent = /** @class */ (function () { function StFormFieldComponent() { this.required = false; this.showTooltip = true; this.valueChange = new EventEmitter(); this.blur = new EventEmitter(); this.disabled = false; // To check disable // To check disable this.focus = false; this.errorMessage = undefined; this.onChange = (/** * @param {?} _ * @return {?} */ function (_) { }); this.onTouched = (/** * @return {?} */ function () { }); } StFormFieldComponent_1 = StFormFieldComponent; Object.defineProperty(StFormFieldComponent.prototype, "readOnly", { get: /** * @return {?} */ function () { return this.schema && this.schema.value && this.schema.value.readOnly === true; }, enumerable: true, configurable: true }); /** * @param {?} value * @return {?} */ StFormFieldComponent.prototype.setValue = /** * @param {?} value * @return {?} */ function (value) { this.onChange(value); this.valueChange.emit(value); }; /** * @param {?} enabled * @return {?} */ StFormFieldComponent.prototype.setSwitchValue = /** * @param {?} enabled * @return {?} */ function (enabled) { this.onChange(enabled || undefined); this.valueChange.emit(enabled || undefined); }; /** * @param {?} control * @return {?} */ StFormFieldComponent.prototype.validate = /** * @param {?} control * @return {?} */ function (control) { if (this.templateModel && this.templateModel.control && this.templateModel.control.validator) { return this.templateModel.control.validator(control); } }; /** * @return {?} */ StFormFieldComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; if (this.schema.value && this.schema.value.enum) { this.selectOptions = this.getSelectOptions(); } setTimeout((/** * @return {?} */ function () { if (_this.default !== undefined && (_this.innerValue === undefined || _this.innerValue === null)) { _this.innerValue = _this.default; _this.onChange(_this.innerValue); } if (_this.schema.value.readOnly) { _this.setDisabledState(true); } })); }; /** * @param {?} changes * @return {?} */ StFormFieldComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.schema) { this.selectOptions = this.getSelectOptions(); } }; Object.defineProperty(StFormFieldComponent.prototype, "errors", { get: /** * @return {?} */ function () { if (this.errorMessages) { return this.errorMessages; } return { generic: 'Error', required: 'This field is required', minLength: 'The field min length is ' + this.schema.value.minLength, maxLength: 'The field max length is ' + this.schema.value.maxLength, min: 'The number has to be higher than ' + (this.min - this.getInputStep()), max: 'The number has to be minor than ' + (this.max + this.getInputStep()), pattern: 'Invalid value' }; }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "type", { get: /** * @return {?} */ function () { switch (this.schema.value.type) { case 'string': if (!this.schema.value.enum) { return 'text'; } else { return 'select'; } case 'integer': return 'number'; default: return this.schema.value.type; } }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "min", { get: /** * @return {?} */ function () { return this.schema.value.exclusiveMinimum ? this.schema.value.minimum + this.getInputStep() : this.schema.value.minimum; }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "max", { get: /** * @return {?} */ function () { return this.schema.value.exclusiveMaximum ? this.schema.value.maximum - this.getInputStep() : this.schema.value.maximum; }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "label", { get: /** * @return {?} */ function () { return this.schema.value.title; }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "placeholder", { get: /** * @return {?} */ function () { return this.schema.value.examples && this.schema.value.examples[0] ? this.schema.value.examples[0] : ''; }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "default", { get: /** * @return {?} */ function () { return this.schema.value.default; }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "description", { get: /** * @return {?} */ function () { if (this.showTooltip) { return this.schema.value.description; } else { return undefined; } }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "minLength", { get: /** * @return {?} */ function () { return this.schema.value.minLength; }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "maxLength", { get: /** * @return {?} */ function () { return this.schema.value.maxLength; }, enumerable: true, configurable: true }); Object.defineProperty(StFormFieldComponent.prototype, "pattern", { get: /** * @return {?} */ function () { return this.schema.value.pattern; }, enumerable: true, configurable: true }); /** * @param {?} type * @return {?} */ StFormFieldComponent.prototype.hasType = /** * @param {?} type * @return {?} */ function (type) { switch (type) { case 'input': return this.type === 'text' || this.type === 'number' || this.type === 'integer'; case 'switch': return this.type === 'boolean' && this.hasDependencies; case 'checkbox': return this.type === 'boolean' && !this.hasDependencies; default: return this.type === type; } }; /** * @param {?} value * @return {?} */ StFormFieldComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { this.innerValue = value; this.valueChange.emit(value); this.onChange(value); }; /** * @param {?} fn * @return {?} */ StFormFieldComponent.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.onChange = fn; }; /** * @param {?} fn * @return {?} */ StFormFieldComponent.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** * @param {?} disable * @return {?} */ StFormFieldComponent.prototype.setDisabledState = /** * @param {?} disable * @return {?} */ function (disable) { if (this.templateModel && this.templateModel.control) { if (disable) { this.templateModel.control.disable(); } else { this.templateModel.control.enable(); } } }; /** * @return {?} */ StFormFieldComponent.prototype.getInputStep = /** * @return {?} */ function () { if (this.schema.value.type === 'number') { return 0.1; } else { return 1; } }; /** * @return {?} */ StFormFieldComponent.prototype.getSelectOptions = /** * @return {?} */ function () { /** @type {?} */ var options = []; if (this.schema.value.enum) { options.push((/** @type {?} */ ({ label: 'Select one option', value: undefined }))); /** @type {?} */ var enumValues = this.schema.value.enum; enumValues.forEach((/** * @param {?} value * @return {?} */ function (value) { options.push((/** @type {?} */ ({ label: value, value: value }))); })); } return options; }; /** * @return {?} */ StFormFieldComponent.prototype.onBlur = /** * @return {?} */ function () { this.blur.emit(); }; var StFormFieldComponent_1; StFormFieldComponent.decorators = [ { type: Component, args: [{ selector: 'st-form-field', template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n\n<st-input *ngIf=\"hasType('input') && (!maxWidth || (!maxLength || maxLength < maxWidth) && (!minLength || minLength < maxWidth))\"\n #templateModel=\"ngModel\"\n [forceValidations]=\"forceValidations\"\n [fieldType]=\"type\"\n [label]=\"label\"\n [name]=\"schema.key\"\n [placeholder]=\"placeholder\"\n [ngModel]=\"innerValue\"\n (ngModelChange)=\"setValue($event)\"\n [contextualHelp]=\"description\"\n [errors]=\"errors\"\n [default]=\"default\"\n [max]=\"max\"\n [min]=\"min\"\n [minlength]=\"minLength\"\n [maxlength]=\"maxLength\"\n [required]=\"required\"\n [pattern]=\"pattern\"\n [step]=\"getInputStep()\"\n [qaTag]=\"qaTag\"\n (blur)=\"onBlur()\">\n</st-input>\n\n<st-textarea *ngIf=\"hasType('input') && maxWidth && (maxLength >= maxWidth || minLength >= maxWidth)\"\n #templateModel=\"ngModel\"\n [label]=\"label\"\n [name]=\"schema.key\"\n [default]=\"default\"\n [placeholder]=\"placeholder\"\n [ngModel]=\"innerValue\"\n (ngModelChange)=\"setValue($event)\"\n [contextualHelp]=\"description\"\n [errors]=\"errors\"\n [minlength]=\"minLength\"\n [maxlength]=\"maxLength\"\n [required]=\"required\"\n [pattern]=\"pattern\"\n [qaTag]=\"qaTag\"\n (blur)=\"onBlur()\">\n</st-textarea>\n\n<st-checkbox *ngIf=\"hasType('checkbox')\"\n #templateModel=\"ngModel\"\n [ngModel]=\"innerValue\"\n (ngModelChange)=\"setValue($event)\"\n [checked]=\"innerValue\"\n [value]=\"innerValue\"\n [name]=\"schema.key\"\n [contextualHelp]=\"description\"\n [qaTag]=\"qaTag\"><span>{{schema.value.title}}</span>\n</st-checkbox>\n\n<st-select *ngIf=\"hasType('select')\"\n #templateModel=\"ngModel\"\n [label]=\"label\"\n [tooltip]=\"description\"\n [name]=\"schema.key\"\n [placeholder]=\"placeholder\"\n [default]=\"default\"\n [options]=\"selectOptions\"\n [ngModel]=\"innerValue\"\n (ngModelChange)=\"setValue($event)\"\n [required]=\"required\"\n [id]=\"qaTag\">\n</st-select>\n\n<st-switch *ngIf=\"hasType('switch')\"\n #templateModel=\"ngModel\"\n [label]=\"schema.value.title\"\n [name]=\"schema.key\"\n [contextualHelp]=\"description\"\n [ngModel]=\"innerValue\"\n (ngModelChange)=\"setValue($event)\"\n [value]=\"innerValue\"\n [qaTag]=\"schema.key\"\n [id]=\"qaTag\">\n</st-switch>\n", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return StFormFieldComponent_1; })), multi: true }, { provide: NG_VALIDATORS, useExisting: forwardRef((/** * @return {?} */ function () { return StFormFieldComponent_1; })), multi: true } ], changeDetection: ChangeDetectionStrategy.OnPush, host: { class: 'st-form-field' }, styles: ["@charset \"UTF-8\";"] }] } ]; StFormFieldComponent.propDecorators = { schema: [{ type: Input }], required: [{ type: Input }], errorMessages: [{ type: Input }], qaTag: [{ type: Input }], name: [{ type: Input }], value: [{ type: Input }], hasDependencies: [{ type: Input }], forceValidations: [{ type: Input }], showTooltip: [{ type: Input }], maxWidth: [{ type: Input }], valueChange: [{ type: Output }], blur: [{ type: Output }], templateModel: [{ type: ViewChild, args: ['templateModel', { static: false },] }], readOnly: [{ type: HostBinding, args: ['class.read-only',] }] }; tslib_1.__decorate([ StRequired(), tslib_1.__metadata("design:type", Object) ], StFormFieldComponent.prototype, "schema", void 0); StFormFieldComponent = StFormFieldComponent_1 = tslib_1.__decorate([ StEgeo() ], StFormFieldComponent); return StFormFieldComponent; }()); export { StFormFieldComponent }; if (false) { /** @type {?} */ StFormFieldComponent.prototype.schema; /** @type {?} */ StFormFieldComponent.prototype.required; /** @type {?} */ StFormFieldComponent.prototype.errorMessages; /** @type {?} */ StFormFieldComponent.prototype.qaTag; /** @type {?} */ StFormFieldComponent.prototype.name; /** @type {?} */ StFormFieldComponent.prototype.value; /** @type {?} */ StFormFieldComponent.prototype.hasDependencies; /** @type {?} */ StFormFieldComponent.prototype.forceValidations; /** @type {?} */ StFormFieldComponent.prototype.showTooltip; /** @type {?} */ StFormFieldComponent.prototype.maxWidth; /** @type {?} */ StFormFieldComponent.prototype.valueChange; /** @type {?} */ StFormFieldComponent.prototype.blur; /** @type {?} */ StFormFieldComponent.prototype.templateModel; /** @type {?} */ StFormFieldComponent.prototype.disabled; /** @type {?} */ StFormFieldComponent.prototype.focus; /** @type {?} */ StFormFieldComponent.prototype.errorMessage; /** @type {?} */ StFormFieldComponent.prototype.selectOptions; /** @type {?} */ StFormFieldComponent.prototype.innerValue; /** @type {?} */ StFormFieldComponent.prototype.onChange; /** @type {?} */ StFormFieldComponent.prototype.onTouched; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-form-field.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-form/st-form-field/st-form-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\nimport {\n   Component,\n   OnInit,\n   Input,\n   Output,\n   forwardRef,\n   ChangeDetectionStrategy,\n   EventEmitter,\n   ViewChild,\n   HostBinding, OnChanges, SimpleChanges\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, FormControl, NG_VALIDATORS, NgModel } from '@angular/forms';\nimport { StInputError } from '../../st-input/st-input.error.model';\nimport { StEgeo, StRequired } from '../../decorators/require-decorators';\nimport { StDropDownMenuItem } from '../../st-dropdown-menu/st-dropdown-menu.interface';\n\n@StEgeo()\n@Component({\n   selector: 'st-form-field',\n   templateUrl: './st-form-field.component.html',\n   styleUrls: ['./st-form-field.component.scss'],\n   providers: [\n      { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => StFormFieldComponent), multi: true },\n      { provide: NG_VALIDATORS, useExisting: forwardRef(() => StFormFieldComponent), multi: true }\n   ],\n   changeDetection: ChangeDetectionStrategy.OnPush,\n   host: {\n      class: 'st-form-field'\n   }\n})\n\nexport class StFormFieldComponent implements ControlValueAccessor, OnInit, OnChanges {\n   @Input() @StRequired() schema: any;\n   @Input() required: boolean = false;\n   @Input() errorMessages: StInputError;\n   @Input() qaTag: string;\n   @Input() name: string;\n   @Input() value: any;\n   @Input() hasDependencies: boolean;\n   @Input() forceValidations: boolean;\n   @Input() showTooltip: boolean = true;\n   @Input() maxWidth: number;\n   @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n   @Output() blur: EventEmitter<any> = new EventEmitter<any>();\n   @ViewChild('templateModel', {static: false}) templateModel: NgModel;\n\n   public disabled: boolean = false; // To check disable\n   public focus: boolean = false;\n   public errorMessage: string = undefined;\n   public selectOptions: StDropDownMenuItem[];\n   public innerValue: any;\n\n   @HostBinding('class.read-only')\n   get readOnly(): boolean {\n      return this.schema && this.schema.value && this.schema.value.readOnly === true;\n   }\n\n   onChange = (_: any) => {\n   }\n\n   onTouched = () => {\n   }\n\n   setValue(value: any): void {\n      this.onChange(value);\n      this.valueChange.emit(value);\n   }\n\n   setSwitchValue(enabled: boolean): void {\n      this.onChange(enabled || undefined);\n      this.valueChange.emit(enabled || undefined);\n   }\n\n   validate(control: FormControl): any {\n      if (this.templateModel && this.templateModel.control && this.templateModel.control.validator) {\n         return this.templateModel.control.validator(control);\n      }\n   }\n\n   ngOnInit(): void {\n      if (this.schema.value && this.schema.value.enum) {\n         this.selectOptions = this.getSelectOptions();\n      }\n      setTimeout(() => {\n         if (this.default !== undefined && (this.innerValue === undefined || this.innerValue === null)) {\n            this.innerValue = this.default;\n            this.onChange(this.innerValue);\n         }\n         if (this.schema.value.readOnly) {\n            this.setDisabledState(true);\n         }\n      });\n   }\n\n   public ngOnChanges(changes: SimpleChanges): void {\n      if (changes.schema) {\n        this.selectOptions = this.getSelectOptions();\n      }\n   }\n\n   get errors(): any {\n      if (this.errorMessages) {\n         return this.errorMessages;\n      }\n\n      return {\n         generic: 'Error',\n         required: 'This field is required',\n         minLength: 'The field min length is ' + this.schema.value.minLength,\n         maxLength: 'The field max length is ' + this.schema.value.maxLength,\n         min: 'The number has to be higher than ' + (this.min - this.getInputStep()),\n         max: 'The number has to be minor than ' + (this.max + this.getInputStep()),\n         pattern: 'Invalid value'\n      };\n   }\n\n   get type(): string {\n      switch (this.schema.value.type) {\n         case 'string':\n            if (!this.schema.value.enum) {\n               return 'text';\n            } else {\n               return 'select';\n            }\n         case 'integer':\n            return 'number';\n         default:\n            return this.schema.value.type;\n      }\n   }\n\n   get min(): number {\n      return this.schema.value.exclusiveMinimum ? this.schema.value.minimum + this.getInputStep() : this.schema.value.minimum;\n   }\n\n   get max(): number {\n      return this.schema.value.exclusiveMaximum ? this.schema.value.maximum - this.getInputStep() : this.schema.value.maximum;\n   }\n\n   get label(): string {\n      return this.schema.value.title;\n   }\n\n   get placeholder(): string {\n      return this.schema.value.examples && this.schema.value.examples[0] ? this.schema.value.examples[0] : '';\n   }\n\n   get default(): string {\n      return this.schema.value.default;\n   }\n\n   get description(): string {\n      if (this.showTooltip) {\n         return this.schema.value.description;\n      } else {\n         return undefined;\n      }\n   }\n\n   get minLength(): number {\n      return this.schema.value.minLength;\n   }\n\n   get maxLength(): number {\n      return this.schema.value.maxLength;\n   }\n\n   get pattern(): string {\n      return this.schema.value.pattern;\n   }\n\n   hasType(type: string): boolean {\n      switch (type) {\n         case 'input':\n            return this.type === 'text' || this.type === 'number' || this.type === 'integer';\n         case 'switch':\n            return this.type === 'boolean' && this.hasDependencies;\n         case 'checkbox':\n            return this.type === 'boolean' && !this.hasDependencies;\n         default:\n            return this.type === type;\n      }\n   }\n\n   writeValue(value: any): void {\n         this.innerValue = value;\n         this.valueChange.emit(value);\n         this.onChange(value);\n   }\n\n   registerOnChange(fn: (_: any) => void): void {\n      this.onChange = fn;\n   }\n\n   registerOnTouched(fn: () => void): void {\n      this.onTouched = fn;\n   }\n\n   setDisabledState(disable: boolean): void {\n      if (this.templateModel && this.templateModel.control) {\n         if (disable) {\n            this.templateModel.control.disable();\n         } else {\n            this.templateModel.control.enable();\n         }\n      }\n   }\n\n   getInputStep(): number {\n      if (this.schema.value.type === 'number') {\n         return 0.1;\n      } else {\n         return 1;\n      }\n   }\n\n   getSelectOptions(): StDropDownMenuItem[] {\n      let options: StDropDownMenuItem[] = [];\n      if (this.schema.value.enum) {\n         options.push(<StDropDownMenuItem> { label: 'Select one option', value: undefined });\n         let enumValues: string[] = this.schema.value.enum;\n         enumValues.forEach((value) => {\n            options.push(<StDropDownMenuItem> { label: value, value: value });\n         });\n      }\n      return options;\n   }\n\n   onBlur(): void {\n      this.blur.emit();\n   }\n}\n"]}