@testgorilla/tgo-ui 2.29.6 → 2.29.7-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  import { EventEmitter, OnInit, SimpleChanges } from '@angular/core';
2
- import { AbstractControl, ControlValueAccessor, FormBuilder, FormControl, NgControl } from '@angular/forms';
2
+ import { AbstractControl, ControlValueAccessor, FormBuilder, FormControl, NgControl, ValidatorFn } from '@angular/forms';
3
3
  import { ApplicationTheme } from '../../models/application-theme.model';
4
4
  import { MultiInputValue } from './multi-input.model';
5
5
  import * as i0 from "@angular/core";
@@ -57,11 +57,11 @@ export declare class MultiInputComponent implements ControlValueAccessor, OnInit
57
57
  */
58
58
  label: string;
59
59
  /**
60
- *
61
- * @description Defines the placeholder of the multi input
62
- * @type {string}
63
- * @memberof MultiInputComponent
64
- */
60
+ *
61
+ * @description Defines the placeholder of the multi input
62
+ * @type {string}
63
+ * @memberof MultiInputComponent
64
+ */
65
65
  placeholder: string;
66
66
  /**
67
67
  *
@@ -112,6 +112,13 @@ export declare class MultiInputComponent implements ControlValueAccessor, OnInit
112
112
  * @memberof MultiInputComponent
113
113
  */
114
114
  maxCharacters: number;
115
+ /**
116
+ *
117
+ * @description The validators to apply to input field
118
+ * @type {Validators[]}
119
+ * @memberof MultiInputComponent
120
+ */
121
+ validators: ValidatorFn[];
115
122
  /**
116
123
  *
117
124
  * @description The width of the multi input
@@ -154,7 +161,7 @@ export declare class MultiInputComponent implements ControlValueAccessor, OnInit
154
161
  private addValidation;
155
162
  private updateDisableState;
156
163
  static ɵfac: i0.ɵɵFactoryDeclaration<MultiInputComponent, [{ optional: true; self: true; }, { optional: true; }, null]>;
157
- static ɵcmp: i0.ɵɵComponentDeclaration<MultiInputComponent, "ui-multi-input", never, { "itemsList": { "alias": "itemsList"; "required": true; }; "itemTextField": { "alias": "itemTextField"; "required": true; }; "itemValueField": { "alias": "itemValueField"; "required": true; }; "value": { "alias": "value"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "required": { "alias": "required"; "required": false; }; "label": { "alias": "label"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "allowDecimal": { "alias": "allowDecimal"; "required": false; }; "allowNegative": { "alias": "allowNegative"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "errors": { "alias": "errors"; "required": false; }; "hideBuiltInErrors": { "alias": "hideBuiltInErrors"; "required": false; }; "hideLabelInErrors": { "alias": "hideLabelInErrors"; "required": false; }; "maxCharacters": { "alias": "maxCharacters"; "required": false; }; "fullWidth": { "alias": "fullWidth"; "required": false; }; }, { "valueChange": "valueChange"; }, never, never, false, never>;
164
+ static ɵcmp: i0.ɵɵComponentDeclaration<MultiInputComponent, "ui-multi-input", never, { "itemsList": { "alias": "itemsList"; "required": true; }; "itemTextField": { "alias": "itemTextField"; "required": true; }; "itemValueField": { "alias": "itemValueField"; "required": true; }; "value": { "alias": "value"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "required": { "alias": "required"; "required": false; }; "label": { "alias": "label"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "allowDecimal": { "alias": "allowDecimal"; "required": false; }; "allowNegative": { "alias": "allowNegative"; "required": false; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; }; "errors": { "alias": "errors"; "required": false; }; "hideBuiltInErrors": { "alias": "hideBuiltInErrors"; "required": false; }; "hideLabelInErrors": { "alias": "hideLabelInErrors"; "required": false; }; "maxCharacters": { "alias": "maxCharacters"; "required": false; }; "validators": { "alias": "validators"; "required": false; }; "fullWidth": { "alias": "fullWidth"; "required": false; }; }, { "valueChange": "valueChange"; }, never, never, false, never>;
158
165
  static ngAcceptInputType_disabled: unknown;
159
166
  static ngAcceptInputType_required: unknown;
160
167
  static ngAcceptInputType_allowDecimal: unknown;
@@ -1,6 +1,6 @@
1
1
  import { booleanAttribute, Component, EventEmitter, HostBinding, Inject, Input, Optional, Output, Self, } from '@angular/core';
2
2
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
- import { FormControl, Validators } from '@angular/forms';
3
+ import { FormControl, Validators, } from '@angular/forms';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/forms";
6
6
  import * as i2 from "@angular/common";
@@ -69,11 +69,11 @@ export class MultiInputComponent {
69
69
  */
70
70
  this.label = '';
71
71
  /**
72
- *
73
- * @description Defines the placeholder of the multi input
74
- * @type {string}
75
- * @memberof MultiInputComponent
76
- */
72
+ *
73
+ * @description Defines the placeholder of the multi input
74
+ * @type {string}
75
+ * @memberof MultiInputComponent
76
+ */
77
77
  this.placeholder = '';
78
78
  /**
79
79
  *
@@ -124,6 +124,13 @@ export class MultiInputComponent {
124
124
  * @memberof MultiInputComponent
125
125
  */
126
126
  this.maxCharacters = 0;
127
+ /**
128
+ *
129
+ * @description The validators to apply to input field
130
+ * @type {Validators[]}
131
+ * @memberof MultiInputComponent
132
+ */
133
+ this.validators = [];
127
134
  /**
128
135
  *
129
136
  * @description The width of the multi input
@@ -151,9 +158,7 @@ export class MultiInputComponent {
151
158
  if (this.defaultAppTheme) {
152
159
  this.applicationTheme = this.defaultAppTheme;
153
160
  }
154
- this.multiInputForm.valueChanges
155
- .pipe(takeUntilDestroyed())
156
- .subscribe(formValue => {
161
+ this.multiInputForm.valueChanges.pipe(takeUntilDestroyed()).subscribe(formValue => {
157
162
  this.valueChanged(formValue);
158
163
  this.checkFormErrors();
159
164
  if (!formValue.value && !formValue[this.itemValueField]) {
@@ -206,13 +211,16 @@ export class MultiInputComponent {
206
211
  return this.multiInputForm.get('value');
207
212
  }
208
213
  checkFormErrors() {
214
+ const hasErrors = this.inputControl?.errors || this.dropdownControl?.errors;
209
215
  if (this.ngControl) {
210
- this.ngControl.control?.setErrors({ ...this.inputControl?.errors, ...this.dropdownControl?.errors });
216
+ this.ngControl.control?.setErrors(!!hasErrors ? { ...this.inputControl?.errors, ...this.dropdownControl?.errors } : null);
211
217
  }
212
- this.showError = !!(this.inputControl?.errors || this.dropdownControl?.errors);
218
+ this.showError = !!hasErrors;
213
219
  }
214
220
  markAsTouched() {
215
- if (this.ngControl && ((this.inputControl?.touched && this.dropdownControl?.touched) || (!this.inputControl?.value && !this.dropdownControl?.value))) {
221
+ if (this.ngControl &&
222
+ ((this.inputControl?.touched && this.dropdownControl?.touched) ||
223
+ (!this.inputControl?.value && !this.dropdownControl?.value))) {
216
224
  this.ngControl.control?.markAsTouched();
217
225
  }
218
226
  }
@@ -224,13 +232,13 @@ export class MultiInputComponent {
224
232
  }
225
233
  get controlHasError() {
226
234
  return this.ngControl
227
- ? (this.showError && !!this.ngControl.control?.touched)
228
- || (!this.inputControl?.valid && !!this.inputControl?.touched)
229
- || (!this.dropdownControl?.valid && !!this.dropdownControl?.touched)
230
- : this.showError
231
- || !!this.errors.length
232
- || (!this.inputControl?.valid && !!this.inputControl?.touched)
233
- || (!this.dropdownControl?.valid && !!this.dropdownControl?.touched);
235
+ ? (this.showError && !!this.ngControl.control?.touched) ||
236
+ (!this.inputControl?.valid && !!this.inputControl?.touched) ||
237
+ (!this.dropdownControl?.valid && !!this.dropdownControl?.touched)
238
+ : this.showError ||
239
+ !!this.errors.length ||
240
+ (!this.inputControl?.valid && !!this.inputControl?.touched) ||
241
+ (!this.dropdownControl?.valid && !!this.dropdownControl?.touched);
234
242
  }
235
243
  getValueLength() {
236
244
  return this.inputControl?.value?.toString().length || 0;
@@ -239,6 +247,9 @@ export class MultiInputComponent {
239
247
  if (this.maxCharacters) {
240
248
  this.inputControl?.addValidators(Validators.maxLength(this.maxCharacters));
241
249
  }
250
+ if (this.validators?.length) {
251
+ this.inputControl?.addValidators(this.validators);
252
+ }
242
253
  }
243
254
  updateDisableState(state) {
244
255
  if (state) {
@@ -249,7 +260,7 @@ export class MultiInputComponent {
249
260
  }
250
261
  }
251
262
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MultiInputComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
252
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: MultiInputComponent, selector: "ui-multi-input", inputs: { itemsList: "itemsList", itemTextField: "itemTextField", itemValueField: "itemValueField", value: "value", disabled: ["disabled", "disabled", booleanAttribute], required: ["required", "required", booleanAttribute], label: "label", placeholder: "placeholder", allowDecimal: ["allowDecimal", "allowDecimal", booleanAttribute], allowNegative: ["allowNegative", "allowNegative", booleanAttribute], applicationTheme: "applicationTheme", errors: "errors", hideBuiltInErrors: ["hideBuiltInErrors", "hideBuiltInErrors", booleanAttribute], hideLabelInErrors: ["hideLabelInErrors", "hideLabelInErrors", booleanAttribute], maxCharacters: "maxCharacters", fullWidth: "fullWidth" }, outputs: { valueChange: "valueChange" }, host: { properties: { "attr.theme": "this.applicationTheme", "class.full-width": "this.fullWidth", "class": "this.class" } }, usesOnChanges: true, ngImport: i0, template: "<div [formGroup]=\"multiInputForm\">\n <div class=\"controls-wrapper\">\n <ui-dropdown\n [hasError]=\"controlHasError\"\n [formControlName]=\"itemValueField\"\n [valueList]=\"itemsList\"\n [textField]=\"itemTextField\"\n [valueField]=\"itemValueField\"\n [showBottomContent]=\"false\"\n [allowClear]=\"false\"\n (closed)=\"markAsTouched(); checkFormErrors()\"\n ></ui-dropdown>\n\n <ui-field\n [hasError]=\"controlHasError\"\n [formControlName]=\"'value'\"\n [label]=\"label\"\n [placeholder]=\"placeholder\"\n [required]=\"required\"\n [hideBuiltInErrors]=\"true\"\n [showBottomContent]=\"false\"\n [allowOnlyDigits]=\"true\"\n [fullWidth]=\"fullWidth\"\n (focusout)=\"markAsTouched(); checkFormErrors()\"\n ></ui-field>\n </div>\n\n <mat-hint class=\"info\" *ngIf=\"!controlHasError && maxCharacters && !errors?.length\">{{ getValueLength() }} / {{ maxCharacters }}</mat-hint>\n\n @if (errors?.length || (ngControl?.errors | hasValidationError)) {\n <mat-hint class=\"error\">\n @for (error of errors; track error) {\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Error' : 'Error-in-line'\"\n ></ui-icon>{{ error }}\n }\n @if ((ngControl?.errors | hasValidationError) && !hideBuiltInErrors) {\n <ui-validation-error\n [touchedOn]=\"!controlHasError\"\n [ngControl]=\"ngControl\"\n [label]=\"hideLabelInErrors ? null : label\"\n ></ui-validation-error>\n }\n </mat-hint>\n }\n\n</div>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}:host.ui-multi-input{position:relative!important}:host.ui-multi-input .ng-untouched,:host.ui-multi-input .ng-touched{width:fit-content}:host.ui-multi-input.full-width .ng-untouched{width:100%}:host.ui-multi-input .controls-wrapper{display:flex}:host.ui-multi-input ::ng-deep ui-validation-error .errors{display:flex}:host.ui-multi-input ::ng-deep .ui-dropdown{max-width:120px}:host.ui-multi-input ::ng-deep .ui-dropdown .mdc-notched-outline__trailing{border-right-color:transparent!important;border-top-right-radius:0!important;border-bottom-right-radius:0!important}:host.ui-multi-input ::ng-deep .ui-dropdown:hover .mdc-notched-outline__trailing,:host.ui-multi-input ::ng-deep .ui-dropdown .mat-mdc-form-field-focused .mdc-notched-outline__trailing{border-right-color:#242424}:host.ui-multi-input ::ng-deep .ui-field .mdc-notched-outline__leading{border-top-left-radius:0!important;border-bottom-left-radius:0!important}:host.ui-multi-input ::ng-deep .ui-field .mat-mdc-form-field-subscript-wrapper{position:absolute!important;left:0!important;top:48px!important}:host.ui-multi-input ::ng-deep .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mat-mdc-form-field-infix{padding-top:0!important;padding-bottom:0!important;min-height:48px!important;align-items:center!important;display:flex!important}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.info{display:block;color:#888;width:100%;text-align:right}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.error{display:flex;gap:4px;color:#e02800;align-items:center;padding:4px 0 10px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.error svg{color:#e02800}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint:before{display:none}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error{color:#e02800;font-size:12px;line-height:16px;letter-spacing:.4px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error .errors{display:flex;align-items:center;padding:4px 0 10px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error svg{margin-right:4px;color:#e02800;row-gap:0}:host.ui-multi-input .separator-line{border-left:1px solid var(--mdc-outlined-text-field-outline-color);height:40px;margin:0 12px -7px 8px}:host.ui-multi-input ::ng-deep .mat-mdc-select .mat-mdc-select-arrow-wrapper{display:none}:host.ui-multi-input ::ng-deep .mdc-text-field--outlined{padding-left:12px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "component", type: i4.IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color", "filled", "applicationTheme", "useFullIconName"] }, { kind: "component", type: i5.DropdownComponent, selector: "ui-dropdown", inputs: ["label", "name", "placeholder", "id", "value", "errors", "disabled", "valueList", "allowClear", "allowMultipleSelection", "required", "showBottomContent", "applicationTheme", "hideBuiltInErrors", "hideLabelInErrors", "textField", "valueField", "hasError", "companyColor"], outputs: ["closed", "opened"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i6.ValidationErrorComponent, selector: "ui-validation-error", inputs: ["ngControl", "touchedOn", "errorMessage", "label", "applicationTheme"] }, { kind: "component", type: i7.FieldComponent, selector: "ui-field", inputs: ["fullWidth", "label", "fieldName", "placeholder", "id", "value", "errors", "disabled", "required", "hintMessage", "type", "updateOnBlur", "allowOnlyDigits", "allowNegative", "showBottomContent", "applicationTheme", "ariaLabel", "loading", "isValid", "maxCharacters", "trimOnBlur", "trimOnSubmit", "maxRows", "hideBuiltInErrors", "hideLabelInErrors", "max", "min", "textareaHeight", "ariaLabelledby", "ariaDescribedby", "hasError"], outputs: ["validateEvent", "fieldBlur"] }, { kind: "pipe", type: i8.HasValidationErrorPipe, name: "hasValidationError" }] }); }
263
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: MultiInputComponent, selector: "ui-multi-input", inputs: { itemsList: "itemsList", itemTextField: "itemTextField", itemValueField: "itemValueField", value: "value", disabled: ["disabled", "disabled", booleanAttribute], required: ["required", "required", booleanAttribute], label: "label", placeholder: "placeholder", allowDecimal: ["allowDecimal", "allowDecimal", booleanAttribute], allowNegative: ["allowNegative", "allowNegative", booleanAttribute], applicationTheme: "applicationTheme", errors: "errors", hideBuiltInErrors: ["hideBuiltInErrors", "hideBuiltInErrors", booleanAttribute], hideLabelInErrors: ["hideLabelInErrors", "hideLabelInErrors", booleanAttribute], maxCharacters: "maxCharacters", validators: "validators", fullWidth: "fullWidth" }, outputs: { valueChange: "valueChange" }, host: { properties: { "attr.theme": "this.applicationTheme", "class.full-width": "this.fullWidth", "class": "this.class" } }, usesOnChanges: true, ngImport: i0, template: "<div [formGroup]=\"multiInputForm\">\n <div class=\"controls-wrapper\">\n <ui-dropdown\n [hasError]=\"controlHasError\"\n [formControlName]=\"itemValueField\"\n [valueList]=\"itemsList\"\n [textField]=\"itemTextField\"\n [valueField]=\"itemValueField\"\n [showBottomContent]=\"false\"\n [allowClear]=\"false\"\n (closed)=\"markAsTouched(); checkFormErrors()\"\n ></ui-dropdown>\n\n <ui-field\n [hasError]=\"controlHasError\"\n [formControlName]=\"'value'\"\n [label]=\"label\"\n [placeholder]=\"placeholder\"\n [required]=\"required\"\n [hideBuiltInErrors]=\"true\"\n [showBottomContent]=\"false\"\n [allowOnlyDigits]=\"true\"\n [fullWidth]=\"fullWidth\"\n (focusout)=\"markAsTouched(); checkFormErrors()\"\n ></ui-field>\n </div>\n\n <mat-hint class=\"info\" *ngIf=\"!controlHasError && maxCharacters && !errors?.length\">{{ getValueLength() }} / {{ maxCharacters }}</mat-hint>\n\n @if (errors?.length || (ngControl?.errors | hasValidationError)) {\n <mat-hint class=\"error\">\n @for (error of errors; track error) {\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Error' : 'Error-in-line'\"\n ></ui-icon>{{ error }}\n }\n @if ((ngControl?.errors | hasValidationError) && !hideBuiltInErrors) {\n <ui-validation-error\n [touchedOn]=\"!controlHasError\"\n [ngControl]=\"ngControl\"\n [label]=\"hideLabelInErrors ? null : label\"\n ></ui-validation-error>\n }\n </mat-hint>\n }\n\n</div>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}:host.ui-multi-input{position:relative!important}:host.ui-multi-input .ng-untouched,:host.ui-multi-input .ng-touched{width:fit-content}:host.ui-multi-input.full-width .ng-untouched{width:100%}:host.ui-multi-input .controls-wrapper{display:flex}:host.ui-multi-input ::ng-deep ui-validation-error .errors{display:flex}:host.ui-multi-input ::ng-deep .ui-dropdown{max-width:120px}:host.ui-multi-input ::ng-deep .ui-dropdown .mdc-notched-outline__trailing{border-right-color:transparent!important;border-top-right-radius:0!important;border-bottom-right-radius:0!important}:host.ui-multi-input ::ng-deep .ui-dropdown:hover .mdc-notched-outline__trailing,:host.ui-multi-input ::ng-deep .ui-dropdown .mat-mdc-form-field-focused .mdc-notched-outline__trailing{border-right-color:#242424}:host.ui-multi-input ::ng-deep .ui-field .mdc-notched-outline__leading{border-top-left-radius:0!important;border-bottom-left-radius:0!important}:host.ui-multi-input ::ng-deep .ui-field .mat-mdc-form-field-subscript-wrapper{position:absolute!important;left:0!important;top:48px!important}:host.ui-multi-input ::ng-deep .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mat-mdc-form-field-infix{padding-top:0!important;padding-bottom:0!important;min-height:48px!important;align-items:center!important;display:flex!important}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.info{display:block;color:#888;width:100%;text-align:right}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.error{display:flex;gap:4px;color:#e02800;align-items:center;padding:4px 0 10px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.error svg{color:#e02800}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint:before{display:none}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error{color:#e02800;font-size:12px;line-height:16px;letter-spacing:.4px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error .errors{display:flex;align-items:center;padding:4px 0 10px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error svg{margin-right:4px;color:#e02800;row-gap:0}:host.ui-multi-input .separator-line{border-left:1px solid var(--mdc-outlined-text-field-outline-color);height:40px;margin:0 12px -7px 8px}:host.ui-multi-input ::ng-deep .mat-mdc-select .mat-mdc-select-arrow-wrapper{display:none}:host.ui-multi-input ::ng-deep .mdc-text-field--outlined{padding-left:12px!important}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "component", type: i4.IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color", "filled", "applicationTheme", "useFullIconName"] }, { kind: "component", type: i5.DropdownComponent, selector: "ui-dropdown", inputs: ["label", "name", "placeholder", "id", "value", "errors", "disabled", "valueList", "allowClear", "allowMultipleSelection", "required", "showBottomContent", "applicationTheme", "hideBuiltInErrors", "hideLabelInErrors", "textField", "valueField", "hasError", "companyColor"], outputs: ["closed", "opened"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i6.ValidationErrorComponent, selector: "ui-validation-error", inputs: ["ngControl", "touchedOn", "errorMessage", "label", "applicationTheme"] }, { kind: "component", type: i7.FieldComponent, selector: "ui-field", inputs: ["fullWidth", "label", "fieldName", "placeholder", "id", "value", "errors", "disabled", "required", "hintMessage", "type", "updateOnBlur", "allowOnlyDigits", "allowNegative", "showBottomContent", "applicationTheme", "ariaLabel", "loading", "isValid", "maxCharacters", "trimOnBlur", "trimOnSubmit", "maxRows", "hideBuiltInErrors", "hideLabelInErrors", "max", "min", "textareaHeight", "ariaLabelledby", "ariaDescribedby", "hasError"], outputs: ["validateEvent", "fieldBlur"] }, { kind: "pipe", type: i8.HasValidationErrorPipe, name: "hasValidationError" }] }); }
253
264
  }
254
265
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MultiInputComponent, decorators: [{
255
266
  type: Component,
@@ -305,6 +316,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
305
316
  args: [{ transform: booleanAttribute }]
306
317
  }], maxCharacters: [{
307
318
  type: Input
319
+ }], validators: [{
320
+ type: Input
308
321
  }], fullWidth: [{
309
322
  type: HostBinding,
310
323
  args: ['class.full-width']
@@ -315,4 +328,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
315
328
  }], class: [{
316
329
  type: HostBinding
317
330
  }] } });
318
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-input.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/multi-input/multi-input.component.ts","../../../../../projects/tgo-canopy-ui/components/multi-input/multi-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  Self, SimpleChanges,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { AbstractControl, ControlValueAccessor, FormBuilder, FormControl, NgControl, Validators } from '@angular/forms';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { MultiInputValue } from './multi-input.model';\n\n@Component({\n  selector: 'ui-multi-input',\n  templateUrl: './multi-input.component.html',\n  styleUrl: './multi-input.component.scss',\n})\nexport class MultiInputComponent implements ControlValueAccessor, OnInit {\n  /**\n   *\n   * @description List of items to be displayed in the dropdown list\n   * @type {Record<string, string | null | number>[]}\n   * @memberof MultiInputComponent\n   */\n  @Input({ required: true }) itemsList: Record<string, string | null | number>[] = [];\n\n  /**\n   *\n   * @description The field to be displayed in the dropdown\n   * @type {string}\n   * @memberof MultiInputComponent\n   */\n  @Input({ required: true }) itemTextField = '';\n\n  /**\n   *\n   * @description The value to be displayed in the droddown\n   * @type {string}\n   * @memberof MultiInputComponent\n   */\n  @Input({ required: true }) itemValueField = '';\n\n  /**\n   *\n   * @description The Value of the multi input\n   * @type {MultiInputValue}\n   * @memberof MultiInputComponent\n   */\n  @Input() set value(v: MultiInputValue) {\n    this._value = v;\n    this.addDropdownControl();\n    this.multiInputForm.patchValue(v);\n  }\n\n  /**\n   *\n   * @description Disables the multi input\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) disabled = false;\n\n  /**\n   *\n   * @description Defines if the multi input is required\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) required = false;\n\n  /**\n   *\n   * @description Defines the label of the multi input\n   * @type {string}\n   * @memberof MultiInputComponent\n   */\n  @Input() label = '';\n\n    /**\n   *\n   * @description Defines the placeholder of the multi input\n   * @type {string}\n   * @memberof MultiInputComponent\n   */\n  @Input() placeholder = '';\n\n  /**\n   *\n   * @description Allow decimal values in the multi input\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) allowDecimal = true;\n\n  /**\n   *\n   * @description Allow negative values in the multi input\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) allowNegative = true;\n\n  /**\n   *\n   * @description The theme of the application\n   * @type {ApplicationTheme}\n   * @memberof MultiInputComponent\n   */\n  @HostBinding('attr.theme')\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   *\n   * @description The errors of the multi input\n   * @type {string[]}\n   * @memberof MultiInputComponent\n   */\n  @Input() errors: string[] = [];\n\n  /**\n   *\n   * @description Hide built in errors for Reactive Forms\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) hideBuiltInErrors = false;\n\n  /**\n   *\n   * @description Hide label in errors\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) hideLabelInErrors = false;\n\n  /**\n   *\n   * @description The maximum characters allowed in the multi input\n   * @type {number}\n   * @memberof MultiInputComponent\n   */\n  @Input() maxCharacters = 0;\n\n  /**\n   *\n   * @description The width of the multi input\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @HostBinding('class.full-width')\n  @Input() fullWidth: boolean = false;\n\n  @Output() valueChange = new EventEmitter<MultiInputValue>();\n\n  @HostBinding() class = 'ui-multi-input';\n\n  /**\n   * @ignore\n   */\n  onChange = (_: any): void => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = (): void => {};\n\n  private _value: MultiInputValue | undefined;\n  protected showError = false;\n\n  protected readonly multiInputForm = this.fb.group<MultiInputValue>({\n    value: null,\n  });\n\n  constructor(\n    @Optional() @Self() protected ngControl: NgControl,\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private readonly fb: FormBuilder,\n  ) {\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    if (this.defaultAppTheme) {\n      this.applicationTheme = this.defaultAppTheme;\n    }\n\n    this.multiInputForm.valueChanges\n      .pipe(takeUntilDestroyed())\n      .subscribe(formValue => {\n        this.valueChanged(formValue as MultiInputValue);\n        this.checkFormErrors();\n\n        if (!(formValue as any).value && !(formValue as any)[this.itemValueField]) {\n          this.showError = true;\n        }\n      });\n  }\n\n  ngOnInit(): void {\n    this.addDropdownControl();\n    this.addValidation();\n\n    if (this.ngControl && this.hasRequiredValidator) {\n      this.inputControl?.addValidators(Validators.required);\n      this.dropdownControl?.addValidators(Validators.required);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['disabled']) {\n      this.updateDisableState(this.disabled);\n    }\n  }\n\n  writeValue(value: MultiInputValue): void {\n    this.value = value;\n    this.addDropdownControl();\n    this.multiInputForm.patchValue(value);\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.updateDisableState(isDisabled);\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  protected valueChanged(value: MultiInputValue): void {\n    this.valueChange.emit(value);\n    this.onChange(value);\n  }\n\n  get value(): MultiInputValue | undefined {\n    return this._value;\n  }\n\n  protected get hasRequiredValidator(): boolean {\n    return !!this.ngControl.control?.hasValidator(Validators.required);\n  }\n\n  protected get dropdownControl(): AbstractControl<string | null> | null {\n    return this.multiInputForm.get(this.itemValueField);\n  }\n\n  protected get inputControl(): AbstractControl<number | null> | null {\n    return this.multiInputForm.get('value') as any;\n  }\n\n  protected checkFormErrors(): void {\n    if (this.ngControl) {\n      this.ngControl.control?.setErrors({ ...this.inputControl?.errors, ...this.dropdownControl?.errors });\n    }\n    this.showError = !!(this.inputControl?.errors || this.dropdownControl?.errors);\n  }\n\n  protected markAsTouched(): void {\n    if (this.ngControl && ((this.inputControl?.touched && this.dropdownControl?.touched) || (!this.inputControl?.value && !this.dropdownControl?.value))) {\n      this.ngControl.control?.markAsTouched();\n    }\n  }\n\n  protected addDropdownControl(): void {\n    if (!this.multiInputForm.value[this.itemValueField]) {\n      this.multiInputForm.addControl(this.itemValueField, new FormControl(null), { emitEvent: false });\n      this.updateDisableState(this.disabled);\n    }\n  }\n\n  protected get controlHasError(): boolean {\n    return this.ngControl\n      ? (this.showError && !!this.ngControl.control?.touched)\n        || (!this.inputControl?.valid && !!this.inputControl?.touched)\n        || (!this.dropdownControl?.valid && !!this.dropdownControl?.touched)\n      : this.showError\n      || !!this.errors.length\n      || (!this.inputControl?.valid && !!this.inputControl?.touched)\n      || (!this.dropdownControl?.valid && !!this.dropdownControl?.touched)\n  }\n\n  protected getValueLength(): number {\n    return this.inputControl?.value?.toString().length || 0;\n  }\n\n  private addValidation(): void {\n    if (this.maxCharacters) {\n      this.inputControl?.addValidators(Validators.maxLength(this.maxCharacters));\n    }\n  }\n\n  private updateDisableState(state: boolean): void {\n    if (state) {\n      this.multiInputForm.disable({ emitEvent: false });\n    } else {\n      this.multiInputForm.enable({ emitEvent: false });\n    }\n  }\n}\n","<div [formGroup]=\"multiInputForm\">\n  <div class=\"controls-wrapper\">\n    <ui-dropdown\n      [hasError]=\"controlHasError\"\n      [formControlName]=\"itemValueField\"\n      [valueList]=\"itemsList\"\n      [textField]=\"itemTextField\"\n      [valueField]=\"itemValueField\"\n      [showBottomContent]=\"false\"\n      [allowClear]=\"false\"\n      (closed)=\"markAsTouched(); checkFormErrors()\"\n    ></ui-dropdown>\n\n    <ui-field\n      [hasError]=\"controlHasError\"\n      [formControlName]=\"'value'\"\n      [label]=\"label\"\n      [placeholder]=\"placeholder\"\n      [required]=\"required\"\n      [hideBuiltInErrors]=\"true\"\n      [showBottomContent]=\"false\"\n      [allowOnlyDigits]=\"true\"\n      [fullWidth]=\"fullWidth\"\n      (focusout)=\"markAsTouched(); checkFormErrors()\"\n    ></ui-field>\n  </div>\n\n  <mat-hint class=\"info\" *ngIf=\"!controlHasError && maxCharacters && !errors?.length\">{{ getValueLength() }} / {{ maxCharacters }}</mat-hint>\n\n  @if (errors?.length || (ngControl?.errors | hasValidationError)) {\n    <mat-hint class=\"error\">\n      @for (error of errors; track error) {\n        <ui-icon\n          [applicationTheme]=\"applicationTheme\"\n          [name]=\"applicationTheme === 'classic' ? 'Error' : 'Error-in-line'\"\n        ></ui-icon>{{ error }}\n      }\n      @if ((ngControl?.errors | hasValidationError) && !hideBuiltInErrors) {\n        <ui-validation-error\n          [touchedOn]=\"!controlHasError\"\n          [ngControl]=\"ngControl\"\n          [label]=\"hideLabelInErrors ? null : label\"\n        ></ui-validation-error>\n      }\n    </mat-hint>\n  }\n\n</div>\n"]}
331
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-input.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/multi-input/multi-input.component.ts","../../../../../projects/tgo-canopy-ui/components/multi-input/multi-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  booleanAttribute,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  SimpleChanges,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormBuilder,\n  FormControl,\n  NgControl,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { MultiInputValue } from './multi-input.model';\n\n@Component({\n  selector: 'ui-multi-input',\n  templateUrl: './multi-input.component.html',\n  styleUrl: './multi-input.component.scss',\n})\nexport class MultiInputComponent implements ControlValueAccessor, OnInit {\n  /**\n   *\n   * @description List of items to be displayed in the dropdown list\n   * @type {Record<string, string | null | number>[]}\n   * @memberof MultiInputComponent\n   */\n  @Input({ required: true }) itemsList: Record<string, string | null | number>[] = [];\n\n  /**\n   *\n   * @description The field to be displayed in the dropdown\n   * @type {string}\n   * @memberof MultiInputComponent\n   */\n  @Input({ required: true }) itemTextField = '';\n\n  /**\n   *\n   * @description The value to be displayed in the droddown\n   * @type {string}\n   * @memberof MultiInputComponent\n   */\n  @Input({ required: true }) itemValueField = '';\n\n  /**\n   *\n   * @description The Value of the multi input\n   * @type {MultiInputValue}\n   * @memberof MultiInputComponent\n   */\n  @Input() set value(v: MultiInputValue) {\n    this._value = v;\n    this.addDropdownControl();\n    this.multiInputForm.patchValue(v);\n  }\n\n  /**\n   *\n   * @description Disables the multi input\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) disabled = false;\n\n  /**\n   *\n   * @description Defines if the multi input is required\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) required = false;\n\n  /**\n   *\n   * @description Defines the label of the multi input\n   * @type {string}\n   * @memberof MultiInputComponent\n   */\n  @Input() label = '';\n\n  /**\n   *\n   * @description Defines the placeholder of the multi input\n   * @type {string}\n   * @memberof MultiInputComponent\n   */\n  @Input() placeholder = '';\n\n  /**\n   *\n   * @description Allow decimal values in the multi input\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) allowDecimal = true;\n\n  /**\n   *\n   * @description Allow negative values in the multi input\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) allowNegative = true;\n\n  /**\n   *\n   * @description The theme of the application\n   * @type {ApplicationTheme}\n   * @memberof MultiInputComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   *\n   * @description The errors of the multi input\n   * @type {string[]}\n   * @memberof MultiInputComponent\n   */\n  @Input() errors: string[] = [];\n\n  /**\n   *\n   * @description Hide built in errors for Reactive Forms\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) hideBuiltInErrors = false;\n\n  /**\n   *\n   * @description Hide label in errors\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @Input({ transform: booleanAttribute }) hideLabelInErrors = false;\n\n  /**\n   *\n   * @description The maximum characters allowed in the multi input\n   * @type {number}\n   * @memberof MultiInputComponent\n   */\n  @Input() maxCharacters = 0;\n\n  /**\n   *\n   * @description The validators to apply to input field\n   * @type {Validators[]}\n   * @memberof MultiInputComponent\n   */\n  @Input() validators: ValidatorFn[] = [];\n\n  /**\n   *\n   * @description The width of the multi input\n   * @type {boolean}\n   * @memberof MultiInputComponent\n   */\n  @HostBinding('class.full-width')\n  @Input()\n  fullWidth: boolean = false;\n\n  @Output() valueChange = new EventEmitter<MultiInputValue>();\n\n  @HostBinding() class = 'ui-multi-input';\n\n  /**\n   * @ignore\n   */\n  onChange = (_: any): void => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = (): void => {};\n\n  private _value: MultiInputValue | undefined;\n  protected showError = false;\n\n  protected readonly multiInputForm = this.fb.group<MultiInputValue>({\n    value: null,\n  });\n\n  constructor(\n    @Optional() @Self() protected ngControl: NgControl,\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private readonly fb: FormBuilder\n  ) {\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    if (this.defaultAppTheme) {\n      this.applicationTheme = this.defaultAppTheme;\n    }\n\n    this.multiInputForm.valueChanges.pipe(takeUntilDestroyed()).subscribe(formValue => {\n      this.valueChanged(formValue as MultiInputValue);\n      this.checkFormErrors();\n\n      if (!(formValue as any).value && !(formValue as any)[this.itemValueField]) {\n        this.showError = true;\n      }\n    });\n  }\n\n  ngOnInit(): void {\n    this.addDropdownControl();\n    this.addValidation();\n\n    if (this.ngControl && this.hasRequiredValidator) {\n      this.inputControl?.addValidators(Validators.required);\n      this.dropdownControl?.addValidators(Validators.required);\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['disabled']) {\n      this.updateDisableState(this.disabled);\n    }\n  }\n\n  writeValue(value: MultiInputValue): void {\n    this.value = value;\n    this.addDropdownControl();\n    this.multiInputForm.patchValue(value);\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.updateDisableState(isDisabled);\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  protected valueChanged(value: MultiInputValue): void {\n    this.valueChange.emit(value);\n    this.onChange(value);\n  }\n\n  get value(): MultiInputValue | undefined {\n    return this._value;\n  }\n\n  protected get hasRequiredValidator(): boolean {\n    return !!this.ngControl.control?.hasValidator(Validators.required);\n  }\n\n  protected get dropdownControl(): AbstractControl<string | null> | null {\n    return this.multiInputForm.get(this.itemValueField);\n  }\n\n  protected get inputControl(): AbstractControl<number | null> | null {\n    return this.multiInputForm.get('value') as any;\n  }\n\n  protected checkFormErrors(): void {\n    const hasErrors = this.inputControl?.errors || this.dropdownControl?.errors;\n    if (this.ngControl) {\n      this.ngControl.control?.setErrors(\n        !!hasErrors ? { ...this.inputControl?.errors, ...this.dropdownControl?.errors } : null\n      );\n    }\n    this.showError = !!hasErrors;\n  }\n\n  protected markAsTouched(): void {\n    if (\n      this.ngControl &&\n      ((this.inputControl?.touched && this.dropdownControl?.touched) ||\n        (!this.inputControl?.value && !this.dropdownControl?.value))\n    ) {\n      this.ngControl.control?.markAsTouched();\n    }\n  }\n\n  protected addDropdownControl(): void {\n    if (!this.multiInputForm.value[this.itemValueField]) {\n      this.multiInputForm.addControl(this.itemValueField, new FormControl(null), { emitEvent: false });\n      this.updateDisableState(this.disabled);\n    }\n  }\n\n  protected get controlHasError(): boolean {\n    return this.ngControl\n      ? (this.showError && !!this.ngControl.control?.touched) ||\n          (!this.inputControl?.valid && !!this.inputControl?.touched) ||\n          (!this.dropdownControl?.valid && !!this.dropdownControl?.touched)\n      : this.showError ||\n          !!this.errors.length ||\n          (!this.inputControl?.valid && !!this.inputControl?.touched) ||\n          (!this.dropdownControl?.valid && !!this.dropdownControl?.touched);\n  }\n\n  protected getValueLength(): number {\n    return this.inputControl?.value?.toString().length || 0;\n  }\n\n  private addValidation(): void {\n    if (this.maxCharacters) {\n      this.inputControl?.addValidators(Validators.maxLength(this.maxCharacters));\n    }\n    if (this.validators?.length) {\n      this.inputControl?.addValidators(this.validators);\n    }\n  }\n\n  private updateDisableState(state: boolean): void {\n    if (state) {\n      this.multiInputForm.disable({ emitEvent: false });\n    } else {\n      this.multiInputForm.enable({ emitEvent: false });\n    }\n  }\n}\n","<div [formGroup]=\"multiInputForm\">\n  <div class=\"controls-wrapper\">\n    <ui-dropdown\n      [hasError]=\"controlHasError\"\n      [formControlName]=\"itemValueField\"\n      [valueList]=\"itemsList\"\n      [textField]=\"itemTextField\"\n      [valueField]=\"itemValueField\"\n      [showBottomContent]=\"false\"\n      [allowClear]=\"false\"\n      (closed)=\"markAsTouched(); checkFormErrors()\"\n    ></ui-dropdown>\n\n    <ui-field\n      [hasError]=\"controlHasError\"\n      [formControlName]=\"'value'\"\n      [label]=\"label\"\n      [placeholder]=\"placeholder\"\n      [required]=\"required\"\n      [hideBuiltInErrors]=\"true\"\n      [showBottomContent]=\"false\"\n      [allowOnlyDigits]=\"true\"\n      [fullWidth]=\"fullWidth\"\n      (focusout)=\"markAsTouched(); checkFormErrors()\"\n    ></ui-field>\n  </div>\n\n  <mat-hint class=\"info\" *ngIf=\"!controlHasError && maxCharacters && !errors?.length\">{{ getValueLength() }} / {{ maxCharacters }}</mat-hint>\n\n  @if (errors?.length || (ngControl?.errors | hasValidationError)) {\n    <mat-hint class=\"error\">\n      @for (error of errors; track error) {\n        <ui-icon\n          [applicationTheme]=\"applicationTheme\"\n          [name]=\"applicationTheme === 'classic' ? 'Error' : 'Error-in-line'\"\n        ></ui-icon>{{ error }}\n      }\n      @if ((ngControl?.errors | hasValidationError) && !hideBuiltInErrors) {\n        <ui-validation-error\n          [touchedOn]=\"!controlHasError\"\n          [ngControl]=\"ngControl\"\n          [label]=\"hideLabelInErrors ? null : label\"\n        ></ui-validation-error>\n      }\n    </mat-hint>\n  }\n\n</div>\n"]}
@@ -15479,11 +15479,11 @@ class MultiInputComponent {
15479
15479
  */
15480
15480
  this.label = '';
15481
15481
  /**
15482
- *
15483
- * @description Defines the placeholder of the multi input
15484
- * @type {string}
15485
- * @memberof MultiInputComponent
15486
- */
15482
+ *
15483
+ * @description Defines the placeholder of the multi input
15484
+ * @type {string}
15485
+ * @memberof MultiInputComponent
15486
+ */
15487
15487
  this.placeholder = '';
15488
15488
  /**
15489
15489
  *
@@ -15534,6 +15534,13 @@ class MultiInputComponent {
15534
15534
  * @memberof MultiInputComponent
15535
15535
  */
15536
15536
  this.maxCharacters = 0;
15537
+ /**
15538
+ *
15539
+ * @description The validators to apply to input field
15540
+ * @type {Validators[]}
15541
+ * @memberof MultiInputComponent
15542
+ */
15543
+ this.validators = [];
15537
15544
  /**
15538
15545
  *
15539
15546
  * @description The width of the multi input
@@ -15561,9 +15568,7 @@ class MultiInputComponent {
15561
15568
  if (this.defaultAppTheme) {
15562
15569
  this.applicationTheme = this.defaultAppTheme;
15563
15570
  }
15564
- this.multiInputForm.valueChanges
15565
- .pipe(takeUntilDestroyed())
15566
- .subscribe(formValue => {
15571
+ this.multiInputForm.valueChanges.pipe(takeUntilDestroyed()).subscribe(formValue => {
15567
15572
  this.valueChanged(formValue);
15568
15573
  this.checkFormErrors();
15569
15574
  if (!formValue.value && !formValue[this.itemValueField]) {
@@ -15616,13 +15621,16 @@ class MultiInputComponent {
15616
15621
  return this.multiInputForm.get('value');
15617
15622
  }
15618
15623
  checkFormErrors() {
15624
+ const hasErrors = this.inputControl?.errors || this.dropdownControl?.errors;
15619
15625
  if (this.ngControl) {
15620
- this.ngControl.control?.setErrors({ ...this.inputControl?.errors, ...this.dropdownControl?.errors });
15626
+ this.ngControl.control?.setErrors(!!hasErrors ? { ...this.inputControl?.errors, ...this.dropdownControl?.errors } : null);
15621
15627
  }
15622
- this.showError = !!(this.inputControl?.errors || this.dropdownControl?.errors);
15628
+ this.showError = !!hasErrors;
15623
15629
  }
15624
15630
  markAsTouched() {
15625
- if (this.ngControl && ((this.inputControl?.touched && this.dropdownControl?.touched) || (!this.inputControl?.value && !this.dropdownControl?.value))) {
15631
+ if (this.ngControl &&
15632
+ ((this.inputControl?.touched && this.dropdownControl?.touched) ||
15633
+ (!this.inputControl?.value && !this.dropdownControl?.value))) {
15626
15634
  this.ngControl.control?.markAsTouched();
15627
15635
  }
15628
15636
  }
@@ -15634,13 +15642,13 @@ class MultiInputComponent {
15634
15642
  }
15635
15643
  get controlHasError() {
15636
15644
  return this.ngControl
15637
- ? (this.showError && !!this.ngControl.control?.touched)
15638
- || (!this.inputControl?.valid && !!this.inputControl?.touched)
15639
- || (!this.dropdownControl?.valid && !!this.dropdownControl?.touched)
15640
- : this.showError
15641
- || !!this.errors.length
15642
- || (!this.inputControl?.valid && !!this.inputControl?.touched)
15643
- || (!this.dropdownControl?.valid && !!this.dropdownControl?.touched);
15645
+ ? (this.showError && !!this.ngControl.control?.touched) ||
15646
+ (!this.inputControl?.valid && !!this.inputControl?.touched) ||
15647
+ (!this.dropdownControl?.valid && !!this.dropdownControl?.touched)
15648
+ : this.showError ||
15649
+ !!this.errors.length ||
15650
+ (!this.inputControl?.valid && !!this.inputControl?.touched) ||
15651
+ (!this.dropdownControl?.valid && !!this.dropdownControl?.touched);
15644
15652
  }
15645
15653
  getValueLength() {
15646
15654
  return this.inputControl?.value?.toString().length || 0;
@@ -15649,6 +15657,9 @@ class MultiInputComponent {
15649
15657
  if (this.maxCharacters) {
15650
15658
  this.inputControl?.addValidators(Validators.maxLength(this.maxCharacters));
15651
15659
  }
15660
+ if (this.validators?.length) {
15661
+ this.inputControl?.addValidators(this.validators);
15662
+ }
15652
15663
  }
15653
15664
  updateDisableState(state) {
15654
15665
  if (state) {
@@ -15659,7 +15670,7 @@ class MultiInputComponent {
15659
15670
  }
15660
15671
  }
15661
15672
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MultiInputComponent, deps: [{ token: i1$2.NgControl, optional: true, self: true }, { token: 'CANOPYUI_DEFAULT_APPLICATION_THEME', optional: true }, { token: i1$2.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
15662
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: MultiInputComponent, selector: "ui-multi-input", inputs: { itemsList: "itemsList", itemTextField: "itemTextField", itemValueField: "itemValueField", value: "value", disabled: ["disabled", "disabled", booleanAttribute], required: ["required", "required", booleanAttribute], label: "label", placeholder: "placeholder", allowDecimal: ["allowDecimal", "allowDecimal", booleanAttribute], allowNegative: ["allowNegative", "allowNegative", booleanAttribute], applicationTheme: "applicationTheme", errors: "errors", hideBuiltInErrors: ["hideBuiltInErrors", "hideBuiltInErrors", booleanAttribute], hideLabelInErrors: ["hideLabelInErrors", "hideLabelInErrors", booleanAttribute], maxCharacters: "maxCharacters", fullWidth: "fullWidth" }, outputs: { valueChange: "valueChange" }, host: { properties: { "attr.theme": "this.applicationTheme", "class.full-width": "this.fullWidth", "class": "this.class" } }, usesOnChanges: true, ngImport: i0, template: "<div [formGroup]=\"multiInputForm\">\n <div class=\"controls-wrapper\">\n <ui-dropdown\n [hasError]=\"controlHasError\"\n [formControlName]=\"itemValueField\"\n [valueList]=\"itemsList\"\n [textField]=\"itemTextField\"\n [valueField]=\"itemValueField\"\n [showBottomContent]=\"false\"\n [allowClear]=\"false\"\n (closed)=\"markAsTouched(); checkFormErrors()\"\n ></ui-dropdown>\n\n <ui-field\n [hasError]=\"controlHasError\"\n [formControlName]=\"'value'\"\n [label]=\"label\"\n [placeholder]=\"placeholder\"\n [required]=\"required\"\n [hideBuiltInErrors]=\"true\"\n [showBottomContent]=\"false\"\n [allowOnlyDigits]=\"true\"\n [fullWidth]=\"fullWidth\"\n (focusout)=\"markAsTouched(); checkFormErrors()\"\n ></ui-field>\n </div>\n\n <mat-hint class=\"info\" *ngIf=\"!controlHasError && maxCharacters && !errors?.length\">{{ getValueLength() }} / {{ maxCharacters }}</mat-hint>\n\n @if (errors?.length || (ngControl?.errors | hasValidationError)) {\n <mat-hint class=\"error\">\n @for (error of errors; track error) {\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Error' : 'Error-in-line'\"\n ></ui-icon>{{ error }}\n }\n @if ((ngControl?.errors | hasValidationError) && !hideBuiltInErrors) {\n <ui-validation-error\n [touchedOn]=\"!controlHasError\"\n [ngControl]=\"ngControl\"\n [label]=\"hideLabelInErrors ? null : label\"\n ></ui-validation-error>\n }\n </mat-hint>\n }\n\n</div>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}:host.ui-multi-input{position:relative!important}:host.ui-multi-input .ng-untouched,:host.ui-multi-input .ng-touched{width:fit-content}:host.ui-multi-input.full-width .ng-untouched{width:100%}:host.ui-multi-input .controls-wrapper{display:flex}:host.ui-multi-input ::ng-deep ui-validation-error .errors{display:flex}:host.ui-multi-input ::ng-deep .ui-dropdown{max-width:120px}:host.ui-multi-input ::ng-deep .ui-dropdown .mdc-notched-outline__trailing{border-right-color:transparent!important;border-top-right-radius:0!important;border-bottom-right-radius:0!important}:host.ui-multi-input ::ng-deep .ui-dropdown:hover .mdc-notched-outline__trailing,:host.ui-multi-input ::ng-deep .ui-dropdown .mat-mdc-form-field-focused .mdc-notched-outline__trailing{border-right-color:#242424}:host.ui-multi-input ::ng-deep .ui-field .mdc-notched-outline__leading{border-top-left-radius:0!important;border-bottom-left-radius:0!important}:host.ui-multi-input ::ng-deep .ui-field .mat-mdc-form-field-subscript-wrapper{position:absolute!important;left:0!important;top:48px!important}:host.ui-multi-input ::ng-deep .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mat-mdc-form-field-infix{padding-top:0!important;padding-bottom:0!important;min-height:48px!important;align-items:center!important;display:flex!important}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.info{display:block;color:#888;width:100%;text-align:right}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.error{display:flex;gap:4px;color:#e02800;align-items:center;padding:4px 0 10px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.error svg{color:#e02800}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint:before{display:none}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error{color:#e02800;font-size:12px;line-height:16px;letter-spacing:.4px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error .errors{display:flex;align-items:center;padding:4px 0 10px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error svg{margin-right:4px;color:#e02800;row-gap:0}:host.ui-multi-input .separator-line{border-left:1px solid var(--mdc-outlined-text-field-outline-color);height:40px;margin:0 12px -7px 8px}:host.ui-multi-input ::ng-deep .mat-mdc-select .mat-mdc-select-arrow-wrapper{display:none}:host.ui-multi-input ::ng-deep .mdc-text-field--outlined{padding-left:12px!important}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "component", type: IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color", "filled", "applicationTheme", "useFullIconName"] }, { kind: "component", type: DropdownComponent, selector: "ui-dropdown", inputs: ["label", "name", "placeholder", "id", "value", "errors", "disabled", "valueList", "allowClear", "allowMultipleSelection", "required", "showBottomContent", "applicationTheme", "hideBuiltInErrors", "hideLabelInErrors", "textField", "valueField", "hasError", "companyColor"], outputs: ["closed", "opened"] }, { kind: "directive", type: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: ValidationErrorComponent, selector: "ui-validation-error", inputs: ["ngControl", "touchedOn", "errorMessage", "label", "applicationTheme"] }, { kind: "component", type: FieldComponent, selector: "ui-field", inputs: ["fullWidth", "label", "fieldName", "placeholder", "id", "value", "errors", "disabled", "required", "hintMessage", "type", "updateOnBlur", "allowOnlyDigits", "allowNegative", "showBottomContent", "applicationTheme", "ariaLabel", "loading", "isValid", "maxCharacters", "trimOnBlur", "trimOnSubmit", "maxRows", "hideBuiltInErrors", "hideLabelInErrors", "max", "min", "textareaHeight", "ariaLabelledby", "ariaDescribedby", "hasError"], outputs: ["validateEvent", "fieldBlur"] }, { kind: "pipe", type: HasValidationErrorPipe, name: "hasValidationError" }] }); }
15673
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: MultiInputComponent, selector: "ui-multi-input", inputs: { itemsList: "itemsList", itemTextField: "itemTextField", itemValueField: "itemValueField", value: "value", disabled: ["disabled", "disabled", booleanAttribute], required: ["required", "required", booleanAttribute], label: "label", placeholder: "placeholder", allowDecimal: ["allowDecimal", "allowDecimal", booleanAttribute], allowNegative: ["allowNegative", "allowNegative", booleanAttribute], applicationTheme: "applicationTheme", errors: "errors", hideBuiltInErrors: ["hideBuiltInErrors", "hideBuiltInErrors", booleanAttribute], hideLabelInErrors: ["hideLabelInErrors", "hideLabelInErrors", booleanAttribute], maxCharacters: "maxCharacters", validators: "validators", fullWidth: "fullWidth" }, outputs: { valueChange: "valueChange" }, host: { properties: { "attr.theme": "this.applicationTheme", "class.full-width": "this.fullWidth", "class": "this.class" } }, usesOnChanges: true, ngImport: i0, template: "<div [formGroup]=\"multiInputForm\">\n <div class=\"controls-wrapper\">\n <ui-dropdown\n [hasError]=\"controlHasError\"\n [formControlName]=\"itemValueField\"\n [valueList]=\"itemsList\"\n [textField]=\"itemTextField\"\n [valueField]=\"itemValueField\"\n [showBottomContent]=\"false\"\n [allowClear]=\"false\"\n (closed)=\"markAsTouched(); checkFormErrors()\"\n ></ui-dropdown>\n\n <ui-field\n [hasError]=\"controlHasError\"\n [formControlName]=\"'value'\"\n [label]=\"label\"\n [placeholder]=\"placeholder\"\n [required]=\"required\"\n [hideBuiltInErrors]=\"true\"\n [showBottomContent]=\"false\"\n [allowOnlyDigits]=\"true\"\n [fullWidth]=\"fullWidth\"\n (focusout)=\"markAsTouched(); checkFormErrors()\"\n ></ui-field>\n </div>\n\n <mat-hint class=\"info\" *ngIf=\"!controlHasError && maxCharacters && !errors?.length\">{{ getValueLength() }} / {{ maxCharacters }}</mat-hint>\n\n @if (errors?.length || (ngControl?.errors | hasValidationError)) {\n <mat-hint class=\"error\">\n @for (error of errors; track error) {\n <ui-icon\n [applicationTheme]=\"applicationTheme\"\n [name]=\"applicationTheme === 'classic' ? 'Error' : 'Error-in-line'\"\n ></ui-icon>{{ error }}\n }\n @if ((ngControl?.errors | hasValidationError) && !hideBuiltInErrors) {\n <ui-validation-error\n [touchedOn]=\"!controlHasError\"\n [ngControl]=\"ngControl\"\n [label]=\"hideLabelInErrors ? null : label\"\n ></ui-validation-error>\n }\n </mat-hint>\n }\n\n</div>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}:host.ui-multi-input{position:relative!important}:host.ui-multi-input .ng-untouched,:host.ui-multi-input .ng-touched{width:fit-content}:host.ui-multi-input.full-width .ng-untouched{width:100%}:host.ui-multi-input .controls-wrapper{display:flex}:host.ui-multi-input ::ng-deep ui-validation-error .errors{display:flex}:host.ui-multi-input ::ng-deep .ui-dropdown{max-width:120px}:host.ui-multi-input ::ng-deep .ui-dropdown .mdc-notched-outline__trailing{border-right-color:transparent!important;border-top-right-radius:0!important;border-bottom-right-radius:0!important}:host.ui-multi-input ::ng-deep .ui-dropdown:hover .mdc-notched-outline__trailing,:host.ui-multi-input ::ng-deep .ui-dropdown .mat-mdc-form-field-focused .mdc-notched-outline__trailing{border-right-color:#242424}:host.ui-multi-input ::ng-deep .ui-field .mdc-notched-outline__leading{border-top-left-radius:0!important;border-bottom-left-radius:0!important}:host.ui-multi-input ::ng-deep .ui-field .mat-mdc-form-field-subscript-wrapper{position:absolute!important;left:0!important;top:48px!important}:host.ui-multi-input ::ng-deep .mat-mdc-text-field-wrapper.mdc-text-field--outlined .mat-mdc-form-field-infix{padding-top:0!important;padding-bottom:0!important;min-height:48px!important;align-items:center!important;display:flex!important}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.info{display:block;color:#888;width:100%;text-align:right}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.error{display:flex;gap:4px;color:#e02800;align-items:center;padding:4px 0 10px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint.error svg{color:#e02800}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint:before{display:none}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error{color:#e02800;font-size:12px;line-height:16px;letter-spacing:.4px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error .errors{display:flex;align-items:center;padding:4px 0 10px}:host.ui-multi-input ::ng-deep .mat-mdc-form-field-hint ui-validation-error svg{margin-right:4px;color:#e02800;row-gap:0}:host.ui-multi-input .separator-line{border-left:1px solid var(--mdc-outlined-text-field-outline-color);height:40px;margin:0 12px -7px 8px}:host.ui-multi-input ::ng-deep .mat-mdc-select .mat-mdc-select-arrow-wrapper{display:none}:host.ui-multi-input ::ng-deep .mdc-text-field--outlined{padding-left:12px!important}\n"], dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "component", type: IconComponent, selector: "ui-icon", inputs: ["size", "cssClass", "name", "color", "filled", "applicationTheme", "useFullIconName"] }, { kind: "component", type: DropdownComponent, selector: "ui-dropdown", inputs: ["label", "name", "placeholder", "id", "value", "errors", "disabled", "valueList", "allowClear", "allowMultipleSelection", "required", "showBottomContent", "applicationTheme", "hideBuiltInErrors", "hideLabelInErrors", "textField", "valueField", "hasError", "companyColor"], outputs: ["closed", "opened"] }, { kind: "directive", type: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1$2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1$2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: ValidationErrorComponent, selector: "ui-validation-error", inputs: ["ngControl", "touchedOn", "errorMessage", "label", "applicationTheme"] }, { kind: "component", type: FieldComponent, selector: "ui-field", inputs: ["fullWidth", "label", "fieldName", "placeholder", "id", "value", "errors", "disabled", "required", "hintMessage", "type", "updateOnBlur", "allowOnlyDigits", "allowNegative", "showBottomContent", "applicationTheme", "ariaLabel", "loading", "isValid", "maxCharacters", "trimOnBlur", "trimOnSubmit", "maxRows", "hideBuiltInErrors", "hideLabelInErrors", "max", "min", "textareaHeight", "ariaLabelledby", "ariaDescribedby", "hasError"], outputs: ["validateEvent", "fieldBlur"] }, { kind: "pipe", type: HasValidationErrorPipe, name: "hasValidationError" }] }); }
15663
15674
  }
15664
15675
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MultiInputComponent, decorators: [{
15665
15676
  type: Component,
@@ -15715,6 +15726,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
15715
15726
  args: [{ transform: booleanAttribute }]
15716
15727
  }], maxCharacters: [{
15717
15728
  type: Input
15729
+ }], validators: [{
15730
+ type: Input
15718
15731
  }], fullWidth: [{
15719
15732
  type: HostBinding,
15720
15733
  args: ['class.full-width']