UNPKG

@stratio/egeo

Version:
410 lines 38.5 kB
var StFormFieldComponent_1; /** * @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 { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, HostBinding, Input, Output, ViewChild } from '@angular/core'; import { NG_VALIDATORS, NG_VALUE_ACCESSOR, NgModel } from '@angular/forms'; import { StEgeo, StRequired } from '../../decorators/require-decorators'; let StFormFieldComponent = StFormFieldComponent_1 = class StFormFieldComponent { constructor() { this.required = false; this.showTooltip = true; this.clickLink = new EventEmitter(); this.valueChange = new EventEmitter(); this.blur = new EventEmitter(); this.disabled = false; // To check disable // To check disable this.focus = false; this.errorMessage = undefined; this._defaultErrorMessages = { generic: 'Error', required: 'This field is required', minLength: 'The field min length is ', maxLength: 'The field max length is ', min: 'The number has to be higher than ', max: 'The number has to be minor than ', pattern: 'Invalid value' }; this.onChange = (/** * @param {?} _ * @return {?} */ (_) => { }); this.onTouched = (/** * @return {?} */ () => { }); } /** * @return {?} */ get schema() { return this._schema; } /** * @param {?} schema * @return {?} */ set schema(schema) { this._schema = schema; this.selectOptions = this.getSelectOptions(); } /** * @return {?} */ get readOnly() { return this._schema && this._schema.value && this._schema.value.readOnly === true; } /** * @param {?} value * @return {?} */ setValue(value) { this.onChange(value); this.valueChange.emit(value); } /** * @param {?} control * @return {?} */ validate(control) { if (this.templateModel && this.templateModel.control && this.templateModel.control.validator) { return this.templateModel.control.validator(control); } } /** * @return {?} */ ngOnInit() { if (this._schema.value && this._schema.value.enum) { this.selectOptions = this.getSelectOptions(); } this._loadErrorMessages(); setTimeout((/** * @return {?} */ () => { 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); } })); } /** * @return {?} */ get type() { switch (this._schema.value.type) { case 'string': return this._schema.value.enum ? 'select' : 'text'; case 'integer': return this._schema.value.enum ? 'select' : 'number'; default: return (/** @type {?} */ (this._schema.value.type)); } } /** * @return {?} */ get min() { return this._schema.value.exclusiveMinimum ? this._schema.value.minimum + this.getInputStep() : this._schema.value.minimum; } /** * @return {?} */ get max() { return this._schema.value.exclusiveMaximum ? this._schema.value.maximum - this.getInputStep() : this._schema.value.maximum; } /** * @return {?} */ get label() { return this._schema.value.title; } /** * @return {?} */ get placeholder() { return this._schema.value.examples && this._schema.value.examples[0] ? this._schema.value.examples[0] : ''; } /** * @return {?} */ get default() { return this._schema.value.default; } /** * @return {?} */ get description() { if (this.showTooltip) { return this._schema.value.description; } else { return undefined; } } /** * @return {?} */ get minLength() { return this._schema.value.minLength; } /** * @return {?} */ get maxLength() { return this._schema.value.maxLength; } /** * @return {?} */ get pattern() { return this._schema.value.pattern; } /** * @param {?} type * @return {?} */ hasType(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 {?} */ writeValue(value) { this.innerValue = value; this.valueChange.emit(value); this.onChange(value); } /** * @param {?} fn * @return {?} */ registerOnChange(fn) { this.onChange = fn; } /** * @param {?} fn * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @param {?} disable * @return {?} */ setDisabledState(disable) { if (this.templateModel && this.templateModel.control) { if (disable) { this.templateModel.control.disable(); } else { this.templateModel.control.enable(); } } } /** * @return {?} */ getInputStep() { if (this._schema.value.type === 'number') { return 0.1; } else { return 1; } } /** * @return {?} */ getSelectOptions() { /** @type {?} */ let options = []; if (this._schema.value.enum) { /** @type {?} */ const placeholder = (this.translations && this.translations.placeholder) || 'Select one option'; options.push((/** @type {?} */ ({ label: placeholder, value: undefined }))); /** @type {?} */ let enumValues = (/** @type {?} */ (this._schema.value.enum)); /** @type {?} */ const uiOptions = (this._schema.value.ui && this._schema.value.ui.options) || []; options.push(...uiOptions); enumValues.forEach((/** * @param {?} value * @return {?} */ (value) => { if (!options.find((/** * @param {?} _option * @return {?} */ _option => _option.value === value))) { options.push((/** @type {?} */ ({ label: value, value: value }))); } })); } return options; } /** * @return {?} */ onBlur() { this.blur.emit(); } /** * @return {?} */ onClickLink() { this.clickLink.emit(this._schema.key); } /** * @private * @return {?} */ _loadErrorMessages() { this.errors = { required: (this.errorMessages && this.errorMessages.required) || this._defaultErrorMessages.required, pattern: (this.errorMessages && this.errorMessages.pattern) || this._defaultErrorMessages.pattern, generic: (this.errorMessages && this.errorMessages.generic) || this._defaultErrorMessages.generic, minLength: ((this.errorMessages && this.errorMessages.minLength) || this._defaultErrorMessages.minLength) + this._schema.value.minLength, maxLength: ((this.errorMessages && this.errorMessages.maxLength) || this._defaultErrorMessages.maxLength) + this._schema.value.maxLength, min: ((this.errorMessages && this.errorMessages.min) || this._defaultErrorMessages.min) + (this.min - this.getInputStep()), max: ((this.errorMessages && this.errorMessages.max) || this._defaultErrorMessages.max) + (this.max + this.getInputStep()) }; } }; 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\n<span *ngIf=\"schema?.value?.ui?.link\" class=\"button button-link small\" (click)=\"onClickLink()\">{{schema.value.ui.link}}</span>\n", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ () => StFormFieldComponent_1)), multi: true }, { provide: NG_VALIDATORS, useExisting: forwardRef((/** * @return {?} */ () => StFormFieldComponent_1)), multi: true } ], changeDetection: ChangeDetectionStrategy.OnPush, host: { class: 'st-form-field' }, styles: ["@charset \"UTF-8\";"] }] } ]; StFormFieldComponent.propDecorators = { 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 }], translations: [{ type: Input }], clickLink: [{ type: Output }], valueChange: [{ type: Output }], blur: [{ type: Output }], templateModel: [{ type: ViewChild, args: ['templateModel', { static: false },] }], schema: [{ type: Input }], readOnly: [{ type: HostBinding, args: ['class.read-only',] }] }; tslib_1.__decorate([ StRequired(), tslib_1.__metadata("design:type", Object), tslib_1.__metadata("design:paramtypes", [Object]) ], StFormFieldComponent.prototype, "schema", null); StFormFieldComponent = StFormFieldComponent_1 = tslib_1.__decorate([ StEgeo() ], StFormFieldComponent); export { StFormFieldComponent }; if (false) { /** @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.translations; /** @type {?} */ StFormFieldComponent.prototype.clickLink; /** @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.errors; /** * @type {?} * @private */ StFormFieldComponent.prototype._schema; /** * @type {?} * @private */ StFormFieldComponent.prototype._defaultErrorMessages; /** @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 { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, HostBinding, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, 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';\nimport { JSONSchema4Type, JSONSchema4TypeName } from 'json-schema';\nimport { StFormSchema } from '../st-form.model';\nimport { StFormFieldTranslations } from './st-form-field.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 {\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; // number of characters from witch inputs will be displayed as textarea\n   @Input() translations?: StFormFieldTranslations;\n   @Output() clickLink: EventEmitter<string> = new EventEmitter<string>();\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   public errors: StInputError;\n\n   private _schema: { key: string, value: StFormSchema };\n\n   private readonly _defaultErrorMessages: StInputError = {\n      generic: 'Error',\n      required: 'This field is required',\n      minLength: 'The field min length is ',\n      maxLength: 'The field max length is ',\n      min: 'The number has to be higher than ',\n      max: 'The number has to be minor than ',\n      pattern: 'Invalid value'\n   };\n\n   @Input() @StRequired()\n   get schema(): { key: string, value: StFormSchema } {\n      return this._schema;\n   }\n\n   set schema(schema: { key: string, value: StFormSchema }) {\n      this._schema = schema;\n      this.selectOptions = this.getSelectOptions();\n   }\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   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      this._loadErrorMessages();\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   get type(): string {\n      switch (this._schema.value.type) {\n         case 'string':\n            return this._schema.value.enum ? 'select' : 'text';\n         case 'integer':\n            return this._schema.value.enum ? 'select' : 'number';\n         default:\n            return <JSONSchema4TypeName> 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(): JSONSchema4Type {\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         const placeholder: string = (this.translations && this.translations.placeholder) || 'Select one option';\n         options.push(<StDropDownMenuItem> { label: placeholder, value: undefined });\n         let enumValues: any[] = <any[]> this._schema.value.enum;\n         const uiOptions: StDropDownMenuItem[] = (this._schema.value.ui && this._schema.value.ui.options) || [];\n         options.push(...uiOptions);\n         enumValues.forEach((value) => {\n            if (!options.find(_option => _option.value === value)) {\n               options.push(<StDropDownMenuItem> { label: value, value: value });\n            }\n         });\n      }\n      return options;\n   }\n\n   onBlur(): void {\n      this.blur.emit();\n   }\n\n   onClickLink(): void {\n      this.clickLink.emit(this._schema.key);\n   }\n\n   private _loadErrorMessages(): void {\n      this.errors = {\n         required: (this.errorMessages && this.errorMessages.required) || this._defaultErrorMessages.required,\n         pattern: (this.errorMessages && this.errorMessages.pattern) || this._defaultErrorMessages.pattern,\n         generic: (this.errorMessages && this.errorMessages.generic) || this._defaultErrorMessages.generic,\n         minLength: ((this.errorMessages && this.errorMessages.minLength) || this._defaultErrorMessages.minLength) + this._schema.value.minLength,\n         maxLength: ((this.errorMessages && this.errorMessages.maxLength) || this._defaultErrorMessages.maxLength) + this._schema.value.maxLength,\n         min: ((this.errorMessages && this.errorMessages.min) || this._defaultErrorMessages.min) + (this.min - this.getInputStep()),\n         max: ((this.errorMessages && this.errorMessages.max) || this._defaultErrorMessages.max) + (this.max + this.getInputStep())\n      };\n   }\n}\n"]}