@testgorilla/tgo-ui 1.10.0 → 1.10.1

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.
@@ -21,7 +21,7 @@ export class FieldComponent {
21
21
  * @memberof FieldComponent
22
22
  */
23
23
  set errors(errors) {
24
- this._errors = errors.map(error => this.domSanitizer.bypassSecurityTrustHtml(error));
24
+ this._errors = errors.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));
25
25
  this.errorsLength = this.setErrorsLength();
26
26
  }
27
27
  /**
@@ -229,4 +229,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
229
229
  }], language: [{
230
230
  type: Input
231
231
  }] } });
232
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../src/components/field/field.component.ts","../../../../../src/components/field/field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnInit,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { FieldType } from '../../components/field/field.model';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { Language, LanguageService } from '../../utils/localization/language.service';\n\n@Component({\n  selector: 'ui-field',\n  templateUrl: './field.component.html',\n  styleUrls: ['./field.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FieldComponent),\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FieldComponent implements OnInit, ControlValueAccessor {\n  @HostBinding() class = 'ui-field';\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  @Input() id? = '';\n\n  /**\n   * Input value\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() value = '';\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.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   * 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  @Input() 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   * The language to be used\n   * @property language\n   * @type {Language}\n   * @memberof FieldComponent\n   */\n  @Input() set language(value: Language) {\n    this.lang = value;\n    this.languageService.init(value);\n  }\n\n  private lang = LanguageService.defaultLanguage;\n  protected readonly translationContext = 'FIELD.';\n\n  /**\n   * @ignore\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = () => {};\n\n  constructor(\n    private matIconRegistry: MatIconRegistry,\n    private domSanitizer: DomSanitizer,\n    private readonly languageService: LanguageService\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    this.languageService.init(this.lang);\n  }\n\n  //set search input initial value\n  setSearchInput(): void {\n    if (this.type === '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.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') {\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    this.onChange(this.value);\n  }\n\n  writeValue(value?: any): void {\n    if (value) {\n      this.value = value || '';\n    } else {\n      this.value = '';\n    }\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  }\n}\n","<ng-container *transloco=\"let t\">\n  <mat-form-field #uiField appearance=\"outline\" [color]=\"errorsLength ? 'warn' : 'accent'\">\n    <mat-label *ngIf=\"label && type !== 'search'\">{{ label }} <span *ngIf=\"required\">*</span></mat-label>\n    <mat-icon *ngIf=\"type === 'search'\" matIconPrefix class=\"search-icon\" [svgIcon]=\"'Search'\"></mat-icon>\n    <input\n      matInput\n      (blur)=\"onTouch()\"\n      (input)=\"onInput($event)\"\n      [id]=\"id!\"\n      (keyup)=\"onChangeInputSearch()\"\n      [placeholder]=\"placeholder!\"\n      [value]=\"value\"\n      [disabled]=\"disabled\"\n      [type]=\"currentType\"\n      [name]=\"fieldName!\"\n      digitsOnly\n      [allowOnlyDigits]=\"allowOnlyDigits\"\n    />\n\n    <div class=\"options\" *ngIf=\"type === 'search' || type === 'password'\">\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]=\"t('COMMON.CLEAR')\"\n          (buttonClickEvent)=\"clearValue()\"\n        ></ui-button>\n        <ui-button\n          *ngIf=\"type === 'password'\"\n          variant=\"secondary\"\n          [justIcon]=\"true\"\n          class=\"password\"\n          [iconName]=\"showPassword ? 'Eye-hide' : 'Eye-view'\"\n          [label]=\"t(translationContext + 'VIEW_PASSWORD')\"\n          (buttonClickEvent)=\"showPasswordClick()\"\n        ></ui-button>\n      </div>\n    </div>\n    <mat-hint class=\"info\" *ngIf=\"hintMessage && !_errors\">{{ hintMessage }}</mat-hint>\n    <mat-hint class=\"error\" *ngIf=\"errorsLength\">\n      <div class=\"errors\" *ngFor=\"let error of _errors\">\n        <ui-icon name=\"Error\"></ui-icon>\n        <span [innerHTML]=\"error\"></span>\n      </div>\n    </mat-hint>\n  </mat-form-field>\n</ng-container>\n"]}
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../src/components/field/field.component.ts","../../../../../src/components/field/field.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnInit,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { FieldType } from '../../components/field/field.model';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { Language, LanguageService } from '../../utils/localization/language.service';\n\n@Component({\n  selector: 'ui-field',\n  templateUrl: './field.component.html',\n  styleUrls: ['./field.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FieldComponent),\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FieldComponent implements OnInit, ControlValueAccessor {\n  @HostBinding() class = 'ui-field';\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  @Input() id? = '';\n\n  /**\n   * Input value\n   *\n   * @type {string}\n   * @memberof FieldComponent\n   */\n  @Input() value = '';\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   * 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  @Input() 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   * The language to be used\n   * @property language\n   * @type {Language}\n   * @memberof FieldComponent\n   */\n  @Input() set language(value: Language) {\n    this.lang = value;\n    this.languageService.init(value);\n  }\n\n  private lang = LanguageService.defaultLanguage;\n  protected readonly translationContext = 'FIELD.';\n\n  /**\n   * @ignore\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * @ignore\n   */\n  onTouch = () => {};\n\n  constructor(\n    private matIconRegistry: MatIconRegistry,\n    private domSanitizer: DomSanitizer,\n    private readonly languageService: LanguageService\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    this.languageService.init(this.lang);\n  }\n\n  //set search input initial value\n  setSearchInput(): void {\n    if (this.type === '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.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') {\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    this.onChange(this.value);\n  }\n\n  writeValue(value?: any): void {\n    if (value) {\n      this.value = value || '';\n    } else {\n      this.value = '';\n    }\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  }\n}\n","<ng-container *transloco=\"let t\">\n  <mat-form-field #uiField appearance=\"outline\" [color]=\"errorsLength ? 'warn' : 'accent'\">\n    <mat-label *ngIf=\"label && type !== 'search'\">{{ label }} <span *ngIf=\"required\">*</span></mat-label>\n    <mat-icon *ngIf=\"type === 'search'\" matIconPrefix class=\"search-icon\" [svgIcon]=\"'Search'\"></mat-icon>\n    <input\n      matInput\n      (blur)=\"onTouch()\"\n      (input)=\"onInput($event)\"\n      [id]=\"id!\"\n      (keyup)=\"onChangeInputSearch()\"\n      [placeholder]=\"placeholder!\"\n      [value]=\"value\"\n      [disabled]=\"disabled\"\n      [type]=\"currentType\"\n      [name]=\"fieldName!\"\n      digitsOnly\n      [allowOnlyDigits]=\"allowOnlyDigits\"\n    />\n\n    <div class=\"options\" *ngIf=\"type === 'search' || type === 'password'\">\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]=\"t('COMMON.CLEAR')\"\n          (buttonClickEvent)=\"clearValue()\"\n        ></ui-button>\n        <ui-button\n          *ngIf=\"type === 'password'\"\n          variant=\"secondary\"\n          [justIcon]=\"true\"\n          class=\"password\"\n          [iconName]=\"showPassword ? 'Eye-hide' : 'Eye-view'\"\n          [label]=\"t(translationContext + 'VIEW_PASSWORD')\"\n          (buttonClickEvent)=\"showPasswordClick()\"\n        ></ui-button>\n      </div>\n    </div>\n    <mat-hint class=\"info\" *ngIf=\"hintMessage && !_errors\">{{ hintMessage }}</mat-hint>\n    <mat-hint class=\"error\" *ngIf=\"errorsLength\">\n      <div class=\"errors\" *ngFor=\"let error of _errors\">\n        <ui-icon name=\"Error\"></ui-icon>\n        <span [innerHTML]=\"error\"></span>\n      </div>\n    </mat-hint>\n  </mat-form-field>\n</ng-container>\n"]}
@@ -1672,7 +1672,7 @@ class FieldComponent {
1672
1672
  * @memberof FieldComponent
1673
1673
  */
1674
1674
  set errors(errors) {
1675
- this._errors = errors.map(error => this.domSanitizer.bypassSecurityTrustHtml(error));
1675
+ this._errors = errors.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));
1676
1676
  this.errorsLength = this.setErrorsLength();
1677
1677
  }
1678
1678
  /**