@stratio/egeo
Version:
600 lines • 47.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/st-form/st-form.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/*
* © 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, ViewChild, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
import { NG_VALUE_ACCESSOR, NgForm, NG_VALIDATORS } from '@angular/forms';
import { FORM_UI_COMPONENT } from './shared/ui-component.interface';
/**
* \@description {Component} [Dynamic form]
*
* The form component allows to generate forms dynamically using a JSON schema.
*
* \@example
*
* {html}
*
* ```
* <st-form [schema]="jsonSchema" [(ngModel)]="model" #formModel="ngModel">
* </st-form>
*
* ```
*
*/
var StFormComponent = /** @class */ (function () {
function StFormComponent() {
/**
* \@Input {string} [nestingLevel=0] This informs about the nesting level of the form. This input is only used for design purposes
*/
this.nestingLevel = 0;
/**
* \@Input {string} [disabledSectionMessage='for this instance is disabled.']
* Message displayed when a section is disabled. This is always displayed after the section name
*/
this.disabledSectionMessage = 'for this instance is disabled.';
/**
* \@Input {number} [sectionDescriptionLevel=-1] Level of the section to which description is displayed.
* By default, section descriptions are not displayed.
*/
this.sectionDescriptionLevel = -1;
/**
* \@Input {boolean} [showTooltips=-1] Enable or disable displaying of tooltips
* By default, tooltips are displayed
*/
this.showTooltips = true;
/**
* \@Output {any} [valueChange=] Event emitted when value is changed. This emits the current form value
*/
this.valueChange = new EventEmitter();
this.showCollapsedSectionFields = false;
this.innerValue = {};
this._value = {};
this._parentFieldSubscription = [];
this.onTouched = (/**
* @return {?}
*/
function () {
});
}
/**
* @return {?}
*/
StFormComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (this.schema.dependencies) {
this._parentFields = Object.keys(this.schema.dependencies);
}
};
/**
* @return {?}
*/
StFormComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
if (!this.forceValidations) {
this.form.form.markAsPristine();
}
};
/**
* @return {?}
*/
StFormComponent.prototype.ngAfterViewChecked = /**
* @return {?}
*/
function () {
var _this = this;
if (this._parentFields && this.form.control && this.form.control.controls) {
var _loop_1 = function (i) {
/** @type {?} */
var parentField = this_1._parentFields[i];
if (!this_1._parentFieldSubscription[i] && this_1.form.control.controls[parentField]) {
this_1._parentFieldSubscription[i] = this_1.form.control.controls[this_1._parentFields[i]].valueChanges.subscribe((/**
* @param {?} value
* @return {?}
*/
function (value) {
if (!value) {
/** @type {?} */
var childrenFields = _this.schema.dependencies[parentField];
for (var j = 0; j < childrenFields.length; ++j) {
if (_this.form.controls[childrenFields[j]]) {
_this._value[childrenFields[j]] = undefined;
}
}
}
}));
}
};
var this_1 = this;
for (var i = 0; i < this._parentFields.length; ++i) {
_loop_1(i);
}
}
};
// Function to call when the value changes.
// Function to call when the value changes.
/**
* @param {?} _
* @return {?}
*/
StFormComponent.prototype.onChange =
// Function to call when the value changes.
/**
* @param {?} _
* @return {?}
*/
function (_) {
};
/**
* @param {?} control
* @return {?}
*/
StFormComponent.prototype.validate = /**
* @param {?} control
* @return {?}
*/
function (control) {
var _this = this;
/** @type {?} */
var errors = null;
if (this.form) {
Object.keys(this.form.controls).forEach((/**
* @param {?} propertyName
* @return {?}
*/
function (propertyName) {
if (_this.form.controls[propertyName] && _this.form.controls[propertyName].errors) {
if (!errors) {
errors = {};
}
errors[propertyName] = _this.form.controls[propertyName].errors;
}
}));
this.form.control.setErrors(errors);
}
return errors;
};
/**
* @param {?} propertyName
* @return {?}
*/
StFormComponent.prototype.isRequired = /**
* @param {?} propertyName
* @return {?}
*/
function (propertyName) {
return propertyName && this.schema.required && this.schema.required.indexOf(propertyName) !== -1;
};
/**
* @return {?}
*/
StFormComponent.prototype.isCollapsedSection = /**
* @return {?}
*/
function () {
return this.schema.type === 'object' && this.schema.ui &&
(this.schema.ui.component === FORM_UI_COMPONENT.SHOW_MORE || this.schema.ui.component === FORM_UI_COMPONENT.ACCORDION);
};
/**
* @return {?}
*/
StFormComponent.prototype.iShowMoreSection = /**
* @return {?}
*/
function () {
return this.schema.type === 'object' && this.schema.ui && this.schema.ui.component === FORM_UI_COMPONENT.SHOW_MORE;
};
/**
* @param {?} propertyName
* @return {?}
*/
StFormComponent.prototype.isAParentField = /**
* @param {?} propertyName
* @return {?}
*/
function (propertyName) {
return this.schema.dependencies && this.schema.dependencies[propertyName] && this.schema.dependencies[propertyName].length > 0;
};
/**
* @return {?}
*/
StFormComponent.prototype.getOptionalButtonLabel = /**
* @return {?}
*/
function () {
/** @type {?} */
var label = 'Additional options';
if (this.parentName || this.schema.title) {
label += ' of ';
label += this.parentName || this.schema.title;
}
return label;
};
/**
* @return {?}
*/
StFormComponent.prototype.onChangeOptionalFieldsVisibility = /**
* @return {?}
*/
function () {
this.showCollapsedSectionFields = !this.showCollapsedSectionFields;
};
/**
* @param {?} propertyName
* @return {?}
*/
StFormComponent.prototype.getFieldClasses = /**
* @param {?} propertyName
* @return {?}
*/
function (propertyName) {
return {
'hidden': this.isCollapsedSection() && !this.showCollapsedSectionFields,
'parent-field': this.isAParentField(propertyName) || (this.isASwitchSection() && this.isTheFirstField(propertyName))
};
};
/**
* @param {?} propertyName
* @return {?}
*/
StFormComponent.prototype.fieldHasToBeCreated = /**
* @param {?} propertyName
* @return {?}
*/
function (propertyName) {
/** @type {?} */
var createField = true;
/** @type {?} */
var parentField = this.getParentField(propertyName);
if (((parentField && !this._value[parentField]) || (this.isInADisabledSection() && !this.isTheFirstField(propertyName)))
|| !this.fulfillDependencyVisibility(propertyName)) {
createField = false;
this._value[propertyName] = undefined;
}
return createField;
};
/**
* @param {?} propertyName
* @return {?}
*/
StFormComponent.prototype.isRelatedField = /**
* @param {?} propertyName
* @return {?}
*/
function (propertyName) {
return this.schema.properties[propertyName].ui && this.schema.properties[propertyName].ui.relatedTo;
};
// When value is received from outside
// When value is received from outside
/**
* @param {?} value
* @return {?}
*/
StFormComponent.prototype.writeValue =
// When value is received from outside
/**
* @param {?} value
* @return {?}
*/
function (value) {
if (value) {
this.onChange(value);
this.innerValue = value;
}
};
/**
* @param {?} value
* @param {?} property
* @return {?}
*/
StFormComponent.prototype.onChangeProperty = /**
* @param {?} value
* @param {?} property
* @return {?}
*/
function (value, property) {
var _this = this;
this._value[property] = value;
this.valueChange.emit(this._value);
setTimeout((/**
* @return {?}
*/
function () {
_this.onChange(_this._value);
}));
};
// Registry the change function to propagate internal model changes
// Registry the change function to propagate internal model changes
/**
* @param {?} fn
* @return {?}
*/
StFormComponent.prototype.registerOnChange =
// Registry the change function to propagate internal model changes
/**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChange = fn;
};
// Registry the touch function to propagate internal touch events TODO: make this function.
// Registry the touch function to propagate internal touch events TODO: make this function.
/**
* @param {?} fn
* @return {?}
*/
StFormComponent.prototype.registerOnTouched =
// Registry the touch function to propagate internal touch events TODO: make this function.
/**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
// Allows Angular to disable the form.
// Allows Angular to disable the form.
/**
* @param {?} disable
* @return {?}
*/
StFormComponent.prototype.setDisabledState =
// Allows Angular to disable the form.
/**
* @param {?} disable
* @return {?}
*/
function (disable) {
if (disable) {
this.form.control.disable();
}
else {
this.form.control.enable();
}
};
/**
* @return {?}
*/
StFormComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
if (this._parentFieldSubscription) {
for (var i = 0; i < this._parentFieldSubscription.length; ++i) {
this._parentFieldSubscription[i].unsubscribe();
}
}
};
/**
* @return {?}
*/
StFormComponent.prototype.isInADisabledSection = /**
* @return {?}
*/
function () {
if (this.isASwitchSection()) {
/** @type {?} */
var sectionEnabler = Object.keys(this.schema.properties)[0];
return !(this.form && this.form.controls[sectionEnabler] && this.form.controls[sectionEnabler].value);
}
return false;
};
/**
* @return {?}
*/
StFormComponent.prototype.isASwitchSection = /**
* @return {?}
*/
function () {
return this.schema.ui && this.schema.ui.component === FORM_UI_COMPONENT.SWITCH;
};
/**
* @return {?}
*/
StFormComponent.prototype.isAnAccordion = /**
* @return {?}
*/
function () {
return this.schema.ui && this.schema.ui.component === FORM_UI_COMPONENT.ACCORDION;
};
/**
* @return {?}
*/
StFormComponent.prototype.onClickTitle = /**
* @return {?}
*/
function () {
if (this.isAnAccordion()) {
this.onChangeOptionalFieldsVisibility();
}
};
/**
* @param {?} propertyName
* @return {?}
*/
StFormComponent.prototype.isTheFirstField = /**
* @param {?} propertyName
* @return {?}
*/
function (propertyName) {
return propertyName === Object.keys(this.schema.properties)[0];
};
/**
* @private
* @param {?} propertyName
* @return {?}
*/
StFormComponent.prototype.getParentField = /**
* @private
* @param {?} propertyName
* @return {?}
*/
function (propertyName) {
var _this = this;
/** @type {?} */
var parentField = undefined;
if (this.schema.dependencies) {
Object.keys(this.schema.dependencies).forEach((/**
* @param {?} key
* @return {?}
*/
function (key) {
if (_this.schema.dependencies[key].indexOf(propertyName) !== -1) {
parentField = key;
}
}));
}
return parentField;
};
/**
* @private
* @param {?} propertyName
* @return {?}
*/
StFormComponent.prototype.fulfillDependencyVisibility = /**
* @private
* @param {?} propertyName
* @return {?}
*/
function (propertyName) {
/** @type {?} */
var fulfill = true;
/** @type {?} */
var propertySchema = this.schema.properties[propertyName];
if (propertySchema.ui && propertySchema.ui.visible) {
/** @type {?} */
var keys = Object.keys(propertySchema.ui.visible);
/** @type {?} */
var i = 0;
while (fulfill && i < keys.length && propertySchema.ui.visible.hasOwnProperty(keys[i])) {
if (this._value[keys[i]] !== propertySchema.ui.visible[keys[i]]) {
fulfill = false;
}
++i;
}
}
return fulfill;
};
StFormComponent.decorators = [
{ type: Component, args: [{
selector: 'st-form',
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<form #form=\"ngForm\" *ngIf=\"innerValue\"\n [ngClass]=\"{'category': nestingLevel === 0,\n 'section': nestingLevel === 1,\n 'subsection': nestingLevel > 1,\n 'accordion': isAnAccordion(),\n 'accordion--open': isAnAccordion() && showCollapsedSectionFields}\"\n novalidate>\n <h1 *ngIf=\"schema.title && !isASwitchSection()\" class=\"title\" (click)=\"onClickTitle()\">{{schema.title}}</h1>\n <p *ngIf=\"schema.description && nestingLevel <= sectionDescriptionLevel\" class=\"description\">{{schema.description}}</p>\n <span class=\"optional-fields-button\" *ngIf=\"iShowMoreSection()\">\n <button class=\"button button-link\"\n (click)=\"onChangeOptionalFieldsVisibility()\">\n <span> <i\n [ngClass]=\"{'icon-arrow2_down': showCollapsedSectionFields, 'icon-arrow2_right': !showCollapsedSectionFields}\"></i> {{getOptionalButtonLabel()}}</span>\n </button>\n </span>\n <ng-container *ngFor=\"let property of schema.properties | stObjectToArray; let index = index;\">\n <div class=\"form-field-container\">\n <st-form-field *ngIf=\"property.value.type !== 'object' && fieldHasToBeCreated(property.key)\" class=\"form-field\"\n [schema]=\"property\"\n [name]=\"property.key\"\n [maxWidth]=\"textFieldMaxWidth\"\n [ngModel]=\"innerValue[property.key]\"\n [forceValidations]=\"forceValidations\"\n (ngModelChange)=\"onChangeProperty($event, property.key)\"\n [required]=\"isRequired(property.key)\"\n [hasDependencies]=\"isAParentField(property.key) || (isASwitchSection() && isTheFirstField(property.key))\"\n [ngClass]=\"getFieldClasses(property.key)\"\n [showTooltip]=\"showTooltips\"\n [qaTag]=\"property.key\"\n [attr.id]=\"property.key + '-form-field'\">\n </st-form-field>\n\n <div *ngIf=\"property.value.type === 'object' && fieldHasToBeCreated(property.key)\">\n <st-form\n [hidden]=\"isCollapsedSection() && !showCollapsedSectionFields\"\n [schema]=\"property.value\"\n [parentName]=\"schema.title\"\n [name]=\"property.key\"\n [textFieldMaxWidth]=\"textFieldMaxWidth\"\n [ngModel]=\"innerValue[property.key]\"\n (ngModelChange)=\"onChangeProperty($event, property.key)\"\n [attr.id]=\"property.key + '-section'\"\n [nestingLevel]=\"nestingLevel + 1\"\n [showTooltips]=\"showTooltips\"\n [sectionDescriptionLevel]=\"sectionDescriptionLevel\">\n </st-form>\n </div>\n </div>\n <span class=\"line-break\" *ngIf=\"!isRelatedField(property.key)\"></span>\n </ng-container>\n\n <p *ngIf=\"isInADisabledSection()\" class=\"disabled-section-info\"> {{schema.title}} {{disabledSectionMessage}}</p>\n</form>\n",
host: { class: 'st-form' },
changeDetection: ChangeDetectionStrategy.OnPush,
providers: [
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/**
* @return {?}
*/
function () { return StFormComponent; })), multi: true },
{ provide: NG_VALIDATORS, useExisting: forwardRef((/**
* @return {?}
*/
function () { return StFormComponent; })), multi: true }
],
styles: ["@charset \"UTF-8\";.form-field{display:block;padding-bottom:20px}.form-field.hidden{visibility:hidden;position:absolute}.section-title{padding:10px 0 20px}"]
}] }
];
StFormComponent.propDecorators = {
schema: [{ type: Input }],
parentName: [{ type: Input }],
nestingLevel: [{ type: Input }],
forceValidations: [{ type: Input }],
disabledSectionMessage: [{ type: Input }],
sectionDescriptionLevel: [{ type: Input }],
textFieldMaxWidth: [{ type: Input }],
showTooltips: [{ type: Input }],
valueChange: [{ type: Output }],
form: [{ type: ViewChild, args: ['form', { static: false },] }]
};
return StFormComponent;
}());
export { StFormComponent };
if (false) {
/**
* \@Input {any} [schema=] JSON schema needed to generate the form
* @type {?}
*/
StFormComponent.prototype.schema;
/**
* \@Input {string} [parentName=] Name of the parent section. By default, it is undefined
* @type {?}
*/
StFormComponent.prototype.parentName;
/**
* \@Input {string} [nestingLevel=0] This informs about the nesting level of the form. This input is only used for design purposes
* @type {?}
*/
StFormComponent.prototype.nestingLevel;
/**
* \@Input {boolean} [forceValidations=] Boolean to force the field validations
* @type {?}
*/
StFormComponent.prototype.forceValidations;
/**
* \@Input {string} [disabledSectionMessage='for this instance is disabled.']
* Message displayed when a section is disabled. This is always displayed after the section name
* @type {?}
*/
StFormComponent.prototype.disabledSectionMessage;
/**
* \@Input {number} [sectionDescriptionLevel=-1] Level of the section to which description is displayed.
* By default, section descriptions are not displayed.
* @type {?}
*/
StFormComponent.prototype.sectionDescriptionLevel;
/**
* \@Input {number} [textFieldMaxWidth=] Maximum width of a field needed to paint a input or textarea
* @type {?}
*/
StFormComponent.prototype.textFieldMaxWidth;
/**
* \@Input {boolean} [showTooltips=-1] Enable or disable displaying of tooltips
* By default, tooltips are displayed
* @type {?}
*/
StFormComponent.prototype.showTooltips;
/**
* \@Output {any} [valueChange=] Event emitted when value is changed. This emits the current form value
* @type {?}
*/
StFormComponent.prototype.valueChange;
/** @type {?} */
StFormComponent.prototype.form;
/** @type {?} */
StFormComponent.prototype.showCollapsedSectionFields;
/** @type {?} */
StFormComponent.prototype.innerValue;
/**
* @type {?}
* @private
*/
StFormComponent.prototype._value;
/**
* @type {?}
* @private
*/
StFormComponent.prototype._parentFieldSubscription;
/**
* @type {?}
* @private
*/
StFormComponent.prototype._parentFields;
/** @type {?} */
StFormComponent.prototype.onTouched;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-form.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-form/st-form.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   Input,\n   Output,\n   forwardRef,\n   ViewChild,\n   EventEmitter,\n   ChangeDetectionStrategy,\n   AfterViewChecked,\n   OnInit,\n   OnDestroy,\n   AfterViewInit\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgForm, NG_VALIDATORS, FormControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { FORM_UI_COMPONENT } from './shared/ui-component.interface';\n/**\n * @description {Component} [Dynamic form]\n *\n * The form component allows to generate forms dynamically using a JSON schema.\n *\n * @example\n *\n * {html}\n *\n * ```\n * <st-form [schema]=\"jsonSchema\" [(ngModel)]=\"model\" #formModel=\"ngModel\">\n * </st-form>\n *\n * ```\n *\n */\n@Component({\n   selector: 'st-form',\n   templateUrl: './st-form.component.html',\n   styleUrls: ['./st-form.component.scss'],\n   host: { class: 'st-form' },\n   changeDetection: ChangeDetectionStrategy.OnPush,\n   providers: [\n      { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => StFormComponent), multi: true },\n      { provide: NG_VALIDATORS, useExisting: forwardRef(() => StFormComponent), multi: true }\n   ]\n})\n\nexport class StFormComponent implements AfterViewInit, AfterViewChecked, ControlValueAccessor, OnInit, OnDestroy {\n   /** @Input {any} [schema=] JSON schema needed to generate the form */\n   @Input() schema: any;\n   /** @Input {string} [parentName=] Name of the parent section. By default, it is undefined */\n   @Input() parentName: string;\n   /** @Input {string} [nestingLevel=0] This informs about the nesting level of the form. This input is only used for design purposes */\n   @Input() nestingLevel: number = 0;\n   /** @Input {boolean} [forceValidations=] Boolean to force the field validations */\n   @Input() forceValidations: boolean;\n   /** @Input {string} [disabledSectionMessage='for this instance is disabled.']\n    *  Message displayed when a section is disabled. This is always displayed after the section name\n    */\n   @Input() disabledSectionMessage: string = 'for this instance is disabled.';\n\n   /** @Input {number} [sectionDescriptionLevel=-1] Level of the section to which description is displayed.\n    * By default, section descriptions are not displayed.\n    */\n   @Input() sectionDescriptionLevel: number = -1;\n\n   /** @Input {number} [textFieldMaxWidth=] Maximum width of a field needed to paint a input or textarea */\n   @Input() textFieldMaxWidth: number;\n\n   /** @Input {boolean} [showTooltips=-1] Enable or disable displaying of tooltips\n    * By default, tooltips are displayed\n    */\n   @Input() showTooltips: boolean = true;\n   /** @Output {any} [valueChange=] Event emitted when value is changed. This emits the current form value */\n   @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n   @ViewChild('form', {static: false}) form: NgForm;\n\n   public showCollapsedSectionFields: boolean = false;\n   public innerValue: any = {};\n   private _value: any = {};\n   private _parentFieldSubscription: Subscription[] = [];\n   private _parentFields: string[];\n\n   ngOnInit(): void {\n      if (this.schema.dependencies) {\n         this._parentFields = Object.keys(this.schema.dependencies);\n      }\n   }\n\n   ngAfterViewInit(): void {\n      if (!this.forceValidations) {\n            this.form.form.markAsPristine();\n      }\n   }\n\n   ngAfterViewChecked(): void {\n      if (this._parentFields && this.form.control && this.form.control.controls) {\n         for (let i = 0; i < this._parentFields.length; ++i) {\n            let parentField: string = this._parentFields[i];\n            if (!this._parentFieldSubscription[i] && this.form.control.controls[parentField]) {\n\n               this._parentFieldSubscription[i] = this.form.control.controls[this._parentFields[i]].valueChanges.subscribe((value) => {\n                  if (!value) {\n                     let childrenFields: string[] = this.schema.dependencies[parentField];\n                     for (let j = 0; j < childrenFields.length; ++j) {\n                        if (this.form.controls[childrenFields[j]]) {\n                           this._value[childrenFields[j]] = undefined;\n                        }\n                     }\n                  }\n               });\n            }\n         }\n      }\n   }\n\n   // Function to call when the value changes.\n   onChange(_: any): void {\n   }\n\n   onTouched = () => {\n   }\n\n   validate(control: FormControl): any {\n      let errors: any = null;\n      if (this.form) {\n         Object.keys(this.form.controls).forEach((propertyName) => {\n            if (this.form.controls[propertyName] && this.form.controls[propertyName].errors) {\n               if (!errors) {\n                  errors = {};\n               }\n               errors[propertyName] = this.form.controls[propertyName].errors;\n            }\n         });\n\n         this.form.control.setErrors(errors);\n      }\n      return errors;\n   }\n\n   isRequired(propertyName: string): boolean {\n      return propertyName && this.schema.required && this.schema.required.indexOf(propertyName) !== -1;\n   }\n\n   isCollapsedSection(): boolean {\n      return this.schema.type === 'object' && this.schema.ui &&\n         (this.schema.ui.component === FORM_UI_COMPONENT.SHOW_MORE || this.schema.ui.component === FORM_UI_COMPONENT.ACCORDION);\n   }\n\n   iShowMoreSection(): boolean {\n      return this.schema.type === 'object' && this.schema.ui && this.schema.ui.component === FORM_UI_COMPONENT.SHOW_MORE;\n   }\n\n   isAParentField(propertyName: string): boolean {\n      return this.schema.dependencies && this.schema.dependencies[propertyName] && this.schema.dependencies[propertyName].length > 0;\n   }\n\n   getOptionalButtonLabel(): string {\n      let label: string = 'Additional options';\n\n      if (this.parentName || this.schema.title) {\n         label += ' of ';\n         label += this.parentName || this.schema.title;\n      }\n\n      return label;\n   }\n\n   onChangeOptionalFieldsVisibility(): void {\n      this.showCollapsedSectionFields = !this.showCollapsedSectionFields;\n   }\n\n   getFieldClasses(propertyName: string): any {\n      return {\n         'hidden': this.isCollapsedSection() && !this.showCollapsedSectionFields,\n         'parent-field': this.isAParentField(propertyName) || (this.isASwitchSection() && this.isTheFirstField(propertyName))\n      };\n   }\n\n   fieldHasToBeCreated(propertyName: string): boolean {\n      let createField: boolean = true;\n      let parentField: string = this.getParentField(propertyName);\n      if (((parentField && !this._value[parentField]) || (this.isInADisabledSection() && !this.isTheFirstField(propertyName)))\n         || !this.fulfillDependencyVisibility(propertyName)) {\n         createField = false;\n         this._value[propertyName] = undefined;\n      }\n      return createField;\n   }\n\n   isRelatedField(propertyName: string): boolean {\n      return this.schema.properties[propertyName].ui && this.schema.properties[propertyName].ui.relatedTo;\n   }\n\n   // When value is received from outside\n   writeValue(value: any): void {\n      if (value) {\n         this.onChange(value);\n         this.innerValue = value;\n      }\n   }\n\n   onChangeProperty(value: any, property: string): void {\n      this._value[property] = value;\n      this.valueChange.emit(this._value);\n      setTimeout(() => {\n         this.onChange(this._value);\n      });\n   }\n\n   // Registry the change function to propagate internal model changes\n   registerOnChange(fn: (_: any) => void): void {\n      this.onChange = fn;\n   }\n\n   // Registry the touch function to propagate internal touch events TODO: make this function.\n   registerOnTouched(fn: () => void): void {\n      this.onTouched = fn;\n   }\n\n   // Allows Angular to disable the form.\n   setDisabledState(disable: boolean): void {\n      if (disable) {\n         this.form.control.disable();\n      } else {\n         this.form.control.enable();\n      }\n   }\n\n   ngOnDestroy(): void {\n      if (this._parentFieldSubscription) {\n         for (let i = 0; i < this._parentFieldSubscription.length; ++i) {\n            this._parentFieldSubscription[i].unsubscribe();\n         }\n      }\n   }\n\n   isInADisabledSection(): boolean {\n      if (this.isASwitchSection()) {\n         let sectionEnabler: string = Object.keys(this.schema.properties)[0];\n         return !(this.form && this.form.controls[sectionEnabler] && this.form.controls[sectionEnabler].value);\n      }\n      return false;\n   }\n\n   isASwitchSection(): boolean {\n      return this.schema.ui && this.schema.ui.component === FORM_UI_COMPONENT.SWITCH;\n   }\n\n   isAnAccordion(): boolean {\n      return this.schema.ui && this.schema.ui.component === FORM_UI_COMPONENT.ACCORDION;\n   }\n\n   onClickTitle(): void {\n      if (this.isAnAccordion()) {\n         this.onChangeOptionalFieldsVisibility();\n      }\n   }\n\n   isTheFirstField(propertyName: string): boolean {\n      return propertyName === Object.keys(this.schema.properties)[0];\n   }\n\n   private getParentField(propertyName: string): string {\n      let parentField: string = undefined;\n      if (this.schema.dependencies) {\n         Object.keys(this.schema.dependencies).forEach((key: string) => {\n            if (this.schema.dependencies[key].indexOf(propertyName) !== -1) {\n               parentField = key;\n            }\n         });\n      }\n      return parentField;\n   }\n\n   private fulfillDependencyVisibility(propertyName: string): boolean {\n      let fulfill: boolean = true;\n      let propertySchema: any = this.schema.properties[propertyName];\n      if (propertySchema.ui && propertySchema.ui.visible) {\n         const keys: string[] = Object.keys(propertySchema.ui.visible);\n         let i = 0;\n         while (fulfill && i < keys.length && propertySchema.ui.visible.hasOwnProperty(keys[i])) {\n            if (this._value[keys[i]] !== propertySchema.ui.visible[keys[i]]) {\n               fulfill = false;\n            }\n            ++i;\n         }\n      }\n      return fulfill;\n   }\n}\n"]}