@dsivd/prestations-ng 15.2.0 → 15.2.3-beta1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +26 -0
- package/dsivd-prestations-ng-v15.2.3-beta1.tgz +0 -0
- package/esm2020/foehn-checkables/foehn-checkable-group.component.mjs +9 -4
- package/esm2020/foehn-checkables/foehn-select.component.mjs +4 -17
- package/esm2020/foehn-page/foehn-page.component.mjs +10 -8
- package/esm2020/foehn-table/foehn-table-column-configuration.mjs +1 -1
- package/esm2020/foehn-table/foehn-table.component.mjs +12 -9
- package/esm2020/gesdem/gesdem-handler.service.mjs +2 -1
- package/esm2020/sdk-dictionary/default-dictionary.mjs +8 -5
- package/fesm2015/dsivd-prestations-ng.mjs +41 -41
- package/fesm2015/dsivd-prestations-ng.mjs.map +1 -1
- package/fesm2020/dsivd-prestations-ng.mjs +41 -41
- package/fesm2020/dsivd-prestations-ng.mjs.map +1 -1
- package/foehn-checkables/foehn-checkable-group.component.d.ts +1 -1
- package/foehn-checkables/foehn-select.component.d.ts +0 -9
- package/foehn-page/foehn-page.component.d.ts +1 -0
- package/foehn-table/foehn-table-column-configuration.d.ts +5 -0
- package/foehn-table/foehn-table.component.d.ts +3 -2
- package/package.json +1 -1
- package/dsivd-prestations-ng-v15.2.0.tgz +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -26,6 +26,32 @@ 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.component.ts](projects/prestations-ng/src/foehn-table/foehn-table.component.ts)
|
|
34
|
+
- `@Input() actionButtonsTemplate: TemplateRef<unknown>` adds a column for row actions
|
|
35
|
+
|
|
36
|
+
## [15.2.2]
|
|
37
|
+
|
|
38
|
+
### Fixed
|
|
39
|
+
|
|
40
|
+
- [foehn-select.component.html](projects/prestations-ng/src/foehn-checkables/foehn-select.component.html)
|
|
41
|
+
- use `elementValueIdentity` function if provided
|
|
42
|
+
|
|
43
|
+
### Added
|
|
44
|
+
|
|
45
|
+
- [foehn-table-column-configuration.ts](projects/prestations-ng/src/foehn-table/foehn-table-column-configuration.ts)
|
|
46
|
+
- added optional field `iconGetter` to display an icon in a cell
|
|
47
|
+
|
|
48
|
+
## [15.2.1]
|
|
49
|
+
|
|
50
|
+
### Updated
|
|
51
|
+
|
|
52
|
+
- [foehn-page.component.ts](projects/prestations-ng/src/foehn-page/foehn-page.component.ts)
|
|
53
|
+
- update login message (can be discarded to continue without login)
|
|
54
|
+
|
|
29
55
|
## [15.2.0]
|
|
30
56
|
|
|
31
57
|
### Updated
|
|
Binary file
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
|
-
import {
|
|
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
|
-
|
|
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
|
-
:
|
|
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
|
|
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,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4tc2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1jaGVja2FibGVzL2ZvZWhuLXNlbGVjdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvZm9laG4tY2hlY2thYmxlcy9mb2Vobi1zZWxlY3QuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFrQixNQUFNLGVBQWUsQ0FBQztBQUM3RSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNqRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7Ozs7O0FBYTNFLE1BQU0sT0FBTyxvQkFDVCxTQUFRLDRCQUE0QjtJQUtwQyxZQUFvQixJQUFZO1FBQzVCLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQURJLFNBQUksR0FBSixJQUFJLENBQVE7SUFFaEMsQ0FBQztJQUVEOzs7Ozs7Ozs7T0FTRztJQUNILDhEQUE4RDtJQUM5RCxTQUFTLENBQUMsTUFBVyxFQUFFLE1BQVc7UUFDOUIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNoRCxDQUFDOztpSEF2QlEsb0JBQW9CO3FHQUFwQixvQkFBb0IseUVBUmxCO1FBQ1A7WUFDSSxPQUFPLEVBQUUsbUJBQW1CO1lBQzVCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsb0JBQW9CLENBQUM7WUFDbkQsS0FBSyxFQUFFLElBQUk7U0FDZDtLQUNKLGlEQ2JMLHNvR0EwRkE7MkZEM0VhLG9CQUFvQjtrQkFYaEMsU0FBUzsrQkFDSSxjQUFjLGFBRWI7d0JBQ1A7NEJBQ0ksT0FBTyxFQUFFLG1CQUFtQjs0QkFDNUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUscUJBQXFCLENBQUM7NEJBQ25ELEtBQUssRUFBRSxJQUFJO3lCQUNkO3FCQUNKOzZGQU1ELFFBQVE7c0JBRFAsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5wdXQsIE5nWm9uZSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb2VobkNoZWNrYWJsZUdyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi9mb2Vobi1jaGVja2FibGUtZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7IEZvZWhuSW5wdXRDb21wb25lbnQgfSBmcm9tICcuLi9mb2Vobi1pbnB1dC9mb2Vobi1pbnB1dC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2ZvZWhuLXNlbGVjdCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2ZvZWhuLXNlbGVjdC5jb21wb25lbnQuaHRtbCcsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IEZvZWhuSW5wdXRDb21wb25lbnQsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBGb2VoblNlbGVjdENvbXBvbmVudCksXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZVxuICAgICAgICB9XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBGb2VoblNlbGVjdENvbXBvbmVudFxuICAgIGV4dGVuZHMgRm9laG5DaGVja2FibGVHcm91cENvbXBvbmVudFxuICAgIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKVxuICAgIG11bHRpcGxlOiBib29sZWFuO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSB6b25lOiBOZ1pvbmUpIHtcbiAgICAgICAgc3VwZXIoem9uZSk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQW5ndWxhciB1c2VzIG9iamVjdCBpZGVudGl0eSB0byBzZWxlY3Qgb3B0aW9uLiBJdCdzIHBvc3NpYmxlIGZvciB0aGUgaWRlbnRpdGllcyBvZiBpdGVtcyB0byBjaGFuZ2Ugd2hpbGUgdGhlIGRhdGEgZG9lcyBub3QuXG4gICAgICogVGhpcyBjYW4gaGFwcGVuLCBmb3IgZXhhbXBsZSwgaWYgdGhlIGl0ZW1zIGFyZSBwcm9kdWNlZCBmcm9tIGFuIFJQQyB0byB0aGUgc2VydmVyLCBhbmQgdGhhdCBSUEMgaXMgcmUtcnVuLlxuICAgICAqIEV2ZW4gaWYgdGhlIGRhdGEgaGFzbid0IGNoYW5nZWQsIHRoZSBzZWNvbmQgcmVzcG9uc2Ugd2lsbCBwcm9kdWNlIG9iamVjdHMgd2l0aCBkaWZmZXJlbnQgaWRlbnRpdGllcy5cbiAgICAgKiAoc2VlOiBodHRwczovL2FuZ3VsYXIuaW8vYXBpL2Zvcm1zL1NlbGVjdENvbnRyb2xWYWx1ZUFjY2Vzc29yI2N1c3RvbWl6aW5nLW9wdGlvbi1zZWxlY3Rpb24pXG4gICAgICpcbiAgICAgKiBAcGFyYW0gdmFsdWUxIGFzIGZpcnN0IHZhbHVlIHRvIGNvbXBhcmUgdG9cbiAgICAgKiBAcGFyYW0gdmFsdWUyIGFzIHZhbHVlIHRvIGJlIGNvbXBhcmVkIHRvXG4gICAgICogQHJldHVybnMgYm9vbGVhblxuICAgICAqL1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gICAgY29tcGFyZUZuKHZhbHVlMTogYW55LCB2YWx1ZTI6IGFueSk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5hcmVWYWx1ZXNFcXVhbHModmFsdWUxLCB2YWx1ZTIpO1xuICAgIH1cbn1cbiIsIjxkaXZcbiAgICBjbGFzcz1cImZvcm0tZ3JvdXBcIlxuICAgIFtjbGFzcy5oYXMtZGFuZ2VyXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpXCJcbiAgICBbY2xhc3MudmQtZm9ybS1ncm91cC1kYW5nZXJdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KClcIlxuICAgIFthdHRyLmlkXT1cImJ1aWxkSWQoJ0NvbnRhaW5lcicpXCJcbiAgICB0YWJpbmRleD1cIi0xXCJcbj5cbiAgICA8bGFiZWxcbiAgICAgICAgW2F0dHIuZm9yXT1cImJ1aWxkQ2hpbGRJZCgpXCJcbiAgICAgICAgKm5nSWY9XCIhIWxhYmVsXCJcbiAgICAgICAgW25nQ2xhc3NdPVwiaXNMYWJlbFNyT25seSA/ICdzci1vbmx5JyA6IGxhYmVsU3R5bGVNb2RpZmllclwiXG4gICAgPlxuICAgICAgICA8c3BhbiBbaW5uZXJIVE1MXT1cImxhYmVsXCI+PC9zcGFuPlxuICAgICAgICA8c3BhblxuICAgICAgICAgICAgKm5nSWY9XCIhcmVxdWlyZWQgJiYgIWhpZGVOb3RSZXF1aXJlZEV4dHJhTGFiZWxcIlxuICAgICAgICAgICAgYXJpYS1oaWRkZW49XCJ0cnVlXCJcbiAgICAgICAgPlxuICAgICAgICAgICAge3sgJ2ZvZWhuLWlucHV0Lm9wdGlvbmFsJyB8IGZyb21EaWN0aW9uYXJ5IH19XG4gICAgICAgIDwvc3Bhbj5cbiAgICA8L2xhYmVsPlxuXG4gICAgPGZvZWhuLXZhbGlkYXRpb24tYWxlcnRzIFtjb21wb25lbnRdPVwidGhpc1wiPjwvZm9laG4tdmFsaWRhdGlvbi1hbGVydHM+XG5cbiAgICA8ZGl2ICpuZ0lmPVwiIWVsZW1lbnRzXCI+Q2hhcmdlbWVudC4uLjwvZGl2PlxuXG4gICAgPHNtYWxsXG4gICAgICAgICpuZ0lmPVwiaGVscFRleHRcIlxuICAgICAgICBbYXR0ci5pZF09XCJidWlsZENoaWxkSWQoKSArICdIZWxwJ1wiXG4gICAgICAgIGNsYXNzPVwiZm9ybS10ZXh0IHRleHQtc2Vjb25kYXJ5XCJcbiAgICAgICAgW2lubmVySFRNTF09XCJoZWxwVGV4dFwiXG4gICAgPjwvc21hbGw+XG5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG5cbiAgICA8c2VsZWN0XG4gICAgICAgICpuZ0lmPVwiIW11bHRpcGxlXCJcbiAgICAgICAgW2NsYXNzLmlzLWludmFsaWRdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KCkgfHwgaGFzSW5oZXJpdEVycm9yRnJvbVBhcmVudCgpXCJcbiAgICAgICAgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIlxuICAgICAgICBbbmFtZV09XCJuYW1lIHx8IGxhYmVsXCJcbiAgICAgICAgW2F0dHIuaWRdPVwiYnVpbGRDaGlsZElkKClcIlxuICAgICAgICBbYXR0ci5kaXNhYmxlZF09XCJkaXNhYmxlZCA/ICdkaXNhYmxlZCcgOiBudWxsXCJcbiAgICAgICAgW2F0dHIuYXJpYS1kZXNjcmliZWRieV09XCJnZXREZXNjcmliZWRCeSgpXCJcbiAgICAgICAgW2F0dHIuYXJpYS1pbnZhbGlkXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpIHx8IG51bGxcIlxuICAgICAgICBbYXR0ci5hcmlhLXJlcXVpcmVkXT1cInJlcXVpcmVkIHx8IG51bGxcIlxuICAgICAgICBbYXR0ci5hdXRvY29tcGxldGVdPVwiZ2V0QXV0b0NvbXBsZXRlKClcIlxuICAgICAgICBbbmdNb2RlbF09XCJtb2RlbFwiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInVwZGF0ZU5nTW9kZWwoJGV2ZW50KVwiXG4gICAgICAgIFtjb21wYXJlV2l0aF09XCJjb21wYXJlRm4uYmluZCh0aGlzKVwiXG4gICAgICAgIChjaGFuZ2UpPVwiaGFuZGxlQ2hhbmdlKG1vZGVsKVwiXG4gICAgICAgICNlbnRyeUNvbXBvbmVudFxuICAgICAgICBuZ0RlZmF1bHRDb250cm9sXG4gICAgPlxuICAgICAgICA8b3B0aW9uICpuZ0lmPVwiIXJlcXVpcmVkXCIgW25nVmFsdWVdPVwibnVsbFwiPi08L29wdGlvbj5cbiAgICAgICAgPG9wdGlvblxuICAgICAgICAgICAgKm5nRm9yPVwibGV0IGVsZW1lbnQgb2YgZWxlbWVudHNcIlxuICAgICAgICAgICAgW25nVmFsdWVdPVwiZ2V0VmFsdWUoZWxlbWVudClcIlxuICAgICAgICAgICAgW2F0dHIuc2VsZWN0ZWRdPVwiaXNFbGVtZW50U2VsZWN0ZWQoZWxlbWVudCkgPyAnc2VsZWN0ZWQnIDogbnVsbFwiXG4gICAgICAgICAgICBbYXR0ci5kaXNhYmxlZF09XCJnZXREaXNhYmxlZChlbGVtZW50KSA/ICdkaXNhYmxlZCcgOiBudWxsXCJcbiAgICAgICAgICAgIFtpbm5lckhUTUxdPVwiZ2V0TGFiZWwoZWxlbWVudClcIlxuICAgICAgICA+PC9vcHRpb24+XG4gICAgPC9zZWxlY3Q+XG4gICAgPHNlbGVjdFxuICAgICAgICAqbmdJZj1cIm11bHRpcGxlXCJcbiAgICAgICAgbXVsdGlwbGVcbiAgICAgICAgW2F0dHIuYXJpYS1tdWx0aXNlbGVjdGFibGVdPVwidHJ1ZVwiXG4gICAgICAgIFtjbGFzcy5pcy1pbnZhbGlkXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpIHx8IGhhc0luaGVyaXRFcnJvckZyb21QYXJlbnQoKVwiXG4gICAgICAgIGNsYXNzPVwiZm9ybS1jb250cm9sXCJcbiAgICAgICAgW25hbWVdPVwibmFtZSB8fCBsYWJlbFwiXG4gICAgICAgIFthdHRyLmlkXT1cImJ1aWxkQ2hpbGRJZCgpXCJcbiAgICAgICAgW2F0dHIuZGlzYWJsZWRdPVwiZGlzYWJsZWQgPyAnZGlzYWJsZWQnIDogbnVsbFwiXG4gICAgICAgIFthdHRyLmFyaWEtZGVzY3JpYmVkYnldPVwiZ2V0RGVzY3JpYmVkQnkoKVwiXG4gICAgICAgIFthdHRyLmFyaWEtaW52YWxpZF09XCJoYXNFcnJvcnNUb0Rpc3BsYXkoKSB8fCBudWxsXCJcbiAgICAgICAgW2F0dHIuYXJpYS1yZXF1aXJlZF09XCJyZXF1aXJlZCB8fCBudWxsXCJcbiAgICAgICAgW25nTW9kZWxdPVwibW9kZWxcIlxuICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJ1cGRhdGVOZ01vZGVsKCRldmVudClcIlxuICAgICAgICBbY29tcGFyZVdpdGhdPVwiY29tcGFyZUZuLmJpbmQodGhpcylcIlxuICAgICAgICAoY2hhbmdlKT1cImhhbmRsZUNoYW5nZShtb2RlbClcIlxuICAgICAgICAjZW50cnlDb21wb25lbnRcbiAgICAgICAgbmdEZWZhdWx0Q29udHJvbFxuICAgID5cbiAgICAgICAgPG9wdGlvblxuICAgICAgICAgICAgKm5nRm9yPVwibGV0IGVsZW1lbnQgb2YgZWxlbWVudHNcIlxuICAgICAgICAgICAgW25nVmFsdWVdPVwiZ2V0VmFsdWUoZWxlbWVudClcIlxuICAgICAgICAgICAgW2F0dHIuc2VsZWN0ZWRdPVwiaXNFbGVtZW50U2VsZWN0ZWQoZWxlbWVudCkgPyAnc2VsZWN0ZWQnIDogbnVsbFwiXG4gICAgICAgICAgICBbYXR0ci5hcmlhLXNlbGVjdGVkXT1cImlzRWxlbWVudFNlbGVjdGVkKGVsZW1lbnQpXCJcbiAgICAgICAgPlxuICAgICAgICAgICAge3sgZ2V0TGFiZWwoZWxlbWVudCkgfX1cbiAgICAgICAgPC9vcHRpb24+XG4gICAgPC9zZWxlY3Q+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -23,11 +23,12 @@ import * as i16 from "../foehn-status-progress-bar/foehn-status-progress-bar.com
|
|
|
23
23
|
import * as i17 from "../foehn-icons/foehn-icon-external-link-alt.component";
|
|
24
24
|
import * as i18 from "../sdk-support-alert/support-alert-container.component";
|
|
25
25
|
import * as i19 from "../foehn-user-connected-as/foehn-user-connected-as.component";
|
|
26
|
-
import * as i20 from "../foehn-
|
|
27
|
-
import * as i21 from "
|
|
28
|
-
import * as i22 from "
|
|
29
|
-
import * as i23 from "
|
|
30
|
-
import * as i24 from "
|
|
26
|
+
import * as i20 from "../foehn-icons/foehn-icon-lock.component";
|
|
27
|
+
import * as i21 from "../foehn-footer/foehn-footer.component";
|
|
28
|
+
import * as i22 from "./foehn-page-modal.component";
|
|
29
|
+
import * as i23 from "../foehn-confirm-modal/foehn-confirm-modal.component";
|
|
30
|
+
import * as i24 from "@angular/common";
|
|
31
|
+
import * as i25 from "../sdk-dictionary/sdk-dictionary.pipe";
|
|
31
32
|
const LEAVING_ALERT_CONTENT = 'Ce changement de page entraine une perte des données non sauvegardées.<br/>Souhaitez-vous quand même continuer ?';
|
|
32
33
|
const LEAVING_ALERT_OK = 'Poursuivre sans sauvegarder';
|
|
33
34
|
const LEAVING_ALERT_CANCEL = 'Retourner à la prestation';
|
|
@@ -68,6 +69,7 @@ export class FoehnPageComponent {
|
|
|
68
69
|
* If set to 'false', hide the default Security Best Practice link.
|
|
69
70
|
*/
|
|
70
71
|
this.showDefaultSecurityBestPracticeLink = true;
|
|
72
|
+
this.loginMessagesHidden = false;
|
|
71
73
|
this.browserLinkTitlePrefix = 'Lien pour le téléchargement du navigateur internet';
|
|
72
74
|
this.browserNotSupportedBypass = false;
|
|
73
75
|
this.hasBlockingSupportAlert = supportAlertService.getHasAtLeastOneBlockingAlert();
|
|
@@ -177,10 +179,10 @@ export class FoehnPageComponent {
|
|
|
177
179
|
}
|
|
178
180
|
}
|
|
179
181
|
FoehnPageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnPageComponent, deps: [{ token: i1.Title }, { token: i2.FoehnPageService }, { token: i3.SupportAlertService }, { token: i4.FoehnNavigationService }, { token: i5.ApplicationInfoService }, { token: i6.GesdemEventService }, { token: i7.BreadcrumbEventService }, { token: i8.Router }, { token: i9.SessionInfo }, { token: i10.FoehnPageModalService }, { token: i11.SdkDictionaryService }, { token: i12.SdkStatisticsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
180
|
-
FoehnPageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnPageComponent, selector: "foehn-page", inputs: { appTitle: "appTitle", footerLinks: "footerLinks", supportAlertEnabled: "supportAlertEnabled", supportAlertUrl: "supportAlertUrl", etapeId: "etapeId", userConnectedAsDisplayed: "userConnectedAsDisplayed", statusProgressBarHidden: "statusProgressBarHidden", confirmLeavingAlert: "confirmLeavingAlert", showDefaultContactFooterLink: "showDefaultContactFooterLink", showDefaultGuideFooterLink: "showDefaultGuideFooterLink", showDefaultTermOfUseLink: "showDefaultTermOfUseLink", showDefaultSecurityBestPracticeLink: "showDefaultSecurityBestPracticeLink" }, usesOnChanges: true, ngImport: i0, template: "<foehn-header id=\"foehn_header\" [title]=\"appTitle\"></foehn-header>\n<foehn-growl id=\"foehn_growl\"></foehn-growl>\n<div class=\"vd-bg-pattern-gray\">\n <div class=\"container\">\n <foehn-breadcrumb\n [confirmLeavingAlert]=\"confirmLeavingAlert\"\n ></foehn-breadcrumb>\n </div>\n</div>\n<main id=\"main\">\n <div class=\"vd-bg-pattern-gray\">\n <div class=\"container\">\n <!-- Fix annoying flickering when the page loads -->\n <div class=\"h1 mt-0\" *ngIf=\"!pageTitle\"> </div>\n <h1\n [tabIndex]=\"-1\"\n class=\"mt-0\"\n id=\"page-title\"\n *ngIf=\"!!pageTitle\"\n [innerHTML]=\"pageTitle\"\n ></h1>\n </div>\n </div>\n\n <foehn-status-progress-bar\n [hidden]=\"statusProgressBarHidden\"\n ></foehn-status-progress-bar>\n\n <section\n *ngIf=\"!isBrowserSupported\"\n class=\"container alert alert-danger\"\n id=\"browser_not_supported_block\"\n role=\"alert\"\n >\n <p class=\"alert-heading\">\n <strong>\n Cette prestation n\u2019est pas compatible avec votre navigateur.\n </strong>\n </p>\n <p class=\"mb-0\">\n Nous vous invitons \u00E0 utiliser une version r\u00E9cente de\n <ng-container *ngIf=\"!isApplePlatform\">\n <a\n [title]=\"browserLinkTitlePrefix + ' Edge'\"\n href=\"https://www.microsoft.com/fr-ch/windows/microsoft-edge\"\n target=\"_blank\"\n >\n Edge\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ,\n </ng-container>\n <ng-container *ngIf=\"isApplePlatform\">\n <a\n [title]=\"browserLinkTitlePrefix + ' Safari'\"\n href=\"https://support.apple.com/downloads/safari\"\n target=\"_blank\"\n >\n Safari\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ,\n </ng-container>\n <a\n [title]=\"browserLinkTitlePrefix + ' Firefox'\"\n href=\"https://www.mozilla.org/fr/firefox/\"\n target=\"_blank\"\n >\n Firefox\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ou\n <a\n [title]=\"browserLinkTitlePrefix + ' Chrome'\"\n href=\"https://www.google.com/intl/fr/chrome/\"\n target=\"_blank\"\n >\n Chrome\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n .\n </p>\n <div class=\"row mt-3\">\n <div class=\"col-md-12\">\n <button\n id=\"browser_not_supported_bypass\"\n class=\"float-right btn btn-danger\"\n *ngIf=\"!browserNotSupportedBypass\"\n (click)=\"browserNotSupportedBypass = true\"\n >\n Continuer avec ce navigateur\n </button>\n </div>\n </div>\n </section>\n\n <sdk-support-alert-container\n *ngIf=\"supportAlertEnabled\"\n [etapeId]=\"etapeId\"\n [supportAlertUrl]=\"supportAlertUrl\"\n ></sdk-support-alert-container>\n <ng-container\n *ngIf=\"\n !(hasBlockingSupportAlert | async) &&\n (isBrowserSupported || browserNotSupportedBypass)\n \"\n >\n <div class=\"container mt-5\" id=\"page_content\">\n <foehn-user-connected-as\n *ngIf=\"displayUserCategory | async\"\n ></foehn-user-connected-as>\n <ng-container\n *ngIf=\"displayLoginMessages | async as displayLoginMessagesData\"\n >\n <div\n *ngIf=\"displayLoginMessagesData.displayShouldLoginMessage\"\n class=\"alert alert-info\"\n id=\"displayLoginMessage\"\n >\n <p\n [innerHTML]=\"\n getFullLoginMessage(\n displayLoginMessagesData.decisionElectroniqueAvailable\n ) | async\n \"\n ></p>\n <div class=\"d-flex justify-content-start mr-2 mb-2 mt-2\">\n <a\n class=\"btn btn-primary\"\n [href]=\"getFullLoginUrl() | async\"\n >\n {{ 'use-login.button.text' | fromDictionary }}\n </a>\n </div>\n </div>\n </ng-container>\n </div>\n <ng-content></ng-content>\n </ng-container>\n</main>\n<foehn-footer\n id=\"foehn_footer\"\n [links]=\"footerLinks\"\n [showDefaultContactLink]=\"showDefaultContactFooterLink\"\n [showDefaultGuideLink]=\"showDefaultGuideFooterLink\"\n [showDefaultTermOfUseLink]=\"showDefaultTermOfUseLink\"\n [showDefaultSecurityBestPracticeLink]=\"showDefaultSecurityBestPracticeLink\"\n></foehn-footer>\n<foehn-page-modal></foehn-page-modal>\n<foehn-confirm-modal></foehn-confirm-modal>\n", components: [{ type: i13.FoehnHeaderComponent, selector: "foehn-header", inputs: ["userInfo", "title"] }, { type: i14.FoehnGrowlComponent, selector: "foehn-growl" }, { type: i15.FoehnBreadcrumbComponent, selector: "foehn-breadcrumb", inputs: ["breadcrumbItems", "currentNav", "confirmLeavingAlert"] }, { type: i16.FoehnStatusProgressBarComponent, selector: "foehn-status-progress-bar", inputs: ["hidden"] }, { type: i17.FoehnIconExternalLinkAltComponent, selector: "foehn-icon-external-link-alt" }, { type: i18.SupportAlertContainerComponent, selector: "sdk-support-alert-container", inputs: ["etapeId", "supportAlertUrl"] }, { type: i19.FoehnUserConnectedAsComponent, selector: "foehn-user-connected-as" }, { type: i20.FoehnFooterComponent, selector: "foehn-footer", inputs: ["links", "showDefaultContactLink", "showDefaultGuideLink", "showDefaultTermOfUseLink", "showDefaultSecurityBestPracticeLink"] }, { type: i21.FoehnPageModalComponent, selector: "foehn-page-modal" }, { type: i22.FoehnConfirmModalComponent, selector: "foehn-confirm-modal" }], directives: [{ type: i23.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i23.AsyncPipe, "fromDictionary": i24.SdkDictionaryPipe } });
|
|
182
|
+
FoehnPageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnPageComponent, selector: "foehn-page", inputs: { appTitle: "appTitle", footerLinks: "footerLinks", supportAlertEnabled: "supportAlertEnabled", supportAlertUrl: "supportAlertUrl", etapeId: "etapeId", userConnectedAsDisplayed: "userConnectedAsDisplayed", statusProgressBarHidden: "statusProgressBarHidden", confirmLeavingAlert: "confirmLeavingAlert", showDefaultContactFooterLink: "showDefaultContactFooterLink", showDefaultGuideFooterLink: "showDefaultGuideFooterLink", showDefaultTermOfUseLink: "showDefaultTermOfUseLink", showDefaultSecurityBestPracticeLink: "showDefaultSecurityBestPracticeLink" }, usesOnChanges: true, ngImport: i0, template: "<foehn-header id=\"foehn_header\" [title]=\"appTitle\"></foehn-header>\n<foehn-growl id=\"foehn_growl\"></foehn-growl>\n<div class=\"vd-bg-pattern-gray\">\n <div class=\"container\">\n <foehn-breadcrumb\n [confirmLeavingAlert]=\"confirmLeavingAlert\"\n ></foehn-breadcrumb>\n </div>\n</div>\n<main id=\"main\">\n <div class=\"vd-bg-pattern-gray\">\n <div class=\"container\">\n <!-- Fix annoying flickering when the page loads -->\n <div class=\"h1 mt-0\" *ngIf=\"!pageTitle\"> </div>\n <h1\n [tabIndex]=\"-1\"\n class=\"mt-0\"\n id=\"page-title\"\n *ngIf=\"!!pageTitle\"\n [innerHTML]=\"pageTitle\"\n ></h1>\n </div>\n </div>\n\n <foehn-status-progress-bar\n [hidden]=\"statusProgressBarHidden\"\n ></foehn-status-progress-bar>\n\n <section\n *ngIf=\"!isBrowserSupported\"\n class=\"container alert alert-danger\"\n id=\"browser_not_supported_block\"\n role=\"alert\"\n >\n <p class=\"alert-heading\">\n <strong>\n Cette prestation n\u2019est pas compatible avec votre navigateur.\n </strong>\n </p>\n <p class=\"mb-0\">\n Nous vous invitons \u00E0 utiliser une version r\u00E9cente de\n <ng-container *ngIf=\"!isApplePlatform\">\n <a\n [title]=\"browserLinkTitlePrefix + ' Edge'\"\n href=\"https://www.microsoft.com/fr-ch/windows/microsoft-edge\"\n target=\"_blank\"\n >\n Edge\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ,\n </ng-container>\n <ng-container *ngIf=\"isApplePlatform\">\n <a\n [title]=\"browserLinkTitlePrefix + ' Safari'\"\n href=\"https://support.apple.com/downloads/safari\"\n target=\"_blank\"\n >\n Safari\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ,\n </ng-container>\n <a\n [title]=\"browserLinkTitlePrefix + ' Firefox'\"\n href=\"https://www.mozilla.org/fr/firefox/\"\n target=\"_blank\"\n >\n Firefox\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ou\n <a\n [title]=\"browserLinkTitlePrefix + ' Chrome'\"\n href=\"https://www.google.com/intl/fr/chrome/\"\n target=\"_blank\"\n >\n Chrome\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n .\n </p>\n <div class=\"row mt-3\">\n <div class=\"col-md-12\">\n <button\n id=\"browser_not_supported_bypass\"\n class=\"float-right btn btn-danger\"\n *ngIf=\"!browserNotSupportedBypass\"\n (click)=\"browserNotSupportedBypass = true\"\n >\n Continuer avec ce navigateur\n </button>\n </div>\n </div>\n </section>\n\n <sdk-support-alert-container\n *ngIf=\"supportAlertEnabled\"\n [etapeId]=\"etapeId\"\n [supportAlertUrl]=\"supportAlertUrl\"\n ></sdk-support-alert-container>\n <ng-container\n *ngIf=\"\n !(hasBlockingSupportAlert | async) &&\n (isBrowserSupported || browserNotSupportedBypass)\n \"\n >\n <div class=\"container mt-5\" id=\"page_content\">\n <foehn-user-connected-as\n *ngIf=\"displayUserCategory | async\"\n ></foehn-user-connected-as>\n <ng-container\n *ngIf=\"displayLoginMessages | async as displayLoginMessagesData\"\n >\n <div\n class=\"container\"\n *ngIf=\"\n displayLoginMessagesData.displayShouldLoginMessage &&\n !loginMessagesHidden\n \"\n >\n <div class=\"row\">\n <div\n class=\"alert alert-info col-md-8\"\n id=\"displayLoginMessage\"\n >\n <p\n [innerHTML]=\"\n getFullLoginMessage(\n displayLoginMessagesData.decisionElectroniqueAvailable\n ) | async\n \"\n ></p>\n\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <button\n id=\"continueWithoutLoginButton\"\n class=\"btn btn-link\"\n (click)=\"loginMessagesHidden = true\"\n >\n {{\n 'use-login.continue-without-login.button.text'\n | fromDictionary\n }}\n </button>\n </div>\n <div class=\"ml-md-0 mr-md-2 mb-2 mt-2\">\n <a\n id=\"loginAndContinueButton\"\n class=\"btn btn-primary\"\n [href]=\"getFullLoginUrl() | async\"\n >\n {{\n 'use-login.button.text'\n | fromDictionary\n }}\n <span class=\"ml-1\" aria-hidden=\"true\">\n <foehn-icon-lock\n [title]=\"\n 'use-login.button.text'\n | fromDictionary\n \"\n ></foehn-icon-lock>\n </span>\n </a>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n <ng-content></ng-content>\n </ng-container>\n</main>\n<foehn-footer\n id=\"foehn_footer\"\n [links]=\"footerLinks\"\n [showDefaultContactLink]=\"showDefaultContactFooterLink\"\n [showDefaultGuideLink]=\"showDefaultGuideFooterLink\"\n [showDefaultTermOfUseLink]=\"showDefaultTermOfUseLink\"\n [showDefaultSecurityBestPracticeLink]=\"showDefaultSecurityBestPracticeLink\"\n></foehn-footer>\n<foehn-page-modal></foehn-page-modal>\n<foehn-confirm-modal></foehn-confirm-modal>\n", components: [{ type: i13.FoehnHeaderComponent, selector: "foehn-header", inputs: ["userInfo", "title"] }, { type: i14.FoehnGrowlComponent, selector: "foehn-growl" }, { type: i15.FoehnBreadcrumbComponent, selector: "foehn-breadcrumb", inputs: ["breadcrumbItems", "currentNav", "confirmLeavingAlert"] }, { type: i16.FoehnStatusProgressBarComponent, selector: "foehn-status-progress-bar", inputs: ["hidden"] }, { type: i17.FoehnIconExternalLinkAltComponent, selector: "foehn-icon-external-link-alt" }, { type: i18.SupportAlertContainerComponent, selector: "sdk-support-alert-container", inputs: ["etapeId", "supportAlertUrl"] }, { type: i19.FoehnUserConnectedAsComponent, selector: "foehn-user-connected-as" }, { type: i20.FoehnIconLockComponent, selector: "foehn-icon-lock" }, { type: i21.FoehnFooterComponent, selector: "foehn-footer", inputs: ["links", "showDefaultContactLink", "showDefaultGuideLink", "showDefaultTermOfUseLink", "showDefaultSecurityBestPracticeLink"] }, { type: i22.FoehnPageModalComponent, selector: "foehn-page-modal" }, { type: i23.FoehnConfirmModalComponent, selector: "foehn-confirm-modal" }], directives: [{ type: i24.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i24.AsyncPipe, "fromDictionary": i25.SdkDictionaryPipe } });
|
|
181
183
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnPageComponent, decorators: [{
|
|
182
184
|
type: Component,
|
|
183
|
-
args: [{ selector: 'foehn-page', template: "<foehn-header id=\"foehn_header\" [title]=\"appTitle\"></foehn-header>\n<foehn-growl id=\"foehn_growl\"></foehn-growl>\n<div class=\"vd-bg-pattern-gray\">\n <div class=\"container\">\n <foehn-breadcrumb\n [confirmLeavingAlert]=\"confirmLeavingAlert\"\n ></foehn-breadcrumb>\n </div>\n</div>\n<main id=\"main\">\n <div class=\"vd-bg-pattern-gray\">\n <div class=\"container\">\n <!-- Fix annoying flickering when the page loads -->\n <div class=\"h1 mt-0\" *ngIf=\"!pageTitle\"> </div>\n <h1\n [tabIndex]=\"-1\"\n class=\"mt-0\"\n id=\"page-title\"\n *ngIf=\"!!pageTitle\"\n [innerHTML]=\"pageTitle\"\n ></h1>\n </div>\n </div>\n\n <foehn-status-progress-bar\n [hidden]=\"statusProgressBarHidden\"\n ></foehn-status-progress-bar>\n\n <section\n *ngIf=\"!isBrowserSupported\"\n class=\"container alert alert-danger\"\n id=\"browser_not_supported_block\"\n role=\"alert\"\n >\n <p class=\"alert-heading\">\n <strong>\n Cette prestation n\u2019est pas compatible avec votre navigateur.\n </strong>\n </p>\n <p class=\"mb-0\">\n Nous vous invitons \u00E0 utiliser une version r\u00E9cente de\n <ng-container *ngIf=\"!isApplePlatform\">\n <a\n [title]=\"browserLinkTitlePrefix + ' Edge'\"\n href=\"https://www.microsoft.com/fr-ch/windows/microsoft-edge\"\n target=\"_blank\"\n >\n Edge\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ,\n </ng-container>\n <ng-container *ngIf=\"isApplePlatform\">\n <a\n [title]=\"browserLinkTitlePrefix + ' Safari'\"\n href=\"https://support.apple.com/downloads/safari\"\n target=\"_blank\"\n >\n Safari\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ,\n </ng-container>\n <a\n [title]=\"browserLinkTitlePrefix + ' Firefox'\"\n href=\"https://www.mozilla.org/fr/firefox/\"\n target=\"_blank\"\n >\n Firefox\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ou\n <a\n [title]=\"browserLinkTitlePrefix + ' Chrome'\"\n href=\"https://www.google.com/intl/fr/chrome/\"\n target=\"_blank\"\n >\n Chrome\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n .\n </p>\n <div class=\"row mt-3\">\n <div class=\"col-md-12\">\n <button\n id=\"browser_not_supported_bypass\"\n class=\"float-right btn btn-danger\"\n *ngIf=\"!browserNotSupportedBypass\"\n (click)=\"browserNotSupportedBypass = true\"\n >\n Continuer avec ce navigateur\n </button>\n </div>\n </div>\n </section>\n\n <sdk-support-alert-container\n *ngIf=\"supportAlertEnabled\"\n [etapeId]=\"etapeId\"\n [supportAlertUrl]=\"supportAlertUrl\"\n ></sdk-support-alert-container>\n <ng-container\n *ngIf=\"\n !(hasBlockingSupportAlert | async) &&\n (isBrowserSupported || browserNotSupportedBypass)\n \"\n >\n <div class=\"container mt-5\" id=\"page_content\">\n <foehn-user-connected-as\n *ngIf=\"displayUserCategory | async\"\n ></foehn-user-connected-as>\n <ng-container\n *ngIf=\"displayLoginMessages | async as displayLoginMessagesData\"\n >\n <div\n *ngIf=\"displayLoginMessagesData.displayShouldLoginMessage\"\n class=\"alert alert-info\"\n
|
|
185
|
+
args: [{ selector: 'foehn-page', template: "<foehn-header id=\"foehn_header\" [title]=\"appTitle\"></foehn-header>\n<foehn-growl id=\"foehn_growl\"></foehn-growl>\n<div class=\"vd-bg-pattern-gray\">\n <div class=\"container\">\n <foehn-breadcrumb\n [confirmLeavingAlert]=\"confirmLeavingAlert\"\n ></foehn-breadcrumb>\n </div>\n</div>\n<main id=\"main\">\n <div class=\"vd-bg-pattern-gray\">\n <div class=\"container\">\n <!-- Fix annoying flickering when the page loads -->\n <div class=\"h1 mt-0\" *ngIf=\"!pageTitle\"> </div>\n <h1\n [tabIndex]=\"-1\"\n class=\"mt-0\"\n id=\"page-title\"\n *ngIf=\"!!pageTitle\"\n [innerHTML]=\"pageTitle\"\n ></h1>\n </div>\n </div>\n\n <foehn-status-progress-bar\n [hidden]=\"statusProgressBarHidden\"\n ></foehn-status-progress-bar>\n\n <section\n *ngIf=\"!isBrowserSupported\"\n class=\"container alert alert-danger\"\n id=\"browser_not_supported_block\"\n role=\"alert\"\n >\n <p class=\"alert-heading\">\n <strong>\n Cette prestation n\u2019est pas compatible avec votre navigateur.\n </strong>\n </p>\n <p class=\"mb-0\">\n Nous vous invitons \u00E0 utiliser une version r\u00E9cente de\n <ng-container *ngIf=\"!isApplePlatform\">\n <a\n [title]=\"browserLinkTitlePrefix + ' Edge'\"\n href=\"https://www.microsoft.com/fr-ch/windows/microsoft-edge\"\n target=\"_blank\"\n >\n Edge\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ,\n </ng-container>\n <ng-container *ngIf=\"isApplePlatform\">\n <a\n [title]=\"browserLinkTitlePrefix + ' Safari'\"\n href=\"https://support.apple.com/downloads/safari\"\n target=\"_blank\"\n >\n Safari\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ,\n </ng-container>\n <a\n [title]=\"browserLinkTitlePrefix + ' Firefox'\"\n href=\"https://www.mozilla.org/fr/firefox/\"\n target=\"_blank\"\n >\n Firefox\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n ou\n <a\n [title]=\"browserLinkTitlePrefix + ' Chrome'\"\n href=\"https://www.google.com/intl/fr/chrome/\"\n target=\"_blank\"\n >\n Chrome\n <span class=\"sr-only\">(lien externe)</span>\n <span aria-hidden=\"true\">\n <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n </span>\n </a>\n .\n </p>\n <div class=\"row mt-3\">\n <div class=\"col-md-12\">\n <button\n id=\"browser_not_supported_bypass\"\n class=\"float-right btn btn-danger\"\n *ngIf=\"!browserNotSupportedBypass\"\n (click)=\"browserNotSupportedBypass = true\"\n >\n Continuer avec ce navigateur\n </button>\n </div>\n </div>\n </section>\n\n <sdk-support-alert-container\n *ngIf=\"supportAlertEnabled\"\n [etapeId]=\"etapeId\"\n [supportAlertUrl]=\"supportAlertUrl\"\n ></sdk-support-alert-container>\n <ng-container\n *ngIf=\"\n !(hasBlockingSupportAlert | async) &&\n (isBrowserSupported || browserNotSupportedBypass)\n \"\n >\n <div class=\"container mt-5\" id=\"page_content\">\n <foehn-user-connected-as\n *ngIf=\"displayUserCategory | async\"\n ></foehn-user-connected-as>\n <ng-container\n *ngIf=\"displayLoginMessages | async as displayLoginMessagesData\"\n >\n <div\n class=\"container\"\n *ngIf=\"\n displayLoginMessagesData.displayShouldLoginMessage &&\n !loginMessagesHidden\n \"\n >\n <div class=\"row\">\n <div\n class=\"alert alert-info col-md-8\"\n id=\"displayLoginMessage\"\n >\n <p\n [innerHTML]=\"\n getFullLoginMessage(\n displayLoginMessagesData.decisionElectroniqueAvailable\n ) | async\n \"\n ></p>\n\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <button\n id=\"continueWithoutLoginButton\"\n class=\"btn btn-link\"\n (click)=\"loginMessagesHidden = true\"\n >\n {{\n 'use-login.continue-without-login.button.text'\n | fromDictionary\n }}\n </button>\n </div>\n <div class=\"ml-md-0 mr-md-2 mb-2 mt-2\">\n <a\n id=\"loginAndContinueButton\"\n class=\"btn btn-primary\"\n [href]=\"getFullLoginUrl() | async\"\n >\n {{\n 'use-login.button.text'\n | fromDictionary\n }}\n <span class=\"ml-1\" aria-hidden=\"true\">\n <foehn-icon-lock\n [title]=\"\n 'use-login.button.text'\n | fromDictionary\n \"\n ></foehn-icon-lock>\n </span>\n </a>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n <ng-content></ng-content>\n </ng-container>\n</main>\n<foehn-footer\n id=\"foehn_footer\"\n [links]=\"footerLinks\"\n [showDefaultContactLink]=\"showDefaultContactFooterLink\"\n [showDefaultGuideLink]=\"showDefaultGuideFooterLink\"\n [showDefaultTermOfUseLink]=\"showDefaultTermOfUseLink\"\n [showDefaultSecurityBestPracticeLink]=\"showDefaultSecurityBestPracticeLink\"\n></foehn-footer>\n<foehn-page-modal></foehn-page-modal>\n<foehn-confirm-modal></foehn-confirm-modal>\n" }]
|
|
184
186
|
}], ctorParameters: function () { return [{ type: i1.Title }, { type: i2.FoehnPageService }, { type: i3.SupportAlertService }, { type: i4.FoehnNavigationService }, { type: i5.ApplicationInfoService }, { type: i6.GesdemEventService }, { type: i7.BreadcrumbEventService }, { type: i8.Router }, { type: i9.SessionInfo }, { type: i10.FoehnPageModalService }, { type: i11.SdkDictionaryService }, { type: i12.SdkStatisticsService }]; }, propDecorators: { appTitle: [{
|
|
185
187
|
type: Input
|
|
186
188
|
}], footerLinks: [{
|
|
@@ -212,4 +214,4 @@ export class DisplayLoginMessagesData {
|
|
|
212
214
|
this.displayShouldLoginMessage = displayShouldLoginMessage;
|
|
213
215
|
}
|
|
214
216
|
}
|
|
215
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-page.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-page/foehn-page.component.ts","../../../../projects/prestations-ng/src/foehn-page/foehn-page.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChanges\n} from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { FooterLink } from '../foehn-footer/footer-link.type';\nimport { Title } from '@angular/platform-browser';\nimport { FoehnPageService } from './foehn-page.service';\nimport { SupportAlertService } from '../sdk-support-alert/support-alert.service';\nimport { combineLatest, merge, Observable, of, Subscription } from 'rxjs';\nimport { FoehnNavigationService } from '../foehn-navigation/foehn-navigation.service';\nimport { ApplicationInfoService } from '../sdk-appinfo/application-info.service';\nimport { debounceTime, filter, map } from 'rxjs/operators';\nimport { EtapeInfo } from '../sdk-appinfo/application-info';\nimport { GesdemEventService } from '../gesdem/gesdem-event.service';\nimport { FoehnConfirmModalContent } from '../foehn-confirm-modal/foehn-confirm-modal-content';\nimport { BreadcrumbEventService } from '../foehn-breadcrumb/breadcrumb-event.service';\nimport { supportedBrowsers } from '../supported-browser';\nimport { SessionInfo } from '../sdk-session-info/session-info.service';\nimport { FoehnPageModalService } from '../foehn-page/foehn-page-modal.service';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { SdkStatisticsService } from '../sdk-statistics/sdk-statistics.service';\n\nconst LEAVING_ALERT_CONTENT =\n    'Ce changement de page entraine une perte des données non sauvegardées.<br/>Souhaitez-vous quand même continuer ?';\nconst LEAVING_ALERT_OK = 'Poursuivre sans sauvegarder';\nconst LEAVING_ALERT_CANCEL = 'Retourner à la prestation';\n\n@Component({\n    selector: 'foehn-page',\n    templateUrl: './foehn-page.component.html'\n})\nexport class FoehnPageComponent implements OnDestroy, OnChanges, OnInit {\n    @Input()\n    appTitle: string;\n\n    @Input()\n    footerLinks: FooterLink[];\n\n    @Input()\n    supportAlertEnabled = true;\n\n    @Input()\n    supportAlertUrl: string;\n\n    @Input()\n    etapeId: string;\n\n    @Input()\n    userConnectedAsDisplayed = true;\n\n    @Input()\n    statusProgressBarHidden: boolean;\n\n    @Input()\n    confirmLeavingAlert: FoehnConfirmModalContent = {\n        htmlContent: LEAVING_ALERT_CONTENT,\n        okButtonLabel: LEAVING_ALERT_OK,\n        cancelButtonLabel: LEAVING_ALERT_CANCEL\n    };\n\n    /**\n     * If set to 'false', hide the default Contact link in the footer.\n     */\n    @Input()\n    showDefaultContactFooterLink = true;\n\n    /**\n     * If set to 'false', hide the default Guide link in the footer.\n     */\n    @Input()\n    showDefaultGuideFooterLink = true;\n\n    /**\n     * If set to 'false', hide the default Terms of use link.\n     */\n    @Input()\n    showDefaultTermOfUseLink = true;\n\n    /**\n     * If set to 'false', hide the default Security Best Practice link.\n     */\n    @Input()\n    showDefaultSecurityBestPracticeLink = true;\n\n    pageTitle: string;\n\n    hasBlockingSupportAlert: Observable<boolean>;\n\n    displayUserCategory: Observable<boolean>;\n\n    displayLoginMessages: Observable<DisplayLoginMessagesData>;\n\n    isBrowserSupported: boolean;\n\n    isApplePlatform: boolean;\n\n    browserLinkTitlePrefix =\n        'Lien pour le téléchargement du navigateur internet';\n\n    browserNotSupportedBypass = false;\n\n    private readonly blockedSubscription: Subscription;\n\n    constructor(\n        private _titleService: Title,\n        private foehnPageService: FoehnPageService,\n        private supportAlertService: SupportAlertService,\n        private foehnNavigationService: FoehnNavigationService,\n        private applicationInfoService: ApplicationInfoService,\n        private gesdemEventService: GesdemEventService,\n        private breadcrumbService: BreadcrumbEventService,\n        private router: Router,\n        private sessionInfo: SessionInfo,\n        private foehnPageModalService: FoehnPageModalService,\n        private sdkDictionaryService: SdkDictionaryService,\n        private statisticsService: SdkStatisticsService\n    ) {\n        this.hasBlockingSupportAlert = supportAlertService.getHasAtLeastOneBlockingAlert();\n\n        this.blockedSubscription = combineLatest([\n            this.foehnPageService.foehnPageObservable(),\n            // Ensures there is at least one value in the observable.\n            merge(of(false), this.hasBlockingSupportAlert)\n        ]).subscribe(([title, blocked]) => {\n            if (blocked) {\n                this.setPageTitle('Prestation indisponible');\n            } else if (title) {\n                this.setPageTitle(title);\n            }\n        });\n        this.isBrowserSupported = supportedBrowsers.test(navigator.userAgent);\n        this.isApplePlatform = /(Mac|iPhone|iPod|iPad)/i.test(\n            navigator.platform\n        );\n\n        statisticsService.track();\n    }\n\n    ngOnInit(): void {\n        if (!this.isBrowserSupported) {\n            const pageTitle = 'Navigateur non supporté';\n            this.foehnPageService.setPageTitle(pageTitle);\n            this.breadcrumbService.setCurrentBreadcrumb({\n                url: null,\n                routerLink: null,\n                label: pageTitle\n            });\n        }\n\n        const isInitialStep = this.applicationInfoService.currentEtapeInfo.pipe(\n            map(\n                (currentEtapeInfo: EtapeInfo) =>\n                    currentEtapeInfo &&\n                    currentEtapeInfo.idMetierEtape ===\n                        currentEtapeInfo.idMetierPrestation\n            )\n        );\n\n        // const navigationUpdate: Observable<any> = of (true)\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        const navigationUpdate: Observable<any> = this.router.events.pipe(\n            filter(event => event instanceof NavigationEnd)\n        );\n\n        // Ensures there is at least one value in the observable.\n        const navigationAndInit = merge(of(true), navigationUpdate);\n        const formTransmitted = merge(\n            of(undefined),\n            this.gesdemEventService.formTransmittedObservable()\n        );\n\n        this.displayUserCategory = combineLatest([\n            isInitialStep,\n            this.foehnNavigationService.hasBeenInitialized(),\n            formTransmitted,\n            navigationAndInit\n        ]).pipe(\n            debounceTime(0), // without debounceTime, the outcome is less effective...\n            map(([initialStep, navServiceInitialized, backendResponse]) => {\n                if (navServiceInitialized) {\n                    const isFirstPage = this.foehnNavigationService.isFirstFormPage();\n                    const isLastPage = this.foehnNavigationService.isLastFormPage();\n                    const isCurrentRouteDefined =\n                        this.foehnNavigationService.getCurrentRouteIndex() !==\n                        null;\n                    return this.foehnPageService.isUserCategoryVisible(\n                        isFirstPage,\n                        isLastPage,\n                        this.userConnectedAsDisplayed,\n                        initialStep,\n                        this.sessionInfo.neverConnected,\n                        backendResponse,\n                        isCurrentRouteDefined\n                    );\n                }\n                return false;\n            })\n        );\n\n        const formInitializationObservable = merge(\n            of(undefined),\n            this.gesdemEventService.formInitializationObservable()\n        );\n\n        if (this.sessionInfo.neverConnected) {\n            this.displayLoginMessages = of(\n                new DisplayLoginMessagesData(false, false)\n            );\n        } else {\n            this.displayLoginMessages = combineLatest([\n                formInitializationObservable,\n                this.sessionInfo.data,\n                this.applicationInfoService.currentEtapeInfo\n            ]).pipe(\n                debounceTime(0), // without debounceTime, the outcome is less effective...\n                map(\n                    ([\n                        formInitialization,\n                        sessionInfoData,\n                        currentEtapeInfo\n                    ]) => {\n                        const isConnectedCyberOrIam = !!sessionInfoData;\n                        const isLastPage = this.foehnNavigationService.isLastFormPage();\n                        if (\n                            isConnectedCyberOrIam ||\n                            !currentEtapeInfo.deployeeCyber ||\n                            !!formInitialization ||\n                            isLastPage\n                        ) {\n                            return new DisplayLoginMessagesData(false, false);\n                        }\n\n                        return new DisplayLoginMessagesData(\n                            currentEtapeInfo?.decisionElectroniqueAvailable,\n                            true\n                        );\n                    }\n                )\n            );\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const etapeIdChange = changes.etapeId;\n        if (etapeIdChange && etapeIdChange.currentValue) {\n            this.foehnPageService.setCurrentEtapeId(etapeIdChange.currentValue);\n        }\n\n        const appTitleChange = changes.appTitle;\n        if (appTitleChange) {\n            this._titleService.setTitle(appTitleChange.currentValue);\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.blockedSubscription) {\n            this.blockedSubscription.unsubscribe();\n        }\n    }\n\n    getFullLoginUrl(): Observable<string> {\n        return this.foehnPageModalService.buildSelfRedirectionThroughCyberLogin();\n    }\n\n    getFullLoginMessage(\n        decisionElectroniqueAvailable: boolean\n    ): Observable<string> {\n        if (decisionElectroniqueAvailable) {\n            return combineLatest([\n                this.sdkDictionaryService.getKey('use-login.text'),\n                this.sdkDictionaryService.getKey(\n                    'use-login.text.decision-electronique-available'\n                )\n            ]).pipe(\n                map(\n                    ([loginMsg, decisionElectroniqueAvailableMsg]) =>\n                        `${loginMsg}<br/><br/>${decisionElectroniqueAvailableMsg}`\n                )\n            );\n        }\n        return this.sdkDictionaryService.getKey('use-login.text');\n    }\n\n    private setPageTitle(title: string): void {\n        this.pageTitle = title;\n    }\n}\n\nexport class DisplayLoginMessagesData {\n    decisionElectroniqueAvailable: boolean;\n    displayShouldLoginMessage: boolean;\n\n    constructor(\n        decisionElectroniqueAvailable: boolean,\n        displayShouldLoginMessage: boolean\n    ) {\n        this.decisionElectroniqueAvailable = decisionElectroniqueAvailable;\n        this.displayShouldLoginMessage = displayShouldLoginMessage;\n    }\n}\n","<foehn-header id=\"foehn_header\" [title]=\"appTitle\"></foehn-header>\n<foehn-growl id=\"foehn_growl\"></foehn-growl>\n<div class=\"vd-bg-pattern-gray\">\n    <div class=\"container\">\n        <foehn-breadcrumb\n            [confirmLeavingAlert]=\"confirmLeavingAlert\"\n        ></foehn-breadcrumb>\n    </div>\n</div>\n<main id=\"main\">\n    <div class=\"vd-bg-pattern-gray\">\n        <div class=\"container\">\n            <!-- Fix annoying flickering when the page loads -->\n            <div class=\"h1 mt-0\" *ngIf=\"!pageTitle\">&nbsp;</div>\n            <h1\n                [tabIndex]=\"-1\"\n                class=\"mt-0\"\n                id=\"page-title\"\n                *ngIf=\"!!pageTitle\"\n                [innerHTML]=\"pageTitle\"\n            ></h1>\n        </div>\n    </div>\n\n    <foehn-status-progress-bar\n        [hidden]=\"statusProgressBarHidden\"\n    ></foehn-status-progress-bar>\n\n    <section\n        *ngIf=\"!isBrowserSupported\"\n        class=\"container alert alert-danger\"\n        id=\"browser_not_supported_block\"\n        role=\"alert\"\n    >\n        <p class=\"alert-heading\">\n            <strong>\n                Cette prestation n’est pas compatible avec votre navigateur.\n            </strong>\n        </p>\n        <p class=\"mb-0\">\n            Nous vous invitons à utiliser une version récente de\n            <ng-container *ngIf=\"!isApplePlatform\">\n                <a\n                    [title]=\"browserLinkTitlePrefix + ' Edge'\"\n                    href=\"https://www.microsoft.com/fr-ch/windows/microsoft-edge\"\n                    target=\"_blank\"\n                >\n                    Edge\n                    <span class=\"sr-only\">(lien externe)</span>\n                    <span aria-hidden=\"true\">\n                        <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n                    </span>\n                </a>\n                ,\n            </ng-container>\n            <ng-container *ngIf=\"isApplePlatform\">\n                <a\n                    [title]=\"browserLinkTitlePrefix + ' Safari'\"\n                    href=\"https://support.apple.com/downloads/safari\"\n                    target=\"_blank\"\n                >\n                    Safari\n                    <span class=\"sr-only\">(lien externe)</span>\n                    <span aria-hidden=\"true\">\n                        <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n                    </span>\n                </a>\n                ,\n            </ng-container>\n            <a\n                [title]=\"browserLinkTitlePrefix + ' Firefox'\"\n                href=\"https://www.mozilla.org/fr/firefox/\"\n                target=\"_blank\"\n            >\n                Firefox\n                <span class=\"sr-only\">(lien externe)</span>\n                <span aria-hidden=\"true\">\n                    <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n                </span>\n            </a>\n            ou\n            <a\n                [title]=\"browserLinkTitlePrefix + ' Chrome'\"\n                href=\"https://www.google.com/intl/fr/chrome/\"\n                target=\"_blank\"\n            >\n                Chrome\n                <span class=\"sr-only\">(lien externe)</span>\n                <span aria-hidden=\"true\">\n                    <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n                </span>\n            </a>\n            .\n        </p>\n        <div class=\"row mt-3\">\n            <div class=\"col-md-12\">\n                <button\n                    id=\"browser_not_supported_bypass\"\n                    class=\"float-right btn btn-danger\"\n                    *ngIf=\"!browserNotSupportedBypass\"\n                    (click)=\"browserNotSupportedBypass = true\"\n                >\n                    Continuer avec ce navigateur\n                </button>\n            </div>\n        </div>\n    </section>\n\n    <sdk-support-alert-container\n        *ngIf=\"supportAlertEnabled\"\n        [etapeId]=\"etapeId\"\n        [supportAlertUrl]=\"supportAlertUrl\"\n    ></sdk-support-alert-container>\n    <ng-container\n        *ngIf=\"\n            !(hasBlockingSupportAlert | async) &&\n            (isBrowserSupported || browserNotSupportedBypass)\n        \"\n    >\n        <div class=\"container mt-5\" id=\"page_content\">\n            <foehn-user-connected-as\n                *ngIf=\"displayUserCategory | async\"\n            ></foehn-user-connected-as>\n            <ng-container\n                *ngIf=\"displayLoginMessages | async as displayLoginMessagesData\"\n            >\n                <div\n                    *ngIf=\"displayLoginMessagesData.displayShouldLoginMessage\"\n                    class=\"alert alert-info\"\n                    id=\"displayLoginMessage\"\n                >\n                    <p\n                        [innerHTML]=\"\n                            getFullLoginMessage(\n                                displayLoginMessagesData.decisionElectroniqueAvailable\n                            ) | async\n                        \"\n                    ></p>\n                    <div class=\"d-flex justify-content-start mr-2 mb-2 mt-2\">\n                        <a\n                            class=\"btn btn-primary\"\n                            [href]=\"getFullLoginUrl() | async\"\n                        >\n                            {{ 'use-login.button.text' | fromDictionary }}\n                        </a>\n                    </div>\n                </div>\n            </ng-container>\n        </div>\n        <ng-content></ng-content>\n    </ng-container>\n</main>\n<foehn-footer\n    id=\"foehn_footer\"\n    [links]=\"footerLinks\"\n    [showDefaultContactLink]=\"showDefaultContactFooterLink\"\n    [showDefaultGuideLink]=\"showDefaultGuideFooterLink\"\n    [showDefaultTermOfUseLink]=\"showDefaultTermOfUseLink\"\n    [showDefaultSecurityBestPracticeLink]=\"showDefaultSecurityBestPracticeLink\"\n></foehn-footer>\n<foehn-page-modal></foehn-page-modal>\n<foehn-confirm-modal></foehn-confirm-modal>\n"]}
|
|
217
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-page.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-page/foehn-page.component.ts","../../../../projects/prestations-ng/src/foehn-page/foehn-page.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChanges\n} from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { FooterLink } from '../foehn-footer/footer-link.type';\nimport { Title } from '@angular/platform-browser';\nimport { FoehnPageService } from './foehn-page.service';\nimport { SupportAlertService } from '../sdk-support-alert/support-alert.service';\nimport { combineLatest, merge, Observable, of, Subscription } from 'rxjs';\nimport { FoehnNavigationService } from '../foehn-navigation/foehn-navigation.service';\nimport { ApplicationInfoService } from '../sdk-appinfo/application-info.service';\nimport { debounceTime, filter, map } from 'rxjs/operators';\nimport { EtapeInfo } from '../sdk-appinfo/application-info';\nimport { GesdemEventService } from '../gesdem/gesdem-event.service';\nimport { FoehnConfirmModalContent } from '../foehn-confirm-modal/foehn-confirm-modal-content';\nimport { BreadcrumbEventService } from '../foehn-breadcrumb/breadcrumb-event.service';\nimport { supportedBrowsers } from '../supported-browser';\nimport { SessionInfo } from '../sdk-session-info/session-info.service';\nimport { FoehnPageModalService } from '../foehn-page/foehn-page-modal.service';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { SdkStatisticsService } from '../sdk-statistics/sdk-statistics.service';\n\nconst LEAVING_ALERT_CONTENT =\n    'Ce changement de page entraine une perte des données non sauvegardées.<br/>Souhaitez-vous quand même continuer ?';\nconst LEAVING_ALERT_OK = 'Poursuivre sans sauvegarder';\nconst LEAVING_ALERT_CANCEL = 'Retourner à la prestation';\n\n@Component({\n    selector: 'foehn-page',\n    templateUrl: './foehn-page.component.html'\n})\nexport class FoehnPageComponent implements OnDestroy, OnChanges, OnInit {\n    @Input()\n    appTitle: string;\n\n    @Input()\n    footerLinks: FooterLink[];\n\n    @Input()\n    supportAlertEnabled = true;\n\n    @Input()\n    supportAlertUrl: string;\n\n    @Input()\n    etapeId: string;\n\n    @Input()\n    userConnectedAsDisplayed = true;\n\n    @Input()\n    statusProgressBarHidden: boolean;\n\n    @Input()\n    confirmLeavingAlert: FoehnConfirmModalContent = {\n        htmlContent: LEAVING_ALERT_CONTENT,\n        okButtonLabel: LEAVING_ALERT_OK,\n        cancelButtonLabel: LEAVING_ALERT_CANCEL\n    };\n\n    /**\n     * If set to 'false', hide the default Contact link in the footer.\n     */\n    @Input()\n    showDefaultContactFooterLink = true;\n\n    /**\n     * If set to 'false', hide the default Guide link in the footer.\n     */\n    @Input()\n    showDefaultGuideFooterLink = true;\n\n    /**\n     * If set to 'false', hide the default Terms of use link.\n     */\n    @Input()\n    showDefaultTermOfUseLink = true;\n\n    /**\n     * If set to 'false', hide the default Security Best Practice link.\n     */\n    @Input()\n    showDefaultSecurityBestPracticeLink = true;\n\n    pageTitle: string;\n\n    hasBlockingSupportAlert: Observable<boolean>;\n\n    displayUserCategory: Observable<boolean>;\n\n    displayLoginMessages: Observable<DisplayLoginMessagesData>;\n\n    loginMessagesHidden = false;\n\n    isBrowserSupported: boolean;\n\n    isApplePlatform: boolean;\n\n    browserLinkTitlePrefix =\n        'Lien pour le téléchargement du navigateur internet';\n\n    browserNotSupportedBypass = false;\n\n    private readonly blockedSubscription: Subscription;\n\n    constructor(\n        private _titleService: Title,\n        private foehnPageService: FoehnPageService,\n        private supportAlertService: SupportAlertService,\n        private foehnNavigationService: FoehnNavigationService,\n        private applicationInfoService: ApplicationInfoService,\n        private gesdemEventService: GesdemEventService,\n        private breadcrumbService: BreadcrumbEventService,\n        private router: Router,\n        private sessionInfo: SessionInfo,\n        private foehnPageModalService: FoehnPageModalService,\n        private sdkDictionaryService: SdkDictionaryService,\n        private statisticsService: SdkStatisticsService\n    ) {\n        this.hasBlockingSupportAlert = supportAlertService.getHasAtLeastOneBlockingAlert();\n\n        this.blockedSubscription = combineLatest([\n            this.foehnPageService.foehnPageObservable(),\n            // Ensures there is at least one value in the observable.\n            merge(of(false), this.hasBlockingSupportAlert)\n        ]).subscribe(([title, blocked]) => {\n            if (blocked) {\n                this.setPageTitle('Prestation indisponible');\n            } else if (title) {\n                this.setPageTitle(title);\n            }\n        });\n        this.isBrowserSupported = supportedBrowsers.test(navigator.userAgent);\n        this.isApplePlatform = /(Mac|iPhone|iPod|iPad)/i.test(\n            navigator.platform\n        );\n\n        statisticsService.track();\n    }\n\n    ngOnInit(): void {\n        if (!this.isBrowserSupported) {\n            const pageTitle = 'Navigateur non supporté';\n            this.foehnPageService.setPageTitle(pageTitle);\n            this.breadcrumbService.setCurrentBreadcrumb({\n                url: null,\n                routerLink: null,\n                label: pageTitle\n            });\n        }\n\n        const isInitialStep = this.applicationInfoService.currentEtapeInfo.pipe(\n            map(\n                (currentEtapeInfo: EtapeInfo) =>\n                    currentEtapeInfo &&\n                    currentEtapeInfo.idMetierEtape ===\n                        currentEtapeInfo.idMetierPrestation\n            )\n        );\n\n        // const navigationUpdate: Observable<any> = of (true)\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        const navigationUpdate: Observable<any> = this.router.events.pipe(\n            filter(event => event instanceof NavigationEnd)\n        );\n\n        // Ensures there is at least one value in the observable.\n        const navigationAndInit = merge(of(true), navigationUpdate);\n        const formTransmitted = merge(\n            of(undefined),\n            this.gesdemEventService.formTransmittedObservable()\n        );\n\n        this.displayUserCategory = combineLatest([\n            isInitialStep,\n            this.foehnNavigationService.hasBeenInitialized(),\n            formTransmitted,\n            navigationAndInit\n        ]).pipe(\n            debounceTime(0), // without debounceTime, the outcome is less effective...\n            map(([initialStep, navServiceInitialized, backendResponse]) => {\n                if (navServiceInitialized) {\n                    const isFirstPage = this.foehnNavigationService.isFirstFormPage();\n                    const isLastPage = this.foehnNavigationService.isLastFormPage();\n                    const isCurrentRouteDefined =\n                        this.foehnNavigationService.getCurrentRouteIndex() !==\n                        null;\n                    return this.foehnPageService.isUserCategoryVisible(\n                        isFirstPage,\n                        isLastPage,\n                        this.userConnectedAsDisplayed,\n                        initialStep,\n                        this.sessionInfo.neverConnected,\n                        backendResponse,\n                        isCurrentRouteDefined\n                    );\n                }\n                return false;\n            })\n        );\n\n        const formInitializationObservable = merge(\n            of(undefined),\n            this.gesdemEventService.formInitializationObservable()\n        );\n\n        if (this.sessionInfo.neverConnected) {\n            this.displayLoginMessages = of(\n                new DisplayLoginMessagesData(false, false)\n            );\n        } else {\n            this.displayLoginMessages = combineLatest([\n                formInitializationObservable,\n                this.sessionInfo.data,\n                this.applicationInfoService.currentEtapeInfo\n            ]).pipe(\n                debounceTime(0), // without debounceTime, the outcome is less effective...\n                map(\n                    ([\n                        formInitialization,\n                        sessionInfoData,\n                        currentEtapeInfo\n                    ]) => {\n                        const isConnectedCyberOrIam = !!sessionInfoData;\n                        const isLastPage = this.foehnNavigationService.isLastFormPage();\n                        if (\n                            isConnectedCyberOrIam ||\n                            !currentEtapeInfo.deployeeCyber ||\n                            !!formInitialization ||\n                            isLastPage\n                        ) {\n                            return new DisplayLoginMessagesData(false, false);\n                        }\n\n                        return new DisplayLoginMessagesData(\n                            currentEtapeInfo?.decisionElectroniqueAvailable,\n                            true\n                        );\n                    }\n                )\n            );\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const etapeIdChange = changes.etapeId;\n        if (etapeIdChange && etapeIdChange.currentValue) {\n            this.foehnPageService.setCurrentEtapeId(etapeIdChange.currentValue);\n        }\n\n        const appTitleChange = changes.appTitle;\n        if (appTitleChange) {\n            this._titleService.setTitle(appTitleChange.currentValue);\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this.blockedSubscription) {\n            this.blockedSubscription.unsubscribe();\n        }\n    }\n\n    getFullLoginUrl(): Observable<string> {\n        return this.foehnPageModalService.buildSelfRedirectionThroughCyberLogin();\n    }\n\n    getFullLoginMessage(\n        decisionElectroniqueAvailable: boolean\n    ): Observable<string> {\n        if (decisionElectroniqueAvailable) {\n            return combineLatest([\n                this.sdkDictionaryService.getKey('use-login.text'),\n                this.sdkDictionaryService.getKey(\n                    'use-login.text.decision-electronique-available'\n                )\n            ]).pipe(\n                map(\n                    ([loginMsg, decisionElectroniqueAvailableMsg]) =>\n                        `${loginMsg}<br/><br/>${decisionElectroniqueAvailableMsg}`\n                )\n            );\n        }\n        return this.sdkDictionaryService.getKey('use-login.text');\n    }\n\n    private setPageTitle(title: string): void {\n        this.pageTitle = title;\n    }\n}\n\nexport class DisplayLoginMessagesData {\n    decisionElectroniqueAvailable: boolean;\n    displayShouldLoginMessage: boolean;\n\n    constructor(\n        decisionElectroniqueAvailable: boolean,\n        displayShouldLoginMessage: boolean\n    ) {\n        this.decisionElectroniqueAvailable = decisionElectroniqueAvailable;\n        this.displayShouldLoginMessage = displayShouldLoginMessage;\n    }\n}\n","<foehn-header id=\"foehn_header\" [title]=\"appTitle\"></foehn-header>\n<foehn-growl id=\"foehn_growl\"></foehn-growl>\n<div class=\"vd-bg-pattern-gray\">\n    <div class=\"container\">\n        <foehn-breadcrumb\n            [confirmLeavingAlert]=\"confirmLeavingAlert\"\n        ></foehn-breadcrumb>\n    </div>\n</div>\n<main id=\"main\">\n    <div class=\"vd-bg-pattern-gray\">\n        <div class=\"container\">\n            <!-- Fix annoying flickering when the page loads -->\n            <div class=\"h1 mt-0\" *ngIf=\"!pageTitle\">&nbsp;</div>\n            <h1\n                [tabIndex]=\"-1\"\n                class=\"mt-0\"\n                id=\"page-title\"\n                *ngIf=\"!!pageTitle\"\n                [innerHTML]=\"pageTitle\"\n            ></h1>\n        </div>\n    </div>\n\n    <foehn-status-progress-bar\n        [hidden]=\"statusProgressBarHidden\"\n    ></foehn-status-progress-bar>\n\n    <section\n        *ngIf=\"!isBrowserSupported\"\n        class=\"container alert alert-danger\"\n        id=\"browser_not_supported_block\"\n        role=\"alert\"\n    >\n        <p class=\"alert-heading\">\n            <strong>\n                Cette prestation n’est pas compatible avec votre navigateur.\n            </strong>\n        </p>\n        <p class=\"mb-0\">\n            Nous vous invitons à utiliser une version récente de\n            <ng-container *ngIf=\"!isApplePlatform\">\n                <a\n                    [title]=\"browserLinkTitlePrefix + ' Edge'\"\n                    href=\"https://www.microsoft.com/fr-ch/windows/microsoft-edge\"\n                    target=\"_blank\"\n                >\n                    Edge\n                    <span class=\"sr-only\">(lien externe)</span>\n                    <span aria-hidden=\"true\">\n                        <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n                    </span>\n                </a>\n                ,\n            </ng-container>\n            <ng-container *ngIf=\"isApplePlatform\">\n                <a\n                    [title]=\"browserLinkTitlePrefix + ' Safari'\"\n                    href=\"https://support.apple.com/downloads/safari\"\n                    target=\"_blank\"\n                >\n                    Safari\n                    <span class=\"sr-only\">(lien externe)</span>\n                    <span aria-hidden=\"true\">\n                        <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n                    </span>\n                </a>\n                ,\n            </ng-container>\n            <a\n                [title]=\"browserLinkTitlePrefix + ' Firefox'\"\n                href=\"https://www.mozilla.org/fr/firefox/\"\n                target=\"_blank\"\n            >\n                Firefox\n                <span class=\"sr-only\">(lien externe)</span>\n                <span aria-hidden=\"true\">\n                    <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n                </span>\n            </a>\n            ou\n            <a\n                [title]=\"browserLinkTitlePrefix + ' Chrome'\"\n                href=\"https://www.google.com/intl/fr/chrome/\"\n                target=\"_blank\"\n            >\n                Chrome\n                <span class=\"sr-only\">(lien externe)</span>\n                <span aria-hidden=\"true\">\n                    <foehn-icon-external-link-alt></foehn-icon-external-link-alt>\n                </span>\n            </a>\n            .\n        </p>\n        <div class=\"row mt-3\">\n            <div class=\"col-md-12\">\n                <button\n                    id=\"browser_not_supported_bypass\"\n                    class=\"float-right btn btn-danger\"\n                    *ngIf=\"!browserNotSupportedBypass\"\n                    (click)=\"browserNotSupportedBypass = true\"\n                >\n                    Continuer avec ce navigateur\n                </button>\n            </div>\n        </div>\n    </section>\n\n    <sdk-support-alert-container\n        *ngIf=\"supportAlertEnabled\"\n        [etapeId]=\"etapeId\"\n        [supportAlertUrl]=\"supportAlertUrl\"\n    ></sdk-support-alert-container>\n    <ng-container\n        *ngIf=\"\n            !(hasBlockingSupportAlert | async) &&\n            (isBrowserSupported || browserNotSupportedBypass)\n        \"\n    >\n        <div class=\"container mt-5\" id=\"page_content\">\n            <foehn-user-connected-as\n                *ngIf=\"displayUserCategory | async\"\n            ></foehn-user-connected-as>\n            <ng-container\n                *ngIf=\"displayLoginMessages | async as displayLoginMessagesData\"\n            >\n                <div\n                    class=\"container\"\n                    *ngIf=\"\n                        displayLoginMessagesData.displayShouldLoginMessage &&\n                        !loginMessagesHidden\n                    \"\n                >\n                    <div class=\"row\">\n                        <div\n                            class=\"alert alert-info col-md-8\"\n                            id=\"displayLoginMessage\"\n                        >\n                            <p\n                                [innerHTML]=\"\n                                    getFullLoginMessage(\n                                        displayLoginMessagesData.decisionElectroniqueAvailable\n                                    ) | async\n                                \"\n                            ></p>\n\n                            <div class=\"d-md-flex\">\n                                <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n                                    <button\n                                        id=\"continueWithoutLoginButton\"\n                                        class=\"btn btn-link\"\n                                        (click)=\"loginMessagesHidden = true\"\n                                    >\n                                        {{\n                                            'use-login.continue-without-login.button.text'\n                                                | fromDictionary\n                                        }}\n                                    </button>\n                                </div>\n                                <div class=\"ml-md-0 mr-md-2 mb-2 mt-2\">\n                                    <a\n                                        id=\"loginAndContinueButton\"\n                                        class=\"btn btn-primary\"\n                                        [href]=\"getFullLoginUrl() | async\"\n                                    >\n                                        {{\n                                            'use-login.button.text'\n                                                | fromDictionary\n                                        }}\n                                        <span class=\"ml-1\" aria-hidden=\"true\">\n                                            <foehn-icon-lock\n                                                [title]=\"\n                                                    'use-login.button.text'\n                                                        | fromDictionary\n                                                \"\n                                            ></foehn-icon-lock>\n                                        </span>\n                                    </a>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            </ng-container>\n        </div>\n        <ng-content></ng-content>\n    </ng-container>\n</main>\n<foehn-footer\n    id=\"foehn_footer\"\n    [links]=\"footerLinks\"\n    [showDefaultContactLink]=\"showDefaultContactFooterLink\"\n    [showDefaultGuideLink]=\"showDefaultGuideFooterLink\"\n    [showDefaultTermOfUseLink]=\"showDefaultTermOfUseLink\"\n    [showDefaultSecurityBestPracticeLink]=\"showDefaultSecurityBestPracticeLink\"\n></foehn-footer>\n<foehn-page-modal></foehn-page-modal>\n<foehn-confirm-modal></foehn-confirm-modal>\n"]}
|