Socket
Socket
Sign inDemoInstall

angular-extensions

Package Overview
Dependencies
21
Maintainers
1
Versions
222
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 1.0.20 to 1.0.21

54

bundles/angular-extensions-controls-base-control.umd.js
(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('rxjs'), require('rxjs/operators'), require('@angular/core'), require('@angular/common'), require('@angular/material/form-field'), require('angular-extensions/pipes'), require('@angular/cdk/a11y'), require('@angular/forms'), require('@angular/material/icon'), require('@angular/material/input')) :
typeof define === 'function' && define.amd ? define('angular-extensions/controls/base-control', ['exports', 'rxjs', 'rxjs/operators', '@angular/core', '@angular/common', '@angular/material/form-field', 'angular-extensions/pipes', '@angular/cdk/a11y', '@angular/forms', '@angular/material/icon', '@angular/material/input'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["angular-extensions"] = global["angular-extensions"] || {}, global["angular-extensions"].controls = global["angular-extensions"].controls || {}, global["angular-extensions"].controls["base-control"] = {}), global.rxjs, global.rxjs.operators, global.ng.core, global.ng.common, global.ng.material.formField, global["angular-extensions"].pipes, global.ng.cdk.a11y, global.ng.forms, global.ng.material.icon, global.ng.material.input));
})(this, (function (exports, rxjs, operators, i0, i1, i2, i3, a11y, forms, icon, input) { 'use strict';
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('rxjs'), require('rxjs/operators'), require('@angular/core'), require('@angular/material/form-field'), require('@angular/material/tooltip'), require('@angular/common'), require('angular-extensions/pipes'), require('@angular/cdk/a11y'), require('@angular/forms'), require('@angular/material/icon'), require('@angular/material/input')) :
typeof define === 'function' && define.amd ? define('angular-extensions/controls/base-control', ['exports', 'rxjs', 'rxjs/operators', '@angular/core', '@angular/material/form-field', '@angular/material/tooltip', '@angular/common', 'angular-extensions/pipes', '@angular/cdk/a11y', '@angular/forms', '@angular/material/icon', '@angular/material/input'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["angular-extensions"] = global["angular-extensions"] || {}, global["angular-extensions"].controls = global["angular-extensions"].controls || {}, global["angular-extensions"].controls["base-control"] = {}), global.rxjs, global.rxjs.operators, global.ng.core, global.ng.material.formField, global.ng.material.tooltip, global.ng.common, global["angular-extensions"].pipes, global.ng.cdk.a11y, global.ng.forms, global.ng.material.icon, global.ng.material.input));
})(this, (function (exports, rxjs, operators, i0, i1, i2, i3, i4, a11y, forms, icon, input) { 'use strict';

@@ -29,2 +29,3 @@ function _interopNamespace(e) {

var i3__namespace = /*#__PURE__*/_interopNamespace(i3);
var i4__namespace = /*#__PURE__*/_interopNamespace(i4);

@@ -62,3 +63,3 @@ var BaseControlComponent = /** @class */ (function () {

BaseControlComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: BaseControlComponent, deps: [{ token: i0__namespace.ElementRef }], target: i0__namespace.ɵɵFactoryTarget.Component });
BaseControlComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: BaseControlComponent, selector: "base-control", inputs: { field: "field" }, viewQueries: [{ propertyName: "errorsTemplate", first: true, predicate: i0.TemplateRef, descendants: true }], ngImport: i0__namespace, template: "<ng-content></ng-content>\r\n\r\n<ng-template>\r\n <mat-error *ngIf=\"field.control.errors?.required as error\">\r\n {{ field.validation.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.requiredTrue as error\">\r\n {{ field.validation.requiredTrue?.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.min as error\">\r\n {{ field.validation.min?.text || \"Value should be greater than \" + error.min }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.max as error\">\r\n {{ field.validation.max?.text || \"Value should be smaller than \" + error.max }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minlength as error\">\r\n {{ field.validation.minLength?.text || \"Value should be longer than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxlength as error\">\r\n {{ field.validation.maxLength?.text || \"Value should be shorter than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minDate as error\">\r\n {{ field.validation.minDate?.text || \"Date should be after the \" + (error.minDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minOrEqualDate as error\">\r\n {{ field.validation.minOrEqualDate?.text || \"Date should be same or after the \" + (error.minOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxDate as error\">\r\n {{ field.validation.maxDate?.text || \"Date should be before the \" + (error.maxDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxOrEqualDate as error\">\r\n {{ field.validation.maxOrEqualDate?.text || \"Date should be same or before the \" + (error.maxOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.pattern as error\">\r\n {{ field.validation.pattern?.text || error.message }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.custom as error\">\r\n {{ field.validation.custom?.text || error.message }}\r\n </mat-error>\r\n</ng-template>\r\n", styles: [".control:not(:last-child):not(.d-block){padding-right:1.34375em}.control.d-none{display:none!important}.control.d-block{display:block}.control.d-block mat-form-field{display:block;margin-right:0}.control base-control{font-size:14px}.control base-control mat-form-field{min-width:150px}.control base-control mat-form-field.p-0 .mat-form-field-wrapper{padding:0!important}.control base-control mat-form-field.p-0 .mat-form-field-underline{bottom:0!important}.control base-control mat-form-field .mat-form-field-wrapper{padding-bottom:.25rem}.control base-control mat-form-field .mat-form-field-subscript-wrapper{position:relative}\n"], directives: [{ type: i1__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2__namespace.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "date": i3__namespace.DatePipe }, encapsulation: i0__namespace.ViewEncapsulation.None });
BaseControlComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: BaseControlComponent, selector: "base-control", inputs: { field: "field" }, viewQueries: [{ propertyName: "hintTemplate", first: true, predicate: i0.TemplateRef, descendants: true }, { propertyName: "errorsTemplate", first: true, predicate: i0.TemplateRef, descendants: true }], ngImport: i0__namespace, template: "<ng-content></ng-content>\r\n\r\n<ng-template #hintTemplate>\r\n <mat-hint class=\"text-truncate\"\r\n style=\"cursor: default;\"\r\n [matTooltip]=\"$any(field.info)\">\r\n {{ field.info }}\r\n </mat-hint>\r\n</ng-template>\r\n\r\n<ng-template #errorsTemplate>\r\n <mat-error *ngIf=\"field.control.errors?.required as error\">\r\n {{ field.validation.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.requiredTrue as error\">\r\n {{ field.validation.requiredTrue?.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.min as error\">\r\n {{ field.validation.min?.text || \"Value should be greater than \" + error.min }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.max as error\">\r\n {{ field.validation.max?.text || \"Value should be smaller than \" + error.max }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minlength as error\">\r\n {{ field.validation.minLength?.text || \"Value should be longer than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxlength as error\">\r\n {{ field.validation.maxLength?.text || \"Value should be shorter than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minDate as error\">\r\n {{ field.validation.minDate?.text || \"Date should be after the \" + (error.minDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minOrEqualDate as error\">\r\n {{ field.validation.minOrEqualDate?.text || \"Date should be same or after the \" + (error.minOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxDate as error\">\r\n {{ field.validation.maxDate?.text || \"Date should be before the \" + (error.maxDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxOrEqualDate as error\">\r\n {{ field.validation.maxOrEqualDate?.text || \"Date should be same or before the \" + (error.maxOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.pattern as error\">\r\n {{ field.validation.pattern?.text || error.message }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.custom as error\">\r\n {{ field.validation.custom?.text || error.message }}\r\n </mat-error>\r\n</ng-template>\r\n", styles: [".control:not(:last-child):not(.d-block){padding-right:1.34375em}.control.d-none{display:none!important}.control.d-block{display:block}.control.d-block mat-form-field{display:block;margin-right:0}.control base-control{font-size:14px}.control base-control mat-form-field{min-width:150px}.control base-control mat-form-field.p-0 .mat-form-field-wrapper{padding:0!important}.control base-control mat-form-field.p-0 .mat-form-field-underline{bottom:0!important}.control base-control mat-form-field .mat-form-field-wrapper{padding-bottom:.25rem}.control base-control mat-form-field .mat-form-field-subscript-wrapper{position:relative}.control base-control mat-form-field .mat-hint{display:block;width:100%}\n"], directives: [{ type: i1__namespace.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i2__namespace.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i3__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1__namespace.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "date": i4__namespace.DatePipe }, encapsulation: i0__namespace.ViewEncapsulation.None });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: BaseControlComponent, decorators: [{

@@ -74,2 +75,5 @@ type: i0.Component,

type: i0.Input
}], hintTemplate: [{
type: i0.ViewChild,
args: [i0.TemplateRef]
}], errorsTemplate: [{

@@ -86,31 +90,35 @@ type: i0.ViewChild,

NgxBaseControlModule.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxBaseControlModule, deps: [], target: i0__namespace.ɵɵFactoryTarget.NgModule });
NgxBaseControlModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxBaseControlModule, declarations: [BaseControlComponent], imports: [i1.CommonModule,
NgxBaseControlModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxBaseControlModule, declarations: [BaseControlComponent], imports: [i3.CommonModule,
a11y.A11yModule,
forms.ReactiveFormsModule,
icon.MatIconModule,
i2.MatFormFieldModule,
i1.MatFormFieldModule,
input.MatInputModule,
i3.NgxPipesModule], exports: [i1.CommonModule,
i2.MatTooltipModule,
i4.NgxPipesModule], exports: [i3.CommonModule,
a11y.A11yModule,
forms.ReactiveFormsModule,
icon.MatIconModule,
i2.MatFormFieldModule,
i1.MatFormFieldModule,
input.MatInputModule,
i3.NgxPipesModule,
i2.MatTooltipModule,
i4.NgxPipesModule,
BaseControlComponent] });
NgxBaseControlModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxBaseControlModule, imports: [[
i1.CommonModule,
i3.CommonModule,
a11y.A11yModule,
forms.ReactiveFormsModule,
icon.MatIconModule,
i2.MatFormFieldModule,
i1.MatFormFieldModule,
input.MatInputModule,
i3.NgxPipesModule,
], i1.CommonModule,
i2.MatTooltipModule,
i4.NgxPipesModule,
], i3.CommonModule,
a11y.A11yModule,
forms.ReactiveFormsModule,
icon.MatIconModule,
i2.MatFormFieldModule,
i1.MatFormFieldModule,
input.MatInputModule,
i3.NgxPipesModule] });
i2.MatTooltipModule,
i4.NgxPipesModule] });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxBaseControlModule, decorators: [{

@@ -120,9 +128,10 @@ type: i0.NgModule,

imports: [
i1.CommonModule,
i3.CommonModule,
a11y.A11yModule,
forms.ReactiveFormsModule,
icon.MatIconModule,
i2.MatFormFieldModule,
i1.MatFormFieldModule,
input.MatInputModule,
i3.NgxPipesModule,
i2.MatTooltipModule,
i4.NgxPipesModule,
],

@@ -133,9 +142,10 @@ declarations: [

exports: [
i1.CommonModule,
i3.CommonModule,
a11y.A11yModule,
forms.ReactiveFormsModule,
icon.MatIconModule,
i2.MatFormFieldModule,
i1.MatFormFieldModule,
input.MatInputModule,
i3.NgxPipesModule,
i2.MatTooltipModule,
i4.NgxPipesModule,
BaseControlComponent,

@@ -142,0 +152,0 @@ ]

(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/material/input'), require('angular-extensions/controls/base-control'), require('@angular/material/form-field'), require('@angular/material/icon'), require('@angular/cdk/a11y'), require('@angular/common'), require('ngx-mask'), require('@angular/forms')) :
typeof define === 'function' && define.amd ? define('angular-extensions/controls/text-control', ['exports', '@angular/core', '@angular/material/input', 'angular-extensions/controls/base-control', '@angular/material/form-field', '@angular/material/icon', '@angular/cdk/a11y', '@angular/common', 'ngx-mask', '@angular/forms'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["angular-extensions"] = global["angular-extensions"] || {}, global["angular-extensions"].controls = global["angular-extensions"].controls || {}, global["angular-extensions"].controls["text-control"] = {}), global.ng.core, global.ng.material.input, global["angular-extensions"].controls["base-control"], global.ng.material.formField, global.ng.material.icon, global.ng.cdk.a11y, global.ng.common, global["ngx-mask"], global.ng.forms));
})(this, (function (exports, i0, i6, i1, i2, i3, i4, i5, i7, i8) { 'use strict';
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/material/input'), require('angular-extensions/controls/base-control'), require('@angular/material/form-field'), require('@angular/material/icon'), require('@angular/cdk/a11y'), require('@angular/common'), require('@angular/material/tooltip'), require('ngx-mask'), require('@angular/forms')) :
typeof define === 'function' && define.amd ? define('angular-extensions/controls/text-control', ['exports', '@angular/core', '@angular/material/input', 'angular-extensions/controls/base-control', '@angular/material/form-field', '@angular/material/icon', '@angular/cdk/a11y', '@angular/common', '@angular/material/tooltip', 'ngx-mask', '@angular/forms'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["angular-extensions"] = global["angular-extensions"] || {}, global["angular-extensions"].controls = global["angular-extensions"].controls || {}, global["angular-extensions"].controls["text-control"] = {}), global.ng.core, global.ng.material.input, global["angular-extensions"].controls["base-control"], global.ng.material.formField, global.ng.material.icon, global.ng.cdk.a11y, global.ng.common, global.ng.material.tooltip, global["ngx-mask"], global.ng.forms));
})(this, (function (exports, i0, i7, i1, i2, i3, i4, i5, i6, i8, i9) { 'use strict';

@@ -26,3 +26,3 @@ function _interopNamespace(e) {

var i0__namespace = /*#__PURE__*/_interopNamespace(i0);
var i6__namespace = /*#__PURE__*/_interopNamespace(i6);
var i7__namespace = /*#__PURE__*/_interopNamespace(i7);
var i1__namespace = /*#__PURE__*/_interopNamespace(i1);

@@ -33,4 +33,5 @@ var i2__namespace = /*#__PURE__*/_interopNamespace(i2);

var i5__namespace = /*#__PURE__*/_interopNamespace(i5);
var i7__namespace = /*#__PURE__*/_interopNamespace(i7);
var i6__namespace = /*#__PURE__*/_interopNamespace(i6);
var i8__namespace = /*#__PURE__*/_interopNamespace(i8);
var i9__namespace = /*#__PURE__*/_interopNamespace(i9);

@@ -48,3 +49,3 @@ var TextControlComponent = /** @class */ (function () {

TextControlComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: TextControlComponent, deps: [], target: i0__namespace.ɵɵFactoryTarget.Component });
TextControlComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextControlComponent, selector: "text-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", type: "type", mask: "mask", prefix: "prefix", showMaskTyped: "showMaskTyped", focused: "focused", icon: "icon", clearable: "clearable" }, viewQueries: [{ propertyName: "input", first: true, predicate: i6.MatInput, descendants: true }], ngImport: i0__namespace, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field cdkTrapFocus\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n [cdkTrapFocusAutoCapture]=\"focused\"\r\n (click)=\"input.focus()\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <mat-icon *ngIf=\"icon\"\r\n matPrefix>{{icon}}</mat-icon>\r\n\r\n <button mat-icon-button\r\n *ngIf=\"field.value && clearable\"\r\n matSuffix\r\n aria-label=\"Clear\"\r\n matTooltip=\"Clear\"\r\n (click)=\"field.value = ''\"\r\n type=\"button\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngIf=\"mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [prefix]=\"prefix\"\r\n [mask]=\"mask\"\r\n [showMaskTyped]=\"showMaskTyped\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}\n"], components: [{ type: i1__namespace.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2__namespace.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3__namespace.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i4__namespace.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i2__namespace.MatLabel, selector: "mat-label" }, { type: i2__namespace.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i5__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2__namespace.MatPrefix, selector: "[matPrefix]" }, { type: i2__namespace.MatSuffix, selector: "[matSuffix]" }, { type: i6__namespace.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i7__namespace.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime"] }, { type: i8__namespace.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i8__namespace.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8__namespace.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2__namespace.MatError, selector: "mat-error", inputs: ["id"] }, { type: i5__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
TextControlComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextControlComponent, selector: "text-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", type: "type", mask: "mask", prefix: "prefix", showMaskTyped: "showMaskTyped", focused: "focused", icon: "icon", clearable: "clearable" }, viewQueries: [{ propertyName: "input", first: true, predicate: i7.MatInput, descendants: true }], ngImport: i0__namespace, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field cdkTrapFocus\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n [cdkTrapFocusAutoCapture]=\"focused\"\r\n (click)=\"input.focus()\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <mat-icon *ngIf=\"icon\"\r\n matPrefix>{{icon}}</mat-icon>\r\n\r\n <button mat-icon-button\r\n *ngIf=\"field.value && clearable\"\r\n matSuffix\r\n aria-label=\"Clear\"\r\n matTooltip=\"Clear\"\r\n (click)=\"field.value = ''\"\r\n type=\"button\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngIf=\"mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [prefix]=\"prefix\"\r\n [mask]=\"mask\"\r\n [showMaskTyped]=\"showMaskTyped\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}\n"], components: [{ type: i1__namespace.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2__namespace.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3__namespace.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i4__namespace.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i2__namespace.MatLabel, selector: "mat-label" }, { type: i2__namespace.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i5__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i5__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2__namespace.MatPrefix, selector: "[matPrefix]" }, { type: i2__namespace.MatSuffix, selector: "[matSuffix]" }, { type: i6__namespace.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i7__namespace.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i8__namespace.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime"] }, { type: i9__namespace.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9__namespace.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9__namespace.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2__namespace.MatError, selector: "mat-error", inputs: ["id"] }] });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: TextControlComponent, decorators: [{

@@ -59,3 +60,3 @@ type: i0.Component,

type: i0.ViewChild,
args: [i6.MatInput]
args: [i7.MatInput]
}], field: [{

@@ -90,5 +91,5 @@ type: i0.Input

NgxTextControlModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxTextControlModule, declarations: [TextControlComponent], imports: [i5.CommonModule,
i1.NgxBaseControlModule, i7__namespace.NgxMaskModule], exports: [i5.CommonModule,
i1.NgxBaseControlModule, i8__namespace.NgxMaskModule], exports: [i5.CommonModule,
i1.NgxBaseControlModule,
i7.NgxMaskModule,
i8.NgxMaskModule,
TextControlComponent] });

@@ -98,6 +99,6 @@ NgxTextControlModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxTextControlModule, imports: [[

i1.NgxBaseControlModule,
i7.NgxMaskModule.forChild(),
i8.NgxMaskModule.forChild(),
], i5.CommonModule,
i1.NgxBaseControlModule,
i7.NgxMaskModule] });
i8.NgxMaskModule] });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxTextControlModule, decorators: [{

@@ -109,3 +110,3 @@ type: i0.NgModule,

i1.NgxBaseControlModule,
i7.NgxMaskModule.forChild(),
i8.NgxMaskModule.forChild(),
],

@@ -118,3 +119,3 @@ declarations: [

i1.NgxBaseControlModule,
i7.NgxMaskModule,
i8.NgxMaskModule,
TextControlComponent,

@@ -121,0 +122,0 @@ ]

(function (global, factory) {
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('angular-extensions/controls/base-control'), require('@angular/material/form-field'), require('@angular/material/input'), require('@angular/forms'), require('@angular/common')) :
typeof define === 'function' && define.amd ? define('angular-extensions/controls/textarea-control', ['exports', '@angular/core', 'angular-extensions/controls/base-control', '@angular/material/form-field', '@angular/material/input', '@angular/forms', '@angular/common'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["angular-extensions"] = global["angular-extensions"] || {}, global["angular-extensions"].controls = global["angular-extensions"].controls || {}, global["angular-extensions"].controls["textarea-control"] = {}), global.ng.core, global["angular-extensions"].controls["base-control"], global.ng.material.formField, global.ng.material.input, global.ng.forms, global.ng.common));
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('angular-extensions/controls/base-control'), require('@angular/material/form-field'), require('@angular/common'), require('@angular/material/input'), require('@angular/forms')) :
typeof define === 'function' && define.amd ? define('angular-extensions/controls/textarea-control', ['exports', '@angular/core', 'angular-extensions/controls/base-control', '@angular/material/form-field', '@angular/common', '@angular/material/input', '@angular/forms'], factory) :
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory((global["angular-extensions"] = global["angular-extensions"] || {}, global["angular-extensions"].controls = global["angular-extensions"].controls || {}, global["angular-extensions"].controls["textarea-control"] = {}), global.ng.core, global["angular-extensions"].controls["base-control"], global.ng.material.formField, global.ng.common, global.ng.material.input, global.ng.forms));
})(this, (function (exports, i0, i1, i2, i3, i4, i5) { 'use strict';

@@ -39,3 +39,3 @@

TextAreaControlComponent.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: TextAreaControlComponent, deps: [], target: i0__namespace.ɵɵFactoryTarget.Component });
TextAreaControlComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextAreaControlComponent, selector: "textarea-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance" }, ngImport: i0__namespace, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <textarea matInput\r\n #input\r\n [formControl]=\"field.control\">\r\n </textarea>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:block}\n"], components: [{ type: i1__namespace.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2__namespace.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }], directives: [{ type: i2__namespace.MatLabel, selector: "mat-label" }, { type: i2__namespace.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i3__namespace.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i4__namespace.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4__namespace.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4__namespace.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i5__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2__namespace.MatError, selector: "mat-error", inputs: ["id"] }, { type: i5__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
TextAreaControlComponent.ɵcmp = i0__namespace.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextAreaControlComponent, selector: "textarea-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance" }, ngImport: i0__namespace, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <textarea matInput\r\n #input\r\n [formControl]=\"field.control\">\r\n </textarea>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:block}\n"], components: [{ type: i1__namespace.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2__namespace.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }], directives: [{ type: i2__namespace.MatLabel, selector: "mat-label" }, { type: i2__namespace.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i3__namespace.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i4__namespace.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i5__namespace.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5__namespace.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5__namespace.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3__namespace.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2__namespace.MatError, selector: "mat-error", inputs: ["id"] }] });
i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: TextAreaControlComponent, decorators: [{

@@ -62,10 +62,10 @@ type: i0.Component,

NgxTextAreaControlModule.ɵfac = i0__namespace.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxTextAreaControlModule, deps: [], target: i0__namespace.ɵɵFactoryTarget.NgModule });
NgxTextAreaControlModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxTextAreaControlModule, declarations: [TextAreaControlComponent], imports: [i5.CommonModule,
i1.NgxBaseControlModule], exports: [i5.CommonModule,
NgxTextAreaControlModule.ɵmod = i0__namespace.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxTextAreaControlModule, declarations: [TextAreaControlComponent], imports: [i3.CommonModule,
i1.NgxBaseControlModule], exports: [i3.CommonModule,
i1.NgxBaseControlModule,
TextAreaControlComponent] });
NgxTextAreaControlModule.ɵinj = i0__namespace.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxTextAreaControlModule, imports: [[
i5.CommonModule,
i3.CommonModule,
i1.NgxBaseControlModule,
], i5.CommonModule,
], i3.CommonModule,
i1.NgxBaseControlModule] });

@@ -76,3 +76,3 @@ i0__namespace.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0__namespace, type: NgxTextAreaControlModule, decorators: [{

imports: [
i5.CommonModule,
i3.CommonModule,
i1.NgxBaseControlModule,

@@ -84,3 +84,3 @@ ],

exports: [
i5.CommonModule,
i3.CommonModule,
i1.NgxBaseControlModule,

@@ -87,0 +87,0 @@ TextAreaControlComponent,

@@ -8,2 +8,3 @@ import { Subject } from "rxjs";

field: Field<any>;
hintTemplate: TemplateRef<any>;
errorsTemplate: TemplateRef<any>;

@@ -10,0 +11,0 @@ initialized: boolean;

@@ -9,7 +9,8 @@ import * as i0 from "@angular/core";

import * as i7 from "@angular/material/input";
import * as i8 from "angular-extensions/pipes";
import * as i8 from "@angular/material/tooltip";
import * as i9 from "angular-extensions/pipes";
export declare class NgxBaseControlModule {
static ɵfac: i0.ɵɵFactoryDeclaration<NgxBaseControlModule, never>;
static ɵmod: i0.ɵɵNgModuleDeclaration<NgxBaseControlModule, [typeof i1.BaseControlComponent], [typeof i2.CommonModule, typeof i3.A11yModule, typeof i4.ReactiveFormsModule, typeof i5.MatIconModule, typeof i6.MatFormFieldModule, typeof i7.MatInputModule, typeof i8.NgxPipesModule], [typeof i2.CommonModule, typeof i3.A11yModule, typeof i4.ReactiveFormsModule, typeof i5.MatIconModule, typeof i6.MatFormFieldModule, typeof i7.MatInputModule, typeof i8.NgxPipesModule, typeof i1.BaseControlComponent]>;
static ɵmod: i0.ɵɵNgModuleDeclaration<NgxBaseControlModule, [typeof i1.BaseControlComponent], [typeof i2.CommonModule, typeof i3.A11yModule, typeof i4.ReactiveFormsModule, typeof i5.MatIconModule, typeof i6.MatFormFieldModule, typeof i7.MatInputModule, typeof i8.MatTooltipModule, typeof i9.NgxPipesModule], [typeof i2.CommonModule, typeof i3.A11yModule, typeof i4.ReactiveFormsModule, typeof i5.MatIconModule, typeof i6.MatFormFieldModule, typeof i7.MatInputModule, typeof i8.MatTooltipModule, typeof i9.NgxPipesModule, typeof i1.BaseControlComponent]>;
static ɵinj: i0.ɵɵInjectorDeclaration<NgxBaseControlModule>;
}

@@ -5,5 +5,6 @@ import { Subject } from "rxjs";

import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@angular/material/form-field";
import * as i3 from "angular-extensions/pipes";
import * as i1 from "@angular/material/form-field";
import * as i2 from "@angular/material/tooltip";
import * as i3 from "@angular/common";
import * as i4 from "angular-extensions/pipes";
export class BaseControlComponent {

@@ -37,3 +38,3 @@ constructor(emenentRef) {

BaseControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: BaseControlComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
BaseControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: BaseControlComponent, selector: "base-control", inputs: { field: "field" }, viewQueries: [{ propertyName: "errorsTemplate", first: true, predicate: TemplateRef, descendants: true }], ngImport: i0, template: "<ng-content></ng-content>\r\n\r\n<ng-template>\r\n <mat-error *ngIf=\"field.control.errors?.required as error\">\r\n {{ field.validation.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.requiredTrue as error\">\r\n {{ field.validation.requiredTrue?.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.min as error\">\r\n {{ field.validation.min?.text || \"Value should be greater than \" + error.min }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.max as error\">\r\n {{ field.validation.max?.text || \"Value should be smaller than \" + error.max }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minlength as error\">\r\n {{ field.validation.minLength?.text || \"Value should be longer than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxlength as error\">\r\n {{ field.validation.maxLength?.text || \"Value should be shorter than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minDate as error\">\r\n {{ field.validation.minDate?.text || \"Date should be after the \" + (error.minDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minOrEqualDate as error\">\r\n {{ field.validation.minOrEqualDate?.text || \"Date should be same or after the \" + (error.minOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxDate as error\">\r\n {{ field.validation.maxDate?.text || \"Date should be before the \" + (error.maxDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxOrEqualDate as error\">\r\n {{ field.validation.maxOrEqualDate?.text || \"Date should be same or before the \" + (error.maxOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.pattern as error\">\r\n {{ field.validation.pattern?.text || error.message }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.custom as error\">\r\n {{ field.validation.custom?.text || error.message }}\r\n </mat-error>\r\n</ng-template>\r\n", styles: [".control:not(:last-child):not(.d-block){padding-right:1.34375em}.control.d-none{display:none!important}.control.d-block{display:block}.control.d-block mat-form-field{display:block;margin-right:0}.control base-control{font-size:14px}.control base-control mat-form-field{min-width:150px}.control base-control mat-form-field.p-0 .mat-form-field-wrapper{padding:0!important}.control base-control mat-form-field.p-0 .mat-form-field-underline{bottom:0!important}.control base-control mat-form-field .mat-form-field-wrapper{padding-bottom:.25rem}.control base-control mat-form-field .mat-form-field-subscript-wrapper{position:relative}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "date": i3.DatePipe }, encapsulation: i0.ViewEncapsulation.None });
BaseControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: BaseControlComponent, selector: "base-control", inputs: { field: "field" }, viewQueries: [{ propertyName: "hintTemplate", first: true, predicate: TemplateRef, descendants: true }, { propertyName: "errorsTemplate", first: true, predicate: TemplateRef, descendants: true }], ngImport: i0, template: "<ng-content></ng-content>\r\n\r\n<ng-template #hintTemplate>\r\n <mat-hint class=\"text-truncate\"\r\n style=\"cursor: default;\"\r\n [matTooltip]=\"$any(field.info)\">\r\n {{ field.info }}\r\n </mat-hint>\r\n</ng-template>\r\n\r\n<ng-template #errorsTemplate>\r\n <mat-error *ngIf=\"field.control.errors?.required as error\">\r\n {{ field.validation.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.requiredTrue as error\">\r\n {{ field.validation.requiredTrue?.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.min as error\">\r\n {{ field.validation.min?.text || \"Value should be greater than \" + error.min }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.max as error\">\r\n {{ field.validation.max?.text || \"Value should be smaller than \" + error.max }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minlength as error\">\r\n {{ field.validation.minLength?.text || \"Value should be longer than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxlength as error\">\r\n {{ field.validation.maxLength?.text || \"Value should be shorter than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minDate as error\">\r\n {{ field.validation.minDate?.text || \"Date should be after the \" + (error.minDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minOrEqualDate as error\">\r\n {{ field.validation.minOrEqualDate?.text || \"Date should be same or after the \" + (error.minOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxDate as error\">\r\n {{ field.validation.maxDate?.text || \"Date should be before the \" + (error.maxDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxOrEqualDate as error\">\r\n {{ field.validation.maxOrEqualDate?.text || \"Date should be same or before the \" + (error.maxOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.pattern as error\">\r\n {{ field.validation.pattern?.text || error.message }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.custom as error\">\r\n {{ field.validation.custom?.text || error.message }}\r\n </mat-error>\r\n</ng-template>\r\n", styles: [".control:not(:last-child):not(.d-block){padding-right:1.34375em}.control.d-none{display:none!important}.control.d-block{display:block}.control.d-block mat-form-field{display:block;margin-right:0}.control base-control{font-size:14px}.control base-control mat-form-field{min-width:150px}.control base-control mat-form-field.p-0 .mat-form-field-wrapper{padding:0!important}.control base-control mat-form-field.p-0 .mat-form-field-underline{bottom:0!important}.control base-control mat-form-field .mat-form-field-wrapper{padding-bottom:.25rem}.control base-control mat-form-field .mat-form-field-subscript-wrapper{position:relative}.control base-control mat-form-field .mat-hint{display:block;width:100%}\n"], directives: [{ type: i1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "date": i4.DatePipe }, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: BaseControlComponent, decorators: [{

@@ -49,2 +50,5 @@ type: Component,

type: Input
}], hintTemplate: [{
type: ViewChild,
args: [TemplateRef]
}], errorsTemplate: [{

@@ -54,2 +58,2 @@ type: ViewChild,

}] } });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9iYXNlLWNvbnRyb2wvYmFzZS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9iYXNlLWNvbnRyb2wvYmFzZS1jb250cm9sLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDL0IsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQWlDLGlCQUFpQixFQUFpQixNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFVMUksTUFBTSxPQUFPLG9CQUFvQjtJQVcvQixZQUNVLFVBQW1DOztRQUFuQyxlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQUh0QyxZQUFPLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUs3QixNQUFBLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLGFBQWEsMENBQUUsU0FBUyxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUN4RSxDQUFDO0lBRU0sUUFBUTtRQUNiLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLEVBQUU7WUFDeEIsSUFBSSxDQUFDLEtBQUs7aUJBQ1AsU0FBUztpQkFDVCxZQUFZO2lCQUNaLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO2lCQUM3QixTQUFTLENBQUMsR0FBRyxFQUFFOztnQkFDZCxNQUFBLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLGFBQWEsMENBQUUsU0FBUyxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQy9GLENBQUMsQ0FBQyxDQUFDO1lBRUwsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztTQUMvQztJQUNILENBQUM7SUFFTSxlQUFlO1FBQ3BCLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFTSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdEIsQ0FBQzs7aUhBckNVLG9CQUFvQjtxR0FBcEIsb0JBQW9CLGdJQUtwQixXQUFXLGdEQ2pCeEIsMnJFQW1EQTsyRkR2Q2Esb0JBQW9CO2tCQU5oQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxjQUFjO29CQUN4QixXQUFXLEVBQUUsK0JBQStCO29CQUM1QyxTQUFTLEVBQUUsQ0FBQywrQkFBK0IsQ0FBQztvQkFDNUMsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7aUJBQ3RDO2lHQUlRLEtBQUs7c0JBRFgsS0FBSztnQkFJQyxjQUFjO3NCQURwQixTQUFTO3VCQUFDLFdBQVciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSBcInJ4anNcIjtcclxuaW1wb3J0IHsgdGFrZVVudGlsIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XHJcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIFZpZXdDaGlsZCwgVGVtcGxhdGVSZWYsIEVsZW1lbnRSZWYsIE9uSW5pdCwgT25EZXN0cm95LCBWaWV3RW5jYXBzdWxhdGlvbiwgQWZ0ZXJWaWV3SW5pdCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5pbXBvcnQgeyBGaWVsZCB9IGZyb20gXCJhbmd1bGFyLWV4dGVuc2lvbnMvbW9kZWxzXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJiYXNlLWNvbnRyb2xcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL2Jhc2UtY29udHJvbC5jb21wb25lbnQuaHRtbFwiLFxyXG4gIHN0eWxlVXJsczogW1wiLi9iYXNlLWNvbnRyb2wuY29tcG9uZW50LnNjc3NcIl0sXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQmFzZUNvbnRyb2xDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGZpZWxkOiBGaWVsZDxhbnk+O1xyXG5cclxuICBAVmlld0NoaWxkKFRlbXBsYXRlUmVmKVxyXG4gIHB1YmxpYyBlcnJvcnNUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgcHVibGljIGluaXRpYWxpemVkOiBib29sZWFuO1xyXG4gIHB1YmxpYyBkZXN0cm95ID0gbmV3IFN1YmplY3QoKTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGVtZW5lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LFxyXG4gICkge1xyXG4gICAgdGhpcy5lbWVuZW50UmVmLm5hdGl2ZUVsZW1lbnQucGFyZW50RWxlbWVudD8uY2xhc3NMaXN0LmFkZChcImNvbnRyb2xcIik7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbmdPbkluaXQoKSB7XHJcbiAgICBpZiAodGhpcy5maWVsZC5mb3JtR3JvdXApIHtcclxuICAgICAgdGhpcy5maWVsZFxyXG4gICAgICAgIC5mb3JtR3JvdXBcclxuICAgICAgICAudmFsdWVDaGFuZ2VzXHJcbiAgICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSkpXHJcbiAgICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgICAgICB0aGlzLmVtZW5lbnRSZWYubmF0aXZlRWxlbWVudC5wYXJlbnRFbGVtZW50Py5jbGFzc0xpc3QudG9nZ2xlKFwiZC1ub25lXCIsICF0aGlzLmZpZWxkLnZpc2libGUpO1xyXG4gICAgICAgIH0pO1xyXG5cclxuICAgICAgdGhpcy5maWVsZC5mb3JtR3JvdXAudXBkYXRlVmFsdWVBbmRWYWxpZGl0eSgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcclxuICAgIHNldFRpbWVvdXQoKCkgPT4gdGhpcy5pbml0aWFsaXplZCA9IHRydWUpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG5nT25EZXN0cm95KCkge1xyXG4gICAgdGhpcy5kZXN0cm95Lm5leHQoKTtcclxuICB9XHJcbn1cclxuIiwiPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG5cclxuPG5nLXRlbXBsYXRlPlxyXG4gIDxtYXQtZXJyb3IgKm5nSWY9XCJmaWVsZC5jb250cm9sLmVycm9ycz8ucmVxdWlyZWQgYXMgZXJyb3JcIj5cclxuICAgIHt7IGZpZWxkLnZhbGlkYXRpb24udGV4dCB8fCBcIkZpZWxkIGlzIHJlcXVpcmVkXCIgfX1cclxuICA8L21hdC1lcnJvcj5cclxuXHJcbiAgPG1hdC1lcnJvciAqbmdJZj1cImZpZWxkLmNvbnRyb2wuZXJyb3JzPy5yZXF1aXJlZFRydWUgYXMgZXJyb3JcIj5cclxuICAgIHt7IGZpZWxkLnZhbGlkYXRpb24ucmVxdWlyZWRUcnVlPy50ZXh0IHx8IFwiRmllbGQgaXMgcmVxdWlyZWRcIiB9fVxyXG4gIDwvbWF0LWVycm9yPlxyXG5cclxuICA8bWF0LWVycm9yICpuZ0lmPVwiZmllbGQuY29udHJvbC5lcnJvcnM/Lm1pbiBhcyBlcnJvclwiPlxyXG4gICAge3sgZmllbGQudmFsaWRhdGlvbi5taW4/LnRleHQgfHwgXCJWYWx1ZSBzaG91bGQgYmUgZ3JlYXRlciB0aGFuIFwiICsgZXJyb3IubWluIH19XHJcbiAgPC9tYXQtZXJyb3I+XHJcblxyXG4gIDxtYXQtZXJyb3IgKm5nSWY9XCJmaWVsZC5jb250cm9sLmVycm9ycz8ubWF4IGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLm1heD8udGV4dCB8fCBcIlZhbHVlIHNob3VsZCBiZSBzbWFsbGVyIHRoYW4gXCIgKyBlcnJvci5tYXggfX1cclxuICA8L21hdC1lcnJvcj5cclxuXHJcbiAgPG1hdC1lcnJvciAqbmdJZj1cImZpZWxkLmNvbnRyb2wuZXJyb3JzPy5taW5sZW5ndGggYXMgZXJyb3JcIj5cclxuICAgIHt7IGZpZWxkLnZhbGlkYXRpb24ubWluTGVuZ3RoPy50ZXh0IHx8IFwiVmFsdWUgc2hvdWxkIGJlIGxvbmdlciB0aGFuIFwiICsgZXJyb3IucmVxdWlyZWRMZW5ndGggfX1cclxuICA8L21hdC1lcnJvcj5cclxuXHJcbiAgPG1hdC1lcnJvciAqbmdJZj1cImZpZWxkLmNvbnRyb2wuZXJyb3JzPy5tYXhsZW5ndGggYXMgZXJyb3JcIj5cclxuICAgIHt7IGZpZWxkLnZhbGlkYXRpb24ubWF4TGVuZ3RoPy50ZXh0IHx8IFwiVmFsdWUgc2hvdWxkIGJlIHNob3J0ZXIgdGhhbiBcIiArIGVycm9yLnJlcXVpcmVkTGVuZ3RoIH19XHJcbiAgPC9tYXQtZXJyb3I+XHJcblxyXG4gIDxtYXQtZXJyb3IgKm5nSWY9XCJmaWVsZC5jb250cm9sLmVycm9ycz8ubWluRGF0ZSBhcyBlcnJvclwiPlxyXG4gICAge3sgZmllbGQudmFsaWRhdGlvbi5taW5EYXRlPy50ZXh0IHx8IFwiRGF0ZSBzaG91bGQgYmUgYWZ0ZXIgdGhlIFwiICsgKGVycm9yLm1pbkRhdGUgfCBkYXRlKSB9fVxyXG4gIDwvbWF0LWVycm9yPlxyXG5cclxuICA8bWF0LWVycm9yICpuZ0lmPVwiZmllbGQuY29udHJvbC5lcnJvcnM/Lm1pbk9yRXF1YWxEYXRlIGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLm1pbk9yRXF1YWxEYXRlPy50ZXh0IHx8IFwiRGF0ZSBzaG91bGQgYmUgc2FtZSBvciBhZnRlciB0aGUgXCIgKyAoZXJyb3IubWluT3JFcXVhbERhdGUgfCBkYXRlKSB9fVxyXG4gIDwvbWF0LWVycm9yPlxyXG5cclxuICA8bWF0LWVycm9yICpuZ0lmPVwiZmllbGQuY29udHJvbC5lcnJvcnM/Lm1heERhdGUgYXMgZXJyb3JcIj5cclxuICAgIHt7IGZpZWxkLnZhbGlkYXRpb24ubWF4RGF0ZT8udGV4dCB8fCBcIkRhdGUgc2hvdWxkIGJlIGJlZm9yZSB0aGUgXCIgKyAoZXJyb3IubWF4RGF0ZSB8IGRhdGUpIH19XHJcbiAgPC9tYXQtZXJyb3I+XHJcblxyXG4gIDxtYXQtZXJyb3IgKm5nSWY9XCJmaWVsZC5jb250cm9sLmVycm9ycz8ubWF4T3JFcXVhbERhdGUgYXMgZXJyb3JcIj5cclxuICAgIHt7IGZpZWxkLnZhbGlkYXRpb24ubWF4T3JFcXVhbERhdGU/LnRleHQgfHwgXCJEYXRlIHNob3VsZCBiZSBzYW1lIG9yIGJlZm9yZSB0aGUgXCIgKyAoZXJyb3IubWF4T3JFcXVhbERhdGUgfCBkYXRlKSB9fVxyXG4gIDwvbWF0LWVycm9yPlxyXG5cclxuICA8bWF0LWVycm9yICpuZ0lmPVwiZmllbGQuY29udHJvbC5lcnJvcnM/LnBhdHRlcm4gYXMgZXJyb3JcIj5cclxuICAgIHt7IGZpZWxkLnZhbGlkYXRpb24ucGF0dGVybj8udGV4dCB8fCBlcnJvci5tZXNzYWdlIH19XHJcbiAgPC9tYXQtZXJyb3I+XHJcblxyXG4gIDxtYXQtZXJyb3IgKm5nSWY9XCJmaWVsZC5jb250cm9sLmVycm9ycz8uY3VzdG9tIGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLmN1c3RvbT8udGV4dCB8fCBlcnJvci5tZXNzYWdlIH19XHJcbiAgPC9tYXQtZXJyb3I+XHJcbjwvbmctdGVtcGxhdGU+XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9iYXNlLWNvbnRyb2wvYmFzZS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9iYXNlLWNvbnRyb2wvYmFzZS1jb250cm9sLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDL0IsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQWlDLGlCQUFpQixFQUFpQixNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBVTFJLE1BQU0sT0FBTyxvQkFBb0I7SUFjL0IsWUFDVSxVQUFtQzs7UUFBbkMsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUFIdEMsWUFBTyxHQUFHLElBQUksT0FBTyxFQUFFLENBQUM7UUFLN0IsTUFBQSxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxhQUFhLDBDQUFFLFNBQVMsQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDeEUsQ0FBQztJQUVNLFFBQVE7UUFDYixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxFQUFFO1lBQ3hCLElBQUksQ0FBQyxLQUFLO2lCQUNQLFNBQVM7aUJBQ1QsWUFBWTtpQkFDWixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztpQkFDN0IsU0FBUyxDQUFDLEdBQUcsRUFBRTs7Z0JBQ2QsTUFBQSxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxhQUFhLDBDQUFFLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUMvRixDQUFDLENBQUMsQ0FBQztZQUVMLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLHNCQUFzQixFQUFFLENBQUM7U0FDL0M7SUFDSCxDQUFDO0lBRU0sZUFBZTtRQUNwQixVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3RCLENBQUM7O2lIQXhDVSxvQkFBb0I7cUdBQXBCLG9CQUFvQiw4SEFLcEIsV0FBVyxpRkFHWCxXQUFXLGdEQ3BCeEIsNDZFQTJEQTsyRkQvQ2Esb0JBQW9CO2tCQU5oQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxjQUFjO29CQUN4QixXQUFXLEVBQUUsK0JBQStCO29CQUM1QyxTQUFTLEVBQUUsQ0FBQywrQkFBK0IsQ0FBQztvQkFDNUMsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7aUJBQ3RDO2lHQUlRLEtBQUs7c0JBRFgsS0FBSztnQkFJQyxZQUFZO3NCQURsQixTQUFTO3VCQUFDLFdBQVc7Z0JBSWYsY0FBYztzQkFEcEIsU0FBUzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gXCJyeGpzXCI7XHJcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBWaWV3Q2hpbGQsIFRlbXBsYXRlUmVmLCBFbGVtZW50UmVmLCBPbkluaXQsIE9uRGVzdHJveSwgVmlld0VuY2Fwc3VsYXRpb24sIEFmdGVyVmlld0luaXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5cclxuaW1wb3J0IHsgRmllbGQgfSBmcm9tIFwiYW5ndWxhci1leHRlbnNpb25zL21vZGVsc1wiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwiYmFzZS1jb250cm9sXCIsXHJcbiAgdGVtcGxhdGVVcmw6IFwiLi9iYXNlLWNvbnRyb2wuY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vYmFzZS1jb250cm9sLmNvbXBvbmVudC5zY3NzXCJdLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcclxufSlcclxuZXhwb3J0IGNsYXNzIEJhc2VDb250cm9sQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZDogRmllbGQ8YW55PjtcclxuXHJcbiAgQFZpZXdDaGlsZChUZW1wbGF0ZVJlZilcclxuICBwdWJsaWMgaGludFRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cclxuICBAVmlld0NoaWxkKFRlbXBsYXRlUmVmKVxyXG4gIHB1YmxpYyBlcnJvcnNUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgcHVibGljIGluaXRpYWxpemVkOiBib29sZWFuO1xyXG4gIHB1YmxpYyBkZXN0cm95ID0gbmV3IFN1YmplY3QoKTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGVtZW5lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LFxyXG4gICkge1xyXG4gICAgdGhpcy5lbWVuZW50UmVmLm5hdGl2ZUVsZW1lbnQucGFyZW50RWxlbWVudD8uY2xhc3NMaXN0LmFkZChcImNvbnRyb2xcIik7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbmdPbkluaXQoKSB7XHJcbiAgICBpZiAodGhpcy5maWVsZC5mb3JtR3JvdXApIHtcclxuICAgICAgdGhpcy5maWVsZFxyXG4gICAgICAgIC5mb3JtR3JvdXBcclxuICAgICAgICAudmFsdWVDaGFuZ2VzXHJcbiAgICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSkpXHJcbiAgICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgICAgICB0aGlzLmVtZW5lbnRSZWYubmF0aXZlRWxlbWVudC5wYXJlbnRFbGVtZW50Py5jbGFzc0xpc3QudG9nZ2xlKFwiZC1ub25lXCIsICF0aGlzLmZpZWxkLnZpc2libGUpO1xyXG4gICAgICAgIH0pO1xyXG5cclxuICAgICAgdGhpcy5maWVsZC5mb3JtR3JvdXAudXBkYXRlVmFsdWVBbmRWYWxpZGl0eSgpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcclxuICAgIHNldFRpbWVvdXQoKCkgPT4gdGhpcy5pbml0aWFsaXplZCA9IHRydWUpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG5nT25EZXN0cm95KCkge1xyXG4gICAgdGhpcy5kZXN0cm95Lm5leHQoKTtcclxuICB9XHJcbn1cclxuIiwiPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG5cclxuPG5nLXRlbXBsYXRlICNoaW50VGVtcGxhdGU+XHJcbiAgPG1hdC1oaW50IGNsYXNzPVwidGV4dC10cnVuY2F0ZVwiXHJcbiAgICAgICAgICAgIHN0eWxlPVwiY3Vyc29yOiBkZWZhdWx0O1wiXHJcbiAgICAgICAgICAgIFttYXRUb29sdGlwXT1cIiRhbnkoZmllbGQuaW5mbylcIj5cclxuICAgIHt7IGZpZWxkLmluZm8gfX1cclxuICA8L21hdC1oaW50PlxyXG48L25nLXRlbXBsYXRlPlxyXG5cclxuPG5nLXRlbXBsYXRlICNlcnJvcnNUZW1wbGF0ZT5cclxuICA8bWF0LWVycm9yICpuZ0lmPVwiZmllbGQuY29udHJvbC5lcnJvcnM/LnJlcXVpcmVkIGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLnRleHQgfHwgXCJGaWVsZCBpcyByZXF1aXJlZFwiIH19XHJcbiAgPC9tYXQtZXJyb3I+XHJcblxyXG4gIDxtYXQtZXJyb3IgKm5nSWY9XCJmaWVsZC5jb250cm9sLmVycm9ycz8ucmVxdWlyZWRUcnVlIGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLnJlcXVpcmVkVHJ1ZT8udGV4dCB8fCBcIkZpZWxkIGlzIHJlcXVpcmVkXCIgfX1cclxuICA8L21hdC1lcnJvcj5cclxuXHJcbiAgPG1hdC1lcnJvciAqbmdJZj1cImZpZWxkLmNvbnRyb2wuZXJyb3JzPy5taW4gYXMgZXJyb3JcIj5cclxuICAgIHt7IGZpZWxkLnZhbGlkYXRpb24ubWluPy50ZXh0IHx8IFwiVmFsdWUgc2hvdWxkIGJlIGdyZWF0ZXIgdGhhbiBcIiArIGVycm9yLm1pbiB9fVxyXG4gIDwvbWF0LWVycm9yPlxyXG5cclxuICA8bWF0LWVycm9yICpuZ0lmPVwiZmllbGQuY29udHJvbC5lcnJvcnM/Lm1heCBhcyBlcnJvclwiPlxyXG4gICAge3sgZmllbGQudmFsaWRhdGlvbi5tYXg/LnRleHQgfHwgXCJWYWx1ZSBzaG91bGQgYmUgc21hbGxlciB0aGFuIFwiICsgZXJyb3IubWF4IH19XHJcbiAgPC9tYXQtZXJyb3I+XHJcblxyXG4gIDxtYXQtZXJyb3IgKm5nSWY9XCJmaWVsZC5jb250cm9sLmVycm9ycz8ubWlubGVuZ3RoIGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLm1pbkxlbmd0aD8udGV4dCB8fCBcIlZhbHVlIHNob3VsZCBiZSBsb25nZXIgdGhhbiBcIiArIGVycm9yLnJlcXVpcmVkTGVuZ3RoIH19XHJcbiAgPC9tYXQtZXJyb3I+XHJcblxyXG4gIDxtYXQtZXJyb3IgKm5nSWY9XCJmaWVsZC5jb250cm9sLmVycm9ycz8ubWF4bGVuZ3RoIGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLm1heExlbmd0aD8udGV4dCB8fCBcIlZhbHVlIHNob3VsZCBiZSBzaG9ydGVyIHRoYW4gXCIgKyBlcnJvci5yZXF1aXJlZExlbmd0aCB9fVxyXG4gIDwvbWF0LWVycm9yPlxyXG5cclxuICA8bWF0LWVycm9yICpuZ0lmPVwiZmllbGQuY29udHJvbC5lcnJvcnM/Lm1pbkRhdGUgYXMgZXJyb3JcIj5cclxuICAgIHt7IGZpZWxkLnZhbGlkYXRpb24ubWluRGF0ZT8udGV4dCB8fCBcIkRhdGUgc2hvdWxkIGJlIGFmdGVyIHRoZSBcIiArIChlcnJvci5taW5EYXRlIHwgZGF0ZSkgfX1cclxuICA8L21hdC1lcnJvcj5cclxuXHJcbiAgPG1hdC1lcnJvciAqbmdJZj1cImZpZWxkLmNvbnRyb2wuZXJyb3JzPy5taW5PckVxdWFsRGF0ZSBhcyBlcnJvclwiPlxyXG4gICAge3sgZmllbGQudmFsaWRhdGlvbi5taW5PckVxdWFsRGF0ZT8udGV4dCB8fCBcIkRhdGUgc2hvdWxkIGJlIHNhbWUgb3IgYWZ0ZXIgdGhlIFwiICsgKGVycm9yLm1pbk9yRXF1YWxEYXRlIHwgZGF0ZSkgfX1cclxuICA8L21hdC1lcnJvcj5cclxuXHJcbiAgPG1hdC1lcnJvciAqbmdJZj1cImZpZWxkLmNvbnRyb2wuZXJyb3JzPy5tYXhEYXRlIGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLm1heERhdGU/LnRleHQgfHwgXCJEYXRlIHNob3VsZCBiZSBiZWZvcmUgdGhlIFwiICsgKGVycm9yLm1heERhdGUgfCBkYXRlKSB9fVxyXG4gIDwvbWF0LWVycm9yPlxyXG5cclxuICA8bWF0LWVycm9yICpuZ0lmPVwiZmllbGQuY29udHJvbC5lcnJvcnM/Lm1heE9yRXF1YWxEYXRlIGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLm1heE9yRXF1YWxEYXRlPy50ZXh0IHx8IFwiRGF0ZSBzaG91bGQgYmUgc2FtZSBvciBiZWZvcmUgdGhlIFwiICsgKGVycm9yLm1heE9yRXF1YWxEYXRlIHwgZGF0ZSkgfX1cclxuICA8L21hdC1lcnJvcj5cclxuXHJcbiAgPG1hdC1lcnJvciAqbmdJZj1cImZpZWxkLmNvbnRyb2wuZXJyb3JzPy5wYXR0ZXJuIGFzIGVycm9yXCI+XHJcbiAgICB7eyBmaWVsZC52YWxpZGF0aW9uLnBhdHRlcm4/LnRleHQgfHwgZXJyb3IubWVzc2FnZSB9fVxyXG4gIDwvbWF0LWVycm9yPlxyXG5cclxuICA8bWF0LWVycm9yICpuZ0lmPVwiZmllbGQuY29udHJvbC5lcnJvcnM/LmN1c3RvbSBhcyBlcnJvclwiPlxyXG4gICAge3sgZmllbGQudmFsaWRhdGlvbi5jdXN0b20/LnRleHQgfHwgZXJyb3IubWVzc2FnZSB9fVxyXG4gIDwvbWF0LWVycm9yPlxyXG48L25nLXRlbXBsYXRlPlxyXG4iXX0=

@@ -10,2 +10,3 @@ import { NgModule } from "@angular/core";

import { BaseControlComponent } from "./base-control.component";
import { MatTooltipModule } from "@angular/material/tooltip";
import * as i0 from "@angular/core";

@@ -21,2 +22,3 @@ export class NgxBaseControlModule {

MatInputModule,
MatTooltipModule,
NgxPipesModule], exports: [CommonModule,

@@ -28,2 +30,3 @@ A11yModule,

MatInputModule,
MatTooltipModule,
NgxPipesModule,

@@ -38,2 +41,3 @@ BaseControlComponent] });

MatInputModule,
MatTooltipModule,
NgxPipesModule,

@@ -46,2 +50,3 @@ ], CommonModule,

MatInputModule,
MatTooltipModule,
NgxPipesModule] });

@@ -58,2 +63,3 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: NgxBaseControlModule, decorators: [{

MatInputModule,
MatTooltipModule,
NgxPipesModule,

@@ -71,2 +77,3 @@ ],

MatInputModule,
MatTooltipModule,
NgxPipesModule,

@@ -77,2 +84,2 @@ BaseControlComponent,

}] });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWJhc2UtY29udHJvbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWV4dGVuc2lvbnMvY29udHJvbHMvYmFzZS1jb250cm9sL25neC1iYXNlLWNvbnRyb2wubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRXpELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUErQmhFLE1BQU0sT0FBTyxvQkFBb0I7O2lIQUFwQixvQkFBb0I7a0hBQXBCLG9CQUFvQixpQkFoQjdCLG9CQUFvQixhQVhwQixZQUFZO1FBQ1osVUFBVTtRQUNWLG1CQUFtQjtRQUVuQixhQUFhO1FBQ2Isa0JBQWtCO1FBQ2xCLGNBQWM7UUFFZCxjQUFjLGFBTWQsWUFBWTtRQUNaLFVBQVU7UUFDVixtQkFBbUI7UUFFbkIsYUFBYTtRQUNiLGtCQUFrQjtRQUNsQixjQUFjO1FBRWQsY0FBYztRQUVkLG9CQUFvQjtrSEFHWCxvQkFBb0IsWUE1QnRCO1lBQ1AsWUFBWTtZQUNaLFVBQVU7WUFDVixtQkFBbUI7WUFFbkIsYUFBYTtZQUNiLGtCQUFrQjtZQUNsQixjQUFjO1lBRWQsY0FBYztTQUNmLEVBS0MsWUFBWTtRQUNaLFVBQVU7UUFDVixtQkFBbUI7UUFFbkIsYUFBYTtRQUNiLGtCQUFrQjtRQUNsQixjQUFjO1FBRWQsY0FBYzsyRkFLTCxvQkFBb0I7a0JBN0JoQyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFVBQVU7d0JBQ1YsbUJBQW1CO3dCQUVuQixhQUFhO3dCQUNiLGtCQUFrQjt3QkFDbEIsY0FBYzt3QkFFZCxjQUFjO3FCQUNmO29CQUNELFlBQVksRUFBRTt3QkFDWixvQkFBb0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFVBQVU7d0JBQ1YsbUJBQW1CO3dCQUVuQixhQUFhO3dCQUNiLGtCQUFrQjt3QkFDbEIsY0FBYzt3QkFFZCxjQUFjO3dCQUVkLG9CQUFvQjtxQkFDckI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgQTExeU1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jZGsvYTExeVwiO1xyXG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvblwiO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZFwiO1xyXG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9pbnB1dFwiO1xyXG5cclxuaW1wb3J0IHsgTmd4UGlwZXNNb2R1bGUgfSBmcm9tIFwiYW5ndWxhci1leHRlbnNpb25zL3BpcGVzXCI7XHJcbmltcG9ydCB7IEJhc2VDb250cm9sQ29tcG9uZW50IH0gZnJvbSBcIi4vYmFzZS1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBBMTF5TW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuXHJcbiAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxyXG4gICAgTWF0SW5wdXRNb2R1bGUsXHJcblxyXG4gICAgTmd4UGlwZXNNb2R1bGUsXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIEJhc2VDb250cm9sQ29tcG9uZW50LFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgQTExeU1vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcblxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcclxuICAgIE1hdElucHV0TW9kdWxlLFxyXG5cclxuICAgIE5neFBpcGVzTW9kdWxlLFxyXG5cclxuICAgIEJhc2VDb250cm9sQ29tcG9uZW50LFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIE5neEJhc2VDb250cm9sTW9kdWxlIHsgfVxyXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWJhc2UtY29udHJvbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWV4dGVuc2lvbnMvY29udHJvbHMvYmFzZS1jb250cm9sL25neC1iYXNlLWNvbnRyb2wubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRXpELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7QUFpQzdELE1BQU0sT0FBTyxvQkFBb0I7O2lIQUFwQixvQkFBb0I7a0hBQXBCLG9CQUFvQixpQkFqQjdCLG9CQUFvQixhQVpwQixZQUFZO1FBQ1osVUFBVTtRQUNWLG1CQUFtQjtRQUVuQixhQUFhO1FBQ2Isa0JBQWtCO1FBQ2xCLGNBQWM7UUFDZCxnQkFBZ0I7UUFFaEIsY0FBYyxhQU1kLFlBQVk7UUFDWixVQUFVO1FBQ1YsbUJBQW1CO1FBRW5CLGFBQWE7UUFDYixrQkFBa0I7UUFDbEIsY0FBYztRQUNkLGdCQUFnQjtRQUVoQixjQUFjO1FBRWQsb0JBQW9CO2tIQUdYLG9CQUFvQixZQTlCdEI7WUFDUCxZQUFZO1lBQ1osVUFBVTtZQUNWLG1CQUFtQjtZQUVuQixhQUFhO1lBQ2Isa0JBQWtCO1lBQ2xCLGNBQWM7WUFDZCxnQkFBZ0I7WUFFaEIsY0FBYztTQUNmLEVBS0MsWUFBWTtRQUNaLFVBQVU7UUFDVixtQkFBbUI7UUFFbkIsYUFBYTtRQUNiLGtCQUFrQjtRQUNsQixjQUFjO1FBQ2QsZ0JBQWdCO1FBRWhCLGNBQWM7MkZBS0wsb0JBQW9CO2tCQS9CaEMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixVQUFVO3dCQUNWLG1CQUFtQjt3QkFFbkIsYUFBYTt3QkFDYixrQkFBa0I7d0JBQ2xCLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUVoQixjQUFjO3FCQUNmO29CQUNELFlBQVksRUFBRTt3QkFDWixvQkFBb0I7cUJBQ3JCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFVBQVU7d0JBQ1YsbUJBQW1CO3dCQUVuQixhQUFhO3dCQUNiLGtCQUFrQjt3QkFDbEIsY0FBYzt3QkFDZCxnQkFBZ0I7d0JBRWhCLGNBQWM7d0JBRWQsb0JBQW9CO3FCQUNyQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBBMTF5TW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2Nkay9hMTF5XCI7XHJcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9pY29uXCI7XHJcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkXCI7XHJcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2lucHV0XCI7XHJcblxyXG5pbXBvcnQgeyBOZ3hQaXBlc01vZHVsZSB9IGZyb20gXCJhbmd1bGFyLWV4dGVuc2lvbnMvcGlwZXNcIjtcclxuaW1wb3J0IHsgQmFzZUNvbnRyb2xDb21wb25lbnQgfSBmcm9tIFwiLi9iYXNlLWNvbnRyb2wuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcFwiO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBBMTF5TW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuXHJcbiAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxyXG4gICAgTWF0SW5wdXRNb2R1bGUsXHJcbiAgICBNYXRUb29sdGlwTW9kdWxlLFxyXG5cclxuICAgIE5neFBpcGVzTW9kdWxlLFxyXG4gIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBCYXNlQ29udHJvbENvbXBvbmVudCxcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEExMXlNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG5cclxuICAgIE1hdEljb25Nb2R1bGUsXHJcbiAgICBNYXRGb3JtRmllbGRNb2R1bGUsXHJcbiAgICBNYXRJbnB1dE1vZHVsZSxcclxuICAgIE1hdFRvb2x0aXBNb2R1bGUsXHJcblxyXG4gICAgTmd4UGlwZXNNb2R1bGUsXHJcblxyXG4gICAgQmFzZUNvbnRyb2xDb21wb25lbnQsXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTmd4QmFzZUNvbnRyb2xNb2R1bGUgeyB9XHJcbiJdfQ==

@@ -8,7 +8,7 @@ import { Component, Inject, Input } from "@angular/core";

import * as i4 from "@angular/material/icon";
import * as i5 from "@angular/material/input";
import * as i6 from "angular-extensions/directives";
import * as i7 from "@angular/forms";
import * as i8 from "@angular/material/tooltip";
import * as i9 from "@angular/common";
import * as i5 from "@angular/common";
import * as i6 from "@angular/material/input";
import * as i7 from "angular-extensions/directives";
import * as i8 from "@angular/forms";
import * as i9 from "@angular/material/tooltip";
export class DateControlComponent {

@@ -72,3 +72,3 @@ constructor(elementRef, dateFormats) {

DateControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: DateControlComponent, deps: [{ token: i0.ElementRef }, { token: MAT_DATE_FORMATS }], target: i0.ɵɵFactoryTarget.Component });
DateControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: DateControlComponent, selector: "date-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", targetView: "targetView", startView: "startView", format: "format", clearable: "clearable" }, usesOnChanges: true, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field class=\"cursor-pointer\"\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"datePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"format\"\r\n [formControl]=\"field.control\"\r\n [matDatepicker]=\"datePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"datePicker\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <mat-datepicker #datePicker\r\n [startView]=\"startView\"\r\n (viewChanged)=\"viewChanged($event, datePicker)\"\r\n (monthSelected)=\"monthSelected($event, datePicker)\"\r\n (closed)=\"field.control.markAllAsTouched()\"></mat-datepicker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}:host ::ng-deep input{cursor:pointer}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i6.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i6.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i8.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
DateControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: DateControlComponent, selector: "date-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", targetView: "targetView", startView: "startView", format: "format", clearable: "clearable" }, usesOnChanges: true, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field class=\"cursor-pointer\"\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"datePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"format\"\r\n [formControl]=\"field.control\"\r\n [matDatepicker]=\"datePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"datePicker\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <mat-datepicker #datePicker\r\n [startView]=\"startView\"\r\n (viewChanged)=\"viewChanged($event, datePicker)\"\r\n (monthSelected)=\"monthSelected($event, datePicker)\"\r\n (closed)=\"field.control.markAllAsTouched()\"></mat-datepicker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}:host ::ng-deep input{cursor:pointer}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i7.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i7.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: DateControlComponent, decorators: [{

@@ -99,2 +99,2 @@ type: Component,

}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-control.component.js","sourceRoot":"","sources":["../../../../../projects/angular-extensions/controls/date-control/date-control.component.ts","../../../../../projects/angular-extensions/controls/date-control/date-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentRef, ElementRef, Inject, Input, OnChanges } from \"@angular/core\";\r\nimport { MatFormFieldAppearance } from \"@angular/material/form-field\";\r\nimport { MatCalendarView, MatDatepicker, MatDatepickerContent } from \"@angular/material/datepicker\";\r\nimport { MatDateFormats, MAT_DATE_FORMATS } from \"@angular/material/core\";\r\n\r\nimport { SimpleChanges } from \"angular-extensions/core\";\r\nimport { Field } from \"angular-extensions/models\";\r\n\r\n@Component({\r\n  selector: \"date-control\",\r\n  templateUrl: \"./date-control.component.html\",\r\n  styleUrls: [\"./date-control.component.scss\"]\r\n})\r\nexport class DateControlComponent implements OnChanges {\r\n\r\n  @Input()\r\n  public field: Field<Date>;\r\n\r\n  @Input()\r\n  public fieldClass: string;\r\n\r\n  @Input()\r\n  public appearance: MatFormFieldAppearance = \"outline\";\r\n\r\n  @Input()\r\n  public targetView: \"month\" | \"day\" = \"day\";\r\n\r\n  @Input()\r\n  public startView: MatCalendarView = \"month\";\r\n\r\n  @Input()\r\n  public format: string;\r\n\r\n  @Input()\r\n  public clearable: boolean;\r\n\r\n  constructor(\r\n    elementRef: ElementRef<HTMLElement>,\r\n    @Inject(MAT_DATE_FORMATS) private dateFormats: MatDateFormats,\r\n  ) {\r\n    this.format = dateFormats.display.dateInput;\r\n\r\n    elementRef\r\n      .nativeElement\r\n      .addEventListener(\"blur\", event => event.stopPropagation(), { capture: true });\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges<DateControlComponent>) {\r\n    if (changes.targetView) {\r\n      if (changes.targetView.currentValue == \"month\") {\r\n        this.startView = \"year\";\r\n        this.format = this.dateFormats.display.monthYearA11yLabel;\r\n      }\r\n      else if (changes.targetView.currentValue == \"day\") {\r\n        this.startView = \"month\";\r\n        this.format = this.dateFormats.display.dateInput;\r\n      }\r\n    }\r\n  }\r\n\r\n  public monthSelected(month: Date, datePicker: MatDatepicker<Date>) {\r\n    if (this.targetView == \"month\") {\r\n      this.field.value = month.asUtcDate();\r\n\r\n      datePicker.close();\r\n\r\n      // hide content since we cannot prevent currentView showing month view\r\n      this.getCalendarElement(datePicker).style.display = \"none\";\r\n    }\r\n  }\r\n\r\n  public viewChanged(view: MatCalendarView, datePicker: MatDatepicker<Date>) {\r\n    // fix issue when clicking on year selector it shows \"month\" view which is not correct\r\n    if (this.targetView == \"month\" && view == \"month\") {\r\n      this.getCalendar(datePicker).currentView = \"multi-year\";\r\n    }\r\n  }\r\n\r\n  public onToggle(event: MouseEvent) {\r\n    if (this.clearable && this.field.value != null) {\r\n      this.field.value = null as any;\r\n\r\n      event.preventDefault();\r\n      event.stopImmediatePropagation();\r\n    }\r\n\r\n    (document.activeElement as HTMLElement).blur();\r\n  }\r\n\r\n  private getCalendar(datePicker: MatDatepicker<Date>) {\r\n    return ((datePicker as any)._popupComponentRef as ComponentRef<MatDatepickerContent<Date>>)\r\n      .instance\r\n      ._calendar;\r\n  }\r\n\r\n  private getCalendarElement(datePicker: MatDatepicker<Date>) {\r\n    return ((datePicker as any)._popupComponentRef as ComponentRef<MatDatepickerContent<Date>>)\r\n      .instance\r\n      ._elementRef\r\n      .nativeElement as HTMLElement;\r\n  }\r\n}\r\n","<base-control #baseControl\r\n              [field]=\"field\">\r\n  <mat-form-field class=\"cursor-pointer\"\r\n                  [appearance]=\"appearance\"\r\n                  [class]=\"fieldClass\"\r\n                  (click)=\"datePicker.open(); $event.preventDefault();\">\r\n    <mat-label>\r\n      {{ field.label }}\r\n    </mat-label>\r\n\r\n    <mat-hint>\r\n      {{ field.info }}\r\n    </mat-hint>\r\n\r\n    <input matInput\r\n           #input\r\n           readonly\r\n           [format]=\"format\"\r\n           [formControl]=\"field.control\"\r\n           [matDatepicker]=\"datePicker\">\r\n\r\n    <mat-datepicker-toggle matSuffix\r\n                           [for]=\"datePicker\">\r\n      <mat-icon matDatepickerToggleIcon\r\n                [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n                (click)=\"onToggle($event)\">\r\n        {{ clearable && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n    </mat-datepicker-toggle>\r\n\r\n    <mat-datepicker #datePicker\r\n                    [startView]=\"startView\"\r\n                    (viewChanged)=\"viewChanged($event, datePicker)\"\r\n                    (monthSelected)=\"monthSelected($event, datePicker)\"\r\n                    (closed)=\"field.control.markAllAsTouched()\"></mat-datepicker>\r\n\r\n    <mat-error *ngIf=\"baseControl.initialized\">\r\n      <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n    </mat-error>\r\n  </mat-form-field>\r\n</base-control>\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-control.component.js","sourceRoot":"","sources":["../../../../../projects/angular-extensions/controls/date-control/date-control.component.ts","../../../../../projects/angular-extensions/controls/date-control/date-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentRef, ElementRef, Inject, Input, OnChanges } from \"@angular/core\";\r\nimport { MatFormFieldAppearance } from \"@angular/material/form-field\";\r\nimport { MatCalendarView, MatDatepicker, MatDatepickerContent } from \"@angular/material/datepicker\";\r\nimport { MatDateFormats, MAT_DATE_FORMATS } from \"@angular/material/core\";\r\n\r\nimport { SimpleChanges } from \"angular-extensions/core\";\r\nimport { Field } from \"angular-extensions/models\";\r\n\r\n@Component({\r\n  selector: \"date-control\",\r\n  templateUrl: \"./date-control.component.html\",\r\n  styleUrls: [\"./date-control.component.scss\"]\r\n})\r\nexport class DateControlComponent implements OnChanges {\r\n\r\n  @Input()\r\n  public field: Field<Date>;\r\n\r\n  @Input()\r\n  public fieldClass: string;\r\n\r\n  @Input()\r\n  public appearance: MatFormFieldAppearance = \"outline\";\r\n\r\n  @Input()\r\n  public targetView: \"month\" | \"day\" = \"day\";\r\n\r\n  @Input()\r\n  public startView: MatCalendarView = \"month\";\r\n\r\n  @Input()\r\n  public format: string;\r\n\r\n  @Input()\r\n  public clearable: boolean;\r\n\r\n  constructor(\r\n    elementRef: ElementRef<HTMLElement>,\r\n    @Inject(MAT_DATE_FORMATS) private dateFormats: MatDateFormats,\r\n  ) {\r\n    this.format = dateFormats.display.dateInput;\r\n\r\n    elementRef\r\n      .nativeElement\r\n      .addEventListener(\"blur\", event => event.stopPropagation(), { capture: true });\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges<DateControlComponent>) {\r\n    if (changes.targetView) {\r\n      if (changes.targetView.currentValue == \"month\") {\r\n        this.startView = \"year\";\r\n        this.format = this.dateFormats.display.monthYearA11yLabel;\r\n      }\r\n      else if (changes.targetView.currentValue == \"day\") {\r\n        this.startView = \"month\";\r\n        this.format = this.dateFormats.display.dateInput;\r\n      }\r\n    }\r\n  }\r\n\r\n  public monthSelected(month: Date, datePicker: MatDatepicker<Date>) {\r\n    if (this.targetView == \"month\") {\r\n      this.field.value = month.asUtcDate();\r\n\r\n      datePicker.close();\r\n\r\n      // hide content since we cannot prevent currentView showing month view\r\n      this.getCalendarElement(datePicker).style.display = \"none\";\r\n    }\r\n  }\r\n\r\n  public viewChanged(view: MatCalendarView, datePicker: MatDatepicker<Date>) {\r\n    // fix issue when clicking on year selector it shows \"month\" view which is not correct\r\n    if (this.targetView == \"month\" && view == \"month\") {\r\n      this.getCalendar(datePicker).currentView = \"multi-year\";\r\n    }\r\n  }\r\n\r\n  public onToggle(event: MouseEvent) {\r\n    if (this.clearable && this.field.value != null) {\r\n      this.field.value = null as any;\r\n\r\n      event.preventDefault();\r\n      event.stopImmediatePropagation();\r\n    }\r\n\r\n    (document.activeElement as HTMLElement).blur();\r\n  }\r\n\r\n  private getCalendar(datePicker: MatDatepicker<Date>) {\r\n    return ((datePicker as any)._popupComponentRef as ComponentRef<MatDatepickerContent<Date>>)\r\n      .instance\r\n      ._calendar;\r\n  }\r\n\r\n  private getCalendarElement(datePicker: MatDatepicker<Date>) {\r\n    return ((datePicker as any)._popupComponentRef as ComponentRef<MatDatepickerContent<Date>>)\r\n      .instance\r\n      ._elementRef\r\n      .nativeElement as HTMLElement;\r\n  }\r\n}\r\n","<base-control #baseControl\r\n              [field]=\"field\">\r\n  <mat-form-field class=\"cursor-pointer\"\r\n                  [appearance]=\"appearance\"\r\n                  [class]=\"fieldClass\"\r\n                  (click)=\"datePicker.open(); $event.preventDefault();\">\r\n    <mat-label>\r\n      {{ field.label }}\r\n    </mat-label>\r\n\r\n    <mat-hint>\r\n      <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n    </mat-hint>\r\n\r\n    <input matInput\r\n           #input\r\n           readonly\r\n           [format]=\"format\"\r\n           [formControl]=\"field.control\"\r\n           [matDatepicker]=\"datePicker\">\r\n\r\n    <mat-datepicker-toggle matSuffix\r\n                           [for]=\"datePicker\">\r\n      <mat-icon matDatepickerToggleIcon\r\n                [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n                (click)=\"onToggle($event)\">\r\n        {{ clearable && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n    </mat-datepicker-toggle>\r\n\r\n    <mat-datepicker #datePicker\r\n                    [startView]=\"startView\"\r\n                    (viewChanged)=\"viewChanged($event, datePicker)\"\r\n                    (monthSelected)=\"monthSelected($event, datePicker)\"\r\n                    (closed)=\"field.control.markAllAsTouched()\"></mat-datepicker>\r\n\r\n    <mat-error *ngIf=\"baseControl.initialized\">\r\n      <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n    </mat-error>\r\n  </mat-form-field>\r\n</base-control>\r\n"]}

@@ -9,7 +9,7 @@ import { Component, Inject, Input, ViewEncapsulation } from "@angular/core";

import * as i5 from "@angular-material-components/datetime-picker";
import * as i6 from "@angular/material/input";
import * as i7 from "angular-extensions/directives";
import * as i8 from "@angular/forms";
import * as i9 from "@angular/material/tooltip";
import * as i10 from "@angular/common";
import * as i6 from "@angular/common";
import * as i7 from "@angular/material/input";
import * as i8 from "angular-extensions/directives";
import * as i9 from "@angular/forms";
import * as i10 from "@angular/material/tooltip";
export class DateTimeControlComponent {

@@ -36,3 +36,3 @@ constructor(elementRef, dateFormats) {

DateTimeControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: DateTimeControlComponent, deps: [{ token: i0.ElementRef }, { token: MAT_DATE_FORMATS }], target: i0.ɵɵFactoryTarget.Component });
DateTimeControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: DateTimeControlComponent, selector: "datetime-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", initialTime: "initialTime", clearable: "clearable", disableMinute: "disableMinute", showSeconds: "showSeconds", format: "format" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"dateTimePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"format\"\r\n [formControl]=\"field.control\"\r\n [ngxMatDatetimePicker]=\"dateTimePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"$any(dateTimePicker)\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.control.enabled && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.control.enabled && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #dateTimePicker\r\n [color]=\"'primary'\"\r\n [stepMinute]=\"15\"\r\n [disableMinute]=\"disableMinute\"\r\n [defaultTime]=\"initialTime\"\r\n [showSeconds]=\"showSeconds\"\r\n (closed)=\"field.control.markAllAsTouched()\">\r\n </ngx-mat-datetime-picker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: ["datetime-control{display:inline-block}datetime-control .mat-form-field-flex,datetime-control .mat-form-field-flex input{cursor:pointer}ngx-mat-calendar{height:354px}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["startView", "startAt", "defaultColor", "color", "touchUi", "hideTime", "disabled", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime", "calendarHeaderComponent", "panelClass", "dateClass"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i7.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["value", "ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i7.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i7.DateTimePickerDirective, selector: "ngx-mat-datetime-picker" }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], encapsulation: i0.ViewEncapsulation.None });
DateTimeControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: DateTimeControlComponent, selector: "datetime-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", initialTime: "initialTime", clearable: "clearable", disableMinute: "disableMinute", showSeconds: "showSeconds", format: "format" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"dateTimePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"format\"\r\n [formControl]=\"field.control\"\r\n [ngxMatDatetimePicker]=\"dateTimePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"$any(dateTimePicker)\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.control.enabled && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.control.enabled && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #dateTimePicker\r\n [color]=\"'primary'\"\r\n [stepMinute]=\"15\"\r\n [disableMinute]=\"disableMinute\"\r\n [defaultTime]=\"initialTime\"\r\n [showSeconds]=\"showSeconds\"\r\n (closed)=\"field.control.markAllAsTouched()\">\r\n </ngx-mat-datetime-picker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: ["datetime-control{display:inline-block}datetime-control .mat-form-field-flex,datetime-control .mat-form-field-flex input{cursor:pointer}ngx-mat-calendar{height:354px}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["startView", "startAt", "defaultColor", "color", "touchUi", "hideTime", "disabled", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime", "calendarHeaderComponent", "panelClass", "dateClass"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i8.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["value", "ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i8.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i8.DateTimePickerDirective, selector: "ngx-mat-datetime-picker" }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: DateTimeControlComponent, decorators: [{

@@ -66,2 +66,2 @@ type: Component,

}] } });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXRpbWUtY29udHJvbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWV4dGVuc2lvbnMvY29udHJvbHMvZGF0ZXRpbWUtY29udHJvbC9kYXRldGltZS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9kYXRldGltZS1jb250cm9sL2RhdGV0aW1lLWNvbnRyb2wuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxNQUFNLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hGLE9BQU8sRUFBa0IsZ0JBQWdCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7Ozs7Ozs7Ozs7O0FBVzFFLE1BQU0sT0FBTyx3QkFBd0I7SUEwQm5DLFlBQ0UsVUFBbUMsRUFDVCxXQUEyQjtRQW5CaEQsZUFBVSxHQUEyQixTQUFTLENBQUM7UUFTL0Msa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFHdEIsZ0JBQVcsR0FBRyxJQUFJLENBQUM7UUFTeEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsU0FBUyxXQUFXLENBQUM7UUFFMUQsVUFBVTthQUNQLGFBQWE7YUFDYixnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsZUFBZSxFQUFFLEVBQUUsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNuRixDQUFDO0lBRU0sUUFBUSxDQUFDLEtBQWlCO1FBQy9CLElBQUksSUFBSSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksSUFBSSxFQUFFO1lBQzVFLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLElBQVcsQ0FBQztZQUUvQixJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUVuQyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDdkIsS0FBSyxDQUFDLHdCQUF3QixFQUFFLENBQUM7U0FDbEM7UUFFQSxRQUFRLENBQUMsYUFBNkIsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNqRCxDQUFDOztxSEFoRFUsd0JBQXdCLDRDQTRCekIsZ0JBQWdCO3lHQTVCZix3QkFBd0IsMFFDWnJDLGlxREEwQ0E7MkZEOUJhLHdCQUF3QjtrQkFOcEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixXQUFXLEVBQUUsbUNBQW1DO29CQUNoRCxTQUFTLEVBQUUsQ0FBQyxtQ0FBbUMsQ0FBQztvQkFDaEQsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7aUJBQ3RDOzswQkE2QkksTUFBTTsyQkFBQyxnQkFBZ0I7NENBekJuQixLQUFLO3NCQURYLEtBQUs7Z0JBSUMsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxVQUFVO3NCQURoQixLQUFLO2dCQUlDLFdBQVc7c0JBRGpCLEtBQUs7Z0JBSUMsU0FBUztzQkFEZixLQUFLO2dCQUlDLGFBQWE7c0JBRG5CLEtBQUs7Z0JBSUMsV0FBVztzQkFEakIsS0FBSztnQkFJQyxNQUFNO3NCQURaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEluamVjdCwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTWF0RGF0ZUZvcm1hdHMsIE1BVF9EQVRFX0ZPUk1BVFMgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZVwiO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRBcHBlYXJhbmNlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGRcIjtcclxuXHJcbmltcG9ydCB7IEZpZWxkIH0gZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9tb2RlbHNcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImRhdGV0aW1lLWNvbnRyb2xcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL2RhdGV0aW1lLWNvbnRyb2wuY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vZGF0ZXRpbWUtY29udHJvbC5jb21wb25lbnQuc2Nzc1wiXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZVRpbWVDb250cm9sQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZmllbGQ6IEZpZWxkPERhdGU+O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZENsYXNzOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGFwcGVhcmFuY2U6IE1hdEZvcm1GaWVsZEFwcGVhcmFuY2UgPSBcIm91dGxpbmVcIjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgaW5pdGlhbFRpbWU6IG51bWJlcltdO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjbGVhcmFibGU6IGJvb2xlYW47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGRpc2FibGVNaW51dGUgPSBmYWxzZTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2hvd1NlY29uZHMgPSB0cnVlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmb3JtYXQ6IHN0cmluZztcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcclxuICAgIEBJbmplY3QoTUFUX0RBVEVfRk9STUFUUykgZGF0ZUZvcm1hdHM6IE1hdERhdGVGb3JtYXRzLFxyXG4gICkge1xyXG4gICAgdGhpcy5mb3JtYXQgPSBgJHtkYXRlRm9ybWF0cy5kaXNwbGF5LmRhdGVJbnB1dH0gSEg6bW06c3NgO1xyXG5cclxuICAgIGVsZW1lbnRSZWZcclxuICAgICAgLm5hdGl2ZUVsZW1lbnRcclxuICAgICAgLmFkZEV2ZW50TGlzdGVuZXIoXCJibHVyXCIsIGV2ZW50ID0+IGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpLCB7IGNhcHR1cmU6IHRydWUgfSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25Ub2dnbGUoZXZlbnQ6IE1vdXNlRXZlbnQpIHtcclxuICAgIGlmICh0aGlzLmNsZWFyYWJsZSAmJiB0aGlzLmZpZWxkLmNvbnRyb2wuZW5hYmxlZCAmJiB0aGlzLmZpZWxkLnZhbHVlICE9IG51bGwpIHtcclxuICAgICAgdGhpcy5maWVsZC52YWx1ZSA9IG51bGwgYXMgYW55O1xyXG5cclxuICAgICAgdGhpcy5maWVsZC5jb250cm9sLm1hcmtBc1RvdWNoZWQoKTtcclxuXHJcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICAgIGV2ZW50LnN0b3BJbW1lZGlhdGVQcm9wYWdhdGlvbigpO1xyXG4gICAgfVxyXG5cclxuICAgIChkb2N1bWVudC5hY3RpdmVFbGVtZW50IGFzIEhUTUxFbGVtZW50KS5ibHVyKCk7XHJcbiAgfVxyXG59XHJcbiIsIjxiYXNlLWNvbnRyb2wgI2Jhc2VDb250cm9sXHJcbiAgICAgICAgICAgICAgW2ZpZWxkXT1cImZpZWxkXCI+XHJcbiAgPG1hdC1mb3JtLWZpZWxkIFthcHBlYXJhbmNlXT1cImFwcGVhcmFuY2VcIlxyXG4gICAgICAgICAgICAgICAgICBbY2xhc3NdPVwiZmllbGRDbGFzc1wiXHJcbiAgICAgICAgICAgICAgICAgIChjbGljayk9XCJkYXRlVGltZVBpY2tlci5vcGVuKCk7ICRldmVudC5wcmV2ZW50RGVmYXVsdCgpO1wiPlxyXG4gICAgPG1hdC1sYWJlbD5cclxuICAgICAge3sgZmllbGQubGFiZWwgfX1cclxuICAgIDwvbWF0LWxhYmVsPlxyXG5cclxuICAgIDxtYXQtaGludD5cclxuICAgICAge3sgZmllbGQuaW5mbyB9fVxyXG4gICAgPC9tYXQtaGludD5cclxuXHJcbiAgICA8aW5wdXQgbWF0SW5wdXRcclxuICAgICAgICAgICAjaW5wdXRcclxuICAgICAgICAgICByZWFkb25seVxyXG4gICAgICAgICAgIFtmb3JtYXRdPVwiZm9ybWF0XCJcclxuICAgICAgICAgICBbZm9ybUNvbnRyb2xdPVwiZmllbGQuY29udHJvbFwiXHJcbiAgICAgICAgICAgW25neE1hdERhdGV0aW1lUGlja2VyXT1cImRhdGVUaW1lUGlja2VyXCI+XHJcblxyXG4gICAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBtYXRTdWZmaXhcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgW2Zvcl09XCIkYW55KGRhdGVUaW1lUGlja2VyKVwiPlxyXG4gICAgICA8bWF0LWljb24gbWF0RGF0ZXBpY2tlclRvZ2dsZUljb25cclxuICAgICAgICAgICAgICAgIFttYXRUb29sdGlwXT1cImNsZWFyYWJsZSAmJiBmaWVsZC5jb250cm9sLmVuYWJsZWQgJiYgZmllbGQudmFsdWUgIT0gbnVsbCA/ICdDbGVhcicgOiAnJ1wiXHJcbiAgICAgICAgICAgICAgICAoY2xpY2spPVwib25Ub2dnbGUoJGV2ZW50KVwiPlxyXG4gICAgICAgIHt7IGNsZWFyYWJsZSAmJiBmaWVsZC5jb250cm9sLmVuYWJsZWQgJiYgZmllbGQudmFsdWUgIT0gbnVsbCA/ICdjbG9zZScgOiAndG9kYXknIH19PC9tYXQtaWNvbj5cclxuICAgIDwvbWF0LWRhdGVwaWNrZXItdG9nZ2xlPlxyXG5cclxuICAgIDxuZ3gtbWF0LWRhdGV0aW1lLXBpY2tlciAjZGF0ZVRpbWVQaWNrZXJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbY29sb3JdPVwiJ3ByaW1hcnknXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc3RlcE1pbnV0ZV09XCIxNVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2Rpc2FibGVNaW51dGVdPVwiZGlzYWJsZU1pbnV0ZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2RlZmF1bHRUaW1lXT1cImluaXRpYWxUaW1lXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc2hvd1NlY29uZHNdPVwic2hvd1NlY29uZHNcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgIChjbG9zZWQpPVwiZmllbGQuY29udHJvbC5tYXJrQWxsQXNUb3VjaGVkKClcIj5cclxuICAgIDwvbmd4LW1hdC1kYXRldGltZS1waWNrZXI+XHJcblxyXG4gICAgPG1hdC1lcnJvciAqbmdJZj1cImJhc2VDb250cm9sLmluaXRpYWxpemVkXCI+XHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJiYXNlQ29udHJvbC5lcnJvcnNUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9tYXQtZXJyb3I+XHJcbiAgPC9tYXQtZm9ybS1maWVsZD5cclxuPC9iYXNlLWNvbnRyb2w+XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXRpbWUtY29udHJvbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWV4dGVuc2lvbnMvY29udHJvbHMvZGF0ZXRpbWUtY29udHJvbC9kYXRldGltZS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy9kYXRldGltZS1jb250cm9sL2RhdGV0aW1lLWNvbnRyb2wuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxNQUFNLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hGLE9BQU8sRUFBa0IsZ0JBQWdCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7Ozs7Ozs7Ozs7O0FBVzFFLE1BQU0sT0FBTyx3QkFBd0I7SUEwQm5DLFlBQ0UsVUFBbUMsRUFDVCxXQUEyQjtRQW5CaEQsZUFBVSxHQUEyQixTQUFTLENBQUM7UUFTL0Msa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFHdEIsZ0JBQVcsR0FBRyxJQUFJLENBQUM7UUFTeEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQUMsU0FBUyxXQUFXLENBQUM7UUFFMUQsVUFBVTthQUNQLGFBQWE7YUFDYixnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsZUFBZSxFQUFFLEVBQUUsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNuRixDQUFDO0lBRU0sUUFBUSxDQUFDLEtBQWlCO1FBQy9CLElBQUksSUFBSSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksSUFBSSxFQUFFO1lBQzVFLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLElBQVcsQ0FBQztZQUUvQixJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUVuQyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDdkIsS0FBSyxDQUFDLHdCQUF3QixFQUFFLENBQUM7U0FDbEM7UUFFQSxRQUFRLENBQUMsYUFBNkIsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNqRCxDQUFDOztxSEFoRFUsd0JBQXdCLDRDQTRCekIsZ0JBQWdCO3lHQTVCZix3QkFBd0IsMFFDWnJDLDZ0REEwQ0E7MkZEOUJhLHdCQUF3QjtrQkFOcEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixXQUFXLEVBQUUsbUNBQW1DO29CQUNoRCxTQUFTLEVBQUUsQ0FBQyxtQ0FBbUMsQ0FBQztvQkFDaEQsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7aUJBQ3RDOzswQkE2QkksTUFBTTsyQkFBQyxnQkFBZ0I7NENBekJuQixLQUFLO3NCQURYLEtBQUs7Z0JBSUMsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxVQUFVO3NCQURoQixLQUFLO2dCQUlDLFdBQVc7c0JBRGpCLEtBQUs7Z0JBSUMsU0FBUztzQkFEZixLQUFLO2dCQUlDLGFBQWE7c0JBRG5CLEtBQUs7Z0JBSUMsV0FBVztzQkFEakIsS0FBSztnQkFJQyxNQUFNO3NCQURaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEluamVjdCwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTWF0RGF0ZUZvcm1hdHMsIE1BVF9EQVRFX0ZPUk1BVFMgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZVwiO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRBcHBlYXJhbmNlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGRcIjtcclxuXHJcbmltcG9ydCB7IEZpZWxkIH0gZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9tb2RlbHNcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcImRhdGV0aW1lLWNvbnRyb2xcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL2RhdGV0aW1lLWNvbnRyb2wuY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vZGF0ZXRpbWUtY29udHJvbC5jb21wb25lbnQuc2Nzc1wiXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZVRpbWVDb250cm9sQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZmllbGQ6IEZpZWxkPERhdGU+O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZENsYXNzOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGFwcGVhcmFuY2U6IE1hdEZvcm1GaWVsZEFwcGVhcmFuY2UgPSBcIm91dGxpbmVcIjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgaW5pdGlhbFRpbWU6IG51bWJlcltdO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjbGVhcmFibGU6IGJvb2xlYW47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGRpc2FibGVNaW51dGUgPSBmYWxzZTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2hvd1NlY29uZHMgPSB0cnVlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmb3JtYXQ6IHN0cmluZztcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcclxuICAgIEBJbmplY3QoTUFUX0RBVEVfRk9STUFUUykgZGF0ZUZvcm1hdHM6IE1hdERhdGVGb3JtYXRzLFxyXG4gICkge1xyXG4gICAgdGhpcy5mb3JtYXQgPSBgJHtkYXRlRm9ybWF0cy5kaXNwbGF5LmRhdGVJbnB1dH0gSEg6bW06c3NgO1xyXG5cclxuICAgIGVsZW1lbnRSZWZcclxuICAgICAgLm5hdGl2ZUVsZW1lbnRcclxuICAgICAgLmFkZEV2ZW50TGlzdGVuZXIoXCJibHVyXCIsIGV2ZW50ID0+IGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpLCB7IGNhcHR1cmU6IHRydWUgfSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25Ub2dnbGUoZXZlbnQ6IE1vdXNlRXZlbnQpIHtcclxuICAgIGlmICh0aGlzLmNsZWFyYWJsZSAmJiB0aGlzLmZpZWxkLmNvbnRyb2wuZW5hYmxlZCAmJiB0aGlzLmZpZWxkLnZhbHVlICE9IG51bGwpIHtcclxuICAgICAgdGhpcy5maWVsZC52YWx1ZSA9IG51bGwgYXMgYW55O1xyXG5cclxuICAgICAgdGhpcy5maWVsZC5jb250cm9sLm1hcmtBc1RvdWNoZWQoKTtcclxuXHJcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICAgIGV2ZW50LnN0b3BJbW1lZGlhdGVQcm9wYWdhdGlvbigpO1xyXG4gICAgfVxyXG5cclxuICAgIChkb2N1bWVudC5hY3RpdmVFbGVtZW50IGFzIEhUTUxFbGVtZW50KS5ibHVyKCk7XHJcbiAgfVxyXG59XHJcbiIsIjxiYXNlLWNvbnRyb2wgI2Jhc2VDb250cm9sXHJcbiAgICAgICAgICAgICAgW2ZpZWxkXT1cImZpZWxkXCI+XHJcbiAgPG1hdC1mb3JtLWZpZWxkIFthcHBlYXJhbmNlXT1cImFwcGVhcmFuY2VcIlxyXG4gICAgICAgICAgICAgICAgICBbY2xhc3NdPVwiZmllbGRDbGFzc1wiXHJcbiAgICAgICAgICAgICAgICAgIChjbGljayk9XCJkYXRlVGltZVBpY2tlci5vcGVuKCk7ICRldmVudC5wcmV2ZW50RGVmYXVsdCgpO1wiPlxyXG4gICAgPG1hdC1sYWJlbD5cclxuICAgICAge3sgZmllbGQubGFiZWwgfX1cclxuICAgIDwvbWF0LWxhYmVsPlxyXG5cclxuICAgIDxtYXQtaGludD5cclxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImJhc2VDb250cm9sLmhpbnRUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9tYXQtaGludD5cclxuXHJcbiAgICA8aW5wdXQgbWF0SW5wdXRcclxuICAgICAgICAgICAjaW5wdXRcclxuICAgICAgICAgICByZWFkb25seVxyXG4gICAgICAgICAgIFtmb3JtYXRdPVwiZm9ybWF0XCJcclxuICAgICAgICAgICBbZm9ybUNvbnRyb2xdPVwiZmllbGQuY29udHJvbFwiXHJcbiAgICAgICAgICAgW25neE1hdERhdGV0aW1lUGlja2VyXT1cImRhdGVUaW1lUGlja2VyXCI+XHJcblxyXG4gICAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBtYXRTdWZmaXhcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgW2Zvcl09XCIkYW55KGRhdGVUaW1lUGlja2VyKVwiPlxyXG4gICAgICA8bWF0LWljb24gbWF0RGF0ZXBpY2tlclRvZ2dsZUljb25cclxuICAgICAgICAgICAgICAgIFttYXRUb29sdGlwXT1cImNsZWFyYWJsZSAmJiBmaWVsZC5jb250cm9sLmVuYWJsZWQgJiYgZmllbGQudmFsdWUgIT0gbnVsbCA/ICdDbGVhcicgOiAnJ1wiXHJcbiAgICAgICAgICAgICAgICAoY2xpY2spPVwib25Ub2dnbGUoJGV2ZW50KVwiPlxyXG4gICAgICAgIHt7IGNsZWFyYWJsZSAmJiBmaWVsZC5jb250cm9sLmVuYWJsZWQgJiYgZmllbGQudmFsdWUgIT0gbnVsbCA/ICdjbG9zZScgOiAndG9kYXknIH19PC9tYXQtaWNvbj5cclxuICAgIDwvbWF0LWRhdGVwaWNrZXItdG9nZ2xlPlxyXG5cclxuICAgIDxuZ3gtbWF0LWRhdGV0aW1lLXBpY2tlciAjZGF0ZVRpbWVQaWNrZXJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbY29sb3JdPVwiJ3ByaW1hcnknXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc3RlcE1pbnV0ZV09XCIxNVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2Rpc2FibGVNaW51dGVdPVwiZGlzYWJsZU1pbnV0ZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2RlZmF1bHRUaW1lXT1cImluaXRpYWxUaW1lXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc2hvd1NlY29uZHNdPVwic2hvd1NlY29uZHNcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgIChjbG9zZWQpPVwiZmllbGQuY29udHJvbC5tYXJrQWxsQXNUb3VjaGVkKClcIj5cclxuICAgIDwvbmd4LW1hdC1kYXRldGltZS1waWNrZXI+XHJcblxyXG4gICAgPG1hdC1lcnJvciAqbmdJZj1cImJhc2VDb250cm9sLmluaXRpYWxpemVkXCI+XHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJiYXNlQ29udHJvbC5lcnJvcnNUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9tYXQtZXJyb3I+XHJcbiAgPC9tYXQtZm9ybS1maWVsZD5cclxuPC9iYXNlLWNvbnRyb2w+XHJcbiJdfQ==

@@ -160,3 +160,3 @@ import { of, Subject } from "rxjs";

SelectControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: SelectControlComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.MatMenuTrigger, optional: true }], target: i0.ɵɵFactoryTarget.Component });
SelectControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: SelectControlComponent, selector: "select-control", inputs: { field: "field", fieldClass: "fieldClass", dropdownClass: "dropdownClass", appearance: "appearance", multiple: "multiple", searchable: "searchable", clearable: "clearable", showSelectAll: "showSelectAll", tooltipDisabled: "tooltipDisabled", filter: "filter" }, queries: [{ propertyName: "optionTemplate", first: true, predicate: ["optionTemplate"], descendants: true, static: true }, { propertyName: "triggerTemplate", first: true, predicate: ["triggerTemplate"], descendants: true, static: true }], viewQueries: [{ propertyName: "select", first: true, predicate: ["select"], descendants: true, static: true }, { propertyName: "selectAllOption", first: true, predicate: ["selectAllOption"], descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <mat-select #select\r\n [panelClass]=\"'custom-scroll ' + dropdownClass\"\r\n [ngClass]=\"{ loading: field.isQuerying }\"\r\n [matTooltipDisabled]=\"tooltipDisabled\"\r\n [matTooltip]=\"select.triggerValue\"\r\n [formControl]=\"field.control\"\r\n [disableOptionCentering]=\"searchable\"\r\n [compareWith]=\"optionComparer\"\r\n [multiple]=\"multiple\">\r\n\r\n <mat-select-trigger *ngIf=\"triggerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"triggerTemplate; context: { $implicit: select.triggerValue, label: triggerLabel, option: selectedOption }\"></ng-container>\r\n </mat-select-trigger>\r\n\r\n <mat-option *ngIf=\"searchable\">\r\n <ngx-mat-select-search placeholderLabel=\"Search\"\r\n [noEntriesFoundLabel]=\"$any(null)\"\r\n [formControl]=\"filterControl\"\r\n [searching]=\"field.isQuerying\"></ngx-mat-select-search>\r\n </mat-option>\r\n\r\n <mat-option #selectAllOption\r\n *ngIf=\"multiple && showSelectAll && !filterControl.value\">\r\n All\r\n </mat-option>\r\n\r\n <ng-container *ngIf=\"field.options | filter : field.optionsFilterPredicate : filterControl.value as options\">\r\n <ng-container *ngIf=\"options.length; else noItemsTemplate\">\r\n <ng-container *ngIf=\"field.optionsGroupProvider\">\r\n <mat-optgroup *ngFor=\"let group of options | groupBy : field.optionsGroupProvider\"\r\n [label]=\"group.key | map : field.optionGroupLabel\">\r\n <mat-option *ngFor=\"let option of group.items; trackBy : optionTracker\"\r\n [matTooltip]=\"option | map : field.optionLabel\"\r\n [context]=\"option\"\r\n [value]=\"option | map : field.optionValue\"\r\n [disabled]=\"option | map : field.optionDisabled\">\r\n <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n </mat-option>\r\n </mat-optgroup>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!field.optionsGroupProvider\">\r\n <mat-option *ngFor=\"let option of options; trackBy : optionTracker\"\r\n [matTooltip]=\"option | map : field.optionLabel\"\r\n [context]=\"option\"\r\n [value]=\"option | map : field.optionValue\"\r\n [disabled]=\"option | map : field.optionDisabled\">\r\n <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n </mat-option>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </mat-select>\r\n\r\n <span matSuffix\r\n *ngIf=\"field.isQuerying\">\r\n <spinner [loading]=\"field.isQuerying\"\r\n [size]=\"20\"></spinner>\r\n </span>\r\n\r\n <button *ngIf=\"!multiple && clearable && field.value != null && !field.isQuerying\"\r\n mat-button\r\n matSuffix\r\n mat-icon-button\r\n matTooltip=\"Clear\"\r\n (click)=\"$any(field).value = null; $event.stopPropagation()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n\r\n<ng-template #noItemsTemplate>\r\n <mat-option *ngIf=\"field.isQuerying\"\r\n [disabled]=\"true\">Loading...</mat-option>\r\n\r\n <mat-option *ngIf=\"!field.isQuerying && !filterControl.value && searchable\"\r\n [disabled]=\"true\">Type to search items</mat-option>\r\n\r\n <mat-option *ngIf=\"!field.isQuerying && filterControl.value\"\r\n [disabled]=\"true\">No items found</mat-option>\r\n</ng-template>\r\n\r\n<ng-template #defaultOptionTempalte\r\n let-label\r\n let-option=\"option\">\r\n {{ label }}\r\n</ng-template>\r\n", styles: [":host{display:inline-block}:host ::ng-deep mat-select.loading .mat-select-arrow{color:transparent!important}\n"], components: [{ type: i2.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i4.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i6.MatSelectSearchComponent, selector: "ngx-mat-select-search", inputs: ["placeholderLabel", "type", "noEntriesFoundLabel", "indexAndLengthScreenReaderText", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toogleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { type: i5.MatOptgroup, selector: "mat-optgroup", inputs: ["disabled"], exportAs: ["matOptgroup"] }, { type: i7.SpinnerComponent, selector: "spinner", inputs: ["type", "loading", "size"] }, { type: i8.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i3.MatLabel, selector: "mat-label" }, { type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i10.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i11.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i12.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i13.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i13.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i14.OptionContextDirective, selector: "mat-option[context]", inputs: ["context"] }, { type: i3.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "filter": i15.FilterPipe, "map": i15.MapPipe, "groupBy": i15.GroupByPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
SelectControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: SelectControlComponent, selector: "select-control", inputs: { field: "field", fieldClass: "fieldClass", dropdownClass: "dropdownClass", appearance: "appearance", multiple: "multiple", searchable: "searchable", clearable: "clearable", showSelectAll: "showSelectAll", tooltipDisabled: "tooltipDisabled", filter: "filter" }, queries: [{ propertyName: "optionTemplate", first: true, predicate: ["optionTemplate"], descendants: true, static: true }, { propertyName: "triggerTemplate", first: true, predicate: ["triggerTemplate"], descendants: true, static: true }], viewQueries: [{ propertyName: "select", first: true, predicate: ["select"], descendants: true, static: true }, { propertyName: "selectAllOption", first: true, predicate: ["selectAllOption"], descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <mat-select #select\r\n [panelClass]=\"'custom-scroll ' + dropdownClass\"\r\n [ngClass]=\"{ loading: field.isQuerying }\"\r\n [matTooltipDisabled]=\"tooltipDisabled\"\r\n [matTooltip]=\"select.triggerValue\"\r\n [formControl]=\"field.control\"\r\n [disableOptionCentering]=\"searchable\"\r\n [compareWith]=\"optionComparer\"\r\n [multiple]=\"multiple\">\r\n\r\n <mat-select-trigger *ngIf=\"triggerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"triggerTemplate; context: { $implicit: select.triggerValue, label: triggerLabel, option: selectedOption }\"></ng-container>\r\n </mat-select-trigger>\r\n\r\n <mat-option *ngIf=\"searchable\">\r\n <ngx-mat-select-search placeholderLabel=\"Search\"\r\n [noEntriesFoundLabel]=\"$any(null)\"\r\n [formControl]=\"filterControl\"\r\n [searching]=\"field.isQuerying\"></ngx-mat-select-search>\r\n </mat-option>\r\n\r\n <mat-option #selectAllOption\r\n *ngIf=\"multiple && showSelectAll && !filterControl.value\">\r\n All\r\n </mat-option>\r\n\r\n <ng-container *ngIf=\"field.options | filter : field.optionsFilterPredicate : filterControl.value as options\">\r\n <ng-container *ngIf=\"options.length; else noItemsTemplate\">\r\n <ng-container *ngIf=\"field.optionsGroupProvider\">\r\n <mat-optgroup *ngFor=\"let group of options | groupBy : field.optionsGroupProvider\"\r\n [label]=\"group.key | map : field.optionGroupLabel\">\r\n <mat-option *ngFor=\"let option of group.items; trackBy : optionTracker\"\r\n [matTooltip]=\"option | map : field.optionLabel\"\r\n [context]=\"option\"\r\n [value]=\"option | map : field.optionValue\"\r\n [disabled]=\"option | map : field.optionDisabled\">\r\n <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n </mat-option>\r\n </mat-optgroup>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!field.optionsGroupProvider\">\r\n <mat-option *ngFor=\"let option of options; trackBy : optionTracker\"\r\n [matTooltip]=\"option | map : field.optionLabel\"\r\n [context]=\"option\"\r\n [value]=\"option | map : field.optionValue\"\r\n [disabled]=\"option | map : field.optionDisabled\">\r\n <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n </mat-option>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </mat-select>\r\n\r\n <span matSuffix\r\n *ngIf=\"field.isQuerying\">\r\n <spinner [loading]=\"field.isQuerying\"\r\n [size]=\"20\"></spinner>\r\n </span>\r\n\r\n <button *ngIf=\"!multiple && clearable && field.value != null && !field.isQuerying\"\r\n mat-button\r\n matSuffix\r\n mat-icon-button\r\n matTooltip=\"Clear\"\r\n (click)=\"$any(field).value = null; $event.stopPropagation()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n\r\n<ng-template #noItemsTemplate>\r\n <mat-option *ngIf=\"field.isQuerying\"\r\n [disabled]=\"true\">Loading...</mat-option>\r\n\r\n <mat-option *ngIf=\"!field.isQuerying && !filterControl.value && searchable\"\r\n [disabled]=\"true\">Type to search items</mat-option>\r\n\r\n <mat-option *ngIf=\"!field.isQuerying && filterControl.value\"\r\n [disabled]=\"true\">No items found</mat-option>\r\n</ng-template>\r\n\r\n<ng-template #defaultOptionTempalte\r\n let-label\r\n let-option=\"option\">\r\n {{ label }}\r\n</ng-template>\r\n", styles: [":host{display:inline-block}:host ::ng-deep mat-select.loading .mat-select-arrow{color:transparent!important}\n"], components: [{ type: i2.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i4.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i6.MatSelectSearchComponent, selector: "ngx-mat-select-search", inputs: ["placeholderLabel", "type", "noEntriesFoundLabel", "indexAndLengthScreenReaderText", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toogleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { type: i5.MatOptgroup, selector: "mat-optgroup", inputs: ["disabled"], exportAs: ["matOptgroup"] }, { type: i7.SpinnerComponent, selector: "spinner", inputs: ["type", "loading", "size"] }, { type: i8.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i3.MatLabel, selector: "mat-label" }, { type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i10.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i11.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i12.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i13.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i13.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i14.OptionContextDirective, selector: "mat-option[context]", inputs: ["context"] }, { type: i3.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "filter": i15.FilterPipe, "map": i15.MapPipe, "groupBy": i15.GroupByPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: SelectControlComponent, decorators: [{

@@ -205,2 +205,2 @@ type: Component,

}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-control.component.js","sourceRoot":"","sources":["../../../../../projects/angular-extensions/controls/select-control/select-control.component.ts","../../../../../projects/angular-extensions/controls/select-control/select-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { of, Subject } from \"rxjs\";\r\nimport { catchError, debounceTime, distinctUntilChanged, filter, switchMap, takeUntil, tap } from \"rxjs/operators\";\r\nimport {\r\n  Component, OnInit, Input, Optional, ElementRef, ChangeDetectorRef,\r\n  ViewChild, OnDestroy, AfterViewInit, ContentChild, TemplateRef, ChangeDetectionStrategy,\r\n} from \"@angular/core\";\r\nimport { MatOption } from \"@angular/material/core\";\r\nimport { MatSelect } from \"@angular/material/select\";\r\nimport { MatFormFieldAppearance } from \"@angular/material/form-field\";\r\nimport { FormControl } from \"@angular/forms\";\r\nimport { MatMenuTrigger } from \"@angular/material/menu\";\r\n\r\nimport { Field } from \"angular-extensions/models\";\r\nimport { overrideFunction } from \"angular-extensions/core\";\r\nimport { MatOptionWithContext } from \"./option-context/option-context.directive\";\r\n\r\n@Component({\r\n  selector: \"select-control\",\r\n  templateUrl: \"./select-control.component.html\",\r\n  styleUrls: [\"./select-control.component.scss\"],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SelectControlComponent<TValue, TOption> implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input()\r\n  public field: Field<TValue, TOption>;\r\n\r\n  @Input()\r\n  public fieldClass: string;\r\n\r\n  @Input()\r\n  public dropdownClass = \"\";\r\n\r\n  @Input()\r\n  public appearance: MatFormFieldAppearance = \"outline\";\r\n\r\n  @Input()\r\n  public multiple: boolean;\r\n\r\n  @Input()\r\n  public searchable: boolean;\r\n\r\n  @Input()\r\n  public clearable: boolean;\r\n\r\n  @Input()\r\n  public showSelectAll = false;\r\n\r\n  @Input()\r\n  public tooltipDisabled = false;\r\n\r\n  @Input()\r\n  public filter = \"\";\r\n\r\n  @ViewChild(\"select\", { static: true })\r\n  public select: MatSelect;\r\n\r\n  @ViewChild(\"selectAllOption\")\r\n  public selectAllOption: MatOption;\r\n\r\n  @ContentChild(\"optionTemplate\", { static: true })\r\n  public optionTemplate: TemplateRef<{ $implicit: string; option: TOption }>;\r\n\r\n  @ContentChild(\"triggerTemplate\", { static: true })\r\n  public triggerTemplate: TemplateRef<{ $implicit: string; option: TOption | TOption[] }>;\r\n\r\n  public get selectedOption() {\r\n    if (Array.isArray(this.select?.selected)) {\r\n      return (this.select.selected as MatOptionWithContext<TOption>[]).map(option => option.context);\r\n    }\r\n    else {\r\n      return (this.select.selected as MatOptionWithContext<TOption>)?.context;\r\n    }\r\n  }\r\n\r\n  public get triggerLabel() {\r\n    let selectedOption = this.selectedOption;\r\n\r\n    if (Array.isArray(selectedOption)) {\r\n      return selectedOption.map(option => this.field.optionLabel(option)).join(\", \");\r\n    }\r\n    else if (selectedOption) {\r\n      return this.field.optionLabel(selectedOption);\r\n    }\r\n    else {\r\n      return \"\";\r\n    }\r\n  }\r\n\r\n  private destroy = new Subject();\r\n\r\n  public filterControl = new FormControl();\r\n\r\n  constructor(\r\n    elementRef: ElementRef<HTMLElement>,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    @Optional() matMenuTrigger: MatMenuTrigger,\r\n  ) {\r\n    // provides ability to have select-control to open\r\n    // custom popup menu without processing actual event\r\n    if (matMenuTrigger) {\r\n      elementRef.nativeElement.addEventListener(\r\n        \"click\",\r\n        event => {\r\n          matMenuTrigger.openMenu();\r\n\r\n          event.stopPropagation();\r\n        },\r\n        { capture: true });\r\n    }\r\n  }\r\n\r\n  public ngOnInit() {\r\n    this.filterControl.setValue(this.filter);\r\n\r\n    this.field.control.statusChanges\r\n      .pipe(takeUntil(this.destroy))\r\n      .subscribe(() => {\r\n        this.changeDetectorRef.markForCheck();\r\n      });\r\n\r\n    if (this.multiple && this.showSelectAll) {\r\n      this.select.optionSelectionChanges\r\n        .pipe(\r\n          debounceTime(0),\r\n          takeUntil(this.destroy))\r\n        .subscribe(() => {\r\n          let selectedOptions = this.select.selected as MatOption[];\r\n\r\n          this.setSelectAllState(selectedOptions?.length > 0 && selectedOptions?.length == this.field.options?.length);\r\n        });\r\n    }\r\n  }\r\n\r\n  public ngAfterViewInit() {\r\n    if (this.field.optionDisplayLabel) {\r\n      let optionViewLabel = this.field.optionDisplayLabel;\r\n\r\n      this.select.options.changes\r\n        .pipe(takeUntil(this.destroy))\r\n        .subscribe((options: MatOption[]) => {\r\n          options.forEach(option => {\r\n            Object.defineProperty(option, nameOf(() => option.viewValue), {\r\n              get: () => optionViewLabel(option.value as TOption),\r\n              configurable: true,\r\n            });\r\n          });\r\n        });\r\n    }\r\n\r\n    if (this.searchable && this.multiple && this.select) {\r\n      // fixing issue with select control not propagating\r\n      // changes to model when options filtering is applied\r\n      overrideFunction(\r\n        this.select,\r\n        select => (select as any)._initializeSelection,\r\n        (_, select) => {\r\n          Promise.resolve().then(() => {\r\n            (select as any)._setSelectionByValue([...(select.ngControl.value || []), ...((select as any)._value || [])]);\r\n            select.stateChanges.next();\r\n          });\r\n        });\r\n    }\r\n\r\n    if (this.multiple && this.showSelectAll) {\r\n      this.selectAllOption._getHostElement().addEventListener(\r\n        \"click\",\r\n        event => {\r\n          this.toggleSelectAll();\r\n          event.preventDefault();\r\n          event.stopImmediatePropagation();\r\n        },\r\n        { capture: true });\r\n    }\r\n\r\n    if (this.searchable && this.field.optionsProvider) {\r\n      let optionsProvider = this.field.optionsProvider;\r\n\r\n      this.filterControl.valueChanges\r\n        .pipe(\r\n          filter((query: string) => query != \"\"),\r\n          distinctUntilChanged(),\r\n          tap(() => {\r\n            this.field.options = [];\r\n            this.field.isQuerying = true;\r\n\r\n            this.changeDetectorRef.markForCheck();\r\n          }),\r\n          debounceTime(300),\r\n          switchMap((query: string) => !!query\r\n            ? optionsProvider(query).pipe(catchError(() => of([] as TOption[])))\r\n            : of([])),\r\n          takeUntil(this.destroy))\r\n        .subscribe(options => {\r\n          this.field.options = options;\r\n          this.field.isQuerying = false;\r\n\r\n          this.changeDetectorRef.markForCheck();\r\n        });\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    this.destroy.next();\r\n    this.destroy.complete();\r\n  }\r\n\r\n  public optionTracker = (index: number, option: TOption) => {\r\n    return this.field.optionId(option, index);\r\n  };\r\n\r\n  public optionComparer = (left?: TOption, right?: TOption) => {\r\n    return left != null && right != null && this.field.optionId(left) == this.field.optionId(right);\r\n  };\r\n\r\n  private toggleSelectAll() {\r\n    let shouldSelect = (this.select.selected as MatOption[])?.length < this.field.options?.length;\r\n\r\n    this.select.options\r\n      .filter(option => !option.disabled && option.id != this.selectAllOption.id)\r\n      .forEach(option => {\r\n        if (shouldSelect) {\r\n          option.select();\r\n        }\r\n        else {\r\n          option.deselect();\r\n        }\r\n      });\r\n\r\n    this.setSelectAllState(shouldSelect);\r\n  }\r\n\r\n  private setSelectAllState(selected: boolean) {\r\n    if (this.selectAllOption) {\r\n      (this.selectAllOption as any)._selected = selected;\r\n      (this.selectAllOption as any)._changeDetectorRef.markForCheck();\r\n    }\r\n  }\r\n}\r\n","<base-control #baseControl\r\n              [field]=\"field\">\r\n  <mat-form-field [appearance]=\"appearance\"\r\n                  [class]=\"fieldClass\">\r\n    <mat-label>\r\n      {{ field.label }}\r\n    </mat-label>\r\n\r\n    <mat-hint>\r\n      {{ field.info }}\r\n    </mat-hint>\r\n\r\n    <mat-select #select\r\n                [panelClass]=\"'custom-scroll ' + dropdownClass\"\r\n                [ngClass]=\"{ loading: field.isQuerying }\"\r\n                [matTooltipDisabled]=\"tooltipDisabled\"\r\n                [matTooltip]=\"select.triggerValue\"\r\n                [formControl]=\"field.control\"\r\n                [disableOptionCentering]=\"searchable\"\r\n                [compareWith]=\"optionComparer\"\r\n                [multiple]=\"multiple\">\r\n\r\n      <mat-select-trigger *ngIf=\"triggerTemplate\">\r\n        <ng-container *ngTemplateOutlet=\"triggerTemplate; context: { $implicit: select.triggerValue, label: triggerLabel, option: selectedOption }\"></ng-container>\r\n      </mat-select-trigger>\r\n\r\n      <mat-option *ngIf=\"searchable\">\r\n        <ngx-mat-select-search placeholderLabel=\"Search\"\r\n                               [noEntriesFoundLabel]=\"$any(null)\"\r\n                               [formControl]=\"filterControl\"\r\n                               [searching]=\"field.isQuerying\"></ngx-mat-select-search>\r\n      </mat-option>\r\n\r\n      <mat-option #selectAllOption\r\n                  *ngIf=\"multiple && showSelectAll && !filterControl.value\">\r\n        All\r\n      </mat-option>\r\n\r\n      <ng-container *ngIf=\"field.options | filter : field.optionsFilterPredicate : filterControl.value as options\">\r\n        <ng-container *ngIf=\"options.length; else noItemsTemplate\">\r\n          <ng-container *ngIf=\"field.optionsGroupProvider\">\r\n            <mat-optgroup *ngFor=\"let group of options | groupBy : field.optionsGroupProvider\"\r\n                          [label]=\"group.key | map : field.optionGroupLabel\">\r\n              <mat-option *ngFor=\"let option of group.items; trackBy : optionTracker\"\r\n                          [matTooltip]=\"option | map : field.optionLabel\"\r\n                          [context]=\"option\"\r\n                          [value]=\"option | map : field.optionValue\"\r\n                          [disabled]=\"option | map : field.optionDisabled\">\r\n                <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n                  context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n              </mat-option>\r\n            </mat-optgroup>\r\n          </ng-container>\r\n\r\n          <ng-container *ngIf=\"!field.optionsGroupProvider\">\r\n            <mat-option *ngFor=\"let option of options; trackBy : optionTracker\"\r\n                        [matTooltip]=\"option | map : field.optionLabel\"\r\n                        [context]=\"option\"\r\n                        [value]=\"option | map : field.optionValue\"\r\n                        [disabled]=\"option | map : field.optionDisabled\">\r\n              <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n                context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n            </mat-option>\r\n          </ng-container>\r\n        </ng-container>\r\n      </ng-container>\r\n    </mat-select>\r\n\r\n    <span matSuffix\r\n          *ngIf=\"field.isQuerying\">\r\n      <spinner [loading]=\"field.isQuerying\"\r\n               [size]=\"20\"></spinner>\r\n    </span>\r\n\r\n    <button *ngIf=\"!multiple && clearable && field.value != null && !field.isQuerying\"\r\n            mat-button\r\n            matSuffix\r\n            mat-icon-button\r\n            matTooltip=\"Clear\"\r\n            (click)=\"$any(field).value = null; $event.stopPropagation()\">\r\n      <mat-icon>close</mat-icon>\r\n    </button>\r\n\r\n    <mat-error *ngIf=\"baseControl.initialized\">\r\n      <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n    </mat-error>\r\n  </mat-form-field>\r\n</base-control>\r\n\r\n<ng-template #noItemsTemplate>\r\n  <mat-option *ngIf=\"field.isQuerying\"\r\n              [disabled]=\"true\">Loading...</mat-option>\r\n\r\n  <mat-option *ngIf=\"!field.isQuerying && !filterControl.value && searchable\"\r\n              [disabled]=\"true\">Type to search items</mat-option>\r\n\r\n  <mat-option *ngIf=\"!field.isQuerying && filterControl.value\"\r\n              [disabled]=\"true\">No items found</mat-option>\r\n</ng-template>\r\n\r\n<ng-template #defaultOptionTempalte\r\n             let-label\r\n             let-option=\"option\">\r\n  {{ label }}\r\n</ng-template>\r\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-control.component.js","sourceRoot":"","sources":["../../../../../projects/angular-extensions/controls/select-control/select-control.component.ts","../../../../../projects/angular-extensions/controls/select-control/select-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { of, Subject } from \"rxjs\";\r\nimport { catchError, debounceTime, distinctUntilChanged, filter, switchMap, takeUntil, tap } from \"rxjs/operators\";\r\nimport {\r\n  Component, OnInit, Input, Optional, ElementRef, ChangeDetectorRef,\r\n  ViewChild, OnDestroy, AfterViewInit, ContentChild, TemplateRef, ChangeDetectionStrategy,\r\n} from \"@angular/core\";\r\nimport { MatOption } from \"@angular/material/core\";\r\nimport { MatSelect } from \"@angular/material/select\";\r\nimport { MatFormFieldAppearance } from \"@angular/material/form-field\";\r\nimport { FormControl } from \"@angular/forms\";\r\nimport { MatMenuTrigger } from \"@angular/material/menu\";\r\n\r\nimport { Field } from \"angular-extensions/models\";\r\nimport { overrideFunction } from \"angular-extensions/core\";\r\nimport { MatOptionWithContext } from \"./option-context/option-context.directive\";\r\n\r\n@Component({\r\n  selector: \"select-control\",\r\n  templateUrl: \"./select-control.component.html\",\r\n  styleUrls: [\"./select-control.component.scss\"],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class SelectControlComponent<TValue, TOption> implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input()\r\n  public field: Field<TValue, TOption>;\r\n\r\n  @Input()\r\n  public fieldClass: string;\r\n\r\n  @Input()\r\n  public dropdownClass = \"\";\r\n\r\n  @Input()\r\n  public appearance: MatFormFieldAppearance = \"outline\";\r\n\r\n  @Input()\r\n  public multiple: boolean;\r\n\r\n  @Input()\r\n  public searchable: boolean;\r\n\r\n  @Input()\r\n  public clearable: boolean;\r\n\r\n  @Input()\r\n  public showSelectAll = false;\r\n\r\n  @Input()\r\n  public tooltipDisabled = false;\r\n\r\n  @Input()\r\n  public filter = \"\";\r\n\r\n  @ViewChild(\"select\", { static: true })\r\n  public select: MatSelect;\r\n\r\n  @ViewChild(\"selectAllOption\")\r\n  public selectAllOption: MatOption;\r\n\r\n  @ContentChild(\"optionTemplate\", { static: true })\r\n  public optionTemplate: TemplateRef<{ $implicit: string; option: TOption }>;\r\n\r\n  @ContentChild(\"triggerTemplate\", { static: true })\r\n  public triggerTemplate: TemplateRef<{ $implicit: string; option: TOption | TOption[] }>;\r\n\r\n  public get selectedOption() {\r\n    if (Array.isArray(this.select?.selected)) {\r\n      return (this.select.selected as MatOptionWithContext<TOption>[]).map(option => option.context);\r\n    }\r\n    else {\r\n      return (this.select.selected as MatOptionWithContext<TOption>)?.context;\r\n    }\r\n  }\r\n\r\n  public get triggerLabel() {\r\n    let selectedOption = this.selectedOption;\r\n\r\n    if (Array.isArray(selectedOption)) {\r\n      return selectedOption.map(option => this.field.optionLabel(option)).join(\", \");\r\n    }\r\n    else if (selectedOption) {\r\n      return this.field.optionLabel(selectedOption);\r\n    }\r\n    else {\r\n      return \"\";\r\n    }\r\n  }\r\n\r\n  private destroy = new Subject();\r\n\r\n  public filterControl = new FormControl();\r\n\r\n  constructor(\r\n    elementRef: ElementRef<HTMLElement>,\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    @Optional() matMenuTrigger: MatMenuTrigger,\r\n  ) {\r\n    // provides ability to have select-control to open\r\n    // custom popup menu without processing actual event\r\n    if (matMenuTrigger) {\r\n      elementRef.nativeElement.addEventListener(\r\n        \"click\",\r\n        event => {\r\n          matMenuTrigger.openMenu();\r\n\r\n          event.stopPropagation();\r\n        },\r\n        { capture: true });\r\n    }\r\n  }\r\n\r\n  public ngOnInit() {\r\n    this.filterControl.setValue(this.filter);\r\n\r\n    this.field.control.statusChanges\r\n      .pipe(takeUntil(this.destroy))\r\n      .subscribe(() => {\r\n        this.changeDetectorRef.markForCheck();\r\n      });\r\n\r\n    if (this.multiple && this.showSelectAll) {\r\n      this.select.optionSelectionChanges\r\n        .pipe(\r\n          debounceTime(0),\r\n          takeUntil(this.destroy))\r\n        .subscribe(() => {\r\n          let selectedOptions = this.select.selected as MatOption[];\r\n\r\n          this.setSelectAllState(selectedOptions?.length > 0 && selectedOptions?.length == this.field.options?.length);\r\n        });\r\n    }\r\n  }\r\n\r\n  public ngAfterViewInit() {\r\n    if (this.field.optionDisplayLabel) {\r\n      let optionViewLabel = this.field.optionDisplayLabel;\r\n\r\n      this.select.options.changes\r\n        .pipe(takeUntil(this.destroy))\r\n        .subscribe((options: MatOption[]) => {\r\n          options.forEach(option => {\r\n            Object.defineProperty(option, nameOf(() => option.viewValue), {\r\n              get: () => optionViewLabel(option.value as TOption),\r\n              configurable: true,\r\n            });\r\n          });\r\n        });\r\n    }\r\n\r\n    if (this.searchable && this.multiple && this.select) {\r\n      // fixing issue with select control not propagating\r\n      // changes to model when options filtering is applied\r\n      overrideFunction(\r\n        this.select,\r\n        select => (select as any)._initializeSelection,\r\n        (_, select) => {\r\n          Promise.resolve().then(() => {\r\n            (select as any)._setSelectionByValue([...(select.ngControl.value || []), ...((select as any)._value || [])]);\r\n            select.stateChanges.next();\r\n          });\r\n        });\r\n    }\r\n\r\n    if (this.multiple && this.showSelectAll) {\r\n      this.selectAllOption._getHostElement().addEventListener(\r\n        \"click\",\r\n        event => {\r\n          this.toggleSelectAll();\r\n          event.preventDefault();\r\n          event.stopImmediatePropagation();\r\n        },\r\n        { capture: true });\r\n    }\r\n\r\n    if (this.searchable && this.field.optionsProvider) {\r\n      let optionsProvider = this.field.optionsProvider;\r\n\r\n      this.filterControl.valueChanges\r\n        .pipe(\r\n          filter((query: string) => query != \"\"),\r\n          distinctUntilChanged(),\r\n          tap(() => {\r\n            this.field.options = [];\r\n            this.field.isQuerying = true;\r\n\r\n            this.changeDetectorRef.markForCheck();\r\n          }),\r\n          debounceTime(300),\r\n          switchMap((query: string) => !!query\r\n            ? optionsProvider(query).pipe(catchError(() => of([] as TOption[])))\r\n            : of([])),\r\n          takeUntil(this.destroy))\r\n        .subscribe(options => {\r\n          this.field.options = options;\r\n          this.field.isQuerying = false;\r\n\r\n          this.changeDetectorRef.markForCheck();\r\n        });\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    this.destroy.next();\r\n    this.destroy.complete();\r\n  }\r\n\r\n  public optionTracker = (index: number, option: TOption) => {\r\n    return this.field.optionId(option, index);\r\n  };\r\n\r\n  public optionComparer = (left?: TOption, right?: TOption) => {\r\n    return left != null && right != null && this.field.optionId(left) == this.field.optionId(right);\r\n  };\r\n\r\n  private toggleSelectAll() {\r\n    let shouldSelect = (this.select.selected as MatOption[])?.length < this.field.options?.length;\r\n\r\n    this.select.options\r\n      .filter(option => !option.disabled && option.id != this.selectAllOption.id)\r\n      .forEach(option => {\r\n        if (shouldSelect) {\r\n          option.select();\r\n        }\r\n        else {\r\n          option.deselect();\r\n        }\r\n      });\r\n\r\n    this.setSelectAllState(shouldSelect);\r\n  }\r\n\r\n  private setSelectAllState(selected: boolean) {\r\n    if (this.selectAllOption) {\r\n      (this.selectAllOption as any)._selected = selected;\r\n      (this.selectAllOption as any)._changeDetectorRef.markForCheck();\r\n    }\r\n  }\r\n}\r\n","<base-control #baseControl\r\n              [field]=\"field\">\r\n  <mat-form-field [appearance]=\"appearance\"\r\n                  [class]=\"fieldClass\">\r\n    <mat-label>\r\n      {{ field.label }}\r\n    </mat-label>\r\n\r\n    <mat-hint>\r\n      <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n    </mat-hint>\r\n\r\n    <mat-select #select\r\n                [panelClass]=\"'custom-scroll ' + dropdownClass\"\r\n                [ngClass]=\"{ loading: field.isQuerying }\"\r\n                [matTooltipDisabled]=\"tooltipDisabled\"\r\n                [matTooltip]=\"select.triggerValue\"\r\n                [formControl]=\"field.control\"\r\n                [disableOptionCentering]=\"searchable\"\r\n                [compareWith]=\"optionComparer\"\r\n                [multiple]=\"multiple\">\r\n\r\n      <mat-select-trigger *ngIf=\"triggerTemplate\">\r\n        <ng-container *ngTemplateOutlet=\"triggerTemplate; context: { $implicit: select.triggerValue, label: triggerLabel, option: selectedOption }\"></ng-container>\r\n      </mat-select-trigger>\r\n\r\n      <mat-option *ngIf=\"searchable\">\r\n        <ngx-mat-select-search placeholderLabel=\"Search\"\r\n                               [noEntriesFoundLabel]=\"$any(null)\"\r\n                               [formControl]=\"filterControl\"\r\n                               [searching]=\"field.isQuerying\"></ngx-mat-select-search>\r\n      </mat-option>\r\n\r\n      <mat-option #selectAllOption\r\n                  *ngIf=\"multiple && showSelectAll && !filterControl.value\">\r\n        All\r\n      </mat-option>\r\n\r\n      <ng-container *ngIf=\"field.options | filter : field.optionsFilterPredicate : filterControl.value as options\">\r\n        <ng-container *ngIf=\"options.length; else noItemsTemplate\">\r\n          <ng-container *ngIf=\"field.optionsGroupProvider\">\r\n            <mat-optgroup *ngFor=\"let group of options | groupBy : field.optionsGroupProvider\"\r\n                          [label]=\"group.key | map : field.optionGroupLabel\">\r\n              <mat-option *ngFor=\"let option of group.items; trackBy : optionTracker\"\r\n                          [matTooltip]=\"option | map : field.optionLabel\"\r\n                          [context]=\"option\"\r\n                          [value]=\"option | map : field.optionValue\"\r\n                          [disabled]=\"option | map : field.optionDisabled\">\r\n                <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n                  context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n              </mat-option>\r\n            </mat-optgroup>\r\n          </ng-container>\r\n\r\n          <ng-container *ngIf=\"!field.optionsGroupProvider\">\r\n            <mat-option *ngFor=\"let option of options; trackBy : optionTracker\"\r\n                        [matTooltip]=\"option | map : field.optionLabel\"\r\n                        [context]=\"option\"\r\n                        [value]=\"option | map : field.optionValue\"\r\n                        [disabled]=\"option | map : field.optionDisabled\">\r\n              <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n                context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n            </mat-option>\r\n          </ng-container>\r\n        </ng-container>\r\n      </ng-container>\r\n    </mat-select>\r\n\r\n    <span matSuffix\r\n          *ngIf=\"field.isQuerying\">\r\n      <spinner [loading]=\"field.isQuerying\"\r\n               [size]=\"20\"></spinner>\r\n    </span>\r\n\r\n    <button *ngIf=\"!multiple && clearable && field.value != null && !field.isQuerying\"\r\n            mat-button\r\n            matSuffix\r\n            mat-icon-button\r\n            matTooltip=\"Clear\"\r\n            (click)=\"$any(field).value = null; $event.stopPropagation()\">\r\n      <mat-icon>close</mat-icon>\r\n    </button>\r\n\r\n    <mat-error *ngIf=\"baseControl.initialized\">\r\n      <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n    </mat-error>\r\n  </mat-form-field>\r\n</base-control>\r\n\r\n<ng-template #noItemsTemplate>\r\n  <mat-option *ngIf=\"field.isQuerying\"\r\n              [disabled]=\"true\">Loading...</mat-option>\r\n\r\n  <mat-option *ngIf=\"!field.isQuerying && !filterControl.value && searchable\"\r\n              [disabled]=\"true\">Type to search items</mat-option>\r\n\r\n  <mat-option *ngIf=\"!field.isQuerying && filterControl.value\"\r\n              [disabled]=\"true\">No items found</mat-option>\r\n</ng-template>\r\n\r\n<ng-template #defaultOptionTempalte\r\n             let-label\r\n             let-option=\"option\">\r\n  {{ label }}\r\n</ng-template>\r\n"]}

@@ -9,5 +9,6 @@ import { Component, Input, ViewChild } from "@angular/core";

import * as i5 from "@angular/common";
import * as i6 from "@angular/material/input";
import * as i7 from "ngx-mask";
import * as i8 from "@angular/forms";
import * as i6 from "@angular/material/tooltip";
import * as i7 from "@angular/material/input";
import * as i8 from "ngx-mask";
import * as i9 from "@angular/forms";
export class TextControlComponent {

@@ -23,3 +24,3 @@ constructor() {

TextControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TextControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
TextControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextControlComponent, selector: "text-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", type: "type", mask: "mask", prefix: "prefix", showMaskTyped: "showMaskTyped", focused: "focused", icon: "icon", clearable: "clearable" }, viewQueries: [{ propertyName: "input", first: true, predicate: MatInput, descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field cdkTrapFocus\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n [cdkTrapFocusAutoCapture]=\"focused\"\r\n (click)=\"input.focus()\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <mat-icon *ngIf=\"icon\"\r\n matPrefix>{{icon}}</mat-icon>\r\n\r\n <button mat-icon-button\r\n *ngIf=\"field.value && clearable\"\r\n matSuffix\r\n aria-label=\"Clear\"\r\n matTooltip=\"Clear\"\r\n (click)=\"field.value = ''\"\r\n type=\"button\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngIf=\"mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [prefix]=\"prefix\"\r\n [mask]=\"mask\"\r\n [showMaskTyped]=\"showMaskTyped\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i4.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatPrefix, selector: "[matPrefix]" }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i7.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
TextControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextControlComponent, selector: "text-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", type: "type", mask: "mask", prefix: "prefix", showMaskTyped: "showMaskTyped", focused: "focused", icon: "icon", clearable: "clearable" }, viewQueries: [{ propertyName: "input", first: true, predicate: MatInput, descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field cdkTrapFocus\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n [cdkTrapFocusAutoCapture]=\"focused\"\r\n (click)=\"input.focus()\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <mat-icon *ngIf=\"icon\"\r\n matPrefix>{{icon}}</mat-icon>\r\n\r\n <button mat-icon-button\r\n *ngIf=\"field.value && clearable\"\r\n matSuffix\r\n aria-label=\"Clear\"\r\n matTooltip=\"Clear\"\r\n (click)=\"field.value = ''\"\r\n type=\"button\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngIf=\"mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [prefix]=\"prefix\"\r\n [mask]=\"mask\"\r\n [showMaskTyped]=\"showMaskTyped\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i4.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatPrefix, selector: "[matPrefix]" }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i8.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TextControlComponent, decorators: [{

@@ -56,2 +57,2 @@ type: Component,

}] } });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90ZXh0LWNvbnRyb2wvdGV4dC1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90ZXh0LWNvbnRyb2wvdGV4dC1jb250cm9sLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1RCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0seUJBQXlCLENBQUM7Ozs7Ozs7Ozs7QUFTbkQsTUFBTSxPQUFPLG9CQUFvQjtJQUxqQztRQWlCUyxlQUFVLEdBQTJCLFNBQVMsQ0FBQztRQUcvQyxTQUFJLEdBQWlELE1BQU0sQ0FBQztRQU01RCxXQUFNLEdBQUcsRUFBRSxDQUFDO1FBTVosWUFBTyxHQUFHLEtBQUssQ0FBQztRQU1oQixjQUFTLEdBQUcsS0FBSyxDQUFDO0tBQzFCOztpSEFsQ1ksb0JBQW9CO3FHQUFwQixvQkFBb0IsbVRBRXBCLFFBQVEsZ0RDYnJCLHV0REFzREE7MkZEM0NhLG9CQUFvQjtrQkFMaEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsY0FBYztvQkFDeEIsV0FBVyxFQUFFLCtCQUErQjtvQkFDNUMsU0FBUyxFQUFFLENBQUMsK0JBQStCLENBQUM7aUJBQzdDOzhCQUlRLEtBQUs7c0JBRFgsU0FBUzt1QkFBQyxRQUFRO2dCQUlaLEtBQUs7c0JBRFgsS0FBSztnQkFJQyxVQUFVO3NCQURoQixLQUFLO2dCQUlDLFVBQVU7c0JBRGhCLEtBQUs7Z0JBSUMsSUFBSTtzQkFEVixLQUFLO2dCQUlDLElBQUk7c0JBRFYsS0FBSztnQkFJQyxNQUFNO3NCQURaLEtBQUs7Z0JBSUMsYUFBYTtzQkFEbkIsS0FBSztnQkFJQyxPQUFPO3NCQURiLEtBQUs7Z0JBSUMsSUFBSTtzQkFEVixLQUFLO2dCQUlDLFNBQVM7c0JBRGYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIFZpZXdDaGlsZCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IE1hdEZvcm1GaWVsZEFwcGVhcmFuY2UgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZFwiO1xyXG5pbXBvcnQgeyBNYXRJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9pbnB1dFwiO1xyXG5cclxuaW1wb3J0IHsgRmllbGQsIFRpbWVPZkRheSB9IGZyb20gXCJhbmd1bGFyLWV4dGVuc2lvbnMvbW9kZWxzXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJ0ZXh0LWNvbnRyb2xcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL3RleHQtY29udHJvbC5jb21wb25lbnQuaHRtbFwiLFxyXG4gIHN0eWxlVXJsczogW1wiLi90ZXh0LWNvbnRyb2wuY29tcG9uZW50LnNjc3NcIl1cclxufSlcclxuZXhwb3J0IGNsYXNzIFRleHRDb250cm9sQ29tcG9uZW50IHtcclxuXHJcbiAgQFZpZXdDaGlsZChNYXRJbnB1dClcclxuICBwdWJsaWMgaW5wdXQ6IE1hdElucHV0O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZDogRmllbGQ8c3RyaW5nPiB8IEZpZWxkPG51bWJlcj4gfCBGaWVsZDxUaW1lT2ZEYXk+O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZENsYXNzOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGFwcGVhcmFuY2U6IE1hdEZvcm1GaWVsZEFwcGVhcmFuY2UgPSBcIm91dGxpbmVcIjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgdHlwZTogXCJ0ZXh0XCIgfCBcIm51bWJlclwiIHwgXCJ0aW1lXCIgfCBcImVtYWlsXCIgfCBcInRlbFwiID0gXCJ0ZXh0XCI7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIG1hc2s6IHN0cmluZztcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgcHJlZml4ID0gXCJcIjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2hvd01hc2tUeXBlZDogYm9vbGVhbjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZm9jdXNlZCA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBpY29uOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGNsZWFyYWJsZSA9IGZhbHNlO1xyXG59XHJcbiIsIjxiYXNlLWNvbnRyb2wgI2Jhc2VDb250cm9sXHJcbiAgICAgICAgICAgICAgW2ZpZWxkXT1cImZpZWxkXCI+XHJcbiAgPG1hdC1mb3JtLWZpZWxkIGNka1RyYXBGb2N1c1xyXG4gICAgICAgICAgICAgICAgICBbYXBwZWFyYW5jZV09XCJhcHBlYXJhbmNlXCJcclxuICAgICAgICAgICAgICAgICAgW2NsYXNzXT1cImZpZWxkQ2xhc3NcIlxyXG4gICAgICAgICAgICAgICAgICBbY2RrVHJhcEZvY3VzQXV0b0NhcHR1cmVdPVwiZm9jdXNlZFwiXHJcbiAgICAgICAgICAgICAgICAgIChjbGljayk9XCJpbnB1dC5mb2N1cygpXCI+XHJcbiAgICA8bWF0LWxhYmVsPlxyXG4gICAgICB7eyBmaWVsZC5sYWJlbCB9fVxyXG4gICAgPC9tYXQtbGFiZWw+XHJcblxyXG4gICAgPG1hdC1oaW50PlxyXG4gICAgICB7eyBmaWVsZC5pbmZvIH19XHJcbiAgICA8L21hdC1oaW50PlxyXG5cclxuICAgIDxtYXQtaWNvbiAqbmdJZj1cImljb25cIlxyXG4gICAgICAgICAgICAgIG1hdFByZWZpeD57e2ljb259fTwvbWF0LWljb24+XHJcblxyXG4gICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b25cclxuICAgICAgICAgICAgKm5nSWY9XCJmaWVsZC52YWx1ZSAmJiBjbGVhcmFibGVcIlxyXG4gICAgICAgICAgICBtYXRTdWZmaXhcclxuICAgICAgICAgICAgYXJpYS1sYWJlbD1cIkNsZWFyXCJcclxuICAgICAgICAgICAgbWF0VG9vbHRpcD1cIkNsZWFyXCJcclxuICAgICAgICAgICAgKGNsaWNrKT1cImZpZWxkLnZhbHVlID0gJydcIlxyXG4gICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCI+XHJcbiAgICAgIDxtYXQtaWNvbj5jbG9zZTwvbWF0LWljb24+XHJcbiAgICA8L2J1dHRvbj5cclxuXHJcbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwibWFza1wiPlxyXG4gICAgICA8aW5wdXQgI2lucHV0XHJcbiAgICAgICAgICAgICBtYXRJbnB1dFxyXG4gICAgICAgICAgICAgY2RrRm9jdXNJbml0aWFsXHJcbiAgICAgICAgICAgICBbYXR0ci5pbnB1dG1vZGVdPVwidHlwZSA9PSAnbnVtYmVyJyA/ICdkZWNpbWFsJyA6IG51bGxcIlxyXG4gICAgICAgICAgICAgW3R5cGVdPVwidHlwZVwiXHJcbiAgICAgICAgICAgICBbcHJlZml4XT1cInByZWZpeFwiXHJcbiAgICAgICAgICAgICBbbWFza109XCJtYXNrXCJcclxuICAgICAgICAgICAgIFtzaG93TWFza1R5cGVkXT1cInNob3dNYXNrVHlwZWRcIlxyXG4gICAgICAgICAgICAgW2Zvcm1Db250cm9sXT1cImZpZWxkLmNvbnRyb2xcIj5cclxuICAgIDwvbmctY29udGFpbmVyPlxyXG5cclxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIhbWFza1wiPlxyXG4gICAgICA8aW5wdXQgI2lucHV0XHJcbiAgICAgICAgICAgICBtYXRJbnB1dFxyXG4gICAgICAgICAgICAgY2RrRm9jdXNJbml0aWFsXHJcbiAgICAgICAgICAgICBbYXR0ci5pbnB1dG1vZGVdPVwidHlwZSA9PSAnbnVtYmVyJyA/ICdkZWNpbWFsJyA6IG51bGxcIlxyXG4gICAgICAgICAgICAgW3R5cGVdPVwidHlwZVwiXHJcbiAgICAgICAgICAgICBbZm9ybUNvbnRyb2xdPVwiZmllbGQuY29udHJvbFwiPlxyXG4gICAgPC9uZy1jb250YWluZXI+XHJcblxyXG4gICAgPG1hdC1lcnJvciAqbmdJZj1cImJhc2VDb250cm9sLmluaXRpYWxpemVkXCI+XHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJiYXNlQ29udHJvbC5lcnJvcnNUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9tYXQtZXJyb3I+XHJcbiAgPC9tYXQtZm9ybS1maWVsZD5cclxuPC9iYXNlLWNvbnRyb2w+XHJcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90ZXh0LWNvbnRyb2wvdGV4dC1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90ZXh0LWNvbnRyb2wvdGV4dC1jb250cm9sLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1RCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0seUJBQXlCLENBQUM7Ozs7Ozs7Ozs7O0FBU25ELE1BQU0sT0FBTyxvQkFBb0I7SUFMakM7UUFpQlMsZUFBVSxHQUEyQixTQUFTLENBQUM7UUFHL0MsU0FBSSxHQUFpRCxNQUFNLENBQUM7UUFNNUQsV0FBTSxHQUFHLEVBQUUsQ0FBQztRQU1aLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFNaEIsY0FBUyxHQUFHLEtBQUssQ0FBQztLQUMxQjs7aUhBbENZLG9CQUFvQjtxR0FBcEIsb0JBQW9CLG1UQUVwQixRQUFRLGdEQ2JyQixteERBc0RBOzJGRDNDYSxvQkFBb0I7a0JBTGhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLFdBQVcsRUFBRSwrQkFBK0I7b0JBQzVDLFNBQVMsRUFBRSxDQUFDLCtCQUErQixDQUFDO2lCQUM3Qzs4QkFJUSxLQUFLO3NCQURYLFNBQVM7dUJBQUMsUUFBUTtnQkFJWixLQUFLO3NCQURYLEtBQUs7Z0JBSUMsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxVQUFVO3NCQURoQixLQUFLO2dCQUlDLElBQUk7c0JBRFYsS0FBSztnQkFJQyxJQUFJO3NCQURWLEtBQUs7Z0JBSUMsTUFBTTtzQkFEWixLQUFLO2dCQUlDLGFBQWE7c0JBRG5CLEtBQUs7Z0JBSUMsT0FBTztzQkFEYixLQUFLO2dCQUlDLElBQUk7c0JBRFYsS0FBSztnQkFJQyxTQUFTO3NCQURmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBWaWV3Q2hpbGQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRBcHBlYXJhbmNlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGRcIjtcclxuaW1wb3J0IHsgTWF0SW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXRcIjtcclxuXHJcbmltcG9ydCB7IEZpZWxkLCBUaW1lT2ZEYXkgfSBmcm9tIFwiYW5ndWxhci1leHRlbnNpb25zL21vZGVsc1wiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwidGV4dC1jb250cm9sXCIsXHJcbiAgdGVtcGxhdGVVcmw6IFwiLi90ZXh0LWNvbnRyb2wuY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vdGV4dC1jb250cm9sLmNvbXBvbmVudC5zY3NzXCJdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUZXh0Q29udHJvbENvbXBvbmVudCB7XHJcblxyXG4gIEBWaWV3Q2hpbGQoTWF0SW5wdXQpXHJcbiAgcHVibGljIGlucHV0OiBNYXRJbnB1dDtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZmllbGQ6IEZpZWxkPHN0cmluZz4gfCBGaWVsZDxudW1iZXI+IHwgRmllbGQ8VGltZU9mRGF5PjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZmllbGRDbGFzczogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBhcHBlYXJhbmNlOiBNYXRGb3JtRmllbGRBcHBlYXJhbmNlID0gXCJvdXRsaW5lXCI7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHR5cGU6IFwidGV4dFwiIHwgXCJudW1iZXJcIiB8IFwidGltZVwiIHwgXCJlbWFpbFwiIHwgXCJ0ZWxcIiA9IFwidGV4dFwiO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBtYXNrOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHByZWZpeCA9IFwiXCI7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNob3dNYXNrVHlwZWQ6IGJvb2xlYW47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGZvY3VzZWQgPSBmYWxzZTtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgaWNvbjogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjbGVhcmFibGUgPSBmYWxzZTtcclxufVxyXG4iLCI8YmFzZS1jb250cm9sICNiYXNlQ29udHJvbFxyXG4gICAgICAgICAgICAgIFtmaWVsZF09XCJmaWVsZFwiPlxyXG4gIDxtYXQtZm9ybS1maWVsZCBjZGtUcmFwRm9jdXNcclxuICAgICAgICAgICAgICAgICAgW2FwcGVhcmFuY2VdPVwiYXBwZWFyYW5jZVwiXHJcbiAgICAgICAgICAgICAgICAgIFtjbGFzc109XCJmaWVsZENsYXNzXCJcclxuICAgICAgICAgICAgICAgICAgW2Nka1RyYXBGb2N1c0F1dG9DYXB0dXJlXT1cImZvY3VzZWRcIlxyXG4gICAgICAgICAgICAgICAgICAoY2xpY2spPVwiaW5wdXQuZm9jdXMoKVwiPlxyXG4gICAgPG1hdC1sYWJlbD5cclxuICAgICAge3sgZmllbGQubGFiZWwgfX1cclxuICAgIDwvbWF0LWxhYmVsPlxyXG5cclxuICAgIDxtYXQtaGludD5cclxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImJhc2VDb250cm9sLmhpbnRUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9tYXQtaGludD5cclxuXHJcbiAgICA8bWF0LWljb24gKm5nSWY9XCJpY29uXCJcclxuICAgICAgICAgICAgICBtYXRQcmVmaXg+e3tpY29ufX08L21hdC1pY29uPlxyXG5cclxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uXHJcbiAgICAgICAgICAgICpuZ0lmPVwiZmllbGQudmFsdWUgJiYgY2xlYXJhYmxlXCJcclxuICAgICAgICAgICAgbWF0U3VmZml4XHJcbiAgICAgICAgICAgIGFyaWEtbGFiZWw9XCJDbGVhclwiXHJcbiAgICAgICAgICAgIG1hdFRvb2x0aXA9XCJDbGVhclwiXHJcbiAgICAgICAgICAgIChjbGljayk9XCJmaWVsZC52YWx1ZSA9ICcnXCJcclxuICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiPlxyXG4gICAgICA8bWF0LWljb24+Y2xvc2U8L21hdC1pY29uPlxyXG4gICAgPC9idXR0b24+XHJcblxyXG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIm1hc2tcIj5cclxuICAgICAgPGlucHV0ICNpbnB1dFxyXG4gICAgICAgICAgICAgbWF0SW5wdXRcclxuICAgICAgICAgICAgIGNka0ZvY3VzSW5pdGlhbFxyXG4gICAgICAgICAgICAgW2F0dHIuaW5wdXRtb2RlXT1cInR5cGUgPT0gJ251bWJlcicgPyAnZGVjaW1hbCcgOiBudWxsXCJcclxuICAgICAgICAgICAgIFt0eXBlXT1cInR5cGVcIlxyXG4gICAgICAgICAgICAgW3ByZWZpeF09XCJwcmVmaXhcIlxyXG4gICAgICAgICAgICAgW21hc2tdPVwibWFza1wiXHJcbiAgICAgICAgICAgICBbc2hvd01hc2tUeXBlZF09XCJzaG93TWFza1R5cGVkXCJcclxuICAgICAgICAgICAgIFtmb3JtQ29udHJvbF09XCJmaWVsZC5jb250cm9sXCI+XHJcbiAgICA8L25nLWNvbnRhaW5lcj5cclxuXHJcbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiIW1hc2tcIj5cclxuICAgICAgPGlucHV0ICNpbnB1dFxyXG4gICAgICAgICAgICAgbWF0SW5wdXRcclxuICAgICAgICAgICAgIGNka0ZvY3VzSW5pdGlhbFxyXG4gICAgICAgICAgICAgW2F0dHIuaW5wdXRtb2RlXT1cInR5cGUgPT0gJ251bWJlcicgPyAnZGVjaW1hbCcgOiBudWxsXCJcclxuICAgICAgICAgICAgIFt0eXBlXT1cInR5cGVcIlxyXG4gICAgICAgICAgICAgW2Zvcm1Db250cm9sXT1cImZpZWxkLmNvbnRyb2xcIj5cclxuICAgIDwvbmctY29udGFpbmVyPlxyXG5cclxuICAgIDxtYXQtZXJyb3IgKm5nSWY9XCJiYXNlQ29udHJvbC5pbml0aWFsaXplZFwiPlxyXG4gICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiYmFzZUNvbnRyb2wuZXJyb3JzVGVtcGxhdGVcIj48L25nLWNvbnRhaW5lcj5cclxuICAgIDwvbWF0LWVycm9yPlxyXG4gIDwvbWF0LWZvcm0tZmllbGQ+XHJcbjwvYmFzZS1jb250cm9sPlxyXG4iXX0=

@@ -5,5 +5,5 @@ import { Component, Input } from "@angular/core";

import * as i2 from "@angular/material/form-field";
import * as i3 from "@angular/material/input";
import * as i4 from "@angular/forms";
import * as i5 from "@angular/common";
import * as i3 from "@angular/common";
import * as i4 from "@angular/material/input";
import * as i5 from "@angular/forms";
export class TextAreaControlComponent {

@@ -15,3 +15,3 @@ constructor() {

TextAreaControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TextAreaControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
TextAreaControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextAreaControlComponent, selector: "textarea-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <textarea matInput\r\n #input\r\n [formControl]=\"field.control\">\r\n </textarea>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:block}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
TextAreaControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextAreaControlComponent, selector: "textarea-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <textarea matInput\r\n #input\r\n [formControl]=\"field.control\">\r\n </textarea>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:block}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TextAreaControlComponent, decorators: [{

@@ -31,2 +31,2 @@ type: Component,

}] } });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGFyZWEtY29udHJvbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWV4dGVuc2lvbnMvY29udHJvbHMvdGV4dGFyZWEtY29udHJvbC90ZXh0YXJlYS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90ZXh0YXJlYS1jb250cm9sL3RleHRhcmVhLWNvbnRyb2wuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7QUFTakQsTUFBTSxPQUFPLHdCQUF3QjtJQUxyQztRQWNTLGVBQVUsR0FBMkIsU0FBUyxDQUFDO0tBQ3ZEOztxSEFWWSx3QkFBd0I7eUdBQXhCLHdCQUF3Qix3SUNUckMsaW5CQXNCQTsyRkRiYSx3QkFBd0I7a0JBTHBDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsV0FBVyxFQUFFLG1DQUFtQztvQkFDaEQsU0FBUyxFQUFFLENBQUMsbUNBQW1DLENBQUM7aUJBQ2pEOzhCQUlRLEtBQUs7c0JBRFgsS0FBSztnQkFJQyxVQUFVO3NCQURoQixLQUFLO2dCQUlDLFVBQVU7c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkQXBwZWFyYW5jZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkXCI7XHJcbmltcG9ydCB7IEZpZWxkIH0gZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9tb2RlbHNcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcInRleHRhcmVhLWNvbnRyb2xcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL3RleHRhcmVhLWNvbnRyb2wuY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vdGV4dGFyZWEtY29udHJvbC5jb21wb25lbnQuc2Nzc1wiXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVGV4dEFyZWFDb250cm9sQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZmllbGQ6IEZpZWxkPHN0cmluZz47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGZpZWxkQ2xhc3M6IHN0cmluZztcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgYXBwZWFyYW5jZTogTWF0Rm9ybUZpZWxkQXBwZWFyYW5jZSA9IFwib3V0bGluZVwiO1xyXG59XHJcbiIsIjxiYXNlLWNvbnRyb2wgI2Jhc2VDb250cm9sXHJcbiAgICAgICAgICAgICAgW2ZpZWxkXT1cImZpZWxkXCI+XHJcbiAgPG1hdC1mb3JtLWZpZWxkIFthcHBlYXJhbmNlXT1cImFwcGVhcmFuY2VcIlxyXG4gICAgICAgICAgICAgICAgICBbY2xhc3NdPVwiZmllbGRDbGFzc1wiPlxyXG4gICAgPG1hdC1sYWJlbD5cclxuICAgICAge3sgZmllbGQubGFiZWwgfX1cclxuICAgIDwvbWF0LWxhYmVsPlxyXG5cclxuICAgIDxtYXQtaGludD5cclxuICAgICAge3sgZmllbGQuaW5mbyB9fVxyXG4gICAgPC9tYXQtaGludD5cclxuXHJcbiAgICA8dGV4dGFyZWEgbWF0SW5wdXRcclxuICAgICAgICAgICAgICAjaW5wdXRcclxuICAgICAgICAgICAgICBbZm9ybUNvbnRyb2xdPVwiZmllbGQuY29udHJvbFwiPlxyXG4gICAgPC90ZXh0YXJlYT5cclxuXHJcbiAgICA8bWF0LWVycm9yICpuZ0lmPVwiYmFzZUNvbnRyb2wuaW5pdGlhbGl6ZWRcIj5cclxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImJhc2VDb250cm9sLmVycm9yc1RlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XHJcbiAgICA8L21hdC1lcnJvcj5cclxuICA8L21hdC1mb3JtLWZpZWxkPlxyXG48L2Jhc2UtY29udHJvbD5cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGFyZWEtY29udHJvbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLWV4dGVuc2lvbnMvY29udHJvbHMvdGV4dGFyZWEtY29udHJvbC90ZXh0YXJlYS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90ZXh0YXJlYS1jb250cm9sL3RleHRhcmVhLWNvbnRyb2wuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7QUFTakQsTUFBTSxPQUFPLHdCQUF3QjtJQUxyQztRQWNTLGVBQVUsR0FBMkIsU0FBUyxDQUFDO0tBQ3ZEOztxSEFWWSx3QkFBd0I7eUdBQXhCLHdCQUF3Qix3SUNUckMsNnFCQXNCQTsyRkRiYSx3QkFBd0I7a0JBTHBDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsV0FBVyxFQUFFLG1DQUFtQztvQkFDaEQsU0FBUyxFQUFFLENBQUMsbUNBQW1DLENBQUM7aUJBQ2pEOzhCQUlRLEtBQUs7c0JBRFgsS0FBSztnQkFJQyxVQUFVO3NCQURoQixLQUFLO2dCQUlDLFVBQVU7c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkQXBwZWFyYW5jZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkXCI7XHJcbmltcG9ydCB7IEZpZWxkIH0gZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9tb2RlbHNcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcInRleHRhcmVhLWNvbnRyb2xcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL3RleHRhcmVhLWNvbnRyb2wuY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vdGV4dGFyZWEtY29udHJvbC5jb21wb25lbnQuc2Nzc1wiXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVGV4dEFyZWFDb250cm9sQ29tcG9uZW50IHtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZmllbGQ6IEZpZWxkPHN0cmluZz47XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGZpZWxkQ2xhc3M6IHN0cmluZztcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgYXBwZWFyYW5jZTogTWF0Rm9ybUZpZWxkQXBwZWFyYW5jZSA9IFwib3V0bGluZVwiO1xyXG59XHJcbiIsIjxiYXNlLWNvbnRyb2wgI2Jhc2VDb250cm9sXHJcbiAgICAgICAgICAgICAgW2ZpZWxkXT1cImZpZWxkXCI+XHJcbiAgPG1hdC1mb3JtLWZpZWxkIFthcHBlYXJhbmNlXT1cImFwcGVhcmFuY2VcIlxyXG4gICAgICAgICAgICAgICAgICBbY2xhc3NdPVwiZmllbGRDbGFzc1wiPlxyXG4gICAgPG1hdC1sYWJlbD5cclxuICAgICAge3sgZmllbGQubGFiZWwgfX1cclxuICAgIDwvbWF0LWxhYmVsPlxyXG5cclxuICAgIDxtYXQtaGludD5cclxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImJhc2VDb250cm9sLmhpbnRUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9tYXQtaGludD5cclxuXHJcbiAgICA8dGV4dGFyZWEgbWF0SW5wdXRcclxuICAgICAgICAgICAgICAjaW5wdXRcclxuICAgICAgICAgICAgICBbZm9ybUNvbnRyb2xdPVwiZmllbGQuY29udHJvbFwiPlxyXG4gICAgPC90ZXh0YXJlYT5cclxuXHJcbiAgICA8bWF0LWVycm9yICpuZ0lmPVwiYmFzZUNvbnRyb2wuaW5pdGlhbGl6ZWRcIj5cclxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImJhc2VDb250cm9sLmVycm9yc1RlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XHJcbiAgICA8L21hdC1lcnJvcj5cclxuICA8L21hdC1mb3JtLWZpZWxkPlxyXG48L2Jhc2UtY29udHJvbD5cclxuIl19

@@ -8,7 +8,7 @@ import { Component, Input, ViewEncapsulation } from "@angular/core";

import * as i5 from "@angular-material-components/datetime-picker";
import * as i6 from "@angular/material/input";
import * as i7 from "angular-extensions/directives";
import * as i8 from "@angular/forms";
import * as i9 from "@angular/material/tooltip";
import * as i10 from "@angular/common";
import * as i6 from "@angular/common";
import * as i7 from "@angular/material/input";
import * as i8 from "angular-extensions/directives";
import * as i9 from "@angular/forms";
import * as i10 from "@angular/material/tooltip";
export class TimeControlComponent {

@@ -31,3 +31,3 @@ constructor(elementRef) {

TimeControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TimeControlComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
TimeControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TimeControlComponent, selector: "time-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", initialTime: "initialTime", clearable: "clearable" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"timePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"'HH:mm'\"\r\n [formControl]=\"field.control\"\r\n [ngxMatDatetimePicker]=\"timePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"$any(timePicker)\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.value != null ? 'close' : 'schedule' }}\r\n </mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #timePicker\r\n panelClass=\"time-picker-container\"\r\n [color]=\"'primary'\"\r\n [stepMinute]=\"15\"\r\n [defaultTime]=\"initialTime\"\r\n (closed)=\"field.control.markAllAsTouched()\">\r\n </ngx-mat-datetime-picker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: ["time-control{display:inline-block}time-control .mat-form-field-flex,time-control .mat-form-field-flex input{cursor:pointer}.time-picker-container{display:none!important}.time-picker-container+.time-container{padding:0 2em}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["startView", "startAt", "defaultColor", "color", "touchUi", "hideTime", "disabled", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime", "calendarHeaderComponent", "panelClass", "dateClass"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i7.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["value", "ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i7.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i7.DateTimePickerDirective, selector: "ngx-mat-datetime-picker" }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], encapsulation: i0.ViewEncapsulation.None });
TimeControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TimeControlComponent, selector: "time-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", initialTime: "initialTime", clearable: "clearable" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"timePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"'HH:mm'\"\r\n [formControl]=\"field.control\"\r\n [ngxMatDatetimePicker]=\"timePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"$any(timePicker)\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.value != null ? 'close' : 'schedule' }}\r\n </mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #timePicker\r\n panelClass=\"time-picker-container\"\r\n [color]=\"'primary'\"\r\n [stepMinute]=\"15\"\r\n [defaultTime]=\"initialTime\"\r\n (closed)=\"field.control.markAllAsTouched()\">\r\n </ngx-mat-datetime-picker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: ["time-control{display:inline-block}time-control .mat-form-field-flex,time-control .mat-form-field-flex input{cursor:pointer}.time-picker-container{display:none!important}.time-picker-container+.time-container{padding:0 2em}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["startView", "startAt", "defaultColor", "color", "touchUi", "hideTime", "disabled", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime", "calendarHeaderComponent", "panelClass", "dateClass"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i8.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["value", "ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i8.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i8.DateTimePickerDirective, selector: "ngx-mat-datetime-picker" }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TimeControlComponent, decorators: [{

@@ -52,2 +52,2 @@ type: Component,

}] } });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90aW1lLWNvbnRyb2wvdGltZS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90aW1lLWNvbnRyb2wvdGltZS1jb250cm9sLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7Ozs7QUFVaEYsTUFBTSxPQUFPLG9CQUFvQjtJQWlCL0IsWUFDRSxVQUFtQztRQVQ5QixlQUFVLEdBQTJCLFNBQVMsQ0FBQztRQVdwRCxVQUFVO2FBQ1AsYUFBYTthQUNiLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxlQUFlLEVBQUUsRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFTSxRQUFRLENBQUMsS0FBaUI7UUFDL0IsSUFBSSxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLElBQUksRUFBRTtZQUM5QyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7WUFFeEIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ3ZCLEtBQUssQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1NBQ2xDO1FBRUEsUUFBUSxDQUFDLGFBQTZCLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDakQsQ0FBQzs7aUhBbENVLG9CQUFvQjtxR0FBcEIsb0JBQW9CLHdMQ1ZqQyxrakRBMENBOzJGRGhDYSxvQkFBb0I7a0JBTmhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLFdBQVcsRUFBRSwrQkFBK0I7b0JBQzVDLFNBQVMsRUFBRSxDQUFDLCtCQUErQixDQUFDO29CQUM1QyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtpQkFDdEM7aUdBSVEsS0FBSztzQkFEWCxLQUFLO2dCQUlDLFVBQVU7c0JBRGhCLEtBQUs7Z0JBSUMsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxXQUFXO3NCQURqQixLQUFLO2dCQUlDLFNBQVM7c0JBRGYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkQXBwZWFyYW5jZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkXCI7XHJcbmltcG9ydCB7IEZpZWxkIH0gZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9tb2RlbHNcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcInRpbWUtY29udHJvbFwiLFxyXG4gIHRlbXBsYXRlVXJsOiBcIi4vdGltZS1jb250cm9sLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgc3R5bGVVcmxzOiBbXCIuL3RpbWUtY29udHJvbC5jb21wb25lbnQuc2Nzc1wiXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVGltZUNvbnRyb2xDb21wb25lbnQge1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZDogRmllbGQ8RGF0ZSB8IG51bGw+O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZENsYXNzOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGFwcGVhcmFuY2U6IE1hdEZvcm1GaWVsZEFwcGVhcmFuY2UgPSBcIm91dGxpbmVcIjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgaW5pdGlhbFRpbWU6IG51bWJlcltdO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjbGVhcmFibGU6IGJvb2xlYW47XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXHJcbiAgKSB7XHJcbiAgICBlbGVtZW50UmVmXHJcbiAgICAgIC5uYXRpdmVFbGVtZW50XHJcbiAgICAgIC5hZGRFdmVudExpc3RlbmVyKFwiYmx1clwiLCBldmVudCA9PiBldmVudC5zdG9wUHJvcGFnYXRpb24oKSwgeyBjYXB0dXJlOiB0cnVlIH0pO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG9uVG9nZ2xlKGV2ZW50OiBNb3VzZUV2ZW50KSB7XHJcbiAgICBpZiAodGhpcy5jbGVhcmFibGUgJiYgdGhpcy5maWVsZC52YWx1ZSAhPSBudWxsKSB7XHJcbiAgICAgIHRoaXMuZmllbGQudmFsdWUgPSBudWxsO1xyXG5cclxuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcclxuICAgICAgZXZlbnQuc3RvcEltbWVkaWF0ZVByb3BhZ2F0aW9uKCk7XHJcbiAgICB9XHJcblxyXG4gICAgKGRvY3VtZW50LmFjdGl2ZUVsZW1lbnQgYXMgSFRNTEVsZW1lbnQpLmJsdXIoKTtcclxuICB9XHJcbn1cclxuIiwiPGJhc2UtY29udHJvbCAjYmFzZUNvbnRyb2xcclxuICAgICAgICAgICAgICBbZmllbGRdPVwiZmllbGRcIj5cclxuICA8bWF0LWZvcm0tZmllbGQgW2FwcGVhcmFuY2VdPVwiYXBwZWFyYW5jZVwiXHJcbiAgICAgICAgICAgICAgICAgIFtjbGFzc109XCJmaWVsZENsYXNzXCJcclxuICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cInRpbWVQaWNrZXIub3BlbigpOyAkZXZlbnQucHJldmVudERlZmF1bHQoKTtcIj5cclxuICAgIDxtYXQtbGFiZWw+XHJcbiAgICAgIHt7IGZpZWxkLmxhYmVsIH19XHJcbiAgICA8L21hdC1sYWJlbD5cclxuXHJcbiAgICA8bWF0LWhpbnQ+XHJcbiAgICAgIHt7IGZpZWxkLmluZm8gfX1cclxuICAgIDwvbWF0LWhpbnQ+XHJcblxyXG4gICAgPGlucHV0IG1hdElucHV0XHJcbiAgICAgICAgICAgI2lucHV0XHJcbiAgICAgICAgICAgcmVhZG9ubHlcclxuICAgICAgICAgICBbZm9ybWF0XT1cIidISDptbSdcIlxyXG4gICAgICAgICAgIFtmb3JtQ29udHJvbF09XCJmaWVsZC5jb250cm9sXCJcclxuICAgICAgICAgICBbbmd4TWF0RGF0ZXRpbWVQaWNrZXJdPVwidGltZVBpY2tlclwiPlxyXG5cclxuICAgIDxtYXQtZGF0ZXBpY2tlci10b2dnbGUgbWF0U3VmZml4XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIFtmb3JdPVwiJGFueSh0aW1lUGlja2VyKVwiPlxyXG4gICAgICA8bWF0LWljb24gbWF0RGF0ZXBpY2tlclRvZ2dsZUljb25cclxuICAgICAgICAgICAgICAgIFttYXRUb29sdGlwXT1cImNsZWFyYWJsZSAmJiBmaWVsZC52YWx1ZSAhPSBudWxsID8gJ0NsZWFyJyA6ICcnXCJcclxuICAgICAgICAgICAgICAgIChjbGljayk9XCJvblRvZ2dsZSgkZXZlbnQpXCI+XHJcbiAgICAgICAge3sgY2xlYXJhYmxlICYmIGZpZWxkLnZhbHVlICE9IG51bGwgPyAnY2xvc2UnIDogJ3NjaGVkdWxlJyB9fVxyXG4gICAgICA8L21hdC1pY29uPlxyXG4gICAgPC9tYXQtZGF0ZXBpY2tlci10b2dnbGU+XHJcblxyXG4gICAgPG5neC1tYXQtZGF0ZXRpbWUtcGlja2VyICN0aW1lUGlja2VyXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFuZWxDbGFzcz1cInRpbWUtcGlja2VyLWNvbnRhaW5lclwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2NvbG9yXT1cIidwcmltYXJ5J1wiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW3N0ZXBNaW51dGVdPVwiMTVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtkZWZhdWx0VGltZV09XCJpbml0aWFsVGltZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGNsb3NlZCk9XCJmaWVsZC5jb250cm9sLm1hcmtBbGxBc1RvdWNoZWQoKVwiPlxyXG4gICAgPC9uZ3gtbWF0LWRhdGV0aW1lLXBpY2tlcj5cclxuXHJcbiAgICA8bWF0LWVycm9yICpuZ0lmPVwiYmFzZUNvbnRyb2wuaW5pdGlhbGl6ZWRcIj5cclxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImJhc2VDb250cm9sLmVycm9yc1RlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XHJcbiAgICA8L21hdC1lcnJvcj5cclxuICA8L21hdC1mb3JtLWZpZWxkPlxyXG48L2Jhc2UtY29udHJvbD5cclxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1jb250cm9sLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90aW1lLWNvbnRyb2wvdGltZS1jb250cm9sLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZXh0ZW5zaW9ucy9jb250cm9scy90aW1lLWNvbnRyb2wvdGltZS1jb250cm9sLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7Ozs7Ozs7QUFVaEYsTUFBTSxPQUFPLG9CQUFvQjtJQWlCL0IsWUFDRSxVQUFtQztRQVQ5QixlQUFVLEdBQTJCLFNBQVMsQ0FBQztRQVdwRCxVQUFVO2FBQ1AsYUFBYTthQUNiLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxlQUFlLEVBQUUsRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFFTSxRQUFRLENBQUMsS0FBaUI7UUFDL0IsSUFBSSxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLElBQUksRUFBRTtZQUM5QyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7WUFFeEIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ3ZCLEtBQUssQ0FBQyx3QkFBd0IsRUFBRSxDQUFDO1NBQ2xDO1FBRUEsUUFBUSxDQUFDLGFBQTZCLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDakQsQ0FBQzs7aUhBbENVLG9CQUFvQjtxR0FBcEIsb0JBQW9CLHdMQ1ZqQyw4bURBMENBOzJGRGhDYSxvQkFBb0I7a0JBTmhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLFdBQVcsRUFBRSwrQkFBK0I7b0JBQzVDLFNBQVMsRUFBRSxDQUFDLCtCQUErQixDQUFDO29CQUM1QyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtpQkFDdEM7aUdBSVEsS0FBSztzQkFEWCxLQUFLO2dCQUlDLFVBQVU7c0JBRGhCLEtBQUs7Z0JBSUMsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxXQUFXO3NCQURqQixLQUFLO2dCQUlDLFNBQVM7c0JBRGYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkQXBwZWFyYW5jZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkXCI7XHJcbmltcG9ydCB7IEZpZWxkIH0gZnJvbSBcImFuZ3VsYXItZXh0ZW5zaW9ucy9tb2RlbHNcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcInRpbWUtY29udHJvbFwiLFxyXG4gIHRlbXBsYXRlVXJsOiBcIi4vdGltZS1jb250cm9sLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgc3R5bGVVcmxzOiBbXCIuL3RpbWUtY29udHJvbC5jb21wb25lbnQuc2Nzc1wiXSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVGltZUNvbnRyb2xDb21wb25lbnQge1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZDogRmllbGQ8RGF0ZSB8IG51bGw+O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZENsYXNzOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGFwcGVhcmFuY2U6IE1hdEZvcm1GaWVsZEFwcGVhcmFuY2UgPSBcIm91dGxpbmVcIjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgaW5pdGlhbFRpbWU6IG51bWJlcltdO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjbGVhcmFibGU6IGJvb2xlYW47XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXHJcbiAgKSB7XHJcbiAgICBlbGVtZW50UmVmXHJcbiAgICAgIC5uYXRpdmVFbGVtZW50XHJcbiAgICAgIC5hZGRFdmVudExpc3RlbmVyKFwiYmx1clwiLCBldmVudCA9PiBldmVudC5zdG9wUHJvcGFnYXRpb24oKSwgeyBjYXB0dXJlOiB0cnVlIH0pO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG9uVG9nZ2xlKGV2ZW50OiBNb3VzZUV2ZW50KSB7XHJcbiAgICBpZiAodGhpcy5jbGVhcmFibGUgJiYgdGhpcy5maWVsZC52YWx1ZSAhPSBudWxsKSB7XHJcbiAgICAgIHRoaXMuZmllbGQudmFsdWUgPSBudWxsO1xyXG5cclxuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcclxuICAgICAgZXZlbnQuc3RvcEltbWVkaWF0ZVByb3BhZ2F0aW9uKCk7XHJcbiAgICB9XHJcblxyXG4gICAgKGRvY3VtZW50LmFjdGl2ZUVsZW1lbnQgYXMgSFRNTEVsZW1lbnQpLmJsdXIoKTtcclxuICB9XHJcbn1cclxuIiwiPGJhc2UtY29udHJvbCAjYmFzZUNvbnRyb2xcclxuICAgICAgICAgICAgICBbZmllbGRdPVwiZmllbGRcIj5cclxuICA8bWF0LWZvcm0tZmllbGQgW2FwcGVhcmFuY2VdPVwiYXBwZWFyYW5jZVwiXHJcbiAgICAgICAgICAgICAgICAgIFtjbGFzc109XCJmaWVsZENsYXNzXCJcclxuICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cInRpbWVQaWNrZXIub3BlbigpOyAkZXZlbnQucHJldmVudERlZmF1bHQoKTtcIj5cclxuICAgIDxtYXQtbGFiZWw+XHJcbiAgICAgIHt7IGZpZWxkLmxhYmVsIH19XHJcbiAgICA8L21hdC1sYWJlbD5cclxuXHJcbiAgICA8bWF0LWhpbnQ+XHJcbiAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJiYXNlQ29udHJvbC5oaW50VGVtcGxhdGVcIj48L25nLWNvbnRhaW5lcj5cclxuICAgIDwvbWF0LWhpbnQ+XHJcblxyXG4gICAgPGlucHV0IG1hdElucHV0XHJcbiAgICAgICAgICAgI2lucHV0XHJcbiAgICAgICAgICAgcmVhZG9ubHlcclxuICAgICAgICAgICBbZm9ybWF0XT1cIidISDptbSdcIlxyXG4gICAgICAgICAgIFtmb3JtQ29udHJvbF09XCJmaWVsZC5jb250cm9sXCJcclxuICAgICAgICAgICBbbmd4TWF0RGF0ZXRpbWVQaWNrZXJdPVwidGltZVBpY2tlclwiPlxyXG5cclxuICAgIDxtYXQtZGF0ZXBpY2tlci10b2dnbGUgbWF0U3VmZml4XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgIFtmb3JdPVwiJGFueSh0aW1lUGlja2VyKVwiPlxyXG4gICAgICA8bWF0LWljb24gbWF0RGF0ZXBpY2tlclRvZ2dsZUljb25cclxuICAgICAgICAgICAgICAgIFttYXRUb29sdGlwXT1cImNsZWFyYWJsZSAmJiBmaWVsZC52YWx1ZSAhPSBudWxsID8gJ0NsZWFyJyA6ICcnXCJcclxuICAgICAgICAgICAgICAgIChjbGljayk9XCJvblRvZ2dsZSgkZXZlbnQpXCI+XHJcbiAgICAgICAge3sgY2xlYXJhYmxlICYmIGZpZWxkLnZhbHVlICE9IG51bGwgPyAnY2xvc2UnIDogJ3NjaGVkdWxlJyB9fVxyXG4gICAgICA8L21hdC1pY29uPlxyXG4gICAgPC9tYXQtZGF0ZXBpY2tlci10b2dnbGU+XHJcblxyXG4gICAgPG5neC1tYXQtZGF0ZXRpbWUtcGlja2VyICN0aW1lUGlja2VyXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcGFuZWxDbGFzcz1cInRpbWUtcGlja2VyLWNvbnRhaW5lclwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2NvbG9yXT1cIidwcmltYXJ5J1wiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW3N0ZXBNaW51dGVdPVwiMTVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtkZWZhdWx0VGltZV09XCJpbml0aWFsVGltZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGNsb3NlZCk9XCJmaWVsZC5jb250cm9sLm1hcmtBbGxBc1RvdWNoZWQoKVwiPlxyXG4gICAgPC9uZ3gtbWF0LWRhdGV0aW1lLXBpY2tlcj5cclxuXHJcbiAgICA8bWF0LWVycm9yICpuZ0lmPVwiYmFzZUNvbnRyb2wuaW5pdGlhbGl6ZWRcIj5cclxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImJhc2VDb250cm9sLmVycm9yc1RlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XHJcbiAgICA8L21hdC1lcnJvcj5cclxuICA8L21hdC1mb3JtLWZpZWxkPlxyXG48L2Jhc2UtY29udHJvbD5cclxuIl19

@@ -5,7 +5,9 @@ import { Subject } from 'rxjs';

import { TemplateRef, Component, ViewEncapsulation, Input, ViewChild, NgModule } from '@angular/core';
import * as i1 from '@angular/common';
import * as i1 from '@angular/material/form-field';
import { MatFormFieldModule } from '@angular/material/form-field';
import * as i2 from '@angular/material/tooltip';
import { MatTooltipModule } from '@angular/material/tooltip';
import * as i3 from '@angular/common';
import { CommonModule } from '@angular/common';
import * as i2 from '@angular/material/form-field';
import { MatFormFieldModule } from '@angular/material/form-field';
import * as i3 from 'angular-extensions/pipes';
import * as i4 from 'angular-extensions/pipes';
import { NgxPipesModule } from 'angular-extensions/pipes';

@@ -45,3 +47,3 @@ import { A11yModule } from '@angular/cdk/a11y';

BaseControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: BaseControlComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
BaseControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: BaseControlComponent, selector: "base-control", inputs: { field: "field" }, viewQueries: [{ propertyName: "errorsTemplate", first: true, predicate: TemplateRef, descendants: true }], ngImport: i0, template: "<ng-content></ng-content>\r\n\r\n<ng-template>\r\n <mat-error *ngIf=\"field.control.errors?.required as error\">\r\n {{ field.validation.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.requiredTrue as error\">\r\n {{ field.validation.requiredTrue?.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.min as error\">\r\n {{ field.validation.min?.text || \"Value should be greater than \" + error.min }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.max as error\">\r\n {{ field.validation.max?.text || \"Value should be smaller than \" + error.max }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minlength as error\">\r\n {{ field.validation.minLength?.text || \"Value should be longer than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxlength as error\">\r\n {{ field.validation.maxLength?.text || \"Value should be shorter than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minDate as error\">\r\n {{ field.validation.minDate?.text || \"Date should be after the \" + (error.minDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minOrEqualDate as error\">\r\n {{ field.validation.minOrEqualDate?.text || \"Date should be same or after the \" + (error.minOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxDate as error\">\r\n {{ field.validation.maxDate?.text || \"Date should be before the \" + (error.maxDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxOrEqualDate as error\">\r\n {{ field.validation.maxOrEqualDate?.text || \"Date should be same or before the \" + (error.maxOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.pattern as error\">\r\n {{ field.validation.pattern?.text || error.message }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.custom as error\">\r\n {{ field.validation.custom?.text || error.message }}\r\n </mat-error>\r\n</ng-template>\r\n", styles: [".control:not(:last-child):not(.d-block){padding-right:1.34375em}.control.d-none{display:none!important}.control.d-block{display:block}.control.d-block mat-form-field{display:block;margin-right:0}.control base-control{font-size:14px}.control base-control mat-form-field{min-width:150px}.control base-control mat-form-field.p-0 .mat-form-field-wrapper{padding:0!important}.control base-control mat-form-field.p-0 .mat-form-field-underline{bottom:0!important}.control base-control mat-form-field .mat-form-field-wrapper{padding-bottom:.25rem}.control base-control mat-form-field .mat-form-field-subscript-wrapper{position:relative}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "date": i3.DatePipe }, encapsulation: i0.ViewEncapsulation.None });
BaseControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: BaseControlComponent, selector: "base-control", inputs: { field: "field" }, viewQueries: [{ propertyName: "hintTemplate", first: true, predicate: TemplateRef, descendants: true }, { propertyName: "errorsTemplate", first: true, predicate: TemplateRef, descendants: true }], ngImport: i0, template: "<ng-content></ng-content>\r\n\r\n<ng-template #hintTemplate>\r\n <mat-hint class=\"text-truncate\"\r\n style=\"cursor: default;\"\r\n [matTooltip]=\"$any(field.info)\">\r\n {{ field.info }}\r\n </mat-hint>\r\n</ng-template>\r\n\r\n<ng-template #errorsTemplate>\r\n <mat-error *ngIf=\"field.control.errors?.required as error\">\r\n {{ field.validation.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.requiredTrue as error\">\r\n {{ field.validation.requiredTrue?.text || \"Field is required\" }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.min as error\">\r\n {{ field.validation.min?.text || \"Value should be greater than \" + error.min }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.max as error\">\r\n {{ field.validation.max?.text || \"Value should be smaller than \" + error.max }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minlength as error\">\r\n {{ field.validation.minLength?.text || \"Value should be longer than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxlength as error\">\r\n {{ field.validation.maxLength?.text || \"Value should be shorter than \" + error.requiredLength }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minDate as error\">\r\n {{ field.validation.minDate?.text || \"Date should be after the \" + (error.minDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.minOrEqualDate as error\">\r\n {{ field.validation.minOrEqualDate?.text || \"Date should be same or after the \" + (error.minOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxDate as error\">\r\n {{ field.validation.maxDate?.text || \"Date should be before the \" + (error.maxDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.maxOrEqualDate as error\">\r\n {{ field.validation.maxOrEqualDate?.text || \"Date should be same or before the \" + (error.maxOrEqualDate | date) }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.pattern as error\">\r\n {{ field.validation.pattern?.text || error.message }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field.control.errors?.custom as error\">\r\n {{ field.validation.custom?.text || error.message }}\r\n </mat-error>\r\n</ng-template>\r\n", styles: [".control:not(:last-child):not(.d-block){padding-right:1.34375em}.control.d-none{display:none!important}.control.d-block{display:block}.control.d-block mat-form-field{display:block;margin-right:0}.control base-control{font-size:14px}.control base-control mat-form-field{min-width:150px}.control base-control mat-form-field.p-0 .mat-form-field-wrapper{padding:0!important}.control base-control mat-form-field.p-0 .mat-form-field-underline{bottom:0!important}.control base-control mat-form-field .mat-form-field-wrapper{padding-bottom:.25rem}.control base-control mat-form-field .mat-form-field-subscript-wrapper{position:relative}.control base-control mat-form-field .mat-hint{display:block;width:100%}\n"], directives: [{ type: i1.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "date": i4.DatePipe }, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: BaseControlComponent, decorators: [{

@@ -57,2 +59,5 @@ type: Component,

type: Input
}], hintTemplate: [{
type: ViewChild,
args: [TemplateRef]
}], errorsTemplate: [{

@@ -72,2 +77,3 @@ type: ViewChild,

MatInputModule,
MatTooltipModule,
NgxPipesModule], exports: [CommonModule,

@@ -79,2 +85,3 @@ A11yModule,

MatInputModule,
MatTooltipModule,
NgxPipesModule,

@@ -89,2 +96,3 @@ BaseControlComponent] });

MatInputModule,
MatTooltipModule,
NgxPipesModule,

@@ -97,2 +105,3 @@ ], CommonModule,

MatInputModule,
MatTooltipModule,
NgxPipesModule] });

@@ -109,2 +118,3 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: NgxBaseControlModule, decorators: [{

MatInputModule,
MatTooltipModule,
NgxPipesModule,

@@ -122,2 +132,3 @@ ],

MatInputModule,
MatTooltipModule,
NgxPipesModule,

@@ -124,0 +135,0 @@ BaseControlComponent,

import * as i0 from '@angular/core';
import { Component, ViewChild, Input, NgModule } from '@angular/core';
import * as i6 from '@angular/material/input';
import * as i7 from '@angular/material/input';
import { MatInput } from '@angular/material/input';

@@ -12,5 +12,6 @@ import * as i1 from 'angular-extensions/controls/base-control';

import { CommonModule } from '@angular/common';
import * as i7 from 'ngx-mask';
import * as i6 from '@angular/material/tooltip';
import * as i8 from 'ngx-mask';
import { NgxMaskModule } from 'ngx-mask';
import * as i8 from '@angular/forms';
import * as i9 from '@angular/forms';

@@ -27,3 +28,3 @@ class TextControlComponent {

TextControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TextControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
TextControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextControlComponent, selector: "text-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", type: "type", mask: "mask", prefix: "prefix", showMaskTyped: "showMaskTyped", focused: "focused", icon: "icon", clearable: "clearable" }, viewQueries: [{ propertyName: "input", first: true, predicate: MatInput, descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field cdkTrapFocus\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n [cdkTrapFocusAutoCapture]=\"focused\"\r\n (click)=\"input.focus()\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <mat-icon *ngIf=\"icon\"\r\n matPrefix>{{icon}}</mat-icon>\r\n\r\n <button mat-icon-button\r\n *ngIf=\"field.value && clearable\"\r\n matSuffix\r\n aria-label=\"Clear\"\r\n matTooltip=\"Clear\"\r\n (click)=\"field.value = ''\"\r\n type=\"button\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngIf=\"mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [prefix]=\"prefix\"\r\n [mask]=\"mask\"\r\n [showMaskTyped]=\"showMaskTyped\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i4.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatPrefix, selector: "[matPrefix]" }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i7.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
TextControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextControlComponent, selector: "text-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", type: "type", mask: "mask", prefix: "prefix", showMaskTyped: "showMaskTyped", focused: "focused", icon: "icon", clearable: "clearable" }, viewQueries: [{ propertyName: "input", first: true, predicate: MatInput, descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field cdkTrapFocus\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n [cdkTrapFocusAutoCapture]=\"focused\"\r\n (click)=\"input.focus()\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <mat-icon *ngIf=\"icon\"\r\n matPrefix>{{icon}}</mat-icon>\r\n\r\n <button mat-icon-button\r\n *ngIf=\"field.value && clearable\"\r\n matSuffix\r\n aria-label=\"Clear\"\r\n matTooltip=\"Clear\"\r\n (click)=\"field.value = ''\"\r\n type=\"button\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngIf=\"mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [prefix]=\"prefix\"\r\n [mask]=\"mask\"\r\n [showMaskTyped]=\"showMaskTyped\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!mask\">\r\n <input #input\r\n matInput\r\n cdkFocusInitial\r\n [attr.inputmode]=\"type == 'number' ? 'decimal' : null\"\r\n [type]=\"type\"\r\n [formControl]=\"field.control\">\r\n </ng-container>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i4.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatPrefix, selector: "[matPrefix]" }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i8.MaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TextControlComponent, decorators: [{

@@ -65,3 +66,3 @@ type: Component,

NgxTextControlModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: NgxTextControlModule, declarations: [TextControlComponent], imports: [CommonModule,
NgxBaseControlModule, i7.NgxMaskModule], exports: [CommonModule,
NgxBaseControlModule, i8.NgxMaskModule], exports: [CommonModule,
NgxBaseControlModule,

@@ -68,0 +69,0 @@ NgxMaskModule,

@@ -6,6 +6,6 @@ import * as i0 from '@angular/core';

import * as i2 from '@angular/material/form-field';
import * as i3 from '@angular/material/input';
import * as i4 from '@angular/forms';
import * as i5 from '@angular/common';
import * as i3 from '@angular/common';
import { CommonModule } from '@angular/common';
import * as i4 from '@angular/material/input';
import * as i5 from '@angular/forms';

@@ -18,3 +18,3 @@ class TextAreaControlComponent {

TextAreaControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TextAreaControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
TextAreaControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextAreaControlComponent, selector: "textarea-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <textarea matInput\r\n #input\r\n [formControl]=\"field.control\">\r\n </textarea>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:block}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
TextAreaControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TextAreaControlComponent, selector: "textarea-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <textarea matInput\r\n #input\r\n [formControl]=\"field.control\">\r\n </textarea>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:block}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TextAreaControlComponent, decorators: [{

@@ -21,0 +21,0 @@ type: Component,

@@ -16,11 +16,11 @@ import * as i1 from 'angular-extensions/controls/base-control';

import * as i4 from '@angular/material/icon';
import * as i6 from '@angular/material/input';
import * as i7 from 'angular-extensions/directives';
import * as i6 from '@angular/common';
import { CommonModule } from '@angular/common';
import * as i7 from '@angular/material/input';
import * as i8 from 'angular-extensions/directives';
import { NgxDirectivesModule } from 'angular-extensions/directives';
import * as i8 from '@angular/forms';
import * as i9 from '@angular/forms';
import { FormControl } from '@angular/forms';
import * as i9 from '@angular/material/tooltip';
import * as i10 from '@angular/material/tooltip';
import { MatTooltipModule } from '@angular/material/tooltip';
import * as i10 from '@angular/common';
import { CommonModule } from '@angular/common';
import * as i5 from '@angular-material-components/datetime-picker';

@@ -108,3 +108,3 @@ import { NgxMatNativeDateAdapter, NgxMatDateAdapter, NGX_MAT_DATE_FORMATS, NgxMatDatetimePickerModule, NgxMatTimepickerModule } from '@angular-material-components/datetime-picker';

DateControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: DateControlComponent, deps: [{ token: i0.ElementRef }, { token: MAT_DATE_FORMATS }], target: i0.ɵɵFactoryTarget.Component });
DateControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: DateControlComponent, selector: "date-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", targetView: "targetView", startView: "startView", format: "format", clearable: "clearable" }, usesOnChanges: true, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field class=\"cursor-pointer\"\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"datePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"format\"\r\n [formControl]=\"field.control\"\r\n [matDatepicker]=\"datePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"datePicker\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <mat-datepicker #datePicker\r\n [startView]=\"startView\"\r\n (viewChanged)=\"viewChanged($event, datePicker)\"\r\n (monthSelected)=\"monthSelected($event, datePicker)\"\r\n (closed)=\"field.control.markAllAsTouched()\"></mat-datepicker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}:host ::ng-deep input{cursor:pointer}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i7.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i7.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
DateControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: DateControlComponent, selector: "date-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", targetView: "targetView", startView: "startView", format: "format", clearable: "clearable" }, usesOnChanges: true, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field class=\"cursor-pointer\"\r\n [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"datePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"format\"\r\n [formControl]=\"field.control\"\r\n [matDatepicker]=\"datePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"datePicker\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <mat-datepicker #datePicker\r\n [startView]=\"startView\"\r\n (viewChanged)=\"viewChanged($event, datePicker)\"\r\n (monthSelected)=\"monthSelected($event, datePicker)\"\r\n (closed)=\"field.control.markAllAsTouched()\"></mat-datepicker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: [":host{display:inline-block}:host ::ng-deep input{cursor:pointer}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i8.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i8.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: DateControlComponent, decorators: [{

@@ -153,3 +153,3 @@ type: Component,

TimeControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TimeControlComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
TimeControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TimeControlComponent, selector: "time-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", initialTime: "initialTime", clearable: "clearable" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"timePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"'HH:mm'\"\r\n [formControl]=\"field.control\"\r\n [ngxMatDatetimePicker]=\"timePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"$any(timePicker)\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.value != null ? 'close' : 'schedule' }}\r\n </mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #timePicker\r\n panelClass=\"time-picker-container\"\r\n [color]=\"'primary'\"\r\n [stepMinute]=\"15\"\r\n [defaultTime]=\"initialTime\"\r\n (closed)=\"field.control.markAllAsTouched()\">\r\n </ngx-mat-datetime-picker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: ["time-control{display:inline-block}time-control .mat-form-field-flex,time-control .mat-form-field-flex input{cursor:pointer}.time-picker-container{display:none!important}.time-picker-container+.time-container{padding:0 2em}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["startView", "startAt", "defaultColor", "color", "touchUi", "hideTime", "disabled", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime", "calendarHeaderComponent", "panelClass", "dateClass"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i7.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["value", "ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i7.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i7.DateTimePickerDirective, selector: "ngx-mat-datetime-picker" }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], encapsulation: i0.ViewEncapsulation.None });
TimeControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: TimeControlComponent, selector: "time-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", initialTime: "initialTime", clearable: "clearable" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"timePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"'HH:mm'\"\r\n [formControl]=\"field.control\"\r\n [ngxMatDatetimePicker]=\"timePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"$any(timePicker)\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.value != null ? 'close' : 'schedule' }}\r\n </mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #timePicker\r\n panelClass=\"time-picker-container\"\r\n [color]=\"'primary'\"\r\n [stepMinute]=\"15\"\r\n [defaultTime]=\"initialTime\"\r\n (closed)=\"field.control.markAllAsTouched()\">\r\n </ngx-mat-datetime-picker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: ["time-control{display:inline-block}time-control .mat-form-field-flex,time-control .mat-form-field-flex input{cursor:pointer}.time-picker-container{display:none!important}.time-picker-container+.time-container{padding:0 2em}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["startView", "startAt", "defaultColor", "color", "touchUi", "hideTime", "disabled", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime", "calendarHeaderComponent", "panelClass", "dateClass"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i8.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["value", "ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i8.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i8.DateTimePickerDirective, selector: "ngx-mat-datetime-picker" }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: TimeControlComponent, decorators: [{

@@ -196,3 +196,3 @@ type: Component,

DateTimeControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: DateTimeControlComponent, deps: [{ token: i0.ElementRef }, { token: MAT_DATE_FORMATS }], target: i0.ɵɵFactoryTarget.Component });
DateTimeControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: DateTimeControlComponent, selector: "datetime-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", initialTime: "initialTime", clearable: "clearable", disableMinute: "disableMinute", showSeconds: "showSeconds", format: "format" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"dateTimePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"format\"\r\n [formControl]=\"field.control\"\r\n [ngxMatDatetimePicker]=\"dateTimePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"$any(dateTimePicker)\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.control.enabled && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.control.enabled && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #dateTimePicker\r\n [color]=\"'primary'\"\r\n [stepMinute]=\"15\"\r\n [disableMinute]=\"disableMinute\"\r\n [defaultTime]=\"initialTime\"\r\n [showSeconds]=\"showSeconds\"\r\n (closed)=\"field.control.markAllAsTouched()\">\r\n </ngx-mat-datetime-picker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: ["datetime-control{display:inline-block}datetime-control .mat-form-field-flex,datetime-control .mat-form-field-flex input{cursor:pointer}ngx-mat-calendar{height:354px}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["startView", "startAt", "defaultColor", "color", "touchUi", "hideTime", "disabled", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime", "calendarHeaderComponent", "panelClass", "dateClass"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i7.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["value", "ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i7.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i7.DateTimePickerDirective, selector: "ngx-mat-datetime-picker" }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], encapsulation: i0.ViewEncapsulation.None });
DateTimeControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: DateTimeControlComponent, selector: "datetime-control", inputs: { field: "field", fieldClass: "fieldClass", appearance: "appearance", initialTime: "initialTime", clearable: "clearable", disableMinute: "disableMinute", showSeconds: "showSeconds", format: "format" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\"\r\n (click)=\"dateTimePicker.open(); $event.preventDefault();\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <input matInput\r\n #input\r\n readonly\r\n [format]=\"format\"\r\n [formControl]=\"field.control\"\r\n [ngxMatDatetimePicker]=\"dateTimePicker\">\r\n\r\n <mat-datepicker-toggle matSuffix\r\n [for]=\"$any(dateTimePicker)\">\r\n <mat-icon matDatepickerToggleIcon\r\n [matTooltip]=\"clearable && field.control.enabled && field.value != null ? 'Clear' : ''\"\r\n (click)=\"onToggle($event)\">\r\n {{ clearable && field.control.enabled && field.value != null ? 'close' : 'today' }}</mat-icon>\r\n </mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #dateTimePicker\r\n [color]=\"'primary'\"\r\n [stepMinute]=\"15\"\r\n [disableMinute]=\"disableMinute\"\r\n [defaultTime]=\"initialTime\"\r\n [showSeconds]=\"showSeconds\"\r\n (closed)=\"field.control.markAllAsTouched()\">\r\n </ngx-mat-datetime-picker>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n", styles: ["datetime-control{display:inline-block}datetime-control .mat-form-field-flex,datetime-control .mat-form-field-flex input{cursor:pointer}ngx-mat-calendar{height:354px}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i3.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["tabIndex", "disabled", "for", "aria-label", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["startView", "startAt", "defaultColor", "color", "touchUi", "hideTime", "disabled", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime", "calendarHeaderComponent", "panelClass", "dateClass"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i8.FormatDirective, selector: "input[format]", inputs: ["format"] }, { type: i9.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["value", "ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i3.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { type: i8.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i8.DateTimePickerDirective, selector: "ngx-mat-datetime-picker" }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: DateTimeControlComponent, decorators: [{

@@ -234,3 +234,3 @@ type: Component,

SpinnerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: SpinnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
SpinnerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: SpinnerComponent, selector: "spinner", inputs: { type: "type", loading: "loading", size: "size" }, queries: [{ propertyName: "contentTemplate", first: true, predicate: TemplateRef, descendants: true }], ngImport: i0, template: "<ng-content></ng-content>\r\n\r\n<div *ngIf=\"loading\">\r\n <mat-progress-bar *ngIf=\"type == 'small'\"\r\n mode=\"indeterminate\"></mat-progress-bar>\r\n\r\n <mat-spinner *ngIf=\"type == 'big'\"\r\n [diameter]=\"size\"\r\n mode=\"indeterminate\"></mat-spinner>\r\n</div>\r\n\r\n<ng-container *ngIf=\"!loading && contentTemplate\">\r\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\r\n</ng-container>\r\n", styles: [":host{display:block}:host mat-spinner{margin:0 auto}\n"], components: [{ type: i1$1.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "mode", "value", "bufferValue"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { type: i2$1.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
SpinnerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: SpinnerComponent, selector: "spinner", inputs: { type: "type", loading: "loading", size: "size" }, queries: [{ propertyName: "contentTemplate", first: true, predicate: TemplateRef, descendants: true }], ngImport: i0, template: "<ng-content></ng-content>\r\n\r\n<div *ngIf=\"loading\">\r\n <mat-progress-bar *ngIf=\"type == 'small'\"\r\n mode=\"indeterminate\"></mat-progress-bar>\r\n\r\n <mat-spinner *ngIf=\"type == 'big'\"\r\n [diameter]=\"size\"\r\n mode=\"indeterminate\"></mat-spinner>\r\n</div>\r\n\r\n<ng-container *ngIf=\"!loading && contentTemplate\">\r\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\r\n</ng-container>\r\n", styles: [":host{display:block}:host mat-spinner{margin:0 auto}\n"], components: [{ type: i1$1.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "mode", "value", "bufferValue"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { type: i2$1.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: SpinnerComponent, decorators: [{

@@ -411,3 +411,3 @@ type: Component,

SelectControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: SelectControlComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1$3.MatMenuTrigger, optional: true }], target: i0.ɵɵFactoryTarget.Component });
SelectControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: SelectControlComponent, selector: "select-control", inputs: { field: "field", fieldClass: "fieldClass", dropdownClass: "dropdownClass", appearance: "appearance", multiple: "multiple", searchable: "searchable", clearable: "clearable", showSelectAll: "showSelectAll", tooltipDisabled: "tooltipDisabled", filter: "filter" }, queries: [{ propertyName: "optionTemplate", first: true, predicate: ["optionTemplate"], descendants: true, static: true }, { propertyName: "triggerTemplate", first: true, predicate: ["triggerTemplate"], descendants: true, static: true }], viewQueries: [{ propertyName: "select", first: true, predicate: ["select"], descendants: true, static: true }, { propertyName: "selectAllOption", first: true, predicate: ["selectAllOption"], descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n {{ field.info }}\r\n </mat-hint>\r\n\r\n <mat-select #select\r\n [panelClass]=\"'custom-scroll ' + dropdownClass\"\r\n [ngClass]=\"{ loading: field.isQuerying }\"\r\n [matTooltipDisabled]=\"tooltipDisabled\"\r\n [matTooltip]=\"select.triggerValue\"\r\n [formControl]=\"field.control\"\r\n [disableOptionCentering]=\"searchable\"\r\n [compareWith]=\"optionComparer\"\r\n [multiple]=\"multiple\">\r\n\r\n <mat-select-trigger *ngIf=\"triggerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"triggerTemplate; context: { $implicit: select.triggerValue, label: triggerLabel, option: selectedOption }\"></ng-container>\r\n </mat-select-trigger>\r\n\r\n <mat-option *ngIf=\"searchable\">\r\n <ngx-mat-select-search placeholderLabel=\"Search\"\r\n [noEntriesFoundLabel]=\"$any(null)\"\r\n [formControl]=\"filterControl\"\r\n [searching]=\"field.isQuerying\"></ngx-mat-select-search>\r\n </mat-option>\r\n\r\n <mat-option #selectAllOption\r\n *ngIf=\"multiple && showSelectAll && !filterControl.value\">\r\n All\r\n </mat-option>\r\n\r\n <ng-container *ngIf=\"field.options | filter : field.optionsFilterPredicate : filterControl.value as options\">\r\n <ng-container *ngIf=\"options.length; else noItemsTemplate\">\r\n <ng-container *ngIf=\"field.optionsGroupProvider\">\r\n <mat-optgroup *ngFor=\"let group of options | groupBy : field.optionsGroupProvider\"\r\n [label]=\"group.key | map : field.optionGroupLabel\">\r\n <mat-option *ngFor=\"let option of group.items; trackBy : optionTracker\"\r\n [matTooltip]=\"option | map : field.optionLabel\"\r\n [context]=\"option\"\r\n [value]=\"option | map : field.optionValue\"\r\n [disabled]=\"option | map : field.optionDisabled\">\r\n <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n </mat-option>\r\n </mat-optgroup>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!field.optionsGroupProvider\">\r\n <mat-option *ngFor=\"let option of options; trackBy : optionTracker\"\r\n [matTooltip]=\"option | map : field.optionLabel\"\r\n [context]=\"option\"\r\n [value]=\"option | map : field.optionValue\"\r\n [disabled]=\"option | map : field.optionDisabled\">\r\n <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n </mat-option>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </mat-select>\r\n\r\n <span matSuffix\r\n *ngIf=\"field.isQuerying\">\r\n <spinner [loading]=\"field.isQuerying\"\r\n [size]=\"20\"></spinner>\r\n </span>\r\n\r\n <button *ngIf=\"!multiple && clearable && field.value != null && !field.isQuerying\"\r\n mat-button\r\n matSuffix\r\n mat-icon-button\r\n matTooltip=\"Clear\"\r\n (click)=\"$any(field).value = null; $event.stopPropagation()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n\r\n<ng-template #noItemsTemplate>\r\n <mat-option *ngIf=\"field.isQuerying\"\r\n [disabled]=\"true\">Loading...</mat-option>\r\n\r\n <mat-option *ngIf=\"!field.isQuerying && !filterControl.value && searchable\"\r\n [disabled]=\"true\">Type to search items</mat-option>\r\n\r\n <mat-option *ngIf=\"!field.isQuerying && filterControl.value\"\r\n [disabled]=\"true\">No items found</mat-option>\r\n</ng-template>\r\n\r\n<ng-template #defaultOptionTempalte\r\n let-label\r\n let-option=\"option\">\r\n {{ label }}\r\n</ng-template>\r\n", styles: [":host{display:inline-block}:host ::ng-deep mat-select.loading .mat-select-arrow{color:transparent!important}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i4$1.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i1$2.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i6$1.MatSelectSearchComponent, selector: "ngx-mat-select-search", inputs: ["placeholderLabel", "type", "noEntriesFoundLabel", "indexAndLengthScreenReaderText", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toogleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { type: i1$2.MatOptgroup, selector: "mat-optgroup", inputs: ["disabled"], exportAs: ["matOptgroup"] }, { type: SpinnerComponent, selector: "spinner", inputs: ["type", "loading", "size"] }, { type: i8$1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i10.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4$1.MatSelectTrigger, selector: "mat-select-trigger" }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: OptionContextDirective, selector: "mat-option[context]", inputs: ["context"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "filter": i15.FilterPipe, "map": i15.MapPipe, "groupBy": i15.GroupByPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
SelectControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: SelectControlComponent, selector: "select-control", inputs: { field: "field", fieldClass: "fieldClass", dropdownClass: "dropdownClass", appearance: "appearance", multiple: "multiple", searchable: "searchable", clearable: "clearable", showSelectAll: "showSelectAll", tooltipDisabled: "tooltipDisabled", filter: "filter" }, queries: [{ propertyName: "optionTemplate", first: true, predicate: ["optionTemplate"], descendants: true, static: true }, { propertyName: "triggerTemplate", first: true, predicate: ["triggerTemplate"], descendants: true, static: true }], viewQueries: [{ propertyName: "select", first: true, predicate: ["select"], descendants: true, static: true }, { propertyName: "selectAllOption", first: true, predicate: ["selectAllOption"], descendants: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-form-field [appearance]=\"appearance\"\r\n [class]=\"fieldClass\">\r\n <mat-label>\r\n {{ field.label }}\r\n </mat-label>\r\n\r\n <mat-hint>\r\n <ng-container *ngTemplateOutlet=\"baseControl.hintTemplate\"></ng-container>\r\n </mat-hint>\r\n\r\n <mat-select #select\r\n [panelClass]=\"'custom-scroll ' + dropdownClass\"\r\n [ngClass]=\"{ loading: field.isQuerying }\"\r\n [matTooltipDisabled]=\"tooltipDisabled\"\r\n [matTooltip]=\"select.triggerValue\"\r\n [formControl]=\"field.control\"\r\n [disableOptionCentering]=\"searchable\"\r\n [compareWith]=\"optionComparer\"\r\n [multiple]=\"multiple\">\r\n\r\n <mat-select-trigger *ngIf=\"triggerTemplate\">\r\n <ng-container *ngTemplateOutlet=\"triggerTemplate; context: { $implicit: select.triggerValue, label: triggerLabel, option: selectedOption }\"></ng-container>\r\n </mat-select-trigger>\r\n\r\n <mat-option *ngIf=\"searchable\">\r\n <ngx-mat-select-search placeholderLabel=\"Search\"\r\n [noEntriesFoundLabel]=\"$any(null)\"\r\n [formControl]=\"filterControl\"\r\n [searching]=\"field.isQuerying\"></ngx-mat-select-search>\r\n </mat-option>\r\n\r\n <mat-option #selectAllOption\r\n *ngIf=\"multiple && showSelectAll && !filterControl.value\">\r\n All\r\n </mat-option>\r\n\r\n <ng-container *ngIf=\"field.options | filter : field.optionsFilterPredicate : filterControl.value as options\">\r\n <ng-container *ngIf=\"options.length; else noItemsTemplate\">\r\n <ng-container *ngIf=\"field.optionsGroupProvider\">\r\n <mat-optgroup *ngFor=\"let group of options | groupBy : field.optionsGroupProvider\"\r\n [label]=\"group.key | map : field.optionGroupLabel\">\r\n <mat-option *ngFor=\"let option of group.items; trackBy : optionTracker\"\r\n [matTooltip]=\"option | map : field.optionLabel\"\r\n [context]=\"option\"\r\n [value]=\"option | map : field.optionValue\"\r\n [disabled]=\"option | map : field.optionDisabled\">\r\n <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n </mat-option>\r\n </mat-optgroup>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!field.optionsGroupProvider\">\r\n <mat-option *ngFor=\"let option of options; trackBy : optionTracker\"\r\n [matTooltip]=\"option | map : field.optionLabel\"\r\n [context]=\"option\"\r\n [value]=\"option | map : field.optionValue\"\r\n [disabled]=\"option | map : field.optionDisabled\">\r\n <ng-container *ngTemplateOutlet=\"optionTemplate || defaultOptionTempalte;\r\n context: { $implicit: option | map : field.optionLabel, option: option }\"></ng-container>\r\n </mat-option>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </mat-select>\r\n\r\n <span matSuffix\r\n *ngIf=\"field.isQuerying\">\r\n <spinner [loading]=\"field.isQuerying\"\r\n [size]=\"20\"></spinner>\r\n </span>\r\n\r\n <button *ngIf=\"!multiple && clearable && field.value != null && !field.isQuerying\"\r\n mat-button\r\n matSuffix\r\n mat-icon-button\r\n matTooltip=\"Clear\"\r\n (click)=\"$any(field).value = null; $event.stopPropagation()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n\r\n <mat-error *ngIf=\"baseControl.initialized\">\r\n <ng-container *ngTemplateOutlet=\"baseControl.errorsTemplate\"></ng-container>\r\n </mat-error>\r\n </mat-form-field>\r\n</base-control>\r\n\r\n<ng-template #noItemsTemplate>\r\n <mat-option *ngIf=\"field.isQuerying\"\r\n [disabled]=\"true\">Loading...</mat-option>\r\n\r\n <mat-option *ngIf=\"!field.isQuerying && !filterControl.value && searchable\"\r\n [disabled]=\"true\">Type to search items</mat-option>\r\n\r\n <mat-option *ngIf=\"!field.isQuerying && filterControl.value\"\r\n [disabled]=\"true\">No items found</mat-option>\r\n</ng-template>\r\n\r\n<ng-template #defaultOptionTempalte\r\n let-label\r\n let-option=\"option\">\r\n {{ label }}\r\n</ng-template>\r\n", styles: [":host{display:inline-block}:host ::ng-deep mat-select.loading .mat-select-arrow{color:transparent!important}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i4$1.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i1$2.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i6$1.MatSelectSearchComponent, selector: "ngx-mat-select-search", inputs: ["placeholderLabel", "type", "noEntriesFoundLabel", "indexAndLengthScreenReaderText", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toogleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { type: i1$2.MatOptgroup, selector: "mat-optgroup", inputs: ["disabled"], exportAs: ["matOptgroup"] }, { type: SpinnerComponent, selector: "spinner", inputs: ["type", "loading", "size"] }, { type: i8$1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.MatLabel, selector: "mat-label" }, { type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i8.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4$1.MatSelectTrigger, selector: "mat-select-trigger" }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: OptionContextDirective, selector: "mat-option[context]", inputs: ["context"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }, { type: i2.MatError, selector: "mat-error", inputs: ["id"] }], pipes: { "filter": i15.FilterPipe, "map": i15.MapPipe, "groupBy": i15.GroupByPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: SelectControlComponent, decorators: [{

@@ -460,3 +460,3 @@ type: Component,

CheckboxControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: CheckboxControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
CheckboxControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: CheckboxControlComponent, selector: "checkbox-control", inputs: { field: "field", fieldClass: "fieldClass" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-checkbox [formControl]=\"field.control\">\r\n {{ field.label }}&nbsp;\r\n\r\n <mat-icon *ngIf=\"field.info\"\r\n class=\"align-middle\"\r\n style=\"font-size: 1.25em;\"\r\n [inline]=\"true\"\r\n [matTooltip]=\"field.info\">info_outline</mat-icon>\r\n </mat-checkbox>\r\n</base-control>\r\n", styles: [":host{display:block;padding-bottom:1.34375em}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2$2.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
CheckboxControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: CheckboxControlComponent, selector: "checkbox-control", inputs: { field: "field", fieldClass: "fieldClass" }, ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <mat-checkbox [formControl]=\"field.control\">\r\n {{ field.label }}&nbsp;\r\n\r\n <mat-icon *ngIf=\"field.info\"\r\n class=\"align-middle\"\r\n style=\"font-size: 1.25em;\"\r\n [inline]=\"true\"\r\n [matTooltip]=\"field.info\">info_outline</mat-icon>\r\n </mat-checkbox>\r\n</base-control>\r\n", styles: [":host{display:block;padding-bottom:1.34375em}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i2$2.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i9.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: CheckboxControlComponent, decorators: [{

@@ -482,3 +482,3 @@ type: Component,

CollectionControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: CollectionControlComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
CollectionControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: CollectionControlComponent, selector: "collection-control", inputs: { field: "field", fieldClass: "fieldClass" }, outputs: { add: "add", remove: "remove" }, queries: [{ propertyName: "itemTemplate", first: true, predicate: ["itemTemplate"], descendants: true, static: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <ng-container *ngFor=\"let editor of field.value\"\r\n class=\"bootstrap\">\r\n <div class=\"row inputs\">\r\n\r\n <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: editor }\">\r\n </ng-container>\r\n\r\n <div class=\"col-md-2 input-actions\">\r\n <button mat-icon-button\r\n type=\"button\"\r\n [matTooltip]=\"'Add'\"\r\n (click)=\"add.emit()\">\r\n <mat-icon color=\"primary\">add</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngIf=\"field.value.length > 1\">\r\n <button mat-icon-button\r\n type=\"button\"\r\n [matTooltip]=\"'Delete'\"\r\n (click)=\"remove.emit(editor.form)\">\r\n <mat-icon color=\"warn\">delete</mat-icon>\r\n </button>\r\n </ng-container>\r\n </div>\r\n\r\n </div>\r\n </ng-container>\r\n</base-control>\r\n", styles: [":host .inputs{align-items:baseline}:host .inputs .input-actions{padding:0;display:flex}:host .inputs .input-actions button{border-radius:50%}:host .inputs .input-actions button mat-icon{margin:0}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i8$1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
CollectionControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.9", type: CollectionControlComponent, selector: "collection-control", inputs: { field: "field", fieldClass: "fieldClass" }, outputs: { add: "add", remove: "remove" }, queries: [{ propertyName: "itemTemplate", first: true, predicate: ["itemTemplate"], descendants: true, static: true }], ngImport: i0, template: "<base-control #baseControl\r\n [field]=\"field\">\r\n <ng-container *ngFor=\"let editor of field.value\"\r\n class=\"bootstrap\">\r\n <div class=\"row inputs\">\r\n\r\n <ng-container *ngTemplateOutlet=\"itemTemplate; context: { $implicit: editor }\">\r\n </ng-container>\r\n\r\n <div class=\"col-md-2 input-actions\">\r\n <button mat-icon-button\r\n type=\"button\"\r\n [matTooltip]=\"'Add'\"\r\n (click)=\"add.emit()\">\r\n <mat-icon color=\"primary\">add</mat-icon>\r\n </button>\r\n\r\n <ng-container *ngIf=\"field.value.length > 1\">\r\n <button mat-icon-button\r\n type=\"button\"\r\n [matTooltip]=\"'Delete'\"\r\n (click)=\"remove.emit(editor.form)\">\r\n <mat-icon color=\"warn\">delete</mat-icon>\r\n </button>\r\n </ng-container>\r\n </div>\r\n\r\n </div>\r\n </ng-container>\r\n</base-control>\r\n", styles: [":host .inputs{align-items:baseline}:host .inputs .input-actions{padding:0;display:flex}:host .inputs .input-actions button{border-radius:50%}:host .inputs .input-actions button mat-icon{margin:0}\n"], components: [{ type: i1.BaseControlComponent, selector: "base-control", inputs: ["field"] }, { type: i8$1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i8.TooltipImprovementsDirective, selector: "[matTooltip]" }, { type: i10.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImport: i0, type: CollectionControlComponent, decorators: [{

@@ -485,0 +485,0 @@ type: Component,

{
"name": "angular-extensions",
"version": "1.0.20",
"version": "1.0.21",
"repository": "https://github.com/nazar-kuzo/angular-extensions.git",

@@ -5,0 +5,0 @@ "author": "Nazar Kuzo",

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 too big to display

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

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

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

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc