New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

common-form-elements

Package Overview
Dependencies
Maintainers
1
Versions
86
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

common-form-elements - npm Package Compare versions

Comparing version 0.0.1 to 0.0.2

README.md

62

bundles/common-form-elements.umd.js

@@ -208,3 +208,3 @@ (function (global, factory) {

if (this.isOptionsClosure(this.options)) {
this.options$ = ( /** @type {?} */((( /** @type {?} */(changes['options'].currentValue)))(this.formControlRef, changes['context'].currentValue, ( /**
this.options$ = ( /** @type {?} */((( /** @type {?} */(this.options)))(this.formControlRef, this.context, ( /**
* @return {?}

@@ -399,31 +399,2 @@ */function () { return _this.dataLoadStatusDelegate.next('LOADING'); }), ( /**

/*! *****************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
function __values(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m)
return m.call(o);
if (o && typeof o.length === "number")
return {
next: function () {
if (o && i >= o.length)
o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
}
/**

@@ -436,3 +407,2 @@ * @fileoverview added by tsickle

function CheckboxComponent() {
this.valuesInArr = [];
}

@@ -446,22 +416,2 @@ /**

function () {
var e_1, _a;
try {
for (var _b = __values(Object.keys(this.values)), _c = _b.next(); !_c.done; _c = _b.next()) {
var prop = _c.value;
this.valuesInArr.push(this.values[prop]);
}
}
catch (e_1_1) {
e_1 = { error: e_1_1 };
}
finally {
try {
if (_c && !_c.done && (_a = _b.return))
_a.call(_b);
}
finally {
if (e_1)
throw e_1.error;
}
}
};

@@ -471,4 +421,4 @@ CheckboxComponent.decorators = [

selector: 'sb-checkbox',
template: "<div class=\"sb-checkbox\">\n <span><label>checkbox name</label></span>\n <div *ngFor=\"let value of valuesInArr\">\n <label>{{value}}</label>\n <span><input type=\"checkbox\" name=\"checkbox\" value={{value}}></span>\n </div>\n</div>",
styles: ["label{padding:10px;font-size:16px}"]
template: "<div class=\"sb-checkbox\">\n <div class=\"checkbox-row\">\n <label class=\"container\">\n <input type=\"checkbox\" [formControl]=\"formControlRef\" name=\"checkbox\" value=\"value\">\n <span class=\"checkmark\"></span>\n </label>\n <label class=\"checkbox-label\">{{label}}</label>\n </div>\n</div>",
styles: ["label{font-size:16px}.sb-checkbox{padding:0 0 0 8px}.container{position:relative;cursor:pointer;font-size:22px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.container .checkmark{position:absolute;top:0;left:0;height:25px;width:25px;border:2px solid #000;border-radius:4px}.container input:checked~.checkmark{background-color:#2196f3}.checkmark:after{content:\"\";position:absolute;display:none}.container input:checked~.checkmark:after{display:block}.container .checkmark:after{left:9px;top:5px;width:5px;height:10px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}.checkbox-label{padding:2px 0 0 32px}.checkbox-row{display:-ms-grid;display:grid;-ms-grid-columns:10px 250px;grid-template-columns:10px 250px;grid-gap:0}"]
}] }

@@ -480,3 +430,5 @@ ];

label: [{ type: core.Input }],
values: [{ type: core.Input }]
code: [{ type: core.Input }],
value: [{ type: core.Input }],
formControlRef: [{ type: core.Input }]
};

@@ -747,3 +699,3 @@ return CheckboxComponent;

selector: 'sb-form',
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [label]=\"field.code\" [values]=\"field.templateOptions.labelHtml.values\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [code]=\"field.code\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\" [value]=\"field.default\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
styles: [""]

@@ -750,0 +702,0 @@ }] }

@@ -1,2 +0,2 @@

!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/common"),require("rxjs"),require("rxjs/operators"),require("@angular/forms"),require("@angular/core")):"function"==typeof define&&define.amd?define("common-form-elements",["exports","@angular/common","rxjs","rxjs/operators","@angular/forms","@angular/core"],e):e(t["common-form-elements"]={},t.ng.common,t.rxjs,t.rxjs.operators,t.ng.forms,t.ng.core)}(this,function(t,e,n,o,r,i){"use strict";var a=(l.prototype.ngOnInit=function(){},l.decorators=[{type:i.Component,args:[{selector:"sb-common-form-elements",template:"\n <p>\n common-form-elements works!\n </p>\n "}]}],l.ctorParameters=function(){return[]},l);function l(){}var s=(p.valueComparator=function(t,e){return"object"==typeof t&&"object"==typeof e?d.equals(t,e):t===e||!t&&!e},p);function p(){}var d=(u.equals=function(t,e){var o=function(t){var e=0;for(var n in t)t.hasOwnProperty(n)&&e++;return e},i=function(t,e){if(typeof t!=typeof e)return!1;if("function"==typeof t)return t.toString()===e.toString();if(t instanceof Object&&e instanceof Object){if(o(t)!==o(e))return!1;for(var n in t)if(!i(t[n],e[n]))return!1;return!0}return t===e};return i(t,e)},u.getPropDiff=function(n,o){return Object.keys(n).reduce(function(t,e){return u.equals(n[e],o[e])||t.push(e),t},[])},u.getTruthyProps=function(e){return Object.keys(e).filter(function(t){return!!e[t]})},u.toOrderedString=function(n){return JSON.stringify(Object.keys(n).sort().reduce(function(t,e){return t[e]=n[e],t},{}))},u);function u(){}var c=(f.prototype.ngOnChanges=function(t){var e=this;this.options||(this.options=[]),this.isOptionsClosure(this.options)&&(this.options$=t.options.currentValue(this.formControlRef,t.context.currentValue,function(){return e.dataLoadStatusDelegate.next("LOADING")},function(){return e.dataLoadStatusDelegate.next("LOADED")}))},f.prototype.ngOnInit=function(){var t=this;this.context&&(this.contextValueChangesSubscription=this.context.valueChanges.pipe(o.tap(function(){t.formControlRef.patchValue(null)})).subscribe())},f.prototype.ngOnDestroy=function(){},f.prototype.isOptionsArray=function(t){return Array.isArray(t)},f.prototype.isOptionsClosure=function(t){return"function"==typeof t},f.prototype.isOptionsMap=function(t){return!Array.isArray(t)&&"object"==typeof t},f.decorators=[{type:i.Component,args:[{selector:"sb-dropdown",template:'<div class="sb-dropdown">\n <label>{{label}}</label>\n <ng-container *ngIf="options">\n <div class="dropdown-container">\n <sb-icon-dropdown class="dropdown-icon"></sb-icon-dropdown>\n <select [attr.disabled]="disabled ? true : ( context ? (context.invalid ? true : null) : null )"\n [formControl]="formControlRef"\n [compareWith]="ValueComparator.valueComparator" class="sb-dropdown-select" id="sb-dropdown"\n name="sb-dropdown">\n <option [defaultSelected]="!default" [ngValue]="null" disabled>{{placeHolder}}\n </option>\n <ng-container *ngIf="isOptionsArray(options)">\n <option *ngFor="let option of options" [ngValue]="option.value">{{option.label}}</option>\n </ng-container>\n\n <ng-container *ngIf="isOptionsClosure(options)">\n <option *ngFor="let option of options$ | async" [ngValue]="option.value">{{option.label}}</option>\n </ng-container>\n\n <ng-container *ngIf="isOptionsMap(options) && context && context.value">\n <option *ngFor="let option of options[context.value]" [ngValue]="option.value">{{option.label}}</option>\n </ng-container>\n </select>\n </div>\n </ng-container>\n</div>\n',styles:["label{display:block;padding:10px;font-size:1rem}.dropdown-icon{position:absolute;top:.5rem;right:18px;z-index:1}.dropdown-container{position:relative}select[disabled]{opacity:.3}select{-webkit-appearance:none;-moz-appearance:none;text-indent:1px;text-overflow:''}.sb-dropdown-select{opacity:.99;color:#333;font-family:\"Noto Sans\";font-size:12px;font-weight:700;letter-spacing:0;line-height:17px}.sb-dropdown{margin-bottom:8px}.placeholder select option:first-child{color:#999}.option-default{color:#333;font-weight:700;font-size:12px}.sb-dropdown select{background-color:#fff;padding:10px 20px;font-size:14px;width:100%;border:.5px solid #333}"]}]}],f.ctorParameters=function(){return[]},f.propDecorators={disabled:[{type:i.Input}],options:[{type:i.Input}],label:[{type:i.Input}],placeHolder:[{type:i.Input}],isMultiple:[{type:i.Input}],context:[{type:i.Input}],formControlRef:[{type:i.Input}],"default":[{type:i.Input}],contextData:[{type:i.Input}],dataLoadStatusDelegate:[{type:i.Input}]},f);function f(){this.ValueComparator=s,this.options=[]}var m=(g.prototype.ngOnInit=function(){},g.decorators=[{type:i.Component,args:[{selector:"sb-textbox",template:'<div class="sb-input">\n <label>{{label}}</label>\n <input [formControl]="formControlRef" class="sb-textbox" placeholder={{placeholder}} type="text">\n</div>\n',changeDetection:i.ChangeDetectionStrategy.OnPush,styles:['label{display:block;padding:10px;font-size:1rem}.sb-textbox{width:100%;padding:8px 20px;border:.5px solid #333;box-sizing:border-box}::-moz-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:"Noto Sans";font-size:12px;font-weight:700}:-ms-input-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:"Noto Sans";font-size:12px;font-weight:700}::-ms-input-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:"Noto Sans";font-size:12px;font-weight:700}::placeholder{padding:.25rem;opacity:.99;color:#999;font-family:"Noto Sans";font-size:12px;font-weight:700}.sb-input{margin-bottom:10px}']}]}],g.ctorParameters=function(){return[]},g.propDecorators={label:[{type:i.Input}],placeholder:[{type:i.Input}],formControlRef:[{type:i.Input}]},g);function g(){}var h={INPUT:"input",CHECKBOX:"checkbox",SELECT:"select",LABEL:"label",TEXTAREA:"textarea",NESTED_SELECT:"nested_select",NESTED_GROUP:"nested_group"},b={REQUIRED:"required",MAXLENGTH:"maxLength",MINLENGTH:"minLength",PATTERN:"pattern"},y=(v.prototype.ngOnInit=function(){var e=this.config.validations&&this.config.validations.find(function(t){return t.type===b.MAXLENGTH});e&&(this.remainderValidLength$=this.formControlRef.valueChanges.pipe(o.startWith(""),o.map(function(t){return("number"==typeof e.value?e.value:0)-(t||"").length})))},v.decorators=[{type:i.Component,args:[{selector:"sb-textarea",template:'<div class="sb-textarea-container">\n <label>{{label}}</label>\n <textarea class="sb-textarea" [formControl]="formControlRef" rows="5" name="sb-textarea" placeholder={{placeholder}}>\n </textarea>\n <div class="remaining-length" *ngIf="remainderValidLength$">\n {{remainderValidLength$ | async}} Characters left\n </div>\n</div>\n',styles:['label{display:block;padding:10px;font-size:1rem}.sb-textarea{width:100%;padding:8px 20px;box-sizing:border-box;border:1px solid #ccc;border-radius:.25rem;resize:vertical}.sb-textarea-container{margin-bottom:10px;position:relative}.remaining-length{position:absolute;bottom:.5rem;right:1rem;font-size:10px;color:#999}::-moz-placeholder{padding:.25rem;color:#999;font-family:"Noto Sans";font-size:14px;letter-spacing:0;line-height:20px}:-ms-input-placeholder{padding:.25rem;color:#999;font-family:"Noto Sans";font-size:14px;letter-spacing:0;line-height:20px}::-ms-input-placeholder{padding:.25rem;color:#999;font-family:"Noto Sans";font-size:14px;letter-spacing:0;line-height:20px}::placeholder{padding:.25rem;color:#999;font-family:"Noto Sans";font-size:14px;letter-spacing:0;line-height:20px}']}]}],v.ctorParameters=function(){return[]},v.propDecorators={label:[{type:i.Input}],placeholder:[{type:i.Input}],formControlRef:[{type:i.Input}],config:[{type:i.Input}]},v);function v(){}var x=(C.prototype.ngOnInit=function(){var t,e;try{for(var n=function(t){var e="function"==typeof Symbol&&Symbol.iterator,n=e&&t[e],o=0;if(n)return n.call(t);if(t&&"number"==typeof t.length)return{next:function(){return t&&o>=t.length&&(t=void 0),{value:t&&t[o++],done:!t}}};throw new TypeError(e?"Object is not iterable.":"Symbol.iterator is not defined.")}(Object.keys(this.values)),o=n.next();!o.done;o=n.next()){var i=o.value;this.valuesInArr.push(this.values[i])}}catch(r){t={error:r}}finally{try{o&&!o.done&&(e=n["return"])&&e.call(n)}finally{if(t)throw t.error}}},C.decorators=[{type:i.Component,args:[{selector:"sb-checkbox",template:'<div class="sb-checkbox">\n <span><label>checkbox name</label></span>\n <div *ngFor="let value of valuesInArr">\n <label>{{value}}</label>\n <span><input type="checkbox" name="checkbox" value={{value}}></span>\n </div>\n</div>',styles:["label{padding:10px;font-size:16px}"]}]}],C.ctorParameters=function(){return[]},C.propDecorators={label:[{type:i.Input}],values:[{type:i.Input}]},C);function C(){this.valuesInArr=[]}var S=(O.prototype.ngOnDestroy=function(){this.finalize.emit(),this.statusChangesSubscription&&this.statusChangesSubscription.unsubscribe(),this.valueChangesSubscription&&this.valueChangesSubscription.unsubscribe(),this.dataLoadStatusSinkSubscription&&this.dataLoadStatusSinkSubscription.unsubscribe()},O.prototype.ngOnInit=function(){},O.prototype.ngOnChanges=function(t){var e=this;t.config&&(t.config.currentValue&&t.config.firstChange||t.config.previousValue!==t.config.currentValue)&&this.initializeForm(),this.dataLoadStatusSinkSubscription&&this.dataLoadStatusSinkSubscription.unsubscribe(),this.statusChangesSubscription&&this.statusChangesSubscription.unsubscribe(),this.valueChangesSubscription&&this.valueChangesSubscription.unsubscribe(),this.dataLoadStatusSinkSubscription=this.dataLoadStatusDelegate.pipe(o.scan(function(t,e){return"LOADED"===e?t.loadedCount++:t.loadingCount++,t},{loadingCount:0,loadedCount:0}),o.map(function(t){return t.loadingCount!==t.loadedCount?"LOADING":"LOADED"}),o.distinctUntilChanged(),o.tap(function(t){"LOADING"===t?e.dataLoadStatus.emit("LOADING"):e.dataLoadStatus.emit("LOADED")})).subscribe(),this.statusChangesSubscription=this.formGroup.valueChanges.pipe(o.tap(function(t){e.statusChanges.emit({isPristine:e.formGroup.pristine,isDirty:e.formGroup.dirty,isInvalid:e.formGroup.invalid,isValid:e.formGroup.valid})})).subscribe(),this.valueChangesSubscription=this.formGroup.valueChanges.pipe(o.tap(function(t){e.valueChanges.emit(t)})).subscribe()},O.prototype.onNestedFormFinalize=function(t,e){this.formGroup.get("children")&&this.formGroup.get("children."+e.code)&&(this.formGroup.get("children").removeControl(e.code),Object.keys(this.formGroup.get("children").controls).length||this.formGroup.removeControl("children"))},O.prototype.onNestedFormInitialize=function(t,e){this.formGroup.get("children")||this.formGroup.addControl("children",new r.FormGroup({})),this.formGroup.get("children").addControl(e.code,t)},O.prototype.initializeForm=function(){var o,i=this;this.config.length?(o={},this.config.forEach(function(t,e){var n;t.type!==h.LABEL&&(n=i.prepareFormValidationData(t,e),o[t.code]=n)}),this.formGroup=this.formBuilder.group(o),this.initialize.emit(this.formGroup)):console.error("FORM LIST IS EMPTY")},O.prototype.prepareFormValidationData=function(n,t){var e=[],o=[],i="";switch(n.type){case h.INPUT:i="number"===n.templateOptions.type?n["default"]&&Number.isInteger(n["default"])?n["default"]:0:null;break;case h.SELECT:case h.NESTED_SELECT:i=n.templateOptions.multiple?n["default"]&&Array.isArray(n["default"])?n["default"]:[]:n["default"]||null;break;case h.CHECKBOX:i=!!n["default"]}return e.push(i),n.validations&&n.validations.length&&n.validations.forEach(function(t,e){switch(t.type){case b.REQUIRED:n.type===h.CHECKBOX?o.push(r.Validators.requiredTrue):n.type===h.SELECT||n.type===h.NESTED_SELECT?o.push(function(t){return n.templateOptions.multiple?t.value&&t.value.length?null:"error":t.value?null:"error"}):o.push(r.Validators.required);break;case b.PATTERN:o.push(r.Validators.pattern(n.validations[e].value));break;case b.MINLENGTH:o.push(r.Validators.minLength(n.validations[e].value));break;case b.MAXLENGTH:o.push(r.Validators.maxLength(n.validations[e].value))}}),e.push(r.Validators.compose(o)),e},O.decorators=[{type:i.Component,args:[{selector:"sb-form",template:'<div [formGroup]="formGroup">\n <ng-container *ngFor="let field of config; let index = i">\n <div *ngIf="field.type === FieldConfigInputType.SELECT" [hidden]="field.templateOptions?.hidden || null">\n <sb-dropdown [context]="field.context ? formGroup.get(field.context) : null " [default]="field.default"\n [formControlRef]="formGroup.get(field.code)" [label]="field.templateOptions.label"\n [dataLoadStatusDelegate]="dataLoadStatusDelegate" [options]="field.templateOptions?.options"\n [disabled]="field.templateOptions?.disabled"\n [placeHolder]="field?.templateOptions?.placeHolder">\n </sb-dropdown>\n </div>\n <div *ngIf="field.type === FieldConfigInputType.NESTED_SELECT" [hidden]="field.templateOptions?.hidden || null">\n <sb-dropdown [context]="field.context ? formGroup.get(field.context) : null " [default]="field.default"\n [formControlRef]="formGroup.get(field.code)" [label]="field.templateOptions.label"\n [dataLoadStatusDelegate]="dataLoadStatusDelegate" [options]="field.templateOptions?.options"\n [disabled]="field.templateOptions?.disabled"\n [placeHolder]="field?.templateOptions?.placeHolder">\n </sb-dropdown>\n </div>\n <div *ngIf="field.type === FieldConfigInputType.INPUT" [hidden]="field.templateOptions?.hidden || null">\n <sb-textbox [formControlRef]="formGroup.get(field.code)" [label]="field.templateOptions.label"\n [placeholder]="field.templateOptions.placeHolder">\n </sb-textbox>\n </div>\n <div *ngIf="field.type === FieldConfigInputType.TEXTAREA" [hidden]="field.templateOptions?.hidden || null">\n <sb-textarea [config]="field" [formControlRef]="formGroup.get(field.code)" [label]="field.templateOptions.label"\n [placeholder]="field.templateOptions.placeHolder">\n </sb-textarea>\n </div>\n <div *ngIf="field.type === FieldConfigInputType.CHECKBOX" [hidden]="field.templateOptions?.hidden || null">\n <sb-checkbox [label]="field.code" [values]="field.templateOptions.labelHtml.values"></sb-checkbox>\n </div>\n <ng-container *ngIf="formGroup.get(field.code) as ref">\n <div *ngIf="ref && ref.value && field.children && field.children[ref.value]">\n <sb-form (initialize)="onNestedFormInitialize($event, field)"\n (finalize)="onNestedFormFinalize($event, field)"\n [dataLoadStatusDelegate]="dataLoadStatusDelegate"\n [config]="field.children[ref.value]"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n',styles:[""]}]}],O.ctorParameters=function(){return[{type:r.FormBuilder}]},O.propDecorators={initialize:[{type:i.Output}],finalize:[{type:i.Output}],valueChanges:[{type:i.Output}],statusChanges:[{type:i.Output}],dataLoadStatus:[{type:i.Output}],config:[{type:i.Input}],dataLoadStatusDelegate:[{type:i.Input}]},O);function O(t){this.formBuilder=t,this.initialize=new i.EventEmitter,this.finalize=new i.EventEmitter,this.valueChanges=new i.EventEmitter,this.statusChanges=new i.EventEmitter,this.dataLoadStatus=new i.EventEmitter,this.dataLoadStatusDelegate=new n.Subject,this.FieldConfigInputType=h,window.forms||(window.forms=[]),window.forms.push(this)}var E=(I.prototype.ngOnInit=function(){},I.decorators=[{type:i.Component,args:[{selector:"sb-option-group",template:"<p>\n option-group works!\n</p>\n",changeDetection:i.ChangeDetectionStrategy.OnPush,styles:[""]}]}],I.ctorParameters=function(){return[]},I);function I(){}var w=(L.prototype.ngOnInit=function(){},L.decorators=[{type:i.Component,args:[{selector:"sb-icon-dropdown",template:'<svg width="14px" height="8px" viewBox="0 0 14 8" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">\n \x3c!-- Generator: sketchtool 63.1 (101010) - https://sketch.com --\x3e\n <title>BE94B3C8-E695-41FA-A0FC-2CE95714B444@1.5x</title>\n <desc>Created with sketchtool.</desc>\n <g id="Schooling-@-home" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\n <g id="My-classes-Copy" transform="translate(-316.000000, -248.000000)" fill="#333333">\n <g id="Group" transform="translate(16.000000, 205.000000)">\n <polygon id="Path" transform="translate(306.894756, 47.000000) rotate(-270.000000) translate(-306.894756, -47.000000) " points="304.599756 40.7073171 303.189756 42.1860976 307.769756 47 303.189756 51.8139024 304.599756 53.2926829 310.599756 47"></polygon>\n </g>\n </g>\n </g>\n</svg>\n',styles:[""]}]}],L.ctorParameters=function(){return[]},L);function L(){}var D=(T.decorators=[{type:i.NgModule,args:[{declarations:[a,c,m,y,x,S,E,w],imports:[e.CommonModule,r.ReactiveFormsModule,r.FormsModule],exports:[a,c,m,y,x,S,E,w]}]}],T);function T(){}t.CommonFormElementsComponent=a,t.CommonFormElementsModule=D,t.FieldConfigInputType=h,t.FieldConfigValidationType=b,t.ɵd=x,t.ɵa=c,t.ɵe=S,t.ɵg=w,t.ɵf=E,t.ɵc=y,t.ɵb=m,Object.defineProperty(t,"__esModule",{value:!0})});
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/common"),require("rxjs"),require("rxjs/operators"),require("@angular/forms"),require("@angular/core")):"function"==typeof define&&define.amd?define("common-form-elements",["exports","@angular/common","rxjs","rxjs/operators","@angular/forms","@angular/core"],e):e(t["common-form-elements"]={},t.ng.common,t.rxjs,t.rxjs.operators,t.ng.forms,t.ng.core)}(this,function(t,e,n,o,r,i){"use strict";var a=(l.prototype.ngOnInit=function(){},l.decorators=[{type:i.Component,args:[{selector:"sb-common-form-elements",template:"\n <p>\n common-form-elements works!\n </p>\n "}]}],l.ctorParameters=function(){return[]},l);function l(){}var s=(p.valueComparator=function(t,e){return"object"==typeof t&&"object"==typeof e?d.equals(t,e):t===e||!t&&!e},p);function p(){}var d=(c.equals=function(t,e){var o=function(t){var e=0;for(var n in t)t.hasOwnProperty(n)&&e++;return e},i=function(t,e){if(typeof t!=typeof e)return!1;if("function"==typeof t)return t.toString()===e.toString();if(t instanceof Object&&e instanceof Object){if(o(t)!==o(e))return!1;for(var n in t)if(!i(t[n],e[n]))return!1;return!0}return t===e};return i(t,e)},c.getPropDiff=function(n,o){return Object.keys(n).reduce(function(t,e){return c.equals(n[e],o[e])||t.push(e),t},[])},c.getTruthyProps=function(e){return Object.keys(e).filter(function(t){return!!e[t]})},c.toOrderedString=function(n){return JSON.stringify(Object.keys(n).sort().reduce(function(t,e){return t[e]=n[e],t},{}))},c);function c(){}var u=(f.prototype.ngOnChanges=function(t){var e=this;this.options||(this.options=[]),this.isOptionsClosure(this.options)&&(this.options$=this.options(this.formControlRef,this.context,function(){return e.dataLoadStatusDelegate.next("LOADING")},function(){return e.dataLoadStatusDelegate.next("LOADED")}))},f.prototype.ngOnInit=function(){var t=this;this.context&&(this.contextValueChangesSubscription=this.context.valueChanges.pipe(o.tap(function(){t.formControlRef.patchValue(null)})).subscribe())},f.prototype.ngOnDestroy=function(){},f.prototype.isOptionsArray=function(t){return Array.isArray(t)},f.prototype.isOptionsClosure=function(t){return"function"==typeof t},f.prototype.isOptionsMap=function(t){return!Array.isArray(t)&&"object"==typeof t},f.decorators=[{type:i.Component,args:[{selector:"sb-dropdown",template:'<div class="sb-dropdown">\n <label>{{label}}</label>\n <ng-container *ngIf="options">\n <div class="dropdown-container">\n <sb-icon-dropdown class="dropdown-icon"></sb-icon-dropdown>\n <select [attr.disabled]="disabled ? true : ( context ? (context.invalid ? true : null) : null )"\n [formControl]="formControlRef"\n [compareWith]="ValueComparator.valueComparator" class="sb-dropdown-select" id="sb-dropdown"\n name="sb-dropdown">\n <option [defaultSelected]="!default" [ngValue]="null" disabled>{{placeHolder}}\n </option>\n <ng-container *ngIf="isOptionsArray(options)">\n <option *ngFor="let option of options" [ngValue]="option.value">{{option.label}}</option>\n </ng-container>\n\n <ng-container *ngIf="isOptionsClosure(options)">\n <option *ngFor="let option of options$ | async" [ngValue]="option.value">{{option.label}}</option>\n </ng-container>\n\n <ng-container *ngIf="isOptionsMap(options) && context && context.value">\n <option *ngFor="let option of options[context.value]" [ngValue]="option.value">{{option.label}}</option>\n </ng-container>\n </select>\n </div>\n </ng-container>\n</div>\n',styles:["label{display:block;padding:10px;font-size:1rem}.dropdown-icon{position:absolute;top:.5rem;right:18px;z-index:1}.dropdown-container{position:relative}select[disabled]{opacity:.3}select{-webkit-appearance:none;-moz-appearance:none;text-indent:1px;text-overflow:''}.sb-dropdown-select{opacity:.99;color:#333;font-family:\"Noto Sans\";font-size:12px;font-weight:700;letter-spacing:0;line-height:17px}.sb-dropdown{margin-bottom:8px}.placeholder select option:first-child{color:#999}.option-default{color:#333;font-weight:700;font-size:12px}.sb-dropdown select{background-color:#fff;padding:10px 20px;font-size:14px;width:100%;border:.5px solid #333}"]}]}],f.ctorParameters=function(){return[]},f.propDecorators={disabled:[{type:i.Input}],options:[{type:i.Input}],label:[{type:i.Input}],placeHolder:[{type:i.Input}],isMultiple:[{type:i.Input}],context:[{type:i.Input}],formControlRef:[{type:i.Input}],"default":[{type:i.Input}],contextData:[{type:i.Input}],dataLoadStatusDelegate:[{type:i.Input}]},f);function f(){this.ValueComparator=s,this.options=[]}var m=(g.prototype.ngOnInit=function(){},g.decorators=[{type:i.Component,args:[{selector:"sb-textbox",template:'<div class="sb-input">\n <label>{{label}}</label>\n <input [formControl]="formControlRef" class="sb-textbox" placeholder={{placeholder}} type="text">\n</div>\n',changeDetection:i.ChangeDetectionStrategy.OnPush,styles:['label{display:block;padding:10px;font-size:1rem}.sb-textbox{width:100%;padding:8px 20px;border:.5px solid #333;box-sizing:border-box}::-moz-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:"Noto Sans";font-size:12px;font-weight:700}:-ms-input-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:"Noto Sans";font-size:12px;font-weight:700}::-ms-input-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:"Noto Sans";font-size:12px;font-weight:700}::placeholder{padding:.25rem;opacity:.99;color:#999;font-family:"Noto Sans";font-size:12px;font-weight:700}.sb-input{margin-bottom:10px}']}]}],g.ctorParameters=function(){return[]},g.propDecorators={label:[{type:i.Input}],placeholder:[{type:i.Input}],formControlRef:[{type:i.Input}]},g);function g(){}var h={INPUT:"input",CHECKBOX:"checkbox",SELECT:"select",LABEL:"label",TEXTAREA:"textarea",NESTED_SELECT:"nested_select",NESTED_GROUP:"nested_group"},b={REQUIRED:"required",MAXLENGTH:"maxLength",MINLENGTH:"minLength",PATTERN:"pattern"},y=(x.prototype.ngOnInit=function(){var e=this.config.validations&&this.config.validations.find(function(t){return t.type===b.MAXLENGTH});e&&(this.remainderValidLength$=this.formControlRef.valueChanges.pipe(o.startWith(""),o.map(function(t){return("number"==typeof e.value?e.value:0)-(t||"").length})))},x.decorators=[{type:i.Component,args:[{selector:"sb-textarea",template:'<div class="sb-textarea-container">\n <label>{{label}}</label>\n <textarea class="sb-textarea" [formControl]="formControlRef" rows="5" name="sb-textarea" placeholder={{placeholder}}>\n </textarea>\n <div class="remaining-length" *ngIf="remainderValidLength$">\n {{remainderValidLength$ | async}} Characters left\n </div>\n</div>\n',styles:['label{display:block;padding:10px;font-size:1rem}.sb-textarea{width:100%;padding:8px 20px;box-sizing:border-box;border:1px solid #ccc;border-radius:.25rem;resize:vertical}.sb-textarea-container{margin-bottom:10px;position:relative}.remaining-length{position:absolute;bottom:.5rem;right:1rem;font-size:10px;color:#999}::-moz-placeholder{padding:.25rem;color:#999;font-family:"Noto Sans";font-size:14px;letter-spacing:0;line-height:20px}:-ms-input-placeholder{padding:.25rem;color:#999;font-family:"Noto Sans";font-size:14px;letter-spacing:0;line-height:20px}::-ms-input-placeholder{padding:.25rem;color:#999;font-family:"Noto Sans";font-size:14px;letter-spacing:0;line-height:20px}::placeholder{padding:.25rem;color:#999;font-family:"Noto Sans";font-size:14px;letter-spacing:0;line-height:20px}']}]}],x.ctorParameters=function(){return[]},x.propDecorators={label:[{type:i.Input}],placeholder:[{type:i.Input}],formControlRef:[{type:i.Input}],config:[{type:i.Input}]},x);function x(){}var v=(C.prototype.ngOnInit=function(){},C.decorators=[{type:i.Component,args:[{selector:"sb-checkbox",template:'<div class="sb-checkbox">\n <div class="checkbox-row">\n <label class="container">\n <input type="checkbox" [formControl]="formControlRef" name="checkbox" value="value">\n <span class="checkmark"></span>\n </label>\n <label class="checkbox-label">{{label}}</label>\n </div>\n</div>',styles:['label{font-size:16px}.sb-checkbox{padding:0 0 0 8px}.container{position:relative;cursor:pointer;font-size:22px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.container .checkmark{position:absolute;top:0;left:0;height:25px;width:25px;border:2px solid #000;border-radius:4px}.container input:checked~.checkmark{background-color:#2196f3}.checkmark:after{content:"";position:absolute;display:none}.container input:checked~.checkmark:after{display:block}.container .checkmark:after{left:9px;top:5px;width:5px;height:10px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}.checkbox-label{padding:2px 0 0 32px}.checkbox-row{display:-ms-grid;display:grid;-ms-grid-columns:10px 250px;grid-template-columns:10px 250px;grid-gap:0}']}]}],C.ctorParameters=function(){return[]},C.propDecorators={label:[{type:i.Input}],code:[{type:i.Input}],value:[{type:i.Input}],formControlRef:[{type:i.Input}]},C);function C(){}var S=(O.prototype.ngOnDestroy=function(){this.finalize.emit(),this.statusChangesSubscription&&this.statusChangesSubscription.unsubscribe(),this.valueChangesSubscription&&this.valueChangesSubscription.unsubscribe(),this.dataLoadStatusSinkSubscription&&this.dataLoadStatusSinkSubscription.unsubscribe()},O.prototype.ngOnInit=function(){},O.prototype.ngOnChanges=function(t){var e=this;t.config&&(t.config.currentValue&&t.config.firstChange||t.config.previousValue!==t.config.currentValue)&&this.initializeForm(),this.dataLoadStatusSinkSubscription&&this.dataLoadStatusSinkSubscription.unsubscribe(),this.statusChangesSubscription&&this.statusChangesSubscription.unsubscribe(),this.valueChangesSubscription&&this.valueChangesSubscription.unsubscribe(),this.dataLoadStatusSinkSubscription=this.dataLoadStatusDelegate.pipe(o.scan(function(t,e){return"LOADED"===e?t.loadedCount++:t.loadingCount++,t},{loadingCount:0,loadedCount:0}),o.map(function(t){return t.loadingCount!==t.loadedCount?"LOADING":"LOADED"}),o.distinctUntilChanged(),o.tap(function(t){"LOADING"===t?e.dataLoadStatus.emit("LOADING"):e.dataLoadStatus.emit("LOADED")})).subscribe(),this.statusChangesSubscription=this.formGroup.valueChanges.pipe(o.tap(function(t){e.statusChanges.emit({isPristine:e.formGroup.pristine,isDirty:e.formGroup.dirty,isInvalid:e.formGroup.invalid,isValid:e.formGroup.valid})})).subscribe(),this.valueChangesSubscription=this.formGroup.valueChanges.pipe(o.tap(function(t){e.valueChanges.emit(t)})).subscribe()},O.prototype.onNestedFormFinalize=function(t,e){this.formGroup.get("children")&&this.formGroup.get("children."+e.code)&&(this.formGroup.get("children").removeControl(e.code),Object.keys(this.formGroup.get("children").controls).length||this.formGroup.removeControl("children"))},O.prototype.onNestedFormInitialize=function(t,e){this.formGroup.get("children")||this.formGroup.addControl("children",new r.FormGroup({})),this.formGroup.get("children").addControl(e.code,t)},O.prototype.initializeForm=function(){var o,i=this;this.config.length?(o={},this.config.forEach(function(t,e){var n;t.type!==h.LABEL&&(n=i.prepareFormValidationData(t,e),o[t.code]=n)}),this.formGroup=this.formBuilder.group(o),this.initialize.emit(this.formGroup)):console.error("FORM LIST IS EMPTY")},O.prototype.prepareFormValidationData=function(n,t){var e=[],o=[],i="";switch(n.type){case h.INPUT:i="number"===n.templateOptions.type?n["default"]&&Number.isInteger(n["default"])?n["default"]:0:null;break;case h.SELECT:case h.NESTED_SELECT:i=n.templateOptions.multiple?n["default"]&&Array.isArray(n["default"])?n["default"]:[]:n["default"]||null;break;case h.CHECKBOX:i=!!n["default"]}return e.push(i),n.validations&&n.validations.length&&n.validations.forEach(function(t,e){switch(t.type){case b.REQUIRED:n.type===h.CHECKBOX?o.push(r.Validators.requiredTrue):n.type===h.SELECT||n.type===h.NESTED_SELECT?o.push(function(t){return n.templateOptions.multiple?t.value&&t.value.length?null:"error":t.value?null:"error"}):o.push(r.Validators.required);break;case b.PATTERN:o.push(r.Validators.pattern(n.validations[e].value));break;case b.MINLENGTH:o.push(r.Validators.minLength(n.validations[e].value));break;case b.MAXLENGTH:o.push(r.Validators.maxLength(n.validations[e].value))}}),e.push(r.Validators.compose(o)),e},O.decorators=[{type:i.Component,args:[{selector:"sb-form",template:'<div [formGroup]="formGroup">\n <ng-container *ngFor="let field of config; let index = i">\n <div *ngIf="field.type === FieldConfigInputType.SELECT" [hidden]="field.templateOptions?.hidden || null">\n <sb-dropdown [context]="field.context ? formGroup.get(field.context) : null " [default]="field.default"\n [formControlRef]="formGroup.get(field.code)" [label]="field.templateOptions.label"\n [dataLoadStatusDelegate]="dataLoadStatusDelegate" [options]="field.templateOptions?.options"\n [disabled]="field.templateOptions?.disabled"\n [placeHolder]="field?.templateOptions?.placeHolder">\n </sb-dropdown>\n </div>\n <div *ngIf="field.type === FieldConfigInputType.NESTED_SELECT" [hidden]="field.templateOptions?.hidden || null">\n <sb-dropdown [context]="field.context ? formGroup.get(field.context) : null " [default]="field.default"\n [formControlRef]="formGroup.get(field.code)" [label]="field.templateOptions.label"\n [dataLoadStatusDelegate]="dataLoadStatusDelegate" [options]="field.templateOptions?.options"\n [disabled]="field.templateOptions?.disabled"\n [placeHolder]="field?.templateOptions?.placeHolder">\n </sb-dropdown>\n </div>\n <div *ngIf="field.type === FieldConfigInputType.INPUT" [hidden]="field.templateOptions?.hidden || null">\n <sb-textbox [formControlRef]="formGroup.get(field.code)" [label]="field.templateOptions.label"\n [placeholder]="field.templateOptions.placeHolder">\n </sb-textbox>\n </div>\n <div *ngIf="field.type === FieldConfigInputType.TEXTAREA" [hidden]="field.templateOptions?.hidden || null">\n <sb-textarea [config]="field" [formControlRef]="formGroup.get(field.code)" [label]="field.templateOptions.label"\n [placeholder]="field.templateOptions.placeHolder">\n </sb-textarea>\n </div>\n <div *ngIf="field.type === FieldConfigInputType.CHECKBOX" [hidden]="field.templateOptions?.hidden || null">\n <sb-checkbox [code]="field.code" [formControlRef]="formGroup.get(field.code)" [label]="field.templateOptions.label" [value]="field.default"></sb-checkbox>\n </div>\n <ng-container *ngIf="formGroup.get(field.code) as ref">\n <div *ngIf="ref && ref.value && field.children && field.children[ref.value]">\n <sb-form (initialize)="onNestedFormInitialize($event, field)"\n (finalize)="onNestedFormFinalize($event, field)"\n [dataLoadStatusDelegate]="dataLoadStatusDelegate"\n [config]="field.children[ref.value]"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n',styles:[""]}]}],O.ctorParameters=function(){return[{type:r.FormBuilder}]},O.propDecorators={initialize:[{type:i.Output}],finalize:[{type:i.Output}],valueChanges:[{type:i.Output}],statusChanges:[{type:i.Output}],dataLoadStatus:[{type:i.Output}],config:[{type:i.Input}],dataLoadStatusDelegate:[{type:i.Input}]},O);function O(t){this.formBuilder=t,this.initialize=new i.EventEmitter,this.finalize=new i.EventEmitter,this.valueChanges=new i.EventEmitter,this.statusChanges=new i.EventEmitter,this.dataLoadStatus=new i.EventEmitter,this.dataLoadStatusDelegate=new n.Subject,this.FieldConfigInputType=h,window.forms||(window.forms=[]),window.forms.push(this)}var E=(w.prototype.ngOnInit=function(){},w.decorators=[{type:i.Component,args:[{selector:"sb-option-group",template:"<p>\n option-group works!\n</p>\n",changeDetection:i.ChangeDetectionStrategy.OnPush,styles:[""]}]}],w.ctorParameters=function(){return[]},w);function w(){}var I=(k.prototype.ngOnInit=function(){},k.decorators=[{type:i.Component,args:[{selector:"sb-icon-dropdown",template:'<svg width="14px" height="8px" viewBox="0 0 14 8" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">\n \x3c!-- Generator: sketchtool 63.1 (101010) - https://sketch.com --\x3e\n <title>BE94B3C8-E695-41FA-A0FC-2CE95714B444@1.5x</title>\n <desc>Created with sketchtool.</desc>\n <g id="Schooling-@-home" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">\n <g id="My-classes-Copy" transform="translate(-316.000000, -248.000000)" fill="#333333">\n <g id="Group" transform="translate(16.000000, 205.000000)">\n <polygon id="Path" transform="translate(306.894756, 47.000000) rotate(-270.000000) translate(-306.894756, -47.000000) " points="304.599756 40.7073171 303.189756 42.1860976 307.769756 47 303.189756 51.8139024 304.599756 53.2926829 310.599756 47"></polygon>\n </g>\n </g>\n </g>\n</svg>\n',styles:[""]}]}],k.ctorParameters=function(){return[]},k);function k(){}var L=(D.decorators=[{type:i.NgModule,args:[{declarations:[a,u,m,y,v,S,E,I],imports:[e.CommonModule,r.ReactiveFormsModule,r.FormsModule],exports:[a,u,m,y,v,S,E,I]}]}],D);function D(){}t.CommonFormElementsComponent=a,t.CommonFormElementsModule=L,t.FieldConfigInputType=h,t.FieldConfigValidationType=b,t.ɵd=v,t.ɵa=u,t.ɵe=S,t.ɵg=I,t.ɵf=E,t.ɵc=y,t.ɵb=m,Object.defineProperty(t,"__esModule",{value:!0})});
//# sourceMappingURL=common-form-elements.umd.min.js.map

@@ -1,1 +0,1 @@

{"__symbolic":"module","version":4,"metadata":{"CommonFormElementsComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"sb-common-form-elements","template":"\n <p>\n common-form-elements works!\n </p>\n ","styles":[]}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"CommonFormElementsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":12,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"CommonFormElementsComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":15,"character":13},{"__symbolic":"reference","module":"@angular/forms","name":"ReactiveFormsModule","line":15,"character":27},{"__symbolic":"reference","module":"@angular/forms","name":"FormsModule","line":15,"character":48}],"exports":[{"__symbolic":"reference","name":"CommonFormElementsComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"}]}]}],"members":{}},"FieldConfigInputType":{"INPUT":"input","CHECKBOX":"checkbox","SELECT":"select","LABEL":"label","TEXTAREA":"textarea","NESTED_SELECT":"nested_select","NESTED_GROUP":"nested_group"},"FieldConfigValidationType":{"REQUIRED":"required","MAXLENGTH":"maxLength","MINLENGTH":"minLength","PATTERN":"pattern"},"FieldConfigOptionsBuilder":{"__symbolic":"interface"},"AsyncValidatorFactory":{"__symbolic":"interface"},"FieldConfigOption":{"__symbolic":"interface"},"FieldConfigOptionAssociations":{"__symbolic":"interface"},"FieldConfig":{"__symbolic":"interface"},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":7,"character":1},"arguments":[{"selector":"sb-dropdown","template":"<div class=\"sb-dropdown\">\n <label>{{label}}</label>\n <ng-container *ngIf=\"options\">\n <div class=\"dropdown-container\">\n <sb-icon-dropdown class=\"dropdown-icon\"></sb-icon-dropdown>\n <select [attr.disabled]=\"disabled ? true : ( context ? (context.invalid ? true : null) : null )\"\n [formControl]=\"formControlRef\"\n [compareWith]=\"ValueComparator.valueComparator\" class=\"sb-dropdown-select\" id=\"sb-dropdown\"\n name=\"sb-dropdown\">\n <option [defaultSelected]=\"!default\" [ngValue]=\"null\" disabled>{{placeHolder}}\n </option>\n <ng-container *ngIf=\"isOptionsArray(options)\">\n <option *ngFor=\"let option of options\" [ngValue]=\"option.value\">{{option.label}}</option>\n </ng-container>\n\n <ng-container *ngIf=\"isOptionsClosure(options)\">\n <option *ngFor=\"let option of options$ | async\" [ngValue]=\"option.value\">{{option.label}}</option>\n </ng-container>\n\n <ng-container *ngIf=\"isOptionsMap(options) && context && context.value\">\n <option *ngFor=\"let option of options[context.value]\" [ngValue]=\"option.value\">{{option.label}}</option>\n </ng-container>\n </select>\n </div>\n </ng-container>\n</div>\n","styles":["label{display:block;padding:10px;font-size:1rem}.dropdown-icon{position:absolute;top:.5rem;right:18px;z-index:1}.dropdown-container{position:relative}select[disabled]{opacity:.3}select{-webkit-appearance:none;-moz-appearance:none;text-indent:1px;text-overflow:''}.sb-dropdown-select{opacity:.99;color:#333;font-family:\"Noto Sans\";font-size:12px;font-weight:700;letter-spacing:0;line-height:17px}.sb-dropdown{margin-bottom:8px}.placeholder select option:first-child{color:#999}.option-default{color:#333;font-weight:700;font-size:12px}.sb-dropdown select{background-color:#fff;padding:10px 20px;font-size:14px;width:100%;border:.5px solid #333}"]}]}],"members":{"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"placeHolder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"isMultiple":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"context":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"formControlRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"default":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":22,"character":3}}]}],"contextData":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3}}]}],"dataLoadStatusDelegate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"isOptionsArray":[{"__symbolic":"method"}],"isOptionsClosure":[{"__symbolic":"method"}],"isOptionsMap":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":3,"character":1},"arguments":[{"selector":"sb-textbox","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":7,"character":19},"member":"OnPush"},"template":"<div class=\"sb-input\">\n <label>{{label}}</label>\n <input [formControl]=\"formControlRef\" class=\"sb-textbox\" placeholder={{placeholder}} type=\"text\">\n</div>\n","styles":["label{display:block;padding:10px;font-size:1rem}.sb-textbox{width:100%;padding:8px 20px;border:.5px solid #333;box-sizing:border-box}::-moz-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:\"Noto Sans\";font-size:12px;font-weight:700}:-ms-input-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:\"Noto Sans\";font-size:12px;font-weight:700}::-ms-input-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:\"Noto Sans\";font-size:12px;font-weight:700}::placeholder{padding:.25rem;opacity:.99;color:#999;font-family:\"Noto Sans\";font-size:12px;font-weight:700}.sb-input{margin-bottom:10px}"]}]}],"members":{"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"placeholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"formControlRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵc":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":6,"character":1},"arguments":[{"selector":"sb-textarea","template":"<div class=\"sb-textarea-container\">\n <label>{{label}}</label>\n <textarea class=\"sb-textarea\" [formControl]=\"formControlRef\" rows=\"5\" name=\"sb-textarea\" placeholder={{placeholder}}>\n </textarea>\n <div class=\"remaining-length\" *ngIf=\"remainderValidLength$\">\n {{remainderValidLength$ | async}} Characters left\n </div>\n</div>\n","styles":["label{display:block;padding:10px;font-size:1rem}.sb-textarea{width:100%;padding:8px 20px;box-sizing:border-box;border:1px solid #ccc;border-radius:.25rem;resize:vertical}.sb-textarea-container{margin-bottom:10px;position:relative}.remaining-length{position:absolute;bottom:.5rem;right:1rem;font-size:10px;color:#999}::-moz-placeholder{padding:.25rem;color:#999;font-family:\"Noto Sans\";font-size:14px;letter-spacing:0;line-height:20px}:-ms-input-placeholder{padding:.25rem;color:#999;font-family:\"Noto Sans\";font-size:14px;letter-spacing:0;line-height:20px}::-ms-input-placeholder{padding:.25rem;color:#999;font-family:\"Noto Sans\";font-size:14px;letter-spacing:0;line-height:20px}::placeholder{padding:.25rem;color:#999;font-family:\"Noto Sans\";font-size:14px;letter-spacing:0;line-height:20px}"]}]}],"members":{"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"placeholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":3}}]}],"formControlRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":3}}]}],"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵd":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"sb-checkbox","template":"<div class=\"sb-checkbox\">\n <span><label>checkbox name</label></span>\n <div *ngFor=\"let value of valuesInArr\">\n <label>{{value}}</label>\n <span><input type=\"checkbox\" name=\"checkbox\" value={{value}}></span>\n </div>\n</div>","styles":["label{padding:10px;font-size:16px}"]}]}],"members":{"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":8,"character":3}}]}],"values":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵe":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":6,"character":1},"arguments":[{"selector":"sb-form","template":"<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [label]=\"field.code\" [values]=\"field.templateOptions.labelHtml.values\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n","styles":[""]}]}],"members":{"initialize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":12,"character":3}}]}],"finalize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":13,"character":3}}]}],"valueChanges":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":15,"character":3}}]}],"statusChanges":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":16,"character":3}}]}],"dataLoadStatus":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":17,"character":3}}]}],"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"dataLoadStatusDelegate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/forms","name":"FormBuilder","line":30,"character":25}]}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"onNestedFormFinalize":[{"__symbolic":"method"}],"onNestedFormInitialize":[{"__symbolic":"method"}],"initializeForm":[{"__symbolic":"method"}],"prepareFormValidationData":[{"__symbolic":"method"}]}},"ɵf":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"sb-option-group","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":6,"character":19},"member":"OnPush"},"template":"<p>\n option-group works!\n</p>\n","styles":[""]}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵg":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"sb-icon-dropdown","template":"<svg width=\"14px\" height=\"8px\" viewBox=\"0 0 14 8\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n <!-- Generator: sketchtool 63.1 (101010) - https://sketch.com -->\n <title>BE94B3C8-E695-41FA-A0FC-2CE95714B444@1.5x</title>\n <desc>Created with sketchtool.</desc>\n <g id=\"Schooling-@-home\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n <g id=\"My-classes-Copy\" transform=\"translate(-316.000000, -248.000000)\" fill=\"#333333\">\n <g id=\"Group\" transform=\"translate(16.000000, 205.000000)\">\n <polygon id=\"Path\" transform=\"translate(306.894756, 47.000000) rotate(-270.000000) translate(-306.894756, -47.000000) \" points=\"304.599756 40.7073171 303.189756 42.1860976 307.769756 47 303.189756 51.8139024 304.599756 53.2926829 310.599756 47\"></polygon>\n </g>\n </g>\n </g>\n</svg>\n","styles":[""]}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}}},"origins":{"CommonFormElementsComponent":"./lib/common-form-elements.component","CommonFormElementsModule":"./lib/common-form-elements.module","FieldConfigInputType":"./lib/common-form-config","FieldConfigValidationType":"./lib/common-form-config","FieldConfigOptionsBuilder":"./lib/common-form-config","AsyncValidatorFactory":"./lib/common-form-config","FieldConfigOption":"./lib/common-form-config","FieldConfigOptionAssociations":"./lib/common-form-config","FieldConfig":"./lib/common-form-config","ɵa":"./lib/dropdown/dropdown.component","ɵb":"./lib/textbox/textbox.component","ɵc":"./lib/textarea/textarea.component","ɵd":"./lib/checkbox/checkbox.component","ɵe":"./lib/form/form.component","ɵf":"./lib/option-group/option-group.component","ɵg":"./lib/icon/dropdown/dropdownIcon.component"},"importAs":"common-form-elements"}
{"__symbolic":"module","version":4,"metadata":{"CommonFormElementsComponent":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"sb-common-form-elements","template":"\n <p>\n common-form-elements works!\n </p>\n ","styles":[]}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"CommonFormElementsModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":12,"character":1},"arguments":[{"declarations":[{"__symbolic":"reference","name":"CommonFormElementsComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"}],"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule","line":15,"character":13},{"__symbolic":"reference","module":"@angular/forms","name":"ReactiveFormsModule","line":15,"character":27},{"__symbolic":"reference","module":"@angular/forms","name":"FormsModule","line":15,"character":48}],"exports":[{"__symbolic":"reference","name":"CommonFormElementsComponent"},{"__symbolic":"reference","name":"ɵa"},{"__symbolic":"reference","name":"ɵb"},{"__symbolic":"reference","name":"ɵc"},{"__symbolic":"reference","name":"ɵd"},{"__symbolic":"reference","name":"ɵe"},{"__symbolic":"reference","name":"ɵf"},{"__symbolic":"reference","name":"ɵg"}]}]}],"members":{}},"FieldConfigInputType":{"INPUT":"input","CHECKBOX":"checkbox","SELECT":"select","LABEL":"label","TEXTAREA":"textarea","NESTED_SELECT":"nested_select","NESTED_GROUP":"nested_group"},"FieldConfigValidationType":{"REQUIRED":"required","MAXLENGTH":"maxLength","MINLENGTH":"minLength","PATTERN":"pattern"},"FieldConfigOptionsBuilder":{"__symbolic":"interface"},"AsyncValidatorFactory":{"__symbolic":"interface"},"FieldConfigOption":{"__symbolic":"interface"},"FieldConfigOptionAssociations":{"__symbolic":"interface"},"FieldConfig":{"__symbolic":"interface"},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":7,"character":1},"arguments":[{"selector":"sb-dropdown","template":"<div class=\"sb-dropdown\">\n <label>{{label}}</label>\n <ng-container *ngIf=\"options\">\n <div class=\"dropdown-container\">\n <sb-icon-dropdown class=\"dropdown-icon\"></sb-icon-dropdown>\n <select [attr.disabled]=\"disabled ? true : ( context ? (context.invalid ? true : null) : null )\"\n [formControl]=\"formControlRef\"\n [compareWith]=\"ValueComparator.valueComparator\" class=\"sb-dropdown-select\" id=\"sb-dropdown\"\n name=\"sb-dropdown\">\n <option [defaultSelected]=\"!default\" [ngValue]=\"null\" disabled>{{placeHolder}}\n </option>\n <ng-container *ngIf=\"isOptionsArray(options)\">\n <option *ngFor=\"let option of options\" [ngValue]=\"option.value\">{{option.label}}</option>\n </ng-container>\n\n <ng-container *ngIf=\"isOptionsClosure(options)\">\n <option *ngFor=\"let option of options$ | async\" [ngValue]=\"option.value\">{{option.label}}</option>\n </ng-container>\n\n <ng-container *ngIf=\"isOptionsMap(options) && context && context.value\">\n <option *ngFor=\"let option of options[context.value]\" [ngValue]=\"option.value\">{{option.label}}</option>\n </ng-container>\n </select>\n </div>\n </ng-container>\n</div>\n","styles":["label{display:block;padding:10px;font-size:1rem}.dropdown-icon{position:absolute;top:.5rem;right:18px;z-index:1}.dropdown-container{position:relative}select[disabled]{opacity:.3}select{-webkit-appearance:none;-moz-appearance:none;text-indent:1px;text-overflow:''}.sb-dropdown-select{opacity:.99;color:#333;font-family:\"Noto Sans\";font-size:12px;font-weight:700;letter-spacing:0;line-height:17px}.sb-dropdown{margin-bottom:8px}.placeholder select option:first-child{color:#999}.option-default{color:#333;font-weight:700;font-size:12px}.sb-dropdown select{background-color:#fff;padding:10px 20px;font-size:14px;width:100%;border:.5px solid #333}"]}]}],"members":{"disabled":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"options":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":16,"character":3}}]}],"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":17,"character":3}}]}],"placeHolder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"isMultiple":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"context":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":20,"character":3}}]}],"formControlRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":21,"character":3}}]}],"default":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":22,"character":3}}]}],"contextData":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":23,"character":3}}]}],"dataLoadStatusDelegate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":24,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"ngOnChanges":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnDestroy":[{"__symbolic":"method"}],"isOptionsArray":[{"__symbolic":"method"}],"isOptionsClosure":[{"__symbolic":"method"}],"isOptionsMap":[{"__symbolic":"method"}]}},"ɵb":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":3,"character":1},"arguments":[{"selector":"sb-textbox","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":7,"character":19},"member":"OnPush"},"template":"<div class=\"sb-input\">\n <label>{{label}}</label>\n <input [formControl]=\"formControlRef\" class=\"sb-textbox\" placeholder={{placeholder}} type=\"text\">\n</div>\n","styles":["label{display:block;padding:10px;font-size:1rem}.sb-textbox{width:100%;padding:8px 20px;border:.5px solid #333;box-sizing:border-box}::-moz-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:\"Noto Sans\";font-size:12px;font-weight:700}:-ms-input-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:\"Noto Sans\";font-size:12px;font-weight:700}::-ms-input-placeholder{padding:.25rem;opacity:.99;color:#999;font-family:\"Noto Sans\";font-size:12px;font-weight:700}::placeholder{padding:.25rem;opacity:.99;color:#999;font-family:\"Noto Sans\";font-size:12px;font-weight:700}.sb-input{margin-bottom:10px}"]}]}],"members":{"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"placeholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"formControlRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵc":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":6,"character":1},"arguments":[{"selector":"sb-textarea","template":"<div class=\"sb-textarea-container\">\n <label>{{label}}</label>\n <textarea class=\"sb-textarea\" [formControl]=\"formControlRef\" rows=\"5\" name=\"sb-textarea\" placeholder={{placeholder}}>\n </textarea>\n <div class=\"remaining-length\" *ngIf=\"remainderValidLength$\">\n {{remainderValidLength$ | async}} Characters left\n </div>\n</div>\n","styles":["label{display:block;padding:10px;font-size:1rem}.sb-textarea{width:100%;padding:8px 20px;box-sizing:border-box;border:1px solid #ccc;border-radius:.25rem;resize:vertical}.sb-textarea-container{margin-bottom:10px;position:relative}.remaining-length{position:absolute;bottom:.5rem;right:1rem;font-size:10px;color:#999}::-moz-placeholder{padding:.25rem;color:#999;font-family:\"Noto Sans\";font-size:14px;letter-spacing:0;line-height:20px}:-ms-input-placeholder{padding:.25rem;color:#999;font-family:\"Noto Sans\";font-size:14px;letter-spacing:0;line-height:20px}::-ms-input-placeholder{padding:.25rem;color:#999;font-family:\"Noto Sans\";font-size:14px;letter-spacing:0;line-height:20px}::placeholder{padding:.25rem;color:#999;font-family:\"Noto Sans\";font-size:14px;letter-spacing:0;line-height:20px}"]}]}],"members":{"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"placeholder":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":13,"character":3}}]}],"formControlRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":14,"character":3}}]}],"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":15,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵd":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":3,"character":1},"arguments":[{"selector":"sb-checkbox","template":"<div class=\"sb-checkbox\">\n <div class=\"checkbox-row\">\n <label class=\"container\">\n <input type=\"checkbox\" [formControl]=\"formControlRef\" name=\"checkbox\" value=\"value\">\n <span class=\"checkmark\"></span>\n </label>\n <label class=\"checkbox-label\">{{label}}</label>\n </div>\n</div>","styles":["label{font-size:16px}.sb-checkbox{padding:0 0 0 8px}.container{position:relative;cursor:pointer;font-size:22px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.container .checkmark{position:absolute;top:0;left:0;height:25px;width:25px;border:2px solid #000;border-radius:4px}.container input:checked~.checkmark{background-color:#2196f3}.checkmark:after{content:\"\";position:absolute;display:none}.container input:checked~.checkmark:after{display:block}.container .checkmark:after{left:9px;top:5px;width:5px;height:10px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}.checkbox-label{padding:2px 0 0 32px}.checkbox-row{display:-ms-grid;display:grid;-ms-grid-columns:10px 250px;grid-template-columns:10px 250px;grid-gap:0}"]}]}],"members":{"label":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":9,"character":3}}]}],"code":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":10,"character":3}}]}],"value":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":11,"character":3}}]}],"formControlRef":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":12,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵe":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":6,"character":1},"arguments":[{"selector":"sb-form","template":"<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [code]=\"field.code\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\" [value]=\"field.default\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n","styles":[""]}]}],"members":{"initialize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":12,"character":3}}]}],"finalize":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":13,"character":3}}]}],"valueChanges":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":15,"character":3}}]}],"statusChanges":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":16,"character":3}}]}],"dataLoadStatus":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Output","line":17,"character":3}}]}],"config":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":18,"character":3}}]}],"dataLoadStatusDelegate":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":19,"character":3}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/forms","name":"FormBuilder","line":30,"character":25}]}],"ngOnDestroy":[{"__symbolic":"method"}],"ngOnInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"onNestedFormFinalize":[{"__symbolic":"method"}],"onNestedFormInitialize":[{"__symbolic":"method"}],"initializeForm":[{"__symbolic":"method"}],"prepareFormValidationData":[{"__symbolic":"method"}]}},"ɵf":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"sb-option-group","changeDetection":{"__symbolic":"select","expression":{"__symbolic":"reference","module":"@angular/core","name":"ChangeDetectionStrategy","line":6,"character":19},"member":"OnPush"},"template":"<p>\n option-group works!\n</p>\n","styles":[""]}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}},"ɵg":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Component","line":2,"character":1},"arguments":[{"selector":"sb-icon-dropdown","template":"<svg width=\"14px\" height=\"8px\" viewBox=\"0 0 14 8\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n <!-- Generator: sketchtool 63.1 (101010) - https://sketch.com -->\n <title>BE94B3C8-E695-41FA-A0FC-2CE95714B444@1.5x</title>\n <desc>Created with sketchtool.</desc>\n <g id=\"Schooling-@-home\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\n <g id=\"My-classes-Copy\" transform=\"translate(-316.000000, -248.000000)\" fill=\"#333333\">\n <g id=\"Group\" transform=\"translate(16.000000, 205.000000)\">\n <polygon id=\"Path\" transform=\"translate(306.894756, 47.000000) rotate(-270.000000) translate(-306.894756, -47.000000) \" points=\"304.599756 40.7073171 303.189756 42.1860976 307.769756 47 303.189756 51.8139024 304.599756 53.2926829 310.599756 47\"></polygon>\n </g>\n </g>\n </g>\n</svg>\n","styles":[""]}]}],"members":{"__ctor__":[{"__symbolic":"constructor"}],"ngOnInit":[{"__symbolic":"method"}]}}},"origins":{"CommonFormElementsComponent":"./lib/common-form-elements.component","CommonFormElementsModule":"./lib/common-form-elements.module","FieldConfigInputType":"./lib/common-form-config","FieldConfigValidationType":"./lib/common-form-config","FieldConfigOptionsBuilder":"./lib/common-form-config","AsyncValidatorFactory":"./lib/common-form-config","FieldConfigOption":"./lib/common-form-config","FieldConfigOptionAssociations":"./lib/common-form-config","FieldConfig":"./lib/common-form-config","ɵa":"./lib/dropdown/dropdown.component","ɵb":"./lib/textbox/textbox.component","ɵc":"./lib/textarea/textarea.component","ɵd":"./lib/checkbox/checkbox.component","ɵe":"./lib/form/form.component","ɵf":"./lib/option-group/option-group.component","ɵg":"./lib/icon/dropdown/dropdownIcon.component"},"importAs":"common-form-elements"}

@@ -7,6 +7,5 @@ /**

import { Component, Input } from '@angular/core';
import { FormControl } from '@angular/forms';
export class CheckboxComponent {
constructor() {
this.valuesInArr = [];
}
constructor() { }
/**

@@ -16,5 +15,2 @@ * @return {?}

ngOnInit() {
for (const prop of Object.keys(this.values)) {
this.valuesInArr.push(this.values[prop]);
}
}

@@ -25,4 +21,4 @@ }

selector: 'sb-checkbox',
template: "<div class=\"sb-checkbox\">\n <span><label>checkbox name</label></span>\n <div *ngFor=\"let value of valuesInArr\">\n <label>{{value}}</label>\n <span><input type=\"checkbox\" name=\"checkbox\" value={{value}}></span>\n </div>\n</div>",
styles: ["label{padding:10px;font-size:16px}"]
template: "<div class=\"sb-checkbox\">\n <div class=\"checkbox-row\">\n <label class=\"container\">\n <input type=\"checkbox\" [formControl]=\"formControlRef\" name=\"checkbox\" value=\"value\">\n <span class=\"checkmark\"></span>\n </label>\n <label class=\"checkbox-label\">{{label}}</label>\n </div>\n</div>",
styles: ["label{font-size:16px}.sb-checkbox{padding:0 0 0 8px}.container{position:relative;cursor:pointer;font-size:22px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.container .checkmark{position:absolute;top:0;left:0;height:25px;width:25px;border:2px solid #000;border-radius:4px}.container input:checked~.checkmark{background-color:#2196f3}.checkmark:after{content:\"\";position:absolute;display:none}.container input:checked~.checkmark:after{display:block}.container .checkmark:after{left:9px;top:5px;width:5px;height:10px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}.checkbox-label{padding:2px 0 0 32px}.checkbox-row{display:-ms-grid;display:grid;-ms-grid-columns:10px 250px;grid-template-columns:10px 250px;grid-gap:0}"]
}] }

@@ -34,3 +30,5 @@ ];

label: [{ type: Input }],
values: [{ type: Input }]
code: [{ type: Input }],
value: [{ type: Input }],
formControlRef: [{ type: Input }]
};

@@ -41,6 +39,8 @@ if (false) {

/** @type {?} */
CheckboxComponent.prototype.values;
CheckboxComponent.prototype.code;
/** @type {?} */
CheckboxComponent.prototype.valuesInArr;
CheckboxComponent.prototype.value;
/** @type {?} */
CheckboxComponent.prototype.formControlRef;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vY29tbW9uLWZvcm0tZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFPekQsTUFBTSxPQUFPLGlCQUFpQjtJQUs1QjtRQUZBLGdCQUFXLEdBQUcsRUFBRSxDQUFDO0lBRUQsQ0FBQzs7OztJQUVqQixRQUFRO1FBQ04sS0FBSyxNQUFNLElBQUksSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUMzQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7U0FDMUM7SUFDSCxDQUFDOzs7WUFoQkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxhQUFhO2dCQUN2Qiw2UUFBd0M7O2FBRXpDOzs7OztvQkFFRSxLQUFLO3FCQUNMLEtBQUs7Ozs7SUFETixrQ0FBb0I7O0lBQ3BCLG1DQUFxQjs7SUFDckIsd0NBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NiLWNoZWNrYm94JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NoZWNrYm94LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2hlY2tib3guY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIENoZWNrYm94Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgbGFiZWw6IGFueTtcbiAgQElucHV0KCkgdmFsdWVzOiBhbnk7XG4gIHZhbHVlc0luQXJyID0gW107XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICBmb3IgKGNvbnN0IHByb3Agb2YgT2JqZWN0LmtleXModGhpcy52YWx1ZXMpKSB7XG4gICAgICB0aGlzLnZhbHVlc0luQXJyLnB1c2godGhpcy52YWx1ZXNbcHJvcF0pO1xuICAgIH1cbiAgfVxuXG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vY29tbW9uLWZvcm0tZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBTzdDLE1BQU0sT0FBTyxpQkFBaUI7SUFNNUIsZ0JBQWdCLENBQUM7Ozs7SUFFakIsUUFBUTtJQUNSLENBQUM7OztZQWRGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsYUFBYTtnQkFDdkIsd1dBQXdDOzthQUV6Qzs7Ozs7b0JBRUUsS0FBSzttQkFDTCxLQUFLO29CQUNMLEtBQUs7NkJBQ0wsS0FBSzs7OztJQUhOLGtDQUFvQjs7SUFDcEIsaUNBQW1COztJQUNuQixrQ0FBcUI7O0lBQ3JCLDJDQUFzQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NiLWNoZWNrYm94JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NoZWNrYm94LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2hlY2tib3guY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIENoZWNrYm94Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgbGFiZWw6IGFueTtcbiAgQElucHV0KCkgY29kZTogYW55O1xuICBASW5wdXQoKSB2YWx1ZT86IGFueTtcbiAgQElucHV0KCkgZm9ybUNvbnRyb2xSZWY/OiBGb3JtQ29udHJvbDtcblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIG5nT25Jbml0KCkge1xuICB9XG5cbn1cbiJdfQ==

@@ -25,3 +25,3 @@ /**

if (this.isOptionsClosure(this.options)) {
this.options$ = (/** @type {?} */ (((/** @type {?} */ (changes['options'].currentValue)))(this.formControlRef, changes['context'].currentValue, (/**
this.options$ = (/** @type {?} */ (((/** @type {?} */ (this.options)))(this.formControlRef, this.context, (/**
* @return {?}

@@ -124,2 +124,2 @@ */

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vY29tbW9uLWZvcm0tZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvZHJvcGRvd24vZHJvcGRvd24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQThDLE1BQU0sZUFBZSxDQUFDO0FBQzVGLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQWEsT0FBTyxFQUFlLE1BQU0sTUFBTSxDQUFDO0FBRXZELE9BQU8sRUFBQyxHQUFHLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUNuQyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFPOUQsTUFBTSxPQUFPLGlCQUFpQjtJQWlCNUI7UUFoQkEsb0JBQWUsR0FBRyxlQUFlLENBQUM7UUFHekIsWUFBTyxHQUFRLEVBQUUsQ0FBQztJQWMzQixDQUFDOzs7OztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNqQixJQUFJLENBQUMsT0FBTyxHQUFHLEVBQUUsQ0FBQztTQUNuQjtRQUVELElBQUksSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUN2QyxJQUFJLENBQUMsUUFBUSxHQUFHLG1CQUFBLENBQUMsbUJBQUEsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLFlBQVksRUFBa0MsQ0FBQyxDQUNqRixJQUFJLENBQUMsY0FBYyxFQUNuQixPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsWUFBWTs7O1lBQy9CLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDOzs7WUFDakQsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFDakQsRUFBTyxDQUFDO1NBQ1Y7SUFDSCxDQUFDOzs7O0lBRUQsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNoQixJQUFJLENBQUMsK0JBQStCLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUNuRSxHQUFHOzs7WUFBQyxHQUFHLEVBQUU7Z0JBQ1AsSUFBSSxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDdkMsQ0FBQyxFQUFDLENBQ0gsQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNmO0lBQ0gsQ0FBQzs7OztJQUVELFdBQVc7SUFDWCxDQUFDOzs7OztJQUVELGNBQWMsQ0FBQyxPQUFZO1FBQ3pCLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUVoQyxDQUFDOzs7OztJQUVELGdCQUFnQixDQUFDLE9BQVk7UUFDM0IsT0FBTyxPQUFPLE9BQU8sS0FBSyxVQUFVLENBQUM7SUFDdkMsQ0FBQzs7Ozs7SUFFRCxZQUFZLENBQUMsS0FBVTtRQUNyQixPQUFPLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLENBQUM7SUFDNUQsQ0FBQzs7O1lBaEVGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsYUFBYTtnQkFDdkIseXhDQUF3Qzs7YUFFekM7Ozs7O3VCQUlFLEtBQUs7c0JBQ0wsS0FBSztvQkFDTCxLQUFLOzBCQUNMLEtBQUs7eUJBQ0wsS0FBSztzQkFDTCxLQUFLOzZCQUNMLEtBQUs7c0JBQ0wsS0FBSzswQkFDTCxLQUFLO3FDQUNMLEtBQUs7Ozs7SUFYTiw0Q0FBa0M7O0lBRWxDLHFDQUE0Qjs7SUFDNUIsb0NBQTJCOztJQUMzQixrQ0FBd0I7O0lBQ3hCLHdDQUE4Qjs7SUFDOUIsdUNBQThCOztJQUM5QixvQ0FBK0I7O0lBQy9CLDJDQUFzQzs7SUFDdEMsb0NBQXVCOztJQUN2Qix3Q0FBMEI7O0lBQzFCLG1EQUErRDs7SUFFL0QscUNBQWdEOztJQUNoRCw0REFBK0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgT25EZXN0cm95LCBPbkluaXQsIFNpbXBsZUNoYW5nZXN9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3JtQ29udHJvbH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHtPYnNlcnZhYmxlLCBTdWJqZWN0LCBTdWJzY3JpcHRpb259IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtGaWVsZENvbmZpZ09wdGlvbiwgRmllbGRDb25maWdPcHRpb25zQnVpbGRlcn0gZnJvbSAnLi4vY29tbW9uLWZvcm0tY29uZmlnJztcbmltcG9ydCB7dGFwfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQge1ZhbHVlQ29tcGFyYXRvcn0gZnJvbSAnLi4vdXRpbGl0aWVzL3ZhbHVlLWNvbXBhcmF0b3InO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYi1kcm9wZG93bicsXG4gIHRlbXBsYXRlVXJsOiAnLi9kcm9wZG93bi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Ryb3Bkb3duLmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBEcm9wZG93bkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3kge1xuICBWYWx1ZUNvbXBhcmF0b3IgPSBWYWx1ZUNvbXBhcmF0b3I7XG5cbiAgQElucHV0KCkgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBASW5wdXQoKSBvcHRpb25zOiBhbnkgPSBbXTtcbiAgQElucHV0KCkgbGFiZWw/OiBzdHJpbmc7XG4gIEBJbnB1dCgpIHBsYWNlSG9sZGVyPzogc3RyaW5nO1xuICBASW5wdXQoKSBpc011bHRpcGxlPzogYm9vbGVhbjtcbiAgQElucHV0KCkgY29udGV4dD86IEZvcm1Db250cm9sO1xuICBASW5wdXQoKSBmb3JtQ29udHJvbFJlZj86IEZvcm1Db250cm9sO1xuICBASW5wdXQoKSBkZWZhdWx0PzogYW55O1xuICBASW5wdXQoKSBjb250ZXh0RGF0YTogYW55O1xuICBASW5wdXQoKSBkYXRhTG9hZFN0YXR1c0RlbGVnYXRlOiBTdWJqZWN0PCdMT0FESU5HJyB8ICdMT0FERUQnPjtcblxuICBvcHRpb25zJD86IE9ic2VydmFibGU8RmllbGRDb25maWdPcHRpb248YW55PltdPjtcbiAgY29udGV4dFZhbHVlQ2hhbmdlc1N1YnNjcmlwdGlvbj86IFN1YnNjcmlwdGlvbjtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMub3B0aW9ucykge1xuICAgICAgdGhpcy5vcHRpb25zID0gW107XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuaXNPcHRpb25zQ2xvc3VyZSh0aGlzLm9wdGlvbnMpKSB7XG4gICAgICB0aGlzLm9wdGlvbnMkID0gKGNoYW5nZXNbJ29wdGlvbnMnXS5jdXJyZW50VmFsdWUgYXMgRmllbGRDb25maWdPcHRpb25zQnVpbGRlcjxhbnk+KShcbiAgICAgICAgdGhpcy5mb3JtQ29udHJvbFJlZixcbiAgICAgICAgY2hhbmdlc1snY29udGV4dCddLmN1cnJlbnRWYWx1ZSxcbiAgICAgICAgKCkgPT4gdGhpcy5kYXRhTG9hZFN0YXR1c0RlbGVnYXRlLm5leHQoJ0xPQURJTkcnKSxcbiAgICAgICAgKCkgPT4gdGhpcy5kYXRhTG9hZFN0YXR1c0RlbGVnYXRlLm5leHQoJ0xPQURFRCcpXG4gICAgICApIGFzIGFueTtcbiAgICB9XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICBpZiAodGhpcy5jb250ZXh0KSB7XG4gICAgICB0aGlzLmNvbnRleHRWYWx1ZUNoYW5nZXNTdWJzY3JpcHRpb24gPSB0aGlzLmNvbnRleHQudmFsdWVDaGFuZ2VzLnBpcGUoXG4gICAgICAgIHRhcCgoKSA9PiB7XG4gICAgICAgICAgdGhpcy5mb3JtQ29udHJvbFJlZi5wYXRjaFZhbHVlKG51bGwpO1xuICAgICAgICB9KVxuICAgICAgKS5zdWJzY3JpYmUoKTtcbiAgICB9XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgfVxuXG4gIGlzT3B0aW9uc0FycmF5KG9wdGlvbnM6IGFueSkge1xuICAgIHJldHVybiBBcnJheS5pc0FycmF5KG9wdGlvbnMpO1xuXG4gIH1cblxuICBpc09wdGlvbnNDbG9zdXJlKG9wdGlvbnM6IGFueSkge1xuICAgIHJldHVybiB0eXBlb2Ygb3B0aW9ucyA9PT0gJ2Z1bmN0aW9uJztcbiAgfVxuXG4gIGlzT3B0aW9uc01hcChpbnB1dDogYW55KSB7XG4gICAgcmV0dXJuICFBcnJheS5pc0FycmF5KGlucHV0KSAmJiB0eXBlb2YgaW5wdXQgPT09ICdvYmplY3QnO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vY29tbW9uLWZvcm0tZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvZHJvcGRvd24vZHJvcGRvd24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQThDLE1BQU0sZUFBZSxDQUFDO0FBQzVGLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQWEsT0FBTyxFQUFlLE1BQU0sTUFBTSxDQUFDO0FBRXZELE9BQU8sRUFBQyxHQUFHLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUNuQyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFPOUQsTUFBTSxPQUFPLGlCQUFpQjtJQWlCNUI7UUFoQkEsb0JBQWUsR0FBRyxlQUFlLENBQUM7UUFHekIsWUFBTyxHQUFRLEVBQUUsQ0FBQztJQWMzQixDQUFDOzs7OztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNqQixJQUFJLENBQUMsT0FBTyxHQUFHLEVBQUUsQ0FBQztTQUNuQjtRQUVELElBQUksSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUN2QyxJQUFJLENBQUMsUUFBUSxHQUFHLG1CQUFBLENBQUMsbUJBQUEsSUFBSSxDQUFDLE9BQU8sRUFBa0MsQ0FBQyxDQUM5RCxJQUFJLENBQUMsY0FBYyxFQUNuQixJQUFJLENBQUMsT0FBTzs7O1lBQ1osR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7OztZQUNqRCxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUNqRCxFQUFPLENBQUM7U0FDVjtJQUNILENBQUM7Ozs7SUFFRCxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2hCLElBQUksQ0FBQywrQkFBK0IsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQ25FLEdBQUc7OztZQUFDLEdBQUcsRUFBRTtnQkFDUCxJQUFJLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUN2QyxDQUFDLEVBQUMsQ0FDSCxDQUFDLFNBQVMsRUFBRSxDQUFDO1NBQ2Y7SUFDSCxDQUFDOzs7O0lBRUQsV0FBVztJQUNYLENBQUM7Ozs7O0lBRUQsY0FBYyxDQUFDLE9BQVk7UUFDekIsT0FBTyxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRWhDLENBQUM7Ozs7O0lBRUQsZ0JBQWdCLENBQUMsT0FBWTtRQUMzQixPQUFPLE9BQU8sT0FBTyxLQUFLLFVBQVUsQ0FBQztJQUN2QyxDQUFDOzs7OztJQUVELFlBQVksQ0FBQyxLQUFVO1FBQ3JCLE9BQU8sQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsQ0FBQztJQUM1RCxDQUFDOzs7WUFoRUYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxhQUFhO2dCQUN2Qix5eENBQXdDOzthQUV6Qzs7Ozs7dUJBSUUsS0FBSztzQkFDTCxLQUFLO29CQUNMLEtBQUs7MEJBQ0wsS0FBSzt5QkFDTCxLQUFLO3NCQUNMLEtBQUs7NkJBQ0wsS0FBSztzQkFDTCxLQUFLOzBCQUNMLEtBQUs7cUNBQ0wsS0FBSzs7OztJQVhOLDRDQUFrQzs7SUFFbEMscUNBQTRCOztJQUM1QixvQ0FBMkI7O0lBQzNCLGtDQUF3Qjs7SUFDeEIsd0NBQThCOztJQUM5Qix1Q0FBOEI7O0lBQzlCLG9DQUErQjs7SUFDL0IsMkNBQXNDOztJQUN0QyxvQ0FBdUI7O0lBQ3ZCLHdDQUEwQjs7SUFDMUIsbURBQStEOztJQUUvRCxxQ0FBZ0Q7O0lBQ2hELDREQUErQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3ksIE9uSW5pdCwgU2ltcGxlQ2hhbmdlc30gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Zvcm1Db250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge09ic2VydmFibGUsIFN1YmplY3QsIFN1YnNjcmlwdGlvbn0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0ZpZWxkQ29uZmlnT3B0aW9uLCBGaWVsZENvbmZpZ09wdGlvbnNCdWlsZGVyfSBmcm9tICcuLi9jb21tb24tZm9ybS1jb25maWcnO1xuaW1wb3J0IHt0YXB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7VmFsdWVDb21wYXJhdG9yfSBmcm9tICcuLi91dGlsaXRpZXMvdmFsdWUtY29tcGFyYXRvcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NiLWRyb3Bkb3duJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Ryb3Bkb3duLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZHJvcGRvd24uY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIERyb3Bkb3duQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSB7XG4gIFZhbHVlQ29tcGFyYXRvciA9IFZhbHVlQ29tcGFyYXRvcjtcblxuICBASW5wdXQoKSBkaXNhYmxlZD86IGJvb2xlYW47XG4gIEBJbnB1dCgpIG9wdGlvbnM6IGFueSA9IFtdO1xuICBASW5wdXQoKSBsYWJlbD86IHN0cmluZztcbiAgQElucHV0KCkgcGxhY2VIb2xkZXI/OiBzdHJpbmc7XG4gIEBJbnB1dCgpIGlzTXVsdGlwbGU/OiBib29sZWFuO1xuICBASW5wdXQoKSBjb250ZXh0PzogRm9ybUNvbnRyb2w7XG4gIEBJbnB1dCgpIGZvcm1Db250cm9sUmVmPzogRm9ybUNvbnRyb2w7XG4gIEBJbnB1dCgpIGRlZmF1bHQ/OiBhbnk7XG4gIEBJbnB1dCgpIGNvbnRleHREYXRhOiBhbnk7XG4gIEBJbnB1dCgpIGRhdGFMb2FkU3RhdHVzRGVsZWdhdGU6IFN1YmplY3Q8J0xPQURJTkcnIHwgJ0xPQURFRCc+O1xuXG4gIG9wdGlvbnMkPzogT2JzZXJ2YWJsZTxGaWVsZENvbmZpZ09wdGlvbjxhbnk+W10+O1xuICBjb250ZXh0VmFsdWVDaGFuZ2VzU3Vic2NyaXB0aW9uPzogU3Vic2NyaXB0aW9uO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIGlmICghdGhpcy5vcHRpb25zKSB7XG4gICAgICB0aGlzLm9wdGlvbnMgPSBbXTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5pc09wdGlvbnNDbG9zdXJlKHRoaXMub3B0aW9ucykpIHtcbiAgICAgIHRoaXMub3B0aW9ucyQgPSAodGhpcy5vcHRpb25zIGFzIEZpZWxkQ29uZmlnT3B0aW9uc0J1aWxkZXI8YW55PikoXG4gICAgICAgIHRoaXMuZm9ybUNvbnRyb2xSZWYsXG4gICAgICAgIHRoaXMuY29udGV4dCxcbiAgICAgICAgKCkgPT4gdGhpcy5kYXRhTG9hZFN0YXR1c0RlbGVnYXRlLm5leHQoJ0xPQURJTkcnKSxcbiAgICAgICAgKCkgPT4gdGhpcy5kYXRhTG9hZFN0YXR1c0RlbGVnYXRlLm5leHQoJ0xPQURFRCcpXG4gICAgICApIGFzIGFueTtcbiAgICB9XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICBpZiAodGhpcy5jb250ZXh0KSB7XG4gICAgICB0aGlzLmNvbnRleHRWYWx1ZUNoYW5nZXNTdWJzY3JpcHRpb24gPSB0aGlzLmNvbnRleHQudmFsdWVDaGFuZ2VzLnBpcGUoXG4gICAgICAgIHRhcCgoKSA9PiB7XG4gICAgICAgICAgdGhpcy5mb3JtQ29udHJvbFJlZi5wYXRjaFZhbHVlKG51bGwpO1xuICAgICAgICB9KVxuICAgICAgKS5zdWJzY3JpYmUoKTtcbiAgICB9XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgfVxuXG4gIGlzT3B0aW9uc0FycmF5KG9wdGlvbnM6IGFueSkge1xuICAgIHJldHVybiBBcnJheS5pc0FycmF5KG9wdGlvbnMpO1xuXG4gIH1cblxuICBpc09wdGlvbnNDbG9zdXJlKG9wdGlvbnM6IGFueSkge1xuICAgIHJldHVybiB0eXBlb2Ygb3B0aW9ucyA9PT0gJ2Z1bmN0aW9uJztcbiAgfVxuXG4gIGlzT3B0aW9uc01hcChpbnB1dDogYW55KSB7XG4gICAgcmV0dXJuICFBcnJheS5pc0FycmF5KGlucHV0KSAmJiB0eXBlb2YgaW5wdXQgPT09ICdvYmplY3QnO1xuICB9XG59XG4iXX0=

@@ -247,3 +247,3 @@ /**

selector: 'sb-form',
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [label]=\"field.code\" [values]=\"field.templateOptions.labelHtml.values\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [code]=\"field.code\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\" [value]=\"field.default\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
styles: [""]

@@ -305,2 +305,2 @@ }] }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"ng://common-form-elements/","sources":["lib/form/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges} from '@angular/core';\nimport {FieldConfig, FieldConfigInputType, FieldConfigValidationType} from '../common-form-config';\nimport {FormBuilder, FormGroup, Validators} from '@angular/forms';\nimport {Subject, Subscription} from 'rxjs';\nimport {distinctUntilChanged, map, scan, tap} from 'rxjs/operators';\n\n@Component({\n  selector: 'sb-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.css']\n})\nexport class FormComponent implements OnInit, OnChanges, OnDestroy {\n  @Output() initialize = new EventEmitter();\n  @Output() finalize = new EventEmitter();\n\n  @Output() valueChanges = new EventEmitter();\n  @Output() statusChanges = new EventEmitter();\n  @Output() dataLoadStatus = new EventEmitter<'LOADING' | 'LOADED'>();\n  @Input() config;\n  @Input() dataLoadStatusDelegate = new Subject<'LOADING' | 'LOADED'>();\n\n  formGroup: FormGroup;\n\n  FieldConfigInputType = FieldConfigInputType;\n\n  private statusChangesSubscription: Subscription;\n  private valueChangesSubscription: Subscription;\n  private dataLoadStatusSinkSubscription: Subscription;\n\n  constructor(\n    private formBuilder: FormBuilder\n  ) {\n    if (!window['forms']) {\n      window['forms'] = [];\n    }\n    window['forms'].push(this);\n  }\n\n  ngOnDestroy(): void {\n    this.finalize.emit();\n\n    if (this.statusChangesSubscription) {\n      this.statusChangesSubscription.unsubscribe();\n    }\n\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n\n    if (this.dataLoadStatusSinkSubscription) {\n      this.dataLoadStatusSinkSubscription.unsubscribe();\n    }\n  }\n\n  ngOnInit() {\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) {\n      if ((changes['config'].currentValue && changes['config'].firstChange) || changes['config'].previousValue !== changes['config'].currentValue) {\n        this.initializeForm();\n      }\n    }\n\n    if (this.dataLoadStatusSinkSubscription) {\n      this.dataLoadStatusSinkSubscription.unsubscribe();\n    }\n\n    if (this.statusChangesSubscription) {\n      this.statusChangesSubscription.unsubscribe();\n    }\n\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n\n    this.dataLoadStatusSinkSubscription = this.dataLoadStatusDelegate.pipe(\n      scan<'LOADING' | 'LOADED', { loadingCount: 0, loadedCount: 0 }>((acc, event) => {\n        if (event === 'LOADED') {\n          acc.loadedCount++;\n          return acc;\n        }\n\n        acc.loadingCount++;\n        return acc;\n      }, {loadingCount: 0, loadedCount: 0}),\n      map<{ loadingCount: 0, loadedCount: 0 }, 'LOADING' | 'LOADED'>((aggregates) => {\n        if (aggregates.loadingCount !== aggregates.loadedCount) {\n          return 'LOADING';\n        }\n\n        return 'LOADED';\n      }),\n      distinctUntilChanged(),\n      tap((result) => {\n        if (result === 'LOADING') {\n          this.dataLoadStatus.emit('LOADING');\n        } else {\n          this.dataLoadStatus.emit('LOADED');\n        }\n      })\n    ).subscribe();\n\n    this.statusChangesSubscription = this.formGroup.valueChanges.pipe(\n      tap((v) => {\n        this.statusChanges.emit({\n          isPristine: this.formGroup.pristine,\n          isDirty: this.formGroup.dirty,\n          isInvalid: this.formGroup.invalid,\n          isValid: this.formGroup.valid\n        });\n      })\n    ).subscribe();\n\n    this.valueChangesSubscription = this.formGroup.valueChanges.pipe(\n      tap((v) => {\n        this.valueChanges.emit(v);\n      })\n    ).subscribe();\n  }\n\n  onNestedFormFinalize(nestedFormGroup: FormGroup, fieldConfig: FieldConfig<any>) {\n    if (!this.formGroup.get('children') || !this.formGroup.get(`children.${fieldConfig.code}`)) {\n      return;\n    }\n\n    (this.formGroup.get('children') as FormGroup).removeControl(fieldConfig.code);\n\n    if (!Object.keys((this.formGroup.get('children') as FormGroup).controls).length) {\n      this.formGroup.removeControl('children');\n    }\n  }\n\n  onNestedFormInitialize(nestedFormGroup: FormGroup, fieldConfig: FieldConfig<any>) {\n    if (!this.formGroup.get('children')) {\n      this.formGroup.addControl('children', new FormGroup({}));\n    }\n\n    (this.formGroup.get('children') as FormGroup).addControl(fieldConfig.code, nestedFormGroup);\n  }\n\n  private initializeForm() {\n    if (!this.config.length) {\n      console.error('FORM LIST IS EMPTY');\n      return;\n    }\n    const formGroupData = {};\n    this.config.forEach((element: any, index) => {\n      if (element.type !== FieldConfigInputType.LABEL) {\n        const formValueList = this.prepareFormValidationData(element, index);\n        formGroupData[element.code] = formValueList;\n      }\n    });\n\n    this.formGroup = this.formBuilder.group(formGroupData);\n    this.initialize.emit(this.formGroup);\n  }\n\n  private prepareFormValidationData(element: FieldConfig<any>, index) {\n    const formValueList = [];\n    const validationList = [];\n\n    let defaultVal: any = '';\n    switch (element.type) {\n      case FieldConfigInputType.INPUT:\n        defaultVal = element.templateOptions.type === 'number' ?\n          (element.default && Number.isInteger(element.default) ? element.default : 0) : null;\n        break;\n      case FieldConfigInputType.SELECT:\n      case FieldConfigInputType.NESTED_SELECT:\n        defaultVal = element.templateOptions.multiple ?\n          (element.default && Array.isArray(element.default) ? element.default : []) : (element.default || null);\n        break;\n      case FieldConfigInputType.CHECKBOX:\n        defaultVal = false || !!element.default;\n        break;\n    }\n\n    formValueList.push(defaultVal);\n\n    if (element.validations && element.validations.length) {\n      element.validations.forEach((data, i) => {\n        switch (data.type) {\n          case FieldConfigValidationType.REQUIRED:\n            if (element.type === FieldConfigInputType.CHECKBOX) {\n              validationList.push(Validators.requiredTrue);\n            } else if (element.type === FieldConfigInputType.SELECT || element.type === FieldConfigInputType.NESTED_SELECT) {\n              validationList.push((c) => {\n                if (element.templateOptions.multiple) {\n                  return c.value && c.value.length ? null : 'error';\n                }\n                return !!c.value ? null : 'error';\n              });\n            } else {\n              validationList.push(Validators.required);\n            }\n            break;\n          case FieldConfigValidationType.PATTERN:\n            validationList.push(Validators.pattern(element.validations[i].value as string));\n            break;\n          case FieldConfigValidationType.MINLENGTH:\n            validationList.push(Validators.minLength(element.validations[i].value as number));\n            break;\n          case FieldConfigValidationType.MAXLENGTH:\n            validationList.push(Validators.maxLength(element.validations[i].value as number));\n            break;\n        }\n      });\n    }\n\n    formValueList.push(Validators.compose(validationList));\n\n    return formValueList;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"ng://common-form-elements/","sources":["lib/form/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges} from '@angular/core';\nimport {FieldConfig, FieldConfigInputType, FieldConfigValidationType} from '../common-form-config';\nimport {FormBuilder, FormGroup, Validators} from '@angular/forms';\nimport {Subject, Subscription} from 'rxjs';\nimport {distinctUntilChanged, map, scan, tap} from 'rxjs/operators';\n\n@Component({\n  selector: 'sb-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.css']\n})\nexport class FormComponent implements OnInit, OnChanges, OnDestroy {\n  @Output() initialize = new EventEmitter();\n  @Output() finalize = new EventEmitter();\n\n  @Output() valueChanges = new EventEmitter();\n  @Output() statusChanges = new EventEmitter();\n  @Output() dataLoadStatus = new EventEmitter<'LOADING' | 'LOADED'>();\n  @Input() config;\n  @Input() dataLoadStatusDelegate = new Subject<'LOADING' | 'LOADED'>();\n\n  formGroup: FormGroup;\n\n  FieldConfigInputType = FieldConfigInputType;\n\n  private statusChangesSubscription: Subscription;\n  private valueChangesSubscription: Subscription;\n  private dataLoadStatusSinkSubscription: Subscription;\n\n  constructor(\n    private formBuilder: FormBuilder\n  ) {\n    if (!window['forms']) {\n      window['forms'] = [];\n    }\n    window['forms'].push(this);\n  }\n\n  ngOnDestroy(): void {\n    this.finalize.emit();\n\n    if (this.statusChangesSubscription) {\n      this.statusChangesSubscription.unsubscribe();\n    }\n\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n\n    if (this.dataLoadStatusSinkSubscription) {\n      this.dataLoadStatusSinkSubscription.unsubscribe();\n    }\n  }\n\n  ngOnInit() {\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) {\n      if ((changes['config'].currentValue && changes['config'].firstChange) || changes['config'].previousValue !== changes['config'].currentValue) {\n        this.initializeForm();\n      }\n    }\n\n    if (this.dataLoadStatusSinkSubscription) {\n      this.dataLoadStatusSinkSubscription.unsubscribe();\n    }\n\n    if (this.statusChangesSubscription) {\n      this.statusChangesSubscription.unsubscribe();\n    }\n\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n\n    this.dataLoadStatusSinkSubscription = this.dataLoadStatusDelegate.pipe(\n      scan<'LOADING' | 'LOADED', { loadingCount: 0, loadedCount: 0 }>((acc, event) => {\n        if (event === 'LOADED') {\n          acc.loadedCount++;\n          return acc;\n        }\n\n        acc.loadingCount++;\n        return acc;\n      }, {loadingCount: 0, loadedCount: 0}),\n      map<{ loadingCount: 0, loadedCount: 0 }, 'LOADING' | 'LOADED'>((aggregates) => {\n        if (aggregates.loadingCount !== aggregates.loadedCount) {\n          return 'LOADING';\n        }\n\n        return 'LOADED';\n      }),\n      distinctUntilChanged(),\n      tap((result) => {\n        if (result === 'LOADING') {\n          this.dataLoadStatus.emit('LOADING');\n        } else {\n          this.dataLoadStatus.emit('LOADED');\n        }\n      })\n    ).subscribe();\n\n    this.statusChangesSubscription = this.formGroup.valueChanges.pipe(\n      tap((v) => {\n        this.statusChanges.emit({\n          isPristine: this.formGroup.pristine,\n          isDirty: this.formGroup.dirty,\n          isInvalid: this.formGroup.invalid,\n          isValid: this.formGroup.valid\n        });\n      })\n    ).subscribe();\n\n    this.valueChangesSubscription = this.formGroup.valueChanges.pipe(\n      tap((v) => {\n        this.valueChanges.emit(v);\n      })\n    ).subscribe();\n  }\n\n  onNestedFormFinalize(nestedFormGroup: FormGroup, fieldConfig: FieldConfig<any>) {\n    if (!this.formGroup.get('children') || !this.formGroup.get(`children.${fieldConfig.code}`)) {\n      return;\n    }\n\n    (this.formGroup.get('children') as FormGroup).removeControl(fieldConfig.code);\n\n    if (!Object.keys((this.formGroup.get('children') as FormGroup).controls).length) {\n      this.formGroup.removeControl('children');\n    }\n  }\n\n  onNestedFormInitialize(nestedFormGroup: FormGroup, fieldConfig: FieldConfig<any>) {\n    if (!this.formGroup.get('children')) {\n      this.formGroup.addControl('children', new FormGroup({}));\n    }\n\n    (this.formGroup.get('children') as FormGroup).addControl(fieldConfig.code, nestedFormGroup);\n  }\n\n  private initializeForm() {\n    if (!this.config.length) {\n      console.error('FORM LIST IS EMPTY');\n      return;\n    }\n    const formGroupData = {};\n    this.config.forEach((element: any, index) => {\n      if (element.type !== FieldConfigInputType.LABEL) {\n        const formValueList = this.prepareFormValidationData(element, index);\n        formGroupData[element.code] = formValueList;\n      }\n    });\n\n    this.formGroup = this.formBuilder.group(formGroupData);\n    this.initialize.emit(this.formGroup);\n  }\n\n  private prepareFormValidationData(element: FieldConfig<any>, index) {\n    const formValueList = [];\n    const validationList = [];\n\n    let defaultVal: any = '';\n    switch (element.type) {\n      case FieldConfigInputType.INPUT:\n        defaultVal = element.templateOptions.type === 'number' ?\n          (element.default && Number.isInteger(element.default) ? element.default : 0) : null;\n        break;\n      case FieldConfigInputType.SELECT:\n      case FieldConfigInputType.NESTED_SELECT:\n        defaultVal = element.templateOptions.multiple ?\n          (element.default && Array.isArray(element.default) ? element.default : []) : (element.default || null);\n        break;\n      case FieldConfigInputType.CHECKBOX:\n        defaultVal = false || !!element.default;\n        break;\n    }\n\n    formValueList.push(defaultVal);\n\n    if (element.validations && element.validations.length) {\n      element.validations.forEach((data, i) => {\n        switch (data.type) {\n          case FieldConfigValidationType.REQUIRED:\n            if (element.type === FieldConfigInputType.CHECKBOX) {\n              validationList.push(Validators.requiredTrue);\n            } else if (element.type === FieldConfigInputType.SELECT || element.type === FieldConfigInputType.NESTED_SELECT) {\n              validationList.push((c) => {\n                if (element.templateOptions.multiple) {\n                  return c.value && c.value.length ? null : 'error';\n                }\n                return !!c.value ? null : 'error';\n              });\n            } else {\n              validationList.push(Validators.required);\n            }\n            break;\n          case FieldConfigValidationType.PATTERN:\n            validationList.push(Validators.pattern(element.validations[i].value as string));\n            break;\n          case FieldConfigValidationType.MINLENGTH:\n            validationList.push(Validators.minLength(element.validations[i].value as number));\n            break;\n          case FieldConfigValidationType.MAXLENGTH:\n            validationList.push(Validators.maxLength(element.validations[i].value as number));\n            break;\n        }\n      });\n    }\n\n    formValueList.push(Validators.compose(validationList));\n\n    return formValueList;\n  }\n}\n"]}

@@ -6,7 +6,6 @@ /**

*/
import * as tslib_1 from "tslib";
import { Component, Input } from '@angular/core';
import { FormControl } from '@angular/forms';
var CheckboxComponent = /** @class */ (function () {
function CheckboxComponent() {
this.valuesInArr = [];
}

@@ -20,16 +19,2 @@ /**

function () {
var e_1, _a;
try {
for (var _b = tslib_1.__values(Object.keys(this.values)), _c = _b.next(); !_c.done; _c = _b.next()) {
var prop = _c.value;
this.valuesInArr.push(this.values[prop]);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
};

@@ -39,4 +24,4 @@ CheckboxComponent.decorators = [

selector: 'sb-checkbox',
template: "<div class=\"sb-checkbox\">\n <span><label>checkbox name</label></span>\n <div *ngFor=\"let value of valuesInArr\">\n <label>{{value}}</label>\n <span><input type=\"checkbox\" name=\"checkbox\" value={{value}}></span>\n </div>\n</div>",
styles: ["label{padding:10px;font-size:16px}"]
template: "<div class=\"sb-checkbox\">\n <div class=\"checkbox-row\">\n <label class=\"container\">\n <input type=\"checkbox\" [formControl]=\"formControlRef\" name=\"checkbox\" value=\"value\">\n <span class=\"checkmark\"></span>\n </label>\n <label class=\"checkbox-label\">{{label}}</label>\n </div>\n</div>",
styles: ["label{font-size:16px}.sb-checkbox{padding:0 0 0 8px}.container{position:relative;cursor:pointer;font-size:22px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.container .checkmark{position:absolute;top:0;left:0;height:25px;width:25px;border:2px solid #000;border-radius:4px}.container input:checked~.checkmark{background-color:#2196f3}.checkmark:after{content:\"\";position:absolute;display:none}.container input:checked~.checkmark:after{display:block}.container .checkmark:after{left:9px;top:5px;width:5px;height:10px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}.checkbox-label{padding:2px 0 0 32px}.checkbox-row{display:-ms-grid;display:grid;-ms-grid-columns:10px 250px;grid-template-columns:10px 250px;grid-gap:0}"]
}] }

@@ -48,3 +33,5 @@ ];

label: [{ type: Input }],
values: [{ type: Input }]
code: [{ type: Input }],
value: [{ type: Input }],
formControlRef: [{ type: Input }]
};

@@ -58,6 +45,8 @@ return CheckboxComponent;

/** @type {?} */
CheckboxComponent.prototype.values;
CheckboxComponent.prototype.code;
/** @type {?} */
CheckboxComponent.prototype.valuesInArr;
CheckboxComponent.prototype.value;
/** @type {?} */
CheckboxComponent.prototype.formControlRef;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vY29tbW9uLWZvcm0tZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpEO0lBVUU7UUFGQSxnQkFBVyxHQUFHLEVBQUUsQ0FBQztJQUVELENBQUM7Ozs7SUFFakIsb0NBQVE7OztJQUFSOzs7WUFDRSxLQUFtQixJQUFBLEtBQUEsaUJBQUEsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUEsZ0JBQUEsNEJBQUU7Z0JBQXhDLElBQU0sSUFBSSxXQUFBO2dCQUNiLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQzthQUMxQzs7Ozs7Ozs7O0lBQ0gsQ0FBQzs7Z0JBaEJGLFNBQVMsU0FBQztvQkFDVCxRQUFRLEVBQUUsYUFBYTtvQkFDdkIsNlFBQXdDOztpQkFFekM7Ozs7O3dCQUVFLEtBQUs7eUJBQ0wsS0FBSzs7SUFXUix3QkFBQztDQUFBLEFBbEJELElBa0JDO1NBYlksaUJBQWlCOzs7SUFDNUIsa0NBQW9COztJQUNwQixtQ0FBcUI7O0lBQ3JCLHdDQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYi1jaGVja2JveCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaGVja2JveC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NoZWNrYm94LmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBDaGVja2JveENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIGxhYmVsOiBhbnk7XG4gIEBJbnB1dCgpIHZhbHVlczogYW55O1xuICB2YWx1ZXNJbkFyciA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgZm9yIChjb25zdCBwcm9wIG9mIE9iamVjdC5rZXlzKHRoaXMudmFsdWVzKSkge1xuICAgICAgdGhpcy52YWx1ZXNJbkFyci5wdXNoKHRoaXMudmFsdWVzW3Byb3BdKTtcbiAgICB9XG4gIH1cblxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2tib3guY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vY29tbW9uLWZvcm0tZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTdDO0lBV0U7SUFBZ0IsQ0FBQzs7OztJQUVqQixvQ0FBUTs7O0lBQVI7SUFDQSxDQUFDOztnQkFkRixTQUFTLFNBQUM7b0JBQ1QsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLHdXQUF3Qzs7aUJBRXpDOzs7Ozt3QkFFRSxLQUFLO3VCQUNMLEtBQUs7d0JBQ0wsS0FBSztpQ0FDTCxLQUFLOztJQU9SLHdCQUFDO0NBQUEsQUFoQkQsSUFnQkM7U0FYWSxpQkFBaUI7OztJQUM1QixrQ0FBb0I7O0lBQ3BCLGlDQUFtQjs7SUFDbkIsa0NBQXFCOztJQUNyQiwyQ0FBc0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1Db250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYi1jaGVja2JveCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaGVja2JveC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NoZWNrYm94LmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBDaGVja2JveENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpIGxhYmVsOiBhbnk7XG4gIEBJbnB1dCgpIGNvZGU6IGFueTtcbiAgQElucHV0KCkgdmFsdWU/OiBhbnk7XG4gIEBJbnB1dCgpIGZvcm1Db250cm9sUmVmPzogRm9ybUNvbnRyb2w7XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuICBuZ09uSW5pdCgpIHtcbiAgfVxuXG59XG4iXX0=

@@ -30,3 +30,3 @@ /**

if (this.isOptionsClosure(this.options)) {
this.options$ = (/** @type {?} */ (((/** @type {?} */ (changes['options'].currentValue)))(this.formControlRef, changes['context'].currentValue, (/**
this.options$ = (/** @type {?} */ (((/** @type {?} */ (this.options)))(this.formControlRef, this.context, (/**
* @return {?}

@@ -150,2 +150,2 @@ */

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vY29tbW9uLWZvcm0tZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvZHJvcGRvd24vZHJvcGRvd24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQThDLE1BQU0sZUFBZSxDQUFDO0FBQzVGLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQWEsT0FBTyxFQUFlLE1BQU0sTUFBTSxDQUFDO0FBRXZELE9BQU8sRUFBQyxHQUFHLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUNuQyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFFOUQ7SUFzQkU7UUFoQkEsb0JBQWUsR0FBRyxlQUFlLENBQUM7UUFHekIsWUFBTyxHQUFRLEVBQUUsQ0FBQztJQWMzQixDQUFDOzs7OztJQUVELHVDQUFXOzs7O0lBQVgsVUFBWSxPQUFzQjtRQUFsQyxpQkFhQztRQVpDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2pCLElBQUksQ0FBQyxPQUFPLEdBQUcsRUFBRSxDQUFDO1NBQ25CO1FBRUQsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQ3ZDLElBQUksQ0FBQyxRQUFRLEdBQUcsbUJBQUEsQ0FBQyxtQkFBQSxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsWUFBWSxFQUFrQyxDQUFDLENBQ2pGLElBQUksQ0FBQyxjQUFjLEVBQ25CLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxZQUFZOzs7WUFDL0IsY0FBTSxPQUFBLEtBQUksQ0FBQyxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQTNDLENBQTJDOzs7WUFDakQsY0FBTSxPQUFBLEtBQUksQ0FBQyxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQTFDLENBQTBDLEVBQ2pELEVBQU8sQ0FBQztTQUNWO0lBQ0gsQ0FBQzs7OztJQUVELG9DQUFROzs7SUFBUjtRQUFBLGlCQVFDO1FBUEMsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2hCLElBQUksQ0FBQywrQkFBK0IsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQ25FLEdBQUc7OztZQUFDO2dCQUNGLEtBQUksQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ3ZDLENBQUMsRUFBQyxDQUNILENBQUMsU0FBUyxFQUFFLENBQUM7U0FDZjtJQUNILENBQUM7Ozs7SUFFRCx1Q0FBVzs7O0lBQVg7SUFDQSxDQUFDOzs7OztJQUVELDBDQUFjOzs7O0lBQWQsVUFBZSxPQUFZO1FBQ3pCLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUVoQyxDQUFDOzs7OztJQUVELDRDQUFnQjs7OztJQUFoQixVQUFpQixPQUFZO1FBQzNCLE9BQU8sT0FBTyxPQUFPLEtBQUssVUFBVSxDQUFDO0lBQ3ZDLENBQUM7Ozs7O0lBRUQsd0NBQVk7Ozs7SUFBWixVQUFhLEtBQVU7UUFDckIsT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxDQUFDO0lBQzVELENBQUM7O2dCQWhFRixTQUFTLFNBQUM7b0JBQ1QsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLHl4Q0FBd0M7O2lCQUV6Qzs7Ozs7MkJBSUUsS0FBSzswQkFDTCxLQUFLO3dCQUNMLEtBQUs7OEJBQ0wsS0FBSzs2QkFDTCxLQUFLOzBCQUNMLEtBQUs7aUNBQ0wsS0FBSzswQkFDTCxLQUFLOzhCQUNMLEtBQUs7eUNBQ0wsS0FBSzs7SUFnRFIsd0JBQUM7Q0FBQSxBQWpFRCxJQWlFQztTQTVEWSxpQkFBaUI7OztJQUM1Qiw0Q0FBa0M7O0lBRWxDLHFDQUE0Qjs7SUFDNUIsb0NBQTJCOztJQUMzQixrQ0FBd0I7O0lBQ3hCLHdDQUE4Qjs7SUFDOUIsdUNBQThCOztJQUM5QixvQ0FBK0I7O0lBQy9CLDJDQUFzQzs7SUFDdEMsb0NBQXVCOztJQUN2Qix3Q0FBMEI7O0lBQzFCLG1EQUErRDs7SUFFL0QscUNBQWdEOztJQUNoRCw0REFBK0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgT25EZXN0cm95LCBPbkluaXQsIFNpbXBsZUNoYW5nZXN9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3JtQ29udHJvbH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHtPYnNlcnZhYmxlLCBTdWJqZWN0LCBTdWJzY3JpcHRpb259IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtGaWVsZENvbmZpZ09wdGlvbiwgRmllbGRDb25maWdPcHRpb25zQnVpbGRlcn0gZnJvbSAnLi4vY29tbW9uLWZvcm0tY29uZmlnJztcbmltcG9ydCB7dGFwfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQge1ZhbHVlQ29tcGFyYXRvcn0gZnJvbSAnLi4vdXRpbGl0aWVzL3ZhbHVlLWNvbXBhcmF0b3InO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYi1kcm9wZG93bicsXG4gIHRlbXBsYXRlVXJsOiAnLi9kcm9wZG93bi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Ryb3Bkb3duLmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBEcm9wZG93bkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3kge1xuICBWYWx1ZUNvbXBhcmF0b3IgPSBWYWx1ZUNvbXBhcmF0b3I7XG5cbiAgQElucHV0KCkgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBASW5wdXQoKSBvcHRpb25zOiBhbnkgPSBbXTtcbiAgQElucHV0KCkgbGFiZWw/OiBzdHJpbmc7XG4gIEBJbnB1dCgpIHBsYWNlSG9sZGVyPzogc3RyaW5nO1xuICBASW5wdXQoKSBpc011bHRpcGxlPzogYm9vbGVhbjtcbiAgQElucHV0KCkgY29udGV4dD86IEZvcm1Db250cm9sO1xuICBASW5wdXQoKSBmb3JtQ29udHJvbFJlZj86IEZvcm1Db250cm9sO1xuICBASW5wdXQoKSBkZWZhdWx0PzogYW55O1xuICBASW5wdXQoKSBjb250ZXh0RGF0YTogYW55O1xuICBASW5wdXQoKSBkYXRhTG9hZFN0YXR1c0RlbGVnYXRlOiBTdWJqZWN0PCdMT0FESU5HJyB8ICdMT0FERUQnPjtcblxuICBvcHRpb25zJD86IE9ic2VydmFibGU8RmllbGRDb25maWdPcHRpb248YW55PltdPjtcbiAgY29udGV4dFZhbHVlQ2hhbmdlc1N1YnNjcmlwdGlvbj86IFN1YnNjcmlwdGlvbjtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMub3B0aW9ucykge1xuICAgICAgdGhpcy5vcHRpb25zID0gW107XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuaXNPcHRpb25zQ2xvc3VyZSh0aGlzLm9wdGlvbnMpKSB7XG4gICAgICB0aGlzLm9wdGlvbnMkID0gKGNoYW5nZXNbJ29wdGlvbnMnXS5jdXJyZW50VmFsdWUgYXMgRmllbGRDb25maWdPcHRpb25zQnVpbGRlcjxhbnk+KShcbiAgICAgICAgdGhpcy5mb3JtQ29udHJvbFJlZixcbiAgICAgICAgY2hhbmdlc1snY29udGV4dCddLmN1cnJlbnRWYWx1ZSxcbiAgICAgICAgKCkgPT4gdGhpcy5kYXRhTG9hZFN0YXR1c0RlbGVnYXRlLm5leHQoJ0xPQURJTkcnKSxcbiAgICAgICAgKCkgPT4gdGhpcy5kYXRhTG9hZFN0YXR1c0RlbGVnYXRlLm5leHQoJ0xPQURFRCcpXG4gICAgICApIGFzIGFueTtcbiAgICB9XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICBpZiAodGhpcy5jb250ZXh0KSB7XG4gICAgICB0aGlzLmNvbnRleHRWYWx1ZUNoYW5nZXNTdWJzY3JpcHRpb24gPSB0aGlzLmNvbnRleHQudmFsdWVDaGFuZ2VzLnBpcGUoXG4gICAgICAgIHRhcCgoKSA9PiB7XG4gICAgICAgICAgdGhpcy5mb3JtQ29udHJvbFJlZi5wYXRjaFZhbHVlKG51bGwpO1xuICAgICAgICB9KVxuICAgICAgKS5zdWJzY3JpYmUoKTtcbiAgICB9XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgfVxuXG4gIGlzT3B0aW9uc0FycmF5KG9wdGlvbnM6IGFueSkge1xuICAgIHJldHVybiBBcnJheS5pc0FycmF5KG9wdGlvbnMpO1xuXG4gIH1cblxuICBpc09wdGlvbnNDbG9zdXJlKG9wdGlvbnM6IGFueSkge1xuICAgIHJldHVybiB0eXBlb2Ygb3B0aW9ucyA9PT0gJ2Z1bmN0aW9uJztcbiAgfVxuXG4gIGlzT3B0aW9uc01hcChpbnB1dDogYW55KSB7XG4gICAgcmV0dXJuICFBcnJheS5pc0FycmF5KGlucHV0KSAmJiB0eXBlb2YgaW5wdXQgPT09ICdvYmplY3QnO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vY29tbW9uLWZvcm0tZWxlbWVudHMvIiwic291cmNlcyI6WyJsaWIvZHJvcGRvd24vZHJvcGRvd24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQThDLE1BQU0sZUFBZSxDQUFDO0FBQzVGLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQWEsT0FBTyxFQUFlLE1BQU0sTUFBTSxDQUFDO0FBRXZELE9BQU8sRUFBQyxHQUFHLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUNuQyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFFOUQ7SUFzQkU7UUFoQkEsb0JBQWUsR0FBRyxlQUFlLENBQUM7UUFHekIsWUFBTyxHQUFRLEVBQUUsQ0FBQztJQWMzQixDQUFDOzs7OztJQUVELHVDQUFXOzs7O0lBQVgsVUFBWSxPQUFzQjtRQUFsQyxpQkFhQztRQVpDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2pCLElBQUksQ0FBQyxPQUFPLEdBQUcsRUFBRSxDQUFDO1NBQ25CO1FBRUQsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQ3ZDLElBQUksQ0FBQyxRQUFRLEdBQUcsbUJBQUEsQ0FBQyxtQkFBQSxJQUFJLENBQUMsT0FBTyxFQUFrQyxDQUFDLENBQzlELElBQUksQ0FBQyxjQUFjLEVBQ25CLElBQUksQ0FBQyxPQUFPOzs7WUFDWixjQUFNLE9BQUEsS0FBSSxDQUFDLHNCQUFzQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBM0MsQ0FBMkM7OztZQUNqRCxjQUFNLE9BQUEsS0FBSSxDQUFDLHNCQUFzQixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBMUMsQ0FBMEMsRUFDakQsRUFBTyxDQUFDO1NBQ1Y7SUFDSCxDQUFDOzs7O0lBRUQsb0NBQVE7OztJQUFSO1FBQUEsaUJBUUM7UUFQQyxJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDaEIsSUFBSSxDQUFDLCtCQUErQixHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLElBQUksQ0FDbkUsR0FBRzs7O1lBQUM7Z0JBQ0YsS0FBSSxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDdkMsQ0FBQyxFQUFDLENBQ0gsQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNmO0lBQ0gsQ0FBQzs7OztJQUVELHVDQUFXOzs7SUFBWDtJQUNBLENBQUM7Ozs7O0lBRUQsMENBQWM7Ozs7SUFBZCxVQUFlLE9BQVk7UUFDekIsT0FBTyxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRWhDLENBQUM7Ozs7O0lBRUQsNENBQWdCOzs7O0lBQWhCLFVBQWlCLE9BQVk7UUFDM0IsT0FBTyxPQUFPLE9BQU8sS0FBSyxVQUFVLENBQUM7SUFDdkMsQ0FBQzs7Ozs7SUFFRCx3Q0FBWTs7OztJQUFaLFVBQWEsS0FBVTtRQUNyQixPQUFPLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLENBQUM7SUFDNUQsQ0FBQzs7Z0JBaEVGLFNBQVMsU0FBQztvQkFDVCxRQUFRLEVBQUUsYUFBYTtvQkFDdkIseXhDQUF3Qzs7aUJBRXpDOzs7OzsyQkFJRSxLQUFLOzBCQUNMLEtBQUs7d0JBQ0wsS0FBSzs4QkFDTCxLQUFLOzZCQUNMLEtBQUs7MEJBQ0wsS0FBSztpQ0FDTCxLQUFLOzBCQUNMLEtBQUs7OEJBQ0wsS0FBSzt5Q0FDTCxLQUFLOztJQWdEUix3QkFBQztDQUFBLEFBakVELElBaUVDO1NBNURZLGlCQUFpQjs7O0lBQzVCLDRDQUFrQzs7SUFFbEMscUNBQTRCOztJQUM1QixvQ0FBMkI7O0lBQzNCLGtDQUF3Qjs7SUFDeEIsd0NBQThCOztJQUM5Qix1Q0FBOEI7O0lBQzlCLG9DQUErQjs7SUFDL0IsMkNBQXNDOztJQUN0QyxvQ0FBdUI7O0lBQ3ZCLHdDQUEwQjs7SUFDMUIsbURBQStEOztJQUUvRCxxQ0FBZ0Q7O0lBQ2hELDREQUErQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3ksIE9uSW5pdCwgU2ltcGxlQ2hhbmdlc30gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Zvcm1Db250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge09ic2VydmFibGUsIFN1YmplY3QsIFN1YnNjcmlwdGlvbn0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0ZpZWxkQ29uZmlnT3B0aW9uLCBGaWVsZENvbmZpZ09wdGlvbnNCdWlsZGVyfSBmcm9tICcuLi9jb21tb24tZm9ybS1jb25maWcnO1xuaW1wb3J0IHt0YXB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7VmFsdWVDb21wYXJhdG9yfSBmcm9tICcuLi91dGlsaXRpZXMvdmFsdWUtY29tcGFyYXRvcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NiLWRyb3Bkb3duJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Ryb3Bkb3duLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZHJvcGRvd24uY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIERyb3Bkb3duQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSB7XG4gIFZhbHVlQ29tcGFyYXRvciA9IFZhbHVlQ29tcGFyYXRvcjtcblxuICBASW5wdXQoKSBkaXNhYmxlZD86IGJvb2xlYW47XG4gIEBJbnB1dCgpIG9wdGlvbnM6IGFueSA9IFtdO1xuICBASW5wdXQoKSBsYWJlbD86IHN0cmluZztcbiAgQElucHV0KCkgcGxhY2VIb2xkZXI/OiBzdHJpbmc7XG4gIEBJbnB1dCgpIGlzTXVsdGlwbGU/OiBib29sZWFuO1xuICBASW5wdXQoKSBjb250ZXh0PzogRm9ybUNvbnRyb2w7XG4gIEBJbnB1dCgpIGZvcm1Db250cm9sUmVmPzogRm9ybUNvbnRyb2w7XG4gIEBJbnB1dCgpIGRlZmF1bHQ/OiBhbnk7XG4gIEBJbnB1dCgpIGNvbnRleHREYXRhOiBhbnk7XG4gIEBJbnB1dCgpIGRhdGFMb2FkU3RhdHVzRGVsZWdhdGU6IFN1YmplY3Q8J0xPQURJTkcnIHwgJ0xPQURFRCc+O1xuXG4gIG9wdGlvbnMkPzogT2JzZXJ2YWJsZTxGaWVsZENvbmZpZ09wdGlvbjxhbnk+W10+O1xuICBjb250ZXh0VmFsdWVDaGFuZ2VzU3Vic2NyaXB0aW9uPzogU3Vic2NyaXB0aW9uO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcyk6IHZvaWQge1xuICAgIGlmICghdGhpcy5vcHRpb25zKSB7XG4gICAgICB0aGlzLm9wdGlvbnMgPSBbXTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5pc09wdGlvbnNDbG9zdXJlKHRoaXMub3B0aW9ucykpIHtcbiAgICAgIHRoaXMub3B0aW9ucyQgPSAodGhpcy5vcHRpb25zIGFzIEZpZWxkQ29uZmlnT3B0aW9uc0J1aWxkZXI8YW55PikoXG4gICAgICAgIHRoaXMuZm9ybUNvbnRyb2xSZWYsXG4gICAgICAgIHRoaXMuY29udGV4dCxcbiAgICAgICAgKCkgPT4gdGhpcy5kYXRhTG9hZFN0YXR1c0RlbGVnYXRlLm5leHQoJ0xPQURJTkcnKSxcbiAgICAgICAgKCkgPT4gdGhpcy5kYXRhTG9hZFN0YXR1c0RlbGVnYXRlLm5leHQoJ0xPQURFRCcpXG4gICAgICApIGFzIGFueTtcbiAgICB9XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICBpZiAodGhpcy5jb250ZXh0KSB7XG4gICAgICB0aGlzLmNvbnRleHRWYWx1ZUNoYW5nZXNTdWJzY3JpcHRpb24gPSB0aGlzLmNvbnRleHQudmFsdWVDaGFuZ2VzLnBpcGUoXG4gICAgICAgIHRhcCgoKSA9PiB7XG4gICAgICAgICAgdGhpcy5mb3JtQ29udHJvbFJlZi5wYXRjaFZhbHVlKG51bGwpO1xuICAgICAgICB9KVxuICAgICAgKS5zdWJzY3JpYmUoKTtcbiAgICB9XG4gIH1cblxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgfVxuXG4gIGlzT3B0aW9uc0FycmF5KG9wdGlvbnM6IGFueSkge1xuICAgIHJldHVybiBBcnJheS5pc0FycmF5KG9wdGlvbnMpO1xuXG4gIH1cblxuICBpc09wdGlvbnNDbG9zdXJlKG9wdGlvbnM6IGFueSkge1xuICAgIHJldHVybiB0eXBlb2Ygb3B0aW9ucyA9PT0gJ2Z1bmN0aW9uJztcbiAgfVxuXG4gIGlzT3B0aW9uc01hcChpbnB1dDogYW55KSB7XG4gICAgcmV0dXJuICFBcnJheS5pc0FycmF5KGlucHV0KSAmJiB0eXBlb2YgaW5wdXQgPT09ICdvYmplY3QnO1xuICB9XG59XG4iXX0=

@@ -275,3 +275,3 @@ /**

selector: 'sb-form',
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [label]=\"field.code\" [values]=\"field.templateOptions.labelHtml.values\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [code]=\"field.code\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\" [value]=\"field.default\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
styles: [""]

@@ -336,2 +336,2 @@ }] }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"ng://common-form-elements/","sources":["lib/form/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges} from '@angular/core';\nimport {FieldConfig, FieldConfigInputType, FieldConfigValidationType} from '../common-form-config';\nimport {FormBuilder, FormGroup, Validators} from '@angular/forms';\nimport {Subject, Subscription} from 'rxjs';\nimport {distinctUntilChanged, map, scan, tap} from 'rxjs/operators';\n\n@Component({\n  selector: 'sb-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.css']\n})\nexport class FormComponent implements OnInit, OnChanges, OnDestroy {\n  @Output() initialize = new EventEmitter();\n  @Output() finalize = new EventEmitter();\n\n  @Output() valueChanges = new EventEmitter();\n  @Output() statusChanges = new EventEmitter();\n  @Output() dataLoadStatus = new EventEmitter<'LOADING' | 'LOADED'>();\n  @Input() config;\n  @Input() dataLoadStatusDelegate = new Subject<'LOADING' | 'LOADED'>();\n\n  formGroup: FormGroup;\n\n  FieldConfigInputType = FieldConfigInputType;\n\n  private statusChangesSubscription: Subscription;\n  private valueChangesSubscription: Subscription;\n  private dataLoadStatusSinkSubscription: Subscription;\n\n  constructor(\n    private formBuilder: FormBuilder\n  ) {\n    if (!window['forms']) {\n      window['forms'] = [];\n    }\n    window['forms'].push(this);\n  }\n\n  ngOnDestroy(): void {\n    this.finalize.emit();\n\n    if (this.statusChangesSubscription) {\n      this.statusChangesSubscription.unsubscribe();\n    }\n\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n\n    if (this.dataLoadStatusSinkSubscription) {\n      this.dataLoadStatusSinkSubscription.unsubscribe();\n    }\n  }\n\n  ngOnInit() {\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) {\n      if ((changes['config'].currentValue && changes['config'].firstChange) || changes['config'].previousValue !== changes['config'].currentValue) {\n        this.initializeForm();\n      }\n    }\n\n    if (this.dataLoadStatusSinkSubscription) {\n      this.dataLoadStatusSinkSubscription.unsubscribe();\n    }\n\n    if (this.statusChangesSubscription) {\n      this.statusChangesSubscription.unsubscribe();\n    }\n\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n\n    this.dataLoadStatusSinkSubscription = this.dataLoadStatusDelegate.pipe(\n      scan<'LOADING' | 'LOADED', { loadingCount: 0, loadedCount: 0 }>((acc, event) => {\n        if (event === 'LOADED') {\n          acc.loadedCount++;\n          return acc;\n        }\n\n        acc.loadingCount++;\n        return acc;\n      }, {loadingCount: 0, loadedCount: 0}),\n      map<{ loadingCount: 0, loadedCount: 0 }, 'LOADING' | 'LOADED'>((aggregates) => {\n        if (aggregates.loadingCount !== aggregates.loadedCount) {\n          return 'LOADING';\n        }\n\n        return 'LOADED';\n      }),\n      distinctUntilChanged(),\n      tap((result) => {\n        if (result === 'LOADING') {\n          this.dataLoadStatus.emit('LOADING');\n        } else {\n          this.dataLoadStatus.emit('LOADED');\n        }\n      })\n    ).subscribe();\n\n    this.statusChangesSubscription = this.formGroup.valueChanges.pipe(\n      tap((v) => {\n        this.statusChanges.emit({\n          isPristine: this.formGroup.pristine,\n          isDirty: this.formGroup.dirty,\n          isInvalid: this.formGroup.invalid,\n          isValid: this.formGroup.valid\n        });\n      })\n    ).subscribe();\n\n    this.valueChangesSubscription = this.formGroup.valueChanges.pipe(\n      tap((v) => {\n        this.valueChanges.emit(v);\n      })\n    ).subscribe();\n  }\n\n  onNestedFormFinalize(nestedFormGroup: FormGroup, fieldConfig: FieldConfig<any>) {\n    if (!this.formGroup.get('children') || !this.formGroup.get(`children.${fieldConfig.code}`)) {\n      return;\n    }\n\n    (this.formGroup.get('children') as FormGroup).removeControl(fieldConfig.code);\n\n    if (!Object.keys((this.formGroup.get('children') as FormGroup).controls).length) {\n      this.formGroup.removeControl('children');\n    }\n  }\n\n  onNestedFormInitialize(nestedFormGroup: FormGroup, fieldConfig: FieldConfig<any>) {\n    if (!this.formGroup.get('children')) {\n      this.formGroup.addControl('children', new FormGroup({}));\n    }\n\n    (this.formGroup.get('children') as FormGroup).addControl(fieldConfig.code, nestedFormGroup);\n  }\n\n  private initializeForm() {\n    if (!this.config.length) {\n      console.error('FORM LIST IS EMPTY');\n      return;\n    }\n    const formGroupData = {};\n    this.config.forEach((element: any, index) => {\n      if (element.type !== FieldConfigInputType.LABEL) {\n        const formValueList = this.prepareFormValidationData(element, index);\n        formGroupData[element.code] = formValueList;\n      }\n    });\n\n    this.formGroup = this.formBuilder.group(formGroupData);\n    this.initialize.emit(this.formGroup);\n  }\n\n  private prepareFormValidationData(element: FieldConfig<any>, index) {\n    const formValueList = [];\n    const validationList = [];\n\n    let defaultVal: any = '';\n    switch (element.type) {\n      case FieldConfigInputType.INPUT:\n        defaultVal = element.templateOptions.type === 'number' ?\n          (element.default && Number.isInteger(element.default) ? element.default : 0) : null;\n        break;\n      case FieldConfigInputType.SELECT:\n      case FieldConfigInputType.NESTED_SELECT:\n        defaultVal = element.templateOptions.multiple ?\n          (element.default && Array.isArray(element.default) ? element.default : []) : (element.default || null);\n        break;\n      case FieldConfigInputType.CHECKBOX:\n        defaultVal = false || !!element.default;\n        break;\n    }\n\n    formValueList.push(defaultVal);\n\n    if (element.validations && element.validations.length) {\n      element.validations.forEach((data, i) => {\n        switch (data.type) {\n          case FieldConfigValidationType.REQUIRED:\n            if (element.type === FieldConfigInputType.CHECKBOX) {\n              validationList.push(Validators.requiredTrue);\n            } else if (element.type === FieldConfigInputType.SELECT || element.type === FieldConfigInputType.NESTED_SELECT) {\n              validationList.push((c) => {\n                if (element.templateOptions.multiple) {\n                  return c.value && c.value.length ? null : 'error';\n                }\n                return !!c.value ? null : 'error';\n              });\n            } else {\n              validationList.push(Validators.required);\n            }\n            break;\n          case FieldConfigValidationType.PATTERN:\n            validationList.push(Validators.pattern(element.validations[i].value as string));\n            break;\n          case FieldConfigValidationType.MINLENGTH:\n            validationList.push(Validators.minLength(element.validations[i].value as number));\n            break;\n          case FieldConfigValidationType.MAXLENGTH:\n            validationList.push(Validators.maxLength(element.validations[i].value as number));\n            break;\n        }\n      });\n    }\n\n    formValueList.push(Validators.compose(validationList));\n\n    return formValueList;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"ng://common-form-elements/","sources":["lib/form/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges} from '@angular/core';\nimport {FieldConfig, FieldConfigInputType, FieldConfigValidationType} from '../common-form-config';\nimport {FormBuilder, FormGroup, Validators} from '@angular/forms';\nimport {Subject, Subscription} from 'rxjs';\nimport {distinctUntilChanged, map, scan, tap} from 'rxjs/operators';\n\n@Component({\n  selector: 'sb-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.css']\n})\nexport class FormComponent implements OnInit, OnChanges, OnDestroy {\n  @Output() initialize = new EventEmitter();\n  @Output() finalize = new EventEmitter();\n\n  @Output() valueChanges = new EventEmitter();\n  @Output() statusChanges = new EventEmitter();\n  @Output() dataLoadStatus = new EventEmitter<'LOADING' | 'LOADED'>();\n  @Input() config;\n  @Input() dataLoadStatusDelegate = new Subject<'LOADING' | 'LOADED'>();\n\n  formGroup: FormGroup;\n\n  FieldConfigInputType = FieldConfigInputType;\n\n  private statusChangesSubscription: Subscription;\n  private valueChangesSubscription: Subscription;\n  private dataLoadStatusSinkSubscription: Subscription;\n\n  constructor(\n    private formBuilder: FormBuilder\n  ) {\n    if (!window['forms']) {\n      window['forms'] = [];\n    }\n    window['forms'].push(this);\n  }\n\n  ngOnDestroy(): void {\n    this.finalize.emit();\n\n    if (this.statusChangesSubscription) {\n      this.statusChangesSubscription.unsubscribe();\n    }\n\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n\n    if (this.dataLoadStatusSinkSubscription) {\n      this.dataLoadStatusSinkSubscription.unsubscribe();\n    }\n  }\n\n  ngOnInit() {\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) {\n      if ((changes['config'].currentValue && changes['config'].firstChange) || changes['config'].previousValue !== changes['config'].currentValue) {\n        this.initializeForm();\n      }\n    }\n\n    if (this.dataLoadStatusSinkSubscription) {\n      this.dataLoadStatusSinkSubscription.unsubscribe();\n    }\n\n    if (this.statusChangesSubscription) {\n      this.statusChangesSubscription.unsubscribe();\n    }\n\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n\n    this.dataLoadStatusSinkSubscription = this.dataLoadStatusDelegate.pipe(\n      scan<'LOADING' | 'LOADED', { loadingCount: 0, loadedCount: 0 }>((acc, event) => {\n        if (event === 'LOADED') {\n          acc.loadedCount++;\n          return acc;\n        }\n\n        acc.loadingCount++;\n        return acc;\n      }, {loadingCount: 0, loadedCount: 0}),\n      map<{ loadingCount: 0, loadedCount: 0 }, 'LOADING' | 'LOADED'>((aggregates) => {\n        if (aggregates.loadingCount !== aggregates.loadedCount) {\n          return 'LOADING';\n        }\n\n        return 'LOADED';\n      }),\n      distinctUntilChanged(),\n      tap((result) => {\n        if (result === 'LOADING') {\n          this.dataLoadStatus.emit('LOADING');\n        } else {\n          this.dataLoadStatus.emit('LOADED');\n        }\n      })\n    ).subscribe();\n\n    this.statusChangesSubscription = this.formGroup.valueChanges.pipe(\n      tap((v) => {\n        this.statusChanges.emit({\n          isPristine: this.formGroup.pristine,\n          isDirty: this.formGroup.dirty,\n          isInvalid: this.formGroup.invalid,\n          isValid: this.formGroup.valid\n        });\n      })\n    ).subscribe();\n\n    this.valueChangesSubscription = this.formGroup.valueChanges.pipe(\n      tap((v) => {\n        this.valueChanges.emit(v);\n      })\n    ).subscribe();\n  }\n\n  onNestedFormFinalize(nestedFormGroup: FormGroup, fieldConfig: FieldConfig<any>) {\n    if (!this.formGroup.get('children') || !this.formGroup.get(`children.${fieldConfig.code}`)) {\n      return;\n    }\n\n    (this.formGroup.get('children') as FormGroup).removeControl(fieldConfig.code);\n\n    if (!Object.keys((this.formGroup.get('children') as FormGroup).controls).length) {\n      this.formGroup.removeControl('children');\n    }\n  }\n\n  onNestedFormInitialize(nestedFormGroup: FormGroup, fieldConfig: FieldConfig<any>) {\n    if (!this.formGroup.get('children')) {\n      this.formGroup.addControl('children', new FormGroup({}));\n    }\n\n    (this.formGroup.get('children') as FormGroup).addControl(fieldConfig.code, nestedFormGroup);\n  }\n\n  private initializeForm() {\n    if (!this.config.length) {\n      console.error('FORM LIST IS EMPTY');\n      return;\n    }\n    const formGroupData = {};\n    this.config.forEach((element: any, index) => {\n      if (element.type !== FieldConfigInputType.LABEL) {\n        const formValueList = this.prepareFormValidationData(element, index);\n        formGroupData[element.code] = formValueList;\n      }\n    });\n\n    this.formGroup = this.formBuilder.group(formGroupData);\n    this.initialize.emit(this.formGroup);\n  }\n\n  private prepareFormValidationData(element: FieldConfig<any>, index) {\n    const formValueList = [];\n    const validationList = [];\n\n    let defaultVal: any = '';\n    switch (element.type) {\n      case FieldConfigInputType.INPUT:\n        defaultVal = element.templateOptions.type === 'number' ?\n          (element.default && Number.isInteger(element.default) ? element.default : 0) : null;\n        break;\n      case FieldConfigInputType.SELECT:\n      case FieldConfigInputType.NESTED_SELECT:\n        defaultVal = element.templateOptions.multiple ?\n          (element.default && Array.isArray(element.default) ? element.default : []) : (element.default || null);\n        break;\n      case FieldConfigInputType.CHECKBOX:\n        defaultVal = false || !!element.default;\n        break;\n    }\n\n    formValueList.push(defaultVal);\n\n    if (element.validations && element.validations.length) {\n      element.validations.forEach((data, i) => {\n        switch (data.type) {\n          case FieldConfigValidationType.REQUIRED:\n            if (element.type === FieldConfigInputType.CHECKBOX) {\n              validationList.push(Validators.requiredTrue);\n            } else if (element.type === FieldConfigInputType.SELECT || element.type === FieldConfigInputType.NESTED_SELECT) {\n              validationList.push((c) => {\n                if (element.templateOptions.multiple) {\n                  return c.value && c.value.length ? null : 'error';\n                }\n                return !!c.value ? null : 'error';\n              });\n            } else {\n              validationList.push(Validators.required);\n            }\n            break;\n          case FieldConfigValidationType.PATTERN:\n            validationList.push(Validators.pattern(element.validations[i].value as string));\n            break;\n          case FieldConfigValidationType.MINLENGTH:\n            validationList.push(Validators.minLength(element.validations[i].value as number));\n            break;\n          case FieldConfigValidationType.MAXLENGTH:\n            validationList.push(Validators.maxLength(element.validations[i].value as number));\n            break;\n        }\n      });\n    }\n\n    formValueList.push(Validators.compose(validationList));\n\n    return formValueList;\n  }\n}\n"]}

@@ -178,3 +178,3 @@ import { CommonModule } from '@angular/common';

if (this.isOptionsClosure(this.options)) {
this.options$ = (/** @type {?} */ (((/** @type {?} */ (changes['options'].currentValue)))(this.formControlRef, changes['context'].currentValue, (/**
this.options$ = (/** @type {?} */ (((/** @type {?} */ (this.options)))(this.formControlRef, this.context, (/**
* @return {?}

@@ -352,5 +352,3 @@ */

class CheckboxComponent {
constructor() {
this.valuesInArr = [];
}
constructor() { }
/**

@@ -360,5 +358,2 @@ * @return {?}

ngOnInit() {
for (const prop of Object.keys(this.values)) {
this.valuesInArr.push(this.values[prop]);
}
}

@@ -369,4 +364,4 @@ }

selector: 'sb-checkbox',
template: "<div class=\"sb-checkbox\">\n <span><label>checkbox name</label></span>\n <div *ngFor=\"let value of valuesInArr\">\n <label>{{value}}</label>\n <span><input type=\"checkbox\" name=\"checkbox\" value={{value}}></span>\n </div>\n</div>",
styles: ["label{padding:10px;font-size:16px}"]
template: "<div class=\"sb-checkbox\">\n <div class=\"checkbox-row\">\n <label class=\"container\">\n <input type=\"checkbox\" [formControl]=\"formControlRef\" name=\"checkbox\" value=\"value\">\n <span class=\"checkmark\"></span>\n </label>\n <label class=\"checkbox-label\">{{label}}</label>\n </div>\n</div>",
styles: ["label{font-size:16px}.sb-checkbox{padding:0 0 0 8px}.container{position:relative;cursor:pointer;font-size:22px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.container .checkmark{position:absolute;top:0;left:0;height:25px;width:25px;border:2px solid #000;border-radius:4px}.container input:checked~.checkmark{background-color:#2196f3}.checkmark:after{content:\"\";position:absolute;display:none}.container input:checked~.checkmark:after{display:block}.container .checkmark:after{left:9px;top:5px;width:5px;height:10px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}.checkbox-label{padding:2px 0 0 32px}.checkbox-row{display:-ms-grid;display:grid;-ms-grid-columns:10px 250px;grid-template-columns:10px 250px;grid-gap:0}"]
}] }

@@ -378,3 +373,5 @@ ];

label: [{ type: Input }],
values: [{ type: Input }]
code: [{ type: Input }],
value: [{ type: Input }],
formControlRef: [{ type: Input }]
};

@@ -623,3 +620,3 @@

selector: 'sb-form',
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [label]=\"field.code\" [values]=\"field.templateOptions.labelHtml.values\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [code]=\"field.code\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\" [value]=\"field.default\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
styles: [""]

@@ -626,0 +623,0 @@ }] }

import { CommonModule } from '@angular/common';
import { __values } from 'tslib';
import { Subject } from 'rxjs';

@@ -214,3 +213,3 @@ import { tap, map, startWith, distinctUntilChanged, scan } from 'rxjs/operators';

if (this.isOptionsClosure(this.options)) {
this.options$ = (/** @type {?} */ (((/** @type {?} */ (changes['options'].currentValue)))(this.formControlRef, changes['context'].currentValue, (/**
this.options$ = (/** @type {?} */ (((/** @type {?} */ (this.options)))(this.formControlRef, this.context, (/**
* @return {?}

@@ -417,3 +416,2 @@ */

function CheckboxComponent() {
this.valuesInArr = [];
}

@@ -427,16 +425,2 @@ /**

function () {
var e_1, _a;
try {
for (var _b = __values(Object.keys(this.values)), _c = _b.next(); !_c.done; _c = _b.next()) {
var prop = _c.value;
this.valuesInArr.push(this.values[prop]);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
};

@@ -446,4 +430,4 @@ CheckboxComponent.decorators = [

selector: 'sb-checkbox',
template: "<div class=\"sb-checkbox\">\n <span><label>checkbox name</label></span>\n <div *ngFor=\"let value of valuesInArr\">\n <label>{{value}}</label>\n <span><input type=\"checkbox\" name=\"checkbox\" value={{value}}></span>\n </div>\n</div>",
styles: ["label{padding:10px;font-size:16px}"]
template: "<div class=\"sb-checkbox\">\n <div class=\"checkbox-row\">\n <label class=\"container\">\n <input type=\"checkbox\" [formControl]=\"formControlRef\" name=\"checkbox\" value=\"value\">\n <span class=\"checkmark\"></span>\n </label>\n <label class=\"checkbox-label\">{{label}}</label>\n </div>\n</div>",
styles: ["label{font-size:16px}.sb-checkbox{padding:0 0 0 8px}.container{position:relative;cursor:pointer;font-size:22px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.container .checkmark{position:absolute;top:0;left:0;height:25px;width:25px;border:2px solid #000;border-radius:4px}.container input:checked~.checkmark{background-color:#2196f3}.checkmark:after{content:\"\";position:absolute;display:none}.container input:checked~.checkmark:after{display:block}.container .checkmark:after{left:9px;top:5px;width:5px;height:10px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}.checkbox-label{padding:2px 0 0 32px}.checkbox-row{display:-ms-grid;display:grid;-ms-grid-columns:10px 250px;grid-template-columns:10px 250px;grid-gap:0}"]
}] }

@@ -455,3 +439,5 @@ ];

label: [{ type: Input }],
values: [{ type: Input }]
code: [{ type: Input }],
value: [{ type: Input }],
formControlRef: [{ type: Input }]
};

@@ -730,3 +716,3 @@ return CheckboxComponent;

selector: 'sb-form',
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [label]=\"field.code\" [values]=\"field.templateOptions.labelHtml.values\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
template: "<div [formGroup]=\"formGroup\">\n <ng-container *ngFor=\"let field of config; let index = i\">\n <div *ngIf=\"field.type === FieldConfigInputType.SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.NESTED_SELECT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-dropdown [context]=\"field.context ? formGroup.get(field.context) : null \" [default]=\"field.default\"\n [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\" [options]=\"field.templateOptions?.options\"\n [disabled]=\"field.templateOptions?.disabled\"\n [placeHolder]=\"field?.templateOptions?.placeHolder\">\n </sb-dropdown>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.INPUT\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textbox [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textbox>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.TEXTAREA\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-textarea [config]=\"field\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\"\n [placeholder]=\"field.templateOptions.placeHolder\">\n </sb-textarea>\n </div>\n <div *ngIf=\"field.type === FieldConfigInputType.CHECKBOX\" [hidden]=\"field.templateOptions?.hidden || null\">\n <sb-checkbox [code]=\"field.code\" [formControlRef]=\"formGroup.get(field.code)\" [label]=\"field.templateOptions.label\" [value]=\"field.default\"></sb-checkbox>\n </div>\n <ng-container *ngIf=\"formGroup.get(field.code) as ref\">\n <div *ngIf=\"ref && ref.value && field.children && field.children[ref.value]\">\n <sb-form (initialize)=\"onNestedFormInitialize($event, field)\"\n (finalize)=\"onNestedFormFinalize($event, field)\"\n [dataLoadStatusDelegate]=\"dataLoadStatusDelegate\"\n [config]=\"field.children[ref.value]\"></sb-form>\n </div>\n </ng-container>\n </ng-container>\n</div>\n",
styles: [""]

@@ -733,0 +719,0 @@ }] }

import { OnInit } from '@angular/core';
import { FormControl } from '@angular/forms';
export declare class CheckboxComponent implements OnInit {
label: any;
values: any;
valuesInArr: any[];
code: any;
value?: any;
formControlRef?: FormControl;
constructor();
ngOnInit(): void;
}
{
"name": "common-form-elements",
"version": "0.0.1",
"version": "0.0.2",
"peerDependencies": {

@@ -5,0 +5,0 @@ "@angular/common": "^7.1.0",

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc