@dsivd/prestations-ng 16.5.1-beta.3 → 16.5.1

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
@@ -23,6 +23,11 @@
23
23
  - [bo-multi-upload.service.ts](projects/prestations-ng/src/foehn-upload/foehn-bo-multi-upload/bo-multi-upload.service.ts)
24
24
  - now opens redirect modal to cyberLogin when adding or deleting a document fails due to required authentification
25
25
 
26
+ ### Fixed
27
+
28
+ - [foehn-multiselect-autocomplete.component.ts](projects/prestations-ng/src/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.ts)
29
+ - fixed bug where multi-select would remain hidden after clearing the model (when all elements were selected)
30
+
26
31
  ## [16.5.0] - must be aligned with prestations-be (16.5.0+)
27
32
 
28
33
  ### Updated
Binary file
@@ -44,6 +44,12 @@ export class FoehnMultiselectAutocompleteComponent extends FoehnAutocompleteComp
44
44
  this.hostName = this.hostId;
45
45
  this.excludeFromErrorSummary = true;
46
46
  }
47
+ onModelChange(value) {
48
+ super.onModelChange(value);
49
+ if (!value || ObjectHelper.isEmpty(value)) {
50
+ this.manageSuggestionListAndFocusAfterRemovingAnItem(null);
51
+ }
52
+ }
47
53
  hasErrorsToDisplay() {
48
54
  return !!this.autocompleteComponent
49
55
  ? this.autocompleteComponent.hasErrorsToDisplay()
@@ -195,15 +201,19 @@ export class FoehnMultiselectAutocompleteComponent extends FoehnAutocompleteComp
195
201
  manageSuggestionListAndFocusAfterRemovingAnItem(removedIndex) {
196
202
  // Hide message saying no more suggestions to display
197
203
  this.showEmptyListMessage = false;
198
- // Manually show autocomplete because there is at least one suggestions to display
199
- this.autocompleteComponent.inputElement.nativeElement.hidden = false;
200
- // Add back selected item to autocomplete suggestion list
201
- this.autocompleteComponent.elements = this.filterAutocompleteElements(this.elements);
202
- // When deleting a selected item, check were to set focus back when no more items to delete
203
- // eslint-disable-next-line rxjs-angular/prefer-async-pipe
204
- this.selectedElemRef.changes.pipe(first()).subscribe(() => {
205
- this.focusNextAreaAfterDelete(removedIndex);
206
- });
204
+ if (this.autocompleteComponent) {
205
+ // Manually show autocomplete because there is at least one suggestions to display
206
+ this.autocompleteComponent.inputElement.nativeElement.hidden = false;
207
+ // Add back selected item to autocomplete suggestion list
208
+ this.autocompleteComponent.elements = this.filterAutocompleteElements(this.elements);
209
+ }
210
+ if (removedIndex !== null) {
211
+ // When deleting a selected item, check were to set focus back when no more items to delete
212
+ // eslint-disable-next-line rxjs-angular/prefer-async-pipe
213
+ this.selectedElemRef.changes.pipe(first()).subscribe(() => {
214
+ this.focusNextAreaAfterDelete(removedIndex);
215
+ });
216
+ }
207
217
  }
208
218
  showAlertMessageAndHideAutocomplete() {
209
219
  // Show a message to user indicating there is no more suggestions to display
@@ -271,4 +281,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
271
281
  }], defaultElementValue: [{
272
282
  type: Input
273
283
  }] } });
274
- //# 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    @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    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 = this.filterAutocompleteElements(\n                    elements\n                );\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 = this.alertMessageContainer.nativeElement.querySelector(\n                    'p'\n                );\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        // Manually show autocomplete because there is at least one suggestions to display\n        this.autocompleteComponent.inputElement.nativeElement.hidden = false;\n        // Add back selected item to autocomplete suggestion list\n        this.autocompleteComponent.elements = this.filterAutocompleteElements(\n            this.elements\n        );\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    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=\"sr-only\"\n            aria-live=\"polite\"\n            aria-atomic=\"true\"\n        >\n            {{ srAnnouncements }}\n        </p>\n\n        <fieldset\n            *ngIf=\"!!model?.length\"\n            class=\"form-group 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 badge-pill badge-secondary mr-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=\"sr-only\">\n                            {{\n                                'foehn-multiselect-autocomplete.sr-default-selected-element'\n                                    | fromDictionary\n                            }}\n                        </span>\n                    </span>\n                    <button\n                        *ngIf=\"canBeDeleted(index)\"\n                        class=\"btn btn-primary badge badge-pill mr-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=\"ml-2\"\n                            [title]=\"getDeleteButtonAriaLabel(element)\"\n                        ></foehn-icon-times>\n                    </button>\n                </ng-container>\n            </div>\n        </fieldset>\n    </div>\n</div>\n"]}
284
+ //# 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    @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 = this.filterAutocompleteElements(\n                    elements\n                );\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 = this.alertMessageContainer.nativeElement.querySelector(\n                    'p'\n                );\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 = false;\n            // Add back selected item to autocomplete suggestion list\n            this.autocompleteComponent.elements = this.filterAutocompleteElements(\n                this.elements\n            );\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=\"sr-only\"\n            aria-live=\"polite\"\n            aria-atomic=\"true\"\n        >\n            {{ srAnnouncements }}\n        </p>\n\n        <fieldset\n            *ngIf=\"!!model?.length\"\n            class=\"form-group 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 badge-pill badge-secondary mr-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=\"sr-only\">\n                            {{\n                                'foehn-multiselect-autocomplete.sr-default-selected-element'\n                                    | fromDictionary\n                            }}\n                        </span>\n                    </span>\n                    <button\n                        *ngIf=\"canBeDeleted(index)\"\n                        class=\"btn btn-primary badge badge-pill mr-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=\"ml-2\"\n                            [title]=\"getDeleteButtonAriaLabel(element)\"\n                        ></foehn-icon-times>\n                    </button>\n                </ng-container>\n            </div>\n        </fieldset>\n    </div>\n</div>\n"]}
@@ -1,2 +1,2 @@
1
- export const supportedBrowsers = /((CPU[ +]OS|iPhone[ +]OS|CPU[ +]iPhone|CPU IPhone OS)[ +]+(14[_\.]0|14[_\.]([1-9]|\d{2,})|14[_\.]4|14[_\.]([5-9]|\d{2,})|14[_\.]8|14[_\.](9|\d{2,})|(1[5-9]|[2-9]\d|\d{3,})[_\.]\d+|15[_\.]0|15[_\.]([1-9]|\d{2,})|15[_\.]8|15[_\.](9|\d{2,})|(1[6-9]|[2-9]\d|\d{3,})[_\.]\d+|16[_\.]0|16[_\.]([1-9]|\d{2,})|(1[7-9]|[2-9]\d|\d{3,})[_\.]\d+|17[_\.]0|17[_\.]([1-9]|\d{2,})|(1[8-9]|[2-9]\d|\d{3,})[_\.]\d+)(?:[_\.]\d+)?)|(OperaMini(?:\/att)?\/?(\d+)?(?:\.\d+)?(?:\.\d+)?)|(Opera\/.+Opera Mobi.+Version\/(73\.0|73\.([1-9]|\d{2,})|(7[4-9]|[8-9]\d|\d{3,})\.\d+))|(Opera\/(73\.0|73\.([1-9]|\d{2,})|(7[4-9]|[8-9]\d|\d{3,})\.\d+).+Opera Mobi)|(Opera Mobi.+Opera(?:\/|\s+)(73\.0|73\.([1-9]|\d{2,})|(7[4-9]|[8-9]\d|\d{3,})\.\d+))|(SamsungBrowser\/(22\.0|22\.([1-9]|\d{2,})|(2[3-9]|[3-9]\d|\d{3,})\.\d+))|(Edge\/(85(?:\.0)?|85(?:\.([1-9]|\d{2,}))?|(8[6-9]|9\d|\d{3,})(?:\.\d+)?))|(HeadlessChrome((?:\/85\.0\.\d+)?|(?:\/85\.([1-9]|\d{2,})\.\d+)?|(?:\/(8[6-9]|9\d|\d{3,})\.\d+\.\d+)?))|((Chromium|Chrome)\/(85\.0|85\.([1-9]|\d{2,})|(8[6-9]|9\d|\d{3,})\.\d+)(?:\.\d+)?)|(Version\/(14\.0|14\.([1-9]|\d{2,})|(1[5-9]|[2-9]\d|\d{3,})\.\d+|15\.0|15\.([1-9]|\d{2,})|(1[6-9]|[2-9]\d|\d{3,})\.\d+|16\.0|16\.([1-9]|\d{2,})|(1[7-9]|[2-9]\d|\d{3,})\.\d+|17\.0|17\.([1-9]|\d{2,})|(1[8-9]|[2-9]\d|\d{3,})\.\d+)(?:\.\d+)?.*Safari\/)|(Firefox\/(68\.0|68\.([1-9]|\d{2,})|(69|[7-9]\d|\d{3,})\.\d+|80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+)\.\d+)|(Firefox\/(68\.0|68\.([1-9]|\d{2,})|(69|[7-9]\d|\d{3,})\.\d+|80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+)(pre|[ab]\d+[a-z]*)?)/;
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwcG9ydGVkLWJyb3dzZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvc3VwcG9ydGVkLWJyb3dzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsNmdEQUE2Z0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBzdXBwb3J0ZWRCcm93c2VycyA9IC8oKENQVVsgK11PU3xpUGhvbmVbICtdT1N8Q1BVWyArXWlQaG9uZXxDUFUgSVBob25lIE9TKVsgK10rKDE0W19cXC5dMHwxNFtfXFwuXShbMS05XXxcXGR7Mix9KXwxNFtfXFwuXTR8MTRbX1xcLl0oWzUtOV18XFxkezIsfSl8MTRbX1xcLl04fDE0W19cXC5dKDl8XFxkezIsfSl8KDFbNS05XXxbMi05XVxcZHxcXGR7Myx9KVtfXFwuXVxcZCt8MTVbX1xcLl0wfDE1W19cXC5dKFsxLTldfFxcZHsyLH0pfDE1W19cXC5dOHwxNVtfXFwuXSg5fFxcZHsyLH0pfCgxWzYtOV18WzItOV1cXGR8XFxkezMsfSlbX1xcLl1cXGQrfDE2W19cXC5dMHwxNltfXFwuXShbMS05XXxcXGR7Mix9KXwoMVs3LTldfFsyLTldXFxkfFxcZHszLH0pW19cXC5dXFxkK3wxN1tfXFwuXTB8MTdbX1xcLl0oWzEtOV18XFxkezIsfSl8KDFbOC05XXxbMi05XVxcZHxcXGR7Myx9KVtfXFwuXVxcZCspKD86W19cXC5dXFxkKyk/KXwoT3BlcmFNaW5pKD86XFwvYXR0KT9cXC8/KFxcZCspPyg/OlxcLlxcZCspPyg/OlxcLlxcZCspPyl8KE9wZXJhXFwvLitPcGVyYSBNb2JpLitWZXJzaW9uXFwvKDczXFwuMHw3M1xcLihbMS05XXxcXGR7Mix9KXwoN1s0LTldfFs4LTldXFxkfFxcZHszLH0pXFwuXFxkKykpfChPcGVyYVxcLyg3M1xcLjB8NzNcXC4oWzEtOV18XFxkezIsfSl8KDdbNC05XXxbOC05XVxcZHxcXGR7Myx9KVxcLlxcZCspLitPcGVyYSBNb2JpKXwoT3BlcmEgTW9iaS4rT3BlcmEoPzpcXC98XFxzKykoNzNcXC4wfDczXFwuKFsxLTldfFxcZHsyLH0pfCg3WzQtOV18WzgtOV1cXGR8XFxkezMsfSlcXC5cXGQrKSl8KFNhbXN1bmdCcm93c2VyXFwvKDIyXFwuMHwyMlxcLihbMS05XXxcXGR7Mix9KXwoMlszLTldfFszLTldXFxkfFxcZHszLH0pXFwuXFxkKykpfChFZGdlXFwvKDg1KD86XFwuMCk/fDg1KD86XFwuKFsxLTldfFxcZHsyLH0pKT98KDhbNi05XXw5XFxkfFxcZHszLH0pKD86XFwuXFxkKyk/KSl8KEhlYWRsZXNzQ2hyb21lKCg/OlxcLzg1XFwuMFxcLlxcZCspP3woPzpcXC84NVxcLihbMS05XXxcXGR7Mix9KVxcLlxcZCspP3woPzpcXC8oOFs2LTldfDlcXGR8XFxkezMsfSlcXC5cXGQrXFwuXFxkKyk/KSl8KChDaHJvbWl1bXxDaHJvbWUpXFwvKDg1XFwuMHw4NVxcLihbMS05XXxcXGR7Mix9KXwoOFs2LTldfDlcXGR8XFxkezMsfSlcXC5cXGQrKSg/OlxcLlxcZCspPyl8KFZlcnNpb25cXC8oMTRcXC4wfDE0XFwuKFsxLTldfFxcZHsyLH0pfCgxWzUtOV18WzItOV1cXGR8XFxkezMsfSlcXC5cXGQrfDE1XFwuMHwxNVxcLihbMS05XXxcXGR7Mix9KXwoMVs2LTldfFsyLTldXFxkfFxcZHszLH0pXFwuXFxkK3wxNlxcLjB8MTZcXC4oWzEtOV18XFxkezIsfSl8KDFbNy05XXxbMi05XVxcZHxcXGR7Myx9KVxcLlxcZCt8MTdcXC4wfDE3XFwuKFsxLTldfFxcZHsyLH0pfCgxWzgtOV18WzItOV1cXGR8XFxkezMsfSlcXC5cXGQrKSg/OlxcLlxcZCspPy4qU2FmYXJpXFwvKXwoRmlyZWZveFxcLyg2OFxcLjB8NjhcXC4oWzEtOV18XFxkezIsfSl8KDY5fFs3LTldXFxkfFxcZHszLH0pXFwuXFxkK3w4MFxcLjB8ODBcXC4oWzEtOV18XFxkezIsfSl8KDhbMS05XXw5XFxkfFxcZHszLH0pXFwuXFxkKylcXC5cXGQrKXwoRmlyZWZveFxcLyg2OFxcLjB8NjhcXC4oWzEtOV18XFxkezIsfSl8KDY5fFs3LTldXFxkfFxcZHszLH0pXFwuXFxkK3w4MFxcLjB8ODBcXC4oWzEtOV18XFxkezIsfSl8KDhbMS05XXw5XFxkfFxcZHszLH0pXFwuXFxkKykocHJlfFthYl1cXGQrW2Etel0qKT8pLztcbiJdfQ==
1
+ export const supportedBrowsers = /((CPU[ +]OS|iPhone[ +]OS|CPU[ +]iPhone|CPU IPhone OS)[ +]+(14[_\.]0|14[_\.]([1-9]|\d{2,})|14[_\.]4|14[_\.]([5-9]|\d{2,})|14[_\.]8|14[_\.](9|\d{2,})|(1[5-9]|[2-9]\d|\d{3,})[_\.]\d+|15[_\.]0|15[_\.]([1-9]|\d{2,})|15[_\.]8|15[_\.](9|\d{2,})|(1[6-9]|[2-9]\d|\d{3,})[_\.]\d+|16[_\.]0|16[_\.]([1-9]|\d{2,})|(1[7-9]|[2-9]\d|\d{3,})[_\.]\d+|17[_\.]0|17[_\.]([1-9]|\d{2,})|(1[8-9]|[2-9]\d|\d{3,})[_\.]\d+)(?:[_\.]\d+)?)|(OperaMini(?:\/att)?\/?(\d+)?(?:\.\d+)?(?:\.\d+)?)|(Opera\/.+Opera Mobi.+Version\/(80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+))|(Opera\/(80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+).+Opera Mobi)|(Opera Mobi.+Opera(?:\/|\s+)(80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+))|(SamsungBrowser\/(22\.0|22\.([1-9]|\d{2,})|(2[3-9]|[3-9]\d|\d{3,})\.\d+))|(Edge\/(85(?:\.0)?|85(?:\.([1-9]|\d{2,}))?|(8[6-9]|9\d|\d{3,})(?:\.\d+)?))|(HeadlessChrome((?:\/85\.0\.\d+)?|(?:\/85\.([1-9]|\d{2,})\.\d+)?|(?:\/(8[6-9]|9\d|\d{3,})\.\d+\.\d+)?))|((Chromium|Chrome)\/(85\.0|85\.([1-9]|\d{2,})|(8[6-9]|9\d|\d{3,})\.\d+)(?:\.\d+)?)|(Version\/(14\.0|14\.([1-9]|\d{2,})|(1[5-9]|[2-9]\d|\d{3,})\.\d+|15\.0|15\.([1-9]|\d{2,})|(1[6-9]|[2-9]\d|\d{3,})\.\d+|16\.0|16\.([1-9]|\d{2,})|(1[7-9]|[2-9]\d|\d{3,})\.\d+|17\.0|17\.([1-9]|\d{2,})|(1[8-9]|[2-9]\d|\d{3,})\.\d+)(?:\.\d+)?.*Safari\/)|(Firefox\/(68\.0|68\.([1-9]|\d{2,})|(69|[7-9]\d|\d{3,})\.\d+|80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+)\.\d+)|(Firefox\/(68\.0|68\.([1-9]|\d{2,})|(69|[7-9]\d|\d{3,})\.\d+|80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+)(pre|[ab]\d+[a-z]*)?)/;
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3VwcG9ydGVkLWJyb3dzZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvc3VwcG9ydGVkLWJyb3dzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsaWdEQUFpZ0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBzdXBwb3J0ZWRCcm93c2VycyA9IC8oKENQVVsgK11PU3xpUGhvbmVbICtdT1N8Q1BVWyArXWlQaG9uZXxDUFUgSVBob25lIE9TKVsgK10rKDE0W19cXC5dMHwxNFtfXFwuXShbMS05XXxcXGR7Mix9KXwxNFtfXFwuXTR8MTRbX1xcLl0oWzUtOV18XFxkezIsfSl8MTRbX1xcLl04fDE0W19cXC5dKDl8XFxkezIsfSl8KDFbNS05XXxbMi05XVxcZHxcXGR7Myx9KVtfXFwuXVxcZCt8MTVbX1xcLl0wfDE1W19cXC5dKFsxLTldfFxcZHsyLH0pfDE1W19cXC5dOHwxNVtfXFwuXSg5fFxcZHsyLH0pfCgxWzYtOV18WzItOV1cXGR8XFxkezMsfSlbX1xcLl1cXGQrfDE2W19cXC5dMHwxNltfXFwuXShbMS05XXxcXGR7Mix9KXwoMVs3LTldfFsyLTldXFxkfFxcZHszLH0pW19cXC5dXFxkK3wxN1tfXFwuXTB8MTdbX1xcLl0oWzEtOV18XFxkezIsfSl8KDFbOC05XXxbMi05XVxcZHxcXGR7Myx9KVtfXFwuXVxcZCspKD86W19cXC5dXFxkKyk/KXwoT3BlcmFNaW5pKD86XFwvYXR0KT9cXC8/KFxcZCspPyg/OlxcLlxcZCspPyg/OlxcLlxcZCspPyl8KE9wZXJhXFwvLitPcGVyYSBNb2JpLitWZXJzaW9uXFwvKDgwXFwuMHw4MFxcLihbMS05XXxcXGR7Mix9KXwoOFsxLTldfDlcXGR8XFxkezMsfSlcXC5cXGQrKSl8KE9wZXJhXFwvKDgwXFwuMHw4MFxcLihbMS05XXxcXGR7Mix9KXwoOFsxLTldfDlcXGR8XFxkezMsfSlcXC5cXGQrKS4rT3BlcmEgTW9iaSl8KE9wZXJhIE1vYmkuK09wZXJhKD86XFwvfFxccyspKDgwXFwuMHw4MFxcLihbMS05XXxcXGR7Mix9KXwoOFsxLTldfDlcXGR8XFxkezMsfSlcXC5cXGQrKSl8KFNhbXN1bmdCcm93c2VyXFwvKDIyXFwuMHwyMlxcLihbMS05XXxcXGR7Mix9KXwoMlszLTldfFszLTldXFxkfFxcZHszLH0pXFwuXFxkKykpfChFZGdlXFwvKDg1KD86XFwuMCk/fDg1KD86XFwuKFsxLTldfFxcZHsyLH0pKT98KDhbNi05XXw5XFxkfFxcZHszLH0pKD86XFwuXFxkKyk/KSl8KEhlYWRsZXNzQ2hyb21lKCg/OlxcLzg1XFwuMFxcLlxcZCspP3woPzpcXC84NVxcLihbMS05XXxcXGR7Mix9KVxcLlxcZCspP3woPzpcXC8oOFs2LTldfDlcXGR8XFxkezMsfSlcXC5cXGQrXFwuXFxkKyk/KSl8KChDaHJvbWl1bXxDaHJvbWUpXFwvKDg1XFwuMHw4NVxcLihbMS05XXxcXGR7Mix9KXwoOFs2LTldfDlcXGR8XFxkezMsfSlcXC5cXGQrKSg/OlxcLlxcZCspPyl8KFZlcnNpb25cXC8oMTRcXC4wfDE0XFwuKFsxLTldfFxcZHsyLH0pfCgxWzUtOV18WzItOV1cXGR8XFxkezMsfSlcXC5cXGQrfDE1XFwuMHwxNVxcLihbMS05XXxcXGR7Mix9KXwoMVs2LTldfFsyLTldXFxkfFxcZHszLH0pXFwuXFxkK3wxNlxcLjB8MTZcXC4oWzEtOV18XFxkezIsfSl8KDFbNy05XXxbMi05XVxcZHxcXGR7Myx9KVxcLlxcZCt8MTdcXC4wfDE3XFwuKFsxLTldfFxcZHsyLH0pfCgxWzgtOV18WzItOV1cXGR8XFxkezMsfSlcXC5cXGQrKSg/OlxcLlxcZCspPy4qU2FmYXJpXFwvKXwoRmlyZWZveFxcLyg2OFxcLjB8NjhcXC4oWzEtOV18XFxkezIsfSl8KDY5fFs3LTldXFxkfFxcZHszLH0pXFwuXFxkK3w4MFxcLjB8ODBcXC4oWzEtOV18XFxkezIsfSl8KDhbMS05XXw5XFxkfFxcZHszLH0pXFwuXFxkKylcXC5cXGQrKXwoRmlyZWZveFxcLyg2OFxcLjB8NjhcXC4oWzEtOV18XFxkezIsfSl8KDY5fFs3LTldXFxkfFxcZHszLH0pXFwuXFxkK3w4MFxcLjB8ODBcXC4oWzEtOV18XFxkezIsfSl8KDhbMS05XXw5XFxkfFxcZHszLH0pXFwuXFxkKykocHJlfFthYl1cXGQrW2Etel0qKT8pLztcbiJdfQ==
@@ -4475,7 +4475,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
4475
4475
  }]
4476
4476
  }], ctorParameters: function () { return [{ type: SessionInfo }, { type: GesdemEventService }, { type: GesdemHandlerService }]; } });
4477
4477
 
4478
- const supportedBrowsers = /((CPU[ +]OS|iPhone[ +]OS|CPU[ +]iPhone|CPU IPhone OS)[ +]+(14[_\.]0|14[_\.]([1-9]|\d{2,})|14[_\.]4|14[_\.]([5-9]|\d{2,})|14[_\.]8|14[_\.](9|\d{2,})|(1[5-9]|[2-9]\d|\d{3,})[_\.]\d+|15[_\.]0|15[_\.]([1-9]|\d{2,})|15[_\.]8|15[_\.](9|\d{2,})|(1[6-9]|[2-9]\d|\d{3,})[_\.]\d+|16[_\.]0|16[_\.]([1-9]|\d{2,})|(1[7-9]|[2-9]\d|\d{3,})[_\.]\d+|17[_\.]0|17[_\.]([1-9]|\d{2,})|(1[8-9]|[2-9]\d|\d{3,})[_\.]\d+)(?:[_\.]\d+)?)|(OperaMini(?:\/att)?\/?(\d+)?(?:\.\d+)?(?:\.\d+)?)|(Opera\/.+Opera Mobi.+Version\/(73\.0|73\.([1-9]|\d{2,})|(7[4-9]|[8-9]\d|\d{3,})\.\d+))|(Opera\/(73\.0|73\.([1-9]|\d{2,})|(7[4-9]|[8-9]\d|\d{3,})\.\d+).+Opera Mobi)|(Opera Mobi.+Opera(?:\/|\s+)(73\.0|73\.([1-9]|\d{2,})|(7[4-9]|[8-9]\d|\d{3,})\.\d+))|(SamsungBrowser\/(22\.0|22\.([1-9]|\d{2,})|(2[3-9]|[3-9]\d|\d{3,})\.\d+))|(Edge\/(85(?:\.0)?|85(?:\.([1-9]|\d{2,}))?|(8[6-9]|9\d|\d{3,})(?:\.\d+)?))|(HeadlessChrome((?:\/85\.0\.\d+)?|(?:\/85\.([1-9]|\d{2,})\.\d+)?|(?:\/(8[6-9]|9\d|\d{3,})\.\d+\.\d+)?))|((Chromium|Chrome)\/(85\.0|85\.([1-9]|\d{2,})|(8[6-9]|9\d|\d{3,})\.\d+)(?:\.\d+)?)|(Version\/(14\.0|14\.([1-9]|\d{2,})|(1[5-9]|[2-9]\d|\d{3,})\.\d+|15\.0|15\.([1-9]|\d{2,})|(1[6-9]|[2-9]\d|\d{3,})\.\d+|16\.0|16\.([1-9]|\d{2,})|(1[7-9]|[2-9]\d|\d{3,})\.\d+|17\.0|17\.([1-9]|\d{2,})|(1[8-9]|[2-9]\d|\d{3,})\.\d+)(?:\.\d+)?.*Safari\/)|(Firefox\/(68\.0|68\.([1-9]|\d{2,})|(69|[7-9]\d|\d{3,})\.\d+|80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+)\.\d+)|(Firefox\/(68\.0|68\.([1-9]|\d{2,})|(69|[7-9]\d|\d{3,})\.\d+|80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+)(pre|[ab]\d+[a-z]*)?)/;
4478
+ const supportedBrowsers = /((CPU[ +]OS|iPhone[ +]OS|CPU[ +]iPhone|CPU IPhone OS)[ +]+(14[_\.]0|14[_\.]([1-9]|\d{2,})|14[_\.]4|14[_\.]([5-9]|\d{2,})|14[_\.]8|14[_\.](9|\d{2,})|(1[5-9]|[2-9]\d|\d{3,})[_\.]\d+|15[_\.]0|15[_\.]([1-9]|\d{2,})|15[_\.]8|15[_\.](9|\d{2,})|(1[6-9]|[2-9]\d|\d{3,})[_\.]\d+|16[_\.]0|16[_\.]([1-9]|\d{2,})|(1[7-9]|[2-9]\d|\d{3,})[_\.]\d+|17[_\.]0|17[_\.]([1-9]|\d{2,})|(1[8-9]|[2-9]\d|\d{3,})[_\.]\d+)(?:[_\.]\d+)?)|(OperaMini(?:\/att)?\/?(\d+)?(?:\.\d+)?(?:\.\d+)?)|(Opera\/.+Opera Mobi.+Version\/(80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+))|(Opera\/(80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+).+Opera Mobi)|(Opera Mobi.+Opera(?:\/|\s+)(80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+))|(SamsungBrowser\/(22\.0|22\.([1-9]|\d{2,})|(2[3-9]|[3-9]\d|\d{3,})\.\d+))|(Edge\/(85(?:\.0)?|85(?:\.([1-9]|\d{2,}))?|(8[6-9]|9\d|\d{3,})(?:\.\d+)?))|(HeadlessChrome((?:\/85\.0\.\d+)?|(?:\/85\.([1-9]|\d{2,})\.\d+)?|(?:\/(8[6-9]|9\d|\d{3,})\.\d+\.\d+)?))|((Chromium|Chrome)\/(85\.0|85\.([1-9]|\d{2,})|(8[6-9]|9\d|\d{3,})\.\d+)(?:\.\d+)?)|(Version\/(14\.0|14\.([1-9]|\d{2,})|(1[5-9]|[2-9]\d|\d{3,})\.\d+|15\.0|15\.([1-9]|\d{2,})|(1[6-9]|[2-9]\d|\d{3,})\.\d+|16\.0|16\.([1-9]|\d{2,})|(1[7-9]|[2-9]\d|\d{3,})\.\d+|17\.0|17\.([1-9]|\d{2,})|(1[8-9]|[2-9]\d|\d{3,})\.\d+)(?:\.\d+)?.*Safari\/)|(Firefox\/(68\.0|68\.([1-9]|\d{2,})|(69|[7-9]\d|\d{3,})\.\d+|80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+)\.\d+)|(Firefox\/(68\.0|68\.([1-9]|\d{2,})|(69|[7-9]\d|\d{3,})\.\d+|80\.0|80\.([1-9]|\d{2,})|(8[1-9]|9\d|\d{3,})\.\d+)(pre|[ab]\d+[a-z]*)?)/;
4479
4479
 
4480
4480
  class FoehnPageModalService {
4481
4481
  constructor(applicationInfoService) {
@@ -11388,6 +11388,12 @@ class FoehnMultiselectAutocompleteComponent extends FoehnAutocompleteComponent {
11388
11388
  this.hostName = this.hostId;
11389
11389
  this.excludeFromErrorSummary = true;
11390
11390
  }
11391
+ onModelChange(value) {
11392
+ super.onModelChange(value);
11393
+ if (!value || ObjectHelper.isEmpty(value)) {
11394
+ this.manageSuggestionListAndFocusAfterRemovingAnItem(null);
11395
+ }
11396
+ }
11391
11397
  hasErrorsToDisplay() {
11392
11398
  return !!this.autocompleteComponent
11393
11399
  ? this.autocompleteComponent.hasErrorsToDisplay()
@@ -11540,15 +11546,19 @@ class FoehnMultiselectAutocompleteComponent extends FoehnAutocompleteComponent {
11540
11546
  manageSuggestionListAndFocusAfterRemovingAnItem(removedIndex) {
11541
11547
  // Hide message saying no more suggestions to display
11542
11548
  this.showEmptyListMessage = false;
11543
- // Manually show autocomplete because there is at least one suggestions to display
11544
- this.autocompleteComponent.inputElement.nativeElement.hidden = false;
11545
- // Add back selected item to autocomplete suggestion list
11546
- this.autocompleteComponent.elements = this.filterAutocompleteElements(this.elements);
11547
- // When deleting a selected item, check were to set focus back when no more items to delete
11548
- // eslint-disable-next-line rxjs-angular/prefer-async-pipe
11549
- this.selectedElemRef.changes.pipe(first()).subscribe(() => {
11550
- this.focusNextAreaAfterDelete(removedIndex);
11551
- });
11549
+ if (this.autocompleteComponent) {
11550
+ // Manually show autocomplete because there is at least one suggestions to display
11551
+ this.autocompleteComponent.inputElement.nativeElement.hidden = false;
11552
+ // Add back selected item to autocomplete suggestion list
11553
+ this.autocompleteComponent.elements = this.filterAutocompleteElements(this.elements);
11554
+ }
11555
+ if (removedIndex !== null) {
11556
+ // When deleting a selected item, check were to set focus back when no more items to delete
11557
+ // eslint-disable-next-line rxjs-angular/prefer-async-pipe
11558
+ this.selectedElemRef.changes.pipe(first()).subscribe(() => {
11559
+ this.focusNextAreaAfterDelete(removedIndex);
11560
+ });
11561
+ }
11552
11562
  }
11553
11563
  showAlertMessageAndHideAutocomplete() {
11554
11564
  // Show a message to user indicating there is no more suggestions to display