@testgorilla/tgo-ui 3.4.0 → 3.5.0

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.
@@ -5,8 +5,8 @@ import { MatIconRegistry } from '@angular/material/icon';
5
5
  import { DomSanitizer, SafeHtml } from '@angular/platform-browser';
6
6
  import { FieldType } from '../../components/field/field.model';
7
7
  import { ApplicationTheme } from '../../models/application-theme.model';
8
- import { IconName } from '../icon/icon.model';
9
8
  import { BadgeVariant } from '../badge/badge.model';
9
+ import { IconName } from '../icon/icon.model';
10
10
  import * as i0 from "@angular/core";
11
11
  /**
12
12
  * A global counter used to generate unique field IDs.
@@ -369,8 +369,8 @@ export class FieldComponent {
369
369
  }
370
370
  }
371
371
  writeValue(value) {
372
- if (value) {
373
- this.value = value || '';
372
+ if (value !== null && value !== undefined) {
373
+ this.value = value;
374
374
  }
375
375
  else {
376
376
  this.value = '';
@@ -516,4 +516,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
516
516
  type: ViewChild,
517
517
  args: ['inputElement', { read: ElementRef }]
518
518
  }] } });
519
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/field/field.component.ts","../../../../../projects/tgo-canopy-ui/components/field/field.component.html"],"names":[],"mappings":"AAEA,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EACT,QAAQ,EAGR,UAAU,EACV,YAAY,EACZ,WAAW,EACX,MAAM,EACN,KAAK,EACL,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,MAAM,EACN,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;;;;;;;;;;AAShE;;;;;;;GAOG;AACH,MAAM,CAAC,IAAI,OAAO,GAAG,CAAC,CAAC;AASvB,MAAM,OAAO,cAAc;IA8DzB;;;;;OAKG;IACH,IAAa,MAAM,CAAC,MAAgB;QAClC,IAAI,CAAC,OAAO,GAAG,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC,CAAC;QACtG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;IAC7C,CAAC;IA+OD,IAAI,eAAe;QACjB,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC;QACrD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;gBAC/C,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC;YAC7D,CAAC;iBAAM,CAAC;gBACN,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC;YAC3D,CAAC;QACH,CAAC;IACH,CAAC;IAmBD,YAC6E,eAAiC,EACpG,eAAgC,EAChC,YAA0B,EAC1B,GAAsB,EACH,SAAoB,EACvC,YAA0B,EAC1B,MAAc,EACd,UAAsB;QAP6C,oBAAe,GAAf,eAAe,CAAkB;QACpG,oBAAe,GAAf,eAAe,CAAiB;QAChC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,QAAG,GAAH,GAAG,CAAmB;QACH,cAAS,GAAT,SAAS,CAAW;QACvC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,WAAM,GAAN,MAAM,CAAQ;QACd,eAAU,GAAV,UAAU,CAAY;QA1VjB,UAAK,GAAG,UAAU,CAAC;QAElC;;;;;WAKG;QAGH,cAAS,GAAG,IAAI,CAAC;QAEjB;;;;;WAKG;QACM,UAAK,GAAI,EAAE,CAAC;QAUrB;;;;;WAKG;QACM,gBAAW,GAAI,EAAE,CAAC;QAE3B;;;;;WAKG;QACH,OAAE,GAAG,KAAK,CAAC,SAAS,OAAO,EAAE,EAAE,CAAC,CAAC;QAEjC;;;;;WAKG;QACM,UAAK,GAAG,EAAE,CAAC;QAsCpB;;;;;WAKG;QACM,aAAQ,GAAY,KAAK,CAAC;QAEnC;;;;;WAKG;QACM,gBAAW,GAAG,EAAE,CAAC;QAE1B;;;;;WAKG;QAGH,SAAI,GAAc,MAAM,CAAC;QAEzB;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAE9B;;;;;WAKG;QACM,oBAAe,GAAG,KAAK,CAAC;QAEjC;;;;;WAKG;QACM,kBAAa,GAAG,IAAI,CAAC;QAE9B;;;;;WAKG;QACM,sBAAiB,GAAG,IAAI,CAAC;QAElC;;;;;;WAMG;QAGH,qBAAgB,GAAqB,OAAO,CAAC;QAU7C;;;;;WAKG;QACM,YAAO,GAAG,KAAK,CAAC;QAEzB;;;;;WAKG;QACM,YAAO,GAAG,KAAK,CAAC;QAEzB;;;;;WAKG;QACM,kBAAa,GAAG,GAAG,CAAC;QAE7B;;;;;WAKG;QACM,eAAU,GAAG,KAAK,CAAC;QAC5B;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAC9B;;;;;WAKG;QACM,YAAO,GAAG,CAAC,CAAC;QACrB;;;;;WAKG;QACM,uBAAkB,GAAG,IAAI,CAAC;QAEnC;;;;;WAKG;QACM,sBAAiB,GAAG,KAAK,CAAC;QAEnC;;;;;WAKG;QACM,sBAAiB,GAAG,KAAK,CAAC;QAkBnC;;;;;WAKG;QACM,mBAAc,GAAG,GAAG,CAAC;QAE9B;;;;;WAKG;QACM,eAAU,GAAG,KAAK,CAAC;QAE5B;;;;;WAKG;QACgB,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,EAAE,YAAY,CAAC,CAAC;QAE/E;;;;;WAKG;QACgB,mBAAc,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;QACzE;;;;;WAKG;QACgB,sBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,EAAE,cAAc,CAAC,CAAC;QAElF;;;;;WAKG;QACgB,oBAAe,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;QAE1E;;;;WAIG;QACM,aAAQ,GAAG,KAAK,CAAC;QAEhB,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QAC3C,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAC;QAgB/C,kBAAa,GAAG,KAAK,CAAC;QACtB,kBAAa,GAAG,KAAK,CAAC;QAEtB,oBAAe,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAEb,uBAAkB,GAAG,QAAQ,CAAC;QAEjD;;WAEG;QACH,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAE1B;;WAEG;QACH,YAAO,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QA0KnB,cAAS,GAAG,CAAC,KAAa,EAAE,KAAU,EAAE,EAAE,CAAC,KAAK,CAAC,qCAAqC,CAAC;QA9JrF,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC;QAC1C,CAAC;QAED,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,EAAE,CAAC;YAC3B,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;QACtC,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY;aACd,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC;aACnB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aACzC,SAAS,CAAC,MAAM,CAAC,EAAE,CAClB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;YACnB,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC;QAClD,CAAC,CAAC,CACH,CAAC;IACN,CAAC;IAED;;;OAGG;IACH,SAAS;QACP,IAAI,IAAI,CAAC,SAAS,EAAE,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,CAAC;YACtD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAOD,QAAQ;QACN,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IACpC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,gCAAgC;IAChC,cAAc;QACZ,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;YAC/D,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,8BAA8B,CAAC,mBAAmB,CAAC,CAAC,CAAC;QACnH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC;IACH,CAAC;IAED,iCAAiC;IACjC,OAAO;QACL,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YAClD,OAAO,MAAM,CAAC;QAChB,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED,mBAAmB;IACnB,UAAU;QACR,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,qBAAqB;IACrB,iBAAiB;QACf,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;QACvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IACpC,CAAC;IAED,8BAA8B;IAC9B,mBAAmB;QACjB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,EAAE,CAAC;YAC/D,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;gBAChB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACzB,CAAC;YACD,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBACf,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACxB,CAAC;QACH,CAAC;IACH,CAAC;IAED,mCAAmC;IACnC,uDAAuD;IACvD,eAAe;QACb,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACrE,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,kBAAkB;IAClB,OAAO,CAAC,KAAU;QAChB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAChC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAC3C,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,EAAE,CAAC;QACjB,CAAC;QACD,IAAI,IAAI,CAAC,eAAe,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC;YACnE,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QACnB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACnE,CAAC;IACH,CAAC;IAED,UAAU,CAAC,KAAW;QACpB,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;QAC3B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAClB,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,QAAQ,CAAC,KAAc,EAAE,MAAc;QACrC,IAAI,MAAM,KAAK,OAAO,EAAE,CAAC;YACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC7B,CAAC;aAAM,IAAI,MAAM,KAAK,OAAO,EAAE,CAAC;YAC9B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAE3B,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;gBAC9B,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,CAAC;QACH,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IAID,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACnC,CAAC;IAED,qBAAqB,CAAC,GAAQ;QAC5B,UAAU,CAAC,GAAG,EAAE;YACd,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACxB,CAAC,EAAE,CAAC,CAAC,CAAC;IACR,CAAC;+GArgBU,cAAc,kBAoVH,oCAAoC;mGApV/C,cAAc,shKAoTU,UAAU,6BCvW/C,qkNAiLA;;4FD9Ha,cAAc;kBAP1B,SAAS;+BACE,UAAU,iBAGL,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;;0BAsV5C,QAAQ;;0BAAI,MAAM;2BAAC,oCAAoC;;0BAIvD,QAAQ;;0BAAI,IAAI;kHAvVJ,KAAK;sBAAnB,WAAW;gBAUZ,SAAS;sBAFR,WAAW;uBAAC,kBAAkB;;sBAC9B,KAAK;gBASG,KAAK;sBAAb,KAAK;gBAQG,SAAS;sBAAjB,KAAK;gBAQG,WAAW;sBAAnB,KAAK;gBAgBG,KAAK;sBAAb,KAAK;gBAQG,YAAY;sBAApB,KAAK;gBASO,MAAM;sBAAlB,KAAK;gBAWG,QAAQ;sBAAhB,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBAQG,QAAQ;sBAAhB,KAAK;gBAQG,WAAW;sBAAnB,KAAK;gBAUN,IAAI;sBAFH,WAAW;uBAAC,kBAAkB;;sBAC9B,KAAK;gBASG,YAAY;sBAApB,KAAK;gBAQG,eAAe;sBAAvB,KAAK;gBAQG,aAAa;sBAArB,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAWN,gBAAgB;sBAFf,WAAW;uBAAC,YAAY;;sBACxB,KAAK;gBASG,SAAS;sBAAjB,KAAK;gBAQG,OAAO;sBAAf,KAAK;gBAQG,OAAO;sBAAf,KAAK;gBAQG,aAAa;sBAArB,KAAK;gBAQG,UAAU;sBAAlB,KAAK;gBAOG,YAAY;sBAApB,KAAK;gBAOG,OAAO;sBAAf,KAAK;gBAOG,kBAAkB;sBAA1B,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAQG,iBAAiB;sBAAzB,KAAK;gBAQG,GAAG;sBAAX,KAAK;gBAQG,GAAG;sBAAX,KAAK;gBAQG,cAAc;sBAAtB,KAAK;gBAQG,UAAU;sBAAlB,KAAK;gBAsCG,QAAQ;sBAAhB,KAAK;gBAEI,aAAa;sBAAtB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBAE0C,KAAK;sBAArD,SAAS;uBAAC,cAAc,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE","sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport { FocusMonitor } from '@angular/cdk/a11y';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  computed,\n  DestroyRef,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  input,\n  Input,\n  NgZone,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { FieldType } from '../../components/field/field.model';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { IconName } from '../icon/icon.model';\nimport { BadgeVariant } from '../badge/badge.model';\n\n/**\n * A global counter used to generate unique field IDs.\n * This variable is incremented each time a new field ID is needed.\n *\n * @remarks\n * This is primarily used to ensure that each field component\n * has a unique identifier within the application / useful for their Aria Labels.\n */\nexport let fieldID = 0;\n\n@Component({\n  selector: 'ui-field',\n  templateUrl: './field.component.html',\n  styleUrls: ['./field.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FieldComponent implements OnInit, ControlValueAccessor, DoCheck, AfterViewInit {\n  @HostBinding() class = 'ui-field';\n\n  /**\n   * Indicator of the autocomplete width\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @HostBinding('class.full-width')\n  @Input()\n  fullWidth = true;\n\n  /**\n   * Form field label\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() label? = '';\n\n  /**\n   * Input name attribute\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() fieldName?: string;\n\n  /**\n   * Input placeholder\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() placeholder? = '';\n\n  /**\n   * Input id\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  id = input(`field-${fieldID++}`);\n\n  /**\n   * Input value\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() value = '';\n\n  /**\n   * Variant of badge to use\n   *\n   * @type {BadgeVariant}\n   * @memberof FieldComponent\n   */\n  @Input() badgeVariant?: BadgeVariant | undefined;\n\n  _errors: SafeHtml[];\n  /**\n   * Input field errors\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this._errors = errors?.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));\n    this.errorsLength = this.setErrorsLength();\n  }\n\n  /**\n   * Determines if input is disabled\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() disabled: boolean;\n\n  /**\n   * Input is required or not\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   * Input is readonly or not\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() readOnly: boolean = false;\n\n  /**\n   * Hint text\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() hintMessage = '';\n\n  /**\n   * Input type\n   *\n   * @type {FieldType}\n   * @memberof FieldComponent\n   */\n  @HostBinding('attr.field-class')\n  @Input()\n  type: FieldType = 'text';\n\n  /**\n   * Input is update only on blur\n   *\n   * @type {Boolean}\n   * @memberof FieldComponent\n   */\n  @Input() updateOnBlur = false;\n\n  /**\n   * allow only digits in input\n   *\n   * @type {Boolean}\n   * @memberof FieldComponent\n   */\n  @Input() allowOnlyDigits = false;\n\n  /**\n   * allow negative numbers\n   *\n   * @type {Boolean}\n   * @memberof FieldComponent\n   */\n  @Input() allowNegative = true;\n\n  /**\n   * Show reserved content below form field\n   * @property showBottomContent\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() showBottomContent = true;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof FieldComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * A string representing the ARIA label for accessibility.\n   * This label is used to provide an accessible name for the input element.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() ariaLabel: string;\n\n  /**\n   * Show loading button. Only for text\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() loading = false;\n\n  /**\n   * Show icon when field is valid\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() isValid = false;\n\n  /**\n   * Max characters number\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() maxCharacters = 255;\n\n  /**\n   * Trim text on blur\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() trimOnBlur = false;\n  /**\n   * Trim text on submit\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() trimOnSubmit = false;\n  /**\n   * Max rows for multi-line type\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() maxRows = 0;\n  /**\n   * has text area counter\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() hasTextAreaCounter = true;\n\n  /**\n   * Hide in build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  /**\n   * Set maximum number\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() max: number | undefined;\n\n  /**\n   * Set minimum number\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() min: number | undefined;\n\n  /**\n   * Sets textarea height. Default 110\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() textareaHeight = 110;\n\n  /**\n   * Sets textarea borderless. Default false\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() borderless = false;\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used for input field Aria Labeled By Element Id.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  protected readonly ariaLabelledbyId = computed(() => `${this.id()}-labeledBy`);\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used for input field Aria LabeledBy Text.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  protected readonly ariaLabelledby = input<string | undefined>(undefined);\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used for input field Aria Described By Element Id.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  protected readonly ariaDescribedbyId = computed(() => `${this.id()}-describedBy`);\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used for input field Aria DescribedBy Text.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  protected readonly ariaDescribedby = input<string | undefined>(undefined);\n\n  /**\n   * Show state of error\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() hasError = false;\n\n  @Output() validateEvent = new EventEmitter<string>();\n  @Output() fieldBlur = new EventEmitter<void>();\n\n  @ViewChild('inputElement', { read: ElementRef }) field: ElementRef<HTMLInputElement>;\n\n  get getPasswordIcon(): IconName {\n    if (this.applicationTheme === 'classic') {\n      return this.showPassword ? 'Eye-hide' : 'Eye-view';\n    } else {\n      if (!this.isActiveField && !this.isActiveHover) {\n        return this.showPassword ? 'View-in-line' : 'Hide-in-line';\n      } else {\n        return this.showPassword ? 'View-filled' : 'Hide-filled';\n      }\n    }\n  }\n\n  isActiveField = false;\n  isActiveHover = false;\n\n  keyboardFocused = signal(false);\n\n  protected readonly translationContext = 'FIELD.';\n\n  /**\n   * @ignore\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = () => {};\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private matIconRegistry: MatIconRegistry,\n    private domSanitizer: DomSanitizer,\n    private cdr: ChangeDetectorRef,\n    @Optional() @Self() public ngControl: NgControl,\n    private focusMonitor: FocusMonitor,\n    private ngZone: NgZone,\n    private destroyRef: DestroyRef\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.focusMonitor\n      .monitor(this.field)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(origin =>\n        this.ngZone.run(() => {\n          this.keyboardFocused.set(origin === 'keyboard');\n        })\n      );\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\n   * to display validation errors that might happen (e.g. required)\n   */\n  ngDoCheck(): void {\n    if (this.ngControl?.touched || this.ngControl?.errors) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  showClose: boolean;\n  showPassword: boolean;\n  currentType: string;\n  errorsLength: boolean;\n\n  ngOnInit(): void {\n    this.setSearchInput();\n    this.currentType = this.getType();\n  }\n\n  validate(): void {\n    this.validateEvent.emit(this.value);\n  }\n\n  //set search input initial value\n  setSearchInput(): void {\n    if (this.type === 'search' || this.type === 'collapsed-search') {\n      this.matIconRegistry.addSvgIcon('Search', this.domSanitizer.bypassSecurityTrustResourceUrl('/icons/Search.svg'));\n    } else {\n      this.showClose = false;\n    }\n  }\n\n  //change type for reveal password\n  getType(): string {\n    if (this.type === 'password' && this.showPassword) {\n      return 'text';\n    }\n    return this.type;\n  }\n\n  //Clear input value\n  clearValue(): void {\n    this.value = '';\n    this.onChange(this.value);\n    this.onChangeInputSearch();\n  }\n\n  //toggle for password\n  showPasswordClick() {\n    this.showPassword = !this.showPassword;\n    this.currentType = this.getType();\n  }\n\n  //Set options for search input\n  onChangeInputSearch() {\n    if (this.type === 'search' || this.type === 'collapsed-search') {\n      if (!this.value) {\n        this.showClose = false;\n      }\n      if (this.value) {\n        this.showClose = true;\n      }\n    }\n  }\n\n  // Set errors length for validation\n  // Consider only those errors which which are not empty\n  setErrorsLength(): boolean {\n    if (!!this._errors) {\n      return this._errors.filter(err => !!err).length > 0 ? true : false;\n    }\n    return false;\n  }\n\n  //Save input value\n  onInput(event: any) {\n    this.value = event.target.value;\n    this.errorsLength = this.setErrorsLength();\n    if (!this.updateOnBlur) {\n      this.onTouch();\n    }\n    if (this.allowOnlyDigits && !this.allowNegative && +this.value < 0) {\n      this.value = '0';\n    } else {\n      this.onChange(this.type === 'number' ? +this.value : this.value);\n    }\n  }\n\n  writeValue(value?: any): void {\n    if (value) {\n      this.value = value || '';\n    } else {\n      this.value = '';\n    }\n    this.cdr.markForCheck();\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  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  onActive(state: boolean, action: string): void {\n    if (action === 'hover') {\n      this.isActiveHover = state;\n    } else if (action === 'focus') {\n      this.isActiveField = state;\n\n      if (!state && this.trimOnBlur) {\n        this.clearSpace();\n      }\n    }\n  }\n\n  onSubmit(): void {\n    if (this.trimOnSubmit) {\n      this.clearSpace();\n    }\n  }\n\n  private clearSpace(): void {\n    this.value = this.value.trim();\n    this.onChange(this.value);\n  }\n\n  onBlur(): void {\n    this.fieldBlur.emit();\n  }\n\n  trackByFn = (index: number, value: any) => value.changingThisBreaksApplicationSecurity;\n\n  focus(): void {\n    this.field.nativeElement.focus();\n  }\n\n  refocusPasswordButton(btn: any) {\n    setTimeout(() => {\n      btn.focus('keyboard');\n    }, 0);\n  }\n}\n","<ng-container>\n  <mat-form-field\n    [ngStyle]=\"{\n      '--textarea-height': textareaHeight - 10 + 'px',\n      '--textarea-height-container': textareaHeight + 'px',\n    }\"\n    #uiField\n    appearance=\"outline\"\n    [color]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError ? 'warn' : 'accent'\"\n    [ngClass]=\"{\n      'hide-bottom-content': !showBottomContent,\n      textarea: type === 'textarea',\n      'multi-line': type === 'multi-line',\n      'keyboard-focused': keyboardFocused(),\n      'has-label': !!label,\n      'has-value': !!value,\n      'text-area-borderless': type === 'textarea' && borderless,\n    }\"\n    (mouseenter)=\"onActive(true, 'hover')\"\n    (mouseleave)=\"onActive(false, 'hover')\"\n  >\n    <span [style.display]=\"'none'\" [id]=\"ariaDescribedbyId()\">\n      @if (required) {\n        <span>{{ 'ERRORS.REQUIRED' | uiTranslate | async }}</span>\n      }\n      {{ ariaDescribedby() }}\n    </span>\n    <span [style.display]=\"'none'\" [id]=\"ariaLabelledbyId()\">\n      {{ ariaLabelledby() ?? label }}\n    </span>\n    <mat-label\n      *ngIf=\"label && ((type !== 'search' && applicationTheme === 'classic') || applicationTheme !== 'classic')\"\n      >{{ label }}</mat-label\n    >\n    <mat-icon\n      *ngIf=\"type === 'search' || type === 'collapsed-search'\"\n      matIconPrefix\n      class=\"search-icon\"\n      [svgIcon]=\"'Search'\"\n    ></mat-icon>\n    <input\n      [readonly]=\"readOnly\"\n      *ngIf=\"type !== 'textarea' && type !== 'multi-line'; else textarea\"\n      matInput\n      #inputElement\n      (blur)=\"onTouch(); onActive(false, 'focus'); onBlur()\"\n      (input)=\"onInput($event)\"\n      [id]=\"id()\"\n      (keyup)=\"onChangeInputSearch()\"\n      [placeholder]=\"placeholder!\"\n      [value]=\"value\"\n      [disabled]=\"disabled || loading\"\n      [type]=\"currentType\"\n      (keyup.enter)=\"onSubmit()\"\n      [max]=\"max\"\n      [min]=\"min\"\n      [name]=\"fieldName!\"\n      [required]=\"required\"\n      [attr.aria-label]=\"ariaLabel\"\n      [attr.aria-invalid]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError\"\n      [attr.aria-labelledby]=\"ariaLabelledbyId()\"\n      [attr.aria-describedby]=\"ariaDescribedbyId()\"\n      role=\"textbox\"\n      digitsOnly\n      [allowOnlyDigits]=\"allowOnlyDigits\"\n      [allowNegative]=\"allowNegative\"\n      (focusin)=\"onActive(true, 'focus')\"\n    />\n\n    <ng-template #textarea>\n      <textarea\n        matInput\n        #inputElement\n        [readonly]=\"readOnly\"\n        (blur)=\"onTouch(); onActive(false, 'focus'); onBlur()\"\n        (input)=\"onInput($event)\"\n        [id]=\"id()\"\n        (keyup)=\"onChangeInputSearch()\"\n        (keyup.enter)=\"onSubmit()\"\n        [placeholder]=\"placeholder!\"\n        [value]=\"value\"\n        [disabled]=\"disabled\"\n        [type]=\"currentType\"\n        [name]=\"fieldName!\"\n        [required]=\"required\"\n        [attr.aria-label]=\"!label ? ariaLabel : ''\"\n        [attr.aria-invalid]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError\"\n        [attr.aria-labelledby]=\"ariaLabelledbyId()\"\n        [attr.aria-describedby]=\"ariaDescribedbyId()\"\n        role=\"textbox\"\n        [cdkTextareaAutosize]=\"type === 'multi-line'\"\n        [cdkAutosizeMinRows]=\"type === 'multi-line' ? 1 : 5\"\n        [cdkAutosizeMaxRows]=\"type === 'multi-line' ? maxRows : 5\"\n        (focusin)=\"onActive(true, 'focus')\"\n      ></textarea>\n    </ng-template>\n\n    <div class=\"options\" *ngIf=\"type === 'search' || type === 'collapsed-search' || type === 'password' || type === 'validation-text'\">\n      <div class=\"options-container\">\n        <ui-button\n          *ngIf=\"showClose\"\n          variant=\"secondary\"\n          [justIcon]=\"true\"\n          class=\"close\"\n          iconName=\"Close\"\n          [label]=\"('COMMON.CLEAR' | uiTranslate | async)!\"\n          (buttonClickEvent)=\"clearValue()\"\n          [ariaLabel]=\"ariaLabel + '--' + ('COMMON.CLEAR' | uiTranslate | async)\"\n        ></ui-button>\n        <ui-button\n          class=\"password\"\n          variant=\"secondary\"\n          [tooltip]=\"((showPassword ? 'FIELD.HIDE_PASSWORD' : 'FIELD.SHOW_PASSWORD') | uiTranslate | async)!\"\n          *ngIf=\"type === 'password'\"\n          [justIcon]=\"true\"\n          role=\"switch\"\n          [attr.aria-checked]=\"showPassword\"\n          [iconName]=\"getPasswordIcon\"\n          [applicationTheme]=\"applicationTheme\"\n          (click)=\"showPasswordClick()\"\n          #btn\n          (keydown.enter)=\"refocusPasswordButton(btn)\"\n          (keydown.space)=\"refocusPasswordButton(btn)\"\n        ></ui-button>\n\n        <ng-container\n          *ngIf=\"\n            type === 'validation-text' && (applicationTheme === 'dark' || applicationTheme === 'light') && value.length\n          \"\n        >\n          <ui-button\n            *ngIf=\"!isValid\"\n            class=\"validation\"\n            [variant]=\"'text'\"\n            [applicationTheme]=\"'light'\"\n            [label]=\"'Validate'\"\n            [loading]=\"loading\"\n            (click)=\"validate()\"\n            [disabled]=\"disabled\"\n            [size]=\"'small'\"\n          ></ui-button>\n          <ui-icon class=\"valid\" [color]=\"'white'\" applicationTheme=\"light\" [name]=\"'Check'\" *ngIf=\"isValid\"></ui-icon>\n        </ng-container>\n      </div>\n    </div>\n    @if (hasTextAreaCounter) {\n      <mat-hint class=\"info\" *ngIf=\"type === 'textarea' && !errorsLength && !(ngControl?.errors | hasValidationError)\"\n        >{{ value.length }} / {{ maxCharacters }}</mat-hint\n      >\n    }\n\n    <mat-hint\n      class=\"info\"\n      *ngIf=\"hintMessage && !errorsLength && !(ngControl?.errors | hasValidationError) && type !== 'textarea'\"\n      >{{ hintMessage }}</mat-hint\n    >\n    <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.errors | hasValidationError)\">\n      <ng-template [ngIf]=\"errorsLength\">\n        <div class=\"errors\" *ngFor=\"let error of _errors; trackBy: trackByFn\">\n          <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n          <span [innerHTML]=\"error\"></span>\n        </div>\n      </ng-template>\n\n      <ui-validation-error\n        *ngIf=\"ngControl && !hideBuiltInErrors\"\n        [ngControl]=\"ngControl\"\n        [label]=\"hideLabelInErrors ? null : label\"\n      ></ui-validation-error>\n    </mat-hint>\n\n    @if (badgeVariant) {\n      <ui-badge class=\"field-badge\"\n                [variant]=\"badgeVariant\"></ui-badge>\n    }\n  </mat-form-field>\n</ng-container>\n"]}
519
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/field/field.component.ts","../../../../../projects/tgo-canopy-ui/components/field/field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport { FocusMonitor } from '@angular/cdk/a11y';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  computed,\n  DestroyRef,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  input,\n  Input,\n  NgZone,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { FieldType } from '../../components/field/field.model';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { BadgeVariant } from '../badge/badge.model';\nimport { IconName } from '../icon/icon.model';\n\n/**\n * A global counter used to generate unique field IDs.\n * This variable is incremented each time a new field ID is needed.\n *\n * @remarks\n * This is primarily used to ensure that each field component\n * has a unique identifier within the application / useful for their Aria Labels.\n */\nexport let fieldID = 0;\n\n@Component({\n  selector: 'ui-field',\n  templateUrl: './field.component.html',\n  styleUrls: ['./field.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FieldComponent implements OnInit, ControlValueAccessor, DoCheck, AfterViewInit {\n  @HostBinding() class = 'ui-field';\n\n  /**\n   * Indicator of the autocomplete width\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @HostBinding('class.full-width')\n  @Input()\n  fullWidth = true;\n\n  /**\n   * Form field label\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() label? = '';\n\n  /**\n   * Input name attribute\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() fieldName?: string;\n\n  /**\n   * Input placeholder\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() placeholder? = '';\n\n  /**\n   * Input id\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  id = input(`field-${fieldID++}`);\n\n  /**\n   * Input value\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() value = '';\n\n  /**\n   * Variant of badge to use\n   *\n   * @type {BadgeVariant}\n   * @memberof FieldComponent\n   */\n  @Input() badgeVariant?: BadgeVariant | undefined;\n\n  _errors: SafeHtml[];\n  /**\n   * Input field errors\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this._errors = errors?.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));\n    this.errorsLength = this.setErrorsLength();\n  }\n\n  /**\n   * Determines if input is disabled\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() disabled: boolean;\n\n  /**\n   * Input is required or not\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   * Input is readonly or not\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() readOnly: boolean = false;\n\n  /**\n   * Hint text\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() hintMessage = '';\n\n  /**\n   * Input type\n   *\n   * @type {FieldType}\n   * @memberof FieldComponent\n   */\n  @HostBinding('attr.field-class')\n  @Input()\n  type: FieldType = 'text';\n\n  /**\n   * Input is update only on blur\n   *\n   * @type {Boolean}\n   * @memberof FieldComponent\n   */\n  @Input() updateOnBlur = false;\n\n  /**\n   * allow only digits in input\n   *\n   * @type {Boolean}\n   * @memberof FieldComponent\n   */\n  @Input() allowOnlyDigits = false;\n\n  /**\n   * allow negative numbers\n   *\n   * @type {Boolean}\n   * @memberof FieldComponent\n   */\n  @Input() allowNegative = true;\n\n  /**\n   * Show reserved content below form field\n   * @property showBottomContent\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() showBottomContent = true;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof FieldComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * A string representing the ARIA label for accessibility.\n   * This label is used to provide an accessible name for the input element.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() ariaLabel: string;\n\n  /**\n   * Show loading button. Only for text\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() loading = false;\n\n  /**\n   * Show icon when field is valid\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() isValid = false;\n\n  /**\n   * Max characters number\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() maxCharacters = 255;\n\n  /**\n   * Trim text on blur\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() trimOnBlur = false;\n  /**\n   * Trim text on submit\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() trimOnSubmit = false;\n  /**\n   * Max rows for multi-line type\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() maxRows = 0;\n  /**\n   * has text area counter\n   *\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() hasTextAreaCounter = true;\n\n  /**\n   * Hide in build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  /**\n   * Set maximum number\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() max: number | undefined;\n\n  /**\n   * Set minimum number\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() min: number | undefined;\n\n  /**\n   * Sets textarea height. Default 110\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() textareaHeight = 110;\n\n  /**\n   * Sets textarea borderless. Default false\n   *\n   * @type {number}\n   * @memberof FieldComponent\n   */\n  @Input() borderless = false;\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used for input field Aria Labeled By Element Id.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  protected readonly ariaLabelledbyId = computed(() => `${this.id()}-labeledBy`);\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used for input field Aria LabeledBy Text.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  protected readonly ariaLabelledby = input<string | undefined>(undefined);\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used for input field Aria Described By Element Id.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  protected readonly ariaDescribedbyId = computed(() => `${this.id()}-describedBy`);\n\n  /**\n   * A string representing the ARIA requirement for accessibility.\n   * This attribute is used for input field Aria DescribedBy Text.\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  protected readonly ariaDescribedby = input<string | undefined>(undefined);\n\n  /**\n   * Show state of error\n   * @type {boolean}\n   * @memberof FieldComponent\n   */\n  @Input() hasError = false;\n\n  @Output() validateEvent = new EventEmitter<string>();\n  @Output() fieldBlur = new EventEmitter<void>();\n\n  @ViewChild('inputElement', { read: ElementRef }) field: ElementRef<HTMLInputElement>;\n\n  get getPasswordIcon(): IconName {\n    if (this.applicationTheme === 'classic') {\n      return this.showPassword ? 'Eye-hide' : 'Eye-view';\n    } else {\n      if (!this.isActiveField && !this.isActiveHover) {\n        return this.showPassword ? 'View-in-line' : 'Hide-in-line';\n      } else {\n        return this.showPassword ? 'View-filled' : 'Hide-filled';\n      }\n    }\n  }\n\n  isActiveField = false;\n  isActiveHover = false;\n\n  keyboardFocused = signal(false);\n\n  protected readonly translationContext = 'FIELD.';\n\n  /**\n   * @ignore\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = () => {};\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private matIconRegistry: MatIconRegistry,\n    private domSanitizer: DomSanitizer,\n    private cdr: ChangeDetectorRef,\n    @Optional() @Self() public ngControl: NgControl,\n    private focusMonitor: FocusMonitor,\n    private ngZone: NgZone,\n    private destroyRef: DestroyRef\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.focusMonitor\n      .monitor(this.field)\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(origin =>\n        this.ngZone.run(() => {\n          this.keyboardFocused.set(origin === 'keyboard');\n        })\n      );\n  }\n\n  /**\n   * Used to mark component view as dirty when touched programmatically with markAsTouched/markAllAsTouched or errors\n   * to display validation errors that might happen (e.g. required)\n   */\n  ngDoCheck(): void {\n    if (this.ngControl?.touched || this.ngControl?.errors) {\n      this.cdr.markForCheck();\n    }\n  }\n\n  showClose: boolean;\n  showPassword: boolean;\n  currentType: string;\n  errorsLength: boolean;\n\n  ngOnInit(): void {\n    this.setSearchInput();\n    this.currentType = this.getType();\n  }\n\n  validate(): void {\n    this.validateEvent.emit(this.value);\n  }\n\n  //set search input initial value\n  setSearchInput(): void {\n    if (this.type === 'search' || this.type === 'collapsed-search') {\n      this.matIconRegistry.addSvgIcon('Search', this.domSanitizer.bypassSecurityTrustResourceUrl('/icons/Search.svg'));\n    } else {\n      this.showClose = false;\n    }\n  }\n\n  //change type for reveal password\n  getType(): string {\n    if (this.type === 'password' && this.showPassword) {\n      return 'text';\n    }\n    return this.type;\n  }\n\n  //Clear input value\n  clearValue(): void {\n    this.value = '';\n    this.onChange(this.value);\n    this.onChangeInputSearch();\n  }\n\n  //toggle for password\n  showPasswordClick() {\n    this.showPassword = !this.showPassword;\n    this.currentType = this.getType();\n  }\n\n  //Set options for search input\n  onChangeInputSearch() {\n    if (this.type === 'search' || this.type === 'collapsed-search') {\n      if (!this.value) {\n        this.showClose = false;\n      }\n      if (this.value) {\n        this.showClose = true;\n      }\n    }\n  }\n\n  // Set errors length for validation\n  // Consider only those errors which which are not empty\n  setErrorsLength(): boolean {\n    if (!!this._errors) {\n      return this._errors.filter(err => !!err).length > 0 ? true : false;\n    }\n    return false;\n  }\n\n  //Save input value\n  onInput(event: any) {\n    this.value = event.target.value;\n    this.errorsLength = this.setErrorsLength();\n    if (!this.updateOnBlur) {\n      this.onTouch();\n    }\n    if (this.allowOnlyDigits && !this.allowNegative && +this.value < 0) {\n      this.value = '0';\n    } else {\n      this.onChange(this.type === 'number' ? +this.value : this.value);\n    }\n  }\n\n  writeValue(value?: any): void {\n    if (value !== null && value !== undefined) {\n      this.value = value;\n    } else {\n      this.value = '';\n    }\n    this.cdr.markForCheck();\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  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  onActive(state: boolean, action: string): void {\n    if (action === 'hover') {\n      this.isActiveHover = state;\n    } else if (action === 'focus') {\n      this.isActiveField = state;\n\n      if (!state && this.trimOnBlur) {\n        this.clearSpace();\n      }\n    }\n  }\n\n  onSubmit(): void {\n    if (this.trimOnSubmit) {\n      this.clearSpace();\n    }\n  }\n\n  private clearSpace(): void {\n    this.value = this.value.trim();\n    this.onChange(this.value);\n  }\n\n  onBlur(): void {\n    this.fieldBlur.emit();\n  }\n\n  trackByFn = (index: number, value: any) => value.changingThisBreaksApplicationSecurity;\n\n  focus(): void {\n    this.field.nativeElement.focus();\n  }\n\n  refocusPasswordButton(btn: any) {\n    setTimeout(() => {\n      btn.focus('keyboard');\n    }, 0);\n  }\n}\n","<ng-container>\n  <mat-form-field\n    [ngStyle]=\"{\n      '--textarea-height': textareaHeight - 10 + 'px',\n      '--textarea-height-container': textareaHeight + 'px',\n    }\"\n    #uiField\n    appearance=\"outline\"\n    [color]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError ? 'warn' : 'accent'\"\n    [ngClass]=\"{\n      'hide-bottom-content': !showBottomContent,\n      textarea: type === 'textarea',\n      'multi-line': type === 'multi-line',\n      'keyboard-focused': keyboardFocused(),\n      'has-label': !!label,\n      'has-value': !!value,\n      'text-area-borderless': type === 'textarea' && borderless,\n    }\"\n    (mouseenter)=\"onActive(true, 'hover')\"\n    (mouseleave)=\"onActive(false, 'hover')\"\n  >\n    <span [style.display]=\"'none'\" [id]=\"ariaDescribedbyId()\">\n      @if (required) {\n        <span>{{ 'ERRORS.REQUIRED' | uiTranslate | async }}</span>\n      }\n      {{ ariaDescribedby() }}\n    </span>\n    <span [style.display]=\"'none'\" [id]=\"ariaLabelledbyId()\">\n      {{ ariaLabelledby() ?? label }}\n    </span>\n    <mat-label\n      *ngIf=\"label && ((type !== 'search' && applicationTheme === 'classic') || applicationTheme !== 'classic')\"\n      >{{ label }}</mat-label\n    >\n    <mat-icon\n      *ngIf=\"type === 'search' || type === 'collapsed-search'\"\n      matIconPrefix\n      class=\"search-icon\"\n      [svgIcon]=\"'Search'\"\n    ></mat-icon>\n    <input\n      [readonly]=\"readOnly\"\n      *ngIf=\"type !== 'textarea' && type !== 'multi-line'; else textarea\"\n      matInput\n      #inputElement\n      (blur)=\"onTouch(); onActive(false, 'focus'); onBlur()\"\n      (input)=\"onInput($event)\"\n      [id]=\"id()\"\n      (keyup)=\"onChangeInputSearch()\"\n      [placeholder]=\"placeholder!\"\n      [value]=\"value\"\n      [disabled]=\"disabled || loading\"\n      [type]=\"currentType\"\n      (keyup.enter)=\"onSubmit()\"\n      [max]=\"max\"\n      [min]=\"min\"\n      [name]=\"fieldName!\"\n      [required]=\"required\"\n      [attr.aria-label]=\"ariaLabel\"\n      [attr.aria-invalid]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError\"\n      [attr.aria-labelledby]=\"ariaLabelledbyId()\"\n      [attr.aria-describedby]=\"ariaDescribedbyId()\"\n      role=\"textbox\"\n      digitsOnly\n      [allowOnlyDigits]=\"allowOnlyDigits\"\n      [allowNegative]=\"allowNegative\"\n      (focusin)=\"onActive(true, 'focus')\"\n    />\n\n    <ng-template #textarea>\n      <textarea\n        matInput\n        #inputElement\n        [readonly]=\"readOnly\"\n        (blur)=\"onTouch(); onActive(false, 'focus'); onBlur()\"\n        (input)=\"onInput($event)\"\n        [id]=\"id()\"\n        (keyup)=\"onChangeInputSearch()\"\n        (keyup.enter)=\"onSubmit()\"\n        [placeholder]=\"placeholder!\"\n        [value]=\"value\"\n        [disabled]=\"disabled\"\n        [type]=\"currentType\"\n        [name]=\"fieldName!\"\n        [required]=\"required\"\n        [attr.aria-label]=\"!label ? ariaLabel : ''\"\n        [attr.aria-invalid]=\"errorsLength || (ngControl?.errors && ngControl?.touched) || hasError\"\n        [attr.aria-labelledby]=\"ariaLabelledbyId()\"\n        [attr.aria-describedby]=\"ariaDescribedbyId()\"\n        role=\"textbox\"\n        [cdkTextareaAutosize]=\"type === 'multi-line'\"\n        [cdkAutosizeMinRows]=\"type === 'multi-line' ? 1 : 5\"\n        [cdkAutosizeMaxRows]=\"type === 'multi-line' ? maxRows : 5\"\n        (focusin)=\"onActive(true, 'focus')\"\n      ></textarea>\n    </ng-template>\n\n    <div class=\"options\" *ngIf=\"type === 'search' || type === 'collapsed-search' || type === 'password' || type === 'validation-text'\">\n      <div class=\"options-container\">\n        <ui-button\n          *ngIf=\"showClose\"\n          variant=\"secondary\"\n          [justIcon]=\"true\"\n          class=\"close\"\n          iconName=\"Close\"\n          [label]=\"('COMMON.CLEAR' | uiTranslate | async)!\"\n          (buttonClickEvent)=\"clearValue()\"\n          [ariaLabel]=\"ariaLabel + '--' + ('COMMON.CLEAR' | uiTranslate | async)\"\n        ></ui-button>\n        <ui-button\n          class=\"password\"\n          variant=\"secondary\"\n          [tooltip]=\"((showPassword ? 'FIELD.HIDE_PASSWORD' : 'FIELD.SHOW_PASSWORD') | uiTranslate | async)!\"\n          *ngIf=\"type === 'password'\"\n          [justIcon]=\"true\"\n          role=\"switch\"\n          [attr.aria-checked]=\"showPassword\"\n          [iconName]=\"getPasswordIcon\"\n          [applicationTheme]=\"applicationTheme\"\n          (click)=\"showPasswordClick()\"\n          #btn\n          (keydown.enter)=\"refocusPasswordButton(btn)\"\n          (keydown.space)=\"refocusPasswordButton(btn)\"\n        ></ui-button>\n\n        <ng-container\n          *ngIf=\"\n            type === 'validation-text' && (applicationTheme === 'dark' || applicationTheme === 'light') && value.length\n          \"\n        >\n          <ui-button\n            *ngIf=\"!isValid\"\n            class=\"validation\"\n            [variant]=\"'text'\"\n            [applicationTheme]=\"'light'\"\n            [label]=\"'Validate'\"\n            [loading]=\"loading\"\n            (click)=\"validate()\"\n            [disabled]=\"disabled\"\n            [size]=\"'small'\"\n          ></ui-button>\n          <ui-icon class=\"valid\" [color]=\"'white'\" applicationTheme=\"light\" [name]=\"'Check'\" *ngIf=\"isValid\"></ui-icon>\n        </ng-container>\n      </div>\n    </div>\n    @if (hasTextAreaCounter) {\n      <mat-hint class=\"info\" *ngIf=\"type === 'textarea' && !errorsLength && !(ngControl?.errors | hasValidationError)\"\n        >{{ value.length }} / {{ maxCharacters }}</mat-hint\n      >\n    }\n\n    <mat-hint\n      class=\"info\"\n      *ngIf=\"hintMessage && !errorsLength && !(ngControl?.errors | hasValidationError) && type !== 'textarea'\"\n      >{{ hintMessage }}</mat-hint\n    >\n    <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.errors | hasValidationError)\">\n      <ng-template [ngIf]=\"errorsLength\">\n        <div class=\"errors\" *ngFor=\"let error of _errors; trackBy: trackByFn\">\n          <ui-icon [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n          <span [innerHTML]=\"error\"></span>\n        </div>\n      </ng-template>\n\n      <ui-validation-error\n        *ngIf=\"ngControl && !hideBuiltInErrors\"\n        [ngControl]=\"ngControl\"\n        [label]=\"hideLabelInErrors ? null : label\"\n      ></ui-validation-error>\n    </mat-hint>\n\n    @if (badgeVariant) {\n      <ui-badge class=\"field-badge\"\n                [variant]=\"badgeVariant\"></ui-badge>\n    }\n  </mat-form-field>\n</ng-container>\n"]}
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Injectable, Input, HostBinding, Optional, Inject, ViewEncapsulation, Component, EventEmitter, booleanAttribute, Output, Pipe, ChangeDetectionStrategy, NgModule, HostListener, Directive, ViewChild, Self, ContentChild, input, computed, signal, ElementRef, forwardRef, ViewContainerRef, Host, TemplateRef, inject, ViewChildren, InjectionToken, PLATFORM_ID, ChangeDetectorRef, effect, DestroyRef, EnvironmentInjector, ApplicationRef, Injector, createComponent, viewChild, model, output } from '@angular/core';
2
+ import { Injectable, Component, ViewEncapsulation, Optional, Inject, HostBinding, Input, EventEmitter, booleanAttribute, Output, Pipe, ChangeDetectionStrategy, NgModule, Directive, HostListener, ViewChild, Self, ContentChild, input, computed, signal, ElementRef, forwardRef, ViewContainerRef, Host, TemplateRef, inject, ViewChildren, InjectionToken, PLATFORM_ID, ChangeDetectorRef, effect, DestroyRef, EnvironmentInjector, ApplicationRef, Injector, createComponent, viewChild, model, output } from '@angular/core';
3
3
  import * as i1$1 from '@angular/common';
4
4
  import { CommonModule, KeyValuePipe, NgIf, NgForOf, NgClass, NgTemplateOutlet, AsyncPipe, formatDate, isPlatformBrowser, NgOptimizedImage, DecimalPipe } from '@angular/common';
5
5
  import * as i1 from '@angular/material/icon';
@@ -70,7 +70,7 @@ import * as i7$2 from '@angular/material/sort';
70
70
  import { MatSortModule } from '@angular/material/sort';
71
71
  import * as i2$7 from '@angular/material/slider';
72
72
  import { MatSliderModule } from '@angular/material/slider';
73
- import { NgxMaskDirective, provideNgxMask } from 'ngx-mask';
73
+ import { provideNgxMask, NgxMaskDirective } from 'ngx-mask';
74
74
  import * as i2$8 from '@angular/material/divider';
75
75
  import { MatDividerModule } from '@angular/material/divider';
76
76
  import { hasModifierKey, SPACE, ENTER } from '@angular/cdk/keycodes';
@@ -7375,8 +7375,8 @@ class FieldComponent {
7375
7375
  }
7376
7376
  }
7377
7377
  writeValue(value) {
7378
- if (value) {
7379
- this.value = value || '';
7378
+ if (value !== null && value !== undefined) {
7379
+ this.value = value;
7380
7380
  }
7381
7381
  else {
7382
7382
  this.value = '';