@dsivd/prestations-ng 17.2.2 → 17.2.4

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.
package/CHANGELOG.md CHANGED
@@ -6,13 +6,27 @@
6
6
 
7
7
  ---
8
8
 
9
- ## [17.X.X]
9
+ ## [17.2.4]
10
+
11
+ ### Fixed
12
+
13
+ - [foehn-multiselect-autocomplete.component.html](projects/prestations-ng/src/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.html)
14
+ - added missing inputs to `foehn-autocomplete`: `isLabelSrOnly` and `isSuggestionListDynamic`
15
+
16
+ - [foehn-input-address.component.ts](projects/prestations-ng/src/foehn-address/foehn-input-address.component.ts)
17
+ - locality identity (equals) is now checked on `zipCodeId` instead of `postalLocalityHistoryId` (not a stable id)
18
+
19
+ ## [17.2.3]
10
20
 
11
21
  ### Added
12
22
 
13
23
  - [foehn-table.component.ts](projects/prestations-ng/src/foehn-table/foehn-table.component.ts)
24
+
14
25
  - Build filtered list in the list input setter
15
26
 
27
+ - [gesdem-action-recovery-login.component.ts](projects/prestations-ng/src/gesdem-action-recovery/gesdem-action-recovery-login/gesdem-action-recovery-login.component.ts)
28
+ - Fix redirection after expired session
29
+
16
30
  ## [17.2.1]
17
31
 
18
32
  ### Fixed
Binary file
@@ -51,7 +51,7 @@ export class FoehnInputAddressComponent extends FoehnInputComponent {
51
51
  this.isOnlySwissChangeSubject = new BehaviorSubject(true);
52
52
  this.identity = (n) => n;
53
53
  this.countryIdentity = (country) => country.iso2Id;
54
- this.localityIdentity = (loc) => loc.postalLocalityHistoryId;
54
+ this.localityIdentity = (loc) => loc.zipCodeId;
55
55
  this.streetIdentity = (street) => street.estrid;
56
56
  this.streetGenerator = (longName) => ({
57
57
  estrid: null,
@@ -290,9 +290,7 @@ export class FoehnInputAddressComponent extends FoehnInputComponent {
290
290
  if (this.isModelEmpty()) {
291
291
  return;
292
292
  }
293
- if (this.isOnlySwiss &&
294
- this.country &&
295
- this.country.iso2Id !== SWISS_ISO_ID) {
293
+ if (this.isOnlySwiss && this.country?.iso2Id !== SWISS_ISO_ID) {
296
294
  // Do not remove this warning. Needed for debugging at all time.
297
295
  console.warn(
298
296
  // eslint-disable-next-line max-len
@@ -362,9 +360,9 @@ export class FoehnInputAddressComponent extends FoehnInputComponent {
362
360
  };
363
361
  }
364
362
  getValidLocality(value) {
365
- // PRESTAKIT-352: Need a fake 'postalLocalityHistoryId' for individual errors on 'zipCode' and 'longName'
363
+ // PRESTAKIT-352: Need a fake 'zipCodeId' for individual errors on 'zipCode' and 'longName'
366
364
  if (!this.isSwiss() && !value) {
367
- return { postalLocalityHistoryId: '-1' };
365
+ return { zipCodeId: '-1' };
368
366
  }
369
367
  return value;
370
368
  }
@@ -473,4 +471,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
473
471
  }], withDefaultCountry: [{
474
472
  type: Input
475
473
  }] } });
476
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-address.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-address/foehn-input-address.component.ts","../../../../projects/prestations-ng/src/foehn-address/foehn-input-address.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport {\n    Component,\n    forwardRef,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChange,\n    SimpleChanges,\n    ViewChild\n} from '@angular/core';\nimport {\n    BehaviorSubject,\n    combineLatest,\n    Observable,\n    of,\n    Subscription\n} from 'rxjs';\nimport {\n    debounceTime,\n    distinctUntilChanged,\n    map,\n    shareReplay,\n    switchMap,\n    tap\n} from 'rxjs/operators';\n\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { FoehnInputTextComponent } from '../foehn-input/foehn-input-text.component';\nimport { ObjectHelper } from '../helpers/object.helper';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { Address, Country, Locality, Street } from './address.type';\nimport { FoehnInputForeignLocalityComponent } from './foehn-input-foreign-locality.component';\nimport { FoehnInputForeignStreetComponent } from './foehn-input-foreign-street.component';\n\n// eslint-disable max-classes-per-file\nexport const SWISS_ISO_ID = 'CH';\n\nexport class StreetNumber {\n    name: string;\n}\n\nconst isDefined = (value: boolean): boolean =>\n    value === true || value === false;\n\nconst hasInputChanged = (change: SimpleChange): boolean =>\n    change && !ObjectHelper.isEqual(change.previousValue, change.currentValue);\n\n@Component({\n    selector: 'foehn-input-address',\n    templateUrl: './foehn-input-address.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnInputAddressComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnInputAddressComponent\n    extends FoehnInputComponent<Address>\n    implements OnInit, OnChanges, OnDestroy\n{\n    @ViewChild(FoehnInputForeignLocalityComponent, { static: false })\n    foreignLocalityComponent: FoehnInputForeignLocalityComponent;\n\n    @ViewChild(FoehnInputForeignStreetComponent, { static: false })\n    foreignStreetComponent: FoehnInputForeignStreetComponent;\n\n    @ViewChild('foreignHouseNumber', { static: false })\n    foreignHouseNumber: FoehnInputTextComponent;\n\n    @Input()\n    countriesUrl = 'api/refinf/countries';\n\n    @Input()\n    isOnlySwiss = true;\n\n    @Input()\n    showPostOfficeBoxText = false;\n\n    @Input()\n    showAdressLines = true;\n\n    @Input()\n    showAdressLine1 = true;\n\n    @Input()\n    showAdressLine2 = true;\n\n    @Input()\n    specifiedCanton: string;\n\n    @Input()\n    countryRequired = true;\n\n    @Input()\n    swissNpaLocalityRequired = true;\n\n    @Input()\n    streetRequired: boolean;\n\n    @Input()\n    streetNumberRequired = false;\n\n    @Input()\n    hideNotRequiredExtraLabelStreetNumber = true;\n\n    @Input()\n    foreignZipCodeRequired = true;\n\n    @Input()\n    foreignLocalityRequired = true;\n\n    @Input()\n    foreignStreetRequired: boolean;\n\n    @Input()\n    foreignStreetNumberRequired = false;\n\n    @Input()\n    postOfficeBoxTextRequired: boolean;\n\n    @Input()\n    addressLine1Required = false;\n\n    @Input()\n    addressLine2Required = false;\n\n    @Input()\n    withCompanyLocalities = false;\n\n    @Input()\n    withDefaultCountry = true;\n\n    country: Country;\n    locality: Locality;\n    street: Street;\n    houseNumber: string;\n    postOfficeBoxText: string;\n    addressLine1: string;\n    addressLine2: string;\n\n    countries: Observable<Country[]>;\n    localities: Observable<Locality[]>;\n    streets: Observable<Street[]>;\n    streetNumbers: Observable<StreetNumber[]>;\n\n    streetCustomErrors: { [key: string]: string } = {};\n\n    private iso2IdSubject = new BehaviorSubject<string>(null);\n    private zipCodeIdSubject = new BehaviorSubject<string>(null);\n    private estrIdSubject = new BehaviorSubject<string>(null);\n\n    private countryModelChangeSubject = new BehaviorSubject<Country>(null);\n    private isOnlySwissChangeSubject = new BehaviorSubject<boolean>(true);\n    private manageDefaultCountrySubscription: Subscription;\n\n    constructor(\n        private httpClient: HttpClient,\n        private dictionaryService: SdkDictionaryService\n    ) {\n        super();\n    }\n\n    identity = <T>(n: T): T => n;\n    countryIdentity = (country: Country): string => country.iso2Id;\n    localityIdentity = (loc: Locality): string => loc.postalLocalityHistoryId;\n    streetIdentity = (street: Street): string => street.estrid;\n    streetGenerator = (longName: string): Street => ({\n        estrid: null,\n        longName\n    });\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.manageDefaultCountrySubscription = this.manageDefaultCountry();\n\n        if (!this.showPostOfficeBoxText) {\n            this.streetCustomErrors.AtLeastOneNotNull =\n                this.dictionaryService.getKeySync('errors.NotNull');\n        }\n\n        this.countries = this.getCountries();\n\n        this.localities = this.iso2IdSubject.pipe(\n            distinctUntilChanged(),\n            // The list of localities, or an empty array as the default value.\n            switchMap(iso2Id => this.getLocalities(iso2Id)),\n            shareReplay(1)\n        );\n\n        this.streets = combineLatest([\n            this.zipCodeIdSubject,\n            this.localities\n        ]).pipe(\n            // The zipCodeId when locality changes or match locality (postalLocalityHistoryId) from model\n            map(\n                ([zipCodeId, localities]) =>\n                    zipCodeId ||\n                    this.extractLocalityZipCodeId(localities, this.locality)\n            ),\n            distinctUntilChanged(),\n            // The list of streets or a default value to an empty array\n            switchMap(zipCodeId => this.getStreetsFor(zipCodeId)),\n            shareReplay(1)\n        );\n\n        this.streetNumbers = combineLatest([\n            this.estrIdSubject,\n            this.streets\n        ]).pipe(\n            // The estrid when street changes or match street (longName) from model\n            map(\n                ([estrid, streets]) =>\n                    estrid || this.extractStreetEstrid(streets, this.street)\n            ),\n            distinctUntilChanged(),\n            // The list of streets or a default value to an empty array\n            switchMap(estrid => this.getStreetNumberFor(estrid)),\n            // Some street might not have an name, RefInf sometimes returns weird data.\n            map(values => values.filter(streetNumber => !!streetNumber.name)),\n            map(values => {\n                const collator = new Intl.Collator(undefined, {\n                    numeric: true,\n                    sensitivity: 'base'\n                });\n                return values.sort((a, b) => collator.compare(a.name, b.name));\n            }),\n            shareReplay(1)\n        );\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.manageDefaultCountrySubscription?.unsubscribe();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const modelChange: SimpleChange = changes.model;\n        const isOnlySwiss: SimpleChange = changes.isOnlySwiss;\n\n        if (hasInputChanged(modelChange)) {\n            this.countryModelChangeSubject.next(\n                modelChange.currentValue?.country\n            );\n        }\n        if (hasInputChanged(isOnlySwiss)) {\n            this.isOnlySwissChangeSubject.next(isOnlySwiss.currentValue);\n        }\n    }\n\n    updateAddress(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    updateNgModel(value: Address): void {\n        if (!!value) {\n            // avoid wrongfull prefill by session info\n            if (!this.showAdressLines || !this.showAdressLine1) {\n                value.addressLine1 = null;\n            }\n            if (!this.showAdressLines || !this.showAdressLine2) {\n                value.addressLine2 = null;\n            }\n            if (!this.showPostOfficeBoxText) {\n                value.postOfficeBoxText = null;\n            }\n            // never updatable in the component\n            value.postOfficeBoxNumber = null;\n        }\n\n        super.updateNgModel(value);\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    onModelChange(value: Address): void {\n        if (value) {\n            this.country = value.country;\n            this.locality = value.locality;\n            this.street = value.street;\n            this.houseNumber = value.houseNumber;\n            this.postOfficeBoxText = value.postOfficeBoxText;\n            this.addressLine1 = value.addressLine1;\n            this.addressLine2 = value.addressLine2;\n        } else if (!value) {\n            // country is managed by `manageDefaultCountry()`\n            this.locality = null;\n            this.street = null;\n            this.houseNumber = null;\n            this.postOfficeBoxText = null;\n            this.addressLine1 = null;\n            this.addressLine2 = null;\n        }\n    }\n\n    isSwiss(): boolean {\n        return !!(\n            this.isOnlySwiss ||\n            (this.country && this.country.iso2Id === SWISS_ISO_ID)\n        );\n    }\n\n    userInputCountry(): void {\n        this.zipCodeIdSubject.next(null);\n        this.estrIdSubject.next(null);\n\n        this.locality = null;\n        this.street = null;\n        this.houseNumber = null;\n        this.postOfficeBoxText = null;\n        this.addressLine1 = null;\n        this.addressLine2 = null;\n\n        this.updateAddress();\n        this.handleUserInput();\n    }\n\n    userInputLocality(locality: unknown): void {\n        if (!locality) {\n            this.zipCodeIdSubject.next(null);\n        }\n        // Always reset suggestion list of houseNumber when locality changes\n        this.estrIdSubject.next(null);\n\n        this.street = null;\n        this.houseNumber = null;\n\n        this.updateAddress();\n        this.handleUserInput();\n    }\n\n    userInputStreet(street: unknown): void {\n        if (!street) {\n            this.estrIdSubject.next(null);\n        }\n        this.houseNumber = null;\n        this.handleUserInput();\n    }\n\n    countryUpdated(country: Country): void {\n        // No double-binding on country in view to ensure we update properly model\n        this.country = country;\n        this.updateAddress();\n\n        if (!country) {\n            return;\n        }\n\n        const { iso2Id } = country;\n        this.iso2IdSubject.next(iso2Id);\n    }\n\n    getLocalityDisplayedName(locality: Locality): string | void {\n        if (!locality) {\n            return;\n        }\n\n        return `${locality.zipCode} ${locality.longName}`;\n    }\n\n    localityUpdated(locality: Locality): void {\n        // No double-binding on locality in view to ensure we update properly model\n        this.locality = locality;\n        this.updateAddress();\n\n        if (!locality) {\n            return;\n        }\n\n        const { zipCodeId } = locality;\n        this.zipCodeIdSubject.next(zipCodeId);\n    }\n\n    streetUpdated(street: Street): void {\n        // No double-binding on street in view to ensure we update properly model\n        this.street = street;\n        this.updateAddress();\n\n        if (!street) {\n            return;\n        }\n\n        const { estrid } = street;\n        this.estrIdSubject.next(estrid);\n    }\n\n    isStreetRequired(): boolean {\n        if (isDefined(this.streetRequired)) {\n            // respect overriden value\n            return this.streetRequired;\n        }\n\n        if (!this.showPostOfficeBoxText) {\n            return true;\n        }\n\n        return !this.postOfficeBoxText || !!this.street;\n    }\n\n    isForeignStreetRequired(): boolean {\n        if (isDefined(this.foreignStreetRequired)) {\n            // respect overriden value\n            return this.foreignStreetRequired;\n        }\n\n        if (!this.showPostOfficeBoxText) {\n            return true;\n        }\n\n        return !this.postOfficeBoxText || !!this.street;\n    }\n\n    isPostOfficeBoxTextRequired(): boolean {\n        if (isDefined(this.postOfficeBoxTextRequired)) {\n            // respect overriden value\n            return this.postOfficeBoxTextRequired;\n        }\n        return !this.street || !!this.postOfficeBoxText;\n    }\n\n    private getCountries(): Observable<Country[]> {\n        return this.httpClient.get<Country[]>(this.countriesUrl);\n    }\n\n    private getLocalities(iso2Id: string): Observable<Locality[]> {\n        if (iso2Id !== SWISS_ISO_ID) {\n            return of([]);\n        }\n\n        const queryParams = !!this.withCompanyLocalities\n            ? '?withCompanyLocalities=true'\n            : '';\n\n        if (!!this.specifiedCanton) {\n            return this.httpClient.get<Locality[]>(\n                `api/refinf/locality/${this.specifiedCanton}${queryParams}`\n            );\n        } else {\n            return this.httpClient.get<Locality[]>(\n                `api/refinf/locality/all${queryParams}`\n            );\n        }\n    }\n\n    private getStreetNumberFor(estrid: string): Observable<StreetNumber[]> {\n        if (!estrid) {\n            return of([]);\n        }\n\n        const url = `api/refinf/addresses/${estrid}`;\n        return this.httpClient.get<StreetNumber[]>(url);\n    }\n\n    private getStreetsFor(zipCodeId: string): Observable<Street[]> {\n        if (!zipCodeId) {\n            return of([]);\n        }\n\n        const url = `api/refinf/streets/${zipCodeId}`;\n        return this.httpClient.get<Street[]>(url);\n    }\n\n    private clearAutocompletesWhenCountryIsUnappropriatedToComponentConfiguration(): void {\n        if (this.isModelEmpty()) {\n            return;\n        }\n\n        if (\n            this.isOnlySwiss &&\n            this.country &&\n            this.country.iso2Id !== SWISS_ISO_ID\n        ) {\n            // Do not remove this warning. Needed for debugging at all time.\n            console.warn(\n                // eslint-disable-next-line max-len\n                `Country address was '${this.country.iso2Id}'. Only swiss is asked in component 'foehn-input-address' configuration. Address model resetted.`\n            );\n            this.clearAutocompletes();\n        }\n    }\n\n    private getSwissCountry(): Country {\n        return {\n            iso2Id: SWISS_ISO_ID,\n            shortNameFr: 'Suisse'\n        };\n    }\n\n    private setDefaultCountry(): void {\n        if (\n            this.withDefaultCountry &&\n            (this.isOnlySwiss || !this.country || !this.country.iso2Id)\n        ) {\n            this.country = this.getSwissCountry();\n            this.iso2IdSubject.next(SWISS_ISO_ID);\n\n            this.updateAddress();\n        }\n    }\n\n    private clearAutocompletes(): void {\n        this.country = null;\n        this.street = null;\n        this.locality = null;\n        this.houseNumber = null;\n        // No updateAddress() here because done in setDefaultCountry()\n    }\n\n    private extractLocalityZipCodeId(\n        localities: Locality[],\n        localityToMatch: Locality\n    ): string {\n        if (localityToMatch && localityToMatch.postalLocalityHistoryId) {\n            const matched = localities.find(\n                (locality: Locality) =>\n                    locality.postalLocalityHistoryId ===\n                    localityToMatch.postalLocalityHistoryId\n            );\n            if (matched) {\n                return matched.zipCodeId;\n            }\n        }\n\n        return null;\n    }\n\n    private extractStreetEstrid(\n        streets: Street[],\n        streetToMatch: Street\n    ): string {\n        if (streetToMatch && streetToMatch.longName) {\n            const matched = streets.find(\n                (street: Street) => street.longName === streetToMatch.longName\n            );\n            if (matched) {\n                return matched.estrid;\n            }\n        }\n\n        return null;\n    }\n\n    private getValidCountry(): Country {\n        // Be sure to always send Swiss country when 'isOnlySwiss' is set to true\n        return this.isOnlySwiss ? this.getSwissCountry() : this.country;\n    }\n\n    private getValidValue(): Address | null | undefined {\n        if (this.isModelEmpty()) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        return {\n            country: this.getValidCountry(),\n            locality: this.getValidLocality(this.locality),\n            street: this.street,\n            houseNumber: this.houseNumber,\n            postOfficeBoxText: this.postOfficeBoxText,\n            addressLine1: this.addressLine1,\n            addressLine2: this.addressLine2\n        };\n    }\n\n    private getValidLocality(value: Locality): Locality {\n        // PRESTAKIT-352: Need a fake 'postalLocalityHistoryId' for individual errors on 'zipCode' and 'longName'\n        if (!this.isSwiss() && !value) {\n            return { postalLocalityHistoryId: '-1' };\n        }\n\n        return value;\n    }\n\n    private isModelEmpty(): boolean {\n        return (\n            (this.isOnlySwiss ||\n                !this.country ||\n                ObjectHelper.isEmpty(this.country)) &&\n            (!this.locality || ObjectHelper.isEmpty(this.locality)) &&\n            (!this.street || ObjectHelper.isEmpty(this.street)) &&\n            this.isEmpty(this.houseNumber) &&\n            this.isEmpty(this.postOfficeBoxText) &&\n            this.isEmpty(this.addressLine1) &&\n            this.isEmpty(this.addressLine2)\n        );\n    }\n\n    private manageDefaultCountry(): Subscription {\n        return (\n            combineLatest([\n                this.countryModelChangeSubject.asObservable().pipe(\n                    debounceTime(0),\n                    distinctUntilChanged(\n                        (previous, current) =>\n                            previous?.iso2Id === current?.iso2Id\n                    )\n                ),\n                this.isOnlySwissChangeSubject\n                    .asObservable()\n                    .pipe(debounceTime(0), distinctUntilChanged())\n            ])\n                .pipe(\n                    tap(([country, isOnlySwiss]) => {\n                        if (!isOnlySwiss && !country) {\n                            this.setDefaultCountry();\n                            return;\n                        }\n\n                        if (isOnlySwiss) {\n                            // When there is a country, we need to check if it has to be cleaned and set to default\n                            if (!!country && !ObjectHelper.isEmpty(country)) {\n                                this.clearAutocompletesWhenCountryIsUnappropriatedToComponentConfiguration();\n                            }\n                            this.setDefaultCountry();\n                            return;\n                        }\n                    })\n                )\n                // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n                .subscribe()\n        );\n    }\n}\n","<div\n    [attr.id]=\"buildId() + 'Container'\"\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [tabIndex]=\"-1\"\n>\n    <fieldset\n        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend\n            *ngIf=\"!!label\"\n            [ngClass]=\"isLabelSrOnly ? 'visually-hidden' : 'vd-p'\"\n        >\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <foehn-autocomplete\n            *ngIf=\"!isOnlySwiss\"\n            [label]=\"'foehn-input-address.country.label' | fromDictionary\"\n            [elements]=\"countries | async\"\n            elementLabel=\"shortNameFr\"\n            [elementValue]=\"identity\"\n            [elementValueIdentity]=\"countryIdentity\"\n            (modelChange)=\"countryUpdated($event)\"\n            (userInput)=\"userInputCountry()\"\n            [model]=\"country\"\n            [name]=\"name + '.country'\"\n            [required]=\"countryRequired\"\n            [disabled]=\"disabled\"\n        ></foehn-autocomplete>\n\n        <ng-container *ngIf=\"isSwiss()\">\n            <foehn-autocomplete\n                [label]=\"'foehn-input-address.locality.label' | fromDictionary\"\n                [elements]=\"localities | async\"\n                [elementLabel]=\"getLocalityDisplayedName\"\n                [elementValue]=\"identity\"\n                [elementValueIdentity]=\"localityIdentity\"\n                (modelChange)=\"localityUpdated($event)\"\n                (userInput)=\"userInputLocality($event)\"\n                [model]=\"locality\"\n                [name]=\"name + '.locality'\"\n                [allowCustomValue]=\"disabled\"\n                [required]=\"swissNpaLocalityRequired\"\n                [disabled]=\"disabled\"\n            ></foehn-autocomplete>\n\n            <foehn-autocomplete\n                [label]=\"'foehn-input-address.street.label' | fromDictionary\"\n                [elements]=\"streets | async\"\n                elementLabel=\"longName\"\n                [elementValue]=\"identity\"\n                [elementValueIdentity]=\"streetIdentity\"\n                (modelChange)=\"streetUpdated($event)\"\n                [model]=\"street\"\n                [name]=\"name + '.street'\"\n                [allowCustomValue]=\"true\"\n                [customValueModelGenerator]=\"streetGenerator\"\n                [required]=\"isStreetRequired()\"\n                [helpText]=\"\n                    'foehn-input-address.street.help-text' | fromDictionary\n                \"\n                [customErrors]=\"streetCustomErrors\"\n                (userInput)=\"userInputStreet($event)\"\n                [disabled]=\"disabled\"\n            ></foehn-autocomplete>\n\n            <foehn-autocomplete\n                [label]=\"\n                    'foehn-input-address.houseNumber.label' | fromDictionary\n                \"\n                [elements]=\"streetNumbers | async\"\n                elementLabel=\"name\"\n                elementValue=\"name\"\n                [(model)]=\"houseNumber\"\n                [name]=\"name + '.houseNumber'\"\n                [allowCustomValue]=\"true\"\n                [helpText]=\"\n                    'foehn-input-address.houseNumber.help-text' | fromDictionary\n                \"\n                (modelChange)=\"updateAddress()\"\n                (userInput)=\"handleUserInput()\"\n                [required]=\"streetNumberRequired\"\n                [hideNotRequiredExtraLabel]=\"\n                    hideNotRequiredExtraLabelStreetNumber\n                \"\n                [disabled]=\"disabled\"\n            ></foehn-autocomplete>\n        </ng-container>\n\n        <ng-container *ngIf=\"!isSwiss()\">\n            <!--\n            Component <foehn-input-foreign-locality> is special because we use the same model when swiss or foreigner.\n            To do so, we need:\n                - Errors will be bind on 'locality' when NULL or on 'zipCode' and 'longName' model inside component when EMPTY\n                - Hide label from component because we need label from children to be displayed (isLabelSrOnly: true)\n                - required and disabled params are transmitted to children\n             -->\n            <foehn-input-foreign-locality\n                [label]=\"'foehn-input-address.locality.label' | fromDictionary\"\n                [name]=\"name + '.locality'\"\n                [(model)]=\"locality\"\n                [zipCodeRequired]=\"foreignZipCodeRequired\"\n                [localityRequired]=\"foreignLocalityRequired\"\n                [isLabelSrOnly]=\"true\"\n                [disabled]=\"!country || disabled\"\n                (modelChange)=\"updateAddress()\"\n                (userInput)=\"handleUserInput()\"\n            ></foehn-input-foreign-locality>\n            <!--\n            Component <foehn-input-foreign-street> is special because we use the same model when swiss or foreigner.\n            To do so, we need:\n                - Errors will be bind on 'street' when NULL or on 'longName' model inside component when EMPTY\n                - required, helpText, isLabelSrOnly and disabled  params are transmitted to children\n             -->\n            <foehn-input-foreign-street\n                [label]=\"'foehn-input-address.street.label' | fromDictionary\"\n                [name]=\"name + '.street'\"\n                [(model)]=\"street\"\n                [required]=\"isForeignStreetRequired()\"\n                [helpText]=\"\n                    'foehn-input-address.street.help-text' | fromDictionary\n                \"\n                [customErrors]=\"streetCustomErrors\"\n                [disabled]=\"!country || disabled\"\n                (modelChange)=\"updateAddress()\"\n                (userInput)=\"handleUserInput()\"\n            ></foehn-input-foreign-street>\n\n            <foehn-input-text\n                #foreignHouseNumber\n                [label]=\"\n                    'foehn-input-address.houseNumber.label' | fromDictionary\n                \"\n                [name]=\"name + '.houseNumber'\"\n                [(model)]=\"houseNumber\"\n                [helpText]=\"\n                    'foehn-input-address.houseNumber.help-text' | fromDictionary\n                \"\n                [disabled]=\"!country || disabled\"\n                (modelChange)=\"updateAddress()\"\n                (userInput)=\"handleUserInput()\"\n                [required]=\"foreignStreetNumberRequired\"\n            ></foehn-input-text>\n        </ng-container>\n\n        <foehn-input-text\n            *ngIf=\"showPostOfficeBoxText\"\n            [(model)]=\"postOfficeBoxText\"\n            [helpText]=\"\n                'foehn-input-address.postOfficeBoxText.help-text'\n                    | fromDictionary\n            \"\n            [label]=\"\n                'foehn-input-address.postOfficeBoxText.label' | fromDictionary\n            \"\n            [name]=\"name + '.postOfficeBoxText'\"\n            (modelChange)=\"updateAddress()\"\n            (userInput)=\"handleUserInput()\"\n            [required]=\"isPostOfficeBoxTextRequired()\"\n            [disabled]=\"disabled\"\n        ></foehn-input-text>\n\n        <foehn-input-text\n            *ngIf=\"showAdressLines && showAdressLine1\"\n            [(model)]=\"addressLine1\"\n            [label]=\"'foehn-input-address.addressLine1.label' | fromDictionary\"\n            [name]=\"name + '.addressLine1'\"\n            (modelChange)=\"updateAddress()\"\n            (userInput)=\"handleUserInput()\"\n            [required]=\"addressLine1Required\"\n            [autocomplete]=\"'address-line2'\"\n            [disabled]=\"disabled\"\n        ></foehn-input-text>\n\n        <foehn-input-text\n            *ngIf=\"showAdressLines && showAdressLine2\"\n            [(model)]=\"addressLine2\"\n            [label]=\"'foehn-input-address.addressLine2.label' | fromDictionary\"\n            [name]=\"name + '.addressLine2'\"\n            (modelChange)=\"updateAddress()\"\n            (userInput)=\"handleUserInput()\"\n            [required]=\"addressLine2Required\"\n            [autocomplete]=\"'address-line3'\"\n            [disabled]=\"disabled\"\n        ></foehn-input-text>\n    </fieldset>\n</div>\n"]}
474
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-address.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-address/foehn-input-address.component.ts","../../../../projects/prestations-ng/src/foehn-address/foehn-input-address.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport {\n    Component,\n    forwardRef,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChange,\n    SimpleChanges,\n    ViewChild\n} from '@angular/core';\nimport {\n    BehaviorSubject,\n    combineLatest,\n    Observable,\n    of,\n    Subscription\n} from 'rxjs';\nimport {\n    debounceTime,\n    distinctUntilChanged,\n    map,\n    shareReplay,\n    switchMap,\n    tap\n} from 'rxjs/operators';\n\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { FoehnInputTextComponent } from '../foehn-input/foehn-input-text.component';\nimport { ObjectHelper } from '../helpers/object.helper';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { Address, Country, Locality, Street } from './address.type';\nimport { FoehnInputForeignLocalityComponent } from './foehn-input-foreign-locality.component';\nimport { FoehnInputForeignStreetComponent } from './foehn-input-foreign-street.component';\n\n// eslint-disable max-classes-per-file\nexport const SWISS_ISO_ID = 'CH';\n\nexport class StreetNumber {\n    name: string;\n}\n\nconst isDefined = (value: boolean): boolean =>\n    value === true || value === false;\n\nconst hasInputChanged = (change: SimpleChange): boolean =>\n    change && !ObjectHelper.isEqual(change.previousValue, change.currentValue);\n\n@Component({\n    selector: 'foehn-input-address',\n    templateUrl: './foehn-input-address.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnInputAddressComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnInputAddressComponent\n    extends FoehnInputComponent<Address>\n    implements OnInit, OnChanges, OnDestroy\n{\n    @ViewChild(FoehnInputForeignLocalityComponent, { static: false })\n    foreignLocalityComponent: FoehnInputForeignLocalityComponent;\n\n    @ViewChild(FoehnInputForeignStreetComponent, { static: false })\n    foreignStreetComponent: FoehnInputForeignStreetComponent;\n\n    @ViewChild('foreignHouseNumber', { static: false })\n    foreignHouseNumber: FoehnInputTextComponent;\n\n    @Input()\n    countriesUrl = 'api/refinf/countries';\n\n    @Input()\n    isOnlySwiss = true;\n\n    @Input()\n    showPostOfficeBoxText = false;\n\n    @Input()\n    showAdressLines = true;\n\n    @Input()\n    showAdressLine1 = true;\n\n    @Input()\n    showAdressLine2 = true;\n\n    @Input()\n    specifiedCanton: string;\n\n    @Input()\n    countryRequired = true;\n\n    @Input()\n    swissNpaLocalityRequired = true;\n\n    @Input()\n    streetRequired: boolean;\n\n    @Input()\n    streetNumberRequired = false;\n\n    @Input()\n    hideNotRequiredExtraLabelStreetNumber = true;\n\n    @Input()\n    foreignZipCodeRequired = true;\n\n    @Input()\n    foreignLocalityRequired = true;\n\n    @Input()\n    foreignStreetRequired: boolean;\n\n    @Input()\n    foreignStreetNumberRequired = false;\n\n    @Input()\n    postOfficeBoxTextRequired: boolean;\n\n    @Input()\n    addressLine1Required = false;\n\n    @Input()\n    addressLine2Required = false;\n\n    @Input()\n    withCompanyLocalities = false;\n\n    @Input()\n    withDefaultCountry = true;\n\n    country: Country;\n    locality: Locality;\n    street: Street;\n    houseNumber: string;\n    postOfficeBoxText: string;\n    addressLine1: string;\n    addressLine2: string;\n\n    countries: Observable<Country[]>;\n    localities: Observable<Locality[]>;\n    streets: Observable<Street[]>;\n    streetNumbers: Observable<StreetNumber[]>;\n\n    streetCustomErrors: { [key: string]: string } = {};\n\n    private iso2IdSubject = new BehaviorSubject<string>(null);\n    private zipCodeIdSubject = new BehaviorSubject<string>(null);\n    private estrIdSubject = new BehaviorSubject<string>(null);\n\n    private countryModelChangeSubject = new BehaviorSubject<Country>(null);\n    private isOnlySwissChangeSubject = new BehaviorSubject<boolean>(true);\n    private manageDefaultCountrySubscription: Subscription;\n\n    constructor(\n        private httpClient: HttpClient,\n        private dictionaryService: SdkDictionaryService\n    ) {\n        super();\n    }\n\n    identity = <T>(n: T): T => n;\n    countryIdentity = (country: Country): string => country.iso2Id;\n    localityIdentity = (loc: Locality): string => loc.zipCodeId;\n    streetIdentity = (street: Street): string => street.estrid;\n    streetGenerator = (longName: string): Street => ({\n        estrid: null,\n        longName\n    });\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.manageDefaultCountrySubscription = this.manageDefaultCountry();\n\n        if (!this.showPostOfficeBoxText) {\n            this.streetCustomErrors.AtLeastOneNotNull =\n                this.dictionaryService.getKeySync('errors.NotNull');\n        }\n\n        this.countries = this.getCountries();\n\n        this.localities = this.iso2IdSubject.pipe(\n            distinctUntilChanged(),\n            // The list of localities, or an empty array as the default value.\n            switchMap(iso2Id => this.getLocalities(iso2Id)),\n            shareReplay(1)\n        );\n\n        this.streets = combineLatest([\n            this.zipCodeIdSubject,\n            this.localities\n        ]).pipe(\n            // The zipCodeId when locality changes or match locality (postalLocalityHistoryId) from model\n            map(\n                ([zipCodeId, localities]) =>\n                    zipCodeId ||\n                    this.extractLocalityZipCodeId(localities, this.locality)\n            ),\n            distinctUntilChanged(),\n            // The list of streets or a default value to an empty array\n            switchMap(zipCodeId => this.getStreetsFor(zipCodeId)),\n            shareReplay(1)\n        );\n\n        this.streetNumbers = combineLatest([\n            this.estrIdSubject,\n            this.streets\n        ]).pipe(\n            // The estrid when street changes or match street (longName) from model\n            map(\n                ([estrid, streets]) =>\n                    estrid || this.extractStreetEstrid(streets, this.street)\n            ),\n            distinctUntilChanged(),\n            // The list of streets or a default value to an empty array\n            switchMap(estrid => this.getStreetNumberFor(estrid)),\n            // Some street might not have an name, RefInf sometimes returns weird data.\n            map(values => values.filter(streetNumber => !!streetNumber.name)),\n            map(values => {\n                const collator = new Intl.Collator(undefined, {\n                    numeric: true,\n                    sensitivity: 'base'\n                });\n                return values.sort((a, b) => collator.compare(a.name, b.name));\n            }),\n            shareReplay(1)\n        );\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.manageDefaultCountrySubscription?.unsubscribe();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const modelChange: SimpleChange = changes.model;\n        const isOnlySwiss: SimpleChange = changes.isOnlySwiss;\n\n        if (hasInputChanged(modelChange)) {\n            this.countryModelChangeSubject.next(\n                modelChange.currentValue?.country\n            );\n        }\n        if (hasInputChanged(isOnlySwiss)) {\n            this.isOnlySwissChangeSubject.next(isOnlySwiss.currentValue);\n        }\n    }\n\n    updateAddress(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    updateNgModel(value: Address): void {\n        if (!!value) {\n            // avoid wrongfull prefill by session info\n            if (!this.showAdressLines || !this.showAdressLine1) {\n                value.addressLine1 = null;\n            }\n            if (!this.showAdressLines || !this.showAdressLine2) {\n                value.addressLine2 = null;\n            }\n            if (!this.showPostOfficeBoxText) {\n                value.postOfficeBoxText = null;\n            }\n            // never updatable in the component\n            value.postOfficeBoxNumber = null;\n        }\n\n        super.updateNgModel(value);\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    onModelChange(value: Address): void {\n        if (value) {\n            this.country = value.country;\n            this.locality = value.locality;\n            this.street = value.street;\n            this.houseNumber = value.houseNumber;\n            this.postOfficeBoxText = value.postOfficeBoxText;\n            this.addressLine1 = value.addressLine1;\n            this.addressLine2 = value.addressLine2;\n        } else if (!value) {\n            // country is managed by `manageDefaultCountry()`\n            this.locality = null;\n            this.street = null;\n            this.houseNumber = null;\n            this.postOfficeBoxText = null;\n            this.addressLine1 = null;\n            this.addressLine2 = null;\n        }\n    }\n\n    isSwiss(): boolean {\n        return !!(\n            this.isOnlySwiss ||\n            (this.country && this.country.iso2Id === SWISS_ISO_ID)\n        );\n    }\n\n    userInputCountry(): void {\n        this.zipCodeIdSubject.next(null);\n        this.estrIdSubject.next(null);\n\n        this.locality = null;\n        this.street = null;\n        this.houseNumber = null;\n        this.postOfficeBoxText = null;\n        this.addressLine1 = null;\n        this.addressLine2 = null;\n\n        this.updateAddress();\n        this.handleUserInput();\n    }\n\n    userInputLocality(locality: unknown): void {\n        if (!locality) {\n            this.zipCodeIdSubject.next(null);\n        }\n        // Always reset suggestion list of houseNumber when locality changes\n        this.estrIdSubject.next(null);\n\n        this.street = null;\n        this.houseNumber = null;\n\n        this.updateAddress();\n        this.handleUserInput();\n    }\n\n    userInputStreet(street: unknown): void {\n        if (!street) {\n            this.estrIdSubject.next(null);\n        }\n        this.houseNumber = null;\n        this.handleUserInput();\n    }\n\n    countryUpdated(country: Country): void {\n        // No double-binding on country in view to ensure we update properly model\n        this.country = country;\n        this.updateAddress();\n\n        if (!country) {\n            return;\n        }\n\n        const { iso2Id } = country;\n        this.iso2IdSubject.next(iso2Id);\n    }\n\n    getLocalityDisplayedName(locality: Locality): string | void {\n        if (!locality) {\n            return;\n        }\n\n        return `${locality.zipCode} ${locality.longName}`;\n    }\n\n    localityUpdated(locality: Locality): void {\n        // No double-binding on locality in view to ensure we update properly model\n        this.locality = locality;\n        this.updateAddress();\n\n        if (!locality) {\n            return;\n        }\n\n        const { zipCodeId } = locality;\n        this.zipCodeIdSubject.next(zipCodeId);\n    }\n\n    streetUpdated(street: Street): void {\n        // No double-binding on street in view to ensure we update properly model\n        this.street = street;\n        this.updateAddress();\n\n        if (!street) {\n            return;\n        }\n\n        const { estrid } = street;\n        this.estrIdSubject.next(estrid);\n    }\n\n    isStreetRequired(): boolean {\n        if (isDefined(this.streetRequired)) {\n            // respect overriden value\n            return this.streetRequired;\n        }\n\n        if (!this.showPostOfficeBoxText) {\n            return true;\n        }\n\n        return !this.postOfficeBoxText || !!this.street;\n    }\n\n    isForeignStreetRequired(): boolean {\n        if (isDefined(this.foreignStreetRequired)) {\n            // respect overriden value\n            return this.foreignStreetRequired;\n        }\n\n        if (!this.showPostOfficeBoxText) {\n            return true;\n        }\n\n        return !this.postOfficeBoxText || !!this.street;\n    }\n\n    isPostOfficeBoxTextRequired(): boolean {\n        if (isDefined(this.postOfficeBoxTextRequired)) {\n            // respect overriden value\n            return this.postOfficeBoxTextRequired;\n        }\n        return !this.street || !!this.postOfficeBoxText;\n    }\n\n    private getCountries(): Observable<Country[]> {\n        return this.httpClient.get<Country[]>(this.countriesUrl);\n    }\n\n    private getLocalities(iso2Id: string): Observable<Locality[]> {\n        if (iso2Id !== SWISS_ISO_ID) {\n            return of([]);\n        }\n\n        const queryParams = !!this.withCompanyLocalities\n            ? '?withCompanyLocalities=true'\n            : '';\n\n        if (!!this.specifiedCanton) {\n            return this.httpClient.get<Locality[]>(\n                `api/refinf/locality/${this.specifiedCanton}${queryParams}`\n            );\n        } else {\n            return this.httpClient.get<Locality[]>(\n                `api/refinf/locality/all${queryParams}`\n            );\n        }\n    }\n\n    private getStreetNumberFor(estrid: string): Observable<StreetNumber[]> {\n        if (!estrid) {\n            return of([]);\n        }\n\n        const url = `api/refinf/addresses/${estrid}`;\n        return this.httpClient.get<StreetNumber[]>(url);\n    }\n\n    private getStreetsFor(zipCodeId: string): Observable<Street[]> {\n        if (!zipCodeId) {\n            return of([]);\n        }\n\n        const url = `api/refinf/streets/${zipCodeId}`;\n        return this.httpClient.get<Street[]>(url);\n    }\n\n    private clearAutocompletesWhenCountryIsUnappropriatedToComponentConfiguration(): void {\n        if (this.isModelEmpty()) {\n            return;\n        }\n\n        if (this.isOnlySwiss && this.country?.iso2Id !== SWISS_ISO_ID) {\n            // Do not remove this warning. Needed for debugging at all time.\n            console.warn(\n                // eslint-disable-next-line max-len\n                `Country address was '${this.country.iso2Id}'. Only swiss is asked in component 'foehn-input-address' configuration. Address model resetted.`\n            );\n            this.clearAutocompletes();\n        }\n    }\n\n    private getSwissCountry(): Country {\n        return {\n            iso2Id: SWISS_ISO_ID,\n            shortNameFr: 'Suisse'\n        };\n    }\n\n    private setDefaultCountry(): void {\n        if (\n            this.withDefaultCountry &&\n            (this.isOnlySwiss || !this.country || !this.country.iso2Id)\n        ) {\n            this.country = this.getSwissCountry();\n            this.iso2IdSubject.next(SWISS_ISO_ID);\n\n            this.updateAddress();\n        }\n    }\n\n    private clearAutocompletes(): void {\n        this.country = null;\n        this.street = null;\n        this.locality = null;\n        this.houseNumber = null;\n        // No updateAddress() here because done in setDefaultCountry()\n    }\n\n    private extractLocalityZipCodeId(\n        localities: Locality[],\n        localityToMatch: Locality\n    ): string {\n        if (localityToMatch && localityToMatch.postalLocalityHistoryId) {\n            const matched = localities.find(\n                (locality: Locality) =>\n                    locality.postalLocalityHistoryId ===\n                    localityToMatch.postalLocalityHistoryId\n            );\n            if (matched) {\n                return matched.zipCodeId;\n            }\n        }\n\n        return null;\n    }\n\n    private extractStreetEstrid(\n        streets: Street[],\n        streetToMatch: Street\n    ): string {\n        if (streetToMatch && streetToMatch.longName) {\n            const matched = streets.find(\n                (street: Street) => street.longName === streetToMatch.longName\n            );\n            if (matched) {\n                return matched.estrid;\n            }\n        }\n\n        return null;\n    }\n\n    private getValidCountry(): Country {\n        // Be sure to always send Swiss country when 'isOnlySwiss' is set to true\n        return this.isOnlySwiss ? this.getSwissCountry() : this.country;\n    }\n\n    private getValidValue(): Address | null | undefined {\n        if (this.isModelEmpty()) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        return {\n            country: this.getValidCountry(),\n            locality: this.getValidLocality(this.locality),\n            street: this.street,\n            houseNumber: this.houseNumber,\n            postOfficeBoxText: this.postOfficeBoxText,\n            addressLine1: this.addressLine1,\n            addressLine2: this.addressLine2\n        };\n    }\n\n    private getValidLocality(value: Locality): Locality {\n        // PRESTAKIT-352: Need a fake 'zipCodeId' for individual errors on 'zipCode' and 'longName'\n        if (!this.isSwiss() && !value) {\n            return { zipCodeId: '-1' };\n        }\n\n        return value;\n    }\n\n    private isModelEmpty(): boolean {\n        return (\n            (this.isOnlySwiss ||\n                !this.country ||\n                ObjectHelper.isEmpty(this.country)) &&\n            (!this.locality || ObjectHelper.isEmpty(this.locality)) &&\n            (!this.street || ObjectHelper.isEmpty(this.street)) &&\n            this.isEmpty(this.houseNumber) &&\n            this.isEmpty(this.postOfficeBoxText) &&\n            this.isEmpty(this.addressLine1) &&\n            this.isEmpty(this.addressLine2)\n        );\n    }\n\n    private manageDefaultCountry(): Subscription {\n        return (\n            combineLatest([\n                this.countryModelChangeSubject.asObservable().pipe(\n                    debounceTime(0),\n                    distinctUntilChanged(\n                        (previous, current) =>\n                            previous?.iso2Id === current?.iso2Id\n                    )\n                ),\n                this.isOnlySwissChangeSubject\n                    .asObservable()\n                    .pipe(debounceTime(0), distinctUntilChanged())\n            ])\n                .pipe(\n                    tap(([country, isOnlySwiss]) => {\n                        if (!isOnlySwiss && !country) {\n                            this.setDefaultCountry();\n                            return;\n                        }\n\n                        if (isOnlySwiss) {\n                            // When there is a country, we need to check if it has to be cleaned and set to default\n                            if (!!country && !ObjectHelper.isEmpty(country)) {\n                                this.clearAutocompletesWhenCountryIsUnappropriatedToComponentConfiguration();\n                            }\n                            this.setDefaultCountry();\n                            return;\n                        }\n                    })\n                )\n                // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n                .subscribe()\n        );\n    }\n}\n","<div\n    [attr.id]=\"buildId() + 'Container'\"\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [tabIndex]=\"-1\"\n>\n    <fieldset\n        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend\n            *ngIf=\"!!label\"\n            [ngClass]=\"isLabelSrOnly ? 'visually-hidden' : 'vd-p'\"\n        >\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <foehn-autocomplete\n            *ngIf=\"!isOnlySwiss\"\n            [label]=\"'foehn-input-address.country.label' | fromDictionary\"\n            [elements]=\"countries | async\"\n            elementLabel=\"shortNameFr\"\n            [elementValue]=\"identity\"\n            [elementValueIdentity]=\"countryIdentity\"\n            (modelChange)=\"countryUpdated($event)\"\n            (userInput)=\"userInputCountry()\"\n            [model]=\"country\"\n            [name]=\"name + '.country'\"\n            [required]=\"countryRequired\"\n            [disabled]=\"disabled\"\n        ></foehn-autocomplete>\n\n        <ng-container *ngIf=\"isSwiss()\">\n            <foehn-autocomplete\n                [label]=\"'foehn-input-address.locality.label' | fromDictionary\"\n                [elements]=\"localities | async\"\n                [elementLabel]=\"getLocalityDisplayedName\"\n                [elementValue]=\"identity\"\n                [elementValueIdentity]=\"localityIdentity\"\n                (modelChange)=\"localityUpdated($event)\"\n                (userInput)=\"userInputLocality($event)\"\n                [model]=\"locality\"\n                [name]=\"name + '.locality'\"\n                [allowCustomValue]=\"disabled\"\n                [required]=\"swissNpaLocalityRequired\"\n                [disabled]=\"disabled\"\n            ></foehn-autocomplete>\n\n            <foehn-autocomplete\n                [label]=\"'foehn-input-address.street.label' | fromDictionary\"\n                [elements]=\"streets | async\"\n                elementLabel=\"longName\"\n                [elementValue]=\"identity\"\n                [elementValueIdentity]=\"streetIdentity\"\n                (modelChange)=\"streetUpdated($event)\"\n                [model]=\"street\"\n                [name]=\"name + '.street'\"\n                [allowCustomValue]=\"true\"\n                [customValueModelGenerator]=\"streetGenerator\"\n                [required]=\"isStreetRequired()\"\n                [helpText]=\"\n                    'foehn-input-address.street.help-text' | fromDictionary\n                \"\n                [customErrors]=\"streetCustomErrors\"\n                (userInput)=\"userInputStreet($event)\"\n                [disabled]=\"disabled\"\n            ></foehn-autocomplete>\n\n            <foehn-autocomplete\n                [label]=\"\n                    'foehn-input-address.houseNumber.label' | fromDictionary\n                \"\n                [elements]=\"streetNumbers | async\"\n                elementLabel=\"name\"\n                elementValue=\"name\"\n                [(model)]=\"houseNumber\"\n                [name]=\"name + '.houseNumber'\"\n                [allowCustomValue]=\"true\"\n                [helpText]=\"\n                    'foehn-input-address.houseNumber.help-text' | fromDictionary\n                \"\n                (modelChange)=\"updateAddress()\"\n                (userInput)=\"handleUserInput()\"\n                [required]=\"streetNumberRequired\"\n                [hideNotRequiredExtraLabel]=\"\n                    hideNotRequiredExtraLabelStreetNumber\n                \"\n                [disabled]=\"disabled\"\n            ></foehn-autocomplete>\n        </ng-container>\n\n        <ng-container *ngIf=\"!isSwiss()\">\n            <!--\n            Component <foehn-input-foreign-locality> is special because we use the same model when swiss or foreigner.\n            To do so, we need:\n                - Errors will be bind on 'locality' when NULL or on 'zipCode' and 'longName' model inside component when EMPTY\n                - Hide label from component because we need label from children to be displayed (isLabelSrOnly: true)\n                - required and disabled params are transmitted to children\n             -->\n            <foehn-input-foreign-locality\n                [label]=\"'foehn-input-address.locality.label' | fromDictionary\"\n                [name]=\"name + '.locality'\"\n                [(model)]=\"locality\"\n                [zipCodeRequired]=\"foreignZipCodeRequired\"\n                [localityRequired]=\"foreignLocalityRequired\"\n                [isLabelSrOnly]=\"true\"\n                [disabled]=\"!country || disabled\"\n                (modelChange)=\"updateAddress()\"\n                (userInput)=\"handleUserInput()\"\n            ></foehn-input-foreign-locality>\n            <!--\n            Component <foehn-input-foreign-street> is special because we use the same model when swiss or foreigner.\n            To do so, we need:\n                - Errors will be bind on 'street' when NULL or on 'longName' model inside component when EMPTY\n                - required, helpText, isLabelSrOnly and disabled  params are transmitted to children\n             -->\n            <foehn-input-foreign-street\n                [label]=\"'foehn-input-address.street.label' | fromDictionary\"\n                [name]=\"name + '.street'\"\n                [(model)]=\"street\"\n                [required]=\"isForeignStreetRequired()\"\n                [helpText]=\"\n                    'foehn-input-address.street.help-text' | fromDictionary\n                \"\n                [customErrors]=\"streetCustomErrors\"\n                [disabled]=\"!country || disabled\"\n                (modelChange)=\"updateAddress()\"\n                (userInput)=\"handleUserInput()\"\n            ></foehn-input-foreign-street>\n\n            <foehn-input-text\n                #foreignHouseNumber\n                [label]=\"\n                    'foehn-input-address.houseNumber.label' | fromDictionary\n                \"\n                [name]=\"name + '.houseNumber'\"\n                [(model)]=\"houseNumber\"\n                [helpText]=\"\n                    'foehn-input-address.houseNumber.help-text' | fromDictionary\n                \"\n                [disabled]=\"!country || disabled\"\n                (modelChange)=\"updateAddress()\"\n                (userInput)=\"handleUserInput()\"\n                [required]=\"foreignStreetNumberRequired\"\n            ></foehn-input-text>\n        </ng-container>\n\n        <foehn-input-text\n            *ngIf=\"showPostOfficeBoxText\"\n            [(model)]=\"postOfficeBoxText\"\n            [helpText]=\"\n                'foehn-input-address.postOfficeBoxText.help-text'\n                    | fromDictionary\n            \"\n            [label]=\"\n                'foehn-input-address.postOfficeBoxText.label' | fromDictionary\n            \"\n            [name]=\"name + '.postOfficeBoxText'\"\n            (modelChange)=\"updateAddress()\"\n            (userInput)=\"handleUserInput()\"\n            [required]=\"isPostOfficeBoxTextRequired()\"\n            [disabled]=\"disabled\"\n        ></foehn-input-text>\n\n        <foehn-input-text\n            *ngIf=\"showAdressLines && showAdressLine1\"\n            [(model)]=\"addressLine1\"\n            [label]=\"'foehn-input-address.addressLine1.label' | fromDictionary\"\n            [name]=\"name + '.addressLine1'\"\n            (modelChange)=\"updateAddress()\"\n            (userInput)=\"handleUserInput()\"\n            [required]=\"addressLine1Required\"\n            [autocomplete]=\"'address-line2'\"\n            [disabled]=\"disabled\"\n        ></foehn-input-text>\n\n        <foehn-input-text\n            *ngIf=\"showAdressLines && showAdressLine2\"\n            [(model)]=\"addressLine2\"\n            [label]=\"'foehn-input-address.addressLine2.label' | fromDictionary\"\n            [name]=\"name + '.addressLine2'\"\n            (modelChange)=\"updateAddress()\"\n            (userInput)=\"handleUserInput()\"\n            [required]=\"addressLine2Required\"\n            [autocomplete]=\"'address-line3'\"\n            [disabled]=\"disabled\"\n        ></foehn-input-text>\n    </fieldset>\n</div>\n"]}
@@ -244,7 +244,7 @@ export class FoehnMultiselectAutocompleteComponent extends FoehnAutocompleteComp
244
244
  useExisting: forwardRef(() => FoehnMultiselectAutocompleteComponent),
245
245
  multi: true
246
246
  }
247
- ], viewQueries: [{ propertyName: "autocompleteComponent", first: true, predicate: ["autocompleteComponent"], descendants: true }, { propertyName: "alertMessageContainer", first: true, predicate: ["alertMessageContainer"], descendants: true }, { propertyName: "defaultDeleteFocusArea", first: true, predicate: ["defaultDeleteFocusArea"], descendants: true }, { propertyName: "selectedElemRef", predicate: ["selectedElemRef"], descendants: true }, { propertyName: "defaultElemRef", predicate: ["defaultElemRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group container-box\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n>\n <foehn-autocomplete\n #autocompleteComponent\n [name]=\"name\"\n [label]=\"label\"\n [elements]=\"elements\"\n [elementsUrl]=\"elementsUrl\"\n [elementValue]=\"elementValue\"\n [elementLabel]=\"elementLabel\"\n [elementSuggestionLabel]=\"elementSuggestionLabel\"\n [elementValueIdentity]=\"elementValueIdentity\"\n [elementDisabled]=\"elementDisabled\"\n [elementGroup]=\"elementGroup\"\n [allowCustomValue]=\"false\"\n [searchValueMinCharsCount]=\"searchValueMinCharsCount\"\n [customValueModelGenerator]=\"customValueModelGenerator\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n (userInput)=\"addItem($event)\"\n [(model)]=\"autocompleteInputValue\"\n (elementsLoaded)=\"onAutocompleteElementsLoaded($event)\"\n [showErrorWhenDisabled]=\"showErrorWhenDisabled\"\n [hideNotRequiredExtraLabel]=\"hideNotRequiredExtraLabel\"\n [itemHeightInSuggestionListInPx]=\"itemHeightInSuggestionListInPx\"\n [caseSensitiveSearch]=\"caseSensitiveSearch\"\n >\n <small\n *ngIf=\"!showEmptyListMessage\"\n [attr.id]=\"buildChildId('Help')\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"\n helpText\n ? helpText\n : ('foehn-multiselect-autocomplete.autocomplete.screen-reader.label'\n | fromDictionary)\n \"\n ></small>\n\n <ng-content></ng-content>\n\n <div\n [id]=\"buildChildId('AlertMessageContainer')\"\n role=\"status\"\n #alertMessageContainer\n >\n <p\n *ngIf=\"showEmptyListMessage\"\n class=\"alert alert-info mb-0\"\n tabindex=\"0\"\n >\n {{\n 'foehn-multiselect-autocomplete.autocomplete.empty-message'\n | fromDictionary\n }}\n </p>\n </div>\n </foehn-autocomplete>\n\n <div class=\"selected-list-container pt-2\" tabindex=\"-1\">\n <small\n *ngIf=\"hasDefaultDeleteFocusArea()\"\n class=\"form-text text-secondary my-0\"\n [tabindex]=\"0\"\n [innerHTML]=\"noElementsSelectedLabel | fromDictionary\"\n #defaultDeleteFocusArea\n ></small>\n\n <p\n [id]=\"buildChildId('srOnlyAnnouncements')\"\n class=\"visually-hidden\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n >\n {{ srAnnouncements }}\n </p>\n\n <fieldset\n *ngIf=\"!!model?.length\"\n class=\"mb-0\"\n [attr.aria-describedby]=\"buildChildId('Label')\"\n >\n <legend\n [id]=\"buildChildId('Legend')\"\n class=\"form-text text-secondary small mb-0\"\n [innerHTML]=\"selectedItemsListLegend | fromDictionary\"\n ></legend>\n\n <div class=\"selected-list d-flex align-content-stretch flex-wrap\">\n <ng-container\n *ngFor=\"\n let element of model;\n let index = index;\n trackBy: trackByFn\n \"\n >\n <span\n *ngIf=\"!canBeDeleted(index)\"\n class=\"badge rounded-pill bg-secondary me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"disabled ? -1 : 0\"\n [attr.aria-describedby]=\"buildChildId('Legend')\"\n #defaultElemRef\n >\n {{ getBadgeLabel(element) }}\n <span class=\"visually-hidden\">\n {{\n 'foehn-multiselect-autocomplete.sr-default-selected-element'\n | fromDictionary\n }}\n </span>\n </span>\n <button\n *ngIf=\"canBeDeleted(index)\"\n type=\"button\"\n class=\"btn btn-primary badge rounded-pill me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"0\"\n [attr.aria-label]=\"getDeleteButtonAriaLabel(element)\"\n [attr.aria-describedby]=\"buildChildId('Legend')\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n (click)=\"removeItem(element, index)\"\n #selectedElemRef\n >\n {{ getBadgeLabel(element) }}\n <foehn-icon-times\n aria-hidden=\"true\"\n class=\"ms-2\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n ></foehn-icon-times>\n </button>\n </ng-container>\n </div>\n </fieldset>\n </div>\n</div>\n", styles: ["foehn-autocomplete p.alert:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}:host ::ng-deep foehn-autocomplete .form-group{margin-bottom:0!important}.selected-list-container .btn{text-transform:none}:host ::ng-deep .btn .svg-inline--fa{color:#fff!important}.selected-list-container span.rounded-pill:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}.container-box{border:1px solid #ededed;background-color:#fbfbfb;padding:.5rem}.container-box.vd-form-group-danger{border-left:5px solid var(--vd-danger);padding-left:1rem}:host ::ng-deep foehn-autocomplete div.vd-form-group-danger{border-left:0;padding-left:0}\n"], dependencies: [{ kind: "component", type: i2.FoehnAutocompleteComponent, selector: "foehn-autocomplete", inputs: ["searchValueMinCharsCount", "allowCustomValue", "isSuggestionListDynamic", "customValueModelGenerator", "itemHeightInSuggestionListInPx", "elementSuggestionLabel", "caseSensitiveSearch", "disabled"], outputs: ["userSearchInput"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.FoehnIconTimesComponent, selector: "foehn-icon-times" }, { kind: "pipe", type: i5.SdkDictionaryPipe, name: "fromDictionary" }] }); }
247
+ ], viewQueries: [{ propertyName: "autocompleteComponent", first: true, predicate: ["autocompleteComponent"], descendants: true }, { propertyName: "alertMessageContainer", first: true, predicate: ["alertMessageContainer"], descendants: true }, { propertyName: "defaultDeleteFocusArea", first: true, predicate: ["defaultDeleteFocusArea"], descendants: true }, { propertyName: "selectedElemRef", predicate: ["selectedElemRef"], descendants: true }, { propertyName: "defaultElemRef", predicate: ["defaultElemRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group container-box\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n>\n <foehn-autocomplete\n #autocompleteComponent\n [name]=\"name\"\n [label]=\"label\"\n [elements]=\"elements\"\n [elementsUrl]=\"elementsUrl\"\n [elementValue]=\"elementValue\"\n [elementLabel]=\"elementLabel\"\n [elementSuggestionLabel]=\"elementSuggestionLabel\"\n [elementValueIdentity]=\"elementValueIdentity\"\n [elementDisabled]=\"elementDisabled\"\n [elementGroup]=\"elementGroup\"\n [allowCustomValue]=\"false\"\n [searchValueMinCharsCount]=\"searchValueMinCharsCount\"\n [customValueModelGenerator]=\"customValueModelGenerator\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n (userInput)=\"addItem($event)\"\n [(model)]=\"autocompleteInputValue\"\n (elementsLoaded)=\"onAutocompleteElementsLoaded($event)\"\n [showErrorWhenDisabled]=\"showErrorWhenDisabled\"\n [hideNotRequiredExtraLabel]=\"hideNotRequiredExtraLabel\"\n [itemHeightInSuggestionListInPx]=\"itemHeightInSuggestionListInPx\"\n [caseSensitiveSearch]=\"caseSensitiveSearch\"\n [isLabelSrOnly]=\"isLabelSrOnly\"\n [isSuggestionListDynamic]=\"isSuggestionListDynamic\"\n >\n <small\n *ngIf=\"!showEmptyListMessage\"\n [attr.id]=\"buildChildId('Help')\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"\n helpText\n ? helpText\n : ('foehn-multiselect-autocomplete.autocomplete.screen-reader.label'\n | fromDictionary)\n \"\n ></small>\n\n <ng-content></ng-content>\n\n <div\n [id]=\"buildChildId('AlertMessageContainer')\"\n role=\"status\"\n #alertMessageContainer\n >\n <p\n *ngIf=\"showEmptyListMessage\"\n class=\"alert alert-info mb-0\"\n tabindex=\"0\"\n >\n {{\n 'foehn-multiselect-autocomplete.autocomplete.empty-message'\n | fromDictionary\n }}\n </p>\n </div>\n </foehn-autocomplete>\n\n <div class=\"selected-list-container pt-2\" tabindex=\"-1\">\n <small\n *ngIf=\"hasDefaultDeleteFocusArea()\"\n class=\"form-text text-secondary my-0\"\n [tabindex]=\"0\"\n [innerHTML]=\"noElementsSelectedLabel | fromDictionary\"\n #defaultDeleteFocusArea\n ></small>\n\n <p\n [id]=\"buildChildId('srOnlyAnnouncements')\"\n class=\"visually-hidden\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n >\n {{ srAnnouncements }}\n </p>\n\n <fieldset\n *ngIf=\"!!model?.length\"\n class=\"mb-0\"\n [attr.aria-describedby]=\"buildChildId('Label')\"\n >\n <legend\n [id]=\"buildChildId('Legend')\"\n class=\"form-text text-secondary small mb-0\"\n [innerHTML]=\"selectedItemsListLegend | fromDictionary\"\n ></legend>\n\n <div class=\"selected-list d-flex align-content-stretch flex-wrap\">\n <ng-container\n *ngFor=\"\n let element of model;\n let index = index;\n trackBy: trackByFn\n \"\n >\n <span\n *ngIf=\"!canBeDeleted(index)\"\n class=\"badge rounded-pill bg-secondary me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"disabled ? -1 : 0\"\n [attr.aria-describedby]=\"buildChildId('Legend')\"\n #defaultElemRef\n >\n {{ getBadgeLabel(element) }}\n <span class=\"visually-hidden\">\n {{\n 'foehn-multiselect-autocomplete.sr-default-selected-element'\n | fromDictionary\n }}\n </span>\n </span>\n <button\n *ngIf=\"canBeDeleted(index)\"\n type=\"button\"\n class=\"btn btn-primary badge rounded-pill me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"0\"\n [attr.aria-label]=\"getDeleteButtonAriaLabel(element)\"\n [attr.aria-describedby]=\"buildChildId('Legend')\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n (click)=\"removeItem(element, index)\"\n #selectedElemRef\n >\n {{ getBadgeLabel(element) }}\n <foehn-icon-times\n aria-hidden=\"true\"\n class=\"ms-2\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n ></foehn-icon-times>\n </button>\n </ng-container>\n </div>\n </fieldset>\n </div>\n</div>\n", styles: ["foehn-autocomplete p.alert:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}:host ::ng-deep foehn-autocomplete .form-group{margin-bottom:0!important}.selected-list-container .btn{text-transform:none}:host ::ng-deep .btn .svg-inline--fa{color:#fff!important}.selected-list-container span.rounded-pill:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}.container-box{border:1px solid #ededed;background-color:#fbfbfb;padding:.5rem}.container-box.vd-form-group-danger{border-left:5px solid var(--vd-danger);padding-left:1rem}:host ::ng-deep foehn-autocomplete div.vd-form-group-danger{border-left:0;padding-left:0}\n"], dependencies: [{ kind: "component", type: i2.FoehnAutocompleteComponent, selector: "foehn-autocomplete", inputs: ["searchValueMinCharsCount", "allowCustomValue", "isSuggestionListDynamic", "customValueModelGenerator", "itemHeightInSuggestionListInPx", "elementSuggestionLabel", "caseSensitiveSearch", "disabled"], outputs: ["userSearchInput"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.FoehnIconTimesComponent, selector: "foehn-icon-times" }, { kind: "pipe", type: i5.SdkDictionaryPipe, name: "fromDictionary" }] }); }
248
248
  }
249
249
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FoehnMultiselectAutocompleteComponent, decorators: [{
250
250
  type: Component,
@@ -254,7 +254,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
254
254
  useExisting: forwardRef(() => FoehnMultiselectAutocompleteComponent),
255
255
  multi: true
256
256
  }
257
- ], template: "<div\n class=\"form-group container-box\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n>\n <foehn-autocomplete\n #autocompleteComponent\n [name]=\"name\"\n [label]=\"label\"\n [elements]=\"elements\"\n [elementsUrl]=\"elementsUrl\"\n [elementValue]=\"elementValue\"\n [elementLabel]=\"elementLabel\"\n [elementSuggestionLabel]=\"elementSuggestionLabel\"\n [elementValueIdentity]=\"elementValueIdentity\"\n [elementDisabled]=\"elementDisabled\"\n [elementGroup]=\"elementGroup\"\n [allowCustomValue]=\"false\"\n [searchValueMinCharsCount]=\"searchValueMinCharsCount\"\n [customValueModelGenerator]=\"customValueModelGenerator\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n (userInput)=\"addItem($event)\"\n [(model)]=\"autocompleteInputValue\"\n (elementsLoaded)=\"onAutocompleteElementsLoaded($event)\"\n [showErrorWhenDisabled]=\"showErrorWhenDisabled\"\n [hideNotRequiredExtraLabel]=\"hideNotRequiredExtraLabel\"\n [itemHeightInSuggestionListInPx]=\"itemHeightInSuggestionListInPx\"\n [caseSensitiveSearch]=\"caseSensitiveSearch\"\n >\n <small\n *ngIf=\"!showEmptyListMessage\"\n [attr.id]=\"buildChildId('Help')\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"\n helpText\n ? helpText\n : ('foehn-multiselect-autocomplete.autocomplete.screen-reader.label'\n | fromDictionary)\n \"\n ></small>\n\n <ng-content></ng-content>\n\n <div\n [id]=\"buildChildId('AlertMessageContainer')\"\n role=\"status\"\n #alertMessageContainer\n >\n <p\n *ngIf=\"showEmptyListMessage\"\n class=\"alert alert-info mb-0\"\n tabindex=\"0\"\n >\n {{\n 'foehn-multiselect-autocomplete.autocomplete.empty-message'\n | fromDictionary\n }}\n </p>\n </div>\n </foehn-autocomplete>\n\n <div class=\"selected-list-container pt-2\" tabindex=\"-1\">\n <small\n *ngIf=\"hasDefaultDeleteFocusArea()\"\n class=\"form-text text-secondary my-0\"\n [tabindex]=\"0\"\n [innerHTML]=\"noElementsSelectedLabel | fromDictionary\"\n #defaultDeleteFocusArea\n ></small>\n\n <p\n [id]=\"buildChildId('srOnlyAnnouncements')\"\n class=\"visually-hidden\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n >\n {{ srAnnouncements }}\n </p>\n\n <fieldset\n *ngIf=\"!!model?.length\"\n class=\"mb-0\"\n [attr.aria-describedby]=\"buildChildId('Label')\"\n >\n <legend\n [id]=\"buildChildId('Legend')\"\n class=\"form-text text-secondary small mb-0\"\n [innerHTML]=\"selectedItemsListLegend | fromDictionary\"\n ></legend>\n\n <div class=\"selected-list d-flex align-content-stretch flex-wrap\">\n <ng-container\n *ngFor=\"\n let element of model;\n let index = index;\n trackBy: trackByFn\n \"\n >\n <span\n *ngIf=\"!canBeDeleted(index)\"\n class=\"badge rounded-pill bg-secondary me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"disabled ? -1 : 0\"\n [attr.aria-describedby]=\"buildChildId('Legend')\"\n #defaultElemRef\n >\n {{ getBadgeLabel(element) }}\n <span class=\"visually-hidden\">\n {{\n 'foehn-multiselect-autocomplete.sr-default-selected-element'\n | fromDictionary\n }}\n </span>\n </span>\n <button\n *ngIf=\"canBeDeleted(index)\"\n type=\"button\"\n class=\"btn btn-primary badge rounded-pill me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"0\"\n [attr.aria-label]=\"getDeleteButtonAriaLabel(element)\"\n [attr.aria-describedby]=\"buildChildId('Legend')\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n (click)=\"removeItem(element, index)\"\n #selectedElemRef\n >\n {{ getBadgeLabel(element) }}\n <foehn-icon-times\n aria-hidden=\"true\"\n class=\"ms-2\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n ></foehn-icon-times>\n </button>\n </ng-container>\n </div>\n </fieldset>\n </div>\n</div>\n", styles: ["foehn-autocomplete p.alert:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}:host ::ng-deep foehn-autocomplete .form-group{margin-bottom:0!important}.selected-list-container .btn{text-transform:none}:host ::ng-deep .btn .svg-inline--fa{color:#fff!important}.selected-list-container span.rounded-pill:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}.container-box{border:1px solid #ededed;background-color:#fbfbfb;padding:.5rem}.container-box.vd-form-group-danger{border-left:5px solid var(--vd-danger);padding-left:1rem}:host ::ng-deep foehn-autocomplete div.vd-form-group-danger{border-left:0;padding-left:0}\n"] }]
257
+ ], template: "<div\n class=\"form-group container-box\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n>\n <foehn-autocomplete\n #autocompleteComponent\n [name]=\"name\"\n [label]=\"label\"\n [elements]=\"elements\"\n [elementsUrl]=\"elementsUrl\"\n [elementValue]=\"elementValue\"\n [elementLabel]=\"elementLabel\"\n [elementSuggestionLabel]=\"elementSuggestionLabel\"\n [elementValueIdentity]=\"elementValueIdentity\"\n [elementDisabled]=\"elementDisabled\"\n [elementGroup]=\"elementGroup\"\n [allowCustomValue]=\"false\"\n [searchValueMinCharsCount]=\"searchValueMinCharsCount\"\n [customValueModelGenerator]=\"customValueModelGenerator\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n (userInput)=\"addItem($event)\"\n [(model)]=\"autocompleteInputValue\"\n (elementsLoaded)=\"onAutocompleteElementsLoaded($event)\"\n [showErrorWhenDisabled]=\"showErrorWhenDisabled\"\n [hideNotRequiredExtraLabel]=\"hideNotRequiredExtraLabel\"\n [itemHeightInSuggestionListInPx]=\"itemHeightInSuggestionListInPx\"\n [caseSensitiveSearch]=\"caseSensitiveSearch\"\n [isLabelSrOnly]=\"isLabelSrOnly\"\n [isSuggestionListDynamic]=\"isSuggestionListDynamic\"\n >\n <small\n *ngIf=\"!showEmptyListMessage\"\n [attr.id]=\"buildChildId('Help')\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"\n helpText\n ? helpText\n : ('foehn-multiselect-autocomplete.autocomplete.screen-reader.label'\n | fromDictionary)\n \"\n ></small>\n\n <ng-content></ng-content>\n\n <div\n [id]=\"buildChildId('AlertMessageContainer')\"\n role=\"status\"\n #alertMessageContainer\n >\n <p\n *ngIf=\"showEmptyListMessage\"\n class=\"alert alert-info mb-0\"\n tabindex=\"0\"\n >\n {{\n 'foehn-multiselect-autocomplete.autocomplete.empty-message'\n | fromDictionary\n }}\n </p>\n </div>\n </foehn-autocomplete>\n\n <div class=\"selected-list-container pt-2\" tabindex=\"-1\">\n <small\n *ngIf=\"hasDefaultDeleteFocusArea()\"\n class=\"form-text text-secondary my-0\"\n [tabindex]=\"0\"\n [innerHTML]=\"noElementsSelectedLabel | fromDictionary\"\n #defaultDeleteFocusArea\n ></small>\n\n <p\n [id]=\"buildChildId('srOnlyAnnouncements')\"\n class=\"visually-hidden\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n >\n {{ srAnnouncements }}\n </p>\n\n <fieldset\n *ngIf=\"!!model?.length\"\n class=\"mb-0\"\n [attr.aria-describedby]=\"buildChildId('Label')\"\n >\n <legend\n [id]=\"buildChildId('Legend')\"\n class=\"form-text text-secondary small mb-0\"\n [innerHTML]=\"selectedItemsListLegend | fromDictionary\"\n ></legend>\n\n <div class=\"selected-list d-flex align-content-stretch flex-wrap\">\n <ng-container\n *ngFor=\"\n let element of model;\n let index = index;\n trackBy: trackByFn\n \"\n >\n <span\n *ngIf=\"!canBeDeleted(index)\"\n class=\"badge rounded-pill bg-secondary me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"disabled ? -1 : 0\"\n [attr.aria-describedby]=\"buildChildId('Legend')\"\n #defaultElemRef\n >\n {{ getBadgeLabel(element) }}\n <span class=\"visually-hidden\">\n {{\n 'foehn-multiselect-autocomplete.sr-default-selected-element'\n | fromDictionary\n }}\n </span>\n </span>\n <button\n *ngIf=\"canBeDeleted(index)\"\n type=\"button\"\n class=\"btn btn-primary badge rounded-pill me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n [tabindex]=\"0\"\n [attr.aria-label]=\"getDeleteButtonAriaLabel(element)\"\n [attr.aria-describedby]=\"buildChildId('Legend')\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n (click)=\"removeItem(element, index)\"\n #selectedElemRef\n >\n {{ getBadgeLabel(element) }}\n <foehn-icon-times\n aria-hidden=\"true\"\n class=\"ms-2\"\n [title]=\"getDeleteButtonAriaLabel(element)\"\n ></foehn-icon-times>\n </button>\n </ng-container>\n </div>\n </fieldset>\n </div>\n</div>\n", styles: ["foehn-autocomplete p.alert:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}:host ::ng-deep foehn-autocomplete .form-group{margin-bottom:0!important}.selected-list-container .btn{text-transform:none}:host ::ng-deep .btn .svg-inline--fa{color:#fff!important}.selected-list-container span.rounded-pill:focus{outline:0;box-shadow:inset 0 1px 1px #00000013,0 0 0 .2rem var(--vd-focus)}.container-box{border:1px solid #ededed;background-color:#fbfbfb;padding:.5rem}.container-box.vd-form-group-danger{border-left:5px solid var(--vd-danger);padding-left:1rem}:host ::ng-deep foehn-autocomplete div.vd-form-group-danger{border-left:0;padding-left:0}\n"] }]
258
258
  }], ctorParameters: () => [{ type: i0.NgZone }, { type: i1.SdkDictionaryService }], propDecorators: { hostName: [{
259
259
  type: HostBinding,
260
260
  args: ['attr.name']
@@ -284,4 +284,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
284
284
  }], defaultElementValue: [{
285
285
  type: Input
286
286
  }] } });
287
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-multiselect-autocomplete.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.ts","../../../../projects/prestations-ng/src/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n    Component,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    Input,\n    NgZone,\n    OnInit,\n    QueryList,\n    ViewChild,\n    ViewChildren\n} from '@angular/core';\nimport { first } from 'rxjs/operators';\n\nimport { FoehnAutocompleteComponent } from '../foehn-autocomplete/foehn-autocomplete.component';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { ObjectHelper } from '../helpers/object.helper';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\n\n@Component({\n    selector: 'foehn-multiselect-autocomplete',\n    templateUrl: './foehn-multiselect-autocomplete.component.html',\n    styleUrls: ['./foehn-multiselect-autocomplete.component.css'],\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(\n                () => FoehnMultiselectAutocompleteComponent\n            ),\n            multi: true\n        }\n    ]\n})\nexport class FoehnMultiselectAutocompleteComponent\n    extends FoehnAutocompleteComponent\n    implements OnInit\n{\n    @HostBinding('attr.name')\n    hostName: string;\n\n    @ViewChild('autocompleteComponent')\n    autocompleteComponent: FoehnAutocompleteComponent;\n\n    @ViewChild('alertMessageContainer')\n    alertMessageContainer: ElementRef;\n\n    @ViewChildren('selectedElemRef')\n    selectedElemRef: QueryList<ElementRef>;\n\n    @ViewChildren('defaultElemRef')\n    defaultElemRef: QueryList<ElementRef>;\n\n    @ViewChild('defaultDeleteFocusArea')\n    defaultDeleteFocusArea: ElementRef;\n\n    /**\n     * The label in the object. Can be a string or a function\n     * Defaults to `label`\n     */\n    @Input()\n    elementBadgeLabel: any = 'label';\n\n    @Input()\n    selectedItemsListLegend =\n        'foehn-multiselect-autocomplete.selected-items-list-legend';\n\n    @Input()\n    noElementsSelectedLabel =\n        'foehn-multiselect-autocomplete.sr-default-focus.no-element-to-delete';\n\n    autocompleteInputValue: string;\n    showEmptyListMessage = false;\n    srAnnouncements = '';\n\n    private defaultElementValues_: unknown[];\n    private srAnnouncementClearTimer: any;\n    private readonly SR_ANNOUNCEMENT_CLEAR_TIMEOUT_INTERVAL_MS = 2000;\n\n    constructor(\n        ngZone: NgZone,\n        private dictionaryService: SdkDictionaryService\n    ) {\n        super(ngZone);\n    }\n\n    get defaultElementValues(): unknown[] {\n        return this.defaultElementValues_;\n    }\n\n    @Input()\n    set defaultElementValues(items: unknown[]) {\n        this.defaultElementValues_ = [...items];\n        if ((!this.model || !this.model.length) && items) {\n            this.updateNgModel(items);\n        }\n    }\n\n    @Input()\n    set defaultElementValue(item: string) {\n        this.defaultElementValues = [item];\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        // The host is not related to foehn error management but foehn-autocomplete is.\n        this.hostId = this.buildId('ParentContainer');\n        this.hostName = this.hostId;\n        this.excludeFromErrorSummary = true;\n    }\n\n    onModelChange(value: any): void {\n        super.onModelChange(value);\n        if (!value || ObjectHelper.isEmpty(value)) {\n            this.manageSuggestionListAndFocusAfterRemovingAnItem(null);\n        }\n    }\n\n    hasErrorsToDisplay(): boolean {\n        return !!this.autocompleteComponent\n            ? this.autocompleteComponent.hasErrorsToDisplay()\n            : false;\n    }\n\n    updateMultiselectAutocomplete(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    addItem(item: unknown): void {\n        if (!!item) {\n            if (!this.model) {\n                this.model = [];\n            }\n\n            const index = this.model.indexOf(item);\n            if (index === -1) {\n                this.model.push(item);\n                this.updateMultiselectAutocomplete();\n                this.handleUserInput();\n                this.manageSuggestionListAndFocusAfterAddingAnItem();\n                this.manageScreenReaderAnnouncement(item, false);\n            }\n        }\n    }\n\n    removeItem(item: unknown, index: number): void {\n        this.model.splice(index, 1);\n        this.updateMultiselectAutocomplete();\n        this.handleUserInput();\n        this.manageSuggestionListAndFocusAfterRemovingAnItem(index);\n        this.manageScreenReaderAnnouncement(item, true);\n        this.autocompleteComponent.markAsDirty();\n    }\n\n    trackByFn(index: number): number {\n        return index;\n    }\n\n    getLabel(value: any): string {\n        const elem = this.findElementByModelItem(value);\n        return super.getLabel(elem);\n    }\n\n    canBeDeleted(index: number): boolean {\n        return (\n            !this.disabled &&\n            (!this.defaultElementValues ||\n                !this.defaultElementValues.includes(this.model[index]))\n        );\n    }\n\n    onAutocompleteElementsLoaded(elements: []): void {\n        // Need to wait for childView to be loaded\n        setTimeout(() => {\n            if (!!this.autocompleteComponent) {\n                this.autocompleteComponent.elements =\n                    this.filterAutocompleteElements(elements);\n                if (\n                    !this.disabled &&\n                    !this.autocompleteComponent.elements.length\n                ) {\n                    this.showAlertMessageAndHideAutocomplete();\n                }\n            }\n        });\n    }\n\n    getDeleteButtonAriaLabel(element: unknown): string {\n        return `${this.dictionaryService.getKeySync(\n            'foehn-multiselect-autocomplete.selected.delete',\n            { elementLabel: this.getLabel(element) }\n        )}`;\n    }\n\n    hasDefaultDeleteFocusArea(): boolean {\n        return (\n            !this.disabled &&\n            !this.defaultElementValues?.length &&\n            !this.model?.length\n        );\n    }\n\n    getBadgeLabel(element: any): string {\n        if (typeof this.elementBadgeLabel === 'string') {\n            return this.getLabel(element);\n        }\n        return this.elementBadgeLabel(element);\n    }\n\n    private findElementByModelItem(item: unknown): unknown {\n        if (!!this.elements && !!this.elements.length) {\n            const itemValue: unknown =\n                typeof item !== 'object' ? item : this.getValue(item);\n            const elem = this.elements.find(\n                (element: unknown) => this.getValue(element) === itemValue\n            );\n            if (!!elem) {\n                return elem;\n            }\n        }\n        return item;\n    }\n\n    private getValidValue(): number[] | null | undefined {\n        if (!this.model || !this.model.length) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        return this.model;\n    }\n\n    private focusNextAreaAfterDelete(removedIndex: number): void {\n        // Adjust index depending on default elements that are not deletable\n        if (!!this.defaultElementValues) {\n            removedIndex -= this.defaultElementValues.length;\n        }\n        const closeButtonsElemRefArray = [...this.selectedElemRef.toArray()];\n        // Need to find an element to focus on\n        if (removedIndex === closeButtonsElemRefArray.length) {\n            if (!!closeButtonsElemRefArray.length) {\n                return closeButtonsElemRefArray[\n                    removedIndex - 1\n                ].nativeElement.focus();\n            }\n            const defaultElemRefArray = [...this.defaultElemRef.toArray()];\n            if (!!defaultElemRefArray.length) {\n                return defaultElemRefArray[\n                    defaultElemRefArray.length - 1\n                ].nativeElement.focus();\n            }\n            return this.defaultDeleteFocusArea.nativeElement.focus();\n        }\n        // Otherwise focus element by DOM replacement\n    }\n\n    private filterAutocompleteElements(elements: []): unknown {\n        const filteredElements = ObjectHelper.deepCopy(elements);\n        if (!!this.model && !!this.model.length) {\n            this.model.forEach((selected: unknown) => {\n                for (const [index, value] of filteredElements.entries()) {\n                    const elem = this.findElementByModelItem(selected);\n                    if (ObjectHelper.isEqual(elem, value)) {\n                        filteredElements.splice(index, 1);\n                        break;\n                    }\n                }\n            });\n        }\n        return filteredElements;\n    }\n\n    private manageSuggestionListAndFocusAfterAddingAnItem(): void {\n        // Empty autocomplete input\n        this.autocompleteInputValue = null;\n        // Remove selected item from autocomplete suggestion list\n        this.autocompleteComponent.elements = this.filterAutocompleteElements(\n            this.elements\n        );\n        // Check if we still have suggestions to display\n        if (!this.autocompleteComponent.elements.length) {\n            this.showAlertMessageAndHideAutocomplete();\n            // Need setTimeout to ensure alert message is on the DOM and can be focusable\n            setTimeout(() => {\n                const alertMessage: HTMLElement =\n                    this.alertMessageContainer.nativeElement.querySelector('p');\n                if (alertMessage) {\n                    alertMessage.focus();\n                }\n            });\n        }\n    }\n\n    private manageSuggestionListAndFocusAfterRemovingAnItem(\n        removedIndex: number\n    ): void {\n        // Hide message saying no more suggestions to display\n        this.showEmptyListMessage = false;\n        if (this.autocompleteComponent) {\n            // Manually show autocomplete because there is at least one suggestions to display\n            this.autocompleteComponent.inputElement.nativeElement.hidden =\n                false;\n            // Add back selected item to autocomplete suggestion list\n            this.autocompleteComponent.elements =\n                this.filterAutocompleteElements(this.elements);\n        }\n\n        if (removedIndex !== null) {\n            // When deleting a selected item, check were to set focus back when no more items to delete\n            // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n            this.selectedElemRef.changes.pipe(first()).subscribe(() => {\n                this.focusNextAreaAfterDelete(removedIndex);\n            });\n        }\n    }\n\n    private showAlertMessageAndHideAutocomplete(): void {\n        // Show a message to user indicating there is no more suggestions to display\n        this.showEmptyListMessage = true;\n        // Manually reset and hide autocomplete because there is no more suggestions to display\n        this.autocompleteInputValue = null;\n        this.autocompleteComponent.inputElement.nativeElement.hidden = true;\n    }\n\n    private manageScreenReaderAnnouncement(\n        element: unknown,\n        isDelete: boolean\n    ): void {\n        clearTimeout(this.srAnnouncementClearTimer);\n        if (isDelete) {\n            this.srAnnouncements += `${this.dictionaryService.getKeySync(\n                'foehn-multiselect-autocomplete.sr-announcement.deleted',\n                { elementLabel: this.getLabel(element) }\n            )}`;\n        } else {\n            this.srAnnouncements += `${this.dictionaryService.getKeySync(\n                'foehn-multiselect-autocomplete.sr-announcement.added',\n                { elementLabel: this.getLabel(element) }\n            )}`;\n        }\n        this.srAnnouncementClearTimer = setTimeout(() => {\n            this.srAnnouncements = '';\n        }, this.SR_ANNOUNCEMENT_CLEAR_TIMEOUT_INTERVAL_MS);\n    }\n}\n","<div\n    class=\"form-group container-box\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n>\n    <foehn-autocomplete\n        #autocompleteComponent\n        [name]=\"name\"\n        [label]=\"label\"\n        [elements]=\"elements\"\n        [elementsUrl]=\"elementsUrl\"\n        [elementValue]=\"elementValue\"\n        [elementLabel]=\"elementLabel\"\n        [elementSuggestionLabel]=\"elementSuggestionLabel\"\n        [elementValueIdentity]=\"elementValueIdentity\"\n        [elementDisabled]=\"elementDisabled\"\n        [elementGroup]=\"elementGroup\"\n        [allowCustomValue]=\"false\"\n        [searchValueMinCharsCount]=\"searchValueMinCharsCount\"\n        [customValueModelGenerator]=\"customValueModelGenerator\"\n        [required]=\"required\"\n        [disabled]=\"disabled\"\n        (userInput)=\"addItem($event)\"\n        [(model)]=\"autocompleteInputValue\"\n        (elementsLoaded)=\"onAutocompleteElementsLoaded($event)\"\n        [showErrorWhenDisabled]=\"showErrorWhenDisabled\"\n        [hideNotRequiredExtraLabel]=\"hideNotRequiredExtraLabel\"\n        [itemHeightInSuggestionListInPx]=\"itemHeightInSuggestionListInPx\"\n        [caseSensitiveSearch]=\"caseSensitiveSearch\"\n    >\n        <small\n            *ngIf=\"!showEmptyListMessage\"\n            [attr.id]=\"buildChildId('Help')\"\n            class=\"form-text text-secondary\"\n            [innerHTML]=\"\n                helpText\n                    ? helpText\n                    : ('foehn-multiselect-autocomplete.autocomplete.screen-reader.label'\n                      | fromDictionary)\n            \"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div\n            [id]=\"buildChildId('AlertMessageContainer')\"\n            role=\"status\"\n            #alertMessageContainer\n        >\n            <p\n                *ngIf=\"showEmptyListMessage\"\n                class=\"alert alert-info mb-0\"\n                tabindex=\"0\"\n            >\n                {{\n                    'foehn-multiselect-autocomplete.autocomplete.empty-message'\n                        | fromDictionary\n                }}\n            </p>\n        </div>\n    </foehn-autocomplete>\n\n    <div class=\"selected-list-container pt-2\" tabindex=\"-1\">\n        <small\n            *ngIf=\"hasDefaultDeleteFocusArea()\"\n            class=\"form-text text-secondary my-0\"\n            [tabindex]=\"0\"\n            [innerHTML]=\"noElementsSelectedLabel | fromDictionary\"\n            #defaultDeleteFocusArea\n        ></small>\n\n        <p\n            [id]=\"buildChildId('srOnlyAnnouncements')\"\n            class=\"visually-hidden\"\n            aria-live=\"polite\"\n            aria-atomic=\"true\"\n        >\n            {{ srAnnouncements }}\n        </p>\n\n        <fieldset\n            *ngIf=\"!!model?.length\"\n            class=\"mb-0\"\n            [attr.aria-describedby]=\"buildChildId('Label')\"\n        >\n            <legend\n                [id]=\"buildChildId('Legend')\"\n                class=\"form-text text-secondary small mb-0\"\n                [innerHTML]=\"selectedItemsListLegend | fromDictionary\"\n            ></legend>\n\n            <div class=\"selected-list d-flex align-content-stretch flex-wrap\">\n                <ng-container\n                    *ngFor=\"\n                        let element of model;\n                        let index = index;\n                        trackBy: trackByFn\n                    \"\n                >\n                    <span\n                        *ngIf=\"!canBeDeleted(index)\"\n                        class=\"badge rounded-pill bg-secondary me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n                        [tabindex]=\"disabled ? -1 : 0\"\n                        [attr.aria-describedby]=\"buildChildId('Legend')\"\n                        #defaultElemRef\n                    >\n                        {{ getBadgeLabel(element) }}\n                        <span class=\"visually-hidden\">\n                            {{\n                                'foehn-multiselect-autocomplete.sr-default-selected-element'\n                                    | fromDictionary\n                            }}\n                        </span>\n                    </span>\n                    <button\n                        *ngIf=\"canBeDeleted(index)\"\n                        type=\"button\"\n                        class=\"btn btn-primary badge rounded-pill me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n                        [tabindex]=\"0\"\n                        [attr.aria-label]=\"getDeleteButtonAriaLabel(element)\"\n                        [attr.aria-describedby]=\"buildChildId('Legend')\"\n                        [title]=\"getDeleteButtonAriaLabel(element)\"\n                        (click)=\"removeItem(element, index)\"\n                        #selectedElemRef\n                    >\n                        {{ getBadgeLabel(element) }}\n                        <foehn-icon-times\n                            aria-hidden=\"true\"\n                            class=\"ms-2\"\n                            [title]=\"getDeleteButtonAriaLabel(element)\"\n                        ></foehn-icon-times>\n                    </button>\n                </ng-container>\n            </div>\n        </fieldset>\n    </div>\n</div>\n"]}
287
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-multiselect-autocomplete.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.ts","../../../../projects/prestations-ng/src/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n    Component,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    Input,\n    NgZone,\n    OnInit,\n    QueryList,\n    ViewChild,\n    ViewChildren\n} from '@angular/core';\nimport { first } from 'rxjs/operators';\n\nimport { FoehnAutocompleteComponent } from '../foehn-autocomplete/foehn-autocomplete.component';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { ObjectHelper } from '../helpers/object.helper';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\n\n@Component({\n    selector: 'foehn-multiselect-autocomplete',\n    templateUrl: './foehn-multiselect-autocomplete.component.html',\n    styleUrls: ['./foehn-multiselect-autocomplete.component.css'],\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(\n                () => FoehnMultiselectAutocompleteComponent\n            ),\n            multi: true\n        }\n    ]\n})\nexport class FoehnMultiselectAutocompleteComponent\n    extends FoehnAutocompleteComponent\n    implements OnInit\n{\n    @HostBinding('attr.name')\n    hostName: string;\n\n    @ViewChild('autocompleteComponent')\n    autocompleteComponent: FoehnAutocompleteComponent;\n\n    @ViewChild('alertMessageContainer')\n    alertMessageContainer: ElementRef;\n\n    @ViewChildren('selectedElemRef')\n    selectedElemRef: QueryList<ElementRef>;\n\n    @ViewChildren('defaultElemRef')\n    defaultElemRef: QueryList<ElementRef>;\n\n    @ViewChild('defaultDeleteFocusArea')\n    defaultDeleteFocusArea: ElementRef;\n\n    /**\n     * The label in the object. Can be a string or a function\n     * Defaults to `label`\n     */\n    @Input()\n    elementBadgeLabel: any = 'label';\n\n    @Input()\n    selectedItemsListLegend =\n        'foehn-multiselect-autocomplete.selected-items-list-legend';\n\n    @Input()\n    noElementsSelectedLabel =\n        'foehn-multiselect-autocomplete.sr-default-focus.no-element-to-delete';\n\n    autocompleteInputValue: string;\n    showEmptyListMessage = false;\n    srAnnouncements = '';\n\n    private defaultElementValues_: unknown[];\n    private srAnnouncementClearTimer: any;\n    private readonly SR_ANNOUNCEMENT_CLEAR_TIMEOUT_INTERVAL_MS = 2000;\n\n    constructor(\n        ngZone: NgZone,\n        private dictionaryService: SdkDictionaryService\n    ) {\n        super(ngZone);\n    }\n\n    get defaultElementValues(): unknown[] {\n        return this.defaultElementValues_;\n    }\n\n    @Input()\n    set defaultElementValues(items: unknown[]) {\n        this.defaultElementValues_ = [...items];\n        if ((!this.model || !this.model.length) && items) {\n            this.updateNgModel(items);\n        }\n    }\n\n    @Input()\n    set defaultElementValue(item: string) {\n        this.defaultElementValues = [item];\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        // The host is not related to foehn error management but foehn-autocomplete is.\n        this.hostId = this.buildId('ParentContainer');\n        this.hostName = this.hostId;\n        this.excludeFromErrorSummary = true;\n    }\n\n    onModelChange(value: any): void {\n        super.onModelChange(value);\n        if (!value || ObjectHelper.isEmpty(value)) {\n            this.manageSuggestionListAndFocusAfterRemovingAnItem(null);\n        }\n    }\n\n    hasErrorsToDisplay(): boolean {\n        return !!this.autocompleteComponent\n            ? this.autocompleteComponent.hasErrorsToDisplay()\n            : false;\n    }\n\n    updateMultiselectAutocomplete(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    addItem(item: unknown): void {\n        if (!!item) {\n            if (!this.model) {\n                this.model = [];\n            }\n\n            const index = this.model.indexOf(item);\n            if (index === -1) {\n                this.model.push(item);\n                this.updateMultiselectAutocomplete();\n                this.handleUserInput();\n                this.manageSuggestionListAndFocusAfterAddingAnItem();\n                this.manageScreenReaderAnnouncement(item, false);\n            }\n        }\n    }\n\n    removeItem(item: unknown, index: number): void {\n        this.model.splice(index, 1);\n        this.updateMultiselectAutocomplete();\n        this.handleUserInput();\n        this.manageSuggestionListAndFocusAfterRemovingAnItem(index);\n        this.manageScreenReaderAnnouncement(item, true);\n        this.autocompleteComponent.markAsDirty();\n    }\n\n    trackByFn(index: number): number {\n        return index;\n    }\n\n    getLabel(value: any): string {\n        const elem = this.findElementByModelItem(value);\n        return super.getLabel(elem);\n    }\n\n    canBeDeleted(index: number): boolean {\n        return (\n            !this.disabled &&\n            (!this.defaultElementValues ||\n                !this.defaultElementValues.includes(this.model[index]))\n        );\n    }\n\n    onAutocompleteElementsLoaded(elements: []): void {\n        // Need to wait for childView to be loaded\n        setTimeout(() => {\n            if (!!this.autocompleteComponent) {\n                this.autocompleteComponent.elements =\n                    this.filterAutocompleteElements(elements);\n                if (\n                    !this.disabled &&\n                    !this.autocompleteComponent.elements.length\n                ) {\n                    this.showAlertMessageAndHideAutocomplete();\n                }\n            }\n        });\n    }\n\n    getDeleteButtonAriaLabel(element: unknown): string {\n        return `${this.dictionaryService.getKeySync(\n            'foehn-multiselect-autocomplete.selected.delete',\n            { elementLabel: this.getLabel(element) }\n        )}`;\n    }\n\n    hasDefaultDeleteFocusArea(): boolean {\n        return (\n            !this.disabled &&\n            !this.defaultElementValues?.length &&\n            !this.model?.length\n        );\n    }\n\n    getBadgeLabel(element: any): string {\n        if (typeof this.elementBadgeLabel === 'string') {\n            return this.getLabel(element);\n        }\n        return this.elementBadgeLabel(element);\n    }\n\n    private findElementByModelItem(item: unknown): unknown {\n        if (!!this.elements && !!this.elements.length) {\n            const itemValue: unknown =\n                typeof item !== 'object' ? item : this.getValue(item);\n            const elem = this.elements.find(\n                (element: unknown) => this.getValue(element) === itemValue\n            );\n            if (!!elem) {\n                return elem;\n            }\n        }\n        return item;\n    }\n\n    private getValidValue(): number[] | null | undefined {\n        if (!this.model || !this.model.length) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        return this.model;\n    }\n\n    private focusNextAreaAfterDelete(removedIndex: number): void {\n        // Adjust index depending on default elements that are not deletable\n        if (!!this.defaultElementValues) {\n            removedIndex -= this.defaultElementValues.length;\n        }\n        const closeButtonsElemRefArray = [...this.selectedElemRef.toArray()];\n        // Need to find an element to focus on\n        if (removedIndex === closeButtonsElemRefArray.length) {\n            if (!!closeButtonsElemRefArray.length) {\n                return closeButtonsElemRefArray[\n                    removedIndex - 1\n                ].nativeElement.focus();\n            }\n            const defaultElemRefArray = [...this.defaultElemRef.toArray()];\n            if (!!defaultElemRefArray.length) {\n                return defaultElemRefArray[\n                    defaultElemRefArray.length - 1\n                ].nativeElement.focus();\n            }\n            return this.defaultDeleteFocusArea.nativeElement.focus();\n        }\n        // Otherwise focus element by DOM replacement\n    }\n\n    private filterAutocompleteElements(elements: []): unknown {\n        const filteredElements = ObjectHelper.deepCopy(elements);\n        if (!!this.model && !!this.model.length) {\n            this.model.forEach((selected: unknown) => {\n                for (const [index, value] of filteredElements.entries()) {\n                    const elem = this.findElementByModelItem(selected);\n                    if (ObjectHelper.isEqual(elem, value)) {\n                        filteredElements.splice(index, 1);\n                        break;\n                    }\n                }\n            });\n        }\n        return filteredElements;\n    }\n\n    private manageSuggestionListAndFocusAfterAddingAnItem(): void {\n        // Empty autocomplete input\n        this.autocompleteInputValue = null;\n        // Remove selected item from autocomplete suggestion list\n        this.autocompleteComponent.elements = this.filterAutocompleteElements(\n            this.elements\n        );\n        // Check if we still have suggestions to display\n        if (!this.autocompleteComponent.elements.length) {\n            this.showAlertMessageAndHideAutocomplete();\n            // Need setTimeout to ensure alert message is on the DOM and can be focusable\n            setTimeout(() => {\n                const alertMessage: HTMLElement =\n                    this.alertMessageContainer.nativeElement.querySelector('p');\n                if (alertMessage) {\n                    alertMessage.focus();\n                }\n            });\n        }\n    }\n\n    private manageSuggestionListAndFocusAfterRemovingAnItem(\n        removedIndex: number\n    ): void {\n        // Hide message saying no more suggestions to display\n        this.showEmptyListMessage = false;\n        if (this.autocompleteComponent) {\n            // Manually show autocomplete because there is at least one suggestions to display\n            this.autocompleteComponent.inputElement.nativeElement.hidden =\n                false;\n            // Add back selected item to autocomplete suggestion list\n            this.autocompleteComponent.elements =\n                this.filterAutocompleteElements(this.elements);\n        }\n\n        if (removedIndex !== null) {\n            // When deleting a selected item, check were to set focus back when no more items to delete\n            // eslint-disable-next-line rxjs-angular/prefer-async-pipe\n            this.selectedElemRef.changes.pipe(first()).subscribe(() => {\n                this.focusNextAreaAfterDelete(removedIndex);\n            });\n        }\n    }\n\n    private showAlertMessageAndHideAutocomplete(): void {\n        // Show a message to user indicating there is no more suggestions to display\n        this.showEmptyListMessage = true;\n        // Manually reset and hide autocomplete because there is no more suggestions to display\n        this.autocompleteInputValue = null;\n        this.autocompleteComponent.inputElement.nativeElement.hidden = true;\n    }\n\n    private manageScreenReaderAnnouncement(\n        element: unknown,\n        isDelete: boolean\n    ): void {\n        clearTimeout(this.srAnnouncementClearTimer);\n        if (isDelete) {\n            this.srAnnouncements += `${this.dictionaryService.getKeySync(\n                'foehn-multiselect-autocomplete.sr-announcement.deleted',\n                { elementLabel: this.getLabel(element) }\n            )}`;\n        } else {\n            this.srAnnouncements += `${this.dictionaryService.getKeySync(\n                'foehn-multiselect-autocomplete.sr-announcement.added',\n                { elementLabel: this.getLabel(element) }\n            )}`;\n        }\n        this.srAnnouncementClearTimer = setTimeout(() => {\n            this.srAnnouncements = '';\n        }, this.SR_ANNOUNCEMENT_CLEAR_TIMEOUT_INTERVAL_MS);\n    }\n}\n","<div\n    class=\"form-group container-box\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n>\n    <foehn-autocomplete\n        #autocompleteComponent\n        [name]=\"name\"\n        [label]=\"label\"\n        [elements]=\"elements\"\n        [elementsUrl]=\"elementsUrl\"\n        [elementValue]=\"elementValue\"\n        [elementLabel]=\"elementLabel\"\n        [elementSuggestionLabel]=\"elementSuggestionLabel\"\n        [elementValueIdentity]=\"elementValueIdentity\"\n        [elementDisabled]=\"elementDisabled\"\n        [elementGroup]=\"elementGroup\"\n        [allowCustomValue]=\"false\"\n        [searchValueMinCharsCount]=\"searchValueMinCharsCount\"\n        [customValueModelGenerator]=\"customValueModelGenerator\"\n        [required]=\"required\"\n        [disabled]=\"disabled\"\n        (userInput)=\"addItem($event)\"\n        [(model)]=\"autocompleteInputValue\"\n        (elementsLoaded)=\"onAutocompleteElementsLoaded($event)\"\n        [showErrorWhenDisabled]=\"showErrorWhenDisabled\"\n        [hideNotRequiredExtraLabel]=\"hideNotRequiredExtraLabel\"\n        [itemHeightInSuggestionListInPx]=\"itemHeightInSuggestionListInPx\"\n        [caseSensitiveSearch]=\"caseSensitiveSearch\"\n        [isLabelSrOnly]=\"isLabelSrOnly\"\n        [isSuggestionListDynamic]=\"isSuggestionListDynamic\"\n    >\n        <small\n            *ngIf=\"!showEmptyListMessage\"\n            [attr.id]=\"buildChildId('Help')\"\n            class=\"form-text text-secondary\"\n            [innerHTML]=\"\n                helpText\n                    ? helpText\n                    : ('foehn-multiselect-autocomplete.autocomplete.screen-reader.label'\n                      | fromDictionary)\n            \"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div\n            [id]=\"buildChildId('AlertMessageContainer')\"\n            role=\"status\"\n            #alertMessageContainer\n        >\n            <p\n                *ngIf=\"showEmptyListMessage\"\n                class=\"alert alert-info mb-0\"\n                tabindex=\"0\"\n            >\n                {{\n                    'foehn-multiselect-autocomplete.autocomplete.empty-message'\n                        | fromDictionary\n                }}\n            </p>\n        </div>\n    </foehn-autocomplete>\n\n    <div class=\"selected-list-container pt-2\" tabindex=\"-1\">\n        <small\n            *ngIf=\"hasDefaultDeleteFocusArea()\"\n            class=\"form-text text-secondary my-0\"\n            [tabindex]=\"0\"\n            [innerHTML]=\"noElementsSelectedLabel | fromDictionary\"\n            #defaultDeleteFocusArea\n        ></small>\n\n        <p\n            [id]=\"buildChildId('srOnlyAnnouncements')\"\n            class=\"visually-hidden\"\n            aria-live=\"polite\"\n            aria-atomic=\"true\"\n        >\n            {{ srAnnouncements }}\n        </p>\n\n        <fieldset\n            *ngIf=\"!!model?.length\"\n            class=\"mb-0\"\n            [attr.aria-describedby]=\"buildChildId('Label')\"\n        >\n            <legend\n                [id]=\"buildChildId('Legend')\"\n                class=\"form-text text-secondary small mb-0\"\n                [innerHTML]=\"selectedItemsListLegend | fromDictionary\"\n            ></legend>\n\n            <div class=\"selected-list d-flex align-content-stretch flex-wrap\">\n                <ng-container\n                    *ngFor=\"\n                        let element of model;\n                        let index = index;\n                        trackBy: trackByFn\n                    \"\n                >\n                    <span\n                        *ngIf=\"!canBeDeleted(index)\"\n                        class=\"badge rounded-pill bg-secondary me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n                        [tabindex]=\"disabled ? -1 : 0\"\n                        [attr.aria-describedby]=\"buildChildId('Legend')\"\n                        #defaultElemRef\n                    >\n                        {{ getBadgeLabel(element) }}\n                        <span class=\"visually-hidden\">\n                            {{\n                                'foehn-multiselect-autocomplete.sr-default-selected-element'\n                                    | fromDictionary\n                            }}\n                        </span>\n                    </span>\n                    <button\n                        *ngIf=\"canBeDeleted(index)\"\n                        type=\"button\"\n                        class=\"btn btn-primary badge rounded-pill me-1 mb-1 py-2 px-3 d-flex align-items-center\"\n                        [tabindex]=\"0\"\n                        [attr.aria-label]=\"getDeleteButtonAriaLabel(element)\"\n                        [attr.aria-describedby]=\"buildChildId('Legend')\"\n                        [title]=\"getDeleteButtonAriaLabel(element)\"\n                        (click)=\"removeItem(element, index)\"\n                        #selectedElemRef\n                    >\n                        {{ getBadgeLabel(element) }}\n                        <foehn-icon-times\n                            aria-hidden=\"true\"\n                            class=\"ms-2\"\n                            [title]=\"getDeleteButtonAriaLabel(element)\"\n                        ></foehn-icon-times>\n                    </button>\n                </ng-container>\n            </div>\n        </fieldset>\n    </div>\n</div>\n"]}