@stratio/egeo
Version:
474 lines • 36.7 kB
JavaScript
/**
* @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"]}