@testgorilla/tgo-ui 3.10.17 → 3.10.18

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.
@@ -133,10 +133,10 @@ export declare class PhoneInputComponent implements OnInit, OnDestroy, ControlVa
133
133
  onOptionsSelected(value: UICountry): void;
134
134
  onInput(value: string): void;
135
135
  filteredCountryTrackByMethod(index: number, el: UICountry): string;
136
+ private setCountry;
136
137
  private getNumberWithCountryCode;
137
138
  private subscribeToFocusEvents;
138
139
  private preSelectCountry;
139
- private setCountry;
140
140
  private getCountryByAlpha2Code;
141
141
  private getCountryByCallingCode;
142
142
  private loadCountries;
@@ -19,7 +19,7 @@ export declare class SkeletonComponent {
19
19
  applicationTheme: ApplicationTheme;
20
20
  constructor(defaultAppTheme: ApplicationTheme);
21
21
  protected readonly theme$: BehaviorSubject<NgxSkeletonLoaderConfigTheme>;
22
- protected readonly appearance$: BehaviorSubject<"" | "circle" | "line" | "custom-content">;
22
+ protected readonly appearance$: BehaviorSubject<"" | "line" | "circle" | "custom-content">;
23
23
  protected readonly currentTheme$: import("rxjs").Observable<NgxSkeletonLoaderConfigTheme>;
24
24
  private getThemeWithDefaultValues;
25
25
  static ɵfac: i0.ɵɵFactoryDeclaration<SkeletonComponent, [{ optional: true; }]>;
@@ -214,6 +214,13 @@ export class PhoneInputComponent {
214
214
  filteredCountryTrackByMethod(index, el) {
215
215
  return el.alpha2Code;
216
216
  }
217
+ setCountry(country) {
218
+ if (country) {
219
+ this.selectedCountry = country;
220
+ }
221
+ this.value = this.getNumberWithCountryCode();
222
+ this.onChange(this.value);
223
+ }
217
224
  getNumberWithCountryCode() {
218
225
  const nationalNumber = this.form.value?.phone_number;
219
226
  return nationalNumber ? (this.selectedCountry?.callingCode ?? '') + nationalNumber : '';
@@ -250,12 +257,6 @@ export class PhoneInputComponent {
250
257
  }))
251
258
  .subscribe();
252
259
  }
253
- setCountry(country) {
254
- if (country) {
255
- this.selectedCountry = country;
256
- }
257
- this.value = this.getNumberWithCountryCode();
258
- }
259
260
  getCountryByAlpha2Code(alpha2Code) {
260
261
  return this.countries.value.find(country => country.alpha2Code === alpha2Code);
261
262
  }
@@ -350,4 +351,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
350
351
  type: HostBinding,
351
352
  args: ['attr.aria-describedby']
352
353
  }] } });
353
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-input.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/phone-input/phone-input.component.ts","../../../../../projects/tgo-canopy-ui/components/phone-input/phone-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  HostBinding,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Self,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  NgControl,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  UntypedFormGroup,\n} from '@angular/forms';\nimport { MAT_AUTOCOMPLETE_DEFAULT_OPTIONS } from '@angular/material/autocomplete';\nimport { ErrorStateMatcher } from '@angular/material/core';\nimport { MatInput } from '@angular/material/input';\nimport { MatSelect } from '@angular/material/select';\nimport { parsePhoneNumber } from 'libphonenumber-js';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  debounceTime,\n  delay,\n  filter,\n  first,\n  map,\n  Observable,\n  startWith,\n  Subject,\n  take,\n  tap,\n} from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { UICountry } from './phone-input.model';\n\n@Component({\n  selector: 'ui-phone-input',\n  templateUrl: './phone-input.component.html',\n  styleUrls: ['./phone-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: MAT_AUTOCOMPLETE_DEFAULT_OPTIONS,\n      useValue: { overlayPanelClass: 'phone-number-autocomplete' },\n    },\n  ],\n})\nexport class PhoneInputComponent implements OnInit, OnDestroy, ControlValueAccessor, DoCheck {\n  /**\n   * Phone number\n   *\n   * @type {string}\n   * @memberof PhoneInputComponent\n   */\n  @Input()\n  set value(value: string) {\n    this.initialValue = this.initialValue || value;\n    try {\n      const parsed = parsePhoneNumber(value);\n      const formatted = parsed.formatInternational();\n      this.selectedCountry = this.getCountryByAlpha2Code(parsed.country!) || this.selectedCountry;\n      this.form.patchValue({ phone_number: formatted.replace(this.selectedCountry.callingCode, '') });\n    } catch (err) {\n      if (value?.length <= 4) {\n        this.selectedCountry = this.getCountryByCallingCode(value) || this.selectedCountry;\n      }\n      this.form.patchValue({ phone_number: value?.replace(this.selectedCountry?.callingCode, '') });\n    }\n    this.stateChanges.next();\n  }\n\n  /**\n   * Country list for select\n   *\n   * @type {UICountry[]}\n   * @memberof PhoneInputComponent\n   */\n  @Input() set countryList(countryList: UICountry[]) {\n    this.loadCountries$.next(countryList);\n    this.selectedCountry = this.selectedCountry ?? countryList[0];\n  }\n\n  /**\n   * Placeholder input\n   *\n   * @type {text}\n   * @memberof PhoneInputComponent\n   */\n  @Input()\n  set placeholder(value: string) {\n    this.internalPlaceholder = value;\n    this.stateChanges.next();\n  }\n\n  /**\n   * Determines if input is disabled\n   *\n   * @type {boolean}\n   * @memberof PhoneInputComponent\n   */\n  @HostBinding('attr.disabled')\n  @Input()\n  disabled: boolean;\n\n  /**\n   * Input is required or not\n   *\n   * @type {boolean}\n   * @memberof PhoneInputComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof PhoneInputComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Indicator of the phone input width\n   * @property fullWidth\n   * @type {boolean}\n   * @memberof PhoneInputComponent\n   */\n  @Input() fullWidth = false;\n\n  _errors: SafeHtml[];\n  /**\n   * Input field errors\n   *\n   * @type {string}\n   * @memberof PhoneInputComponent\n   */\n  @Input() set errors(errors: string[]) {\n    if (errors) {\n      this._errors = errors?.filter(Boolean).map(error => this.sanitizer.bypassSecurityTrustHtml(error));\n      this.errorsLength = this.setErrorsLength();\n    }\n  }\n\n  /**\n   * Hide in build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof PhoneInputComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof PhoneInputComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  static nextId = 0;\n\n  private countries = new BehaviorSubject<UICountry[]>([]);\n  protected countries$ = this.countries.asObservable();\n  form: UntypedFormGroup = this.fb.group({\n    phone_number: new UntypedFormControl(),\n  });\n  protected controlType = 'phone-number';\n  protected userAriaDescribedBy?: string;\n  protected loadCountries$ = new BehaviorSubject<UICountry[]>([]);\n  protected countryCode = new BehaviorSubject<string>('US');\n  protected stateChanges = new Subject<void>();\n  protected focused: boolean;\n  protected selectFilterCtrl = new UntypedFormControl('');\n  protected errorsLength: boolean;\n  protected readonly countryFlagSrc = 'assets/svg-country-flags/';\n\n  @ViewChild(MatInput, { read: ElementRef, static: true })\n  public input: ElementRef<HTMLElement>;\n  @ViewChild(MatSelect, { read: ElementRef, static: true })\n  public select: ElementRef<HTMLElement>;\n\n  @HostBinding()\n  id = `phone-number${PhoneInputComponent.nextId++}`;\n\n  @HostBinding('class.floated')\n  get shouldLabelFloat(): boolean {\n    return true;\n  }\n\n  @HostBinding('attr.aria-describedby') describedBy = '';\n\n  get empty(): boolean {\n    return !!this.form.value;\n  }\n\n  get errorState(): boolean {\n    return this.errorMatcher.isErrorState(this.ngControl.control as UntypedFormControl, null);\n  }\n\n  get value(): string {\n    return this.getNumberWithCountryCode();\n  }\n\n  get placeholder() {\n    return this.internalPlaceholder;\n  }\n\n  private initialValue: string;\n  private readonly DEFAULT_COUNTRY_CODE = 'US';\n  private internalPlaceholder: string;\n  protected selectedCountry: UICountry;\n  private unsubscribeAll$ = new Subject<void>();\n\n  constructor(\n    @Optional() @Self() public ngControl: NgControl,\n    private errorMatcher: ErrorStateMatcher,\n    private fb: UntypedFormBuilder,\n    private focusMonitor: FocusMonitor,\n    private ref: ChangeDetectorRef,\n    private sanitizer: DomSanitizer,\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n  ) {\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\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.ref.markForCheck();\n    }\n  }\n\n  ngOnInit(): void {\n    this.loadCountries();\n    this.preSelectCountry();\n    this.subscribeToFocusEvents();\n  }\n\n  setErrorsLength(): boolean {\n    if (!!this._errors) {\n      return this._errors.filter(err => !!err).length > 0;\n    }\n    return false;\n  }\n\n  setDescribedByIds(ids: string[]): void {\n    this.userAriaDescribedBy = ids.join(' ');\n  }\n\n  onChange: (value: string) => void;\n  onTouch: () => void;\n\n  writeValue(phoneNumber: string): void {\n    if (phoneNumber) {\n      this.value = phoneNumber;\n    }\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      this.form.disable();\n    } else {\n      this.form.enable();\n    }\n    this.disabled = isDisabled;\n    this.stateChanges.next();\n    this.ref.markForCheck();\n  }\n\n  ngOnDestroy(): void {\n    this.focusMonitor.stopMonitoring(this.input);\n    this.focusMonitor.stopMonitoring(this.select);\n    this.stateChanges.complete();\n    this.unsubscribeAll$.next();\n    this.unsubscribeAll$.complete();\n  }\n\n  onOptionsSelected(value: UICountry) {\n    this.setCountry(value);\n  }\n\n  onInput(value: string) {\n    this.value = (this.selectedCountry?.callingCode ?? '') + value;\n    this.onChange(this.value);\n  }\n\n  filteredCountryTrackByMethod(index: number, el: UICountry): string {\n    return el.alpha2Code;\n  }\n\n  private getNumberWithCountryCode() {\n    const nationalNumber = this.form.value?.phone_number as string;\n    return nationalNumber ? (this.selectedCountry?.callingCode ?? '') + nationalNumber : '';\n  }\n\n  private subscribeToFocusEvents() {\n    const selectAndInputFocus$ = combineLatest([\n      this.focusMonitor.monitor(this.select),\n      this.focusMonitor.monitor(this.input),\n    ]).pipe(takeUntil(this.unsubscribeAll$), debounceTime(10));\n\n    selectAndInputFocus$.subscribe(([selectFocus, inputFocus]) => {\n      this.focused = !!(selectFocus || inputFocus);\n      this.stateChanges.next();\n    });\n\n    selectAndInputFocus$.pipe(take(1)).subscribe(() => {\n      this.onTouch();\n    });\n  }\n\n  private preSelectCountry() {\n    this.setDisabledState(true);\n    combineLatest([\n      this.countries$.pipe(\n        filter(countries => countries.length > 0),\n        first()\n      ),\n      this.countryCode,\n    ])\n      .pipe(\n        map(([countries, selectedCountry]) => {\n          if (!this.initialValue) {\n            const country =\n              this.getCountryByAlpha2Code(selectedCountry) || this.getCountryByAlpha2Code(this.DEFAULT_COUNTRY_CODE);\n            this.setCountry(country as UICountry);\n          } else {\n            this.value = this.initialValue;\n          }\n\n          this.setDisabledState(false);\n          this.ref.markForCheck();\n        })\n      )\n      .subscribe();\n  }\n\n  private setCountry(country: UICountry | null): void {\n    if (country) {\n      this.selectedCountry = country;\n    }\n    this.value = this.getNumberWithCountryCode();\n  }\n\n  private getCountryByAlpha2Code(alpha2Code: string) {\n    return this.countries.value.find(country => country.alpha2Code === alpha2Code);\n  }\n\n  private getCountryByCallingCode(callingCode: string) {\n    return this.countries.value.find(country => country.callingCode === callingCode);\n  }\n\n  private loadCountries(): void {\n    const searchText$: Observable<string> = this.selectFilterCtrl.valueChanges.pipe(debounceTime(100), startWith(''));\n\n    combineLatest([this.loadCountries$, searchText$])\n      .pipe(\n        takeUntil(this.unsubscribeAll$),\n        tap(([countries, searchText]) => {\n          const searchTextLowerCase = searchText.toLowerCase();\n          const filteredCountries = countries\n            .filter(\n              option =>\n                option.name.toLowerCase().includes(searchTextLowerCase) ||\n                option.alpha2Code.toLowerCase().includes(searchTextLowerCase) ||\n                option.callingCode.toLowerCase().includes(searchTextLowerCase)\n            )\n            .sort((optionA, optionB) => (optionB.name.startsWith(searchText) ? 1 : -1));\n          this.countries.next(filteredCountries);\n        }),\n        delay(1),\n        tap(() => {\n          const countryFound = this.getCountryByAlpha2Code(this.selectedCountry?.alpha2Code);\n          this.selectedCountry = countryFound || this.selectedCountry;\n          this.ref.markForCheck();\n        })\n      )\n      .subscribe();\n  }\n\n  disableClick(ev: Event) {\n    ev.preventDefault();\n    ev.stopPropagation();\n  }\n\n  trackByFn = (index: number, value: any) => value.changingThisBreaksApplicationSecurity;\n}\n","<mat-form-field\n  [formGroup]=\"form\"\n  appearance=\"outline\"\n  [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched )) ? 'warn' : 'accent'\"\n  [ngClass]=\"{ disabled: form.disabled || disabled, 'full-width': fullWidth }\"\n>\n  <mat-label>{{ 'COMMON.PHONE_NUMBER' | uiTranslate | async }} <span *ngIf=\"required\">*</span></mat-label>\n\n  <div matPrefix class=\"country\">\n    <button class=\"selected-flag\" matPrefix *ngIf=\"selectedCountry\">\n      <img [height]=\"20\" [width]=\"24\" [attr.src]=\"countryFlagSrc + selectedCountry?.alpha2Code?.toLowerCase() + '.svg'\"\n           [alt]=\"'Country flag ' + selectedCountry?.alpha2Code?.toLowerCase()\">\n    </button>\n    <mat-select\n      #select\n      (selectionChange)=\"onOptionsSelected($event.value)\"\n      [value]=\"selectedCountry\"\n      [disableOptionCentering]=\"true\"\n      [panelClass]=\"'phone-number-select' + ' ' + applicationTheme\"\n      [ngClass]=\"{ opened: select.panelOpen }\"\n    >\n      <mat-select-trigger>{{ selectedCountry?.callingCode }}</mat-select-trigger>\n      <mat-option>\n        <ngx-mat-select-search\n          [formControl]=\"selectFilterCtrl\"\n          ngDefaultControl\n          placeholderLabel=\"\"\n          noEntriesFoundLabel=\"\"\n        >\n          <ui-icon ngxMatSelectSearchClear size=\"24\" [name]=\"'Close-in-line'\"></ui-icon>\n        </ngx-mat-select-search>\n      </mat-option>\n        <mat-option *ngFor=\"let country of countries$ | async; trackBy: filteredCountryTrackByMethod\" [value]=\"country\">\n          <div class=\"country-option\">\n            <img [height]=\"20\" [width]=\"24\" [attr.src]=\"countryFlagSrc + country?.alpha2Code?.toLowerCase()! + '.svg'\"\n                 [alt]=\"'Country flag ' + country?.alpha2Code?.toLowerCase()!\">\n            <small>{{ $any([country?.name, '(' + country?.callingCode + ')']) | joinStrings : ' ' }}</small>\n          </div>\n        </mat-option>\n    </mat-select>\n  </div>\n\n  <input\n    (input)=\"onInput(form.get('phone_number')!.value)\"\n    formControlName=\"phone_number\"\n    (click)=\"disableClick($event)\"\n    [ngStyle]=\"{ opacity: disabled ? 0.5 : 1 }\"\n    [required]=\"required\"\n    matInput\n    type=\"text\"\n  />\n\n  <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.errors | hasValidationError)\">\n    <ng-container *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-container>\n\n    <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : ('COMMON.PHONE_NUMBER' | uiTranslate | async)\"></ui-validation-error>\n\n  </mat-hint>\n</mat-form-field>\n"]}
354
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-input.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/phone-input/phone-input.component.ts","../../../../../projects/tgo-canopy-ui/components/phone-input/phone-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  ElementRef,\n  HostBinding,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Self,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  NgControl,\n  UntypedFormBuilder,\n  UntypedFormControl,\n  UntypedFormGroup,\n} from '@angular/forms';\nimport { MAT_AUTOCOMPLETE_DEFAULT_OPTIONS } from '@angular/material/autocomplete';\nimport { ErrorStateMatcher } from '@angular/material/core';\nimport { MatInput } from '@angular/material/input';\nimport { MatSelect } from '@angular/material/select';\nimport { parsePhoneNumber } from 'libphonenumber-js';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  debounceTime,\n  delay,\n  filter,\n  first,\n  map,\n  Observable,\n  startWith,\n  Subject,\n  take,\n  tap,\n} from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { UICountry } from './phone-input.model';\n\n@Component({\n  selector: 'ui-phone-input',\n  templateUrl: './phone-input.component.html',\n  styleUrls: ['./phone-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: MAT_AUTOCOMPLETE_DEFAULT_OPTIONS,\n      useValue: { overlayPanelClass: 'phone-number-autocomplete' },\n    },\n  ],\n})\nexport class PhoneInputComponent implements OnInit, OnDestroy, ControlValueAccessor, DoCheck {\n  /**\n   * Phone number\n   *\n   * @type {string}\n   * @memberof PhoneInputComponent\n   */\n  @Input()\n  set value(value: string) {\n    this.initialValue = this.initialValue || value;\n    try {\n      const parsed = parsePhoneNumber(value);\n      const formatted = parsed.formatInternational();\n      this.selectedCountry = this.getCountryByAlpha2Code(parsed.country!) || this.selectedCountry;\n      this.form.patchValue({ phone_number: formatted.replace(this.selectedCountry.callingCode, '') });\n    } catch (err) {\n      if (value?.length <= 4) {\n        this.selectedCountry = this.getCountryByCallingCode(value) || this.selectedCountry;\n      }\n      this.form.patchValue({ phone_number: value?.replace(this.selectedCountry?.callingCode, '') });\n    }\n    this.stateChanges.next();\n  }\n\n  /**\n   * Country list for select\n   *\n   * @type {UICountry[]}\n   * @memberof PhoneInputComponent\n   */\n  @Input() set countryList(countryList: UICountry[]) {\n    this.loadCountries$.next(countryList);\n    this.selectedCountry = this.selectedCountry ?? countryList[0];\n  }\n\n  /**\n   * Placeholder input\n   *\n   * @type {text}\n   * @memberof PhoneInputComponent\n   */\n  @Input()\n  set placeholder(value: string) {\n    this.internalPlaceholder = value;\n    this.stateChanges.next();\n  }\n\n  /**\n   * Determines if input is disabled\n   *\n   * @type {boolean}\n   * @memberof PhoneInputComponent\n   */\n  @HostBinding('attr.disabled')\n  @Input()\n  disabled: boolean;\n\n  /**\n   * Input is required or not\n   *\n   * @type {boolean}\n   * @memberof PhoneInputComponent\n   */\n  @Input() required: boolean;\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof PhoneInputComponent\n   */\n  @HostBinding('attr.theme')\n  @Input()\n  applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Indicator of the phone input width\n   * @property fullWidth\n   * @type {boolean}\n   * @memberof PhoneInputComponent\n   */\n  @Input() fullWidth = false;\n\n  _errors: SafeHtml[];\n  /**\n   * Input field errors\n   *\n   * @type {string}\n   * @memberof PhoneInputComponent\n   */\n  @Input() set errors(errors: string[]) {\n    if (errors) {\n      this._errors = errors?.filter(Boolean).map(error => this.sanitizer.bypassSecurityTrustHtml(error));\n      this.errorsLength = this.setErrorsLength();\n    }\n  }\n\n  /**\n   * Hide in build errors for Reactive Forms\n   *\n   * @type {number}\n   * @memberof PhoneInputComponent\n   */\n  @Input() hideBuiltInErrors = false;\n\n  /**\n   * Hide label in errors\n   *\n   * @type {number}\n   * @memberof PhoneInputComponent\n   */\n  @Input() hideLabelInErrors = false;\n\n  static nextId = 0;\n\n  private countries = new BehaviorSubject<UICountry[]>([]);\n  protected countries$ = this.countries.asObservable();\n  form: UntypedFormGroup = this.fb.group({\n    phone_number: new UntypedFormControl(),\n  });\n  protected controlType = 'phone-number';\n  protected userAriaDescribedBy?: string;\n  protected loadCountries$ = new BehaviorSubject<UICountry[]>([]);\n  protected countryCode = new BehaviorSubject<string>('US');\n  protected stateChanges = new Subject<void>();\n  protected focused: boolean;\n  protected selectFilterCtrl = new UntypedFormControl('');\n  protected errorsLength: boolean;\n  protected readonly countryFlagSrc = 'assets/svg-country-flags/';\n\n  @ViewChild(MatInput, { read: ElementRef, static: true })\n  public input: ElementRef<HTMLElement>;\n  @ViewChild(MatSelect, { read: ElementRef, static: true })\n  public select: ElementRef<HTMLElement>;\n\n  @HostBinding()\n  id = `phone-number${PhoneInputComponent.nextId++}`;\n\n  @HostBinding('class.floated')\n  get shouldLabelFloat(): boolean {\n    return true;\n  }\n\n  @HostBinding('attr.aria-describedby') describedBy = '';\n\n  get empty(): boolean {\n    return !!this.form.value;\n  }\n\n  get errorState(): boolean {\n    return this.errorMatcher.isErrorState(this.ngControl.control as UntypedFormControl, null);\n  }\n\n  get value(): string {\n    return this.getNumberWithCountryCode();\n  }\n\n  get placeholder() {\n    return this.internalPlaceholder;\n  }\n\n  private initialValue: string;\n  private readonly DEFAULT_COUNTRY_CODE = 'US';\n  private internalPlaceholder: string;\n  protected selectedCountry: UICountry;\n  private unsubscribeAll$ = new Subject<void>();\n\n  constructor(\n    @Optional() @Self() public ngControl: NgControl,\n    private errorMatcher: ErrorStateMatcher,\n    private fb: UntypedFormBuilder,\n    private focusMonitor: FocusMonitor,\n    private ref: ChangeDetectorRef,\n    private sanitizer: DomSanitizer,\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme\n  ) {\n    if (this.ngControl != null) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\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.ref.markForCheck();\n    }\n  }\n\n  ngOnInit(): void {\n    this.loadCountries();\n    this.preSelectCountry();\n    this.subscribeToFocusEvents();\n  }\n\n  setErrorsLength(): boolean {\n    if (!!this._errors) {\n      return this._errors.filter(err => !!err).length > 0;\n    }\n    return false;\n  }\n\n  setDescribedByIds(ids: string[]): void {\n    this.userAriaDescribedBy = ids.join(' ');\n  }\n\n  onChange: (value: string) => void;\n  onTouch: () => void;\n\n  writeValue(phoneNumber: string): void {\n    if (phoneNumber) {\n      this.value = phoneNumber;\n    }\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouch = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      this.form.disable();\n    } else {\n      this.form.enable();\n    }\n    this.disabled = isDisabled;\n    this.stateChanges.next();\n    this.ref.markForCheck();\n  }\n\n  ngOnDestroy(): void {\n    this.focusMonitor.stopMonitoring(this.input);\n    this.focusMonitor.stopMonitoring(this.select);\n    this.stateChanges.complete();\n    this.unsubscribeAll$.next();\n    this.unsubscribeAll$.complete();\n  }\n\n  onOptionsSelected(value: UICountry) {\n    this.setCountry(value);\n  }\n\n  onInput(value: string) {\n    this.value = (this.selectedCountry?.callingCode ?? '') + value;\n    this.onChange(this.value);\n  }\n\n  filteredCountryTrackByMethod(index: number, el: UICountry): string {\n    return el.alpha2Code;\n  }\n\n  private setCountry(country: UICountry | null): void {\n    if (country) {\n      this.selectedCountry = country;\n    }\n    this.value = this.getNumberWithCountryCode();\n    this.onChange(this.value);\n  }\n\n  private getNumberWithCountryCode() {\n    const nationalNumber = this.form.value?.phone_number as string;\n    return nationalNumber ? (this.selectedCountry?.callingCode ?? '') + nationalNumber : '';\n  }\n\n  private subscribeToFocusEvents() {\n    const selectAndInputFocus$ = combineLatest([\n      this.focusMonitor.monitor(this.select),\n      this.focusMonitor.monitor(this.input),\n    ]).pipe(takeUntil(this.unsubscribeAll$), debounceTime(10));\n\n    selectAndInputFocus$.subscribe(([selectFocus, inputFocus]) => {\n      this.focused = !!(selectFocus || inputFocus);\n      this.stateChanges.next();\n    });\n\n    selectAndInputFocus$.pipe(take(1)).subscribe(() => {\n      this.onTouch();\n    });\n  }\n\n  private preSelectCountry() {\n    this.setDisabledState(true);\n    combineLatest([\n      this.countries$.pipe(\n        filter(countries => countries.length > 0),\n        first()\n      ),\n      this.countryCode,\n    ])\n      .pipe(\n        map(([countries, selectedCountry]) => {\n          if (!this.initialValue) {\n            const country =\n              this.getCountryByAlpha2Code(selectedCountry) || this.getCountryByAlpha2Code(this.DEFAULT_COUNTRY_CODE);\n            this.setCountry(country as UICountry);\n          } else {\n            this.value = this.initialValue;\n          }\n\n          this.setDisabledState(false);\n          this.ref.markForCheck();\n        })\n      )\n      .subscribe();\n  }\n\n  private getCountryByAlpha2Code(alpha2Code: string) {\n    return this.countries.value.find(country => country.alpha2Code === alpha2Code);\n  }\n\n  private getCountryByCallingCode(callingCode: string) {\n    return this.countries.value.find(country => country.callingCode === callingCode);\n  }\n\n  private loadCountries(): void {\n    const searchText$: Observable<string> = this.selectFilterCtrl.valueChanges.pipe(debounceTime(100), startWith(''));\n\n    combineLatest([this.loadCountries$, searchText$])\n      .pipe(\n        takeUntil(this.unsubscribeAll$),\n        tap(([countries, searchText]) => {\n          const searchTextLowerCase = searchText.toLowerCase();\n          const filteredCountries = countries\n            .filter(\n              option =>\n                option.name.toLowerCase().includes(searchTextLowerCase) ||\n                option.alpha2Code.toLowerCase().includes(searchTextLowerCase) ||\n                option.callingCode.toLowerCase().includes(searchTextLowerCase)\n            )\n            .sort((optionA, optionB) => (optionB.name.startsWith(searchText) ? 1 : -1));\n          this.countries.next(filteredCountries);\n        }),\n        delay(1),\n        tap(() => {\n          const countryFound = this.getCountryByAlpha2Code(this.selectedCountry?.alpha2Code);\n          this.selectedCountry = countryFound || this.selectedCountry;\n          this.ref.markForCheck();\n        })\n      )\n      .subscribe();\n  }\n\n  disableClick(ev: Event) {\n    ev.preventDefault();\n    ev.stopPropagation();\n  }\n\n  trackByFn = (index: number, value: any) => value.changingThisBreaksApplicationSecurity;\n}\n","<mat-form-field\n  [formGroup]=\"form\"\n  appearance=\"outline\"\n  [color]=\"(errorsLength || (ngControl?.errors && ngControl?.touched )) ? 'warn' : 'accent'\"\n  [ngClass]=\"{ disabled: form.disabled || disabled, 'full-width': fullWidth }\"\n>\n  <mat-label>{{ 'COMMON.PHONE_NUMBER' | uiTranslate | async }} <span *ngIf=\"required\">*</span></mat-label>\n\n  <div matPrefix class=\"country\">\n    <button class=\"selected-flag\" matPrefix *ngIf=\"selectedCountry\">\n      <img [height]=\"20\" [width]=\"24\" [attr.src]=\"countryFlagSrc + selectedCountry?.alpha2Code?.toLowerCase() + '.svg'\"\n           [alt]=\"'Country flag ' + selectedCountry?.alpha2Code?.toLowerCase()\">\n    </button>\n    <mat-select\n      #select\n      (selectionChange)=\"onOptionsSelected($event.value)\"\n      [value]=\"selectedCountry\"\n      [disableOptionCentering]=\"true\"\n      [panelClass]=\"'phone-number-select' + ' ' + applicationTheme\"\n      [ngClass]=\"{ opened: select.panelOpen }\"\n    >\n      <mat-select-trigger>{{ selectedCountry?.callingCode }}</mat-select-trigger>\n      <mat-option>\n        <ngx-mat-select-search\n          [formControl]=\"selectFilterCtrl\"\n          ngDefaultControl\n          placeholderLabel=\"\"\n          noEntriesFoundLabel=\"\"\n        >\n          <ui-icon ngxMatSelectSearchClear size=\"24\" [name]=\"'Close-in-line'\"></ui-icon>\n        </ngx-mat-select-search>\n      </mat-option>\n        <mat-option *ngFor=\"let country of countries$ | async; trackBy: filteredCountryTrackByMethod\" [value]=\"country\">\n          <div class=\"country-option\">\n            <img [height]=\"20\" [width]=\"24\" [attr.src]=\"countryFlagSrc + country?.alpha2Code?.toLowerCase()! + '.svg'\"\n                 [alt]=\"'Country flag ' + country?.alpha2Code?.toLowerCase()!\">\n            <small>{{ $any([country?.name, '(' + country?.callingCode + ')']) | joinStrings : ' ' }}</small>\n          </div>\n        </mat-option>\n    </mat-select>\n  </div>\n\n  <input\n    (input)=\"onInput(form.get('phone_number')!.value)\"\n    formControlName=\"phone_number\"\n    (click)=\"disableClick($event)\"\n    [ngStyle]=\"{ opacity: disabled ? 0.5 : 1 }\"\n    [required]=\"required\"\n    matInput\n    type=\"text\"\n  />\n\n  <mat-hint class=\"error\" *ngIf=\"errorsLength || (ngControl?.errors | hasValidationError)\">\n    <ng-container *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-container>\n\n    <ui-validation-error *ngIf=\"ngControl && !hideBuiltInErrors\" [ngControl]=\"ngControl\" [label]=\"hideLabelInErrors ? null : ('COMMON.PHONE_NUMBER' | uiTranslate | async)\"></ui-validation-error>\n\n  </mat-hint>\n</mat-form-field>\n"]}
@@ -16126,6 +16126,13 @@ class PhoneInputComponent {
16126
16126
  filteredCountryTrackByMethod(index, el) {
16127
16127
  return el.alpha2Code;
16128
16128
  }
16129
+ setCountry(country) {
16130
+ if (country) {
16131
+ this.selectedCountry = country;
16132
+ }
16133
+ this.value = this.getNumberWithCountryCode();
16134
+ this.onChange(this.value);
16135
+ }
16129
16136
  getNumberWithCountryCode() {
16130
16137
  const nationalNumber = this.form.value?.phone_number;
16131
16138
  return nationalNumber ? (this.selectedCountry?.callingCode ?? '') + nationalNumber : '';
@@ -16162,12 +16169,6 @@ class PhoneInputComponent {
16162
16169
  }))
16163
16170
  .subscribe();
16164
16171
  }
16165
- setCountry(country) {
16166
- if (country) {
16167
- this.selectedCountry = country;
16168
- }
16169
- this.value = this.getNumberWithCountryCode();
16170
- }
16171
16172
  getCountryByAlpha2Code(alpha2Code) {
16172
16173
  return this.countries.value.find(country => country.alpha2Code === alpha2Code);
16173
16174
  }