@ngx-formly/bootstrap
Version:
ngx-formly is an Angular 2 module which has a Components to help customize and render JavaScript/JSON configured forms. The formly-form Component and the FormlyConfig service are very powerful and bring unmatched maintainability to your application's form
381 lines (363 loc) • 39.5 kB
JavaScript
import { __extends } from 'tslib';
import { Component, ViewChild, ViewContainerRef, NgModule } from '@angular/core';
import { FieldType, FieldWrapper, FormlyModule } from '@ngx-formly/core';
import { FormGroup, FormControl, ReactiveFormsModule } from '@angular/forms';
import { Observable } from 'rxjs';
import { CommonModule } from '@angular/common';
import { FormlySelectModule } from '@ngx-formly/core/select';
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var FormlyFieldCheckbox = /** @class */ (function (_super) {
__extends(FormlyFieldCheckbox, _super);
function FormlyFieldCheckbox() {
return _super !== null && _super.apply(this, arguments) || this;
}
FormlyFieldCheckbox.decorators = [
{ type: Component, args: [{
selector: 'formly-field-checkbox',
template: "\n <div class=\"custom-control custom-checkbox\">\n <input class=\"custom-control-input\" type=\"checkbox\"\n [class.is-invalid]=\"showError\"\n [indeterminate]=\"to.indeterminate && field.formControl.value === null\"\n [formControl]=\"formControl\"\n [formlyAttributes]=\"field\">\n <label class=\"custom-control-label\" [for]=\"id\">\n {{ to.label }}\n <span *ngIf=\"to.required && to.hideRequiredMarker !== true\">*</span>\n </label>\n </div>\n "
}] }
];
return FormlyFieldCheckbox;
}(FieldType));
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var FormlyFieldMultiCheckbox = /** @class */ (function (_super) {
__extends(FormlyFieldMultiCheckbox, _super);
function FormlyFieldMultiCheckbox() {
return _super !== null && _super.apply(this, arguments) || this;
}
/**
* @param {?} model
* @param {?} field
* @return {?}
*/
FormlyFieldMultiCheckbox.createControl = /**
* @param {?} model
* @param {?} field
* @return {?}
*/
function (model, field) {
if (field.templateOptions.options instanceof Observable) {
throw new Error("[Formly Error] You cannot pass an Observable to a multicheckbox yet.");
}
/** @type {?} */
var controls = field.templateOptions.options.reduce(function (obj, option) {
obj[option.key] = new FormControl(model ? model[option.key] : undefined);
return obj;
}, {});
return new FormGroup(controls, field.validators ? field.validators.validation : undefined, field.asyncValidators ? field.asyncValidators.validation : undefined);
};
FormlyFieldMultiCheckbox.decorators = [
{ type: Component, args: [{
selector: 'formly-field-multicheckbox',
template: "\n <div class=\"custom-control custom-checkbox\" *ngFor=\"let option of to.options; let i = index;\">\n <input class=\"custom-control-input\" type=\"checkbox\"\n [id]=\"id + '_' + i\"\n [value]=\"option.value\"\n [formControl]=\"formControl.get(option.key)\"\n [formlyAttributes]=\"field\">\n <label class=\"custom-control-label\" [for]=\"id + '_' + i\">\n {{ option.value }}\n </label>\n </div>\n "
}] }
];
return FormlyFieldMultiCheckbox;
}(FieldType));
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var FormlyFieldInput = /** @class */ (function (_super) {
__extends(FormlyFieldInput, _super);
function FormlyFieldInput() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(FormlyFieldInput.prototype, "type", {
get: /**
* @return {?}
*/
function () {
return this.to.type || 'text';
},
enumerable: true,
configurable: true
});
FormlyFieldInput.decorators = [
{ type: Component, args: [{
selector: 'formly-field-input',
template: "\n <input *ngIf=\"type !== 'number' else numberTmp\" [type]=\"type\" [formControl]=\"formControl\" class=\"form-control\" [formlyAttributes]=\"field\" [class.is-invalid]=\"showError\">\n <ng-template #numberTmp>\n <input type=\"number\" [formControl]=\"formControl\" class=\"form-control\" [formlyAttributes]=\"field\" [class.is-invalid]=\"showError\">\n </ng-template>\n ",
host: {
'[class.d-inline-flex]': 'to.addonLeft || to.addonRight',
'[class.custom-file]': 'to.addonLeft || to.addonRight',
}
}] }
];
return FormlyFieldInput;
}(FieldType));
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var FormlyFieldRadio = /** @class */ (function (_super) {
__extends(FormlyFieldRadio, _super);
function FormlyFieldRadio() {
return _super !== null && _super.apply(this, arguments) || this;
}
FormlyFieldRadio.decorators = [
{ type: Component, args: [{
selector: 'formly-field-radio',
template: "\n <div [formGroup]=\"form\">\n <div class=\"custom-control custom-radio\" *ngFor=\"let option of to.options | formlySelectOptions:field | async; let i = index;\">\n <input class=\"custom-control-input\" type=\"radio\"\n [id]=\"id + '_' + i\"\n [name]=\"id\"\n [class.is-invalid]=\"showError\"\n [value]=\"option.value\"\n [formControl]=\"formControl\"\n [formlyAttributes]=\"field\">\n <label class=\"custom-control-label\" [for]=\"id + '_' + i\">\n {{ option.label }}\n </label>\n </div>\n </div>\n "
}] }
];
return FormlyFieldRadio;
}(FieldType));
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var FormlyFieldTextArea = /** @class */ (function (_super) {
__extends(FormlyFieldTextArea, _super);
function FormlyFieldTextArea() {
return _super !== null && _super.apply(this, arguments) || this;
}
FormlyFieldTextArea.decorators = [
{ type: Component, args: [{
selector: 'formly-field-textarea',
template: "\n <textarea [formControl]=\"formControl\" [cols]=\"to.cols\"\n [rows]=\"to.rows\" class=\"form-control\" [class.is-invalid]=\"showError\"\n [formlyAttributes]=\"field\">\n </textarea>\n "
}] }
];
return FormlyFieldTextArea;
}(FieldType));
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var FormlyFieldSelect = /** @class */ (function (_super) {
__extends(FormlyFieldSelect, _super);
function FormlyFieldSelect() {
return _super !== null && _super.apply(this, arguments) || this;
}
FormlyFieldSelect.decorators = [
{ type: Component, args: [{
selector: 'formly-field-select',
template: "\n <select *ngIf=\"to.multiple; else singleSelect\" class=\"form-control\"\n multiple\n [class.custom-select]=\"to.customSelect\"\n [formControl]=\"formControl\"\n [class.is-invalid]=\"showError\"\n [formlyAttributes]=\"field\">\n <ng-container *ngFor=\"let item of to.options | formlySelectOptions:field | async\">\n <optgroup *ngIf=\"item.group\" label=\"{{item.label}}\">\n <option *ngFor=\"let child of item.group\" [value]=\"child.value\" [disabled]=\"child.disabled\">\n {{ child.label }}\n </option>\n </optgroup>\n <option *ngIf=\"!item.group\" [value]=\"item.value\" [disabled]=\"item.disabled\">{{ item.label }}</option>\n </ng-container>\n </select>\n\n <ng-template #singleSelect>\n <select class=\"form-control\"\n [formControl]=\"formControl\"\n [class.custom-select]=\"to.customSelect\"\n [class.is-invalid]=\"showError\"\n [formlyAttributes]=\"field\">\n <option *ngIf=\"to.placeholder\" value=\"\">{{ to.placeholder }}</option>\n <ng-container *ngFor=\"let item of to.options | formlySelectOptions:field | async\">\n <optgroup *ngIf=\"item.group\" label=\"{{item.label}}\">\n <option *ngFor=\"let child of item.group\" [value]=\"child.value\" [disabled]=\"child.disabled\">\n {{ child.label }}\n </option>\n </optgroup>\n <option *ngIf=\"!item.group\" [value]=\"item.value\" [disabled]=\"item.disabled\">{{ item.label }}</option>\n </ng-container>\n </select>\n </ng-template>\n "
}] }
];
return FormlyFieldSelect;
}(FieldType));
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var FormlyWrapperFormField = /** @class */ (function (_super) {
__extends(FormlyWrapperFormField, _super);
function FormlyWrapperFormField() {
return _super !== null && _super.apply(this, arguments) || this;
}
FormlyWrapperFormField.decorators = [
{ type: Component, args: [{
selector: 'formly-wrapper-form-field',
template: "\n <div class=\"form-group\" [class.has-error]=\"showError\">\n <label *ngIf=\"to.label && to.hideLabel !== true\" [attr.for]=\"id\">\n {{ to.label }} <ng-container *ngIf=\"to.required && to.hideRequiredMarker !== true\">*</ng-container>\n </label>\n\n <ng-template #fieldComponent></ng-template>\n\n <div *ngIf=\"showError\" class=\"invalid-feedback\" [style.display]=\"'block'\">\n <formly-validation-message [field]=\"field\"></formly-validation-message>\n </div>\n\n <small *ngIf=\"to.description\" class=\"form-text text-muted\">{{ to.description }}</small>\n </div>\n "
}] }
];
FormlyWrapperFormField.propDecorators = {
fieldComponent: [{ type: ViewChild, args: ['fieldComponent', { read: ViewContainerRef },] }]
};
return FormlyWrapperFormField;
}(FieldWrapper));
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var FormlyWrapperAddons = /** @class */ (function (_super) {
__extends(FormlyWrapperAddons, _super);
function FormlyWrapperAddons() {
return _super !== null && _super.apply(this, arguments) || this;
}
/**
* @param {?} $event
* @return {?}
*/
FormlyWrapperAddons.prototype.addonRightClick = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.to["addonRight"].onClick) {
this.to["addonRight"].onClick(this.to, this, $event);
}
};
/**
* @param {?} $event
* @return {?}
*/
FormlyWrapperAddons.prototype.addonLeftClick = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.to["addonLeft"].onClick) {
this.to["addonLeft"].onClick(this.to, this, $event);
}
};
FormlyWrapperAddons.decorators = [
{ type: Component, args: [{
selector: 'formly-wrapper-addons',
template: "\n <div class=\"input-group\">\n <div class=\"input-group-prepend\"\n *ngIf=\"to.addonLeft\"\n [ngStyle]=\"{cursor: to.addonLeft.onClick ? 'pointer' : 'inherit'}\"\n (click)=\"addonLeftClick($event)\">\n <i class=\"input-group-text\" [ngClass]=\"to.addonLeft.class\" *ngIf=\"to.addonLeft.class\"></i>\n <span *ngIf=\"to.addonLeft.text\" class=\"input-group-text\">{{ to.addonLeft.text }}</span>\n </div>\n <ng-template #fieldComponent></ng-template>\n <div class=\"input-group-append\"\n *ngIf=\"to.addonRight\"\n [ngStyle]=\"{cursor: to.addonRight.onClick ? 'pointer' : 'inherit'}\"\n (click)=\"addonRightClick($event)\">\n <i class=\"input-group-text\" [ngClass]=\"to.addonRight.class\" *ngIf=\"to.addonRight.class\"></i>\n <span *ngIf=\"to.addonRight.text\" class=\"input-group-text\">{{ to.addonRight.text }}</span>\n </div>\n </div>\n ",
styles: ["\n :host ::ng-deep .input-group>:not(:first-child)> .form-control {\n border-top-left-radius: 0;\n border-bottom-left-radius: 0;\n }\n :host ::ng-deep .input-group>:not(:last-child)> .form-control {\n border-top-right-radius: 0;\n border-bottom-right-radius: 0;\n }\n "]
}] }
];
FormlyWrapperAddons.propDecorators = {
fieldComponent: [{ type: ViewChild, args: ['fieldComponent', { read: ViewContainerRef },] }]
};
return FormlyWrapperAddons;
}(FieldWrapper));
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var TemplateAddons = /** @class */ (function () {
function TemplateAddons() {
}
/**
* @param {?} fc
* @return {?}
*/
TemplateAddons.prototype.run = /**
* @param {?} fc
* @return {?}
*/
function (fc) {
fc.templateManipulators.postWrapper.push(function (field) {
if (field && field.templateOptions && (field.templateOptions["addonLeft"] || field.templateOptions["addonRight"])) {
return 'addons';
}
});
};
return TemplateAddons;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/** @type {?} */
var FIELD_TYPE_COMPONENTS = [
FormlyFieldInput,
FormlyFieldCheckbox,
FormlyFieldRadio,
FormlyFieldSelect,
FormlyFieldTextArea,
FormlyFieldMultiCheckbox,
FormlyWrapperAddons,
FormlyWrapperFormField,
];
/** @type {?} */
var BOOTSTRAP_FORMLY_CONFIG = {
types: [
{
name: 'input',
component: FormlyFieldInput,
wrappers: ['form-field'],
},
{
name: 'checkbox',
component: FormlyFieldCheckbox,
wrappers: ['form-field'],
defaultOptions: {
templateOptions: {
indeterminate: true,
hideLabel: true,
},
},
},
{
name: 'radio',
component: FormlyFieldRadio,
wrappers: ['form-field'],
defaultOptions: {
templateOptions: {
options: [],
},
},
},
{
name: 'select',
component: FormlyFieldSelect,
wrappers: ['form-field'],
defaultOptions: {
templateOptions: {
options: [],
},
},
},
{
name: 'textarea',
component: FormlyFieldTextArea,
wrappers: ['form-field'],
defaultOptions: {
templateOptions: {
cols: 1,
rows: 1,
},
},
},
{
name: 'multicheckbox',
component: FormlyFieldMultiCheckbox,
wrappers: ['form-field'],
defaultOptions: {
templateOptions: {
options: [],
},
},
},
],
wrappers: [
{ name: 'addons', component: FormlyWrapperAddons },
{ name: 'form-field', component: FormlyWrapperFormField },
],
manipulators: [
{ class: TemplateAddons, method: 'run' },
],
};
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
var FormlyBootstrapModule = /** @class */ (function () {
function FormlyBootstrapModule() {
}
FormlyBootstrapModule.decorators = [
{ type: NgModule, args: [{
declarations: [
FIELD_TYPE_COMPONENTS,
],
imports: [
CommonModule,
ReactiveFormsModule,
FormlySelectModule,
FormlyModule.forRoot(BOOTSTRAP_FORMLY_CONFIG),
],
},] }
];
return FormlyBootstrapModule;
}());
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
export { FormlyBootstrapModule, FormlyFieldCheckbox, FormlyFieldMultiCheckbox, FormlyFieldInput, FormlyFieldRadio, FormlyFieldTextArea, FormlyFieldSelect, FormlyWrapperFormField, FormlyWrapperAddons, BOOTSTRAP_FORMLY_CONFIG as ɵb, FIELD_TYPE_COMPONENTS as ɵa, TemplateAddons as ɵc };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-formly-bootstrap.js.map","sources":["ng://@ngx-formly/bootstrap/lib/types/checkbox.ts","ng://@ngx-formly/bootstrap/lib/types/multicheckbox.ts","ng://@ngx-formly/bootstrap/lib/types/input.ts","ng://@ngx-formly/bootstrap/lib/types/radio.ts","ng://@ngx-formly/bootstrap/lib/types/textarea.ts","ng://@ngx-formly/bootstrap/lib/types/select.ts","ng://@ngx-formly/bootstrap/lib/wrappers/form-field.wrapper.ts","ng://@ngx-formly/bootstrap/lib/wrappers/addons.ts","ng://@ngx-formly/bootstrap/lib/run/addon.ts","ng://@ngx-formly/bootstrap/lib/bootstrap.config.ts","ng://@ngx-formly/bootstrap/lib/bootstrap.module.ts"],"sourcesContent":["import { Component } from '@angular/core';\nimport { FieldType } from '@ngx-formly/core';\n\n@Component({\n  selector: 'formly-field-checkbox',\n  template: `\n    <div class=\"custom-control custom-checkbox\">\n      <input class=\"custom-control-input\" type=\"checkbox\"\n        [class.is-invalid]=\"showError\"\n        [indeterminate]=\"to.indeterminate && field.formControl.value === null\"\n        [formControl]=\"formControl\"\n        [formlyAttributes]=\"field\">\n      <label class=\"custom-control-label\" [for]=\"id\">\n        {{ to.label }}\n        <span *ngIf=\"to.required && to.hideRequiredMarker !== true\">*</span>\n      </label>\n    </div>\n  `,\n})\nexport class FormlyFieldCheckbox extends FieldType { }\n","import { Component } from '@angular/core';\nimport { FormGroup, FormControl, AbstractControl } from '@angular/forms';\nimport { FieldType, FormlyFieldConfig } from '@ngx-formly/core';\nimport { Observable } from 'rxjs';\n\n@Component({\n  selector: 'formly-field-multicheckbox',\n  template: `\n    <div class=\"custom-control custom-checkbox\" *ngFor=\"let option of to.options; let i = index;\">\n      <input class=\"custom-control-input\" type=\"checkbox\"\n        [id]=\"id + '_' + i\"\n        [value]=\"option.value\"\n        [formControl]=\"formControl.get(option.key)\"\n        [formlyAttributes]=\"field\">\n      <label class=\"custom-control-label\" [for]=\"id + '_' + i\">\n        {{ option.value }}\n      </label>\n    </div>\n  `,\n})\nexport class FormlyFieldMultiCheckbox extends FieldType {\n\n  static createControl(model: any, field: FormlyFieldConfig): AbstractControl {\n    if (field.templateOptions.options instanceof Observable) {\n      throw new Error(`[Formly Error] You cannot pass an Observable to a multicheckbox yet.`);\n    }\n\n    const controls = field.templateOptions.options.reduce((obj, option) => {\n      obj[option.key] = new FormControl(model ? model[option.key] : undefined);\n      return obj;\n    }, {});\n\n    return new FormGroup(\n      controls,\n      field.validators ? field.validators.validation : undefined,\n      field.asyncValidators ? field.asyncValidators.validation : undefined,\n    );\n  }\n\n}\n","import { Component } from '@angular/core';\nimport { FieldType } from '@ngx-formly/core';\n\n@Component({\n  selector: 'formly-field-input',\n  template: `\n    <input *ngIf=\"type !== 'number' else numberTmp\" [type]=\"type\" [formControl]=\"formControl\" class=\"form-control\" [formlyAttributes]=\"field\" [class.is-invalid]=\"showError\">\n    <ng-template #numberTmp>\n      <input type=\"number\" [formControl]=\"formControl\" class=\"form-control\" [formlyAttributes]=\"field\" [class.is-invalid]=\"showError\">\n    </ng-template>\n  `,\n  host: {\n    '[class.d-inline-flex]': 'to.addonLeft || to.addonRight',\n    '[class.custom-file]': 'to.addonLeft || to.addonRight',\n  },\n})\nexport class FormlyFieldInput extends FieldType {\n  get type() {\n    return this.to.type || 'text';\n  }\n}\n","import { Component } from '@angular/core';\nimport { FieldType } from '@ngx-formly/core';\n\n@Component({\n  selector: 'formly-field-radio',\n  template: `\n    <div [formGroup]=\"form\">\n      <div class=\"custom-control custom-radio\" *ngFor=\"let option of to.options | formlySelectOptions:field | async; let i = index;\">\n        <input class=\"custom-control-input\" type=\"radio\"\n          [id]=\"id + '_' + i\"\n          [name]=\"id\"\n          [class.is-invalid]=\"showError\"\n          [value]=\"option.value\"\n          [formControl]=\"formControl\"\n          [formlyAttributes]=\"field\">\n        <label class=\"custom-control-label\" [for]=\"id + '_' + i\">\n          {{ option.label }}\n        </label>\n      </div>\n    </div>\n  `,\n})\nexport class FormlyFieldRadio extends FieldType {}\n","import { Component } from '@angular/core';\nimport { FieldType } from '@ngx-formly/core';\n\n@Component({\n  selector: 'formly-field-textarea',\n  template: `\n    <textarea [formControl]=\"formControl\" [cols]=\"to.cols\"\n      [rows]=\"to.rows\" class=\"form-control\" [class.is-invalid]=\"showError\"\n      [formlyAttributes]=\"field\">\n    </textarea>\n  `,\n})\nexport class FormlyFieldTextArea extends FieldType {\n}\n","import { Component } from '@angular/core';\nimport { FieldType } from '@ngx-formly/core';\n\n@Component({\n  selector: 'formly-field-select',\n  template: `\n    <select *ngIf=\"to.multiple; else singleSelect\" class=\"form-control\"\n      multiple\n      [class.custom-select]=\"to.customSelect\"\n      [formControl]=\"formControl\"\n      [class.is-invalid]=\"showError\"\n      [formlyAttributes]=\"field\">\n        <ng-container *ngFor=\"let item of to.options | formlySelectOptions:field | async\">\n         <optgroup *ngIf=\"item.group\" label=\"{{item.label}}\">\n            <option *ngFor=\"let child of item.group\" [value]=\"child.value\" [disabled]=\"child.disabled\">\n              {{ child.label }}\n            </option>\n          </optgroup>\n          <option *ngIf=\"!item.group\" [value]=\"item.value\" [disabled]=\"item.disabled\">{{ item.label }}</option>\n        </ng-container>\n    </select>\n\n    <ng-template #singleSelect>\n      <select class=\"form-control\"\n        [formControl]=\"formControl\"\n        [class.custom-select]=\"to.customSelect\"\n        [class.is-invalid]=\"showError\"\n        [formlyAttributes]=\"field\">\n        <option *ngIf=\"to.placeholder\" value=\"\">{{ to.placeholder }}</option>\n        <ng-container *ngFor=\"let item of to.options | formlySelectOptions:field | async\">\n          <optgroup *ngIf=\"item.group\" label=\"{{item.label}}\">\n            <option *ngFor=\"let child of item.group\" [value]=\"child.value\" [disabled]=\"child.disabled\">\n              {{ child.label }}\n            </option>\n          </optgroup>\n          <option *ngIf=\"!item.group\" [value]=\"item.value\" [disabled]=\"item.disabled\">{{ item.label }}</option>\n        </ng-container>\n      </select>\n    </ng-template>\n  `,\n})\nexport class FormlyFieldSelect extends FieldType {}\n","import { Component, ViewChild, ViewContainerRef } from '@angular/core';\nimport { FieldWrapper } from '@ngx-formly/core';\n\n@Component({\n  selector: 'formly-wrapper-form-field',\n  template: `\n    <div class=\"form-group\" [class.has-error]=\"showError\">\n      <label *ngIf=\"to.label && to.hideLabel !== true\" [attr.for]=\"id\">\n        {{ to.label }} <ng-container *ngIf=\"to.required && to.hideRequiredMarker !== true\">*</ng-container>\n      </label>\n\n      <ng-template #fieldComponent></ng-template>\n\n      <div *ngIf=\"showError\" class=\"invalid-feedback\" [style.display]=\"'block'\">\n        <formly-validation-message [field]=\"field\"></formly-validation-message>\n      </div>\n\n      <small *ngIf=\"to.description\" class=\"form-text text-muted\">{{ to.description }}</small>\n    </div>\n  `,\n})\nexport class FormlyWrapperFormField extends FieldWrapper {\n  @ViewChild('fieldComponent', { read: ViewContainerRef }) fieldComponent: ViewContainerRef;\n}\n","import { Component, ViewChild, ViewContainerRef } from '@angular/core';\nimport { FieldWrapper } from '@ngx-formly/core';\n\n@Component({\n  selector: 'formly-wrapper-addons',\n  template: `\n    <div class=\"input-group\">\n      <div class=\"input-group-prepend\"\n        *ngIf=\"to.addonLeft\"\n        [ngStyle]=\"{cursor: to.addonLeft.onClick ? 'pointer' : 'inherit'}\"\n        (click)=\"addonLeftClick($event)\">\n        <i class=\"input-group-text\" [ngClass]=\"to.addonLeft.class\" *ngIf=\"to.addonLeft.class\"></i>\n        <span *ngIf=\"to.addonLeft.text\" class=\"input-group-text\">{{ to.addonLeft.text }}</span>\n      </div>\n      <ng-template #fieldComponent></ng-template>\n      <div class=\"input-group-append\"\n        *ngIf=\"to.addonRight\"\n        [ngStyle]=\"{cursor: to.addonRight.onClick ? 'pointer' : 'inherit'}\"\n        (click)=\"addonRightClick($event)\">\n        <i class=\"input-group-text\" [ngClass]=\"to.addonRight.class\" *ngIf=\"to.addonRight.class\"></i>\n        <span *ngIf=\"to.addonRight.text\" class=\"input-group-text\">{{ to.addonRight.text }}</span>\n      </div>\n    </div>\n  `,\n  styles: [`\n    :host ::ng-deep .input-group>:not(:first-child)> .form-control {\n      border-top-left-radius: 0;\n      border-bottom-left-radius: 0;\n    }\n    :host ::ng-deep .input-group>:not(:last-child)> .form-control {\n      border-top-right-radius: 0;\n      border-bottom-right-radius: 0;\n    }\n  `],\n})\nexport class FormlyWrapperAddons extends FieldWrapper {\n  @ViewChild('fieldComponent', {read: ViewContainerRef}) fieldComponent: ViewContainerRef;\n\n  addonRightClick($event: any) {\n    if (this.to.addonRight.onClick) {\n      this.to.addonRight.onClick(this.to, this, $event);\n    }\n  }\n\n  addonLeftClick($event: any) {\n    if (this.to.addonLeft.onClick) {\n      this.to.addonLeft.onClick(this.to, this, $event);\n    }\n  }\n}\n","import { FormlyConfig } from '@ngx-formly/core';\n\nexport class TemplateAddons {\n  run(fc: FormlyConfig) {\n    fc.templateManipulators.postWrapper.push((field) => {\n      if (field && field.templateOptions && (field.templateOptions.addonLeft || field.templateOptions.addonRight)) {\n        return 'addons';\n      }\n    });\n  }\n}\n","import { ConfigOption } from '@ngx-formly/core';\nimport { TemplateAddons } from './run/addon';\nimport {\n  FormlyFieldInput,\n  FormlyFieldCheckbox,\n  FormlyFieldRadio,\n  FormlyFieldSelect,\n  FormlyFieldTextArea,\n  FormlyFieldMultiCheckbox,\n} from './types/types';\nimport {\n  FormlyWrapperAddons,\n  FormlyWrapperFormField,\n} from './wrappers/wrappers';\n\nexport const FIELD_TYPE_COMPONENTS = [\n  // types\n  FormlyFieldInput,\n  FormlyFieldCheckbox,\n  FormlyFieldRadio,\n  FormlyFieldSelect,\n  FormlyFieldTextArea,\n  FormlyFieldMultiCheckbox,\n\n  // wrappers\n  FormlyWrapperAddons,\n  FormlyWrapperFormField,\n];\n\nexport const BOOTSTRAP_FORMLY_CONFIG: ConfigOption = {\n  types: [\n    {\n      name: 'input',\n      component: FormlyFieldInput,\n      wrappers: ['form-field'],\n    },\n    {\n      name: 'checkbox',\n      component: FormlyFieldCheckbox,\n      wrappers: ['form-field'],\n      defaultOptions: {\n        templateOptions: {\n          indeterminate: true,\n          hideLabel: true,\n        },\n      },\n    },\n    {\n      name: 'radio',\n      component: FormlyFieldRadio,\n      wrappers: ['form-field'],\n      defaultOptions: {\n        templateOptions: {\n          options: [],\n        },\n      },\n    },\n    {\n      name: 'select',\n      component: FormlyFieldSelect,\n      wrappers: ['form-field'],\n      defaultOptions: {\n        templateOptions: {\n          options: [],\n        },\n      },\n    },\n    {\n      name: 'textarea',\n      component: FormlyFieldTextArea,\n      wrappers: ['form-field'],\n      defaultOptions: {\n        templateOptions: {\n          cols: 1,\n          rows: 1,\n        },\n      },\n    },\n    {\n      name: 'multicheckbox',\n      component: FormlyFieldMultiCheckbox,\n      wrappers: ['form-field'],\n      defaultOptions: {\n        templateOptions: {\n          options: [],\n        },\n      },\n    },\n  ],\n  wrappers: [\n    {name: 'addons', component: FormlyWrapperAddons},\n    {name: 'form-field', component: FormlyWrapperFormField},\n  ],\n  manipulators: [\n    {class: TemplateAddons, method: 'run'},\n  ],\n};\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { FormlySelectModule } from '@ngx-formly/core/select';\nimport { BOOTSTRAP_FORMLY_CONFIG, FIELD_TYPE_COMPONENTS } from './bootstrap.config';\n\n@NgModule({\n  declarations: [\n    FIELD_TYPE_COMPONENTS,\n  ],\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormlySelectModule,\n    FormlyModule.forRoot(BOOTSTRAP_FORMLY_CONFIG),\n  ],\n})\nexport class FormlyBootstrapModule {\n}\n"],"names":["tslib_1.__extends"],"mappings":"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"}