@onemrvapublic/design-system 18.1.4 → 18.2.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.
Files changed (68) hide show
  1. package/esm2022/layout/src/components/layout/layout.component.mjs +9 -2
  2. package/esm2022/mat-input-country/src/onemrva-mat-input-country.component.mjs +3 -3
  3. package/esm2022/mat-input-enterprise-number/src/onemrva-mat-input-enterprise-number.component.mjs +3 -3
  4. package/esm2022/mat-input-phone/src/onemrva-mat-input-phone.component.mjs +3 -3
  5. package/esm2022/shared/index.mjs +13 -11
  6. package/esm2022/shared/src/lib/adapters/date.adapter.mjs +62 -0
  7. package/esm2022/shared/src/lib/adapters/index.mjs +2 -0
  8. package/esm2022/shared/src/lib/components/index.mjs +2 -0
  9. package/esm2022/shared/src/lib/constants/CDNUrlModeOptions.mjs +6 -0
  10. package/esm2022/shared/src/lib/constants/cdn.mjs +3 -0
  11. package/esm2022/shared/src/lib/constants/constants.mjs +6 -0
  12. package/esm2022/shared/src/lib/constants/date.format.mjs +12 -0
  13. package/esm2022/shared/src/lib/constants/index.mjs +5 -0
  14. package/esm2022/shared/src/lib/decorators/index.mjs +2 -0
  15. package/esm2022/shared/src/lib/helpers/index.mjs +2 -0
  16. package/esm2022/shared/src/lib/helpers/translation-helper.mjs +30 -0
  17. package/esm2022/shared/src/lib/loaders/index.mjs +3 -0
  18. package/esm2022/shared/src/lib/loaders/onemrva-translate-cdn-loader.mjs +15 -0
  19. package/esm2022/shared/src/lib/loaders/onemrva-translate-http-loader.mjs +30 -0
  20. package/esm2022/shared/src/lib/services/cdn.service.mjs +28 -68
  21. package/esm2022/shared/src/lib/services/country-cdn.service.mjs +72 -0
  22. package/esm2022/shared/src/lib/services/country-lookup.service.mjs +38 -0
  23. package/esm2022/shared/src/lib/services/index.mjs +3 -2
  24. package/esm2022/shared/src/lib/shared.datepicker.module.mjs +3 -3
  25. package/esm2022/shared/src/lib/validators/bank-account.validator.utils.mjs +45 -0
  26. package/esm2022/shared/src/lib/validators/index.mjs +3 -0
  27. package/fesm2022/onemrvapublic-design-system-layout.mjs +8 -1
  28. package/fesm2022/onemrvapublic-design-system-layout.mjs.map +1 -1
  29. package/fesm2022/onemrvapublic-design-system-mat-input-country.mjs +2 -2
  30. package/fesm2022/onemrvapublic-design-system-mat-input-country.mjs.map +1 -1
  31. package/fesm2022/onemrvapublic-design-system-mat-input-enterprise-number.mjs +2 -2
  32. package/fesm2022/onemrvapublic-design-system-mat-input-enterprise-number.mjs.map +1 -1
  33. package/fesm2022/onemrvapublic-design-system-mat-input-phone.mjs +2 -2
  34. package/fesm2022/onemrvapublic-design-system-mat-input-phone.mjs.map +1 -1
  35. package/fesm2022/onemrvapublic-design-system-shared.mjs +591 -490
  36. package/fesm2022/onemrvapublic-design-system-shared.mjs.map +1 -1
  37. package/mat-input-country/src/onemrva-mat-input-country.component.d.ts +2 -2
  38. package/mat-input-enterprise-number/src/onemrva-mat-input-enterprise-number.component.d.ts +2 -2
  39. package/mat-input-phone/src/onemrva-mat-input-phone.component.d.ts +2 -2
  40. package/package.json +1 -1
  41. package/shared/index.d.ts +12 -10
  42. package/shared/src/lib/adapters/index.d.ts +1 -0
  43. package/shared/src/lib/components/index.d.ts +1 -0
  44. package/shared/src/lib/{constants.d.ts → constants/constants.d.ts} +1 -0
  45. package/shared/src/lib/constants/index.d.ts +4 -0
  46. package/shared/src/lib/decorators/index.d.ts +1 -0
  47. package/shared/src/lib/helpers/index.d.ts +1 -0
  48. package/shared/src/lib/helpers/translation-helper.d.ts +2 -0
  49. package/shared/src/lib/loaders/index.d.ts +2 -0
  50. package/shared/src/lib/loaders/onemrva-translate-cdn-loader.d.ts +14 -0
  51. package/shared/src/lib/loaders/onemrva-translate-http-loader.d.ts +14 -0
  52. package/shared/src/lib/services/cdn.service.d.ts +7 -86
  53. package/shared/src/lib/services/country-cdn.service.d.ts +89 -0
  54. package/shared/src/lib/services/{commonCountryLookup.service.d.ts → country-lookup.service.d.ts} +1 -1
  55. package/shared/src/lib/services/index.d.ts +2 -1
  56. package/shared/src/lib/validators/index.d.ts +2 -0
  57. package/esm2022/shared/src/lib/CDNUrlModeOptions.mjs +0 -6
  58. package/esm2022/shared/src/lib/OnemrvaDateAdapter.mjs +0 -62
  59. package/esm2022/shared/src/lib/constants.mjs +0 -5
  60. package/esm2022/shared/src/lib/date.format.mjs +0 -12
  61. package/esm2022/shared/src/lib/injectionTokens.mjs +0 -3
  62. package/esm2022/shared/src/lib/services/commonCountryLookup.service.mjs +0 -38
  63. package/esm2022/shared/src/lib/validators/bankAccountValidator.utils.mjs +0 -45
  64. /package/shared/src/lib/{OnemrvaDateAdapter.d.ts → adapters/date.adapter.d.ts} +0 -0
  65. /package/shared/src/lib/{CDNUrlModeOptions.d.ts → constants/CDNUrlModeOptions.d.ts} +0 -0
  66. /package/shared/src/lib/{injectionTokens.d.ts → constants/cdn.d.ts} +0 -0
  67. /package/shared/src/lib/{date.format.d.ts → constants/date.format.d.ts} +0 -0
  68. /package/shared/src/lib/validators/{bankAccountValidator.utils.d.ts → bank-account.validator.utils.d.ts} +0 -0
@@ -50,7 +50,14 @@ export class LayoutComponent {
50
50
  this.isSmall = true;
51
51
  this.id = 'main';
52
52
  this.role = 'main';
53
- // this.isLogoutUsed = this.logout.observers.length > 0;
53
+ if (this.languages.length === 0) {
54
+ this.translateService.getLangs().forEach(value => {
55
+ this.languages.push({
56
+ code: value,
57
+ label: value.toUpperCase(),
58
+ });
59
+ });
60
+ }
54
61
  }
55
62
  ngOnInit() {
56
63
  this.selectedIndex = this.languages.findIndex(l => l.code === this.translateService.currentLang);
@@ -166,4 +173,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
166
173
  }], role: [{
167
174
  type: Input
168
175
  }] } });
169
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout.component.js","sourceRoot":"","sources":["../../../../../../../../projects/onemrva/design-system/layout/src/components/layout/layout.component.ts","../../../../../../../../projects/onemrva/design-system/layout/src/components/layout/layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  Input,\n  AfterViewInit,\n  OnDestroy,\n  QueryList,\n  OnInit,\n  Inject,\n  isDevMode,\n  EventEmitter,\n  Output,\n  ViewChild,\n} from '@angular/core';\n\nimport { LayoutRouteComponent } from '../layout-route/layout-route.component';\nimport { TranslateService } from '@ngx-translate/core';\nimport { LayoutContentComponent } from '../layout-content/layout-content.component';\nimport { Subject, takeUntil } from 'rxjs';\nimport { LayoutTitleComponent } from '../layout-title/layout-title.component';\n\nimport { Environment } from '../../enums/environment.enum';\nimport {\n  BreakpointObserver,\n  Breakpoints,\n  BreakpointState,\n} from '@angular/cdk/layout';\nimport { DOCUMENT } from '@angular/common';\nimport { LayoutFooterComponent } from '../layout-footer/layout-footer.component';\nimport { OnemRvaProfile } from '../../models/onemrva-profile.model';\nimport { LayoutLoginMenuComponent } from '../layout-login-menu/layout-login-menu.component';\nimport { MatDrawer } from '@angular/material/sidenav';\nimport { DrawerHostDirective } from '../../directives/drawer-host.directive';\nimport { OnemrvaDrawerService } from '../../services/drawer.service';\nimport { LayoutSidenavComponent } from '../layout-sidenav/layout-sidenav.component';\nimport { LayoutAfterNavComponent } from '../layout-after-nav/layout-after-nav.component';\nimport { OnemRvaLanguage } from '../../models/onem-language.model';\n\n@Component({\n  selector: 'onemrva-layout',\n  templateUrl: './layout.component.html',\n  styleUrls: ['./layout.component.scss'],\n})\nexport class LayoutComponent implements OnInit, AfterViewInit, OnDestroy {\n  @ContentChildren(LayoutRouteComponent)\n  routes?: QueryList<LayoutRouteComponent>;\n\n  @ContentChild(LayoutTitleComponent) title?: LayoutTitleComponent;\n  @ContentChild(LayoutLoginMenuComponent) loginMenu?: LayoutLoginMenuComponent;\n  @ContentChild(LayoutContentComponent) content?: LayoutContentComponent;\n  @ContentChild(LayoutAfterNavComponent) afterNav?: LayoutAfterNavComponent;\n\n  @ContentChild(LayoutFooterComponent)\n  footer?: LayoutFooterComponent;\n\n  fluid: boolean = false;\n\n  @Input()\n  logo: string = ''; // custom logo, empty string will show default onem/rva/neo/lfa localised logo\n\n  @Input()\n  languages: OnemRvaLanguage[] = []; // list of languages\n\n  @Input()\n  environment?: Environment; // possible environment to show on the frontend LOCAL, TEST, VAL, PROD\n\n  @Input()\n  logoRedictionUrl?: string | any[] | null = ''; // value for routerLink from logo. \"\" by default. Deactivated when set to null\n\n  selectedIndex = 0;\n  destroyNotifier$: Subject<void> = new Subject();\n\n  @Input()\n  profile: OnemRvaProfile | null = null; // To be defined for application with authentication\n\n  @Output()\n  login: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  logout: EventEmitter<void> = new EventEmitter<void>();\n  //    isLogoutUsed: boolean = false;\n\n  env = Environment;\n\n  isSmall = true;\n\n  @ViewChild(MatDrawer, { static: true }) drawer!: MatDrawer;\n  @ViewChild(DrawerHostDirective, { static: true })\n  drawerHost!: DrawerHostDirective;\n\n  @Input()\n  id: string = 'main';\n\n  @Input()\n  role: string = 'main';\n\n  constructor(\n    private translateService: TranslateService,\n    private cd: ChangeDetectorRef,\n    public breakpointObserver: BreakpointObserver,\n    @Inject(DOCUMENT) private document: Document,\n    public drawerService: OnemrvaDrawerService,\n  ) {\n    //      this.isLogoutUsed = this.logout.observers.length > 0;\n  }\n\n  ngOnInit() {\n    this.selectedIndex = this.languages.findIndex(\n      l => l.code === this.translateService.currentLang,\n    );\n\n    this.document.documentElement.lang = this.translateService.currentLang;\n\n    this.breakpointObserver\n      .observe([Breakpoints.XSmall, Breakpoints.Small])\n      .pipe(takeUntil(this.destroyNotifier$))\n      .subscribe((state: BreakpointState) => {\n        if (state.matches) {\n          this.isSmall = true;\n        } else {\n          this.drawerService.close();\n          this.isSmall = false;\n        }\n      });\n\n    if (this.logo === '') {\n      this.logo = `https://cdn.services.rvaonem.fgov.be/img/logo/logo_${this.translateService.currentLang?.toLocaleLowerCase()}.svg`;\n\n      this.translateService.onLangChange\n        .pipe(takeUntil(this.destroyNotifier$))\n        .subscribe(lang => {\n          this.logo = `https://cdn.services.rvaonem.fgov.be/img/logo/logo_${lang.lang?.toLocaleLowerCase()}.svg`;\n        });\n    }\n    this.translateService.onLangChange\n      .pipe(takeUntil(this.destroyNotifier$))\n      .subscribe(event => {\n        this.selectedIndex = this.languages.findIndex(\n          lang => lang.code === event.lang,\n        );\n      });\n\n    this.drawerService.host = this.drawerHost;\n    this.drawerService.drawer = this.drawer;\n  }\n\n  get currentLanguage() {\n    return this.translateService.currentLang || '';\n  }\n\n  ngAfterViewInit() {\n    if (isDevMode()) {\n      this.cd.detectChanges();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n  }\n\n  doLogout() {\n    this.logout.next();\n  }\n\n  doLogin() {\n    this.login.next();\n  }\n\n  changeLanguage(langCode: string) {\n    this.translateService.use(langCode);\n    this.document.documentElement.lang = langCode;\n  }\n\n  toggleSideNav() {\n    this.drawerHost.viewContainerRef.clear();\n    const componentRef = this.drawerHost.viewContainerRef.createComponent(\n      LayoutSidenavComponent,\n    );\n    componentRef.instance.isSmall = this.isSmall;\n    componentRef.instance.languages = this.languages;\n    componentRef.instance.routes = this.routes;\n    this.drawerService.hasBackdrop = false;\n\n    this.drawer.open();\n  }\n}\n","<mat-drawer-container\n  class=\"example-container\"\n  [hasBackdrop]=\"drawerService.hasBackdrop\"\n  autosize\n>\n  <div class=\"app-content\">\n    <header>\n      <mat-toolbar class=\"mat-elevation-z4\">\n        <div class=\"environment\" [class]=\"environment\">\n          {{ environment }}\n        </div>\n        <div\n          [class.onemrva-layout-container]=\"!fluid\"\n          class=\"nav-container flex-center\"\n        >\n          {{ logoRedictionUrl }}\n          <img\n            class=\"logo\"\n            [src]=\"logo\"\n            [attr.data-cy]=\"\n              'onemrva_logo_' + currentLanguage.toLocaleLowerCase()\n            \"\n            alt=\"Logo ONEM/RVA\"\n            [routerLink]=\"\n              logoRedictionUrl !== null ? logoRedictionUrl : undefined\n            \"\n            [ngStyle]=\"{\n              cursor: logoRedictionUrl !== null ? 'pointer' : 'default',\n            }\"\n          />\n          <div\n            class=\"application-title\"\n            [ngClass]=\"{ 'small-screen': isSmall }\"\n          >\n            <ng-container *ngIf=\"title?.template as titleTpl\">\n              <ng-container *ngTemplateOutlet=\"titleTpl\"></ng-container>\n            </ng-container>\n          </div>\n\n          <div style=\"flex: 1\"></div>\n          <div\n            class=\"flex-center\"\n            mat-tab-nav-bar\n            [tabPanel]=\"tabPanel\"\n            *ngIf=\"!isSmall\"\n          >\n            <ng-container *ngFor=\"let e of routes?.toArray(); let i = index\">\n              <a\n                mat-tab-link\n                [routerLink]=\"e.routerLink\"\n                [routerLinkActiveOptions]=\"{ exact: !e.hasSubroutes() }\"\n                #rla=\"routerLinkActive\"\n                routerLinkActive=\"mdc-tab--active\"\n                [active]=\"rla.isActive || e.isRouteActive()\"\n              >\n                <ng-container *ngIf=\"e.template as routeTemplate\">\n                  <ng-container *ngTemplateOutlet=\"routeTemplate\">\n                  </ng-container>\n                </ng-container>\n              </a>\n            </ng-container>\n          </div>\n\n          <mat-tab-nav-panel #tabPanel></mat-tab-nav-panel>\n\n          <ng-container *ngIf=\"afterNav?.template as tpl\">\n            <ng-container *ngTemplateOutlet=\"tpl\"></ng-container>\n          </ng-container>\n\n          <ng-container *ngIf=\"profile !== null\">\n            <mat-divider\n              vertical\n              style=\"height: 1em; align-self: center\"\n              *ngIf=\"!isSmall\"\n            ></mat-divider>\n            <onemrva-mat-avatar\n              matRipple\n              *ngIf=\"profile.isLoggedIn\"\n              [matMenuTriggerFor]=\"menu\"\n              initials=\"{{ profile.initials() }}\"\n              color=\"accent\"\n              size=\"extrasmall\"\n              class=\"clickable\"\n            ></onemrva-mat-avatar>\n\n            <onemrva-mat-avatar\n              matRipple\n              *ngIf=\"!profile.isLoggedIn\"\n              [matMenuTriggerFor]=\"menu\"\n              icon=\"account_circle\"\n              color=\"\"\n              size=\"extrasmall\"\n              class=\"clickable\"\n            ></onemrva-mat-avatar>\n            <mat-menu #menu=\"matMenu\">\n              <ng-container *ngIf=\"profile.isLoggedIn; else notConnected\">\n                <p class=\"accountName\">\n                  {{ profile.firstName }} {{ profile.lastName }}\n                </p>\n                <mat-divider style=\"align-self: stretch\"></mat-divider>\n\n                <ng-container *ngIf=\"loginMenu?.template as menuLoginTpl\">\n                  <ng-container *ngTemplateOutlet=\"menuLoginTpl\"></ng-container>\n                </ng-container>\n\n                <button\n                  type=\"button\"\n                  class=\"mat-mdc-menu-item\"\n                  mat-menu-item\n                  data-cy=\"logoutButton\"\n                  (click)=\"doLogout()\"\n                  [attr.aria-label]=\"'layout.logout' | translate\"\n                >\n                  <mat-icon>logout</mat-icon>\n                  {{ 'layout.logout' | translate }}\n                </button>\n              </ng-container>\n              <ng-template #notConnected>\n                <button\n                  type=\"button\"\n                  mat-menu-item\n                  data-cy=\"loginButton\"\n                  (click)=\"doLogin()\"\n                  [attr.aria-label]=\"'layout.login' | translate\"\n                >\n                  <mat-icon>login</mat-icon>\n                  {{ 'layout.login' | translate }}\n                </button>\n              </ng-template>\n            </mat-menu>\n          </ng-container>\n          <ng-container\n            *ngIf=\"\n              isSmall &&\n              (routes?.toArray()?.length || (languages && languages.length > 1))\n            \"\n          >\n            <button\n              type=\"button\"\n              mat-icon-button\n              class=\"menu-button\"\n              data-cy=\"smallDeviceMenu\"\n              (click)=\"toggleSideNav()\"\n              [attr.aria-label]=\"'layout.menu' | translate\"\n            >\n              <mat-icon>menu</mat-icon>\n            </button>\n          </ng-container>\n          <div\n            class=\"flex-center\"\n            mat-tab-nav-bar\n            [tabPanel]=\"tabPanel\"\n            *ngIf=\"!isSmall\"\n          >\n            <a\n              [matMenuTriggerFor]=\"languageMenu\"\n              data-cy=\"languageMenu\"\n              [attr.aria-label]=\"'language.selection' | translate\"\n              mat-tab-link\n            >\n              {{ currentLanguage }}\n              <mat-icon style=\"width: 16px\">expand_more</mat-icon>\n            </a>\n          </div>\n          <mat-menu #languageMenu>\n            <button\n              *ngFor=\"let lang of languages\"\n              type=\"button\"\n              class=\"mat-mdc-menu-item\"\n              mat-menu-item\n              [attr.data-cy]=\"'language_' + lang.code\"\n              (click)=\"changeLanguage(lang.code)\"\n              [attr.aria-label]=\"lang.label\"\n            >\n              {{ lang.label }}\n            </button>\n          </mat-menu>\n        </div>\n      </mat-toolbar>\n    </header>\n    <ng-container>\n      <div\n        [id]=\"id\"\n        [attr.role]=\"role\"\n        [class.onemrva-layout-container]=\"!fluid\"\n        class=\"onemrva-layout-content\"\n        *ngIf=\"content?.template as tpl\"\n      >\n        <ng-container *ngTemplateOutlet=\"tpl\"></ng-container>\n\n        <ng-container\n          *ngIf=\"\n            environment &&\n            (environment === env.LOCAL || environment === env.TEST)\n          \"\n        >\n          <button\n            id=\"accessibility_fab\"\n            mat-fab\n            color=\"accent\"\n            aria-label=\"Accessibility check\"\n            matTooltip=\"Accessibility check\"\n            onclick=\"(function() {var _p='//openfed.github.io/AccessibilityCheck/build/';var _i=function(s,cb) {var sc=document.createElement('script');sc.onload = function() {sc.onload = null;sc.onreadystatechange = null;cb.call(this);};sc.onreadystatechange = function(){if(/^(complete|loaded)$/.test(this.readyState) === true){sc.onreadystatechange = null;sc.onload();}};sc.src=s;if (document.head) {document.head.appendChild(sc);} else {document.getElementsByTagName('head')[0].appendChild(sc);}}; var options={path:_p};_i(_p+'HTMLCS.js',function(){HTMLCSAuditor.run('WCAG2AA',null,options);});})();\"\n          >\n            <mat-icon>accessibility</mat-icon>\n          </button>\n        </ng-container>\n      </div>\n\n      <footer class=\"onemrva-footer\" *ngIf=\"footer?.template as footer\">\n        <div [class.onemrva-layout-container]=\"!fluid\">\n          <ng-container *ngTemplateOutlet=\"footer\"></ng-container>\n        </div>\n      </footer>\n    </ng-container>\n  </div>\n\n  <mat-drawer\n    class=\"onemrva-drawer mobile-menu-sidebar\"\n    mode=\"over\"\n    position=\"end\"\n  >\n    <ng-template drawerhost></ng-template>\n  </mat-drawer>\n</mat-drawer-container>\n"]}
176
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout.component.js","sourceRoot":"","sources":["../../../../../../../../projects/onemrva/design-system/layout/src/components/layout/layout.component.ts","../../../../../../../../projects/onemrva/design-system/layout/src/components/layout/layout.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,YAAY,EACZ,eAAe,EACf,KAAK,EAKL,MAAM,EACN,SAAS,EACT,YAAY,EACZ,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAE9E,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAE9E,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAEL,WAAW,GAEZ,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;AAEjF,OAAO,EAAE,wBAAwB,EAAE,MAAM,kDAAkD,CAAC;AAC5F,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,wCAAwC,CAAC;AAE7E,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAE,uBAAuB,EAAE,MAAM,gDAAgD,CAAC;;;;;;;;;;;;;;;;;;AAQzF,MAAM,OAAO,eAAe;IAqD1B,YACU,gBAAkC,EAClC,EAAqB,EACtB,kBAAsC,EACnB,QAAkB,EACrC,aAAmC;QAJlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,OAAE,GAAF,EAAE,CAAmB;QACtB,uBAAkB,GAAlB,kBAAkB,CAAoB;QACnB,aAAQ,GAAR,QAAQ,CAAU;QACrC,kBAAa,GAAb,aAAa,CAAsB;QA9C5C,UAAK,GAAY,KAAK,CAAC;QAGvB,SAAI,GAAW,EAAE,CAAC,CAAC,8EAA8E;QAGjG,cAAS,GAAsB,EAAE,CAAC,CAAC,oBAAoB;QAMvD,qBAAgB,GAA2B,EAAE,CAAC,CAAC,8EAA8E;QAE7H,kBAAa,GAAG,CAAC,CAAC;QAClB,qBAAgB,GAAkB,IAAI,OAAO,EAAE,CAAC;QAGhD,YAAO,GAA0B,IAAI,CAAC,CAAC,oDAAoD;QAG3F,UAAK,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAGrD,WAAM,GAAuB,IAAI,YAAY,EAAQ,CAAC;QACtD,oCAAoC;QAEpC,QAAG,GAAG,WAAW,CAAC;QAElB,YAAO,GAAG,IAAI,CAAC;QAOf,OAAE,GAAW,MAAM,CAAC;QAGpB,SAAI,GAAW,MAAM,CAAC;QASpB,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBAC/C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;oBAClB,IAAI,EAAE,KAAK;oBACX,KAAK,EAAE,KAAK,CAAC,WAAW,EAAE;iBACR,CAAC,CAAC;YACxB,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAC3C,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAClD,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;QAEvE,IAAI,CAAC,kBAAkB;aACpB,OAAO,CAAC,CAAC,WAAW,CAAC,MAAM,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;aAChD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;aACtC,SAAS,CAAC,CAAC,KAAsB,EAAE,EAAE;YACpC,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;gBAClB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACtB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAC3B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACvB,CAAC;QACH,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,IAAI,KAAK,EAAE,EAAE,CAAC;YACrB,IAAI,CAAC,IAAI,GAAG,sDAAsD,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,iBAAiB,EAAE,MAAM,CAAC;YAE/H,IAAI,CAAC,gBAAgB,CAAC,YAAY;iBAC/B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;iBACtC,SAAS,CAAC,IAAI,CAAC,EAAE;gBAChB,IAAI,CAAC,IAAI,GAAG,sDAAsD,IAAI,CAAC,IAAI,EAAE,iBAAiB,EAAE,MAAM,CAAC;YACzG,CAAC,CAAC,CAAC;QACP,CAAC;QACD,IAAI,CAAC,gBAAgB,CAAC,YAAY;aAC/B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;aACtC,SAAS,CAAC,KAAK,CAAC,EAAE;YACjB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAC3C,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,CACjC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC;QAC1C,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;IAC1C,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,gBAAgB,CAAC,WAAW,IAAI,EAAE,CAAC;IACjD,CAAC;IAED,eAAe;QACb,IAAI,SAAS,EAAE,EAAE,CAAC;YAChB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;QAC7B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC;IACnC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACpB,CAAC;IAED,cAAc,CAAC,QAAgB;QAC7B,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,GAAG,QAAQ,CAAC;IAChD,CAAC;IAED,aAAa;QACX,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;QACzC,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,eAAe,CACnE,sBAAsB,CACvB,CAAC;QACF,YAAY,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7C,YAAY,CAAC,QAAQ,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QACjD,YAAY,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC3C,IAAI,CAAC,aAAa,CAAC,WAAW,GAAG,KAAK,CAAC;QAEvC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;8GArJU,eAAe,qHAyDhB,QAAQ;kGAzDP,eAAe,wSAIZ,oBAAoB,4EACpB,wBAAwB,0EACxB,sBAAsB,2EACtB,uBAAuB,yEAEvB,qBAAqB,4DARlB,oBAAoB,qEA0C1B,SAAS,2FACT,mBAAmB,8DCzFhC,gkQAiOA;;2FDpLa,eAAe;kBAL3B,SAAS;+BACE,gBAAgB;;0BA6DvB,MAAM;2BAAC,QAAQ;4EAvDlB,MAAM;sBADL,eAAe;uBAAC,oBAAoB;gBAGD,KAAK;sBAAxC,YAAY;uBAAC,oBAAoB;gBACM,SAAS;sBAAhD,YAAY;uBAAC,wBAAwB;gBACA,OAAO;sBAA5C,YAAY;uBAAC,sBAAsB;gBACG,QAAQ;sBAA9C,YAAY;uBAAC,uBAAuB;gBAGrC,MAAM;sBADL,YAAY;uBAAC,qBAAqB;gBAMnC,IAAI;sBADH,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAIN,gBAAgB;sBADf,KAAK;gBAON,OAAO;sBADN,KAAK;gBAIN,KAAK;sBADJ,MAAM;gBAIP,MAAM;sBADL,MAAM;gBAQiC,MAAM;sBAA7C,SAAS;uBAAC,SAAS,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAEtC,UAAU;sBADT,SAAS;uBAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAIhD,EAAE;sBADD,KAAK;gBAIN,IAAI;sBADH,KAAK","sourcesContent":["import {\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  Input,\n  AfterViewInit,\n  OnDestroy,\n  QueryList,\n  OnInit,\n  Inject,\n  isDevMode,\n  EventEmitter,\n  Output,\n  ViewChild,\n} from '@angular/core';\n\nimport { LayoutRouteComponent } from '../layout-route/layout-route.component';\nimport { TranslateService } from '@ngx-translate/core';\nimport { LayoutContentComponent } from '../layout-content/layout-content.component';\nimport { Subject, takeUntil } from 'rxjs';\nimport { LayoutTitleComponent } from '../layout-title/layout-title.component';\n\nimport { Environment } from '../../enums/environment.enum';\nimport {\n  BreakpointObserver,\n  Breakpoints,\n  BreakpointState,\n} from '@angular/cdk/layout';\nimport { DOCUMENT } from '@angular/common';\nimport { LayoutFooterComponent } from '../layout-footer/layout-footer.component';\nimport { OnemRvaProfile } from '../../models/onemrva-profile.model';\nimport { LayoutLoginMenuComponent } from '../layout-login-menu/layout-login-menu.component';\nimport { MatDrawer } from '@angular/material/sidenav';\nimport { DrawerHostDirective } from '../../directives/drawer-host.directive';\nimport { OnemrvaDrawerService } from '../../services/drawer.service';\nimport { LayoutSidenavComponent } from '../layout-sidenav/layout-sidenav.component';\nimport { LayoutAfterNavComponent } from '../layout-after-nav/layout-after-nav.component';\nimport { OnemRvaLanguage } from '../../models/onem-language.model';\n\n@Component({\n  selector: 'onemrva-layout',\n  templateUrl: './layout.component.html',\n  styleUrls: ['./layout.component.scss'],\n})\nexport class LayoutComponent implements OnInit, AfterViewInit, OnDestroy {\n  @ContentChildren(LayoutRouteComponent)\n  routes?: QueryList<LayoutRouteComponent>;\n\n  @ContentChild(LayoutTitleComponent) title?: LayoutTitleComponent;\n  @ContentChild(LayoutLoginMenuComponent) loginMenu?: LayoutLoginMenuComponent;\n  @ContentChild(LayoutContentComponent) content?: LayoutContentComponent;\n  @ContentChild(LayoutAfterNavComponent) afterNav?: LayoutAfterNavComponent;\n\n  @ContentChild(LayoutFooterComponent)\n  footer?: LayoutFooterComponent;\n\n  fluid: boolean = false;\n\n  @Input()\n  logo: string = ''; // custom logo, empty string will show default onem/rva/neo/lfa localised logo\n\n  @Input()\n  languages: OnemRvaLanguage[] = []; // list of languages\n\n  @Input()\n  environment?: Environment; // possible environment to show on the frontend LOCAL, TEST, VAL, PROD\n\n  @Input()\n  logoRedictionUrl?: string | any[] | null = ''; // value for routerLink from logo. \"\" by default. Deactivated when set to null\n\n  selectedIndex = 0;\n  destroyNotifier$: Subject<void> = new Subject();\n\n  @Input()\n  profile: OnemRvaProfile | null = null; // To be defined for application with authentication\n\n  @Output()\n  login: EventEmitter<void> = new EventEmitter<void>();\n\n  @Output()\n  logout: EventEmitter<void> = new EventEmitter<void>();\n  //    isLogoutUsed: boolean = false;\n\n  env = Environment;\n\n  isSmall = true;\n\n  @ViewChild(MatDrawer, { static: true }) drawer!: MatDrawer;\n  @ViewChild(DrawerHostDirective, { static: true })\n  drawerHost!: DrawerHostDirective;\n\n  @Input()\n  id: string = 'main';\n\n  @Input()\n  role: string = 'main';\n\n  constructor(\n    private translateService: TranslateService,\n    private cd: ChangeDetectorRef,\n    public breakpointObserver: BreakpointObserver,\n    @Inject(DOCUMENT) private document: Document,\n    public drawerService: OnemrvaDrawerService,\n  ) {\n    if (this.languages.length === 0) {\n      this.translateService.getLangs().forEach(value => {\n        this.languages.push({\n          code: value,\n          label: value.toUpperCase(),\n        } as OnemRvaLanguage);\n      });\n    }\n  }\n\n  ngOnInit() {\n    this.selectedIndex = this.languages.findIndex(\n      l => l.code === this.translateService.currentLang,\n    );\n\n    this.document.documentElement.lang = this.translateService.currentLang;\n\n    this.breakpointObserver\n      .observe([Breakpoints.XSmall, Breakpoints.Small])\n      .pipe(takeUntil(this.destroyNotifier$))\n      .subscribe((state: BreakpointState) => {\n        if (state.matches) {\n          this.isSmall = true;\n        } else {\n          this.drawerService.close();\n          this.isSmall = false;\n        }\n      });\n\n    if (this.logo === '') {\n      this.logo = `https://cdn.services.rvaonem.fgov.be/img/logo/logo_${this.translateService.currentLang?.toLocaleLowerCase()}.svg`;\n\n      this.translateService.onLangChange\n        .pipe(takeUntil(this.destroyNotifier$))\n        .subscribe(lang => {\n          this.logo = `https://cdn.services.rvaonem.fgov.be/img/logo/logo_${lang.lang?.toLocaleLowerCase()}.svg`;\n        });\n    }\n    this.translateService.onLangChange\n      .pipe(takeUntil(this.destroyNotifier$))\n      .subscribe(event => {\n        this.selectedIndex = this.languages.findIndex(\n          lang => lang.code === event.lang,\n        );\n      });\n\n    this.drawerService.host = this.drawerHost;\n    this.drawerService.drawer = this.drawer;\n  }\n\n  get currentLanguage() {\n    return this.translateService.currentLang || '';\n  }\n\n  ngAfterViewInit() {\n    if (isDevMode()) {\n      this.cd.detectChanges();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n  }\n\n  doLogout() {\n    this.logout.next();\n  }\n\n  doLogin() {\n    this.login.next();\n  }\n\n  changeLanguage(langCode: string) {\n    this.translateService.use(langCode);\n    this.document.documentElement.lang = langCode;\n  }\n\n  toggleSideNav() {\n    this.drawerHost.viewContainerRef.clear();\n    const componentRef = this.drawerHost.viewContainerRef.createComponent(\n      LayoutSidenavComponent,\n    );\n    componentRef.instance.isSmall = this.isSmall;\n    componentRef.instance.languages = this.languages;\n    componentRef.instance.routes = this.routes;\n    this.drawerService.hasBackdrop = false;\n\n    this.drawer.open();\n  }\n}\n","<mat-drawer-container\n  class=\"example-container\"\n  [hasBackdrop]=\"drawerService.hasBackdrop\"\n  autosize\n>\n  <div class=\"app-content\">\n    <header>\n      <mat-toolbar class=\"mat-elevation-z4\">\n        <div class=\"environment\" [class]=\"environment\">\n          {{ environment }}\n        </div>\n        <div\n          [class.onemrva-layout-container]=\"!fluid\"\n          class=\"nav-container flex-center\"\n        >\n          {{ logoRedictionUrl }}\n          <img\n            class=\"logo\"\n            [src]=\"logo\"\n            [attr.data-cy]=\"\n              'onemrva_logo_' + currentLanguage.toLocaleLowerCase()\n            \"\n            alt=\"Logo ONEM/RVA\"\n            [routerLink]=\"\n              logoRedictionUrl !== null ? logoRedictionUrl : undefined\n            \"\n            [ngStyle]=\"{\n              cursor: logoRedictionUrl !== null ? 'pointer' : 'default',\n            }\"\n          />\n          <div\n            class=\"application-title\"\n            [ngClass]=\"{ 'small-screen': isSmall }\"\n          >\n            <ng-container *ngIf=\"title?.template as titleTpl\">\n              <ng-container *ngTemplateOutlet=\"titleTpl\"></ng-container>\n            </ng-container>\n          </div>\n\n          <div style=\"flex: 1\"></div>\n          <div\n            class=\"flex-center\"\n            mat-tab-nav-bar\n            [tabPanel]=\"tabPanel\"\n            *ngIf=\"!isSmall\"\n          >\n            <ng-container *ngFor=\"let e of routes?.toArray(); let i = index\">\n              <a\n                mat-tab-link\n                [routerLink]=\"e.routerLink\"\n                [routerLinkActiveOptions]=\"{ exact: !e.hasSubroutes() }\"\n                #rla=\"routerLinkActive\"\n                routerLinkActive=\"mdc-tab--active\"\n                [active]=\"rla.isActive || e.isRouteActive()\"\n              >\n                <ng-container *ngIf=\"e.template as routeTemplate\">\n                  <ng-container *ngTemplateOutlet=\"routeTemplate\">\n                  </ng-container>\n                </ng-container>\n              </a>\n            </ng-container>\n          </div>\n\n          <mat-tab-nav-panel #tabPanel></mat-tab-nav-panel>\n\n          <ng-container *ngIf=\"afterNav?.template as tpl\">\n            <ng-container *ngTemplateOutlet=\"tpl\"></ng-container>\n          </ng-container>\n\n          <ng-container *ngIf=\"profile !== null\">\n            <mat-divider\n              vertical\n              style=\"height: 1em; align-self: center\"\n              *ngIf=\"!isSmall\"\n            ></mat-divider>\n            <onemrva-mat-avatar\n              matRipple\n              *ngIf=\"profile.isLoggedIn\"\n              [matMenuTriggerFor]=\"menu\"\n              initials=\"{{ profile.initials() }}\"\n              color=\"accent\"\n              size=\"extrasmall\"\n              class=\"clickable\"\n            ></onemrva-mat-avatar>\n\n            <onemrva-mat-avatar\n              matRipple\n              *ngIf=\"!profile.isLoggedIn\"\n              [matMenuTriggerFor]=\"menu\"\n              icon=\"account_circle\"\n              color=\"\"\n              size=\"extrasmall\"\n              class=\"clickable\"\n            ></onemrva-mat-avatar>\n            <mat-menu #menu=\"matMenu\">\n              <ng-container *ngIf=\"profile.isLoggedIn; else notConnected\">\n                <p class=\"accountName\">\n                  {{ profile.firstName }} {{ profile.lastName }}\n                </p>\n                <mat-divider style=\"align-self: stretch\"></mat-divider>\n\n                <ng-container *ngIf=\"loginMenu?.template as menuLoginTpl\">\n                  <ng-container *ngTemplateOutlet=\"menuLoginTpl\"></ng-container>\n                </ng-container>\n\n                <button\n                  type=\"button\"\n                  class=\"mat-mdc-menu-item\"\n                  mat-menu-item\n                  data-cy=\"logoutButton\"\n                  (click)=\"doLogout()\"\n                  [attr.aria-label]=\"'layout.logout' | translate\"\n                >\n                  <mat-icon>logout</mat-icon>\n                  {{ 'layout.logout' | translate }}\n                </button>\n              </ng-container>\n              <ng-template #notConnected>\n                <button\n                  type=\"button\"\n                  mat-menu-item\n                  data-cy=\"loginButton\"\n                  (click)=\"doLogin()\"\n                  [attr.aria-label]=\"'layout.login' | translate\"\n                >\n                  <mat-icon>login</mat-icon>\n                  {{ 'layout.login' | translate }}\n                </button>\n              </ng-template>\n            </mat-menu>\n          </ng-container>\n          <ng-container\n            *ngIf=\"\n              isSmall &&\n              (routes?.toArray()?.length || (languages && languages.length > 1))\n            \"\n          >\n            <button\n              type=\"button\"\n              mat-icon-button\n              class=\"menu-button\"\n              data-cy=\"smallDeviceMenu\"\n              (click)=\"toggleSideNav()\"\n              [attr.aria-label]=\"'layout.menu' | translate\"\n            >\n              <mat-icon>menu</mat-icon>\n            </button>\n          </ng-container>\n          <div\n            class=\"flex-center\"\n            mat-tab-nav-bar\n            [tabPanel]=\"tabPanel\"\n            *ngIf=\"!isSmall\"\n          >\n            <a\n              [matMenuTriggerFor]=\"languageMenu\"\n              data-cy=\"languageMenu\"\n              [attr.aria-label]=\"'language.selection' | translate\"\n              mat-tab-link\n            >\n              {{ currentLanguage }}\n              <mat-icon style=\"width: 16px\">expand_more</mat-icon>\n            </a>\n          </div>\n          <mat-menu #languageMenu>\n            <button\n              *ngFor=\"let lang of languages\"\n              type=\"button\"\n              class=\"mat-mdc-menu-item\"\n              mat-menu-item\n              [attr.data-cy]=\"'language_' + lang.code\"\n              (click)=\"changeLanguage(lang.code)\"\n              [attr.aria-label]=\"lang.label\"\n            >\n              {{ lang.label }}\n            </button>\n          </mat-menu>\n        </div>\n      </mat-toolbar>\n    </header>\n    <ng-container>\n      <div\n        [id]=\"id\"\n        [attr.role]=\"role\"\n        [class.onemrva-layout-container]=\"!fluid\"\n        class=\"onemrva-layout-content\"\n        *ngIf=\"content?.template as tpl\"\n      >\n        <ng-container *ngTemplateOutlet=\"tpl\"></ng-container>\n\n        <ng-container\n          *ngIf=\"\n            environment &&\n            (environment === env.LOCAL || environment === env.TEST)\n          \"\n        >\n          <button\n            id=\"accessibility_fab\"\n            mat-fab\n            color=\"accent\"\n            aria-label=\"Accessibility check\"\n            matTooltip=\"Accessibility check\"\n            onclick=\"(function() {var _p='//openfed.github.io/AccessibilityCheck/build/';var _i=function(s,cb) {var sc=document.createElement('script');sc.onload = function() {sc.onload = null;sc.onreadystatechange = null;cb.call(this);};sc.onreadystatechange = function(){if(/^(complete|loaded)$/.test(this.readyState) === true){sc.onreadystatechange = null;sc.onload();}};sc.src=s;if (document.head) {document.head.appendChild(sc);} else {document.getElementsByTagName('head')[0].appendChild(sc);}}; var options={path:_p};_i(_p+'HTMLCS.js',function(){HTMLCSAuditor.run('WCAG2AA',null,options);});})();\"\n          >\n            <mat-icon>accessibility</mat-icon>\n          </button>\n        </ng-container>\n      </div>\n\n      <footer class=\"onemrva-footer\" *ngIf=\"footer?.template as footer\">\n        <div [class.onemrva-layout-container]=\"!fluid\">\n          <ng-container *ngTemplateOutlet=\"footer\"></ng-container>\n        </div>\n      </footer>\n    </ng-container>\n  </div>\n\n  <mat-drawer\n    class=\"onemrva-drawer mobile-menu-sidebar\"\n    mode=\"over\"\n    position=\"end\"\n  >\n    <ng-template drawerhost></ng-template>\n  </mat-drawer>\n</mat-drawer-container>\n"]}
@@ -55,7 +55,7 @@ export class OnemrvaMatInputCountryComponent {
55
55
  }
56
56
  return 'input.country.unknown.error';
57
57
  }
58
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: OnemrvaMatInputCountryComponent, deps: [{ token: i1.OnemRvaCDNService }], target: i0.ɵɵFactoryTarget.Component }); }
58
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: OnemrvaMatInputCountryComponent, deps: [{ token: i1.OnemRvaCDNCountryService }], target: i0.ɵɵFactoryTarget.Component }); }
59
59
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.5", type: OnemrvaMatInputCountryComponent, isStandalone: true, selector: "onemrva-mat-input-country", inputs: { readonly: "readonly", country: "country", label: "label", noEntriesFoundLabel: "noEntriesFoundLabel", hint: "hint", placeholderLabel: "placeholderLabel", searchAriaLabel: "searchAriaLabel" }, outputs: { getCountry: "getCountry" }, ngImport: i0, template: "<mat-form-field class=\"onemrva-input-country\">\n <mat-label>{{ label }}</mat-label>\n <mat-select class=\"onemrva-country-select\" [formControl]=\"country\">\n <mat-select-trigger>\n <flag-icon [countryCode]=\"country.getRawValue()\" />&nbsp;&nbsp;{{\n (selectedCountry$ | async)?.name\n }}\n </mat-select-trigger>\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n <mat-option\n *ngFor=\"let country of filteredCountries$ | async\"\n [value]=\"country.code\"\n ><span class=\"country\">\n <flag-icon [countryCode]=\"country.code\" />&nbsp;&nbsp;{{ country.name }}\n </span>\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n <mat-error *ngIf=\"country.invalid\">{{ errors() | translate }}</mat-error>\n</mat-form-field>\n", styles: ["mat-option.mdc-list-item .country{position:relative;display:block;padding-top:4px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatInputModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatSelectSearchModule }, { kind: "component", type: i6.MatSelectSearchComponent, selector: "mat-select-search", inputs: ["placeholderLabel", "type", "closeIcon", "closeSvgIcon", "noEntriesFoundLabel", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toggleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }, { kind: "component", type: FlagIconComponent, selector: "flag-icon", inputs: ["countryCode", "mode", "width"] }], encapsulation: i0.ViewEncapsulation.None }); }
60
60
  }
61
61
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: OnemrvaMatInputCountryComponent, decorators: [{
@@ -70,7 +70,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
70
70
  TranslateModule,
71
71
  FlagIconComponent,
72
72
  ], encapsulation: ViewEncapsulation.None, template: "<mat-form-field class=\"onemrva-input-country\">\n <mat-label>{{ label }}</mat-label>\n <mat-select class=\"onemrva-country-select\" [formControl]=\"country\">\n <mat-select-trigger>\n <flag-icon [countryCode]=\"country.getRawValue()\" />&nbsp;&nbsp;{{\n (selectedCountry$ | async)?.name\n }}\n </mat-select-trigger>\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n <mat-option\n *ngFor=\"let country of filteredCountries$ | async\"\n [value]=\"country.code\"\n ><span class=\"country\">\n <flag-icon [countryCode]=\"country.code\" />&nbsp;&nbsp;{{ country.name }}\n </span>\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n <mat-error *ngIf=\"country.invalid\">{{ errors() | translate }}</mat-error>\n</mat-form-field>\n", styles: ["mat-option.mdc-list-item .country{position:relative;display:block;padding-top:4px}\n"] }]
73
- }], ctorParameters: () => [{ type: i1.OnemRvaCDNService }], propDecorators: { readonly: [{
73
+ }], ctorParameters: () => [{ type: i1.OnemRvaCDNCountryService }], propDecorators: { readonly: [{
74
74
  type: Input
75
75
  }], country: [{
76
76
  type: Input
@@ -87,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
87
87
  }], getCountry: [{
88
88
  type: Output
89
89
  }] } });
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-input-country.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-input-country/src/onemrva-mat-input-country.component.ts","../../../../../../projects/onemrva/design-system/mat-input-country/src/onemrva-mat-input-country.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { TranslateModule } from '@ngx-translate/core';\nimport {\n  Observable,\n  map,\n  startWith,\n  debounceTime,\n  combineLatestWith,\n} from 'rxjs';\nimport { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';\nimport { FlagIconComponent } from '@onemrvapublic/design-system/flag-icon';\nimport {\n  OnemRvaCDNService,\n  OnemrvaMaterialCountry,\n} from '@onemrvapublic/design-system/shared';\n\n@Component({\n  selector: 'onemrva-mat-input-country',\n  styleUrls: ['onemrva-mat-input-country.component.scss'],\n  templateUrl: 'onemrva-mat-input-country.component.html',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatSelectSearchModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    FlagIconComponent,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class OnemrvaMatInputCountryComponent implements OnInit {\n  @Input()\n  readonly: boolean = false;\n\n  @Input() country!: FormControl;\n\n  @Input() label: string = 'Country';\n  @Input() noEntriesFoundLabel = 'Not found';\n  @Input() hint: string = '';\n  @Input() placeholderLabel = 'Search';\n  @Input() searchAriaLabel = '';\n  @Output() getCountry = new EventEmitter<any>();\n\n  public filterCtrl: FormControl<string | null> = new FormControl<string>('');\n\n  public countries$: Observable<OnemrvaMaterialCountry[]>;\n  public filteredCountries$: Observable<OnemrvaMaterialCountry[]>;\n  public selectedCountry$?: Observable<OnemrvaMaterialCountry | undefined>;\n\n  constructor(private cdn: OnemRvaCDNService) {\n    this.countries$ = this.cdn.getCountries();\n\n    this.filteredCountries$ = this.filterCtrl.valueChanges.pipe(\n      debounceTime(400),\n      startWith(''),\n      combineLatestWith(this.countries$),\n      map(([search, countries]) => {\n        return countries.filter((country: OnemrvaMaterialCountry) => {\n          if (!search || search === '') return countries;\n          if (country.name === undefined) return false;\n          return country.name.toLowerCase().indexOf(search.toLowerCase()) > -1;\n        });\n      }),\n    );\n  }\n\n  ngOnInit(): void {\n    this.selectedCountry$ = this.country.valueChanges.pipe(\n      startWith(this.country.getRawValue()),\n      combineLatestWith(this.countries$),\n      map(([value, countries]) => {\n        return countries.find(\n          (country: OnemrvaMaterialCountry) =>\n            country.code === value?.substring(0, country.code.length),\n        );\n      }),\n    );\n  }\n\n  handleClick(e: any) {\n    e.stopPropagation();\n  }\n\n  public errors() {\n    for (const k in this.country.errors) {\n      if (k === 'required') {\n        return 'input.country.required';\n      }\n    }\n    return 'input.country.unknown.error';\n  }\n}\n","<mat-form-field class=\"onemrva-input-country\">\n  <mat-label>{{ label }}</mat-label>\n  <mat-select class=\"onemrva-country-select\" [formControl]=\"country\">\n    <mat-select-trigger>\n      <flag-icon [countryCode]=\"country.getRawValue()\" />&nbsp;&nbsp;{{\n        (selectedCountry$ | async)?.name\n      }}\n    </mat-select-trigger>\n    <mat-option>\n      <mat-select-search\n        [formControl]=\"filterCtrl\"\n        [ariaLabel]=\"searchAriaLabel\"\n        [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n        [placeholderLabel]=\"placeholderLabel\"\n      ></mat-select-search>\n    </mat-option>\n    <mat-option\n      *ngFor=\"let country of filteredCountries$ | async\"\n      [value]=\"country.code\"\n      ><span class=\"country\">\n        <flag-icon [countryCode]=\"country.code\" />&nbsp;&nbsp;{{ country.name }}\n      </span>\n    </mat-option>\n  </mat-select>\n  <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n  <mat-error *ngIf=\"country.invalid\">{{ errors() | translate }}</mat-error>\n</mat-form-field>\n"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-input-country.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-input-country/src/onemrva-mat-input-country.component.ts","../../../../../../projects/onemrva/design-system/mat-input-country/src/onemrva-mat-input-country.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { TranslateModule } from '@ngx-translate/core';\nimport {\n  Observable,\n  map,\n  startWith,\n  debounceTime,\n  combineLatestWith,\n} from 'rxjs';\nimport { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';\nimport { FlagIconComponent } from '@onemrvapublic/design-system/flag-icon';\nimport {\n  OnemRvaCDNCountryService,\n  OnemrvaMaterialCountry,\n} from '@onemrvapublic/design-system/shared';\n\n@Component({\n  selector: 'onemrva-mat-input-country',\n  styleUrls: ['onemrva-mat-input-country.component.scss'],\n  templateUrl: 'onemrva-mat-input-country.component.html',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatSelectSearchModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    FlagIconComponent,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class OnemrvaMatInputCountryComponent implements OnInit {\n  @Input()\n  readonly: boolean = false;\n\n  @Input() country!: FormControl;\n\n  @Input() label: string = 'Country';\n  @Input() noEntriesFoundLabel = 'Not found';\n  @Input() hint: string = '';\n  @Input() placeholderLabel = 'Search';\n  @Input() searchAriaLabel = '';\n  @Output() getCountry = new EventEmitter<any>();\n\n  public filterCtrl: FormControl<string | null> = new FormControl<string>('');\n\n  public countries$: Observable<OnemrvaMaterialCountry[]>;\n  public filteredCountries$: Observable<OnemrvaMaterialCountry[]>;\n  public selectedCountry$?: Observable<OnemrvaMaterialCountry | undefined>;\n\n  constructor(private cdn: OnemRvaCDNCountryService) {\n    this.countries$ = this.cdn.getCountries();\n\n    this.filteredCountries$ = this.filterCtrl.valueChanges.pipe(\n      debounceTime(400),\n      startWith(''),\n      combineLatestWith(this.countries$),\n      map(([search, countries]) => {\n        return countries.filter((country: OnemrvaMaterialCountry) => {\n          if (!search || search === '') return countries;\n          if (country.name === undefined) return false;\n          return country.name.toLowerCase().indexOf(search.toLowerCase()) > -1;\n        });\n      }),\n    );\n  }\n\n  ngOnInit(): void {\n    this.selectedCountry$ = this.country.valueChanges.pipe(\n      startWith(this.country.getRawValue()),\n      combineLatestWith(this.countries$),\n      map(([value, countries]) => {\n        return countries.find(\n          (country: OnemrvaMaterialCountry) =>\n            country.code === value?.substring(0, country.code.length),\n        );\n      }),\n    );\n  }\n\n  handleClick(e: any) {\n    e.stopPropagation();\n  }\n\n  public errors() {\n    for (const k in this.country.errors) {\n      if (k === 'required') {\n        return 'input.country.required';\n      }\n    }\n    return 'input.country.unknown.error';\n  }\n}\n","<mat-form-field class=\"onemrva-input-country\">\n  <mat-label>{{ label }}</mat-label>\n  <mat-select class=\"onemrva-country-select\" [formControl]=\"country\">\n    <mat-select-trigger>\n      <flag-icon [countryCode]=\"country.getRawValue()\" />&nbsp;&nbsp;{{\n        (selectedCountry$ | async)?.name\n      }}\n    </mat-select-trigger>\n    <mat-option>\n      <mat-select-search\n        [formControl]=\"filterCtrl\"\n        [ariaLabel]=\"searchAriaLabel\"\n        [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n        [placeholderLabel]=\"placeholderLabel\"\n      ></mat-select-search>\n    </mat-option>\n    <mat-option\n      *ngFor=\"let country of filteredCountries$ | async\"\n      [value]=\"country.code\"\n      ><span class=\"country\">\n        <flag-icon [countryCode]=\"country.code\" />&nbsp;&nbsp;{{ country.name }}\n      </span>\n    </mat-option>\n  </mat-select>\n  <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n  <mat-error *ngIf=\"country.invalid\">{{ errors() | translate }}</mat-error>\n</mat-form-field>\n"]}
@@ -138,7 +138,7 @@ export class OnemrvaMatInputEnterpriseNumberComponent {
138
138
  }
139
139
  return 'input.vies.unknown.error';
140
140
  }
141
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: OnemrvaMatInputEnterpriseNumberComponent, deps: [{ token: i1.OnemRvaCDNService }], target: i0.ɵɵFactoryTarget.Component }); }
141
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: OnemrvaMatInputEnterpriseNumberComponent, deps: [{ token: i1.OnemRvaCDNCountryService }], target: i0.ɵɵFactoryTarget.Component }); }
142
142
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.5", type: OnemrvaMatInputEnterpriseNumberComponent, isStandalone: true, selector: "onemrva-mat-input-enterprise-number", inputs: { readonly: "readonly", enterpriseNumber: "enterpriseNumber", label: "label", noEntriesFoundLabel: "noEntriesFoundLabel", placeholderLabel: "placeholderLabel", defaultCountry: "defaultCountry", searchAriaLabel: "searchAriaLabel", hint: "hint" }, outputs: { getCountry: "getCountry" }, viewQueries: [{ propertyName: "numberInput", first: true, predicate: ["numberInput"], descendants: true }], ngImport: i0, template: "<ng-container>\n <mat-form-field class=\"onemrva-input-enterprise-number\">\n <mat-label>{{ label }}</mat-label>\n <input\n (click)=\"handleClick($event)\"\n type=\"text\"\n matInput\n #numberInput\n placeholder=\"\"\n [formControl]=\"enterpriseNumber\"\n class=\"onemrva-text-enterprise-number\"\n [mask]=\"mask$ | async\"\n />\n <mat-select\n matTextPrefix\n class=\"onemrva-phone-number-select\"\n [formControl]=\"countryCode\"\n >\n <mat-select-trigger>\n <flag-icon [countryCode]=\"countryCode.getRawValue()\" />\n </mat-select-trigger>\n\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n\n <mat-option\n *ngFor=\"let country of filteredCountries$ | async\"\n [value]=\"country.code\"\n >\n <flag-icon [countryCode]=\"country.code\" />&nbsp;&nbsp;{{ country.name }}\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n <mat-error *ngIf=\"number.invalid\">{{ errors() | translate }}</mat-error>\n </mat-form-field>\n</ng-container>\n", styles: [".onemrva-input-enterprise-number mat-select{padding:0 0 0 8px}.onemrva-input-enterprise-number mat-select .mat-mdc-select-placeholder{width:1em!important;display:block!important}.onemrva-input-enterprise-number mat-select .mat-mdc-select-placeholder:before{width:1em!important;height:1em!important;background:#eee!important;visibility:visible!important;margin:10px 0!important}.onemrva-input-enterprise-number mat-select .mat-mdc-select-value{padding-right:8px}.onemrva-input-enterprise-number .onemrva-text-enterprise-number{padding-left:12px!important;vertical-align:middle}.onemrva-input-enterprise-number .mat-mdc-form-field-text-prefix mat-select{line-height:14px!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i5.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }, { kind: "component", type: FlagIconComponent, selector: "flag-icon", inputs: ["countryCode", "mode", "width"] }, { kind: "directive", type: NgxMaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "leadZero", "triggerOnMaskChange", "apm", "inputTransformFn", "outputTransformFn", "keepCharacterPositions"], outputs: ["maskFilled"], exportAs: ["mask", "ngxMask"] }, { kind: "ngmodule", type: MatSelectSearchModule }, { kind: "component", type: i9.MatSelectSearchComponent, selector: "mat-select-search", inputs: ["placeholderLabel", "type", "closeIcon", "closeSvgIcon", "noEntriesFoundLabel", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toggleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }], encapsulation: i0.ViewEncapsulation.None }); }
143
143
  }
144
144
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: OnemrvaMatInputEnterpriseNumberComponent, decorators: [{
@@ -154,7 +154,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
154
154
  NgxMaskDirective,
155
155
  MatSelectSearchModule,
156
156
  ], encapsulation: ViewEncapsulation.None, template: "<ng-container>\n <mat-form-field class=\"onemrva-input-enterprise-number\">\n <mat-label>{{ label }}</mat-label>\n <input\n (click)=\"handleClick($event)\"\n type=\"text\"\n matInput\n #numberInput\n placeholder=\"\"\n [formControl]=\"enterpriseNumber\"\n class=\"onemrva-text-enterprise-number\"\n [mask]=\"mask$ | async\"\n />\n <mat-select\n matTextPrefix\n class=\"onemrva-phone-number-select\"\n [formControl]=\"countryCode\"\n >\n <mat-select-trigger>\n <flag-icon [countryCode]=\"countryCode.getRawValue()\" />\n </mat-select-trigger>\n\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n\n <mat-option\n *ngFor=\"let country of filteredCountries$ | async\"\n [value]=\"country.code\"\n >\n <flag-icon [countryCode]=\"country.code\" />&nbsp;&nbsp;{{ country.name }}\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n <mat-error *ngIf=\"number.invalid\">{{ errors() | translate }}</mat-error>\n </mat-form-field>\n</ng-container>\n", styles: [".onemrva-input-enterprise-number mat-select{padding:0 0 0 8px}.onemrva-input-enterprise-number mat-select .mat-mdc-select-placeholder{width:1em!important;display:block!important}.onemrva-input-enterprise-number mat-select .mat-mdc-select-placeholder:before{width:1em!important;height:1em!important;background:#eee!important;visibility:visible!important;margin:10px 0!important}.onemrva-input-enterprise-number mat-select .mat-mdc-select-value{padding-right:8px}.onemrva-input-enterprise-number .onemrva-text-enterprise-number{padding-left:12px!important;vertical-align:middle}.onemrva-input-enterprise-number .mat-mdc-form-field-text-prefix mat-select{line-height:14px!important}\n"] }]
157
- }], ctorParameters: () => [{ type: i1.OnemRvaCDNService }], propDecorators: { readonly: [{
157
+ }], ctorParameters: () => [{ type: i1.OnemRvaCDNCountryService }], propDecorators: { readonly: [{
158
158
  type: Input
159
159
  }], enterpriseNumber: [{
160
160
  type: Input
@@ -176,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
176
176
  type: ViewChild,
177
177
  args: ['numberInput']
178
178
  }] } });
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-input-enterprise-number.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-input-enterprise-number/src/onemrva-mat-input-enterprise-number.component.ts","../../../../../../projects/onemrva/design-system/mat-input-enterprise-number/src/onemrva-mat-input-enterprise-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControl, ReactiveFormsModule, Validators } from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { NgxMaskDirective } from 'ngx-mask';\nimport {\n  combineLatestWith,\n  debounceTime,\n  map,\n  Observable,\n  startWith,\n  Subject,\n  takeUntil,\n  zip,\n} from 'rxjs';\nimport { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';\nimport {\n  OnemRvaCDNService,\n  OnemrvaMaterialCountry,\n} from '@onemrvapublic/design-system/shared';\nimport { FlagIconComponent } from '@onemrvapublic/design-system/flag-icon';\n\n@Component({\n  selector: 'onemrva-mat-input-enterprise-number',\n  styleUrls: ['onemrva-mat-input-enterprise-number.component.scss'],\n  templateUrl: 'onemrva-mat-input-enterprise-number.component.html',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    FlagIconComponent,\n    NgxMaskDirective,\n    MatSelectSearchModule,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class OnemrvaMatInputEnterpriseNumberComponent\n  implements OnInit, OnDestroy\n{\n  @Input()\n  readonly: boolean = false;\n\n  @Input() enterpriseNumber!: FormControl;\n  @Input() label: string = 'VIES';\n  @Input() noEntriesFoundLabel = 'Not found';\n  @Input() placeholderLabel = 'Search';\n  @Input() defaultCountry: string = 'BE';\n  @Input() searchAriaLabel = '';\n  @Input() hint: string = '';\n  @Output() getCountry = new EventEmitter<any>();\n  @ViewChild('numberInput') numberInput!: ElementRef;\n\n  countryCode: FormControl = new FormControl('');\n\n  public filterCtrl: FormControl<string | null> = new FormControl<string>('');\n\n  destroyNotifier$: Subject<void> = new Subject();\n\n  mask$!: Observable<string | undefined>;\n\n  public countries$: Observable<OnemrvaMaterialCountry[]> =\n    this.cdn.getCountriesByZone('EU');\n  public filteredCountries$: Observable<OnemrvaMaterialCountry[]>;\n\n  constructor(private cdn: OnemRvaCDNService) {\n    this.filteredCountries$ = this.filterCtrl.valueChanges.pipe(\n      debounceTime(400),\n      startWith(''),\n      combineLatestWith(this.countries$),\n      map(([search, countries]) => {\n        return countries.filter((country: OnemrvaMaterialCountry) => {\n          if (!search || search === '') return countries;\n          if (country.name === undefined) return false;\n          return country.name.toLowerCase().indexOf(search.toLowerCase()) > -1;\n        });\n      }),\n    );\n  }\n\n  get number(): FormControl {\n    return this.enterpriseNumber as FormControl;\n  }\n\n  private setCode(country: OnemrvaMaterialCountry | null) {\n    this.clearValidators();\n    if (country) {\n      this.countryCode.setValue(country.code);\n      this.formatEnterpriseNumber(country);\n    }\n  }\n\n  ngOnInit(): void {\n    this.number.valueChanges\n      .pipe(\n        startWith(this.number.getRawValue()),\n        takeUntil(this.destroyNotifier$),\n      )\n      .subscribe(number => {\n        if (number === '0') {\n          this.cdn\n            .findCountryFromCode(this.defaultCountry)\n            .pipe(takeUntil(this.destroyNotifier$))\n            .subscribe(country => {\n              if (country) {\n                number = country.pattern.substring(0, 2) + number;\n                this.number.setValue(number, { emitEvent: false });\n                this.countryCode.setValue(country.code);\n              } else {\n                this.countryCode.setValue('');\n              }\n            });\n        } else {\n          if (number.length > 1) {\n            this.cdn\n              .findCountryFromVIESCode(number)\n              .pipe(takeUntil(this.destroyNotifier$))\n              .subscribe(country => {\n                if (country) {\n                  this.countryCode.setValue(country.code);\n                }\n              });\n          }\n        }\n      });\n\n    this.countryCode.valueChanges\n      .pipe(takeUntil(this.destroyNotifier$))\n      .subscribe(value => {\n        let number = this.number.getRawValue();\n        zip(\n          this.cdn.findCountryFromVIESCode(number),\n          this.cdn.findCountryFromCode(value),\n        ).subscribe(([countryFromVies, countryFromCode]) => {\n          if (countryFromVies) {\n            number = number.replace(\n              countryFromVies.pattern.substring(0, 2),\n              '',\n            );\n          }\n          if (countryFromCode) {\n            this.getCountry.next(countryFromCode);\n            number = countryFromCode.pattern.substring(0, 2) + number;\n            this.formatEnterpriseNumber(countryFromCode);\n          }\n          this.number.setValue(number, { emitEvent: false });\n          this.formatEnterpriseNumber(countryFromCode);\n        });\n      });\n  }\n\n  private clearValidators() {\n    let required = false;\n    if (this.number.hasValidator(Validators.required)) {\n      required = true;\n    }\n    this.number.clearValidators();\n    if (required) {\n      this.number.addValidators(Validators.required);\n    }\n  }\n\n  private formatEnterpriseNumber(country: OnemrvaMaterialCountry | undefined) {\n    this.clearValidators();\n    if (this.countryCode.getRawValue() !== '' && country) {\n      this.enterpriseNumber.addValidators(\n        Validators.pattern(new RegExp(country.pattern)),\n      );\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n  }\n\n  handleClick(e: any) {\n    e.stopPropagation();\n  }\n\n  errors() {\n    for (const k in this.number.errors) {\n      if (k === 'required') {\n        return 'input.vies.required';\n      } else {\n        return 'input.vies.invalid';\n      }\n    }\n    return 'input.vies.unknown.error';\n  }\n}\n","<ng-container>\n  <mat-form-field class=\"onemrva-input-enterprise-number\">\n    <mat-label>{{ label }}</mat-label>\n    <input\n      (click)=\"handleClick($event)\"\n      type=\"text\"\n      matInput\n      #numberInput\n      placeholder=\"\"\n      [formControl]=\"enterpriseNumber\"\n      class=\"onemrva-text-enterprise-number\"\n      [mask]=\"mask$ | async\"\n    />\n    <mat-select\n      matTextPrefix\n      class=\"onemrva-phone-number-select\"\n      [formControl]=\"countryCode\"\n    >\n      <mat-select-trigger>\n        <flag-icon [countryCode]=\"countryCode.getRawValue()\" />\n      </mat-select-trigger>\n\n      <mat-option>\n        <mat-select-search\n          [formControl]=\"filterCtrl\"\n          [ariaLabel]=\"searchAriaLabel\"\n          [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n          [placeholderLabel]=\"placeholderLabel\"\n        ></mat-select-search>\n      </mat-option>\n\n      <mat-option\n        *ngFor=\"let country of filteredCountries$ | async\"\n        [value]=\"country.code\"\n      >\n        <flag-icon [countryCode]=\"country.code\" />&nbsp;&nbsp;{{ country.name }}\n      </mat-option>\n    </mat-select>\n    <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n    <mat-error *ngIf=\"number.invalid\">{{ errors() | translate }}</mat-error>\n  </mat-form-field>\n</ng-container>\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-input-enterprise-number.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-input-enterprise-number/src/onemrva-mat-input-enterprise-number.component.ts","../../../../../../projects/onemrva/design-system/mat-input-enterprise-number/src/onemrva-mat-input-enterprise-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControl, ReactiveFormsModule, Validators } from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { NgxMaskDirective } from 'ngx-mask';\nimport {\n  combineLatestWith,\n  debounceTime,\n  map,\n  Observable,\n  startWith,\n  Subject,\n  takeUntil,\n  zip,\n} from 'rxjs';\nimport { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';\nimport {\n  OnemRvaCDNCountryService,\n  OnemrvaMaterialCountry,\n} from '@onemrvapublic/design-system/shared';\nimport { FlagIconComponent } from '@onemrvapublic/design-system/flag-icon';\n\n@Component({\n  selector: 'onemrva-mat-input-enterprise-number',\n  styleUrls: ['onemrva-mat-input-enterprise-number.component.scss'],\n  templateUrl: 'onemrva-mat-input-enterprise-number.component.html',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    FlagIconComponent,\n    NgxMaskDirective,\n    MatSelectSearchModule,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class OnemrvaMatInputEnterpriseNumberComponent\n  implements OnInit, OnDestroy\n{\n  @Input()\n  readonly: boolean = false;\n\n  @Input() enterpriseNumber!: FormControl;\n  @Input() label: string = 'VIES';\n  @Input() noEntriesFoundLabel = 'Not found';\n  @Input() placeholderLabel = 'Search';\n  @Input() defaultCountry: string = 'BE';\n  @Input() searchAriaLabel = '';\n  @Input() hint: string = '';\n  @Output() getCountry = new EventEmitter<any>();\n  @ViewChild('numberInput') numberInput!: ElementRef;\n\n  countryCode: FormControl = new FormControl('');\n\n  public filterCtrl: FormControl<string | null> = new FormControl<string>('');\n\n  destroyNotifier$: Subject<void> = new Subject();\n\n  mask$!: Observable<string | undefined>;\n\n  public countries$: Observable<OnemrvaMaterialCountry[]> =\n    this.cdn.getCountriesByZone('EU');\n  public filteredCountries$: Observable<OnemrvaMaterialCountry[]>;\n\n  constructor(private cdn: OnemRvaCDNCountryService) {\n    this.filteredCountries$ = this.filterCtrl.valueChanges.pipe(\n      debounceTime(400),\n      startWith(''),\n      combineLatestWith(this.countries$),\n      map(([search, countries]) => {\n        return countries.filter((country: OnemrvaMaterialCountry) => {\n          if (!search || search === '') return countries;\n          if (country.name === undefined) return false;\n          return country.name.toLowerCase().indexOf(search.toLowerCase()) > -1;\n        });\n      }),\n    );\n  }\n\n  get number(): FormControl {\n    return this.enterpriseNumber as FormControl;\n  }\n\n  private setCode(country: OnemrvaMaterialCountry | null) {\n    this.clearValidators();\n    if (country) {\n      this.countryCode.setValue(country.code);\n      this.formatEnterpriseNumber(country);\n    }\n  }\n\n  ngOnInit(): void {\n    this.number.valueChanges\n      .pipe(\n        startWith(this.number.getRawValue()),\n        takeUntil(this.destroyNotifier$),\n      )\n      .subscribe(number => {\n        if (number === '0') {\n          this.cdn\n            .findCountryFromCode(this.defaultCountry)\n            .pipe(takeUntil(this.destroyNotifier$))\n            .subscribe(country => {\n              if (country) {\n                number = country.pattern.substring(0, 2) + number;\n                this.number.setValue(number, { emitEvent: false });\n                this.countryCode.setValue(country.code);\n              } else {\n                this.countryCode.setValue('');\n              }\n            });\n        } else {\n          if (number.length > 1) {\n            this.cdn\n              .findCountryFromVIESCode(number)\n              .pipe(takeUntil(this.destroyNotifier$))\n              .subscribe(country => {\n                if (country) {\n                  this.countryCode.setValue(country.code);\n                }\n              });\n          }\n        }\n      });\n\n    this.countryCode.valueChanges\n      .pipe(takeUntil(this.destroyNotifier$))\n      .subscribe(value => {\n        let number = this.number.getRawValue();\n        zip(\n          this.cdn.findCountryFromVIESCode(number),\n          this.cdn.findCountryFromCode(value),\n        ).subscribe(([countryFromVies, countryFromCode]) => {\n          if (countryFromVies) {\n            number = number.replace(\n              countryFromVies.pattern.substring(0, 2),\n              '',\n            );\n          }\n          if (countryFromCode) {\n            this.getCountry.next(countryFromCode);\n            number = countryFromCode.pattern.substring(0, 2) + number;\n            this.formatEnterpriseNumber(countryFromCode);\n          }\n          this.number.setValue(number, { emitEvent: false });\n          this.formatEnterpriseNumber(countryFromCode);\n        });\n      });\n  }\n\n  private clearValidators() {\n    let required = false;\n    if (this.number.hasValidator(Validators.required)) {\n      required = true;\n    }\n    this.number.clearValidators();\n    if (required) {\n      this.number.addValidators(Validators.required);\n    }\n  }\n\n  private formatEnterpriseNumber(country: OnemrvaMaterialCountry | undefined) {\n    this.clearValidators();\n    if (this.countryCode.getRawValue() !== '' && country) {\n      this.enterpriseNumber.addValidators(\n        Validators.pattern(new RegExp(country.pattern)),\n      );\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n  }\n\n  handleClick(e: any) {\n    e.stopPropagation();\n  }\n\n  errors() {\n    for (const k in this.number.errors) {\n      if (k === 'required') {\n        return 'input.vies.required';\n      } else {\n        return 'input.vies.invalid';\n      }\n    }\n    return 'input.vies.unknown.error';\n  }\n}\n","<ng-container>\n  <mat-form-field class=\"onemrva-input-enterprise-number\">\n    <mat-label>{{ label }}</mat-label>\n    <input\n      (click)=\"handleClick($event)\"\n      type=\"text\"\n      matInput\n      #numberInput\n      placeholder=\"\"\n      [formControl]=\"enterpriseNumber\"\n      class=\"onemrva-text-enterprise-number\"\n      [mask]=\"mask$ | async\"\n    />\n    <mat-select\n      matTextPrefix\n      class=\"onemrva-phone-number-select\"\n      [formControl]=\"countryCode\"\n    >\n      <mat-select-trigger>\n        <flag-icon [countryCode]=\"countryCode.getRawValue()\" />\n      </mat-select-trigger>\n\n      <mat-option>\n        <mat-select-search\n          [formControl]=\"filterCtrl\"\n          [ariaLabel]=\"searchAriaLabel\"\n          [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n          [placeholderLabel]=\"placeholderLabel\"\n        ></mat-select-search>\n      </mat-option>\n\n      <mat-option\n        *ngFor=\"let country of filteredCountries$ | async\"\n        [value]=\"country.code\"\n      >\n        <flag-icon [countryCode]=\"country.code\" />&nbsp;&nbsp;{{ country.name }}\n      </mat-option>\n    </mat-select>\n    <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n    <mat-error *ngIf=\"number.invalid\">{{ errors() | translate }}</mat-error>\n  </mat-form-field>\n</ng-container>\n"]}
@@ -188,7 +188,7 @@ export class OnemrvaMatInputPhoneComponent {
188
188
  return { phoneNumber: { value: 'input.phone.invalid' } };
189
189
  };
190
190
  }
191
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: OnemrvaMatInputPhoneComponent, deps: [{ token: i1.OnemRvaCDNService }], target: i0.ɵɵFactoryTarget.Component }); }
191
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: OnemrvaMatInputPhoneComponent, deps: [{ token: i1.OnemRvaCDNCountryService }], target: i0.ɵɵFactoryTarget.Component }); }
192
192
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.5", type: OnemrvaMatInputPhoneComponent, isStandalone: true, selector: "onemrva-mat-input-phone", inputs: { readonly: "readonly", phoneNumber: "phoneNumber", label: "label", noEntriesFoundLabel: "noEntriesFoundLabel", placeholderLabel: "placeholderLabel", defaultPrefix: "defaultPrefix", searchAriaLabel: "searchAriaLabel", hint: "hint" }, outputs: { getCountry: "getCountry" }, viewQueries: [{ propertyName: "numberInput", first: true, predicate: ["numberInput"], descendants: true }], ngImport: i0, template: "<ng-container>\n <mat-form-field class=\"onemrva-input-phone-number\">\n <mat-label>{{ label }}</mat-label>\n\n <input\n (click)=\"handleClick($event)\"\n type=\"tel\"\n matInput\n phoneNumber\n #numberInput\n placeholder=\"+32 475 12 34 56\"\n [formControl]=\"phoneNumber\"\n class=\"onemrva-text-number\"\n [readOnly]=\"readonly\"\n />\n <mat-select\n matTextPrefix\n class=\"onemrva-phone-number-select\"\n [formControl]=\"countryCode\"\n >\n <mat-select-trigger>\n <flag-icon [countryCode]=\"countryCode.getRawValue()\" />\n </mat-select-trigger>\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n <mat-option\n *ngFor=\"let country of filteredCountries$ | async\"\n [value]=\"country.code\"\n >\n <flag-icon [countryCode]=\"country.code\" />\n &nbsp;&nbsp;&nbsp;\n {{ country.name }}\n &nbsp;&nbsp;&nbsp;\n <span class=\"dialcode\">\n {{ country.dial_code }}\n </span>\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n <mat-error *ngIf=\"number.invalid\">{{ errors() | translate }}</mat-error>\n </mat-form-field>\n</ng-container>\n", styles: [".onemrva-input-phone-number mat-select .mat-mdc-select-placeholder{width:1em!important;display:block!important}.onemrva-input-phone-number mat-select .mat-mdc-select-placeholder:before{width:1em!important;height:1em!important;background:#eee!important;visibility:visible!important;margin:10px 0!important}.onemrva-input-phone-number mat-select .mat-mdc-select-value{padding-right:8px}.onemrva-input-phone-number .onemrva-text-number{padding-left:12px!important;vertical-align:middle}.onemrva-input-phone-number .mat-mdc-form-field-text-prefix mat-select{line-height:14px!important}.onemrva-input-phone-number span.dialcode{color:#acaab2}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatPrefix, selector: "[matPrefix], [matIconPrefix], [matTextPrefix]", inputs: ["matTextPrefix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i5.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i6.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: MatSelectSearchModule }, { kind: "component", type: i7.MatSelectSearchComponent, selector: "mat-select-search", inputs: ["placeholderLabel", "type", "closeIcon", "closeSvgIcon", "noEntriesFoundLabel", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toggleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }, { kind: "directive", type: PhoneNumberDirective, selector: "[phoneNumber]" }, { kind: "component", type: FlagIconComponent, selector: "flag-icon", inputs: ["countryCode", "mode", "width"] }], encapsulation: i0.ViewEncapsulation.None }); }
193
193
  }
194
194
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: OnemrvaMatInputPhoneComponent, decorators: [{
@@ -204,7 +204,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
204
204
  PhoneNumberDirective,
205
205
  FlagIconComponent,
206
206
  ], encapsulation: ViewEncapsulation.None, template: "<ng-container>\n <mat-form-field class=\"onemrva-input-phone-number\">\n <mat-label>{{ label }}</mat-label>\n\n <input\n (click)=\"handleClick($event)\"\n type=\"tel\"\n matInput\n phoneNumber\n #numberInput\n placeholder=\"+32 475 12 34 56\"\n [formControl]=\"phoneNumber\"\n class=\"onemrva-text-number\"\n [readOnly]=\"readonly\"\n />\n <mat-select\n matTextPrefix\n class=\"onemrva-phone-number-select\"\n [formControl]=\"countryCode\"\n >\n <mat-select-trigger>\n <flag-icon [countryCode]=\"countryCode.getRawValue()\" />\n </mat-select-trigger>\n <mat-option>\n <mat-select-search\n [formControl]=\"filterCtrl\"\n [ariaLabel]=\"searchAriaLabel\"\n [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n [placeholderLabel]=\"placeholderLabel\"\n ></mat-select-search>\n </mat-option>\n <mat-option\n *ngFor=\"let country of filteredCountries$ | async\"\n [value]=\"country.code\"\n >\n <flag-icon [countryCode]=\"country.code\" />\n &nbsp;&nbsp;&nbsp;\n {{ country.name }}\n &nbsp;&nbsp;&nbsp;\n <span class=\"dialcode\">\n {{ country.dial_code }}\n </span>\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n <mat-error *ngIf=\"number.invalid\">{{ errors() | translate }}</mat-error>\n </mat-form-field>\n</ng-container>\n", styles: [".onemrva-input-phone-number mat-select .mat-mdc-select-placeholder{width:1em!important;display:block!important}.onemrva-input-phone-number mat-select .mat-mdc-select-placeholder:before{width:1em!important;height:1em!important;background:#eee!important;visibility:visible!important;margin:10px 0!important}.onemrva-input-phone-number mat-select .mat-mdc-select-value{padding-right:8px}.onemrva-input-phone-number .onemrva-text-number{padding-left:12px!important;vertical-align:middle}.onemrva-input-phone-number .mat-mdc-form-field-text-prefix mat-select{line-height:14px!important}.onemrva-input-phone-number span.dialcode{color:#acaab2}\n"] }]
207
- }], ctorParameters: () => [{ type: i1.OnemRvaCDNService }], propDecorators: { readonly: [{
207
+ }], ctorParameters: () => [{ type: i1.OnemRvaCDNCountryService }], propDecorators: { readonly: [{
208
208
  type: Input
209
209
  }], phoneNumber: [{
210
210
  type: Input
@@ -231,4 +231,4 @@ function genericValidator(message) {
231
231
  return { phoneNumber: { value: message } };
232
232
  };
233
233
  }
234
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-input-phone.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-input-phone/src/onemrva-mat-input-phone.component.ts","../../../../../../projects/onemrva/design-system/mat-input-phone/src/onemrva-mat-input-phone.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  ReactiveFormsModule,\n  ValidationErrors,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { TranslateModule } from '@ngx-translate/core';\nimport {\n  Observable,\n  Subject,\n  map,\n  startWith,\n  debounceTime,\n  takeUntil,\n  combineLatestWith,\n  zip,\n} from 'rxjs';\nimport { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';\nimport { PhoneNumberDirective } from './phone-number.directive';\nimport parsePhoneNumber from 'libphonenumber-js';\nimport { FlagIconComponent } from '@onemrvapublic/design-system/flag-icon';\nimport {\n  OnemRvaCDNService,\n  OnemrvaMaterialCountry,\n} from '@onemrvapublic/design-system/shared';\n\n@Component({\n  selector: 'onemrva-mat-input-phone',\n  styleUrls: ['onemrva-mat-input-phone.component.scss'],\n  templateUrl: 'onemrva-mat-input-phone.component.html',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatSelectSearchModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    PhoneNumberDirective,\n    FlagIconComponent,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class OnemrvaMatInputPhoneComponent implements OnInit, OnDestroy {\n  @Input()\n  readonly: boolean = false;\n\n  @Input() phoneNumber!: FormControl;\n  @Input() label: string = 'Phone number';\n  @Input() noEntriesFoundLabel = 'Not found';\n  @Input() placeholderLabel = 'Search';\n  @Input() defaultPrefix: string = '+32';\n  @Input() searchAriaLabel = '';\n  @Input() hint: string = '';\n  @Output() getCountry = new EventEmitter<any>();\n  @ViewChild('numberInput') numberInput!: ElementRef;\n\n  countryCode: FormControl = new FormControl('');\n\n  public filterCtrl: FormControl<string | null> = new FormControl<string>('');\n\n  destroyNotifier$: Subject<void> = new Subject();\n\n  public countries$: Observable<OnemrvaMaterialCountry[]> =\n    this.cdn.getCountries();\n  public filteredCountries$: Observable<OnemrvaMaterialCountry[]>;\n\n  constructor(private cdn: OnemRvaCDNService) {\n    this.filteredCountries$ = this.filterCtrl.valueChanges.pipe(\n      debounceTime(400),\n      startWith(''),\n      combineLatestWith(this.countries$),\n      map(([search, countries]) => {\n        return countries.filter((country: OnemrvaMaterialCountry) => {\n          if (!search || search === '') return countries;\n          if (country.name === undefined) return false;\n          return country.name.toLowerCase().indexOf(search.toLowerCase()) > -1;\n        });\n      }),\n    );\n  }\n\n  get number(): FormControl {\n    return this.phoneNumber as FormControl;\n  }\n\n  ngOnInit(): void {\n    this.number.valueChanges\n      .pipe(\n        startWith(this.number.getRawValue()),\n        takeUntil(this.destroyNotifier$),\n      )\n      .subscribe(number => {\n        if (number !== '') {\n          if (number.substring(0, 1) !== '+')\n            this.countryCode.setValue('', { emitEvent: false });\n          if (number === '0') {\n            this.cdn\n              .findCountryFromPrefix(this.defaultPrefix)\n              .pipe(takeUntil(this.destroyNotifier$))\n              .subscribe(country => {\n                if (country) {\n                  //this.getCountry.next(country);\n                  this.number.setValue(this.defaultPrefix, {\n                    emitEvent: false,\n                  });\n                  this.countryCode.setValue(country.code, { emitEvent: false });\n                } else {\n                  this.countryCode.setValue('');\n                }\n                this.formatPhoneNumber();\n              });\n          } else {\n            this.cdn\n              .findCountryFromPrefix(number)\n              .pipe(takeUntil(this.destroyNotifier$))\n              .subscribe(country => {\n                if (country) {\n                  //this.getCountry.next(country);\n                  this.countryCode.setValue(country.code);\n                } else {\n                  this.countryCode.setValue('');\n                }\n                this.formatPhoneNumber();\n              });\n          }\n        }\n      });\n\n    this.countryCode.valueChanges\n      .pipe(takeUntil(this.destroyNotifier$))\n      .subscribe(value => {\n        let number = this.number.getRawValue();\n        zip(\n          this.cdn.findCountryFromPrefix(number),\n          this.cdn.findCountryFromCode(value),\n        ).subscribe(([countryFromVies, countryFromCode]) => {\n          // Perform your action here using countryFromVies and countryFromCode\n          if (countryFromVies) {\n            number = number.replace(countryFromVies.dial_code, '');\n          }\n          if (countryFromCode) {\n            this.getCountry.next(countryFromCode);\n            if (number.substring(0, 1) === '+') {\n              number = number.replace('+', '');\n            }\n            number = countryFromCode.dial_code + number;\n            this.number.setValue(number, { emitEvent: false });\n            this.formatPhoneNumber();\n          }\n          setTimeout(() => {\n            this.numberInput.nativeElement.focus();\n          }, 200);\n        });\n      });\n  }\n\n  handleClick(e: any) {\n    e.stopPropagation();\n  }\n\n  private clearValidators() {\n    let required = false;\n    if (this.number.hasValidator(Validators.required)) {\n      required = true;\n    }\n    this.number.clearValidators();\n    if (required) {\n      this.number.addValidators(Validators.required);\n    }\n  }\n\n  private formatPhoneNumber() {\n    this.clearValidators();\n    if (this.countryCode.getRawValue() !== '') {\n      this.number.addValidators([\n        this.phoneNumberValidator(this.countryCode.getRawValue()),\n      ]);\n    }\n    try {\n      const parsedPhone = parsePhoneNumber(this.number.getRawValue());\n      const code = parsedPhone?.country;\n      if (code) {\n        this.countryCode.setValue(code, { emitEvent: false });\n        this.clearValidators();\n        this.number.addValidators([this.phoneNumberValidator(code)]);\n        this.number.setValue(parsedPhone?.format('INTERNATIONAL'), {\n          emitEvent: false,\n        });\n      } else {\n        this.number.addValidators([genericValidator('input.phone.invalid')]);\n      }\n    } catch (e: any) {\n      this.number.addValidators([genericValidator(e.message)]);\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n  }\n\n  errors() {\n    for (const k in this.number.errors) {\n      if (k === 'required') {\n        return 'input.phone.required';\n      } else {\n        return 'input.phone.invalid';\n      }\n    }\n    return 'input.phone.unknown.error';\n  }\n\n  phoneNumberValidator(code: string): ValidatorFn {\n    return (_control: AbstractControl): ValidationErrors | null => {\n      let number: string = this.countryCode + _control.getRawValue();\n\n      if (number === '') {\n        return null;\n      }\n\n      try {\n        number = number.replace(code, '');\n        const parsedNumber = parsePhoneNumber(number);\n\n        if (parsedNumber?.isValid()) {\n          return null;\n        }\n      } catch (e: any) {\n        console.warn(e.message);\n        return { phoneNumber: { value: 'input.phone.invalid' } };\n      }\n      return { phoneNumber: { value: 'input.phone.invalid' } };\n    };\n  }\n}\n\nfunction genericValidator(message: string): ValidatorFn {\n  return (_control: AbstractControl): ValidationErrors | null => {\n    return { phoneNumber: { value: message } };\n  };\n}\n","<ng-container>\n  <mat-form-field class=\"onemrva-input-phone-number\">\n    <mat-label>{{ label }}</mat-label>\n\n    <input\n      (click)=\"handleClick($event)\"\n      type=\"tel\"\n      matInput\n      phoneNumber\n      #numberInput\n      placeholder=\"+32 475 12 34 56\"\n      [formControl]=\"phoneNumber\"\n      class=\"onemrva-text-number\"\n      [readOnly]=\"readonly\"\n    />\n    <mat-select\n      matTextPrefix\n      class=\"onemrva-phone-number-select\"\n      [formControl]=\"countryCode\"\n    >\n      <mat-select-trigger>\n        <flag-icon [countryCode]=\"countryCode.getRawValue()\" />\n      </mat-select-trigger>\n      <mat-option>\n        <mat-select-search\n          [formControl]=\"filterCtrl\"\n          [ariaLabel]=\"searchAriaLabel\"\n          [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n          [placeholderLabel]=\"placeholderLabel\"\n        ></mat-select-search>\n      </mat-option>\n      <mat-option\n        *ngFor=\"let country of filteredCountries$ | async\"\n        [value]=\"country.code\"\n      >\n        <flag-icon [countryCode]=\"country.code\" />\n        &nbsp;&nbsp;&nbsp;\n        {{ country.name }}\n        &nbsp;&nbsp;&nbsp;\n        <span class=\"dialcode\">\n          {{ country.dial_code }}\n        </span>\n      </mat-option>\n    </mat-select>\n    <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n    <mat-error *ngIf=\"number.invalid\">{{ errors() | translate }}</mat-error>\n  </mat-form-field>\n</ng-container>\n"]}
234
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onemrva-mat-input-phone.component.js","sourceRoot":"","sources":["../../../../../../projects/onemrva/design-system/mat-input-phone/src/onemrva-mat-input-phone.component.ts","../../../../../../projects/onemrva/design-system/mat-input-phone/src/onemrva-mat-input-phone.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  ReactiveFormsModule,\n  ValidationErrors,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatSelectModule } from '@angular/material/select';\nimport { TranslateModule } from '@ngx-translate/core';\nimport {\n  Observable,\n  Subject,\n  map,\n  startWith,\n  debounceTime,\n  takeUntil,\n  combineLatestWith,\n  zip,\n} from 'rxjs';\nimport { MatSelectSearchModule } from '@onemrvapublic/design-system/mat-select-search';\nimport { PhoneNumberDirective } from './phone-number.directive';\nimport parsePhoneNumber from 'libphonenumber-js';\nimport { FlagIconComponent } from '@onemrvapublic/design-system/flag-icon';\nimport {\n  OnemRvaCDNCountryService,\n  OnemrvaMaterialCountry,\n} from '@onemrvapublic/design-system/shared';\n\n@Component({\n  selector: 'onemrva-mat-input-phone',\n  styleUrls: ['onemrva-mat-input-phone.component.scss'],\n  templateUrl: 'onemrva-mat-input-phone.component.html',\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatInputModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatSelectSearchModule,\n    ReactiveFormsModule,\n    TranslateModule,\n    PhoneNumberDirective,\n    FlagIconComponent,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class OnemrvaMatInputPhoneComponent implements OnInit, OnDestroy {\n  @Input()\n  readonly: boolean = false;\n\n  @Input() phoneNumber!: FormControl;\n  @Input() label: string = 'Phone number';\n  @Input() noEntriesFoundLabel = 'Not found';\n  @Input() placeholderLabel = 'Search';\n  @Input() defaultPrefix: string = '+32';\n  @Input() searchAriaLabel = '';\n  @Input() hint: string = '';\n  @Output() getCountry = new EventEmitter<any>();\n  @ViewChild('numberInput') numberInput!: ElementRef;\n\n  countryCode: FormControl = new FormControl('');\n\n  public filterCtrl: FormControl<string | null> = new FormControl<string>('');\n\n  destroyNotifier$: Subject<void> = new Subject();\n\n  public countries$: Observable<OnemrvaMaterialCountry[]> =\n    this.cdn.getCountries();\n  public filteredCountries$: Observable<OnemrvaMaterialCountry[]>;\n\n  constructor(private cdn: OnemRvaCDNCountryService) {\n    this.filteredCountries$ = this.filterCtrl.valueChanges.pipe(\n      debounceTime(400),\n      startWith(''),\n      combineLatestWith(this.countries$),\n      map(([search, countries]) => {\n        return countries.filter((country: OnemrvaMaterialCountry) => {\n          if (!search || search === '') return countries;\n          if (country.name === undefined) return false;\n          return country.name.toLowerCase().indexOf(search.toLowerCase()) > -1;\n        });\n      }),\n    );\n  }\n\n  get number(): FormControl {\n    return this.phoneNumber as FormControl;\n  }\n\n  ngOnInit(): void {\n    this.number.valueChanges\n      .pipe(\n        startWith(this.number.getRawValue()),\n        takeUntil(this.destroyNotifier$),\n      )\n      .subscribe(number => {\n        if (number !== '') {\n          if (number.substring(0, 1) !== '+')\n            this.countryCode.setValue('', { emitEvent: false });\n          if (number === '0') {\n            this.cdn\n              .findCountryFromPrefix(this.defaultPrefix)\n              .pipe(takeUntil(this.destroyNotifier$))\n              .subscribe(country => {\n                if (country) {\n                  //this.getCountry.next(country);\n                  this.number.setValue(this.defaultPrefix, {\n                    emitEvent: false,\n                  });\n                  this.countryCode.setValue(country.code, { emitEvent: false });\n                } else {\n                  this.countryCode.setValue('');\n                }\n                this.formatPhoneNumber();\n              });\n          } else {\n            this.cdn\n              .findCountryFromPrefix(number)\n              .pipe(takeUntil(this.destroyNotifier$))\n              .subscribe(country => {\n                if (country) {\n                  //this.getCountry.next(country);\n                  this.countryCode.setValue(country.code);\n                } else {\n                  this.countryCode.setValue('');\n                }\n                this.formatPhoneNumber();\n              });\n          }\n        }\n      });\n\n    this.countryCode.valueChanges\n      .pipe(takeUntil(this.destroyNotifier$))\n      .subscribe(value => {\n        let number = this.number.getRawValue();\n        zip(\n          this.cdn.findCountryFromPrefix(number),\n          this.cdn.findCountryFromCode(value),\n        ).subscribe(([countryFromVies, countryFromCode]) => {\n          // Perform your action here using countryFromVies and countryFromCode\n          if (countryFromVies) {\n            number = number.replace(countryFromVies.dial_code, '');\n          }\n          if (countryFromCode) {\n            this.getCountry.next(countryFromCode);\n            if (number.substring(0, 1) === '+') {\n              number = number.replace('+', '');\n            }\n            number = countryFromCode.dial_code + number;\n            this.number.setValue(number, { emitEvent: false });\n            this.formatPhoneNumber();\n          }\n          setTimeout(() => {\n            this.numberInput.nativeElement.focus();\n          }, 200);\n        });\n      });\n  }\n\n  handleClick(e: any) {\n    e.stopPropagation();\n  }\n\n  private clearValidators() {\n    let required = false;\n    if (this.number.hasValidator(Validators.required)) {\n      required = true;\n    }\n    this.number.clearValidators();\n    if (required) {\n      this.number.addValidators(Validators.required);\n    }\n  }\n\n  private formatPhoneNumber() {\n    this.clearValidators();\n    if (this.countryCode.getRawValue() !== '') {\n      this.number.addValidators([\n        this.phoneNumberValidator(this.countryCode.getRawValue()),\n      ]);\n    }\n    try {\n      const parsedPhone = parsePhoneNumber(this.number.getRawValue());\n      const code = parsedPhone?.country;\n      if (code) {\n        this.countryCode.setValue(code, { emitEvent: false });\n        this.clearValidators();\n        this.number.addValidators([this.phoneNumberValidator(code)]);\n        this.number.setValue(parsedPhone?.format('INTERNATIONAL'), {\n          emitEvent: false,\n        });\n      } else {\n        this.number.addValidators([genericValidator('input.phone.invalid')]);\n      }\n    } catch (e: any) {\n      this.number.addValidators([genericValidator(e.message)]);\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyNotifier$.next();\n    this.destroyNotifier$.complete();\n  }\n\n  errors() {\n    for (const k in this.number.errors) {\n      if (k === 'required') {\n        return 'input.phone.required';\n      } else {\n        return 'input.phone.invalid';\n      }\n    }\n    return 'input.phone.unknown.error';\n  }\n\n  phoneNumberValidator(code: string): ValidatorFn {\n    return (_control: AbstractControl): ValidationErrors | null => {\n      let number: string = this.countryCode + _control.getRawValue();\n\n      if (number === '') {\n        return null;\n      }\n\n      try {\n        number = number.replace(code, '');\n        const parsedNumber = parsePhoneNumber(number);\n\n        if (parsedNumber?.isValid()) {\n          return null;\n        }\n      } catch (e: any) {\n        console.warn(e.message);\n        return { phoneNumber: { value: 'input.phone.invalid' } };\n      }\n      return { phoneNumber: { value: 'input.phone.invalid' } };\n    };\n  }\n}\n\nfunction genericValidator(message: string): ValidatorFn {\n  return (_control: AbstractControl): ValidationErrors | null => {\n    return { phoneNumber: { value: message } };\n  };\n}\n","<ng-container>\n  <mat-form-field class=\"onemrva-input-phone-number\">\n    <mat-label>{{ label }}</mat-label>\n\n    <input\n      (click)=\"handleClick($event)\"\n      type=\"tel\"\n      matInput\n      phoneNumber\n      #numberInput\n      placeholder=\"+32 475 12 34 56\"\n      [formControl]=\"phoneNumber\"\n      class=\"onemrva-text-number\"\n      [readOnly]=\"readonly\"\n    />\n    <mat-select\n      matTextPrefix\n      class=\"onemrva-phone-number-select\"\n      [formControl]=\"countryCode\"\n    >\n      <mat-select-trigger>\n        <flag-icon [countryCode]=\"countryCode.getRawValue()\" />\n      </mat-select-trigger>\n      <mat-option>\n        <mat-select-search\n          [formControl]=\"filterCtrl\"\n          [ariaLabel]=\"searchAriaLabel\"\n          [noEntriesFoundLabel]=\"noEntriesFoundLabel\"\n          [placeholderLabel]=\"placeholderLabel\"\n        ></mat-select-search>\n      </mat-option>\n      <mat-option\n        *ngFor=\"let country of filteredCountries$ | async\"\n        [value]=\"country.code\"\n      >\n        <flag-icon [countryCode]=\"country.code\" />\n        &nbsp;&nbsp;&nbsp;\n        {{ country.name }}\n        &nbsp;&nbsp;&nbsp;\n        <span class=\"dialcode\">\n          {{ country.dial_code }}\n        </span>\n      </mat-option>\n    </mat-select>\n    <mat-hint *ngIf=\"hint !== ''\">{{ hint }}</mat-hint>\n    <mat-error *ngIf=\"number.invalid\">{{ errors() | translate }}</mat-error>\n  </mat-form-field>\n</ng-container>\n"]}
@@ -1,16 +1,18 @@
1
1
  /*
2
2
  * Public API Surface of shared
3
3
  */
4
- export * from './src/lib/shared.module';
5
- export * from './src/lib/shared.datepicker.module';
6
- export * from './src/lib/OnemrvaDateAdapter';
7
- export * from './src/lib/date.format';
4
+ export * from './src/lib/adapters';
5
+ export * from './src/lib/components';
6
+ export * from './src/lib/constants';
7
+ export * from './src/lib/containers';
8
+ export * from './src/lib/decorators';
8
9
  export * from './src/lib/directives';
10
+ export * from './src/lib/helpers';
11
+ export * from './src/lib/loaders';
12
+ export * from './src/lib/interfaces';
9
13
  export * from './src/lib/pipes';
10
- export * from './src/lib/validators/onemrva-validators';
11
- export * from './src/lib/services/index';
12
- export * from './src/lib/interfaces/index';
13
- export * from './src/lib/containers';
14
- export * from './src/lib/validators/bankAccountValidator.utils';
15
- export const NISS_MASK = '000000/000-00';
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vbmVtcnZhL2Rlc2lnbi1zeXN0ZW0vc2hhcmVkL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGlEQUFpRCxDQUFDO0FBRWhFLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHNoYXJlZFxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vc3JjL2xpYi9zaGFyZWQubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2xpYi9zaGFyZWQuZGF0ZXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvbGliL09uZW1ydmFEYXRlQWRhcHRlcic7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvZGF0ZS5mb3JtYXQnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvbGliL2RpcmVjdGl2ZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvbGliL3BpcGVzJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2xpYi92YWxpZGF0b3JzL29uZW1ydmEtdmFsaWRhdG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvc2VydmljZXMvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvbGliL2ludGVyZmFjZXMvaW5kZXgnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvbGliL2NvbnRhaW5lcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvbGliL3ZhbGlkYXRvcnMvYmFua0FjY291bnRWYWxpZGF0b3IudXRpbHMnO1xuXG5leHBvcnQgY29uc3QgTklTU19NQVNLID0gJzAwMDAwMC8wMDAtMDAnO1xuIl19
14
+ export * from './src/lib/services';
15
+ export * from './src/lib/validators';
16
+ export * from './src/lib/shared.module';
17
+ export * from './src/lib/shared.datepicker.module';
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9vbmVtcnZhL2Rlc2lnbi1zeXN0ZW0vc2hhcmVkL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLG9DQUFvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBzaGFyZWRcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvYWRhcHRlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvbGliL2NvbXBvbmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvbGliL2NvbnN0YW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvY29udGFpbmVycyc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvZGVjb3JhdG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvZGlyZWN0aXZlcyc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvaGVscGVycyc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvbG9hZGVycyc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9saWIvcGlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvbGliL3NlcnZpY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2xpYi92YWxpZGF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2xpYi9zaGFyZWQubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2xpYi9zaGFyZWQuZGF0ZXBpY2tlci5tb2R1bGUnO1xuIl19