@stratio/egeo
Version:
375 lines • 32.7 kB
JavaScript
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 { 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';
let StFormFieldComponent = StFormFieldComponent_1 = class StFormFieldComponent {
constructor() {
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 {?}
*/
(_) => {
});
this.onTouched = (/**
* @return {?}
*/
() => {
});
}
/**
* @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 {?} enabled
* @return {?}
*/
setSwitchValue(enabled) {
this.onChange(enabled || undefined);
this.valueChange.emit(enabled || undefined);
}
/**
* @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();
}
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);
}
}));
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
if (changes.schema) {
this.selectOptions = this.getSelectOptions();
}
}
/**
* @return {?}
*/
get errors() {
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'
};
}
/**
* @return {?}
*/
get type() {
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;
}
}
/**
* @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) {
options.push((/** @type {?} */ ({ label: 'Select one option', value: undefined })));
/** @type {?} */
let enumValues = this.schema.value.enum;
enumValues.forEach((/**
* @param {?} value
* @return {?}
*/
(value) => {
options.push((/** @type {?} */ ({ label: value, value: value })));
}));
}
return options;
}
/**
* @return {?}
*/
onBlur() {
this.blur.emit();
}
};
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 {?}
*/
() => 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 = {
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);
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"]}