asksuite-citrus 3.11.2 → 3.11.3-beta2

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.
@@ -175,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
175
175
  type: ViewChildren,
176
176
  args: [AskDropdownDirective]
177
177
  }] } });
178
- //# 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 {TemplatePortal} from \"@angular/cdk/portal\";\nimport {Overlay, OverlayRef} from \"@angular/cdk/overlay\";\nimport {debounceTime, map, Subscription} 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\";\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  @Output() valueChange = new EventEmitter<string>();\n  @Output() onChangeFlag = new EventEmitter<CountryData>();\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  @ViewChildren(AskDropdownDirective)\n  dropdownList?: QueryList<AskDropdownDirective>;\n\n  selectedFlag?: CountryData;\n  countryItems: CountryData[] = []\n  onChange!: (value?: any) => void;\n  onTouch!: () => void;\n  protected closed = true;\n  protected inputValue = ''\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  ) {\n    super(overlay, viewContainerRef);\n  }\n\n  ngOnInit() {\n    this.countryFlagService.list().subscribe(this.addAvailableFlags.bind(this))\n    this.handleInputChange();\n  }\n\n  handleOptionSelected(item: any) {\n      this.selectedFlag = item;\n      this.hideOptions();\n      this.onChange('');\n      this.onChangeFlag.emit(this.selectedFlag);\n      setTimeout(() => {\n        this.inputValue = '';\n        this.searchFieldControl.setValue('');\n        this.value = '';\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) {\n    const newValue = number?.replace(NON_DIGIT_REGEX, '');\n\n    if (this.selectedFlag && newValue?.startsWith(this.selectedFlag?.code.substring(1))) {\n      this.value = newValue\n      this.onChange(this.value)\n    } else if (!newValue || !this.value.includes(newValue)) {\n      // substring to remove the + from the code (ex: +55 -> 55)\n      this.value = (newValue ? (this.selectedFlag?.code ?? '').substring(1) : '') + newValue;\n      this.onChange(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  writeValue(value: any): void {\n    this.value = value;\n    if (this.countryItems.length && this.value) {\n      this.initSelectedFlag(this.countryItems);\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 addAvailableFlags(data: CountryData[]) {\n    this.countryItems = data;\n    this.filteredOptions = this.countryItems;\n    this.initSelectedFlag(data);\n  }\n\n  private initSelectedFlag(data: CountryData[]) {\n    if (!this.value) {\n      this.selectedFlag = this.countryFlagService.getDefaultCountryFlag(data);\n      this.onChangeFlag.emit(this.selectedFlag);\n      return;\n    }\n    const country = getCountryFromPhone(this.value)\n\n    if (!country) {\n      this.selectedFlag = this.countryFlagService.getDefaultCountryFlag(data)\n      this.onChangeFlag.emit(this.selectedFlag);\n      return;\n    }\n    this.selectedFlag = this.countryItems.find(item => item.countryCode === country.toLowerCase())\n    const numberWithoutCountry = this.value.substring(this.selectedFlag?.code.substring(1).length || 0)\n\n    setTimeout(() =>{\n      this.inputValue = numberWithoutCountry;\n      this.onChangeFlag.emit(this.selectedFlag);\n    })\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  handlePhoneChange(event: any) {\n    this.onChangePhoneNumber(event.target.value)\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\n  <input\n    *ngIf=\"selectedFlag; else loadingPhoneInput\"\n    [disabled]=\"disabled\"\n    [(ngModel)]=\"inputValue\"\n    (change)=\"handlePhoneChange($event)\"\n    [placeholder]=\"'PHONE_PLACEHOLDER' | translate\"\n    [mask]=\"selectedFlag.mask\"\n    [prefix]=\"selectedFlag.code + ' '\"\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"]}
178
+ //# 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, map, Subscription} 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\";\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  @Output() valueChange = new EventEmitter<string>();\n  @Output() onChangeFlag = new EventEmitter<CountryData>();\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  @ViewChildren(AskDropdownDirective)\n  dropdownList?: QueryList<AskDropdownDirective>;\n\n  selectedFlag?: CountryData;\n  countryItems: CountryData[] = []\n  onChange!: (value?: any) => void;\n  onTouch!: () => void;\n  protected closed = true;\n  protected inputValue = ''\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  ) {\n    super(overlay, viewContainerRef);\n  }\n\n  ngOnInit() {\n    this.countryFlagService.list().subscribe(this.addAvailableFlags.bind(this))\n    this.handleInputChange();\n  }\n\n  handleOptionSelected(item: any) {\n      this.selectedFlag = item;\n      this.hideOptions();\n      this.onChange('');\n      this.onChangeFlag.emit(this.selectedFlag);\n      setTimeout(() => {\n        this.inputValue = '';\n        this.searchFieldControl.setValue('');\n        this.value = '';\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) {\n    const newValue = number?.replace(NON_DIGIT_REGEX, '');\n\n    if (this.selectedFlag && newValue?.startsWith(this.selectedFlag?.code.substring(1))) {\n      this.value = newValue\n      this.onChange(this.value)\n    } else if (!newValue || !this.value.includes(newValue)) {\n      // substring to remove the + from the code (ex: +55 -> 55)\n      this.value = (newValue ? (this.selectedFlag?.code ?? '').substring(1) : '') + newValue;\n      this.onChange(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  writeValue(value: any): void {\n    this.value = value;\n    if (this.countryItems.length && this.value) {\n      this.initSelectedFlag(this.countryItems);\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 addAvailableFlags(data: CountryData[]) {\n    this.countryItems = data;\n    this.filteredOptions = this.countryItems;\n    this.initSelectedFlag(data);\n  }\n\n  private initSelectedFlag(data: CountryData[]) {\n    if (!this.value) {\n      this.selectedFlag = this.countryFlagService.getDefaultCountryFlag(data);\n      this.onChangeFlag.emit(this.selectedFlag);\n      return;\n    }\n    const country = getCountryFromPhone(this.value)\n\n    if (!country) {\n      this.selectedFlag = this.countryFlagService.getDefaultCountryFlag(data)\n      this.onChangeFlag.emit(this.selectedFlag);\n      return;\n    }\n    this.selectedFlag = this.countryItems.find(item => item.countryCode === country.toLowerCase())\n    const numberWithoutCountry = this.value.substring(this.selectedFlag?.code.substring(1).length || 0)\n\n    setTimeout(() =>{\n      this.inputValue = numberWithoutCountry;\n      this.onChangeFlag.emit(this.selectedFlag);\n    })\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  handlePhoneChange(event: any) {\n    this.onChangePhoneNumber(event.target.value)\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\n  <input\n    *ngIf=\"selectedFlag; else loadingPhoneInput\"\n    [disabled]=\"disabled\"\n    [(ngModel)]=\"inputValue\"\n    (change)=\"handlePhoneChange($event)\"\n    [placeholder]=\"'PHONE_PLACEHOLDER' | translate\"\n    [mask]=\"selectedFlag.mask\"\n    [prefix]=\"selectedFlag.code + ' '\"\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"]}
@@ -4,6 +4,7 @@ import { map, of, tap } from "rxjs";
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common/http";
6
6
  import * as i2 from "@ngx-translate/core";
7
+ import * as i3 from "./location-api.service";
7
8
  var CountryLanguageMap;
8
9
  (function (CountryLanguageMap) {
9
10
  CountryLanguageMap["EN"] = "US";
@@ -11,10 +12,11 @@ var CountryLanguageMap;
11
12
  CountryLanguageMap["ES"] = "ES";
12
13
  })(CountryLanguageMap || (CountryLanguageMap = {}));
13
14
  export default class CountryFlagService {
14
- constructor(flagUrl, http, translateService) {
15
+ constructor(flagUrl, http, translateService, locationApiService) {
15
16
  this.flagUrl = flagUrl;
16
17
  this.http = http;
17
18
  this.translateService = translateService;
19
+ this.locationApiService = locationApiService;
18
20
  this.defaultCountryCode = 'br';
19
21
  this.defaultCountryLanguage = 'pt_br';
20
22
  this.cacheList = [];
@@ -27,17 +29,23 @@ export default class CountryFlagService {
27
29
  }
28
30
  return this.http.get(this.flagUrl).pipe(map(countryData => countryData.map(this.formatCountryData)), tap(data => this.cacheList = data));
29
31
  };
32
+ this.locationApiService.getLocation().subscribe((locationData) => this.countryCodeByLocation = locationData?.country_code.toLocaleLowerCase() || null);
30
33
  }
31
- getDefaultCountryFlag(searchData) {
32
- const language = this.getDefaultCountryLanguage();
34
+ getDefaultCountryFlag(searchData, useLocationApi = false) {
35
+ const language = this.getDefaultCountryLanguage(useLocationApi);
33
36
  const countryCode = this.extractCountryCode([
34
37
  language,
35
38
  navigator.language
36
39
  ]);
40
+ return this.getCountryDataForFlag(searchData, countryCode);
41
+ }
42
+ getCountryDataForFlag(searchData, countryCode) {
37
43
  return searchData.find(countryItem => countryItem.countryCode === countryCode) || searchData[0];
38
44
  }
39
- getDefaultCountryLanguage() {
40
- const language = this.translateService.currentLang;
45
+ getDefaultCountryLanguage(useLocationApi) {
46
+ const language = useLocationApi && this.countryCodeByLocation
47
+ ? this.countryCodeByLocation
48
+ : this.translateService.currentLang;
41
49
  if (!language) {
42
50
  return this.defaultCountryLanguage;
43
51
  }
@@ -69,7 +77,7 @@ export default class CountryFlagService {
69
77
  dashMask: dash_mask
70
78
  };
71
79
  }
72
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CountryFlagService, deps: [{ token: FLAG_PROVIDER_URL }, { token: i1.HttpClient }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Injectable }); }
80
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CountryFlagService, deps: [{ token: FLAG_PROVIDER_URL }, { token: i1.HttpClient }, { token: i2.TranslateService }, { token: i3.LocationApiService }], target: i0.ɵɵFactoryTarget.Injectable }); }
73
81
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CountryFlagService, providedIn: 'root' }); }
74
82
  }
75
83
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CountryFlagService, decorators: [{
@@ -80,5 +88,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
80
88
  }], ctorParameters: () => [{ type: undefined, decorators: [{
81
89
  type: Inject,
82
90
  args: [FLAG_PROVIDER_URL]
83
- }] }, { type: i1.HttpClient }, { type: i2.TranslateService }] });
84
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291bnRyeS1mbGFnLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL3NoYXJlZC9zZXJ2aWNlcy9jb3VudHJ5LWZsYWcuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsTUFBTSxFQUFFLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQTBCLGlCQUFpQixFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFFdEYsT0FBTyxFQUFDLEdBQUcsRUFBRSxFQUFFLEVBQUUsR0FBRyxFQUFDLE1BQU0sTUFBTSxDQUFDOzs7O0FBR2xDLElBQUssa0JBSUo7QUFKRCxXQUFLLGtCQUFrQjtJQUNyQiwrQkFBUyxDQUFBO0lBQ1QsK0JBQVMsQ0FBQTtJQUNULCtCQUFTLENBQUE7QUFDWCxDQUFDLEVBSkksa0JBQWtCLEtBQWxCLGtCQUFrQixRQUl0QjtBQUtELE1BQU0sQ0FBQyxPQUFPLE9BQU8sa0JBQWtCO0lBT3JDLFlBRW1CLE9BQWUsRUFDZixJQUFnQixFQUNoQixnQkFBa0M7UUFGbEMsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQUNmLFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQVY3Qyx1QkFBa0IsR0FBRyxJQUFJLENBQUM7UUFFMUIsMkJBQXNCLEdBQUcsT0FBTyxDQUFDO1FBRWpDLGNBQVMsR0FBa0IsRUFBRSxDQUFBO1FBVXJDLFNBQUksR0FBRyxHQUFHLEVBQUU7WUFDVixJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUNsQixPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUNoQixDQUFDO1lBRUQsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDO2dCQUMxQixPQUFPLEVBQUUsQ0FBQyxDQUFDLEdBQUcsSUFB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QUM7OEdBdEZrQixrQkFBa0Isa0JBUTNCLGlCQUFpQjtrSEFSUixrQkFBa0IsY0FGekIsTUFBTTs7MkZBRUMsa0JBQWtCO2tCQUh0QyxVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7MEJBU0ksTUFBTTsyQkFBQyxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdCwgSW5qZWN0YWJsZX0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7Q291bnRyeURhdGEsIENvdW50cnlEZGksIEZMQUdfUFJPVklERVJfVVJMfSBmcm9tIFwiLi4vcHJvdmlkZXJzL2ZsYWcucHJvdmlkZXJcIjtcbmltcG9ydCB7SHR0cENsaWVudH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XG5pbXBvcnQge21hcCwgb2YsIHRhcH0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7VHJhbnNsYXRlU2VydmljZX0gZnJvbSBcIkBuZ3gtdHJhbnNsYXRlL2NvcmVcIjtcblxuZW51bSBDb3VudHJ5TGFuZ3VhZ2VNYXAge1xuICBFTiA9ICdVUycsXG4gIFBUID0gJ0JSJyxcbiAgRVMgPSAnRVMnXG59XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQ291bnRyeUZsYWdTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBkZWZhdWx0Q291bnRyeUNvZGUgPSAnYnInO1xuXG4gIHByaXZhdGUgZGVmYXVsdENvdW50cnlMYW5ndWFnZSA9ICdwdF9icic7XG5cbiAgcHJpdmF0ZSBjYWNoZUxpc3Q6IENvdW50cnlEYXRhW10gPSBbXVxuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoRkxBR19QUk9WSURFUl9VUkwpXG4gICAgcHJpdmF0ZSByZWFkb25seSBmbGFnVXJsOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSByZWFkb25seSBodHRwOiBIdHRwQ2xpZW50LFxuICAgIHByaXZhdGUgcmVhZG9ubHkgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZVxuICApIHtcbiAgfVxuXG4gIGxpc3QgPSAoKSA9PiB7XG4gICAgaWYgKCF0aGlzLmZsYWdVcmwpIHtcbiAgICAgIHJldHVybiBvZihbXSk7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuY2FjaGVMaXN0Lmxlbmd0aCkge1xuICAgICAgcmV0dXJuIG9mKFsuLi50aGlzLmNhY2hlTGlzdF0pO1xuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmh0dHAuZ2V0PENvdW50cnlEZGlbXT4odGhpcy5mbGFnVXJsKS5waXBlKFxuICAgICAgbWFwKGNvdW50cnlEYXRhID0+IGNvdW50cnlEYXRhLm1hcCh0aGlzLmZvcm1hdENvdW50cnlEYXRhKSksXG4gICAgICB0YXAoZGF0YSA9PiB0aGlzLmNhY2hlTGlzdCA9IGRhdGEpXG4gICAgKTtcbiAgfVxuXG4gIGdldERlZmF1bHRDb3VudHJ5RmxhZyhzZWFyY2hEYXRhOiBDb3VudHJ5RGF0YVtdKSB7XG4gICAgY29uc3QgbGFuZ3VhZ2UgPSB0aGlzLmdldERlZmF1bHRDb3VudHJ5TGFuZ3VhZ2UoKTtcblxuICAgIGNvbnN0IGNvdW50cnlDb2RlID0gdGhpcy5leHRyYWN0Q291bnRyeUNvZGUoW1xuICAgICAgbGFuZ3VhZ2UsXG4gICAgICBuYXZpZ2F0b3IubGFuZ3VhZ2VcbiAgICBdKVxuXG4gICAgcmV0dXJuIHNlYXJjaERhdGEuZmluZChjb3VudHJ5SXRlbSA9PiBjb3VudHJ5SXRlbS5jb3VudHJ5Q29kZSA9PT0gY291bnRyeUNvZGUpIHx8IHNlYXJjaERhdGFbMF07XG4gIH1cblxuICBwcml2YXRlIGdldERlZmF1bHRDb3VudHJ5TGFuZ3VhZ2UoKSB7XG4gICAgY29uc3QgbGFuZ3VhZ2UgPSB0aGlzLnRyYW5zbGF0ZVNlcnZpY2UuY3VycmVudExhbmc7XG5cbiAgICBpZiAoIWxhbmd1YWdlKSB7XG4gICAgICByZXR1cm4gdGhpcy5kZWZhdWx0Q291bnRyeUxhbmd1YWdlO1xuICAgIH1cblxuICAgIGNvbnN0IFttYWluTGFuZ3VhZ2UsIGNvdW50cnlMYW5ndWFnZV0gPSBsYW5ndWFnZT8uc3BsaXQoL1tfXFwtXS8pO1xuXG4gICAgaWYgKGNvdW50cnlMYW5ndWFnZSkge1xuICAgICAgcmV0dXJuIGxhbmd1YWdlO1xuICAgIH1cblxuICAgIGNvbnN0IGRlZmF1bHRDb3VudHJ5TGFuZ3VhZ2UgPSBPYmplY3Qua2V5cyhDb3VudHJ5TGFuZ3VhZ2VNYXApLmluY2x1ZGVzKG1haW5MYW5ndWFnZS50b1VwcGVyQ2FzZSgpIGFzIGFueSkgJiZcbiAgICAgIENvdW50cnlMYW5ndWFnZU1hcFttYWluTGFuZ3VhZ2UudG9VcHBlckNhc2UoKSBhcyBrZXlvZiB0eXBlb2YgQ291bnRyeUxhbmd1YWdlTWFwXTtcblxuICAgIHJldHVybiBkZWZhdWx0Q291bnRyeUxhbmd1YWdlID8gbGFuZ3VhZ2UgKyAnXycgKyBkZWZhdWx0Q291bnRyeUxhbmd1YWdlIDogdGhpcy5kZWZhdWx0Q291bnRyeUxhbmd1YWdlO1xuICB9XG5cbiAgcHJpdmF0ZSBleHRyYWN0Q291bnRyeUNvZGUobGFuZ3VhZ2VzVG9TZWFyY2g6IHN0cmluZ1tdKSB7XG4gICAgbGV0IGZvdW5kQ291bnRyeUNvZGUgPSBudWxsLCBjdXJyZW50SW5kZXggPSAwO1xuXG4gICAgd2hpbGUgKGZvdW5kQ291bnRyeUNvZGUgPT09IG51bGwgJiYgY3VycmVudEluZGV4IDwgbGFuZ3VhZ2VzVG9TZWFyY2gubGVuZ3RoKSB7XG4gICAgICBjb25zdCBsYW5ndWFnZSA9IGxhbmd1YWdlc1RvU2VhcmNoW2N1cnJlbnRJbmRleF07XG4gICAgICBjb25zdCBbLCBzZWNvbmRMYW5ndWFnZV0gPSBsYW5ndWFnZS5zcGxpdCgvW19cXC1dLylcblxuICAgICAgY29uc3QgY291bnRyeUNvZGUgPSBzZWNvbmRMYW5ndWFnZT8udG9Mb3dlckNhc2UoKSB8fCBsYW5ndWFnZS50b0xvd2VyQ2FzZSgpO1xuXG4gICAgICBpZiAoY291bnRyeUNvZGUpIHtcbiAgICAgICAgZm91bmRDb3VudHJ5Q29kZSA9IGNvdW50cnlDb2RlO1xuICAgICAgfVxuXG4gICAgICBjdXJyZW50SW5kZXgrKztcbiAgICB9XG5cbiAgICByZXR1cm4gZm91bmRDb3VudHJ5Q29kZSB8fCB0aGlzLmRlZmF1bHRDb3VudHJ5Q29kZTtcbiAgfVxuXG4gIHByaXZhdGUgZm9ybWF0Q291bnRyeURhdGEoe21hc2ssIGRhc2hfbWFzaywgLi4uZGF0YX06IENvdW50cnlEZGkpOiBDb3VudHJ5RGF0YSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmRhdGEsXG4gICAgICBtYXNrOiBtYXNrLnJlcGxhY2UoL1swLTldL2csICcwJykucmVwbGFjZSgnWCcsICc5JyksXG4gICAgICBkYXNoTWFzazogZGFzaF9tYXNrXG4gICAgfTtcblxuICB9XG59XG4iXX0=
91
+ }] }, { type: i1.HttpClient }, { type: i2.TranslateService }, { type: i3.LocationApiService }] });
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"country-flag.service.js","sourceRoot":"","sources":["../../../../../projects/asksuite-citrus/src/shared/services/country-flag.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable} from \"@angular/core\";\nimport {CountryData, CountryDdi, FLAG_PROVIDER_URL} from \"../providers/flag.provider\";\nimport {HttpClient} from \"@angular/common/http\";\nimport {map, of, tap} from \"rxjs\";\nimport {TranslateService} from \"@ngx-translate/core\";\nimport { LocationApiService } from \"./location-api.service\";\n\nenum CountryLanguageMap {\n  EN = 'US',\n  PT = 'BR',\n  ES = 'ES'\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport default class CountryFlagService {\n  private defaultCountryCode = 'br';\n\n  private defaultCountryLanguage = 'pt_br';\n\n  private cacheList: CountryData[] = []\n  private countryCodeByLocation!: string | null;\n\n  constructor(\n    @Inject(FLAG_PROVIDER_URL)\n    private readonly flagUrl: string,\n    private readonly http: HttpClient,\n    private readonly translateService: TranslateService,\n    private readonly locationApiService: LocationApiService\n  ) {\n    this.locationApiService.getLocation().subscribe((locationData) => \n      this.countryCodeByLocation = locationData?.country_code.toLocaleLowerCase() || null\n    );\n  }\n\n  list = () => {\n    if (!this.flagUrl) {\n      return of([]);\n    }\n\n    if (this.cacheList.length) {\n      return of([...this.cacheList]);\n    }\n\n    return this.http.get<CountryDdi[]>(this.flagUrl).pipe(\n      map(countryData => countryData.map(this.formatCountryData)),\n      tap(data => this.cacheList = data)\n    );\n  }\n\n  getDefaultCountryFlag(searchData: CountryData[], useLocationApi = false) {\n    const language = this.getDefaultCountryLanguage(useLocationApi);\n\n    const countryCode = this.extractCountryCode([\n      language,\n      navigator.language\n    ])\n\n    return this.getCountryDataForFlag(searchData, countryCode);\n  }\n\n  getCountryDataForFlag(searchData: CountryData[], countryCode: string) {\n    return searchData.find(countryItem => countryItem.countryCode === countryCode) || searchData[0];\n  }\n\n  private getDefaultCountryLanguage(useLocationApi: boolean) {\n    const language = useLocationApi && this.countryCodeByLocation \n      ? this.countryCodeByLocation \n      : this.translateService.currentLang;\n\n    if (!language) {\n      return this.defaultCountryLanguage;\n    }\n\n    const [mainLanguage, countryLanguage] = language?.split(/[_\\-]/);\n\n    if (countryLanguage) {\n      return language;\n    }\n\n    const defaultCountryLanguage = Object.keys(CountryLanguageMap).includes(mainLanguage.toUpperCase() as any) &&\n      CountryLanguageMap[mainLanguage.toUpperCase() as keyof typeof CountryLanguageMap];\n\n    return defaultCountryLanguage ? language + '_' + defaultCountryLanguage : this.defaultCountryLanguage;\n  }\n\n  private extractCountryCode(languagesToSearch: string[]) {\n    let foundCountryCode = null, currentIndex = 0;\n\n    while (foundCountryCode === null && currentIndex < languagesToSearch.length) {\n      const language = languagesToSearch[currentIndex];\n      const [, secondLanguage] = language.split(/[_\\-]/)\n\n      const countryCode = secondLanguage?.toLowerCase() || language.toLowerCase();\n\n      if (countryCode) {\n        foundCountryCode = countryCode;\n      }\n\n      currentIndex++;\n    }\n\n    return foundCountryCode || this.defaultCountryCode;\n  }\n\n  private formatCountryData({mask, dash_mask, ...data}: CountryDdi): CountryData {\n    return {\n      ...data,\n      mask: mask.replace(/[0-9]/g, '0').replace('X', '9'),\n      dashMask: dash_mask\n    };\n\n  }\n}\n"]}
@@ -0,0 +1,20 @@
1
+ import { Injectable } from "@angular/core";
2
+ import { catchError, map, of } from "rxjs";
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common/http";
5
+ export class LocationApiService {
6
+ constructor(http) {
7
+ this.http = http;
8
+ this.apiUrl = 'https://location-api.asksuite.com/v1/locations/by-ip';
9
+ }
10
+ getLocation() {
11
+ return this.http.get(this.apiUrl).pipe(map(response => response.data.location), catchError(error => of(null)));
12
+ }
13
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: LocationApiService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
14
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: LocationApiService, providedIn: 'root' }); }
15
+ }
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: LocationApiService, decorators: [{
17
+ type: Injectable,
18
+ args: [{ providedIn: 'root' }]
19
+ }], ctorParameters: () => [{ type: i1.HttpClient }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYXRpb24tYXBpLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hc2tzdWl0ZS1jaXRydXMvc3JjL3NoYXJlZC9zZXJ2aWNlcy9sb2NhdGlvbi1hcGkuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBYyxVQUFVLEVBQUUsR0FBRyxFQUFFLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7O0FBWXZELE1BQU0sT0FBTyxrQkFBa0I7SUFJN0IsWUFBb0IsSUFBZ0I7UUFBaEIsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUY1QixXQUFNLEdBQUcsc0RBQXNELENBQUM7SUFFakMsQ0FBQztJQUV4QyxXQUFXO1FBQ1QsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBTSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxDQUN6QyxHQUFHLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUN2QyxVQUFVLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FDOUIsQ0FBQztJQUNKLENBQUM7OEdBWFUsa0JBQWtCO2tIQUFsQixrQkFBa0IsY0FETCxNQUFNOzsyRkFDbkIsa0JBQWtCO2tCQUQ5QixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uL2h0dHBcIjtcbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgY2F0Y2hFcnJvciwgbWFwLCBvZiB9IGZyb20gXCJyeGpzXCI7XG5cbnR5cGUgTG9jYXRpb25EYXRhID0ge1xuICBjaXR5OiBzdHJpbmc7XG4gIGNvdW50cnk6IHN0cmluZztcbiAgY291bnRyeV9jb2RlOiBzdHJpbmc7XG4gIGlwOiBzdHJpbmc7XG4gIGxvY2F0aW9uOiBzdHJpbmc7XG4gIHN0YXRlOiBzdHJpbmc7XG59XG5cbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXG5leHBvcnQgY2xhc3MgTG9jYXRpb25BcGlTZXJ2aWNlIHtcblxuICBwcml2YXRlIGFwaVVybCA9ICdodHRwczovL2xvY2F0aW9uLWFwaS5hc2tzdWl0ZS5jb20vdjEvbG9jYXRpb25zL2J5LWlwJztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQpIHt9XG5cbiAgZ2V0TG9jYXRpb24oKTogT2JzZXJ2YWJsZTxMb2NhdGlvbkRhdGEgfCBudWxsPiB7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQ8YW55Pih0aGlzLmFwaVVybCkucGlwZShcbiAgICAgIG1hcChyZXNwb25zZSA9PiByZXNwb25zZS5kYXRhLmxvY2F0aW9uKSxcbiAgICAgIGNhdGNoRXJyb3IoZXJyb3IgPT4gb2YobnVsbCkpXG4gICAgKTtcbiAgfVxufSJdfQ==
@@ -8,7 +8,7 @@ import * as i2 from '@angular/forms';
8
8
  import { NG_VALUE_ACCESSOR, FormControl, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
9
9
  import * as i3 from 'ngx-mask';
10
10
  import { NgxMaskDirective, NgxMaskPipe, provideNgxMask } from 'ngx-mask';
11
- import { debounceTime, tap, map, fromEvent, filter, BehaviorSubject, Subject, delay, Subscription, distinctUntilChanged, of } from 'rxjs';
11
+ import { debounceTime, tap, map, fromEvent, filter, BehaviorSubject, Subject, delay, Subscription, distinctUntilChanged, catchError, of } from 'rxjs';
12
12
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
13
13
  import { TemplatePortal, ComponentPortal } from '@angular/cdk/portal';
14
14
  import * as i1$2 from '@angular/cdk/overlay';
@@ -3440,6 +3440,22 @@ function searchArray(array, keys, searchValue) {
3440
3440
 
3441
3441
  const FLAG_PROVIDER_URL = new InjectionToken('Flags');
3442
3442
 
3443
+ class LocationApiService {
3444
+ constructor(http) {
3445
+ this.http = http;
3446
+ this.apiUrl = 'https://location-api.asksuite.com/v1/locations/by-ip';
3447
+ }
3448
+ getLocation() {
3449
+ return this.http.get(this.apiUrl).pipe(map(response => response.data.location), catchError(error => of(null)));
3450
+ }
3451
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: LocationApiService, deps: [{ token: i1$4.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
3452
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: LocationApiService, providedIn: 'root' }); }
3453
+ }
3454
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: LocationApiService, decorators: [{
3455
+ type: Injectable,
3456
+ args: [{ providedIn: 'root' }]
3457
+ }], ctorParameters: () => [{ type: i1$4.HttpClient }] });
3458
+
3443
3459
  var CountryLanguageMap;
3444
3460
  (function (CountryLanguageMap) {
3445
3461
  CountryLanguageMap["EN"] = "US";
@@ -3447,10 +3463,11 @@ var CountryLanguageMap;
3447
3463
  CountryLanguageMap["ES"] = "ES";
3448
3464
  })(CountryLanguageMap || (CountryLanguageMap = {}));
3449
3465
  class CountryFlagService {
3450
- constructor(flagUrl, http, translateService) {
3466
+ constructor(flagUrl, http, translateService, locationApiService) {
3451
3467
  this.flagUrl = flagUrl;
3452
3468
  this.http = http;
3453
3469
  this.translateService = translateService;
3470
+ this.locationApiService = locationApiService;
3454
3471
  this.defaultCountryCode = 'br';
3455
3472
  this.defaultCountryLanguage = 'pt_br';
3456
3473
  this.cacheList = [];
@@ -3463,17 +3480,23 @@ class CountryFlagService {
3463
3480
  }
3464
3481
  return this.http.get(this.flagUrl).pipe(map(countryData => countryData.map(this.formatCountryData)), tap(data => this.cacheList = data));
3465
3482
  };
3483
+ this.locationApiService.getLocation().subscribe((locationData) => this.countryCodeByLocation = locationData?.country_code.toLocaleLowerCase() || null);
3466
3484
  }
3467
- getDefaultCountryFlag(searchData) {
3468
- const language = this.getDefaultCountryLanguage();
3485
+ getDefaultCountryFlag(searchData, useLocationApi = false) {
3486
+ const language = this.getDefaultCountryLanguage(useLocationApi);
3469
3487
  const countryCode = this.extractCountryCode([
3470
3488
  language,
3471
3489
  navigator.language
3472
3490
  ]);
3491
+ return this.getCountryDataForFlag(searchData, countryCode);
3492
+ }
3493
+ getCountryDataForFlag(searchData, countryCode) {
3473
3494
  return searchData.find(countryItem => countryItem.countryCode === countryCode) || searchData[0];
3474
3495
  }
3475
- getDefaultCountryLanguage() {
3476
- const language = this.translateService.currentLang;
3496
+ getDefaultCountryLanguage(useLocationApi) {
3497
+ const language = useLocationApi && this.countryCodeByLocation
3498
+ ? this.countryCodeByLocation
3499
+ : this.translateService.currentLang;
3477
3500
  if (!language) {
3478
3501
  return this.defaultCountryLanguage;
3479
3502
  }
@@ -3505,7 +3528,7 @@ class CountryFlagService {
3505
3528
  dashMask: dash_mask
3506
3529
  };
3507
3530
  }
3508
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CountryFlagService, deps: [{ token: FLAG_PROVIDER_URL }, { token: i1$4.HttpClient }, { token: i3$1.TranslateService }], target: i0.ɵɵFactoryTarget.Injectable }); }
3531
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CountryFlagService, deps: [{ token: FLAG_PROVIDER_URL }, { token: i1$4.HttpClient }, { token: i3$1.TranslateService }, { token: LocationApiService }], target: i0.ɵɵFactoryTarget.Injectable }); }
3509
3532
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CountryFlagService, providedIn: 'root' }); }
3510
3533
  }
3511
3534
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: CountryFlagService, decorators: [{
@@ -3516,7 +3539,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
3516
3539
  }], ctorParameters: () => [{ type: undefined, decorators: [{
3517
3540
  type: Inject,
3518
3541
  args: [FLAG_PROVIDER_URL]
3519
- }] }, { type: i1$4.HttpClient }, { type: i3$1.TranslateService }] });
3542
+ }] }, { type: i1$4.HttpClient }, { type: i3$1.TranslateService }, { type: LocationApiService }] });
3520
3543
 
3521
3544
  const DIGIT_REGEX = /\d/g;
3522
3545
  const NON_DIGIT_REGEX = /\D+/g;