@dsivd/prestations-ng 15.2.1 → 15.2.3-beta10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (29) hide show
  1. package/CHANGELOG.md +35 -0
  2. package/dsivd-prestations-ng-v15.2.3-beta10.tgz +0 -0
  3. package/esm2020/foehn-checkables/foehn-checkable-group.component.mjs +9 -4
  4. package/esm2020/foehn-checkables/foehn-select.component.mjs +4 -17
  5. package/esm2020/foehn-confirm-modal/foehn-confirm-modal.component.mjs +1 -1
  6. package/esm2020/foehn-help-modal/foehn-help-modal.component.mjs +1 -1
  7. package/esm2020/foehn-menu-prestation/foehn-menu-items/foehn-menu-item-transmit/foehn-menu-item-transmit.component.mjs +1 -1
  8. package/esm2020/foehn-modal/foehn-modal.component.mjs +2 -5
  9. package/esm2020/foehn-page/foehn-page-modal.component.mjs +1 -1
  10. package/esm2020/foehn-table/foehn-table-column-configuration.mjs +1 -1
  11. package/esm2020/foehn-table/foehn-table.component.mjs +9 -8
  12. package/esm2020/gesdem/gesdem-handler.service.mjs +2 -1
  13. package/esm2020/gesdem-action-recovery/gesdem-action-recovery-registration/gesdem-action-recovery-registration.component.mjs +1 -1
  14. package/esm2020/sdk-dictionary/default-dictionary.mjs +2 -1
  15. package/esm2020/sdk-epayment/sdk-epayment.component.mjs +1 -1
  16. package/esm2020/sdk-redirect/iam-expired-interceptor.service.mjs +28 -16
  17. package/esm2020/sdk-redirect/redirect.component.mjs +10 -19
  18. package/fesm2015/dsivd-prestations-ng.mjs +54 -60
  19. package/fesm2015/dsivd-prestations-ng.mjs.map +1 -1
  20. package/fesm2020/dsivd-prestations-ng.mjs +54 -60
  21. package/fesm2020/dsivd-prestations-ng.mjs.map +1 -1
  22. package/foehn-checkables/foehn-checkable-group.component.d.ts +1 -1
  23. package/foehn-checkables/foehn-select.component.d.ts +0 -9
  24. package/foehn-modal/foehn-modal.component.d.ts +1 -2
  25. package/foehn-table/foehn-table-column-configuration.d.ts +11 -1
  26. package/package.json +2 -2
  27. package/sdk-redirect/iam-expired-interceptor.service.d.ts +2 -2
  28. package/sdk-redirect/redirect.component.d.ts +2 -8
  29. package/dsivd-prestations-ng-v15.2.1.tgz +0 -0
package/CHANGELOG.md CHANGED
@@ -26,6 +26,41 @@ A change is considered **breaking** if you have to change your code or update yo
26
26
 
27
27
  ---
28
28
 
29
+ ## [unreleased]
30
+
31
+ ### Added
32
+
33
+ - [foehn-table-column-configuration.ts](projects/prestations-ng/src/foehn-table/foehn-table-column-configuration.ts)
34
+ - add optional field `template: TemplateRef<unknown>` to customize a cell
35
+ - field `valueGetter` becomes optional
36
+
37
+ ### Fixed
38
+
39
+ - [redirect.component.ts](projects/prestations-ng/src/sdk-redirect/redirect.component.ts)
40
+ - reload page instead of redirecting to `/iam/accueil` when session has expired
41
+
42
+ ### Removed
43
+
44
+ - [foehn-modal.component.ts](projects/prestations-ng/src/foehn-modal/foehn-modal.component.ts)
45
+ - removed `@Input() modalFooterText` (was not used in the template)
46
+
47
+ ### Updated
48
+
49
+ - [package.json](package.json)
50
+ - Updated `core-js` to ~3.23.3
51
+
52
+ ## [15.2.2]
53
+
54
+ ### Fixed
55
+
56
+ - [foehn-select.component.html](projects/prestations-ng/src/foehn-checkables/foehn-select.component.html)
57
+ - use `elementValueIdentity` function if provided
58
+
59
+ ### Added
60
+
61
+ - [foehn-table-column-configuration.ts](projects/prestations-ng/src/foehn-table/foehn-table-column-configuration.ts)
62
+ - added optional field `iconGetter` to display an icon in a cell
63
+
29
64
  ## [15.2.1]
30
65
 
31
66
  ### Updated
@@ -1,5 +1,5 @@
1
1
  /* eslint-disable @typescript-eslint/no-explicit-any */
2
- import { Input, Directive, Output, EventEmitter } from '@angular/core';
2
+ import { Directive, EventEmitter, Input, Output } from '@angular/core';
3
3
  import { FoehnInputComponent } from '../foehn-input/foehn-input.component';
4
4
  import { HttpClient } from '@angular/common/http';
5
5
  import { ServiceLocator } from '../service-locator';
@@ -165,7 +165,12 @@ export class FoehnCheckableGroupComponent extends FoehnInputComponent {
165
165
  // This allows us to properly use an object as the model rather
166
166
  // than a string.
167
167
  const identityFn = this.getValueIdentityFunction();
168
- return identityFn(value1) === identityFn(value2);
168
+ if (identityFn) {
169
+ return identityFn(value1) === identityFn(value2);
170
+ }
171
+ else {
172
+ return ObjectHelper.isEqual(value1, value2);
173
+ }
169
174
  }
170
175
  onElementsRetrieved() {
171
176
  if (!this.model && this.defaultElementValue) {
@@ -232,7 +237,7 @@ export class FoehnCheckableGroupComponent extends FoehnInputComponent {
232
237
  getValueIdentityFunction() {
233
238
  return typeof this.elementValueIdentity === 'function'
234
239
  ? this.elementValueIdentity
235
- : (x) => x;
240
+ : null;
236
241
  }
237
242
  fetchData() {
238
243
  return this.httpClient.get(this.elementsUrl).pipe(map(r => {
@@ -290,4 +295,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
290
295
  }], defaultElementValue: [{
291
296
  type: Input
292
297
  }] } });
293
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-checkable-group.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-checkables/foehn-checkable-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n    Input,\n    NgZone,\n    OnChanges,\n    OnInit,\n    SimpleChange,\n    SimpleChanges,\n    Directive,\n    Output,\n    EventEmitter\n} from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { HttpClient } from '@angular/common/http';\nimport { ServiceLocator } from '../service-locator';\nimport { Observable, of, Subject } from 'rxjs';\nimport { first, map, shareReplay } from 'rxjs/operators';\nimport { FormSelectOptionGroup } from './form-select-option-group';\nimport { ObjectHelper } from '../helpers/object.helper';\n\n@Directive()\nexport abstract class FoehnCheckableGroupComponent\n    extends FoehnInputComponent<any>\n    implements OnInit, OnChanges {\n    @Input()\n    elements: any;\n\n    @Input()\n    elementsUrl: string;\n\n    /**\n     * The value in the object. Can be a string or a function.\n     * Defaults to `value`\n     */\n    @Input()\n    elementValue: any = 'value';\n\n    /**\n     * The label in the object. Can be a string or a function\n     * Defaults to `label`\n     */\n    @Input()\n    elementLabel: any = 'label';\n\n    /**\n     * The identify value to match the value to the list of elements.\n     * By default `x => x`\n     */\n    @Input()\n    elementValueIdentity: (element: any) => any;\n\n    @Input()\n    elementDisabled: any = 'disabled';\n\n    @Input()\n    allElementDisabled = false;\n\n    @Input()\n    elementGroup: any;\n\n    @Output()\n    elementsLoaded = new EventEmitter<any>();\n\n    groupedElements: FormSelectOptionGroup[];\n\n    httpClient: HttpClient;\n\n    protected multiple = false;\n    private pulling_: Observable<any>;\n    private _onInitSubject: Subject<any> = new Subject<any>();\n    private defaultElementValue_: string;\n\n    constructor(private ngZone: NgZone) {\n        super();\n        this.httpClient = ServiceLocator.injector.get(HttpClient);\n        this.autocomplete = 'off';\n    }\n\n    get onInitSubject(): Subject<any> {\n        return this._onInitSubject;\n    }\n\n    get defaultElementValue(): string {\n        return this.defaultElementValue_;\n    }\n\n    @Input()\n    set defaultElementValue(val: string) {\n        this.defaultElementValue_ = val;\n        if (!this.elementsUrl) {\n            this.onElementsRetrieved();\n        }\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (this.elementsUrl) {\n            this.fetchElementsFromUrl();\n        } else if (this.elements) {\n            this.onElementsRetrieved();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        // Handle a change in the elements Input.\n        this.onElementsChange(changes.elements);\n\n        // Handle a change in the elementsUrl Input.\n        this.onElementsUrlChange(changes.elementsUrl);\n    }\n\n    getElements(): Observable<any> {\n        if (!!this.elementsUrl) {\n            return this.pulling_;\n        }\n\n        return of(this.elements);\n    }\n\n    getGroup(element: any): string {\n        if (!element || !this.elementGroup) {\n            return null;\n        }\n\n        if (typeof this.elementGroup === 'string') {\n            return this.getNestedProperty(element, this.elementGroup);\n        }\n        return this.elementGroup(element);\n    }\n\n    setElements(elements: any[]): void {\n        this.elements = elements;\n        this.elementsLoaded.next(elements);\n        this.onElementsRetrieved();\n    }\n\n    getValue(element: any): string {\n        if (!element) {\n            return null;\n        }\n\n        if (typeof this.elementValue === 'string') {\n            return this.getNestedProperty(element, this.elementValue);\n        }\n        return this.elementValue(element);\n    }\n\n    getLabel(element: any): string {\n        if (typeof this.elementLabel === 'string') {\n            return this.getNestedProperty(element, this.elementLabel);\n        }\n        return this.elementLabel(element);\n    }\n\n    getDisabled(element: any): string {\n        if (this.allElementDisabled) {\n            return 'disabled';\n        }\n\n        if (typeof this.elementDisabled === 'string') {\n            return this.getNestedProperty(element, this.elementDisabled);\n        }\n        return this.elementDisabled(element);\n    }\n\n    onCheck(\n        element: any,\n        selectEvent: any,\n        fireModelChange: boolean = true\n    ): void {\n        const value = this.getValue(element);\n        if (this.multiple) {\n            if (!this.model) {\n                this.model = [];\n            }\n            const modelArray = this.model as string[];\n            if (!!selectEvent) {\n                if (this.findIndexInModel(value) < 0) {\n                    modelArray.push(value);\n                }\n            } else {\n                const indexInModel = this.findIndexInModel(value);\n                if (indexInModel >= 0) {\n                    modelArray.splice(indexInModel, 1);\n                }\n            }\n            if (fireModelChange) {\n                this.model = [...modelArray];\n            }\n        } else {\n            if (!!selectEvent) {\n                this.model = value;\n            } else {\n                if (this.areValuesEquals(this.model, value)) {\n                    this.model = null;\n                }\n            }\n        }\n    }\n\n    isElementSelected(element: any): boolean {\n        const value = this.getValue(element);\n        if (this.multiple) {\n            return this.model && this.findIndexInModel(value) >= 0;\n        }\n\n        return this.areValuesEquals(this.model, value);\n    }\n\n    reset(): void {\n        if (!!this.defaultElementValue) {\n            this.updateNgModel(this.defaultElementValue);\n        } else {\n            super.reset();\n        }\n    }\n\n    refreshElementsUrl(): void {\n        if (this.elementsUrl) {\n            this.fetchElementsFromUrl();\n        }\n    }\n\n    protected findIndexInModel(value: any): number {\n        if (this.multiple) {\n            return (this.model as any[]).findIndex(modelValue =>\n                this.areValuesEquals(value, modelValue)\n            );\n        }\n        throw new Error(\n            'findIndexInModel cannot be used when this.multiple is false !'\n        );\n    }\n\n    protected areValuesEquals(value1: any, value2: any): boolean {\n        // Get an option way to compare the value from the model.\n        // This allows us to properly use an object as the model rather\n        // than a string.\n        const identityFn = this.getValueIdentityFunction();\n        return identityFn(value1) === identityFn(value2);\n    }\n\n    protected onElementsRetrieved(): void {\n        if (!this.model && this.defaultElementValue) {\n            this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n                this.updateNgModel(this.defaultElementValue);\n            });\n        } else if (this.model) {\n            this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n                this.updateNgModel(this.model_);\n            });\n        }\n        this.groupedElements = this.getGroupedElements();\n    }\n\n    private getGroupedElements(): FormSelectOptionGroup[] {\n        if (!this.elements) {\n            return [];\n        }\n        if (!this.elementGroup) {\n            return [{ groupTitle: null, elements: this.elements }];\n        }\n\n        const elementsByGroup: Map<string, any[]> = new Map<string, any[]>();\n\n        const emptyGroup = new FormSelectOptionGroup();\n        emptyGroup.elements = [];\n\n        for (const element of this.elements) {\n            const groupId = this.getGroup(element);\n            if (!!groupId) {\n                let elementsOfGroup: any[] = elementsByGroup.get(groupId);\n                if (!elementsOfGroup) {\n                    elementsOfGroup = [];\n                    elementsByGroup.set(groupId, elementsOfGroup);\n                }\n                elementsOfGroup.push(element);\n            } else {\n                emptyGroup.elements.push(element);\n            }\n        }\n\n        const formSelectOptionsGroup: FormSelectOptionGroup[] = [];\n\n        if (emptyGroup.elements.length > 0) {\n            formSelectOptionsGroup.push(emptyGroup);\n        }\n        elementsByGroup.forEach((value, key) => {\n            formSelectOptionsGroup.push({ groupTitle: key, elements: value });\n        });\n\n        return formSelectOptionsGroup;\n    }\n\n    private getNestedProperty(obj: any, key: string): any {\n        for (const property in obj) {\n            if (obj.hasOwnProperty(property)) {\n                // in case it is an object\n                if (typeof obj[property] === 'object') {\n                    const result = this.getNestedProperty(\n                        obj[property],\n                        key.split('.').slice(1).join('.')\n                    );\n\n                    if (typeof result !== 'undefined') {\n                        return result;\n                    }\n                } else if (property === key) {\n                    return obj[key]; // returns the value\n                }\n            }\n        }\n    }\n\n    private getValueIdentityFunction(): any {\n        return typeof this.elementValueIdentity === 'function'\n            ? this.elementValueIdentity\n            : (x: any) => x;\n    }\n\n    private fetchData(): Observable<any> {\n        return this.httpClient.get(this.elementsUrl).pipe(\n            map(r => {\n                const elements: any = r;\n                this.setElements(elements);\n                return elements;\n            }),\n            shareReplay(1)\n        );\n    }\n\n    private fetchElementsFromUrl(): void {\n        this.pulling_ = this.fetchData();\n        this.pulling_.subscribe(() => {\n            this.onInitSubject.next(null);\n        });\n    }\n\n    private onElementsChange(change: SimpleChange): void {\n        if (change && !change.firstChange) {\n            // When elements are deferred from ngOnInit (i.e. pipe async is used)\n            this.onElementsRetrieved();\n            // Hack to refresh the display value\n            this.updateNgModel(this.model_);\n        } else if (\n            change &&\n            !ObjectHelper.isEqual(change.currentValue, change.previousValue)\n        ) {\n            this.elementsLoaded.next(change.currentValue);\n        }\n    }\n\n    private onElementsUrlChange(change: SimpleChange): void {\n        if (change && !change.firstChange) {\n            this.fetchElementsFromUrl();\n        }\n    }\n}\n"]}
298
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-checkable-group.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-checkables/foehn-checkable-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n    Directive,\n    EventEmitter,\n    Input,\n    NgZone,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChange,\n    SimpleChanges\n} from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { HttpClient } from '@angular/common/http';\nimport { ServiceLocator } from '../service-locator';\nimport { Observable, of, Subject } from 'rxjs';\nimport { first, map, shareReplay } from 'rxjs/operators';\nimport { FormSelectOptionGroup } from './form-select-option-group';\nimport { ObjectHelper } from '../helpers/object.helper';\n\n@Directive()\nexport abstract class FoehnCheckableGroupComponent\n    extends FoehnInputComponent<any>\n    implements OnInit, OnChanges {\n    @Input()\n    elements: any;\n\n    @Input()\n    elementsUrl: string;\n\n    /**\n     * The value in the object. Can be a string or a function.\n     * Defaults to `value`\n     */\n    @Input()\n    elementValue: any = 'value';\n\n    /**\n     * The label in the object. Can be a string or a function\n     * Defaults to `label`\n     */\n    @Input()\n    elementLabel: any = 'label';\n\n    /**\n     * The identify value to match the value to the list of elements.\n     * By default `x => x`\n     */\n    @Input()\n    elementValueIdentity: (element: any) => any;\n\n    @Input()\n    elementDisabled: any = 'disabled';\n\n    @Input()\n    allElementDisabled = false;\n\n    @Input()\n    elementGroup: any;\n\n    @Output()\n    elementsLoaded = new EventEmitter<any>();\n\n    groupedElements: FormSelectOptionGroup[];\n\n    httpClient: HttpClient;\n\n    protected multiple = false;\n    private pulling_: Observable<any>;\n    private _onInitSubject: Subject<any> = new Subject<any>();\n    private defaultElementValue_: string;\n\n    constructor(private ngZone: NgZone) {\n        super();\n        this.httpClient = ServiceLocator.injector.get(HttpClient);\n        this.autocomplete = 'off';\n    }\n\n    get onInitSubject(): Subject<any> {\n        return this._onInitSubject;\n    }\n\n    get defaultElementValue(): string {\n        return this.defaultElementValue_;\n    }\n\n    @Input()\n    set defaultElementValue(val: string) {\n        this.defaultElementValue_ = val;\n        if (!this.elementsUrl) {\n            this.onElementsRetrieved();\n        }\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (this.elementsUrl) {\n            this.fetchElementsFromUrl();\n        } else if (this.elements) {\n            this.onElementsRetrieved();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        // Handle a change in the elements Input.\n        this.onElementsChange(changes.elements);\n\n        // Handle a change in the elementsUrl Input.\n        this.onElementsUrlChange(changes.elementsUrl);\n    }\n\n    getElements(): Observable<any> {\n        if (!!this.elementsUrl) {\n            return this.pulling_;\n        }\n\n        return of(this.elements);\n    }\n\n    getGroup(element: any): string {\n        if (!element || !this.elementGroup) {\n            return null;\n        }\n\n        if (typeof this.elementGroup === 'string') {\n            return this.getNestedProperty(element, this.elementGroup);\n        }\n        return this.elementGroup(element);\n    }\n\n    setElements(elements: any[]): void {\n        this.elements = elements;\n        this.elementsLoaded.next(elements);\n        this.onElementsRetrieved();\n    }\n\n    getValue(element: any): string {\n        if (!element) {\n            return null;\n        }\n\n        if (typeof this.elementValue === 'string') {\n            return this.getNestedProperty(element, this.elementValue);\n        }\n        return this.elementValue(element);\n    }\n\n    getLabel(element: any): string {\n        if (typeof this.elementLabel === 'string') {\n            return this.getNestedProperty(element, this.elementLabel);\n        }\n        return this.elementLabel(element);\n    }\n\n    getDisabled(element: any): string {\n        if (this.allElementDisabled) {\n            return 'disabled';\n        }\n\n        if (typeof this.elementDisabled === 'string') {\n            return this.getNestedProperty(element, this.elementDisabled);\n        }\n        return this.elementDisabled(element);\n    }\n\n    onCheck(\n        element: any,\n        selectEvent: any,\n        fireModelChange: boolean = true\n    ): void {\n        const value = this.getValue(element);\n        if (this.multiple) {\n            if (!this.model) {\n                this.model = [];\n            }\n            const modelArray = this.model as string[];\n            if (!!selectEvent) {\n                if (this.findIndexInModel(value) < 0) {\n                    modelArray.push(value);\n                }\n            } else {\n                const indexInModel = this.findIndexInModel(value);\n                if (indexInModel >= 0) {\n                    modelArray.splice(indexInModel, 1);\n                }\n            }\n            if (fireModelChange) {\n                this.model = [...modelArray];\n            }\n        } else {\n            if (!!selectEvent) {\n                this.model = value;\n            } else {\n                if (this.areValuesEquals(this.model, value)) {\n                    this.model = null;\n                }\n            }\n        }\n    }\n\n    isElementSelected(element: any): boolean {\n        const value = this.getValue(element);\n        if (this.multiple) {\n            return this.model && this.findIndexInModel(value) >= 0;\n        }\n\n        return this.areValuesEquals(this.model, value);\n    }\n\n    reset(): void {\n        if (!!this.defaultElementValue) {\n            this.updateNgModel(this.defaultElementValue);\n        } else {\n            super.reset();\n        }\n    }\n\n    refreshElementsUrl(): void {\n        if (this.elementsUrl) {\n            this.fetchElementsFromUrl();\n        }\n    }\n\n    protected findIndexInModel(value: any): number {\n        if (this.multiple) {\n            return (this.model as any[]).findIndex(modelValue =>\n                this.areValuesEquals(value, modelValue)\n            );\n        }\n        throw new Error(\n            'findIndexInModel cannot be used when this.multiple is false !'\n        );\n    }\n\n    protected areValuesEquals(value1: any, value2: any): boolean {\n        // Get an option way to compare the value from the model.\n        // This allows us to properly use an object as the model rather\n        // than a string.\n        const identityFn = this.getValueIdentityFunction();\n        if (identityFn) {\n            return identityFn(value1) === identityFn(value2);\n        } else {\n            return ObjectHelper.isEqual(value1, value2);\n        }\n    }\n\n    protected onElementsRetrieved(): void {\n        if (!this.model && this.defaultElementValue) {\n            this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n                this.updateNgModel(this.defaultElementValue);\n            });\n        } else if (this.model) {\n            this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n                this.updateNgModel(this.model_);\n            });\n        }\n        this.groupedElements = this.getGroupedElements();\n    }\n\n    private getGroupedElements(): FormSelectOptionGroup[] {\n        if (!this.elements) {\n            return [];\n        }\n        if (!this.elementGroup) {\n            return [{ groupTitle: null, elements: this.elements }];\n        }\n\n        const elementsByGroup: Map<string, any[]> = new Map<string, any[]>();\n\n        const emptyGroup = new FormSelectOptionGroup();\n        emptyGroup.elements = [];\n\n        for (const element of this.elements) {\n            const groupId = this.getGroup(element);\n            if (!!groupId) {\n                let elementsOfGroup: any[] = elementsByGroup.get(groupId);\n                if (!elementsOfGroup) {\n                    elementsOfGroup = [];\n                    elementsByGroup.set(groupId, elementsOfGroup);\n                }\n                elementsOfGroup.push(element);\n            } else {\n                emptyGroup.elements.push(element);\n            }\n        }\n\n        const formSelectOptionsGroup: FormSelectOptionGroup[] = [];\n\n        if (emptyGroup.elements.length > 0) {\n            formSelectOptionsGroup.push(emptyGroup);\n        }\n        elementsByGroup.forEach((value, key) => {\n            formSelectOptionsGroup.push({ groupTitle: key, elements: value });\n        });\n\n        return formSelectOptionsGroup;\n    }\n\n    private getNestedProperty(obj: any, key: string): any {\n        for (const property in obj) {\n            if (obj.hasOwnProperty(property)) {\n                // in case it is an object\n                if (typeof obj[property] === 'object') {\n                    const result = this.getNestedProperty(\n                        obj[property],\n                        key.split('.').slice(1).join('.')\n                    );\n\n                    if (typeof result !== 'undefined') {\n                        return result;\n                    }\n                } else if (property === key) {\n                    return obj[key]; // returns the value\n                }\n            }\n        }\n    }\n\n    private getValueIdentityFunction(): (element: any) => any {\n        return typeof this.elementValueIdentity === 'function'\n            ? this.elementValueIdentity\n            : null;\n    }\n\n    private fetchData(): Observable<any> {\n        return this.httpClient.get(this.elementsUrl).pipe(\n            map(r => {\n                const elements: any = r;\n                this.setElements(elements);\n                return elements;\n            }),\n            shareReplay(1)\n        );\n    }\n\n    private fetchElementsFromUrl(): void {\n        this.pulling_ = this.fetchData();\n        this.pulling_.subscribe(() => {\n            this.onInitSubject.next(null);\n        });\n    }\n\n    private onElementsChange(change: SimpleChange): void {\n        if (change && !change.firstChange) {\n            // When elements are deferred from ngOnInit (i.e. pipe async is used)\n            this.onElementsRetrieved();\n            // Hack to refresh the display value\n            this.updateNgModel(this.model_);\n        } else if (\n            change &&\n            !ObjectHelper.isEqual(change.currentValue, change.previousValue)\n        ) {\n            this.elementsLoaded.next(change.currentValue);\n        }\n    }\n\n    private onElementsUrlChange(change: SimpleChange): void {\n        if (change && !change.firstChange) {\n            this.fetchElementsFromUrl();\n        }\n    }\n}\n"]}
@@ -1,7 +1,6 @@
1
1
  import { Component, forwardRef, Input } from '@angular/core';
2
2
  import { FoehnCheckableGroupComponent } from './foehn-checkable-group.component';
3
3
  import { FoehnInputComponent } from '../foehn-input/foehn-input.component';
4
- import { ObjectHelper } from '../helpers/object.helper';
5
4
  import * as i0 from "@angular/core";
6
5
  import * as i1 from "../foehn-validation-alerts/foehn-validation-alerts.component";
7
6
  import * as i2 from "@angular/common";
@@ -24,19 +23,7 @@ export class FoehnSelectComponent extends FoehnCheckableGroupComponent {
24
23
  */
25
24
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
26
25
  compareFn(value1, value2) {
27
- return ObjectHelper.isEqual(value1, value2);
28
- }
29
- /**
30
- * We override areValuesEquals from FoehnCheckableGroupComponent so we keep only one way of comparing objects
31
- * So there is no need to use 'elementValueIdentity' anymore
32
- *
33
- * @param value1 to be compared to
34
- * @param value2 to be compared to
35
- * @returns boolean
36
- */
37
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
38
- areValuesEquals(value1, value2) {
39
- return ObjectHelper.isEqual(value1, value2);
26
+ return this.areValuesEquals(value1, value2);
40
27
  }
41
28
  }
42
29
  FoehnSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnSelectComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
@@ -46,7 +33,7 @@ FoehnSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", v
46
33
  useExisting: forwardRef(() => FoehnSelectComponent),
47
34
  multi: true
48
35
  }
49
- ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\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 </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <div *ngIf=\"!elements\">Chargement...</div>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <select\n *ngIf=\"!multiple\"\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [attr.autocomplete]=\"getAutoComplete()\"\n [ngModel]=\"model\"\n (ngModelChange)=\"updateNgModel($event)\"\n [compareWith]=\"compareFn\"\n (change)=\"handleChange(model)\"\n #entryComponent\n ngDefaultControl\n >\n <option *ngIf=\"!required\" [ngValue]=\"null\">-</option>\n <option\n *ngFor=\"let element of elements\"\n [ngValue]=\"getValue(element)\"\n [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n [attr.disabled]=\"getDisabled(element) ? 'disabled' : null\"\n [innerHTML]=\"getLabel(element)\"\n ></option>\n </select>\n <select\n *ngIf=\"multiple\"\n multiple\n [attr.aria-multiselectable]=\"true\"\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [ngModel]=\"model\"\n (ngModelChange)=\"updateNgModel($event)\"\n [compareWith]=\"compareFn\"\n (change)=\"handleChange(model)\"\n #entryComponent\n ngDefaultControl\n >\n <option\n *ngFor=\"let element of elements\"\n [ngValue]=\"getValue(element)\"\n [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n [attr.aria-selected]=\"isElementSelected(element)\"\n >\n {{ getLabel(element) }}\n </option>\n </select>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.SelectMultipleControlValueAccessor, selector: "select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]", inputs: ["compareWith"] }], pipes: { "fromDictionary": i4.SdkDictionaryPipe } });
36
+ ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\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 </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <div *ngIf=\"!elements\">Chargement...</div>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <select\n *ngIf=\"!multiple\"\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [attr.autocomplete]=\"getAutoComplete()\"\n [ngModel]=\"model\"\n (ngModelChange)=\"updateNgModel($event)\"\n [compareWith]=\"compareFn.bind(this)\"\n (change)=\"handleChange(model)\"\n #entryComponent\n ngDefaultControl\n >\n <option *ngIf=\"!required\" [ngValue]=\"null\">-</option>\n <option\n *ngFor=\"let element of elements\"\n [ngValue]=\"getValue(element)\"\n [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n [attr.disabled]=\"getDisabled(element) ? 'disabled' : null\"\n [innerHTML]=\"getLabel(element)\"\n ></option>\n </select>\n <select\n *ngIf=\"multiple\"\n multiple\n [attr.aria-multiselectable]=\"true\"\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [ngModel]=\"model\"\n (ngModelChange)=\"updateNgModel($event)\"\n [compareWith]=\"compareFn.bind(this)\"\n (change)=\"handleChange(model)\"\n #entryComponent\n ngDefaultControl\n >\n <option\n *ngFor=\"let element of elements\"\n [ngValue]=\"getValue(element)\"\n [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n [attr.aria-selected]=\"isElementSelected(element)\"\n >\n {{ getLabel(element) }}\n </option>\n </select>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.SelectMultipleControlValueAccessor, selector: "select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]", inputs: ["compareWith"] }], pipes: { "fromDictionary": i4.SdkDictionaryPipe } });
50
37
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnSelectComponent, decorators: [{
51
38
  type: Component,
52
39
  args: [{ selector: 'foehn-select', providers: [
@@ -55,8 +42,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
55
42
  useExisting: forwardRef(() => FoehnSelectComponent),
56
43
  multi: true
57
44
  }
58
- ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\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 </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <div *ngIf=\"!elements\">Chargement...</div>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <select\n *ngIf=\"!multiple\"\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [attr.autocomplete]=\"getAutoComplete()\"\n [ngModel]=\"model\"\n (ngModelChange)=\"updateNgModel($event)\"\n [compareWith]=\"compareFn\"\n (change)=\"handleChange(model)\"\n #entryComponent\n ngDefaultControl\n >\n <option *ngIf=\"!required\" [ngValue]=\"null\">-</option>\n <option\n *ngFor=\"let element of elements\"\n [ngValue]=\"getValue(element)\"\n [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n [attr.disabled]=\"getDisabled(element) ? 'disabled' : null\"\n [innerHTML]=\"getLabel(element)\"\n ></option>\n </select>\n <select\n *ngIf=\"multiple\"\n multiple\n [attr.aria-multiselectable]=\"true\"\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [ngModel]=\"model\"\n (ngModelChange)=\"updateNgModel($event)\"\n [compareWith]=\"compareFn\"\n (change)=\"handleChange(model)\"\n #entryComponent\n ngDefaultControl\n >\n <option\n *ngFor=\"let element of elements\"\n [ngValue]=\"getValue(element)\"\n [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n [attr.aria-selected]=\"isElementSelected(element)\"\n >\n {{ getLabel(element) }}\n </option>\n </select>\n</div>\n" }]
45
+ ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"!!label\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\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 </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <div *ngIf=\"!elements\">Chargement...</div>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <select\n *ngIf=\"!multiple\"\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [attr.autocomplete]=\"getAutoComplete()\"\n [ngModel]=\"model\"\n (ngModelChange)=\"updateNgModel($event)\"\n [compareWith]=\"compareFn.bind(this)\"\n (change)=\"handleChange(model)\"\n #entryComponent\n ngDefaultControl\n >\n <option *ngIf=\"!required\" [ngValue]=\"null\">-</option>\n <option\n *ngFor=\"let element of elements\"\n [ngValue]=\"getValue(element)\"\n [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n [attr.disabled]=\"getDisabled(element) ? 'disabled' : null\"\n [innerHTML]=\"getLabel(element)\"\n ></option>\n </select>\n <select\n *ngIf=\"multiple\"\n multiple\n [attr.aria-multiselectable]=\"true\"\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.id]=\"buildChildId()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [ngModel]=\"model\"\n (ngModelChange)=\"updateNgModel($event)\"\n [compareWith]=\"compareFn.bind(this)\"\n (change)=\"handleChange(model)\"\n #entryComponent\n ngDefaultControl\n >\n <option\n *ngFor=\"let element of elements\"\n [ngValue]=\"getValue(element)\"\n [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n [attr.aria-selected]=\"isElementSelected(element)\"\n >\n {{ getLabel(element) }}\n </option>\n </select>\n</div>\n" }]
59
46
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { multiple: [{
60
47
  type: Input
61
48
  }] } });
62
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-select.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-checkables/foehn-select.component.ts","../../../../projects/prestations-ng/src/foehn-checkables/foehn-select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAkB,MAAM,eAAe,CAAC;AAC7E,OAAO,EAAE,4BAA4B,EAAE,MAAM,mCAAmC,CAAC;AACjF,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;;;;;;AAaxD,MAAM,OAAO,oBACT,SAAQ,4BAA4B;IAKpC,YAAoB,IAAY;QAC5B,KAAK,CAAC,IAAI,CAAC,CAAC;QADI,SAAI,GAAJ,IAAI,CAAQ;IAEhC,CAAC;IAED;;;;;;;;;OASG;IACH,8DAA8D;IAC9D,SAAS,CAAC,MAAW,EAAE,MAAW;QAC9B,OAAO,YAAY,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChD,CAAC;IAED;;;;;;;OAOG;IACH,8DAA8D;IACpD,eAAe,CAAC,MAAW,EAAE,MAAW;QAC9C,OAAO,YAAY,CAAC,OAAO,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChD,CAAC;;iHApCQ,oBAAoB;qGAApB,oBAAoB,yEARlB;QACP;YACI,OAAO,EAAE,mBAAmB;YAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;YACnD,KAAK,EAAE,IAAI;SACd;KACJ,iDCdL,gnGA0FA;2FD1Ea,oBAAoB;kBAXhC,SAAS;+BACI,cAAc,aAEb;wBACP;4BACI,OAAO,EAAE,mBAAmB;4BAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,qBAAqB,CAAC;4BACnD,KAAK,EAAE,IAAI;yBACd;qBACJ;6FAMD,QAAQ;sBADP,KAAK","sourcesContent":["import { Component, forwardRef, Input, NgZone, OnInit } from '@angular/core';\nimport { FoehnCheckableGroupComponent } from './foehn-checkable-group.component';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { ObjectHelper } from '../helpers/object.helper';\n\n@Component({\n    selector: 'foehn-select',\n    templateUrl: './foehn-select.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnSelectComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnSelectComponent\n    extends FoehnCheckableGroupComponent\n    implements OnInit {\n    @Input()\n    multiple: boolean;\n\n    constructor(private zone: NgZone) {\n        super(zone);\n    }\n\n    /**\n     * Angular uses object identity to select option. It's possible for the identities of items to change while the data does not.\n     * This can happen, for example, if the items are produced from an RPC to the server, and that RPC is re-run.\n     * Even if the data hasn't changed, the second response will produce objects with different identities.\n     * (see: https://angular.io/api/forms/SelectControlValueAccessor#customizing-option-selection)\n     *\n     * @param value1 as first value to compare to\n     * @param value2 as value to be compared to\n     * @returns boolean\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    compareFn(value1: any, value2: any): boolean {\n        return ObjectHelper.isEqual(value1, value2);\n    }\n\n    /**\n     * We override areValuesEquals from FoehnCheckableGroupComponent so we keep only one way of comparing objects\n     * So there is no need to use 'elementValueIdentity' anymore\n     *\n     * @param value1 to be compared to\n     * @param value2 to be compared to\n     * @returns boolean\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    protected areValuesEquals(value1: any, value2: any): boolean {\n        return ObjectHelper.isEqual(value1, value2);\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <label\n        [attr.for]=\"buildChildId()\"\n        *ngIf=\"!!label\"\n        [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\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    </label>\n\n    <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n    <div *ngIf=\"!elements\">Chargement...</div>\n\n    <small\n        *ngIf=\"helpText\"\n        [attr.id]=\"buildChildId() + 'Help'\"\n        class=\"form-text text-secondary\"\n        [innerHTML]=\"helpText\"\n    ></small>\n\n    <ng-content></ng-content>\n\n    <select\n        *ngIf=\"!multiple\"\n        [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n        class=\"form-control\"\n        [name]=\"name || label\"\n        [attr.id]=\"buildChildId()\"\n        [attr.disabled]=\"disabled ? 'disabled' : null\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n        [attr.aria-required]=\"required || null\"\n        [attr.autocomplete]=\"getAutoComplete()\"\n        [ngModel]=\"model\"\n        (ngModelChange)=\"updateNgModel($event)\"\n        [compareWith]=\"compareFn\"\n        (change)=\"handleChange(model)\"\n        #entryComponent\n        ngDefaultControl\n    >\n        <option *ngIf=\"!required\" [ngValue]=\"null\">-</option>\n        <option\n            *ngFor=\"let element of elements\"\n            [ngValue]=\"getValue(element)\"\n            [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n            [attr.disabled]=\"getDisabled(element) ? 'disabled' : null\"\n            [innerHTML]=\"getLabel(element)\"\n        ></option>\n    </select>\n    <select\n        *ngIf=\"multiple\"\n        multiple\n        [attr.aria-multiselectable]=\"true\"\n        [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n        class=\"form-control\"\n        [name]=\"name || label\"\n        [attr.id]=\"buildChildId()\"\n        [attr.disabled]=\"disabled ? 'disabled' : null\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n        [attr.aria-required]=\"required || null\"\n        [ngModel]=\"model\"\n        (ngModelChange)=\"updateNgModel($event)\"\n        [compareWith]=\"compareFn\"\n        (change)=\"handleChange(model)\"\n        #entryComponent\n        ngDefaultControl\n    >\n        <option\n            *ngFor=\"let element of elements\"\n            [ngValue]=\"getValue(element)\"\n            [attr.selected]=\"isElementSelected(element) ? 'selected' : null\"\n            [attr.aria-selected]=\"isElementSelected(element)\"\n        >\n            {{ getLabel(element) }}\n        </option>\n    </select>\n</div>\n"]}
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4tc2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1jaGVja2FibGVzL2ZvZWhuLXNlbGVjdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvZm9laG4tY2hlY2thYmxlcy9mb2Vobi1zZWxlY3QuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFrQixNQUFNLGVBQWUsQ0FBQztBQUM3RSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNqRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7Ozs7O0FBYTNFLE1BQU0sT0FBTyxvQkFDVCxTQUFRLDRCQUE0QjtJQUtwQyxZQUFvQixJQUFZO1FBQzVCLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQURJLFNBQUksR0FBSixJQUFJLENBQVE7SUFFaEMsQ0FBQztJQUVEOzs7Ozs7Ozs7T0FTRztJQUNILDhEQUE4RDtJQUM5RCxTQUFTLENBQUMsTUFBVyxFQUFFLE1BQVc7UUFDOUIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNoRCxDQUFDOztpSEF2QlEsb0JBQW9CO3FHQUFwQixvQkFBb0IseUVBUmxCO1FBQ1A7WUFDSSxPQUFPLEVBQUUsbUJBQW1CO1lBQzVCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsb0JBQW9CLENBQUM7WUFDbkQsS0FBSyxFQUFFLElBQUk7U0FDZDtLQUNKLGlEQ2JMLHNvR0EwRkE7MkZEM0VhLG9CQUFvQjtrQkFYaEMsU0FBUzsrQkFDSSxjQUFjLGFBRWI7d0JBQ1A7NEJBQ0ksT0FBTyxFQUFFLG1CQUFtQjs0QkFDNUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUscUJBQXFCLENBQUM7NEJBQ25ELEtBQUssRUFBRSxJQUFJO3lCQUNkO3FCQUNKOzZGQU1ELFFBQVE7c0JBRFAsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5wdXQsIE5nWm9uZSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb2VobkNoZWNrYWJsZUdyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi9mb2Vobi1jaGVja2FibGUtZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7IEZvZWhuSW5wdXRDb21wb25lbnQgfSBmcm9tICcuLi9mb2Vobi1pbnB1dC9mb2Vobi1pbnB1dC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2ZvZWhuLXNlbGVjdCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2ZvZWhuLXNlbGVjdC5jb21wb25lbnQuaHRtbCcsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IEZvZWhuSW5wdXRDb21wb25lbnQsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBGb2VoblNlbGVjdENvbXBvbmVudCksXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZVxuICAgICAgICB9XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBGb2VoblNlbGVjdENvbXBvbmVudFxuICAgIGV4dGVuZHMgRm9laG5DaGVja2FibGVHcm91cENvbXBvbmVudFxuICAgIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKVxuICAgIG11bHRpcGxlOiBib29sZWFuO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSB6b25lOiBOZ1pvbmUpIHtcbiAgICAgICAgc3VwZXIoem9uZSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQW5ndWxhciB1c2VzIG9iamVjdCBpZGVudGl0eSB0byBzZWxlY3Qgb3B0aW9uLiBJdCdzIHBvc3NpYmxlIGZvciB0aGUgaWRlbnRpdGllcyBvZiBpdGVtcyB0byBjaGFuZ2Ugd2hpbGUgdGhlIGRhdGEgZG9lcyBub3QuXG4gICAgICogVGhpcyBjYW4gaGFwcGVuLCBmb3IgZXhhbXBsZSwgaWYgdGhlIGl0ZW1zIGFyZSBwcm9kdWNlZCBmcm9tIGFuIFJQQyB0byB0aGUgc2VydmVyLCBhbmQgdGhhdCBSUEMgaXMgcmUtcnVuLlxuICAgICAqIEV2ZW4gaWYgdGhlIGRhdGEgaGFzbid0IGNoYW5nZWQsIHRoZSBzZWNvbmQgcmVzcG9uc2Ugd2lsbCBwcm9kdWNlIG9iamVjdHMgd2l0aCBkaWZmZXJlbnQgaWRlbnRpdGllcy5cbiAgICAgKiAoc2VlOiBodHRwczovL2FuZ3VsYXIuaW8vYXBpL2Zvcm1zL1NlbGVjdENvbnRyb2xWYWx1ZUFjY2Vzc29yI2N1c3RvbWl6aW5nLW9wdGlvbi1zZWxlY3Rpb24pXG4gICAgICpcbiAgICAgKiBAcGFyYW0gdmFsdWUxIGFzIGZpcnN0IHZhbHVlIHRvIGNvbXBhcmUgdG9cbiAgICAgKiBAcGFyYW0gdmFsdWUyIGFzIHZhbHVlIHRvIGJlIGNvbXBhcmVkIHRvXG4gICAgICogQHJldHVybnMgYm9vbGVhblxuICAgICAqL1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gICAgY29tcGFyZUZuKHZhbHVlMTogYW55LCB2YWx1ZTI6IGFueSk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5hcmVWYWx1ZXNFcXVhbHModmFsdWUxLCB2YWx1ZTIpO1xuICAgIH1cbn1cbiIsIjxkaXZcbiAgICBjbGFzcz1cImZvcm0tZ3JvdXBcIlxuICAgIFtjbGFzcy5oYXMtZGFuZ2VyXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpXCJcbiAgICBbY2xhc3MudmQtZm9ybS1ncm91cC1kYW5nZXJdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KClcIlxuICAgIFthdHRyLmlkXT1cImJ1aWxkSWQoJ0NvbnRhaW5lcicpXCJcbiAgICB0YWJpbmRleD1cIi0xXCJcbj5cbiAgICA8bGFiZWxcbiAgICAgICAgW2F0dHIuZm9yXT1cImJ1aWxkQ2hpbGRJZCgpXCJcbiAgICAgICAgKm5nSWY9XCIhIWxhYmVsXCJcbiAgICAgICAgW25nQ2xhc3NdPVwiaXNMYWJlbFNyT25seSA/ICdzci1vbmx5JyA6IGxhYmVsU3R5bGVNb2RpZmllclwiXG4gICAgPlxuICAgICAgICA8c3BhbiBbaW5uZXJIVE1MXT1cImxhYmVsXCI+PC9zcGFuPlxuICAgICAgICA8c3BhblxuICAgICAgICAgICAgKm5nSWY9XCIhcmVxdWlyZWQgJiYgIWhpZGVOb3RSZXF1aXJlZEV4dHJhTGFiZWxcIlxuICAgICAgICAgICAgYXJpYS1oaWRkZW49XCJ0cnVlXCJcbiAgICAgICAgPlxuICAgICAgICAgICAge3sgJ2ZvZWhuLWlucHV0Lm9wdGlvbmFsJyB8IGZyb21EaWN0aW9uYXJ5IH19XG4gICAgICAgIDwvc3Bhbj5cbiAgICA8L2xhYmVsPlxuXG4gICAgPGZvZWhuLXZhbGlkYXRpb24tYWxlcnRzIFtjb21wb25lbnRdPVwidGhpc1wiPjwvZm9laG4tdmFsaWRhdGlvbi1hbGVydHM+XG5cbiAgICA8ZGl2ICpuZ0lmPVwiIWVsZW1lbnRzXCI+Q2hhcmdlbWVudC4uLjwvZGl2PlxuXG4gICAgPHNtYWxsXG4gICAgICAgICpuZ0lmPVwiaGVscFRleHRcIlxuICAgICAgICBbYXR0ci5pZF09XCJidWlsZENoaWxkSWQoKSArICdIZWxwJ1wiXG4gICAgICAgIGNsYXNzPVwiZm9ybS10ZXh0IHRleHQtc2Vjb25kYXJ5XCJcbiAgICAgICAgW2lubmVySFRNTF09XCJoZWxwVGV4dFwiXG4gICAgPjwvc21hbGw+XG5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG5cbiAgICA8c2VsZWN0XG4gICAgICAgICpuZ0lmPVwiIW11bHRpcGxlXCJcbiAgICAgICAgW2NsYXNzLmlzLWludmFsaWRdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KCkgfHwgaGFzSW5oZXJpdEVycm9yRnJvbVBhcmVudCgpXCJcbiAgICAgICAgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIlxuICAgICAgICBbbmFtZV09XCJuYW1lIHx8IGxhYmVsXCJcbiAgICAgICAgW2F0dHIuaWRdPVwiYnVpbGRDaGlsZElkKClcIlxuICAgICAgICBbYXR0ci5kaXNhYmxlZF09XCJkaXNhYmxlZCA/ICdkaXNhYmxlZCcgOiBudWxsXCJcbiAgICAgICAgW2F0dHIuYXJpYS1kZXNjcmliZWRieV09XCJnZXREZXNjcmliZWRCeSgpXCJcbiAgICAgICAgW2F0dHIuYXJpYS1pbnZhbGlkXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpIHx8IG51bGxcIlxuICAgICAgICBbYXR0ci5hcmlhLXJlcXVpcmVkXT1cInJlcXVpcmVkIHx8IG51bGxcIlxuICAgICAgICBbYXR0ci5hdXRvY29tcGxldGVdPVwiZ2V0QXV0b0NvbXBsZXRlKClcIlxuICAgICAgICBbbmdNb2RlbF09XCJtb2RlbFwiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInVwZGF0ZU5nTW9kZWwoJGV2ZW50KVwiXG4gICAgICAgIFtjb21wYXJlV2l0aF09XCJjb21wYXJlRm4uYmluZCh0aGlzKVwiXG4gICAgICAgIChjaGFuZ2UpPVwiaGFuZGxlQ2hhbmdlKG1vZGVsKVwiXG4gICAgICAgICNlbnRyeUNvbXBvbmVudFxuICAgICAgICBuZ0RlZmF1bHRDb250cm9sXG4gICAgPlxuICAgICAgICA8b3B0aW9uICpuZ0lmPVwiIXJlcXVpcmVkXCIgW25nVmFsdWVdPVwibnVsbFwiPi08L29wdGlvbj5cbiAgICAgICAgPG9wdGlvblxuICAgICAgICAgICAgKm5nRm9yPVwibGV0IGVsZW1lbnQgb2YgZWxlbWVudHNcIlxuICAgICAgICAgICAgW25nVmFsdWVdPVwiZ2V0VmFsdWUoZWxlbWVudClcIlxuICAgICAgICAgICAgW2F0dHIuc2VsZWN0ZWRdPVwiaXNFbGVtZW50U2VsZWN0ZWQoZWxlbWVudCkgPyAnc2VsZWN0ZWQnIDogbnVsbFwiXG4gICAgICAgICAgICBbYXR0ci5kaXNhYmxlZF09XCJnZXREaXNhYmxlZChlbGVtZW50KSA/ICdkaXNhYmxlZCcgOiBudWxsXCJcbiAgICAgICAgICAgIFtpbm5lckhUTUxdPVwiZ2V0TGFiZWwoZWxlbWVudClcIlxuICAgICAgICA+PC9vcHRpb24+XG4gICAgPC9zZWxlY3Q+XG4gICAgPHNlbGVjdFxuICAgICAgICAqbmdJZj1cIm11bHRpcGxlXCJcbiAgICAgICAgbXVsdGlwbGVcbiAgICAgICAgW2F0dHIuYXJpYS1tdWx0aXNlbGVjdGFibGVdPVwidHJ1ZVwiXG4gICAgICAgIFtjbGFzcy5pcy1pbnZhbGlkXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpIHx8IGhhc0luaGVyaXRFcnJvckZyb21QYXJlbnQoKVwiXG4gICAgICAgIGNsYXNzPVwiZm9ybS1jb250cm9sXCJcbiAgICAgICAgW25hbWVdPVwibmFtZSB8fCBsYWJlbFwiXG4gICAgICAgIFthdHRyLmlkXT1cImJ1aWxkQ2hpbGRJZCgpXCJcbiAgICAgICAgW2F0dHIuZGlzYWJsZWRdPVwiZGlzYWJsZWQgPyAnZGlzYWJsZWQnIDogbnVsbFwiXG4gICAgICAgIFthdHRyLmFyaWEtZGVzY3JpYmVkYnldPVwiZ2V0RGVzY3JpYmVkQnkoKVwiXG4gICAgICAgIFthdHRyLmFyaWEtaW52YWxpZF09XCJoYXNFcnJvcnNUb0Rpc3BsYXkoKSB8fCBudWxsXCJcbiAgICAgICAgW2F0dHIuYXJpYS1yZXF1aXJlZF09XCJyZXF1aXJlZCB8fCBudWxsXCJcbiAgICAgICAgW25nTW9kZWxdPVwibW9kZWxcIlxuICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJ1cGRhdGVOZ01vZGVsKCRldmVudClcIlxuICAgICAgICBbY29tcGFyZVdpdGhdPVwiY29tcGFyZUZuLmJpbmQodGhpcylcIlxuICAgICAgICAoY2hhbmdlKT1cImhhbmRsZUNoYW5nZShtb2RlbClcIlxuICAgICAgICAjZW50cnlDb21wb25lbnRcbiAgICAgICAgbmdEZWZhdWx0Q29udHJvbFxuICAgID5cbiAgICAgICAgPG9wdGlvblxuICAgICAgICAgICAgKm5nRm9yPVwibGV0IGVsZW1lbnQgb2YgZWxlbWVudHNcIlxuICAgICAgICAgICAgW25nVmFsdWVdPVwiZ2V0VmFsdWUoZWxlbWVudClcIlxuICAgICAgICAgICAgW2F0dHIuc2VsZWN0ZWRdPVwiaXNFbGVtZW50U2VsZWN0ZWQoZWxlbWVudCkgPyAnc2VsZWN0ZWQnIDogbnVsbFwiXG4gICAgICAgICAgICBbYXR0ci5hcmlhLXNlbGVjdGVkXT1cImlzRWxlbWVudFNlbGVjdGVkKGVsZW1lbnQpXCJcbiAgICAgICAgPlxuICAgICAgICAgICAge3sgZ2V0TGFiZWwoZWxlbWVudCkgfX1cbiAgICAgICAgPC9vcHRpb24+XG4gICAgPC9zZWxlY3Q+XG48L2Rpdj5cbiJdfQ==
@@ -31,7 +31,7 @@ export class FoehnConfirmModalComponent {
31
31
  }
32
32
  }
33
33
  FoehnConfirmModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnConfirmModalComponent, deps: [{ token: i1.FoehnConfirmModalService }], target: i0.ɵɵFactoryTarget.Component });
34
- FoehnConfirmModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnConfirmModalComponent, selector: "foehn-confirm-modal", ngImport: i0, template: "<foehn-modal\n [modalHeaderText]=\"modalContent.title || 'Confirmation'\"\n modalSize=\"modal-md\"\n [isModalVisible]=\"isVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n [closeable]=\"\n modalContent.closeable !== null && modalContent.closeable !== undefined\n ? modalContent.closeable\n : true\n \"\n *ngIf=\"content | async as modalContent\"\n>\n <p [innerHTML]=\"modalContent.htmlContent\"></p>\n\n <div modal-footer>\n <div class=\"d-flex justify-content-end mr-2 mb-2 mt-2\">\n <button\n id=\"confirmButton\"\n class=\"btn btn-secondary\"\n (click)=\"cancel()\"\n >\n {{ modalContent.cancelButtonLabel || 'Annuler' }}\n </button>\n <button\n id=\"cancelButton\"\n class=\"btn btn-primary ml-3\"\n (click)=\"ok()\"\n >\n {{ modalContent.okButtonLabel || 'Confirmer' }}\n </button>\n </div>\n </div>\n</foehn-modal>\n", components: [{ type: i2.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "modalFooterText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i3.AsyncPipe } });
34
+ FoehnConfirmModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnConfirmModalComponent, selector: "foehn-confirm-modal", ngImport: i0, template: "<foehn-modal\n [modalHeaderText]=\"modalContent.title || 'Confirmation'\"\n modalSize=\"modal-md\"\n [isModalVisible]=\"isVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n [closeable]=\"\n modalContent.closeable !== null && modalContent.closeable !== undefined\n ? modalContent.closeable\n : true\n \"\n *ngIf=\"content | async as modalContent\"\n>\n <p [innerHTML]=\"modalContent.htmlContent\"></p>\n\n <div modal-footer>\n <div class=\"d-flex justify-content-end mr-2 mb-2 mt-2\">\n <button\n id=\"confirmButton\"\n class=\"btn btn-secondary\"\n (click)=\"cancel()\"\n >\n {{ modalContent.cancelButtonLabel || 'Annuler' }}\n </button>\n <button\n id=\"cancelButton\"\n class=\"btn btn-primary ml-3\"\n (click)=\"ok()\"\n >\n {{ modalContent.okButtonLabel || 'Confirmer' }}\n </button>\n </div>\n </div>\n</foehn-modal>\n", components: [{ type: i2.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i3.AsyncPipe } });
35
35
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnConfirmModalComponent, decorators: [{
36
36
  type: Component,
37
37
  args: [{ selector: 'foehn-confirm-modal', template: "<foehn-modal\n [modalHeaderText]=\"modalContent.title || 'Confirmation'\"\n modalSize=\"modal-md\"\n [isModalVisible]=\"isVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n [closeable]=\"\n modalContent.closeable !== null && modalContent.closeable !== undefined\n ? modalContent.closeable\n : true\n \"\n *ngIf=\"content | async as modalContent\"\n>\n <p [innerHTML]=\"modalContent.htmlContent\"></p>\n\n <div modal-footer>\n <div class=\"d-flex justify-content-end mr-2 mb-2 mt-2\">\n <button\n id=\"confirmButton\"\n class=\"btn btn-secondary\"\n (click)=\"cancel()\"\n >\n {{ modalContent.cancelButtonLabel || 'Annuler' }}\n </button>\n <button\n id=\"cancelButton\"\n class=\"btn btn-primary ml-3\"\n (click)=\"ok()\"\n >\n {{ modalContent.okButtonLabel || 'Confirmer' }}\n </button>\n </div>\n </div>\n</foehn-modal>\n" }]
@@ -28,7 +28,7 @@ export class FoehnHelpModalComponent {
28
28
  }
29
29
  }
30
30
  FoehnHelpModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnHelpModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
31
- FoehnHelpModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnHelpModalComponent, selector: "foehn-help-modal", inputs: { modalContent: "modalContent" }, viewQueries: [{ propertyName: "modalTrigger", first: true, predicate: ["modalTrigger"], descendants: true, static: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, static: true }], ngImport: i0, template: "<button\n type=\"button\"\n class=\"clear-button btn d-flex\"\n (click)=\"open()\"\n #modalTrigger\n>\n <foehn-icon-info-circle\n [class.mr-1]=\"hasContent()\"\n title=\"&nbsp;\"\n ></foehn-icon-info-circle>\n\n <span class=\"sr-only button-help-text\" *ngIf=\"!hasContent()\">\n Aide: {{ modalContent.title }}\n </span>\n\n <span #content>\n <ng-content></ng-content>\n </span>\n</button>\n<foehn-modal\n id=\"help-modal\"\n modalSize=\"modal-lg\"\n [modalHeaderText]=\"currentModalTitle\"\n [isModalVisible]=\"isModalVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n (click)=\"close()\"\n [modalTriggerHtmlElement]=\"modalTrigger\"\n>\n <ng-container *ngIf=\"modalContent\">\n <div *ngIf=\"!!modalContent.body\" [innerHtml]=\"modalContent.body\"></div>\n <img\n *ngFor=\"let image of modalContent.images\"\n [src]=\"image.src\"\n [alt]=\"image.alt\"\n class=\"mt-2\"\n width=\"100%\"\n height=\"auto\"\n />\n </ng-container>\n</foehn-modal>\n", styles: [":host ::ng-deep .modal-body{height:100%}:host ::ng-deep .clear-button.btn .svg-inline--fa{color:#000!important}.clear-button{background:none;margin-left:-1em}\n"], components: [{ type: i1.FoehnIconInfoCircleComponent, selector: "foehn-icon-info-circle" }, { type: i2.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "modalFooterText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
31
+ FoehnHelpModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnHelpModalComponent, selector: "foehn-help-modal", inputs: { modalContent: "modalContent" }, viewQueries: [{ propertyName: "modalTrigger", first: true, predicate: ["modalTrigger"], descendants: true, static: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, static: true }], ngImport: i0, template: "<button\n type=\"button\"\n class=\"clear-button btn d-flex\"\n (click)=\"open()\"\n #modalTrigger\n>\n <foehn-icon-info-circle\n [class.mr-1]=\"hasContent()\"\n title=\"&nbsp;\"\n ></foehn-icon-info-circle>\n\n <span class=\"sr-only button-help-text\" *ngIf=\"!hasContent()\">\n Aide: {{ modalContent.title }}\n </span>\n\n <span #content>\n <ng-content></ng-content>\n </span>\n</button>\n<foehn-modal\n id=\"help-modal\"\n modalSize=\"modal-lg\"\n [modalHeaderText]=\"currentModalTitle\"\n [isModalVisible]=\"isModalVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n (click)=\"close()\"\n [modalTriggerHtmlElement]=\"modalTrigger\"\n>\n <ng-container *ngIf=\"modalContent\">\n <div *ngIf=\"!!modalContent.body\" [innerHtml]=\"modalContent.body\"></div>\n <img\n *ngFor=\"let image of modalContent.images\"\n [src]=\"image.src\"\n [alt]=\"image.alt\"\n class=\"mt-2\"\n width=\"100%\"\n height=\"auto\"\n />\n </ng-container>\n</foehn-modal>\n", styles: [":host ::ng-deep .modal-body{height:100%}:host ::ng-deep .clear-button.btn .svg-inline--fa{color:#000!important}.clear-button{background:none;margin-left:-1em}\n"], components: [{ type: i1.FoehnIconInfoCircleComponent, selector: "foehn-icon-info-circle" }, { type: i2.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
32
32
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnHelpModalComponent, decorators: [{
33
33
  type: Component,
34
34
  args: [{ selector: 'foehn-help-modal', template: "<button\n type=\"button\"\n class=\"clear-button btn d-flex\"\n (click)=\"open()\"\n #modalTrigger\n>\n <foehn-icon-info-circle\n [class.mr-1]=\"hasContent()\"\n title=\"&nbsp;\"\n ></foehn-icon-info-circle>\n\n <span class=\"sr-only button-help-text\" *ngIf=\"!hasContent()\">\n Aide: {{ modalContent.title }}\n </span>\n\n <span #content>\n <ng-content></ng-content>\n </span>\n</button>\n<foehn-modal\n id=\"help-modal\"\n modalSize=\"modal-lg\"\n [modalHeaderText]=\"currentModalTitle\"\n [isModalVisible]=\"isModalVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n (click)=\"close()\"\n [modalTriggerHtmlElement]=\"modalTrigger\"\n>\n <ng-container *ngIf=\"modalContent\">\n <div *ngIf=\"!!modalContent.body\" [innerHtml]=\"modalContent.body\"></div>\n <img\n *ngFor=\"let image of modalContent.images\"\n [src]=\"image.src\"\n [alt]=\"image.alt\"\n class=\"mt-2\"\n width=\"100%\"\n height=\"auto\"\n />\n </ng-container>\n</foehn-modal>\n", styles: [":host ::ng-deep .modal-body{height:100%}:host ::ng-deep .clear-button.btn .svg-inline--fa{color:#000!important}.clear-button{background:none;margin-left:-1em}\n"] }]
@@ -31,7 +31,7 @@ export class FoehnMenuItemTransmitComponent {
31
31
  }
32
32
  }
33
33
  FoehnMenuItemTransmitComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnMenuItemTransmitComponent, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.GesdemHandlerService }], target: i0.ɵɵFactoryTarget.Component });
34
- FoehnMenuItemTransmitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnMenuItemTransmitComponent, selector: "foehn-menu-item-transmit", inputs: { linkId: "linkId", rLink: "rLink", labelDicoKey: "labelDicoKey", dicoLabelPlaceHolders: "dicoLabelPlaceHolders", remainingErrorsAlertTitle: "remainingErrorsAlertTitle", remainingErrorsAlertBody: "remainingErrorsAlertBody" }, ngImport: i0, template: "<li\n class=\"d-flex flex-column flex-md-row justify-content-between border-bottom pb-3\"\n>\n <span class=\"align-self-baseline mt-2\">\n <a\n href=\"#\"\n (click)=\"$event.preventDefault(); transmit()\"\n [id]=\"linkId\"\n #transmitLink\n >\n {{ labelDicoKey | fromDictionary: dicoLabelPlaceHolders }}\n </a>\n <foehn-modal\n [(isModalVisible)]=\"showRemainingErrorsAlert\"\n [modalHeaderText]=\"remainingErrorsAlertTitle\"\n [modalTriggerHtmlElement]=\"transmitLink\"\n >\n <p>\n <span [innerHTML]=\"remainingErrorsAlertBody\"></span>\n <foehn-error-pill [errorPrefix]=\"''\"></foehn-error-pill>\n </p>\n </foehn-modal>\n </span>\n</li>\n", components: [{ type: i3.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "modalFooterText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }, { type: i4.FoehnErrorPillComponent, selector: "foehn-error-pill", inputs: ["errorPrefix", "incompleteIndicatorOnly"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe } });
34
+ FoehnMenuItemTransmitComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnMenuItemTransmitComponent, selector: "foehn-menu-item-transmit", inputs: { linkId: "linkId", rLink: "rLink", labelDicoKey: "labelDicoKey", dicoLabelPlaceHolders: "dicoLabelPlaceHolders", remainingErrorsAlertTitle: "remainingErrorsAlertTitle", remainingErrorsAlertBody: "remainingErrorsAlertBody" }, ngImport: i0, template: "<li\n class=\"d-flex flex-column flex-md-row justify-content-between border-bottom pb-3\"\n>\n <span class=\"align-self-baseline mt-2\">\n <a\n href=\"#\"\n (click)=\"$event.preventDefault(); transmit()\"\n [id]=\"linkId\"\n #transmitLink\n >\n {{ labelDicoKey | fromDictionary: dicoLabelPlaceHolders }}\n </a>\n <foehn-modal\n [(isModalVisible)]=\"showRemainingErrorsAlert\"\n [modalHeaderText]=\"remainingErrorsAlertTitle\"\n [modalTriggerHtmlElement]=\"transmitLink\"\n >\n <p>\n <span [innerHTML]=\"remainingErrorsAlertBody\"></span>\n <foehn-error-pill [errorPrefix]=\"''\"></foehn-error-pill>\n </p>\n </foehn-modal>\n </span>\n</li>\n", components: [{ type: i3.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }, { type: i4.FoehnErrorPillComponent, selector: "foehn-error-pill", inputs: ["errorPrefix", "incompleteIndicatorOnly"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe } });
35
35
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnMenuItemTransmitComponent, decorators: [{
36
36
  type: Component,
37
37
  args: [{ selector: 'foehn-menu-item-transmit', template: "<li\n class=\"d-flex flex-column flex-md-row justify-content-between border-bottom pb-3\"\n>\n <span class=\"align-self-baseline mt-2\">\n <a\n href=\"#\"\n (click)=\"$event.preventDefault(); transmit()\"\n [id]=\"linkId\"\n #transmitLink\n >\n {{ labelDicoKey | fromDictionary: dicoLabelPlaceHolders }}\n </a>\n <foehn-modal\n [(isModalVisible)]=\"showRemainingErrorsAlert\"\n [modalHeaderText]=\"remainingErrorsAlertTitle\"\n [modalTriggerHtmlElement]=\"transmitLink\"\n >\n <p>\n <span [innerHTML]=\"remainingErrorsAlertBody\"></span>\n <foehn-error-pill [errorPrefix]=\"''\"></foehn-error-pill>\n </p>\n </foehn-modal>\n </span>\n</li>\n" }]
@@ -4,7 +4,6 @@ import * as i1 from "@angular/common";
4
4
  import * as i2 from "@angular/cdk/a11y";
5
5
  export class FoehnModalComponent {
6
6
  constructor() {
7
- this.modalFooterText = "L'Administration Cantonale Vaudoise";
8
7
  this.closeable = true;
9
8
  this.isModalVisibleChange = new EventEmitter();
10
9
  this.isVisible = false;
@@ -53,7 +52,7 @@ export class FoehnModalComponent {
53
52
  }
54
53
  }
55
54
  FoehnModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
56
- FoehnModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnModalComponent, selector: "foehn-modal", inputs: { id: "id", name: "name", modalSize: "modalSize", modalBodyText: "modalBodyText", modalHeaderText: "modalHeaderText", modalFooterText: "modalFooterText", closeable: "closeable", modalTriggerHtmlElement: "modalTriggerHtmlElement", isModalVisible: "isModalVisible" }, outputs: { isModalVisibleChange: "isModalVisibleChange" }, host: { listeners: { "keyup": "handleKeyboardEvent($event)" } }, viewQueries: [{ propertyName: "modalBody", first: true, predicate: ["modalBody"], descendants: true }, { propertyName: "modalTitle", first: true, predicate: ["modalTitle"], descendants: true }, { propertyName: "specificfooter", first: true, predicate: ["specificfooter"], descendants: true }, { propertyName: "modalDefaultCloseBtn", first: true, predicate: ["modalDefaultCloseBtn"], descendants: true }], ngImport: i0, template: "<div\n class=\"modal\"\n [id]=\"id || name\"\n role=\"dialog\"\n aria-labelledby=\"modalTitle\"\n aria-describedby=\"modalBody\"\n style=\"display: block\"\n *ngIf=\"isModalVisible\"\n cdkTrapFocus\n>\n <div class=\"modal-dialog modal-dialog-centered\" [ngClass]=\"modalSize\">\n <div class=\"modal-content\">\n <div\n class=\"modal-header d-flex\"\n [ngClass]=\"{ 'flex-row-reverse': closeable }\"\n >\n <button\n *ngIf=\"closeable\"\n (click)=\"isModalVisible = false\"\n type=\"button\"\n class=\"btn close\"\n aria-label=\"Fermer la boite de dialogue\"\n id=\"closeButton\"\n >\n <span aria-hidden=\"true\">&times;</span>\n </button>\n <h2\n class=\"modal-title h5\"\n id=\"modalTitle\"\n #modalTitle\n [innerHTML]=\"modalHeaderText\"\n ></h2>\n </div>\n <div class=\"modal-body\" id=\"modalBody\" #modalBody tabindex=\"-1\">\n <div *ngIf=\"modalBodyText\" [innerHTML]=\"modalBodyText\"></div>\n <ng-content></ng-content>\n </div>\n <div class=\"modal-footer w-100 d-block\">\n <div #specificfooter id=\"specificfooter\">\n <ng-content select=\"[modal-footer]\"></ng-content>\n </div>\n <ng-container *ngIf=\"!specificfooter.innerHTML.trim()\">\n <div modal-footer class=\"w-100\">\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <button\n (click)=\"isModalVisible = false\"\n class=\"btn btn-secondary w-100\"\n data-dismiss=\"modal\"\n aria-label=\"Fermer la boite de dialogue\"\n #modalDefaultCloseBtn\n >\n Fermer\n </button>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n</div>\n", styles: [".modal{top:0;left:0;height:100%;width:100%;position:fixed;z-index:9999;overflow:auto;background-color:#000;background-color:#0006}.modal-title{margin-top:.5em!important}.modal-logo{width:30px}.modal-footer{padding-top:20px}.modal-content{-webkit-animation-name:redirect-animatetop;-webkit-animation-duration:.4s;animation-name:redirect-animatetop;animation-duration:.4s}@keyframes redirect-animatetop{0%{top:-300px;opacity:0}to{top:0;opacity:1}}.redirect-modal-header{padding:14px 16px 10px;background-color:#152025;color:#fff}.redirect-modal-body{padding:10px 16px}.redirect-modal-footer{padding:14px 16px 10px;background-color:#152025;color:#fff}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
55
+ FoehnModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnModalComponent, selector: "foehn-modal", inputs: { id: "id", name: "name", modalSize: "modalSize", modalBodyText: "modalBodyText", modalHeaderText: "modalHeaderText", closeable: "closeable", modalTriggerHtmlElement: "modalTriggerHtmlElement", isModalVisible: "isModalVisible" }, outputs: { isModalVisibleChange: "isModalVisibleChange" }, host: { listeners: { "keyup": "handleKeyboardEvent($event)" } }, viewQueries: [{ propertyName: "modalBody", first: true, predicate: ["modalBody"], descendants: true }, { propertyName: "modalTitle", first: true, predicate: ["modalTitle"], descendants: true }, { propertyName: "specificfooter", first: true, predicate: ["specificfooter"], descendants: true }, { propertyName: "modalDefaultCloseBtn", first: true, predicate: ["modalDefaultCloseBtn"], descendants: true }], ngImport: i0, template: "<div\n class=\"modal\"\n [id]=\"id || name\"\n role=\"dialog\"\n aria-labelledby=\"modalTitle\"\n aria-describedby=\"modalBody\"\n style=\"display: block\"\n *ngIf=\"isModalVisible\"\n cdkTrapFocus\n>\n <div class=\"modal-dialog modal-dialog-centered\" [ngClass]=\"modalSize\">\n <div class=\"modal-content\">\n <div\n class=\"modal-header d-flex\"\n [ngClass]=\"{ 'flex-row-reverse': closeable }\"\n >\n <button\n *ngIf=\"closeable\"\n (click)=\"isModalVisible = false\"\n type=\"button\"\n class=\"btn close\"\n aria-label=\"Fermer la boite de dialogue\"\n id=\"closeButton\"\n >\n <span aria-hidden=\"true\">&times;</span>\n </button>\n <h2\n class=\"modal-title h5\"\n id=\"modalTitle\"\n #modalTitle\n [innerHTML]=\"modalHeaderText\"\n ></h2>\n </div>\n <div class=\"modal-body\" id=\"modalBody\" #modalBody tabindex=\"-1\">\n <div *ngIf=\"modalBodyText\" [innerHTML]=\"modalBodyText\"></div>\n <ng-content></ng-content>\n </div>\n <div class=\"modal-footer w-100 d-block\">\n <div #specificfooter id=\"specificfooter\">\n <ng-content select=\"[modal-footer]\"></ng-content>\n </div>\n <ng-container *ngIf=\"!specificfooter.innerHTML.trim()\">\n <div modal-footer class=\"w-100\">\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <button\n (click)=\"isModalVisible = false\"\n class=\"btn btn-secondary w-100\"\n data-dismiss=\"modal\"\n aria-label=\"Fermer la boite de dialogue\"\n #modalDefaultCloseBtn\n >\n Fermer\n </button>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n</div>\n", styles: [".modal{top:0;left:0;height:100%;width:100%;position:fixed;z-index:9999;overflow:auto;background-color:#000;background-color:#0006}.modal-title{margin-top:.5em!important}.modal-logo{width:30px}.modal-footer{padding-top:20px}.modal-content{-webkit-animation-name:redirect-animatetop;-webkit-animation-duration:.4s;animation-name:redirect-animatetop;animation-duration:.4s}@keyframes redirect-animatetop{0%{top:-300px;opacity:0}to{top:0;opacity:1}}.redirect-modal-header{padding:14px 16px 10px;background-color:#152025;color:#fff}.redirect-modal-body{padding:10px 16px}.redirect-modal-footer{padding:14px 16px 10px;background-color:#152025;color:#fff}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
57
56
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnModalComponent, decorators: [{
58
57
  type: Component,
59
58
  args: [{ selector: 'foehn-modal', template: "<div\n class=\"modal\"\n [id]=\"id || name\"\n role=\"dialog\"\n aria-labelledby=\"modalTitle\"\n aria-describedby=\"modalBody\"\n style=\"display: block\"\n *ngIf=\"isModalVisible\"\n cdkTrapFocus\n>\n <div class=\"modal-dialog modal-dialog-centered\" [ngClass]=\"modalSize\">\n <div class=\"modal-content\">\n <div\n class=\"modal-header d-flex\"\n [ngClass]=\"{ 'flex-row-reverse': closeable }\"\n >\n <button\n *ngIf=\"closeable\"\n (click)=\"isModalVisible = false\"\n type=\"button\"\n class=\"btn close\"\n aria-label=\"Fermer la boite de dialogue\"\n id=\"closeButton\"\n >\n <span aria-hidden=\"true\">&times;</span>\n </button>\n <h2\n class=\"modal-title h5\"\n id=\"modalTitle\"\n #modalTitle\n [innerHTML]=\"modalHeaderText\"\n ></h2>\n </div>\n <div class=\"modal-body\" id=\"modalBody\" #modalBody tabindex=\"-1\">\n <div *ngIf=\"modalBodyText\" [innerHTML]=\"modalBodyText\"></div>\n <ng-content></ng-content>\n </div>\n <div class=\"modal-footer w-100 d-block\">\n <div #specificfooter id=\"specificfooter\">\n <ng-content select=\"[modal-footer]\"></ng-content>\n </div>\n <ng-container *ngIf=\"!specificfooter.innerHTML.trim()\">\n <div modal-footer class=\"w-100\">\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <button\n (click)=\"isModalVisible = false\"\n class=\"btn btn-secondary w-100\"\n data-dismiss=\"modal\"\n aria-label=\"Fermer la boite de dialogue\"\n #modalDefaultCloseBtn\n >\n Fermer\n </button>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n</div>\n", styles: [".modal{top:0;left:0;height:100%;width:100%;position:fixed;z-index:9999;overflow:auto;background-color:#000;background-color:#0006}.modal-title{margin-top:.5em!important}.modal-logo{width:30px}.modal-footer{padding-top:20px}.modal-content{-webkit-animation-name:redirect-animatetop;-webkit-animation-duration:.4s;animation-name:redirect-animatetop;animation-duration:.4s}@keyframes redirect-animatetop{0%{top:-300px;opacity:0}to{top:0;opacity:1}}.redirect-modal-header{padding:14px 16px 10px;background-color:#152025;color:#fff}.redirect-modal-body{padding:10px 16px}.redirect-modal-footer{padding:14px 16px 10px;background-color:#152025;color:#fff}\n"] }]
@@ -67,8 +66,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
67
66
  type: Input
68
67
  }], modalHeaderText: [{
69
68
  type: Input
70
- }], modalFooterText: [{
71
- type: Input
72
69
  }], closeable: [{
73
70
  type: Input
74
71
  }], modalTriggerHtmlElement: [{
@@ -93,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
93
90
  type: HostListener,
94
91
  args: ['keyup', ['$event']]
95
92
  }] } });
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-modal.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-modal/foehn-modal.component.ts","../../../../projects/prestations-ng/src/foehn-modal/foehn-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EAET,YAAY,EACZ,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,EACZ,MAAM,eAAe,CAAC;;;;AAOvB,MAAM,OAAO,mBAAmB;IALhC;QAsBI,oBAAe,GAAG,qCAAqC,CAAC;QAGxD,cAAS,GAAG,IAAI,CAAC;QAMjB,yBAAoB,GAAG,IAAI,YAAY,EAAE,CAAC;QAclC,cAAS,GAAG,KAAK,CAAC;KAkD7B;IAhDG,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,IACI,cAAc,CAAC,GAAY;QAC3B,4EAA4E;QAC5E,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;QAE/B,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;QACrB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC/C,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;QAC3B,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IAC3C,CAAC;IAGD,mBAAmB,CAAC,KAAoB;QACpC,IAAI,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,EAAE;YAC1C,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;SAC/B;IACL,CAAC;IAEO,gBAAgB,CAAC,SAAkB;QACvC,sFAAsF;QACtF,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,SAAS,EAAE;gBACX,IAAI,IAAI,CAAC,oBAAoB,EAAE;oBAC3B,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;iBACnD;qBAAM,IAAI,IAAI,CAAC,SAAS,EAAE;oBACvB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;iBACxC;gBACD,2FAA2F;gBAC3F,0CAA0C;gBAC1C,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,cAAc,EAAE,CAAC;iBAClD;aACJ;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,mBAAmB,CAAC,OAAgB,EAAE,SAAkB;QAC5D,iGAAiG;QACjG,0EAA0E;QAC1E,iCAAiC;QACjC,IAAI,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,uBAAuB,EAAE;YACvD,IAAI,CAAC,uBAAuB,CAAC,KAAK,EAAE,CAAC;SACxC;IACL,CAAC;;gHAzFQ,mBAAmB;oGAAnB,mBAAmB,s1BCfhC,m+EA8DA;2FD/Ca,mBAAmB;kBAL/B,SAAS;+BACI,aAAa;8BAMvB,EAAE;sBADD,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,aAAa;sBADZ,KAAK;gBAIN,eAAe;sBADd,KAAK;gBAIN,eAAe;sBADd,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,uBAAuB;sBADtB,KAAK;gBAIN,oBAAoB;sBADnB,MAAM;gBAIP,SAAS;sBADR,SAAS;uBAAC,WAAW;gBAItB,UAAU;sBADT,SAAS;uBAAC,YAAY;gBAIvB,cAAc;sBADb,SAAS;uBAAC,gBAAgB;gBAI3B,oBAAoB;sBADnB,SAAS;uBAAC,sBAAsB;gBAU7B,cAAc;sBADjB,KAAK;gBAYN,mBAAmB;sBADlB,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    Output,\n    ViewChild\n} from '@angular/core';\n\n@Component({\n    selector: 'foehn-modal',\n    templateUrl: './foehn-modal.component.html',\n    styleUrls: ['./foehn-modal.component.css']\n})\nexport class FoehnModalComponent {\n    @Input()\n    id: string;\n\n    @Input()\n    name: string;\n\n    @Input()\n    modalSize: string;\n\n    @Input()\n    modalBodyText: string;\n\n    @Input()\n    modalHeaderText: string;\n\n    @Input()\n    modalFooterText = \"L'Administration Cantonale Vaudoise\";\n\n    @Input()\n    closeable = true;\n\n    @Input()\n    modalTriggerHtmlElement: HTMLElement;\n\n    @Output()\n    isModalVisibleChange = new EventEmitter();\n\n    @ViewChild('modalBody')\n    modalBody: ElementRef;\n\n    @ViewChild('modalTitle')\n    modalTitle: ElementRef;\n\n    @ViewChild('specificfooter')\n    specificfooter: ElementRef;\n\n    @ViewChild('modalDefaultCloseBtn')\n    modalDefaultCloseBtn: ElementRef;\n\n    private isVisible = false;\n\n    get isModalVisible(): boolean {\n        return this.isVisible;\n    }\n\n    @Input()\n    set isModalVisible(val: boolean) {\n        // Store the previous value to handle transitions from one state to another.\n        const wasOpen = this.isVisible;\n\n        this.isVisible = val;\n        this.isModalVisibleChange.emit(this.isVisible);\n        this.focusOnContainer(val);\n        this.focusOnModalTrigger(wasOpen, val);\n    }\n\n    @HostListener('keyup', ['$event'])\n    handleKeyboardEvent(event: KeyboardEvent): void {\n        if (this.closeable && event.key === 'Escape') {\n            this.isModalVisible = false;\n        }\n    }\n\n    private focusOnContainer(isVisible: boolean): void {\n        // Has to be a setTimeout as we're affecting the DOM outside of the Angular lifecycle.\n        setTimeout(() => {\n            if (isVisible) {\n                if (this.modalDefaultCloseBtn) {\n                    this.modalDefaultCloseBtn.nativeElement.focus();\n                } else if (this.modalBody) {\n                    this.modalBody.nativeElement.focus();\n                }\n                // this condition is useless because this.modalTitle should always be here when \"isVisible\"\n                // but not in tests, so we keep it for now\n                if (this.modalTitle) {\n                    this.modalTitle.nativeElement.scrollIntoView();\n                }\n            }\n        });\n    }\n\n    private focusOnModalTrigger(wasOpen: boolean, isVisible: boolean): void {\n        // Focus back on the trigger. No need for a setTimeout as the trigger should still be in the DOM.\n        // Only does it when the modal is closed from a open state to avoid to set\n        // the focus when the page loads.\n        if (wasOpen && !isVisible && this.modalTriggerHtmlElement) {\n            this.modalTriggerHtmlElement.focus();\n        }\n    }\n}\n","<div\n    class=\"modal\"\n    [id]=\"id || name\"\n    role=\"dialog\"\n    aria-labelledby=\"modalTitle\"\n    aria-describedby=\"modalBody\"\n    style=\"display: block\"\n    *ngIf=\"isModalVisible\"\n    cdkTrapFocus\n>\n    <div class=\"modal-dialog modal-dialog-centered\" [ngClass]=\"modalSize\">\n        <div class=\"modal-content\">\n            <div\n                class=\"modal-header d-flex\"\n                [ngClass]=\"{ 'flex-row-reverse': closeable }\"\n            >\n                <button\n                    *ngIf=\"closeable\"\n                    (click)=\"isModalVisible = false\"\n                    type=\"button\"\n                    class=\"btn close\"\n                    aria-label=\"Fermer la boite de dialogue\"\n                    id=\"closeButton\"\n                >\n                    <span aria-hidden=\"true\">&times;</span>\n                </button>\n                <h2\n                    class=\"modal-title h5\"\n                    id=\"modalTitle\"\n                    #modalTitle\n                    [innerHTML]=\"modalHeaderText\"\n                ></h2>\n            </div>\n            <div class=\"modal-body\" id=\"modalBody\" #modalBody tabindex=\"-1\">\n                <div *ngIf=\"modalBodyText\" [innerHTML]=\"modalBodyText\"></div>\n                <ng-content></ng-content>\n            </div>\n            <div class=\"modal-footer w-100 d-block\">\n                <div #specificfooter id=\"specificfooter\">\n                    <ng-content select=\"[modal-footer]\"></ng-content>\n                </div>\n                <ng-container *ngIf=\"!specificfooter.innerHTML.trim()\">\n                    <div modal-footer class=\"w-100\">\n                        <div class=\"d-md-flex\">\n                            <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n                                <button\n                                    (click)=\"isModalVisible = false\"\n                                    class=\"btn btn-secondary w-100\"\n                                    data-dismiss=\"modal\"\n                                    aria-label=\"Fermer la boite de dialogue\"\n                                    #modalDefaultCloseBtn\n                                >\n                                    Fermer\n                                </button>\n                            </div>\n                        </div>\n                    </div>\n                </ng-container>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-modal.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-modal/foehn-modal.component.ts","../../../../projects/prestations-ng/src/foehn-modal/foehn-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EAET,YAAY,EACZ,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,EACZ,MAAM,eAAe,CAAC;;;;AAOvB,MAAM,OAAO,mBAAmB;IALhC;QAsBI,cAAS,GAAG,IAAI,CAAC;QAMjB,yBAAoB,GAAG,IAAI,YAAY,EAAE,CAAC;QAclC,cAAS,GAAG,KAAK,CAAC;KAkD7B;IAhDG,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,IACI,cAAc,CAAC,GAAY;QAC3B,4EAA4E;QAC5E,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;QAE/B,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC;QACrB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC/C,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;QAC3B,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IAC3C,CAAC;IAGD,mBAAmB,CAAC,KAAoB;QACpC,IAAI,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,EAAE;YAC1C,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;SAC/B;IACL,CAAC;IAEO,gBAAgB,CAAC,SAAkB;QACvC,sFAAsF;QACtF,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,SAAS,EAAE;gBACX,IAAI,IAAI,CAAC,oBAAoB,EAAE;oBAC3B,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;iBACnD;qBAAM,IAAI,IAAI,CAAC,SAAS,EAAE;oBACvB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;iBACxC;gBACD,2FAA2F;gBAC3F,0CAA0C;gBAC1C,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,cAAc,EAAE,CAAC;iBAClD;aACJ;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,mBAAmB,CAAC,OAAgB,EAAE,SAAkB;QAC5D,iGAAiG;QACjG,0EAA0E;QAC1E,iCAAiC;QACjC,IAAI,OAAO,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,uBAAuB,EAAE;YACvD,IAAI,CAAC,uBAAuB,CAAC,KAAK,EAAE,CAAC;SACxC;IACL,CAAC;;gHAtFQ,mBAAmB;oGAAnB,mBAAmB,kzBCfhC,m+EA8DA;2FD/Ca,mBAAmB;kBAL/B,SAAS;+BACI,aAAa;8BAMvB,EAAE;sBADD,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,aAAa;sBADZ,KAAK;gBAIN,eAAe;sBADd,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,uBAAuB;sBADtB,KAAK;gBAIN,oBAAoB;sBADnB,MAAM;gBAIP,SAAS;sBADR,SAAS;uBAAC,WAAW;gBAItB,UAAU;sBADT,SAAS;uBAAC,YAAY;gBAIvB,cAAc;sBADb,SAAS;uBAAC,gBAAgB;gBAI3B,oBAAoB;sBADnB,SAAS;uBAAC,sBAAsB;gBAU7B,cAAc;sBADjB,KAAK;gBAYN,mBAAmB;sBADlB,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    Output,\n    ViewChild\n} from '@angular/core';\n\n@Component({\n    selector: 'foehn-modal',\n    templateUrl: './foehn-modal.component.html',\n    styleUrls: ['./foehn-modal.component.css']\n})\nexport class FoehnModalComponent {\n    @Input()\n    id: string;\n\n    @Input()\n    name: string;\n\n    @Input()\n    modalSize: string;\n\n    @Input()\n    modalBodyText: string;\n\n    @Input()\n    modalHeaderText: string;\n\n    @Input()\n    closeable = true;\n\n    @Input()\n    modalTriggerHtmlElement: HTMLElement;\n\n    @Output()\n    isModalVisibleChange = new EventEmitter();\n\n    @ViewChild('modalBody')\n    modalBody: ElementRef;\n\n    @ViewChild('modalTitle')\n    modalTitle: ElementRef;\n\n    @ViewChild('specificfooter')\n    specificfooter: ElementRef;\n\n    @ViewChild('modalDefaultCloseBtn')\n    modalDefaultCloseBtn: ElementRef;\n\n    private isVisible = false;\n\n    get isModalVisible(): boolean {\n        return this.isVisible;\n    }\n\n    @Input()\n    set isModalVisible(val: boolean) {\n        // Store the previous value to handle transitions from one state to another.\n        const wasOpen = this.isVisible;\n\n        this.isVisible = val;\n        this.isModalVisibleChange.emit(this.isVisible);\n        this.focusOnContainer(val);\n        this.focusOnModalTrigger(wasOpen, val);\n    }\n\n    @HostListener('keyup', ['$event'])\n    handleKeyboardEvent(event: KeyboardEvent): void {\n        if (this.closeable && event.key === 'Escape') {\n            this.isModalVisible = false;\n        }\n    }\n\n    private focusOnContainer(isVisible: boolean): void {\n        // Has to be a setTimeout as we're affecting the DOM outside of the Angular lifecycle.\n        setTimeout(() => {\n            if (isVisible) {\n                if (this.modalDefaultCloseBtn) {\n                    this.modalDefaultCloseBtn.nativeElement.focus();\n                } else if (this.modalBody) {\n                    this.modalBody.nativeElement.focus();\n                }\n                // this condition is useless because this.modalTitle should always be here when \"isVisible\"\n                // but not in tests, so we keep it for now\n                if (this.modalTitle) {\n                    this.modalTitle.nativeElement.scrollIntoView();\n                }\n            }\n        });\n    }\n\n    private focusOnModalTrigger(wasOpen: boolean, isVisible: boolean): void {\n        // Focus back on the trigger. No need for a setTimeout as the trigger should still be in the DOM.\n        // Only does it when the modal is closed from a open state to avoid to set\n        // the focus when the page loads.\n        if (wasOpen && !isVisible && this.modalTriggerHtmlElement) {\n            this.modalTriggerHtmlElement.focus();\n        }\n    }\n}\n","<div\n    class=\"modal\"\n    [id]=\"id || name\"\n    role=\"dialog\"\n    aria-labelledby=\"modalTitle\"\n    aria-describedby=\"modalBody\"\n    style=\"display: block\"\n    *ngIf=\"isModalVisible\"\n    cdkTrapFocus\n>\n    <div class=\"modal-dialog modal-dialog-centered\" [ngClass]=\"modalSize\">\n        <div class=\"modal-content\">\n            <div\n                class=\"modal-header d-flex\"\n                [ngClass]=\"{ 'flex-row-reverse': closeable }\"\n            >\n                <button\n                    *ngIf=\"closeable\"\n                    (click)=\"isModalVisible = false\"\n                    type=\"button\"\n                    class=\"btn close\"\n                    aria-label=\"Fermer la boite de dialogue\"\n                    id=\"closeButton\"\n                >\n                    <span aria-hidden=\"true\">&times;</span>\n                </button>\n                <h2\n                    class=\"modal-title h5\"\n                    id=\"modalTitle\"\n                    #modalTitle\n                    [innerHTML]=\"modalHeaderText\"\n                ></h2>\n            </div>\n            <div class=\"modal-body\" id=\"modalBody\" #modalBody tabindex=\"-1\">\n                <div *ngIf=\"modalBodyText\" [innerHTML]=\"modalBodyText\"></div>\n                <ng-content></ng-content>\n            </div>\n            <div class=\"modal-footer w-100 d-block\">\n                <div #specificfooter id=\"specificfooter\">\n                    <ng-content select=\"[modal-footer]\"></ng-content>\n                </div>\n                <ng-container *ngIf=\"!specificfooter.innerHTML.trim()\">\n                    <div modal-footer class=\"w-100\">\n                        <div class=\"d-md-flex\">\n                            <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n                                <button\n                                    (click)=\"isModalVisible = false\"\n                                    class=\"btn btn-secondary w-100\"\n                                    data-dismiss=\"modal\"\n                                    aria-label=\"Fermer la boite de dialogue\"\n                                    #modalDefaultCloseBtn\n                                >\n                                    Fermer\n                                </button>\n                            </div>\n                        </div>\n                    </div>\n                </ng-container>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
@@ -44,7 +44,7 @@ export class FoehnPageModalComponent {
44
44
  }
45
45
  }
46
46
  FoehnPageModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnPageModalComponent, deps: [{ token: i1.SessionInfo }, { token: i2.ApplicationInfoService }, { token: i3.FoehnPageModalService }], target: i0.ɵɵFactoryTarget.Component });
47
- FoehnPageModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnPageModalComponent, selector: "foehn-page-modal", ngImport: i0, template: "<foehn-modal\n modalHeaderText=\"Acc\u00E8s non autoris\u00E9\"\n modalSize=\"modal-lg\"\n [isModalVisible]=\"wrongPublicModalVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n [closeable]=\"false\"\n>\n <div class=\"modal-body\">\n Vous \u00EAtes connect\u00E9 pour le compte d\u2019un usager de type\n {{ getUserCategory() }}, or cette prestation est destin\u00E9e aux usagers de\n type :\n <ul>\n <li *ngFor=\"let pubCible of formattedPublicsCibles\">\n {{ pubCible }}\n </li>\n </ul>\n </div>\n <div class=\"modal-body\">\n Vous pouvez choisir de vous reconnecter et de continuer, ou bien\n d'abandonner.\n </div>\n\n <div modal-footer class=\"w-100\">\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <a\n class=\"btn btn-primary w-100\"\n [href]=\"getFullLoginUrl() | async\"\n >\n Se reconnecter\n </a>\n </div>\n <div class=\"ml-md-0 mr-md-2 mb-2 mt-2\">\n <a class=\"btn btn-primary w-100\" [href]=\"getAbortUrl() | async\">\n Abandonner\n </a>\n </div>\n </div>\n </div>\n</foehn-modal>\n", components: [{ type: i4.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "modalFooterText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }], directives: [{ type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i5.AsyncPipe } });
47
+ FoehnPageModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnPageModalComponent, selector: "foehn-page-modal", ngImport: i0, template: "<foehn-modal\n modalHeaderText=\"Acc\u00E8s non autoris\u00E9\"\n modalSize=\"modal-lg\"\n [isModalVisible]=\"wrongPublicModalVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n [closeable]=\"false\"\n>\n <div class=\"modal-body\">\n Vous \u00EAtes connect\u00E9 pour le compte d\u2019un usager de type\n {{ getUserCategory() }}, or cette prestation est destin\u00E9e aux usagers de\n type :\n <ul>\n <li *ngFor=\"let pubCible of formattedPublicsCibles\">\n {{ pubCible }}\n </li>\n </ul>\n </div>\n <div class=\"modal-body\">\n Vous pouvez choisir de vous reconnecter et de continuer, ou bien\n d'abandonner.\n </div>\n\n <div modal-footer class=\"w-100\">\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <a\n class=\"btn btn-primary w-100\"\n [href]=\"getFullLoginUrl() | async\"\n >\n Se reconnecter\n </a>\n </div>\n <div class=\"ml-md-0 mr-md-2 mb-2 mt-2\">\n <a class=\"btn btn-primary w-100\" [href]=\"getAbortUrl() | async\">\n Abandonner\n </a>\n </div>\n </div>\n </div>\n</foehn-modal>\n", components: [{ type: i4.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }], directives: [{ type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i5.AsyncPipe } });
48
48
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnPageModalComponent, decorators: [{
49
49
  type: Component,
50
50
  args: [{ selector: 'foehn-page-modal', template: "<foehn-modal\n modalHeaderText=\"Acc\u00E8s non autoris\u00E9\"\n modalSize=\"modal-lg\"\n [isModalVisible]=\"wrongPublicModalVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n [closeable]=\"false\"\n>\n <div class=\"modal-body\">\n Vous \u00EAtes connect\u00E9 pour le compte d\u2019un usager de type\n {{ getUserCategory() }}, or cette prestation est destin\u00E9e aux usagers de\n type :\n <ul>\n <li *ngFor=\"let pubCible of formattedPublicsCibles\">\n {{ pubCible }}\n </li>\n </ul>\n </div>\n <div class=\"modal-body\">\n Vous pouvez choisir de vous reconnecter et de continuer, ou bien\n d'abandonner.\n </div>\n\n <div modal-footer class=\"w-100\">\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <a\n class=\"btn btn-primary w-100\"\n [href]=\"getFullLoginUrl() | async\"\n >\n Se reconnecter\n </a>\n </div>\n <div class=\"ml-md-0 mr-md-2 mb-2 mt-2\">\n <a class=\"btn btn-primary w-100\" [href]=\"getAbortUrl() | async\">\n Abandonner\n </a>\n </div>\n </div>\n </div>\n</foehn-modal>\n" }]
@@ -1,3 +1,3 @@
1
1
  export class FoehnTableColumnConfiguration {
2
2
  }
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4tdGFibGUtY29sdW1uLWNvbmZpZ3VyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvZm9laG4tdGFibGUvZm9laG4tdGFibGUtY29sdW1uLWNvbmZpZ3VyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLDZCQUE2QjtDQU96QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBGb2VoblRhYmxlQ29sdW1uQ29uZmlndXJhdGlvbjxUPiB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBjb2x1bW5MYWJlbEtleTogc3RyaW5nO1xuICAgIGlzSW1wb3J0YW50PzogKGl0ZW06IFQpID0+IGJvb2xlYW47XG4gICAgdmFsdWVHZXR0ZXI6IChpdGVtOiBUKSA9PiBzdHJpbmc7XG4gICAgcm91dGVyTGlua0dldHRlcj86IChpdGVtOiBUKSA9PiBzdHJpbmc7XG4gICAgc29ydEF0dHJpYnV0ZT86IHN0cmluZztcbn1cbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4tdGFibGUtY29sdW1uLWNvbmZpZ3VyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvZm9laG4tdGFibGUvZm9laG4tdGFibGUtY29sdW1uLWNvbmZpZ3VyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSUEsTUFBTSxPQUFPLDZCQUE2QjtDQWlCekMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L25vLXVucmVzb2x2ZWRcbmltcG9ydCB7IEljb25EZWZpbml0aW9uIH0gZnJvbSAnQGZvcnRhd2Vzb21lL2ZvbnRhd2Vzb21lLWNvbW1vbi10eXBlcyc7XG5pbXBvcnQgeyBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY2xhc3MgRm9laG5UYWJsZUNvbHVtbkNvbmZpZ3VyYXRpb248VD4ge1xuICAgIGlkOiBzdHJpbmc7XG4gICAgY29sdW1uTGFiZWxLZXk6IHN0cmluZztcbiAgICBpc0ltcG9ydGFudD86IChpdGVtOiBUKSA9PiBib29sZWFuO1xuICAgIGljb25HZXR0ZXI/OiAoXG4gICAgICAgIGl0ZW06IFRcbiAgICApID0+IHtcbiAgICAgICAgaWNvbjogSWNvbkRlZmluaXRpb247XG4gICAgICAgIGxhYmVsOiBzdHJpbmc7XG4gICAgfTtcbiAgICB2YWx1ZUdldHRlcj86IChpdGVtOiBUKSA9PiBzdHJpbmc7XG4gICAgdGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjx1bmtub3duPjtcbiAgICAvKipcbiAgICAgKiBAZGVwcmVjYXRlZCBUaGUgbWV0aG9kIHNob3VsZCBub3QgYmUgdXNlZFxuICAgICAqL1xuICAgIHJvdXRlckxpbmtHZXR0ZXI/OiAoaXRlbTogVCkgPT4gc3RyaW5nO1xuICAgIHNvcnRBdHRyaWJ1dGU/OiBzdHJpbmc7XG59XG4iXX0=