asksuite-citrus 3.17.30-beta.2 → 3.17.32-beta.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.
@@ -49,7 +49,7 @@ export class PhoneDdiComponent extends OverlayComponent {
49
49
  return this.formControl.value || '';
50
50
  }
51
51
  get prefix() {
52
- return (this.inputMask?.prefix || '55').replace(NON_DIGIT_REGEX, '');
52
+ return (this.selectedFlag?.code.replace('+', '') || '55').replace(NON_DIGIT_REGEX, '');
53
53
  }
54
54
  constructor(overlay, viewContainerRef, countryFlagService, destroyRef) {
55
55
  super(overlay, viewContainerRef);
@@ -274,4 +274,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
274
274
  type: ViewChildren,
275
275
  args: [AskDropdownDirective]
276
276
  }] } });
277
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-ddi.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/phone-ddi/phone-ddi.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/phone-ddi/phone-ddi.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  inject,\n  Input, OnInit,\n  Output,\n  Provider,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {Overlay} from \"@angular/cdk/overlay\";\nimport {debounceTime, filter, map, Subscription, switchMap} from \"rxjs\";\nimport {AskDropdownDirective} from \"../../directives\";\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\nimport {filterSelectedList} from \"../../../shared/helpers/filter.helper\";\nimport CountryFlagService from \"../../../shared/services/country-flag.service\";\nimport {CountryData} from \"../../../shared/providers/flag.provider\";\nimport {NON_DIGIT_REGEX} from \"../../../shared/utils/regex\";\nimport {getCountryFromPhone} from \"../../helpers/phone.helper\";\nimport {OverlayComponent} from \"../../classes/overlay.component\";\nimport { NgxMaskDirective } from 'ngx-mask';\n\nconst valueAccessor: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => PhoneDdiComponent),\n};\n\n@Component({\n  selector: 'ask-phone-ddi',\n  templateUrl: './phone-ddi.component.html',\n  styleUrls: ['./phone-ddi.component.scss'],\n  providers: [valueAccessor],\n})\nexport class PhoneDdiComponent extends OverlayComponent implements OnInit, ControlValueAccessor {\n  @Input() disabled = false;\n  @Input() value = '';\n  @Input() useCountryCode!: string;\n  @Input() disableMask = false;\n  @Input() inferCountryCodeByNumber = true;\n\n  @Output() valueChange = new EventEmitter<string>();\n  @Output() onChangeFlag = new EventEmitter<CountryData>();\n  \n  public formControl = new FormControl();\n\n  @ViewChild('phoneContainer') phoneContainer: ElementRef | undefined\n\n  @ViewChild('wrapper') wrapper: ElementRef | undefined\n\n  @ViewChild(\"menuContainer\") menuContainer: ElementRef | undefined\n\n  @ViewChild('overlayContent') overlayContent: TemplateRef<any> | undefined\n\n  @ViewChild('input', {read: NgxMaskDirective}) inputMask?: NgxMaskDirective;\n  @ViewChild('input', {read: ElementRef}) inputElement?: ElementRef;\n\n  @ViewChildren(AskDropdownDirective)\n  dropdownList?: QueryList<AskDropdownDirective>;\n\n  _selectedFlag?: CountryData;\n\n  set selectedFlag(item: CountryData | undefined) {\n    if (!item) {\n      this._selectedFlag = undefined;\n      return;\n    }\n    \n    const itemCopy = { ...item };\n    \n    if (this.disableMask) {\n      itemCopy.maskFormat = item.mask.replaceAll('_', '') + 'XXXXXXXX';\n    }else{\n      itemCopy.maskFormat = item.mask;\n    }\n    \n    this._selectedFlag = itemCopy;\n  }\n\n  get selectedFlag(): CountryData | undefined {\n    return this._selectedFlag;\n  }\n\n\n  countryItems: CountryData[] = []\n  onChange!: (value?: any) => void;\n  onTouch!: () => void;\n  protected closed = true;\n  set inputValue(value: string) {\n    this.formControl.setValue(value);\n  }\n  \n  get inputValue(): string {\n    return this.formControl.value || '';\n  }\n\n  get prefix(){\n    return (this.inputMask?.prefix || '55').replace(NON_DIGIT_REGEX, '');\n  }\n\n  protected searchFieldControl = new FormControl(\"\")\n  protected filteredOptions: any[] = []\n  private _destroy = inject(DestroyRef)\n  private scrollSub?: Subscription;\n\n  constructor(\n    overlay: Overlay,\n    viewContainerRef: ViewContainerRef,\n    private countryFlagService: CountryFlagService,\n    private destroyRef: DestroyRef\n  ) {\n    super(overlay, viewContainerRef);\n  }\n\n  ngOnInit() {\n    this.formControl.valueChanges\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe((value) => {\n        if(this.onChange){\n          this.onChange((this.inputValue.length ? this.prefix: '') + this.inputValue)\n        }\n      });\n    this.handleInputChange();\n    this.loadCountries();\n  }\n\n  private loadCountries() {\n    this.countryFlagService.list()\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(data => {\n          this.countryItems = data;\n          this.filteredOptions = data;\n          this.initSelectedFlag(data);\n      });\n  }\n\n  private getFullValue(){\n    return this.inputElement?.nativeElement.value.replace(/\\D+/g, '')\n  }\n\n  onPaste(event: any) {\n    event.preventDefault()\n    const pastedText = event.clipboardData?.getData('text') || ''\n    const countryCode = this.selectedFlag?.code.substring(1);\n    const countryMask = this.selectedFlag?.mask;\n    if (countryCode && countryMask) {\n      const cleanMask = countryMask.replace(/[\\s\\-\\(\\)]/g, '');\n      const expectedLength = countryCode.length + cleanMask.length;\n      if (pastedText.startsWith(countryCode) && pastedText.length === expectedLength) {\n        const number = pastedText.substring(countryCode.length);\n        this.inputValue = number;\n        // this.onChangePhoneNumber(number);\n        return;\n      }\n    }\n    this.inputValue = pastedText;\n    this.onChangePhoneNumber(pastedText);\n\n  }\n\n  handleOptionSelected(item: any) {\n    this.selectedFlag = item;\n    this.onChangeFlag.emit(this.selectedFlag);\n    this.hideOptions();\n    if(this.disableMask){ \n      this.onChange(this.getFullValue());\n    }else{\n      this.onChange('');\n      setTimeout(() => {\n        this.inputValue = '';\n        this.searchFieldControl.setValue('');\n        this.value = '';\n      });\n\n    }\n  }\n\n  display(option: any) {\n    return this.displayFn(option)\n  }\n\n  override shouldClose(event: MouseEvent) {\n    return !this.closed\n      && !this.wrapper?.nativeElement.contains(event.target)\n      && !this.menuContainer?.nativeElement.contains(event.target)\n  }\n\n  override afterClosed() {\n    this.closed = true;\n    this.searchFieldControl.setValue('')\n    this.scrollSub?.unsubscribe();\n  }\n\n  handleFlagClick(event?: Event) {\n    event?.stopPropagation()\n    if (!this.disabled) {\n      this.closed\n        ? this.showOptions()\n        : this.hideOptions()\n    }\n  }\n\n  showOptions() {\n    this.closed = false\n    if (this.phoneContainer && this.overlayContent) {\n      this.open(this.phoneContainer, this.overlayContent, {\n        backdropClass: 'cdk-overlay-transparent-backdrop',\n        hasBackdrop: true,\n        maxHeight: 300,\n      })\n    }\n  }\n\n  hideOptions() {\n    this.close();\n  }\n\n  onChangePhoneNumber(number: string, removeDdi = true, changeValue = false) {\n    const normalizedNumber = this.normalizePhoneInput(number);\n    const onlyDigits = normalizedNumber?.replace(NON_DIGIT_REGEX, '') || '';\n    \n    if (!this.selectedFlag) {\n      this.value = onlyDigits;\n      this.onChange(this.value);\n      return;\n    }\n\n    const countryCode = this.selectedFlag.code.substring(1);\n    const phoneWithoutDdi = removeDdi ? this.removeDdiFromNumber(onlyDigits, countryCode) : onlyDigits;\n    this.value = phoneWithoutDdi ? countryCode + phoneWithoutDdi : '';\n    if (changeValue) {\n      this.inputValue = phoneWithoutDdi;\n    }\n    if(this.onChange){\n      this.onChange(this.value);\n    }\n  }\n\n  private normalizePhoneInput(number: string): string {\n    if (!number) return '';\n    return number.startsWith('+') ? number.substring(1) : number;\n  }\n\n  private removeDdiFromNumber(number: string, countryCode: string): string {\n    if (!number || !countryCode) return number;\n    return number.startsWith(countryCode) ? number.substring(countryCode.length) : number;\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  writeValue(value: any): void {\n    this.value = value;\n    \n    if (!this.value) {\n      return;\n    }\n\n    this.countryFlagService.list()\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(data => {\n        if (this.value && data.length) {\n          this.initSelectedFlag(data);\n        }\n      });\n  }\n\n  protected readonly displayFn = (countryFlag: any) => `${countryFlag.countryName} (${countryFlag.code})`;\n\n  protected readonly filterFn = (search: string) =>\n    filterSelectedList(this.countryItems, search, ['code', 'countryName']);\n\n  private initSelectedFlag(data: CountryData[]) {\n    if (!this.value) {\n      return this.getDefaultCountryFlag(data);\n    }\n    \n    if(this.inferCountryCodeByNumber){\n      const country = getCountryFromPhone(this.value);\n      this.selectedFlag = this.countryItems.find(item => item.countryCode === country.toLowerCase())\n      this.inputValue = this.value.substring(this.selectedFlag?.code.substring(1).length || 0);\n      this.onChangeFlag.emit(this.selectedFlag);\n      return;\n    }\n\n    return this.getDefaultCountryFlag(data);\n  }\n\n  private getDefaultCountryFlag(data: CountryData[]) {\n    this.selectedFlag = this.countryFlagService.getDefaultCountryFlag(data, this.useCountryCode);\n    this.inputValue = this.value;\n    this.onChangeFlag.emit(this.selectedFlag);\n    this.onChangePhoneNumber(this.value, false);\n  }\n\n  private handleInputChange() {\n    this.searchFieldControl.valueChanges.pipe(\n      takeUntilDestroyed(this._destroy),\n      debounceTime(300),\n      map(value => this.filterFn(value || ''))\n    ).subscribe(items => {\n      this.filteredOptions = items\n    })\n  }\n}\n","<div #phoneContainer [style]=\"{cursor: disabled ? 'not-allowed' : 'auto'}\" class=\"phone-ddi\">\n\n  <div\n    #wrapper\n    (click)=\"handleFlagClick()\"\n    *ngIf=\"selectedFlag\"\n    [style]=\"{cursor: !disabled ? 'pointer' : 'not-allowed'}\"\n    class=\"flag\"\n    data-testid=\"flag\">\n\n    <div [style]=\"{backgroundPosition: this.selectedFlag?.backgroundPosition}\" class=\"flag-icon\"></div>\n    <div class=\"flag-arrow\"></div>\n  </div>\n  <input\n    #input\n    *ngIf=\"selectedFlag; else loadingPhoneInput\"\n    [disabled]=\"disabled\"\n    [placeholder]=\"selectedFlag.mask\"\n    [mask]=\"selectedFlag.maskFormat\"\n    [prefix]=\"selectedFlag.code + ' '\"\n    (paste)=\"onPaste($event)\"\n    [validation]=\"true\"\n    [formControl]=\"formControl\"\n    askAutofocus\n    class=\"phone\"\n  />\n\n  <ng-template #loadingPhoneInput>\n    <div class=\"skeleton\">\n      <ask-skeleton [barsHeight]=\"24\" [radius]=\"10\" style=\"height: 24px;\"/>\n    </div>\n  </ng-template>\n\n</div>\n\n<ng-template #overlayContent>\n  <div #menuContainer class=\"menu-container\">\n    <div [style]=\"{padding: '8px'}\">\n      <ask-input\n        [formControl]=\"searchFieldControl\"\n        [placeholder]=\"'FIND_DDI_OR_COUNTRY' | translate\"\n        [autoFocus]=\"true\"\n        class=\"search\"\n      />\n    </div>\n\n    <ng-container *ngIf=\"!filteredOptions.length; else list\">\n      <span class=\"empty\">{{\n        'NO_OPTIONS' | translate\n        }}</span>\n    </ng-container>\n\n    <ng-template #list>\n      <div [askScrollThreshold]=\"50\" askScroll class=\"list\">\n        <ng-container *ngFor=\"let countryItem of filteredOptions\">\n          <div\n            (click)=\"handleOptionSelected(countryItem)\"\n            class=\"option-item\"\n          >\n            <div [style]=\"{backgroundPosition: countryItem.backgroundPosition}\" class=\"country\"></div>\n            <p class=\"text\">{{ display(countryItem) }}</p>\n          </div>\n        </ng-container>\n      </div>\n    </ng-template>\n  </div>\n</ng-template>\n"]}
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-ddi.component.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/components/phone-ddi/phone-ddi.component.ts","../../../../../../projects/asksuite-citrus/src/lib/components/phone-ddi/phone-ddi.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  inject,\n  Input, OnInit,\n  Output,\n  Provider,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewChildren,\n  ViewContainerRef,\n} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {Overlay} from \"@angular/cdk/overlay\";\nimport {debounceTime, filter, map, Subscription, switchMap} from \"rxjs\";\nimport {AskDropdownDirective} from \"../../directives\";\nimport {takeUntilDestroyed} from \"@angular/core/rxjs-interop\";\nimport {filterSelectedList} from \"../../../shared/helpers/filter.helper\";\nimport CountryFlagService from \"../../../shared/services/country-flag.service\";\nimport {CountryData} from \"../../../shared/providers/flag.provider\";\nimport {NON_DIGIT_REGEX} from \"../../../shared/utils/regex\";\nimport {getCountryFromPhone} from \"../../helpers/phone.helper\";\nimport {OverlayComponent} from \"../../classes/overlay.component\";\nimport { NgxMaskDirective } from 'ngx-mask';\n\nconst valueAccessor: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  multi: true,\n  useExisting: forwardRef(() => PhoneDdiComponent),\n};\n\n@Component({\n  selector: 'ask-phone-ddi',\n  templateUrl: './phone-ddi.component.html',\n  styleUrls: ['./phone-ddi.component.scss'],\n  providers: [valueAccessor],\n})\nexport class PhoneDdiComponent extends OverlayComponent implements OnInit, ControlValueAccessor {\n  @Input() disabled = false;\n  @Input() value = '';\n  @Input() useCountryCode!: string;\n  @Input() disableMask = false;\n  @Input() inferCountryCodeByNumber = true;\n\n  @Output() valueChange = new EventEmitter<string>();\n  @Output() onChangeFlag = new EventEmitter<CountryData>();\n  \n  public formControl = new FormControl();\n\n  @ViewChild('phoneContainer') phoneContainer: ElementRef | undefined\n\n  @ViewChild('wrapper') wrapper: ElementRef | undefined\n\n  @ViewChild(\"menuContainer\") menuContainer: ElementRef | undefined\n\n  @ViewChild('overlayContent') overlayContent: TemplateRef<any> | undefined\n\n  @ViewChild('input', {read: NgxMaskDirective}) inputMask?: NgxMaskDirective;\n  @ViewChild('input', {read: ElementRef}) inputElement?: ElementRef;\n\n  @ViewChildren(AskDropdownDirective)\n  dropdownList?: QueryList<AskDropdownDirective>;\n\n  _selectedFlag?: CountryData;\n\n  set selectedFlag(item: CountryData | undefined) {\n    if (!item) {\n      this._selectedFlag = undefined;\n      return;\n    }\n    \n    const itemCopy = { ...item };\n    \n    if (this.disableMask) {\n      itemCopy.maskFormat = item.mask.replaceAll('_', '') + 'XXXXXXXX';\n    }else{\n      itemCopy.maskFormat = item.mask;\n    }\n    \n    this._selectedFlag = itemCopy;\n  }\n\n  get selectedFlag(): CountryData | undefined {\n    return this._selectedFlag;\n  }\n\n\n  countryItems: CountryData[] = []\n  onChange!: (value?: any) => void;\n  onTouch!: () => void;\n  protected closed = true;\n  set inputValue(value: string) {\n    this.formControl.setValue(value);\n  }\n  \n  get inputValue(): string {\n    return this.formControl.value || '';\n  }\n\n  get prefix(){\n    return (this.selectedFlag?.code.replace('+', '') || '55').replace(NON_DIGIT_REGEX, '');\n  }\n\n  protected searchFieldControl = new FormControl(\"\")\n  protected filteredOptions: any[] = []\n  private _destroy = inject(DestroyRef)\n  private scrollSub?: Subscription;\n\n  constructor(\n    overlay: Overlay,\n    viewContainerRef: ViewContainerRef,\n    private countryFlagService: CountryFlagService,\n    private destroyRef: DestroyRef\n  ) {\n    super(overlay, viewContainerRef);\n  }\n\n  ngOnInit() {\n    this.formControl.valueChanges\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe((value) => {\n        if(this.onChange){\n          this.onChange((this.inputValue.length ? this.prefix: '') + this.inputValue)\n        }\n      });\n    this.handleInputChange();\n    this.loadCountries();\n  }\n\n  private loadCountries() {\n    this.countryFlagService.list()\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(data => {\n          this.countryItems = data;\n          this.filteredOptions = data;\n          this.initSelectedFlag(data);\n      });\n  }\n\n  private getFullValue(){\n    return this.inputElement?.nativeElement.value.replace(/\\D+/g, '')\n  }\n\n  onPaste(event: any) {\n    event.preventDefault()\n    const pastedText = event.clipboardData?.getData('text') || ''\n    const countryCode = this.selectedFlag?.code.substring(1);\n    const countryMask = this.selectedFlag?.mask;\n    if (countryCode && countryMask) {\n      const cleanMask = countryMask.replace(/[\\s\\-\\(\\)]/g, '');\n      const expectedLength = countryCode.length + cleanMask.length;\n      if (pastedText.startsWith(countryCode) && pastedText.length === expectedLength) {\n        const number = pastedText.substring(countryCode.length);\n        this.inputValue = number;\n        // this.onChangePhoneNumber(number);\n        return;\n      }\n    }\n    this.inputValue = pastedText;\n    this.onChangePhoneNumber(pastedText);\n\n  }\n\n  handleOptionSelected(item: any) {\n    this.selectedFlag = item;\n    this.onChangeFlag.emit(this.selectedFlag);\n    this.hideOptions();\n    if(this.disableMask){ \n      this.onChange(this.getFullValue());\n    }else{\n      this.onChange('');\n      setTimeout(() => {\n        this.inputValue = '';\n        this.searchFieldControl.setValue('');\n        this.value = '';\n      });\n\n    }\n  }\n\n  display(option: any) {\n    return this.displayFn(option)\n  }\n\n  override shouldClose(event: MouseEvent) {\n    return !this.closed\n      && !this.wrapper?.nativeElement.contains(event.target)\n      && !this.menuContainer?.nativeElement.contains(event.target)\n  }\n\n  override afterClosed() {\n    this.closed = true;\n    this.searchFieldControl.setValue('')\n    this.scrollSub?.unsubscribe();\n  }\n\n  handleFlagClick(event?: Event) {\n    event?.stopPropagation()\n    if (!this.disabled) {\n      this.closed\n        ? this.showOptions()\n        : this.hideOptions()\n    }\n  }\n\n  showOptions() {\n    this.closed = false\n    if (this.phoneContainer && this.overlayContent) {\n      this.open(this.phoneContainer, this.overlayContent, {\n        backdropClass: 'cdk-overlay-transparent-backdrop',\n        hasBackdrop: true,\n        maxHeight: 300,\n      })\n    }\n  }\n\n  hideOptions() {\n    this.close();\n  }\n\n  onChangePhoneNumber(number: string, removeDdi = true, changeValue = false) {\n    const normalizedNumber = this.normalizePhoneInput(number);\n    const onlyDigits = normalizedNumber?.replace(NON_DIGIT_REGEX, '') || '';\n    \n    if (!this.selectedFlag) {\n      this.value = onlyDigits;\n      this.onChange(this.value);\n      return;\n    }\n\n    const countryCode = this.selectedFlag.code.substring(1);\n    const phoneWithoutDdi = removeDdi ? this.removeDdiFromNumber(onlyDigits, countryCode) : onlyDigits;\n    this.value = phoneWithoutDdi ? countryCode + phoneWithoutDdi : '';\n    if (changeValue) {\n      this.inputValue = phoneWithoutDdi;\n    }\n    if(this.onChange){\n      this.onChange(this.value);\n    }\n  }\n\n  private normalizePhoneInput(number: string): string {\n    if (!number) return '';\n    return number.startsWith('+') ? number.substring(1) : number;\n  }\n\n  private removeDdiFromNumber(number: string, countryCode: string): string {\n    if (!number || !countryCode) return number;\n    return number.startsWith(countryCode) ? number.substring(countryCode.length) : number;\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  writeValue(value: any): void {\n    this.value = value;\n    \n    if (!this.value) {\n      return;\n    }\n\n    this.countryFlagService.list()\n      .pipe(takeUntilDestroyed(this.destroyRef))\n      .subscribe(data => {\n        if (this.value && data.length) {\n          this.initSelectedFlag(data);\n        }\n      });\n  }\n\n  protected readonly displayFn = (countryFlag: any) => `${countryFlag.countryName} (${countryFlag.code})`;\n\n  protected readonly filterFn = (search: string) =>\n    filterSelectedList(this.countryItems, search, ['code', 'countryName']);\n\n  private initSelectedFlag(data: CountryData[]) {\n    if (!this.value) {\n      return this.getDefaultCountryFlag(data);\n    }\n    \n    if(this.inferCountryCodeByNumber){\n      const country = getCountryFromPhone(this.value);\n      this.selectedFlag = this.countryItems.find(item => item.countryCode === country.toLowerCase())\n      this.inputValue = this.value.substring(this.selectedFlag?.code.substring(1).length || 0);\n      this.onChangeFlag.emit(this.selectedFlag);\n      return;\n    }\n\n    return this.getDefaultCountryFlag(data);\n  }\n\n  private getDefaultCountryFlag(data: CountryData[]) {\n    this.selectedFlag = this.countryFlagService.getDefaultCountryFlag(data, this.useCountryCode);\n    this.inputValue = this.value;\n    this.onChangeFlag.emit(this.selectedFlag);\n    this.onChangePhoneNumber(this.value, false);\n  }\n\n  private handleInputChange() {\n    this.searchFieldControl.valueChanges.pipe(\n      takeUntilDestroyed(this._destroy),\n      debounceTime(300),\n      map(value => this.filterFn(value || ''))\n    ).subscribe(items => {\n      this.filteredOptions = items\n    })\n  }\n}\n","<div #phoneContainer [style]=\"{cursor: disabled ? 'not-allowed' : 'auto'}\" class=\"phone-ddi\">\n\n  <div\n    #wrapper\n    (click)=\"handleFlagClick()\"\n    *ngIf=\"selectedFlag\"\n    [style]=\"{cursor: !disabled ? 'pointer' : 'not-allowed'}\"\n    class=\"flag\"\n    data-testid=\"flag\">\n\n    <div [style]=\"{backgroundPosition: this.selectedFlag?.backgroundPosition}\" class=\"flag-icon\"></div>\n    <div class=\"flag-arrow\"></div>\n  </div>\n  <input\n    #input\n    *ngIf=\"selectedFlag; else loadingPhoneInput\"\n    [disabled]=\"disabled\"\n    [placeholder]=\"selectedFlag.mask\"\n    [mask]=\"selectedFlag.maskFormat\"\n    [prefix]=\"selectedFlag.code + ' '\"\n    (paste)=\"onPaste($event)\"\n    [validation]=\"true\"\n    [formControl]=\"formControl\"\n    askAutofocus\n    class=\"phone\"\n  />\n\n  <ng-template #loadingPhoneInput>\n    <div class=\"skeleton\">\n      <ask-skeleton [barsHeight]=\"24\" [radius]=\"10\" style=\"height: 24px;\"/>\n    </div>\n  </ng-template>\n\n</div>\n\n<ng-template #overlayContent>\n  <div #menuContainer class=\"menu-container\">\n    <div [style]=\"{padding: '8px'}\">\n      <ask-input\n        [formControl]=\"searchFieldControl\"\n        [placeholder]=\"'FIND_DDI_OR_COUNTRY' | translate\"\n        [autoFocus]=\"true\"\n        class=\"search\"\n      />\n    </div>\n\n    <ng-container *ngIf=\"!filteredOptions.length; else list\">\n      <span class=\"empty\">{{\n        'NO_OPTIONS' | translate\n        }}</span>\n    </ng-container>\n\n    <ng-template #list>\n      <div [askScrollThreshold]=\"50\" askScroll class=\"list\">\n        <ng-container *ngFor=\"let countryItem of filteredOptions\">\n          <div\n            (click)=\"handleOptionSelected(countryItem)\"\n            class=\"option-item\"\n          >\n            <div [style]=\"{backgroundPosition: countryItem.backgroundPosition}\" class=\"country\"></div>\n            <p class=\"text\">{{ display(countryItem) }}</p>\n          </div>\n        </ng-container>\n      </div>\n    </ng-template>\n  </div>\n</ng-template>\n"]}
@@ -3913,7 +3913,7 @@ class PhoneDdiComponent extends OverlayComponent {
3913
3913
  return this.formControl.value || '';
3914
3914
  }
3915
3915
  get prefix() {
3916
- return (this.inputMask?.prefix || '55').replace(NON_DIGIT_REGEX, '');
3916
+ return (this.selectedFlag?.code.replace('+', '') || '55').replace(NON_DIGIT_REGEX, '');
3917
3917
  }
3918
3918
  constructor(overlay, viewContainerRef, countryFlagService, destroyRef) {
3919
3919
  super(overlay, viewContainerRef);