@dsivd/prestations-ng 14.5.6 → 14.5.9-beta2

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.
@@ -125,9 +125,9 @@ export class FoehnPageComponent {
125
125
  this.applicationInfoService.currentEtapeInfo
126
126
  ]).pipe(debounceTime(0), // without debounceTime, the outcome is less effective...
127
127
  map(([formInitialization, sessionInfoData, currentEtapeInfo]) => {
128
- const isConnected = !!sessionInfoData && !!sessionInfoData.context;
128
+ const isConnectedCyberOrIam = !!sessionInfoData;
129
129
  const isLastPage = this.foehnNavigationService.isLastFormPage();
130
- if (isConnected ||
130
+ if (isConnectedCyberOrIam ||
131
131
  !currentEtapeInfo.deployeeCyber ||
132
132
  !!formInitialization ||
133
133
  isLastPage) {
@@ -206,4 +206,4 @@ export class DisplayLoginMessagesData {
206
206
  this.displayShouldLoginMessage = displayShouldLoginMessage;
207
207
  }
208
208
  }
209
- //# 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';\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    neverConnected: boolean;\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    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    ) {\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\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.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        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(([formInitialization, sessionInfoData, currentEtapeInfo]) => {\n                const isConnected =\n                    !!sessionInfoData && !!sessionInfoData.context;\n                const isLastPage = this.foehnNavigationService.isLastFormPage();\n                if (\n                    isConnected ||\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    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\n    id=\"foehn_header\"\n    [title]=\"appTitle\"\n    [neverConnected]=\"neverConnected\"\n></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            [neverConnected]=\"neverConnected\"\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    <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"]}
209
+ //# 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';\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    neverConnected: boolean;\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    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    ) {\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\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.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        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(([formInitialization, sessionInfoData, currentEtapeInfo]) => {\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    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\n    id=\"foehn_header\"\n    [title]=\"appTitle\"\n    [neverConnected]=\"neverConnected\"\n></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            [neverConnected]=\"neverConnected\"\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    <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"]}
@@ -30,11 +30,13 @@ export class GesdemActionRecoveryRegistrationComponent {
30
30
  this.isVisible = false;
31
31
  }
32
32
  ngOnInit() {
33
- this.isConnected = this.sessionInfoService.data.pipe(map(sessionInfo => !!sessionInfo && !!sessionInfo.context));
33
+ this.isConnectedCyber = this.sessionInfoService.data.pipe(map(sessionInfo => !!sessionInfo && !!sessionInfo.context));
34
+ const isConnectedIamAcv = this.sessionInfoService.data.pipe(map(sessionInfo => !!sessionInfo && !sessionInfo.context));
34
35
  this.canContinueLater = combineLatest([
35
36
  this.appInfoService.currentEtapeInfo,
36
- this.isConnected
37
- ]).pipe(map(([currentEtapeInfo, isConnected]) => this.canContinueLaterForEtape(currentEtapeInfo, isConnected)));
37
+ this.isConnectedCyber,
38
+ isConnectedIamAcv
39
+ ]).pipe(map(([currentEtapeInfo, isConnectedCyber, connectedIamAcv]) => this.canContinueLaterForEtape(currentEtapeInfo, isConnectedCyber, connectedIamAcv)));
38
40
  }
39
41
  get isModalVisible() {
40
42
  return this.isVisible;
@@ -42,11 +44,11 @@ export class GesdemActionRecoveryRegistrationComponent {
42
44
  open() {
43
45
  this.gesdemEventService
44
46
  .formSentObservable()
45
- .pipe(first(), filter(resp => !!resp.meta.reference), switchMap(() => this.isConnected))
46
- .subscribe(isConnected => {
47
+ .pipe(first(), filter(resp => !!resp.meta.reference), switchMap(() => this.isConnectedCyber))
48
+ .subscribe(isConnectedCyber => {
47
49
  this.mailSent = false;
48
50
  this.isVisible = true;
49
- if (!isConnected) {
51
+ if (!isConnectedCyber) {
50
52
  this.actionRecoveryService
51
53
  .getDefaultRecoveryValue(this.reference)
52
54
  // eslint-disable-next-line rxjs/no-nested-subscribe
@@ -93,10 +95,13 @@ export class GesdemActionRecoveryRegistrationComponent {
93
95
  ? this.gesdemService.lastResponse.meta.reference
94
96
  : null;
95
97
  }
96
- canContinueLaterForEtape(currentEtapeInfo, isConnected) {
98
+ canContinueLaterForEtape(currentEtapeInfo, isConnectedCyber, isConnectedIamAcv) {
99
+ if (isConnectedIamAcv) {
100
+ return false;
101
+ }
97
102
  // If not connected, take the "reprisePossible" flag from CatPrest
98
103
  // into account.
99
- if (!isConnected) {
104
+ if (!isConnectedCyber) {
100
105
  return currentEtapeInfo && currentEtapeInfo.reprisePossible;
101
106
  }
102
107
  // If connected, only display the button if the current step if the initial
@@ -107,7 +112,7 @@ export class GesdemActionRecoveryRegistrationComponent {
107
112
  }
108
113
  }
109
114
  GesdemActionRecoveryRegistrationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: GesdemActionRecoveryRegistrationComponent, deps: [{ token: i1.GesdemActionRecoveryService }, { token: i2.ValidationHandlerService }, { token: i3.FoehnPageService }, { token: i4.GesdemEventService }, { token: i5.GesdemHandlerService }, { token: i6.ApplicationInfoService }, { token: i7.SessionInfo }], target: i0.ɵɵFactoryTarget.Component });
110
- GesdemActionRecoveryRegistrationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: GesdemActionRecoveryRegistrationComponent, selector: "gesdem-action-recovery-registration", inputs: { continueLaterLabel: "continueLaterLabel" }, viewQueries: [{ propertyName: "modalTrigger", first: true, predicate: ["modalTrigger"], descendants: true }, { propertyName: "form", first: true, predicate: FoehnFormComponent, descendants: true }], ngImport: i0, template: "<button\n type=\"button\"\n id=\"continueLaterButton\"\n class=\"btn btn-link pr-0 pl-0 no-text-transform\"\n *ngIf=\"canContinueLater | async\"\n (click)=\"open()\"\n #modalTrigger\n>\n {{ continueLaterLabel }}\n</button>\n\n<foehn-modal\n id=\"action-recovery-registration-modal\"\n [modalHeaderText]=\"'Informations pour la reprise de la demande'\"\n [isModalVisible]=\"isModalVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n>\n <ng-container *ngIf=\"isConnected | async; else notConnectedContent\">\n <p>\n Vos donn\u00E9es ont \u00E9t\u00E9 sauvegard\u00E9es, vous pouvez acc\u00E9der \u00E0 cette\n demande dans la liste de\n <a href=\"/100002/demandes/search/MINE/INITIAL\">\n vos demandes en brouillon\n </a>\n .\n </p>\n </ng-container>\n <ng-template #notConnectedContent>\n <div class=\"alert alert-info\">\n <p *ngIf=\"!mailSent\">\n Les informations demand\u00E9es sont uniquement utilis\u00E9es pour vous\n permettre d'effectuer la reprise de demande.\n </p>\n\n <div *ngIf=\"mailSent\">\n <p>\n Un message contenant le lien de reprise de la demande a \u00E9t\u00E9\n envoy\u00E9 \u00E0 votre email.\n </p>\n <p>\n Vous pouvez cliquer sur ce lien pour reprendre la demande en\n saisissant le code qui sera envoy\u00E9 \u00E0 votre t\u00E9l\u00E9phone.\n </p>\n </div>\n </div>\n\n <foehn-form *ngIf=\"!mailSent\" [shouldDisplayAlertSummary]=\"false\">\n <foehn-input-text\n label=\"Email\"\n helpText=\"Par exemple, john@doe.ch\"\n [(model)]=\"model.email\"\n name=\"email\"\n required=\"true\"\n ></foehn-input-text>\n\n <foehn-input-phone\n label=\"Num\u00E9ro de t\u00E9l\u00E9phone mobile\"\n [acceptInternational]=\"true\"\n [acceptMobilePhone]=\"true\"\n [acceptPhone]=\"false\"\n [(model)]=\"model.mobile\"\n name=\"mobile\"\n required=\"true\"\n ></foehn-input-phone>\n </foehn-form>\n </ng-template>\n\n <div modal-footer class=\"w-100\">\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <button (click)=\"close()\" class=\"btn btn-secondary w-100\">\n Fermer\n </button>\n </div>\n <div\n *ngIf=\"!(isConnected | async)\"\n class=\"ml-md-0 mr-md-2 mb-2 mt-2\"\n >\n <button\n type=\"submit\"\n (click)=\"sendAndClose()\"\n class=\"btn btn-success w-100\"\n *ngIf=\"!mailSent\"\n >\n Sauvegarder\n </button>\n </div>\n </div>\n </div>\n</foehn-modal>\n", styles: [".no-text-transform{text-transform:none;cursor:pointer}\n"], components: [{ type: i8.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "modalFooterText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }, { type: i9.FoehnFormComponent, selector: "foehn-form", inputs: ["shouldDisplayAlertSummary"] }, { type: i10.FoehnInputTextComponent, selector: "foehn-input-text", inputs: ["numberOnly"] }, { type: i11.FoehnInputPhoneComponent, selector: "foehn-input-phone", inputs: ["acceptInternational", "acceptMobilePhone", "acceptPhone"] }], directives: [{ type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i12.AsyncPipe } });
115
+ GesdemActionRecoveryRegistrationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: GesdemActionRecoveryRegistrationComponent, selector: "gesdem-action-recovery-registration", inputs: { continueLaterLabel: "continueLaterLabel" }, viewQueries: [{ propertyName: "modalTrigger", first: true, predicate: ["modalTrigger"], descendants: true }, { propertyName: "form", first: true, predicate: FoehnFormComponent, descendants: true }], ngImport: i0, template: "<button\n type=\"button\"\n id=\"continueLaterButton\"\n class=\"btn btn-link pr-0 pl-0 no-text-transform\"\n *ngIf=\"canContinueLater | async\"\n (click)=\"open()\"\n #modalTrigger\n>\n {{ continueLaterLabel }}\n</button>\n\n<foehn-modal\n id=\"action-recovery-registration-modal\"\n [modalHeaderText]=\"'Informations pour la reprise de la demande'\"\n [isModalVisible]=\"isModalVisible\"\n (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n>\n <ng-container *ngIf=\"isConnectedCyber | async; else notConnectedContent\">\n <p>\n Vos donn\u00E9es ont \u00E9t\u00E9 sauvegard\u00E9es, vous pouvez acc\u00E9der \u00E0 cette\n demande dans la liste de\n <a href=\"/100002/demandes/search/MINE/INITIAL\">\n vos demandes en brouillon\n </a>\n .\n </p>\n </ng-container>\n <ng-template #notConnectedContent>\n <div class=\"alert alert-info\">\n <p *ngIf=\"!mailSent\">\n Les informations demand\u00E9es sont uniquement utilis\u00E9es pour vous\n permettre d'effectuer la reprise de demande.\n </p>\n\n <div *ngIf=\"mailSent\">\n <p>\n Un message contenant le lien de reprise de la demande a \u00E9t\u00E9\n envoy\u00E9 \u00E0 votre email.\n </p>\n <p>\n Vous pouvez cliquer sur ce lien pour reprendre la demande en\n saisissant le code qui sera envoy\u00E9 \u00E0 votre t\u00E9l\u00E9phone.\n </p>\n </div>\n </div>\n\n <foehn-form *ngIf=\"!mailSent\" [shouldDisplayAlertSummary]=\"false\">\n <foehn-input-text\n label=\"Email\"\n helpText=\"Par exemple, john@doe.ch\"\n [(model)]=\"model.email\"\n name=\"email\"\n required=\"true\"\n ></foehn-input-text>\n\n <foehn-input-phone\n label=\"Num\u00E9ro de t\u00E9l\u00E9phone mobile\"\n [acceptInternational]=\"true\"\n [acceptMobilePhone]=\"true\"\n [acceptPhone]=\"false\"\n [(model)]=\"model.mobile\"\n name=\"mobile\"\n required=\"true\"\n ></foehn-input-phone>\n </foehn-form>\n </ng-template>\n\n <div modal-footer class=\"w-100\">\n <div class=\"d-md-flex\">\n <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n <button (click)=\"close()\" class=\"btn btn-secondary w-100\">\n Fermer\n </button>\n </div>\n <div\n *ngIf=\"!(isConnectedCyber | async)\"\n class=\"ml-md-0 mr-md-2 mb-2 mt-2\"\n >\n <button\n type=\"submit\"\n (click)=\"sendAndClose()\"\n class=\"btn btn-success w-100\"\n *ngIf=\"!mailSent\"\n >\n Sauvegarder\n </button>\n </div>\n </div>\n </div>\n</foehn-modal>\n", styles: [".no-text-transform{text-transform:none;cursor:pointer}\n"], components: [{ type: i8.FoehnModalComponent, selector: "foehn-modal", inputs: ["id", "name", "modalSize", "modalBodyText", "modalHeaderText", "modalFooterText", "closeable", "modalTriggerHtmlElement", "isModalVisible"], outputs: ["isModalVisibleChange"] }, { type: i9.FoehnFormComponent, selector: "foehn-form", inputs: ["shouldDisplayAlertSummary"] }, { type: i10.FoehnInputTextComponent, selector: "foehn-input-text", inputs: ["numberOnly"] }, { type: i11.FoehnInputPhoneComponent, selector: "foehn-input-phone", inputs: ["acceptInternational", "acceptMobilePhone", "acceptPhone"] }], directives: [{ type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i12.AsyncPipe } });
111
116
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: GesdemActionRecoveryRegistrationComponent, decorators: [{
112
117
  type: Component,
113
118
  args: [{
@@ -125,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
125
130
  type: ViewChild,
126
131
  args: [FoehnFormComponent]
127
132
  }] } });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gesdem-action-recovery-registration.component.js","sourceRoot":"","sources":["../../../../../projects/prestations-ng/src/gesdem-action-recovery/gesdem-action-recovery-registration/gesdem-action-recovery-registration.component.ts","../../../../../projects/prestations-ng/src/gesdem-action-recovery/gesdem-action-recovery-registration/gesdem-action-recovery-registration.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';\nimport { RepriseInfo } from '../reprise-info';\nimport { GesdemActionRecoveryService } from '../gesdem-action-recovery.service';\nimport { filter, first, map, switchMap, tap } from 'rxjs/operators';\nimport { ValidationHandlerService } from '../../validation/validation-handler.service';\nimport { FoehnFormComponent } from '../../foehn-form/foehn-form.component';\nimport { FoehnPageService } from '../../foehn-page/foehn-page.service';\nimport { GesdemEventService } from '../../gesdem/gesdem-event.service';\nimport { GesdemHandlerService } from '../../gesdem/gesdem-handler.service';\nimport { combineLatest, Observable } from 'rxjs';\nimport { ApplicationInfoService } from '../../sdk-appinfo/application-info.service';\nimport { SessionInfo } from '../../sdk-session-info/session-info.service';\nimport { EtapeInfo } from '../../sdk-appinfo/application-info';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'gesdem-action-recovery-registration',\n    templateUrl: './gesdem-action-recovery-registration.component.html',\n    styleUrls: ['./gesdem-action-recovery-registration.component.css']\n})\nexport class GesdemActionRecoveryRegistrationComponent implements OnInit {\n    @Input()\n    continueLaterLabel: string;\n\n    @ViewChild('modalTrigger')\n    modalTrigger: ElementRef;\n\n    @ViewChild(FoehnFormComponent)\n    form: FoehnFormComponent;\n\n    model = new RepriseInfo();\n    mailSent = false;\n\n    canContinueLater: Observable<boolean>;\n    isConnected: Observable<boolean>;\n\n    private isVisible = false;\n\n    constructor(\n        private actionRecoveryService: GesdemActionRecoveryService,\n        private validationHandler: ValidationHandlerService,\n        private foehnPageService: FoehnPageService,\n        private gesdemEventService: GesdemEventService,\n        private gesdemService: GesdemHandlerService,\n        private appInfoService: ApplicationInfoService,\n        private sessionInfoService: SessionInfo\n    ) {}\n\n    ngOnInit(): void {\n        this.isConnected = this.sessionInfoService.data.pipe(\n            map(sessionInfo => !!sessionInfo && !!sessionInfo.context)\n        );\n\n        this.canContinueLater = combineLatest([\n            this.appInfoService.currentEtapeInfo,\n            this.isConnected\n        ]).pipe(\n            map(([currentEtapeInfo, isConnected]) =>\n                this.canContinueLaterForEtape(currentEtapeInfo, isConnected)\n            )\n        );\n    }\n\n    get isModalVisible(): boolean {\n        return this.isVisible;\n    }\n\n    open(): void {\n        this.gesdemEventService\n            .formSentObservable()\n            .pipe(\n                first(),\n                filter(resp => !!resp.meta.reference),\n                switchMap(() => this.isConnected)\n            )\n            .subscribe(isConnected => {\n                this.mailSent = false;\n                this.isVisible = true;\n                if (!isConnected) {\n                    this.actionRecoveryService\n                        .getDefaultRecoveryValue(this.reference)\n                        // eslint-disable-next-line rxjs/no-nested-subscribe\n                        .subscribe(repriseInfo => (this.model = repriseInfo));\n                } else {\n                    this.model = null;\n                }\n            });\n\n        this.foehnPageService.requestFormSave();\n    }\n\n    close(): void {\n        this.updateVisibilityStatus(false);\n    }\n\n    sendAndClose(): void {\n        this.actionRecoveryService\n            .registerForRecovery(this.reference, this.model)\n            .pipe(\n                tap(err => {\n                    this.form.reset();\n                    this.validationHandler.shouldDisplayErrors(true);\n                    this.validationHandler.updateErrors([\n                        ...err,\n                        ...this.gesdemService.lastResponse.errors\n                    ]);\n                    this.form.focusFirstInError();\n                    this.mailSent = !err.length;\n                })\n            )\n            .subscribe();\n    }\n\n    updateVisibilityStatus(status: boolean): void {\n        // Store the previous value to handle transitions from one state to another.\n        const wasOpen = this.isVisible;\n\n        // In case the modal is closed by another mean.\n        this.isVisible = status;\n\n        // Focus back on the trigger. No need for a setTimeout as the trigger should still be in the DOM.\n        // Only does it when the modal is closed from a open state to avoid to set\n        // the focus when the page loads.\n        if (wasOpen && !this.isVisible && this.modalTrigger) {\n            this.modalTrigger.nativeElement.focus();\n        }\n    }\n\n    get reference(): string {\n        return this.gesdemService.lastResponse\n            ? this.gesdemService.lastResponse.meta.reference\n            : null;\n    }\n\n    private canContinueLaterForEtape(\n        currentEtapeInfo: EtapeInfo,\n        isConnected: boolean\n    ): boolean {\n        // If not connected, take the \"reprisePossible\" flag from CatPrest\n        // into account.\n        if (!isConnected) {\n            return currentEtapeInfo && currentEtapeInfo.reprisePossible;\n        }\n\n        // If connected, only display the button if the current step if the initial\n        // step.\n        return (\n            currentEtapeInfo &&\n            currentEtapeInfo.idMetierEtape ===\n                currentEtapeInfo.idMetierPrestation\n        );\n    }\n}\n","<button\n    type=\"button\"\n    id=\"continueLaterButton\"\n    class=\"btn btn-link pr-0 pl-0 no-text-transform\"\n    *ngIf=\"canContinueLater | async\"\n    (click)=\"open()\"\n    #modalTrigger\n>\n    {{ continueLaterLabel }}\n</button>\n\n<foehn-modal\n    id=\"action-recovery-registration-modal\"\n    [modalHeaderText]=\"'Informations pour la reprise de la demande'\"\n    [isModalVisible]=\"isModalVisible\"\n    (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n>\n    <ng-container *ngIf=\"isConnected | async; else notConnectedContent\">\n        <p>\n            Vos données ont été sauvegardées, vous pouvez accéder à cette\n            demande dans la liste de\n            <a href=\"/100002/demandes/search/MINE/INITIAL\">\n                vos demandes en brouillon\n            </a>\n            .\n        </p>\n    </ng-container>\n    <ng-template #notConnectedContent>\n        <div class=\"alert alert-info\">\n            <p *ngIf=\"!mailSent\">\n                Les informations demandées sont uniquement utilisées pour vous\n                permettre d'effectuer la reprise de demande.\n            </p>\n\n            <div *ngIf=\"mailSent\">\n                <p>\n                    Un message contenant le lien de reprise de la demande a été\n                    envoyé à votre email.\n                </p>\n                <p>\n                    Vous pouvez cliquer sur ce lien pour reprendre la demande en\n                    saisissant le code qui sera envoyé à votre téléphone.\n                </p>\n            </div>\n        </div>\n\n        <foehn-form *ngIf=\"!mailSent\" [shouldDisplayAlertSummary]=\"false\">\n            <foehn-input-text\n                label=\"Email\"\n                helpText=\"Par exemple, john@doe.ch\"\n                [(model)]=\"model.email\"\n                name=\"email\"\n                required=\"true\"\n            ></foehn-input-text>\n\n            <foehn-input-phone\n                label=\"Numéro de téléphone mobile\"\n                [acceptInternational]=\"true\"\n                [acceptMobilePhone]=\"true\"\n                [acceptPhone]=\"false\"\n                [(model)]=\"model.mobile\"\n                name=\"mobile\"\n                required=\"true\"\n            ></foehn-input-phone>\n        </foehn-form>\n    </ng-template>\n\n    <div modal-footer class=\"w-100\">\n        <div class=\"d-md-flex\">\n            <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n                <button (click)=\"close()\" class=\"btn btn-secondary w-100\">\n                    Fermer\n                </button>\n            </div>\n            <div\n                *ngIf=\"!(isConnected | async)\"\n                class=\"ml-md-0 mr-md-2 mb-2 mt-2\"\n            >\n                <button\n                    type=\"submit\"\n                    (click)=\"sendAndClose()\"\n                    class=\"btn btn-success w-100\"\n                    *ngIf=\"!mailSent\"\n                >\n                    Sauvegarder\n                </button>\n            </div>\n        </div>\n    </div>\n</foehn-modal>\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gesdem-action-recovery-registration.component.js","sourceRoot":"","sources":["../../../../../projects/prestations-ng/src/gesdem-action-recovery/gesdem-action-recovery-registration/gesdem-action-recovery-registration.component.ts","../../../../../projects/prestations-ng/src/gesdem-action-recovery/gesdem-action-recovery-registration/gesdem-action-recovery-registration.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';\nimport { RepriseInfo } from '../reprise-info';\nimport { GesdemActionRecoveryService } from '../gesdem-action-recovery.service';\nimport { filter, first, map, switchMap, tap } from 'rxjs/operators';\nimport { ValidationHandlerService } from '../../validation/validation-handler.service';\nimport { FoehnFormComponent } from '../../foehn-form/foehn-form.component';\nimport { FoehnPageService } from '../../foehn-page/foehn-page.service';\nimport { GesdemEventService } from '../../gesdem/gesdem-event.service';\nimport { GesdemHandlerService } from '../../gesdem/gesdem-handler.service';\nimport { combineLatest, Observable } from 'rxjs';\nimport { ApplicationInfoService } from '../../sdk-appinfo/application-info.service';\nimport { SessionInfo } from '../../sdk-session-info/session-info.service';\nimport { EtapeInfo } from '../../sdk-appinfo/application-info';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'gesdem-action-recovery-registration',\n    templateUrl: './gesdem-action-recovery-registration.component.html',\n    styleUrls: ['./gesdem-action-recovery-registration.component.css']\n})\nexport class GesdemActionRecoveryRegistrationComponent implements OnInit {\n    @Input()\n    continueLaterLabel: string;\n\n    @ViewChild('modalTrigger')\n    modalTrigger: ElementRef;\n\n    @ViewChild(FoehnFormComponent)\n    form: FoehnFormComponent;\n\n    model = new RepriseInfo();\n    mailSent = false;\n\n    canContinueLater: Observable<boolean>;\n    isConnectedCyber: Observable<boolean>;\n\n    private isVisible = false;\n\n    constructor(\n        private actionRecoveryService: GesdemActionRecoveryService,\n        private validationHandler: ValidationHandlerService,\n        private foehnPageService: FoehnPageService,\n        private gesdemEventService: GesdemEventService,\n        private gesdemService: GesdemHandlerService,\n        private appInfoService: ApplicationInfoService,\n        private sessionInfoService: SessionInfo\n    ) {}\n\n    ngOnInit(): void {\n        this.isConnectedCyber = this.sessionInfoService.data.pipe(\n            map(sessionInfo => !!sessionInfo && !!sessionInfo.context)\n        );\n\n        const isConnectedIamAcv = this.sessionInfoService.data.pipe(\n            map(sessionInfo => !!sessionInfo && !sessionInfo.context)\n        );\n\n        this.canContinueLater = combineLatest([\n            this.appInfoService.currentEtapeInfo,\n            this.isConnectedCyber,\n            isConnectedIamAcv\n        ]).pipe(\n            map(([currentEtapeInfo, isConnectedCyber, connectedIamAcv]) =>\n                this.canContinueLaterForEtape(\n                    currentEtapeInfo,\n                    isConnectedCyber,\n                    connectedIamAcv\n                )\n            )\n        );\n    }\n\n    get isModalVisible(): boolean {\n        return this.isVisible;\n    }\n\n    open(): void {\n        this.gesdemEventService\n            .formSentObservable()\n            .pipe(\n                first(),\n                filter(resp => !!resp.meta.reference),\n                switchMap(() => this.isConnectedCyber)\n            )\n            .subscribe(isConnectedCyber => {\n                this.mailSent = false;\n                this.isVisible = true;\n                if (!isConnectedCyber) {\n                    this.actionRecoveryService\n                        .getDefaultRecoveryValue(this.reference)\n                        // eslint-disable-next-line rxjs/no-nested-subscribe\n                        .subscribe(repriseInfo => (this.model = repriseInfo));\n                } else {\n                    this.model = null;\n                }\n            });\n\n        this.foehnPageService.requestFormSave();\n    }\n\n    close(): void {\n        this.updateVisibilityStatus(false);\n    }\n\n    sendAndClose(): void {\n        this.actionRecoveryService\n            .registerForRecovery(this.reference, this.model)\n            .pipe(\n                tap(err => {\n                    this.form.reset();\n                    this.validationHandler.shouldDisplayErrors(true);\n                    this.validationHandler.updateErrors([\n                        ...err,\n                        ...this.gesdemService.lastResponse.errors\n                    ]);\n                    this.form.focusFirstInError();\n                    this.mailSent = !err.length;\n                })\n            )\n            .subscribe();\n    }\n\n    updateVisibilityStatus(status: boolean): void {\n        // Store the previous value to handle transitions from one state to another.\n        const wasOpen = this.isVisible;\n\n        // In case the modal is closed by another mean.\n        this.isVisible = status;\n\n        // Focus back on the trigger. No need for a setTimeout as the trigger should still be in the DOM.\n        // Only does it when the modal is closed from a open state to avoid to set\n        // the focus when the page loads.\n        if (wasOpen && !this.isVisible && this.modalTrigger) {\n            this.modalTrigger.nativeElement.focus();\n        }\n    }\n\n    get reference(): string {\n        return this.gesdemService.lastResponse\n            ? this.gesdemService.lastResponse.meta.reference\n            : null;\n    }\n\n    private canContinueLaterForEtape(\n        currentEtapeInfo: EtapeInfo,\n        isConnectedCyber: boolean,\n        isConnectedIamAcv: boolean\n    ): boolean {\n        if (isConnectedIamAcv) {\n            return false;\n        }\n\n        // If not connected, take the \"reprisePossible\" flag from CatPrest\n        // into account.\n        if (!isConnectedCyber) {\n            return currentEtapeInfo && currentEtapeInfo.reprisePossible;\n        }\n\n        // If connected, only display the button if the current step if the initial\n        // step.\n        return (\n            currentEtapeInfo &&\n            currentEtapeInfo.idMetierEtape ===\n                currentEtapeInfo.idMetierPrestation\n        );\n    }\n}\n","<button\n    type=\"button\"\n    id=\"continueLaterButton\"\n    class=\"btn btn-link pr-0 pl-0 no-text-transform\"\n    *ngIf=\"canContinueLater | async\"\n    (click)=\"open()\"\n    #modalTrigger\n>\n    {{ continueLaterLabel }}\n</button>\n\n<foehn-modal\n    id=\"action-recovery-registration-modal\"\n    [modalHeaderText]=\"'Informations pour la reprise de la demande'\"\n    [isModalVisible]=\"isModalVisible\"\n    (isModalVisibleChange)=\"updateVisibilityStatus($event)\"\n>\n    <ng-container *ngIf=\"isConnectedCyber | async; else notConnectedContent\">\n        <p>\n            Vos données ont été sauvegardées, vous pouvez accéder à cette\n            demande dans la liste de\n            <a href=\"/100002/demandes/search/MINE/INITIAL\">\n                vos demandes en brouillon\n            </a>\n            .\n        </p>\n    </ng-container>\n    <ng-template #notConnectedContent>\n        <div class=\"alert alert-info\">\n            <p *ngIf=\"!mailSent\">\n                Les informations demandées sont uniquement utilisées pour vous\n                permettre d'effectuer la reprise de demande.\n            </p>\n\n            <div *ngIf=\"mailSent\">\n                <p>\n                    Un message contenant le lien de reprise de la demande a été\n                    envoyé à votre email.\n                </p>\n                <p>\n                    Vous pouvez cliquer sur ce lien pour reprendre la demande en\n                    saisissant le code qui sera envoyé à votre téléphone.\n                </p>\n            </div>\n        </div>\n\n        <foehn-form *ngIf=\"!mailSent\" [shouldDisplayAlertSummary]=\"false\">\n            <foehn-input-text\n                label=\"Email\"\n                helpText=\"Par exemple, john@doe.ch\"\n                [(model)]=\"model.email\"\n                name=\"email\"\n                required=\"true\"\n            ></foehn-input-text>\n\n            <foehn-input-phone\n                label=\"Numéro de téléphone mobile\"\n                [acceptInternational]=\"true\"\n                [acceptMobilePhone]=\"true\"\n                [acceptPhone]=\"false\"\n                [(model)]=\"model.mobile\"\n                name=\"mobile\"\n                required=\"true\"\n            ></foehn-input-phone>\n        </foehn-form>\n    </ng-template>\n\n    <div modal-footer class=\"w-100\">\n        <div class=\"d-md-flex\">\n            <div class=\"ml-md-auto mr-md-2 mb-2 mt-2\">\n                <button (click)=\"close()\" class=\"btn btn-secondary w-100\">\n                    Fermer\n                </button>\n            </div>\n            <div\n                *ngIf=\"!(isConnectedCyber | async)\"\n                class=\"ml-md-0 mr-md-2 mb-2 mt-2\"\n            >\n                <button\n                    type=\"submit\"\n                    (click)=\"sendAndClose()\"\n                    class=\"btn btn-success w-100\"\n                    *ngIf=\"!mailSent\"\n                >\n                    Sauvegarder\n                </button>\n            </div>\n        </div>\n    </div>\n</foehn-modal>\n"]}
@@ -105,7 +105,7 @@ export class GesdemConfirmationComponent {
105
105
  this.dictionaryService.changeLanguage(languageCode);
106
106
  }
107
107
  // Whether the user has a context we consider it as connected.
108
- this.isConnected = this._sessionInfo.data.pipe(map(userInfo => !!userInfo && !!userInfo.context));
108
+ this.isConnectedCyber = this._sessionInfo.data.pipe(map(userInfo => !!userInfo && !!userInfo.context));
109
109
  if (this.setPageTitle) {
110
110
  this.pageTitleSubscription = this.dictionaryService
111
111
  .getKey('gesdem-confirmation.title')
@@ -156,7 +156,7 @@ export class GesdemConfirmationComponent {
156
156
  }
157
157
  }
158
158
  GesdemConfirmationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: GesdemConfirmationComponent, deps: [{ token: i1.GesdemHandlerService }, { token: i2.FoehnPageService }, { token: i3.ActivatedRoute }, { token: i4.SdkDictionaryService }, { token: i5.Location }], target: i0.ɵɵFactoryTarget.Component });
159
- GesdemConfirmationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: GesdemConfirmationComponent, selector: "gesdem-confirmation", inputs: { reference: "reference", setPageTitle: "setPageTitle", hasEmailSent: "hasEmailSent", closeHref: "closeHref", showDownloadPdfRecapButton: "showDownloadPdfRecapButton", showLinkToMyDemandes: "showLinkToMyDemandes", demandeIsClosedOnTransmit: "demandeIsClosedOnTransmit", actionStatut: "actionStatut", connectedConfirmationMessage: "connectedConfirmationMessage", connectedConfirmationMessageIfAbandoned: "connectedConfirmationMessageIfAbandoned", downloadPdfRecapButtonText: "downloadPdfRecapButtonText", closeButtonText: "closeButtonText", baseUrlPdf: "baseUrlPdf" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"container mt-5\" *ngIf=\"reference && !isInProgress\">\n <div\n class=\"alert text-center mb-2\"\n [ngClass]=\"isTransferred ? 'alert-success' : 'alert-danger'\"\n >\n <p class=\"h2\">\n {{\n isTransferred\n ? (successLabelDicoKey | fromDictionary)\n : ('gesdem-confirmation.abort-label' | fromDictionary)\n }}\n </p>\n <dl>\n <dt class=\"font-weight-light\">\n {{\n 'gesdem-confirmation.reference-title.label' | fromDictionary\n }}\n </dt>\n <dd id=\"numDemande\" class=\"h4 d-block mt-3\">{{ reference }}</dd>\n </dl>\n <p *ngIf=\"hasEmailSent && !(isConnected | async)\">\n {{ 'gesdem-confirmation.mail-sent.label' | fromDictionary }}\n </p>\n </div>\n\n <span\n [innerHTML]=\"'gesdem-confirmation.extra-content' | fromDictionary\"\n ></span>\n\n <ng-content></ng-content>\n\n <div\n class=\"col-md-12 vd-highlight\"\n *ngIf=\"(isConnected | async) && hasConnectedContent()\"\n >\n <span class=\"sr-only\">\n Information suite \u00E0 la transmission de votre demande\n </span>\n <div class=\"row\">\n <div class=\"col-md-1\">\n <foehn-icon-info-circle class=\"h3\"></foehn-icon-info-circle>\n </div>\n <div class=\"col-md-11\">\n <p\n [innerHTML]=\"\n isTransferred\n ? connectedConfirmationMessage\n : connectedConfirmationMessageIfAbandoned\n \"\n ></p>\n <p\n *ngIf=\"\n showLinkToMyDemandes &&\n (demandeIsClosedOnTransmit || isAbandoned)\n \"\n >\n Vous pouvez consulter votre demande en cliquant sur :\n <a href=\"/100002/demandes/search/MINE/TREATED\">\n Mes nouvelles demandes trait\u00E9es\n </a>\n .\n </p>\n <p\n *ngIf=\"\n showLinkToMyDemandes &&\n !demandeIsClosedOnTransmit &&\n !isAbandoned\n \"\n >\n Vous pouvez suivre l'avancement du traitement de votre\n demande en cliquant sur :\n <a href=\"/100002/demandes/search/MINE/IN_PROGRESS\">\n Mes demandes en cours de traitement\n </a>\n .\n </p>\n </div>\n </div>\n </div>\n\n <div\n class=\"col-md-12 list-unstyled d-md-flex p-0 mt-4\"\n *ngIf=\"!(isConnected | async)\"\n >\n <div class=\"ml-0 mr-md-auto mr-md-2 mb-2 mt-2\">\n <a\n *ngIf=\"showDownloadPdfRecapButton\"\n [href]=\"urlPdf\"\n id=\"telechargerBtn\"\n class=\"btn btn-secondary w-100\"\n title=\"T\u00E9l\u00E9charger le PDF\"\n >\n {{ downloadPdfRecapButtonText | fromDictionary }}\n </a>\n </div>\n\n <div\n class=\"mr-0 ml-md-auto mb-2 mt-2\"\n *ngIf=\"closeLink | async as link\"\n >\n <a\n [href]=\"link\"\n id=\"terminerBtn\"\n class=\"btn btn-primary w-100\"\n title=\"Terminer\"\n >\n {{ closeButtonText | fromDictionary }}\n </a>\n </div>\n </div>\n</div>\n\n<div class=\"container mt-5\" *ngIf=\"reference && isInProgress\">\n <div class=\"alert alert-info text-center mb-2\">\n <p class=\"h2\">Demande en cours</p>\n <dl>\n <dt class=\"font-weight-light\">\n {{\n 'gesdem-confirmation.reference-title.label' | fromDictionary\n }}\n </dt>\n <dd id=\"numDemandeEnCours\" class=\"h4 d-block mt-3\">\n {{ reference }}\n </dd>\n </dl>\n </div>\n\n <div class=\"col-md-12 vd-highlight\">\n <div class=\"row\">\n <div class=\"col-md-1\">\n <foehn-icon-info-circle class=\"h3\"></foehn-icon-info-circle>\n </div>\n <div class=\"col-md-11\">\n <p>\n Vous pouvez reprendre votre demande en cliquant sur le lien\n ci-dessous\n </p>\n <p>\n <a [routerLink]=\"firstPageLink\">Reprendre ma demande</a>\n </p>\n </div>\n </div>\n </div>\n</div>\n", components: [{ type: i6.FoehnIconInfoCircleComponent, selector: "foehn-icon-info-circle" }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }], pipes: { "fromDictionary": i7.SdkDictionaryPipe, "async": i5.AsyncPipe } });
159
+ GesdemConfirmationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: GesdemConfirmationComponent, selector: "gesdem-confirmation", inputs: { reference: "reference", setPageTitle: "setPageTitle", hasEmailSent: "hasEmailSent", closeHref: "closeHref", showDownloadPdfRecapButton: "showDownloadPdfRecapButton", showLinkToMyDemandes: "showLinkToMyDemandes", demandeIsClosedOnTransmit: "demandeIsClosedOnTransmit", actionStatut: "actionStatut", connectedConfirmationMessage: "connectedConfirmationMessage", connectedConfirmationMessageIfAbandoned: "connectedConfirmationMessageIfAbandoned", downloadPdfRecapButtonText: "downloadPdfRecapButtonText", closeButtonText: "closeButtonText", baseUrlPdf: "baseUrlPdf" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"container mt-5\" *ngIf=\"reference && !isInProgress\">\n <div\n class=\"alert text-center mb-2\"\n [ngClass]=\"isTransferred ? 'alert-success' : 'alert-danger'\"\n >\n <p class=\"h2\">\n {{\n isTransferred\n ? (successLabelDicoKey | fromDictionary)\n : ('gesdem-confirmation.abort-label' | fromDictionary)\n }}\n </p>\n <dl>\n <dt class=\"font-weight-light\">\n {{\n 'gesdem-confirmation.reference-title.label' | fromDictionary\n }}\n </dt>\n <dd id=\"numDemande\" class=\"h4 d-block mt-3\">{{ reference }}</dd>\n </dl>\n <p *ngIf=\"hasEmailSent && !(isConnectedCyber | async)\">\n {{ 'gesdem-confirmation.mail-sent.label' | fromDictionary }}\n </p>\n </div>\n\n <span\n [innerHTML]=\"'gesdem-confirmation.extra-content' | fromDictionary\"\n ></span>\n\n <ng-content></ng-content>\n\n <div\n class=\"col-md-12 vd-highlight\"\n *ngIf=\"(isConnectedCyber | async) && hasConnectedContent()\"\n >\n <span class=\"sr-only\">\n Information suite \u00E0 la transmission de votre demande\n </span>\n <div class=\"row\">\n <div class=\"col-md-1\">\n <foehn-icon-info-circle class=\"h3\"></foehn-icon-info-circle>\n </div>\n <div class=\"col-md-11\">\n <p\n [innerHTML]=\"\n isTransferred\n ? connectedConfirmationMessage\n : connectedConfirmationMessageIfAbandoned\n \"\n ></p>\n <p\n *ngIf=\"\n showLinkToMyDemandes &&\n (demandeIsClosedOnTransmit || isAbandoned)\n \"\n >\n Vous pouvez consulter votre demande en cliquant sur :\n <a href=\"/100002/demandes/search/MINE/TREATED\">\n Mes nouvelles demandes trait\u00E9es\n </a>\n .\n </p>\n <p\n *ngIf=\"\n showLinkToMyDemandes &&\n !demandeIsClosedOnTransmit &&\n !isAbandoned\n \"\n >\n Vous pouvez suivre l'avancement du traitement de votre\n demande en cliquant sur :\n <a href=\"/100002/demandes/search/MINE/IN_PROGRESS\">\n Mes demandes en cours de traitement\n </a>\n .\n </p>\n </div>\n </div>\n </div>\n\n <div\n class=\"col-md-12 list-unstyled d-md-flex p-0 mt-4\"\n *ngIf=\"!(isConnectedCyber | async)\"\n >\n <div class=\"ml-0 mr-md-auto mr-md-2 mb-2 mt-2\">\n <a\n *ngIf=\"showDownloadPdfRecapButton\"\n [href]=\"urlPdf\"\n id=\"telechargerBtn\"\n class=\"btn btn-secondary w-100\"\n title=\"T\u00E9l\u00E9charger le PDF\"\n >\n {{ downloadPdfRecapButtonText | fromDictionary }}\n </a>\n </div>\n\n <div\n class=\"mr-0 ml-md-auto mb-2 mt-2\"\n *ngIf=\"closeLink | async as link\"\n >\n <a\n [href]=\"link\"\n id=\"terminerBtn\"\n class=\"btn btn-primary w-100\"\n title=\"Terminer\"\n >\n {{ closeButtonText | fromDictionary }}\n </a>\n </div>\n </div>\n</div>\n\n<div class=\"container mt-5\" *ngIf=\"reference && isInProgress\">\n <div class=\"alert alert-info text-center mb-2\">\n <p class=\"h2\">Demande en cours</p>\n <dl>\n <dt class=\"font-weight-light\">\n {{\n 'gesdem-confirmation.reference-title.label' | fromDictionary\n }}\n </dt>\n <dd id=\"numDemandeEnCours\" class=\"h4 d-block mt-3\">\n {{ reference }}\n </dd>\n </dl>\n </div>\n\n <div class=\"col-md-12 vd-highlight\">\n <div class=\"row\">\n <div class=\"col-md-1\">\n <foehn-icon-info-circle class=\"h3\"></foehn-icon-info-circle>\n </div>\n <div class=\"col-md-11\">\n <p>\n Vous pouvez reprendre votre demande en cliquant sur le lien\n ci-dessous\n </p>\n <p>\n <a [routerLink]=\"firstPageLink\">Reprendre ma demande</a>\n </p>\n </div>\n </div>\n </div>\n</div>\n", components: [{ type: i6.FoehnIconInfoCircleComponent, selector: "foehn-icon-info-circle" }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }], pipes: { "fromDictionary": i7.SdkDictionaryPipe, "async": i5.AsyncPipe } });
160
160
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: GesdemConfirmationComponent, decorators: [{
161
161
  type: Component,
162
162
  args: [{
@@ -191,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
191
191
  }], baseUrlPdf: [{
192
192
  type: Input
193
193
  }] } });
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gesdem-confirmation.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/gesdem-confirmation/gesdem-confirmation.component.ts","../../../../projects/prestations-ng/src/gesdem-confirmation/gesdem-confirmation.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChange,\n    SimpleChanges\n} from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { BehaviorSubject, Observable, Subscription } from 'rxjs';\nimport { first, map } from 'rxjs/operators';\n\nimport { GesdemHandlerService } from '../gesdem/gesdem-handler.service';\nimport { BreadcrumbEventService } from '../foehn-breadcrumb/breadcrumb-event.service';\nimport { FoehnPageService } from '../foehn-page/foehn-page.service';\nimport { ServiceLocator } from '../service-locator';\nimport { SessionInfo } from '../sdk-session-info/session-info.service';\nimport { FoehnNavigationService } from '../foehn-navigation/foehn-navigation.service';\nimport { ActionStatut, GesdemStatutUtils } from '../gesdem/gesdem-statut-utils';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { Location } from '@angular/common';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'gesdem-confirmation',\n    templateUrl: './gesdem-confirmation.component.html'\n})\nexport class GesdemConfirmationComponent\n    implements OnInit, OnDestroy, OnChanges {\n    @Input()\n    reference: string;\n\n    @Input()\n    setPageTitle = true;\n\n    @Input()\n    hasEmailSent = false;\n\n    @Input()\n    closeHref: string;\n\n    @Input()\n    showDownloadPdfRecapButton = true;\n\n    @Input()\n    showLinkToMyDemandes = true;\n\n    @Input()\n    demandeIsClosedOnTransmit = false;\n\n    @Input()\n    actionStatut = ActionStatut.TRANSFERRED;\n\n    @Input()\n    connectedConfirmationMessage =\n        'Vous avez effectué la première étape de votre démarche avec succès !';\n\n    @Input()\n    connectedConfirmationMessageIfAbandoned =\n        \"La demande à laquelle vous essayez d'accéder a été abandonnée.\";\n\n    @Input()\n    downloadPdfRecapButtonText: string;\n\n    @Input()\n    closeButtonText: string;\n\n    @Input()\n    baseUrlPdf = 'api/document/pdf/';\n\n    isConnected: Observable<boolean>;\n    firstPageLink = '/';\n    urlPdf: string;\n    closeLink = new BehaviorSubject<string>(null);\n\n    protected _breadcrumbEventService: BreadcrumbEventService;\n    protected _foehnPageService: FoehnPageService;\n    protected _sessionInfo: SessionInfo;\n    protected _navigation: FoehnNavigationService;\n\n    private dataSubscription: Subscription;\n    private pageTitleSubscription: Subscription;\n\n    constructor(\n        protected gesdemService: GesdemHandlerService,\n        protected foehnPageService: FoehnPageService,\n        protected activatedRoute: ActivatedRoute,\n        protected dictionaryService: SdkDictionaryService,\n        protected location: Location\n    ) {\n        this._breadcrumbEventService = ServiceLocator.injector.get(\n            BreadcrumbEventService\n        );\n        this._foehnPageService = ServiceLocator.injector.get(FoehnPageService);\n        this._sessionInfo = ServiceLocator.injector.get(SessionInfo);\n        this._navigation = ServiceLocator.injector.get(FoehnNavigationService);\n\n        const route = FoehnNavigationService.getRootRouteRecursive(\n            activatedRoute.snapshot\n        );\n        this._navigation.initRoute(route);\n\n        // Override from the routing.\n        this.dataSubscription = this.activatedRoute.data.subscribe(\n            routeData => {\n                this.hasEmailSent = routeData.hasEmailSent || this.hasEmailSent;\n                this.closeLink.next(\n                    routeData.closeHref || this.closeLink.getValue()\n                );\n                this.connectedConfirmationMessage =\n                    routeData.connectedConfirmationMessage ||\n                    this.connectedConfirmationMessage;\n                this.connectedConfirmationMessageIfAbandoned =\n                    routeData.connectedConfirmationMessageIfAbandoned ||\n                    this.connectedConfirmationMessageIfAbandoned;\n                this.showDownloadPdfRecapButton =\n                    routeData.showDownloadPdfRecapButton ||\n                    this.showDownloadPdfRecapButton;\n                this.showLinkToMyDemandes =\n                    routeData.showLinkToMyDemandes || this.showLinkToMyDemandes;\n                this.demandeIsClosedOnTransmit =\n                    routeData.demandeIsClosedOnTransmit ||\n                    this.demandeIsClosedOnTransmit;\n                this.downloadPdfRecapButtonText =\n                    routeData.downloadPdfRecapButtonText ||\n                    this.downloadPdfRecapButtonText ||\n                    'gesdem-confirmation.download-pdf-recap-button';\n                this.baseUrlPdf = routeData.baseUrlPdf || this.baseUrlPdf;\n                this.closeButtonText =\n                    routeData.closeButtonText ||\n                    this.closeButtonText ||\n                    'gesdem-confirmation.exit-button';\n\n                // default closeLink if not by @Input and not by route data\n                this.foehnPageService\n                    .onEtapeIdChange()\n                    .pipe(first())\n                    // eslint-disable-next-line rxjs/no-nested-subscribe\n                    .subscribe(etapeId => {\n                        if (!this.closeLink.getValue()) {\n                            this.closeLink.next(\n                                `https://www.vd.ch/go.to?prestation=${etapeId}`\n                            );\n                        }\n                    });\n            }\n        );\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const change: SimpleChange = changes.closeHref;\n        if (change && change.currentValue) {\n            this.closeLink.next(change.currentValue);\n        }\n    }\n\n    ngOnInit(): void {\n        const lastResponse = this.gesdemService.lastResponse;\n        if (lastResponse) {\n            this.reference = lastResponse.meta.reference;\n            this.actionStatut =\n                ActionStatut[lastResponse.meta.statut as ActionStatut];\n            this.urlPdf = this.baseUrlPdf + this.reference;\n            const currentAction = lastResponse.meta.currentAction;\n            if (!!currentAction) {\n                this.urlPdf += `-${currentAction}`;\n                if (this.location.path().includes(`/${this.reference}/`)) {\n                    const fullReferenceUrl = this.location\n                        .path()\n                        .replace(\n                            this.reference,\n                            `${this.reference}-${currentAction}`\n                        );\n                    this.location.replaceState(fullReferenceUrl);\n                }\n            }\n\n            const languageCode = lastResponse.form.language;\n            this.dictionaryService.changeLanguage(languageCode);\n        }\n\n        // Whether the user has a context we consider it as connected.\n        this.isConnected = this._sessionInfo.data.pipe(\n            map(userInfo => !!userInfo && !!userInfo.context)\n        );\n\n        if (this.setPageTitle) {\n            this.pageTitleSubscription = this.dictionaryService\n                .getKey('gesdem-confirmation.title')\n                .subscribe(title => this._foehnPageService.setPageTitle(title));\n        }\n\n        this.firstPageLink = this.getFirstPageLink();\n\n        this._breadcrumbEventService.skipLeavingAlertBecauseDemandIsTransmitted = true;\n    }\n\n    ngOnDestroy(): void {\n        if (this.dataSubscription) {\n            this.dataSubscription.unsubscribe();\n        }\n        if (this.pageTitleSubscription) {\n            this.pageTitleSubscription.unsubscribe();\n        }\n    }\n\n    hasConnectedContent(): boolean {\n        const hasConfMessage =\n            this.isTransferred && !!this.connectedConfirmationMessage;\n        const hasAbandonedConfMessage =\n            !this.isTransferred &&\n            !!this.connectedConfirmationMessageIfAbandoned;\n\n        return (\n            hasConfMessage ||\n            hasAbandonedConfMessage ||\n            !!this.showLinkToMyDemandes\n        );\n    }\n\n    get isTransferred(): boolean {\n        return (\n            this.actionStatut && this.actionStatut === ActionStatut.TRANSFERRED\n        );\n    }\n\n    get isAbandoned(): boolean {\n        return (\n            this.actionStatut && this.actionStatut === ActionStatut.ABANDONED\n        );\n    }\n\n    get isInProgress(): boolean {\n        return !GesdemStatutUtils.isFinal(this.actionStatut);\n    }\n\n    get successLabelDicoKey(): string {\n        const isFirstAction =\n            this.gesdemService.lastResponse?.meta?.currentAction === 1;\n        return isFirstAction\n            ? 'gesdem-confirmation.success-label'\n            : 'gesdem-confirmation.next-step.success-label';\n    }\n\n    private getFirstPageLink(): string {\n        let link = '/';\n        const firstPage = this._navigation.getFirstRoute();\n        if (this.gesdemService.prefix) {\n            link += `${this.gesdemService.prefix}/`;\n        }\n\n        return `${link + this.reference}/${firstPage.path}`;\n    }\n}\n","<div class=\"container mt-5\" *ngIf=\"reference && !isInProgress\">\n    <div\n        class=\"alert text-center mb-2\"\n        [ngClass]=\"isTransferred ? 'alert-success' : 'alert-danger'\"\n    >\n        <p class=\"h2\">\n            {{\n                isTransferred\n                    ? (successLabelDicoKey | fromDictionary)\n                    : ('gesdem-confirmation.abort-label' | fromDictionary)\n            }}\n        </p>\n        <dl>\n            <dt class=\"font-weight-light\">\n                {{\n                    'gesdem-confirmation.reference-title.label' | fromDictionary\n                }}\n            </dt>\n            <dd id=\"numDemande\" class=\"h4 d-block mt-3\">{{ reference }}</dd>\n        </dl>\n        <p *ngIf=\"hasEmailSent && !(isConnected | async)\">\n            {{ 'gesdem-confirmation.mail-sent.label' | fromDictionary }}\n        </p>\n    </div>\n\n    <span\n        [innerHTML]=\"'gesdem-confirmation.extra-content' | fromDictionary\"\n    ></span>\n\n    <ng-content></ng-content>\n\n    <div\n        class=\"col-md-12 vd-highlight\"\n        *ngIf=\"(isConnected | async) && hasConnectedContent()\"\n    >\n        <span class=\"sr-only\">\n            Information suite à la transmission de votre demande\n        </span>\n        <div class=\"row\">\n            <div class=\"col-md-1\">\n                <foehn-icon-info-circle class=\"h3\"></foehn-icon-info-circle>\n            </div>\n            <div class=\"col-md-11\">\n                <p\n                    [innerHTML]=\"\n                        isTransferred\n                            ? connectedConfirmationMessage\n                            : connectedConfirmationMessageIfAbandoned\n                    \"\n                ></p>\n                <p\n                    *ngIf=\"\n                        showLinkToMyDemandes &&\n                        (demandeIsClosedOnTransmit || isAbandoned)\n                    \"\n                >\n                    Vous pouvez consulter votre demande en cliquant sur :\n                    <a href=\"/100002/demandes/search/MINE/TREATED\">\n                        Mes nouvelles demandes traitées\n                    </a>\n                    .\n                </p>\n                <p\n                    *ngIf=\"\n                        showLinkToMyDemandes &&\n                        !demandeIsClosedOnTransmit &&\n                        !isAbandoned\n                    \"\n                >\n                    Vous pouvez suivre l'avancement du traitement de votre\n                    demande en cliquant sur :\n                    <a href=\"/100002/demandes/search/MINE/IN_PROGRESS\">\n                        Mes demandes en cours de traitement\n                    </a>\n                    .\n                </p>\n            </div>\n        </div>\n    </div>\n\n    <div\n        class=\"col-md-12 list-unstyled d-md-flex p-0 mt-4\"\n        *ngIf=\"!(isConnected | async)\"\n    >\n        <div class=\"ml-0 mr-md-auto mr-md-2 mb-2 mt-2\">\n            <a\n                *ngIf=\"showDownloadPdfRecapButton\"\n                [href]=\"urlPdf\"\n                id=\"telechargerBtn\"\n                class=\"btn btn-secondary w-100\"\n                title=\"Télécharger le PDF\"\n            >\n                {{ downloadPdfRecapButtonText | fromDictionary }}\n            </a>\n        </div>\n\n        <div\n            class=\"mr-0 ml-md-auto mb-2 mt-2\"\n            *ngIf=\"closeLink | async as link\"\n        >\n            <a\n                [href]=\"link\"\n                id=\"terminerBtn\"\n                class=\"btn btn-primary w-100\"\n                title=\"Terminer\"\n            >\n                {{ closeButtonText | fromDictionary }}\n            </a>\n        </div>\n    </div>\n</div>\n\n<div class=\"container mt-5\" *ngIf=\"reference && isInProgress\">\n    <div class=\"alert alert-info text-center mb-2\">\n        <p class=\"h2\">Demande en cours</p>\n        <dl>\n            <dt class=\"font-weight-light\">\n                {{\n                    'gesdem-confirmation.reference-title.label' | fromDictionary\n                }}\n            </dt>\n            <dd id=\"numDemandeEnCours\" class=\"h4 d-block mt-3\">\n                {{ reference }}\n            </dd>\n        </dl>\n    </div>\n\n    <div class=\"col-md-12 vd-highlight\">\n        <div class=\"row\">\n            <div class=\"col-md-1\">\n                <foehn-icon-info-circle class=\"h3\"></foehn-icon-info-circle>\n            </div>\n            <div class=\"col-md-11\">\n                <p>\n                    Vous pouvez reprendre votre demande en cliquant sur le lien\n                    ci-dessous\n                </p>\n                <p>\n                    <a [routerLink]=\"firstPageLink\">Reprendre ma demande</a>\n                </p>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gesdem-confirmation.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/gesdem-confirmation/gesdem-confirmation.component.ts","../../../../projects/prestations-ng/src/gesdem-confirmation/gesdem-confirmation.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChange,\n    SimpleChanges\n} from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { BehaviorSubject, Observable, Subscription } from 'rxjs';\nimport { first, map } from 'rxjs/operators';\n\nimport { GesdemHandlerService } from '../gesdem/gesdem-handler.service';\nimport { BreadcrumbEventService } from '../foehn-breadcrumb/breadcrumb-event.service';\nimport { FoehnPageService } from '../foehn-page/foehn-page.service';\nimport { ServiceLocator } from '../service-locator';\nimport { SessionInfo } from '../sdk-session-info/session-info.service';\nimport { FoehnNavigationService } from '../foehn-navigation/foehn-navigation.service';\nimport { ActionStatut, GesdemStatutUtils } from '../gesdem/gesdem-statut-utils';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { Location } from '@angular/common';\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'gesdem-confirmation',\n    templateUrl: './gesdem-confirmation.component.html'\n})\nexport class GesdemConfirmationComponent\n    implements OnInit, OnDestroy, OnChanges {\n    @Input()\n    reference: string;\n\n    @Input()\n    setPageTitle = true;\n\n    @Input()\n    hasEmailSent = false;\n\n    @Input()\n    closeHref: string;\n\n    @Input()\n    showDownloadPdfRecapButton = true;\n\n    @Input()\n    showLinkToMyDemandes = true;\n\n    @Input()\n    demandeIsClosedOnTransmit = false;\n\n    @Input()\n    actionStatut = ActionStatut.TRANSFERRED;\n\n    @Input()\n    connectedConfirmationMessage =\n        'Vous avez effectué la première étape de votre démarche avec succès !';\n\n    @Input()\n    connectedConfirmationMessageIfAbandoned =\n        \"La demande à laquelle vous essayez d'accéder a été abandonnée.\";\n\n    @Input()\n    downloadPdfRecapButtonText: string;\n\n    @Input()\n    closeButtonText: string;\n\n    @Input()\n    baseUrlPdf = 'api/document/pdf/';\n\n    isConnectedCyber: Observable<boolean>;\n    firstPageLink = '/';\n    urlPdf: string;\n    closeLink = new BehaviorSubject<string>(null);\n\n    protected _breadcrumbEventService: BreadcrumbEventService;\n    protected _foehnPageService: FoehnPageService;\n    protected _sessionInfo: SessionInfo;\n    protected _navigation: FoehnNavigationService;\n\n    private dataSubscription: Subscription;\n    private pageTitleSubscription: Subscription;\n\n    constructor(\n        protected gesdemService: GesdemHandlerService,\n        protected foehnPageService: FoehnPageService,\n        protected activatedRoute: ActivatedRoute,\n        protected dictionaryService: SdkDictionaryService,\n        protected location: Location\n    ) {\n        this._breadcrumbEventService = ServiceLocator.injector.get(\n            BreadcrumbEventService\n        );\n        this._foehnPageService = ServiceLocator.injector.get(FoehnPageService);\n        this._sessionInfo = ServiceLocator.injector.get(SessionInfo);\n        this._navigation = ServiceLocator.injector.get(FoehnNavigationService);\n\n        const route = FoehnNavigationService.getRootRouteRecursive(\n            activatedRoute.snapshot\n        );\n        this._navigation.initRoute(route);\n\n        // Override from the routing.\n        this.dataSubscription = this.activatedRoute.data.subscribe(\n            routeData => {\n                this.hasEmailSent = routeData.hasEmailSent || this.hasEmailSent;\n                this.closeLink.next(\n                    routeData.closeHref || this.closeLink.getValue()\n                );\n                this.connectedConfirmationMessage =\n                    routeData.connectedConfirmationMessage ||\n                    this.connectedConfirmationMessage;\n                this.connectedConfirmationMessageIfAbandoned =\n                    routeData.connectedConfirmationMessageIfAbandoned ||\n                    this.connectedConfirmationMessageIfAbandoned;\n                this.showDownloadPdfRecapButton =\n                    routeData.showDownloadPdfRecapButton ||\n                    this.showDownloadPdfRecapButton;\n                this.showLinkToMyDemandes =\n                    routeData.showLinkToMyDemandes || this.showLinkToMyDemandes;\n                this.demandeIsClosedOnTransmit =\n                    routeData.demandeIsClosedOnTransmit ||\n                    this.demandeIsClosedOnTransmit;\n                this.downloadPdfRecapButtonText =\n                    routeData.downloadPdfRecapButtonText ||\n                    this.downloadPdfRecapButtonText ||\n                    'gesdem-confirmation.download-pdf-recap-button';\n                this.baseUrlPdf = routeData.baseUrlPdf || this.baseUrlPdf;\n                this.closeButtonText =\n                    routeData.closeButtonText ||\n                    this.closeButtonText ||\n                    'gesdem-confirmation.exit-button';\n\n                // default closeLink if not by @Input and not by route data\n                this.foehnPageService\n                    .onEtapeIdChange()\n                    .pipe(first())\n                    // eslint-disable-next-line rxjs/no-nested-subscribe\n                    .subscribe(etapeId => {\n                        if (!this.closeLink.getValue()) {\n                            this.closeLink.next(\n                                `https://www.vd.ch/go.to?prestation=${etapeId}`\n                            );\n                        }\n                    });\n            }\n        );\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const change: SimpleChange = changes.closeHref;\n        if (change && change.currentValue) {\n            this.closeLink.next(change.currentValue);\n        }\n    }\n\n    ngOnInit(): void {\n        const lastResponse = this.gesdemService.lastResponse;\n        if (lastResponse) {\n            this.reference = lastResponse.meta.reference;\n            this.actionStatut =\n                ActionStatut[lastResponse.meta.statut as ActionStatut];\n            this.urlPdf = this.baseUrlPdf + this.reference;\n            const currentAction = lastResponse.meta.currentAction;\n            if (!!currentAction) {\n                this.urlPdf += `-${currentAction}`;\n                if (this.location.path().includes(`/${this.reference}/`)) {\n                    const fullReferenceUrl = this.location\n                        .path()\n                        .replace(\n                            this.reference,\n                            `${this.reference}-${currentAction}`\n                        );\n                    this.location.replaceState(fullReferenceUrl);\n                }\n            }\n\n            const languageCode = lastResponse.form.language;\n            this.dictionaryService.changeLanguage(languageCode);\n        }\n\n        // Whether the user has a context we consider it as connected.\n        this.isConnectedCyber = this._sessionInfo.data.pipe(\n            map(userInfo => !!userInfo && !!userInfo.context)\n        );\n\n        if (this.setPageTitle) {\n            this.pageTitleSubscription = this.dictionaryService\n                .getKey('gesdem-confirmation.title')\n                .subscribe(title => this._foehnPageService.setPageTitle(title));\n        }\n\n        this.firstPageLink = this.getFirstPageLink();\n\n        this._breadcrumbEventService.skipLeavingAlertBecauseDemandIsTransmitted = true;\n    }\n\n    ngOnDestroy(): void {\n        if (this.dataSubscription) {\n            this.dataSubscription.unsubscribe();\n        }\n        if (this.pageTitleSubscription) {\n            this.pageTitleSubscription.unsubscribe();\n        }\n    }\n\n    hasConnectedContent(): boolean {\n        const hasConfMessage =\n            this.isTransferred && !!this.connectedConfirmationMessage;\n        const hasAbandonedConfMessage =\n            !this.isTransferred &&\n            !!this.connectedConfirmationMessageIfAbandoned;\n\n        return (\n            hasConfMessage ||\n            hasAbandonedConfMessage ||\n            !!this.showLinkToMyDemandes\n        );\n    }\n\n    get isTransferred(): boolean {\n        return (\n            this.actionStatut && this.actionStatut === ActionStatut.TRANSFERRED\n        );\n    }\n\n    get isAbandoned(): boolean {\n        return (\n            this.actionStatut && this.actionStatut === ActionStatut.ABANDONED\n        );\n    }\n\n    get isInProgress(): boolean {\n        return !GesdemStatutUtils.isFinal(this.actionStatut);\n    }\n\n    get successLabelDicoKey(): string {\n        const isFirstAction =\n            this.gesdemService.lastResponse?.meta?.currentAction === 1;\n        return isFirstAction\n            ? 'gesdem-confirmation.success-label'\n            : 'gesdem-confirmation.next-step.success-label';\n    }\n\n    private getFirstPageLink(): string {\n        let link = '/';\n        const firstPage = this._navigation.getFirstRoute();\n        if (this.gesdemService.prefix) {\n            link += `${this.gesdemService.prefix}/`;\n        }\n\n        return `${link + this.reference}/${firstPage.path}`;\n    }\n}\n","<div class=\"container mt-5\" *ngIf=\"reference && !isInProgress\">\n    <div\n        class=\"alert text-center mb-2\"\n        [ngClass]=\"isTransferred ? 'alert-success' : 'alert-danger'\"\n    >\n        <p class=\"h2\">\n            {{\n                isTransferred\n                    ? (successLabelDicoKey | fromDictionary)\n                    : ('gesdem-confirmation.abort-label' | fromDictionary)\n            }}\n        </p>\n        <dl>\n            <dt class=\"font-weight-light\">\n                {{\n                    'gesdem-confirmation.reference-title.label' | fromDictionary\n                }}\n            </dt>\n            <dd id=\"numDemande\" class=\"h4 d-block mt-3\">{{ reference }}</dd>\n        </dl>\n        <p *ngIf=\"hasEmailSent && !(isConnectedCyber | async)\">\n            {{ 'gesdem-confirmation.mail-sent.label' | fromDictionary }}\n        </p>\n    </div>\n\n    <span\n        [innerHTML]=\"'gesdem-confirmation.extra-content' | fromDictionary\"\n    ></span>\n\n    <ng-content></ng-content>\n\n    <div\n        class=\"col-md-12 vd-highlight\"\n        *ngIf=\"(isConnectedCyber | async) && hasConnectedContent()\"\n    >\n        <span class=\"sr-only\">\n            Information suite à la transmission de votre demande\n        </span>\n        <div class=\"row\">\n            <div class=\"col-md-1\">\n                <foehn-icon-info-circle class=\"h3\"></foehn-icon-info-circle>\n            </div>\n            <div class=\"col-md-11\">\n                <p\n                    [innerHTML]=\"\n                        isTransferred\n                            ? connectedConfirmationMessage\n                            : connectedConfirmationMessageIfAbandoned\n                    \"\n                ></p>\n                <p\n                    *ngIf=\"\n                        showLinkToMyDemandes &&\n                        (demandeIsClosedOnTransmit || isAbandoned)\n                    \"\n                >\n                    Vous pouvez consulter votre demande en cliquant sur :\n                    <a href=\"/100002/demandes/search/MINE/TREATED\">\n                        Mes nouvelles demandes traitées\n                    </a>\n                    .\n                </p>\n                <p\n                    *ngIf=\"\n                        showLinkToMyDemandes &&\n                        !demandeIsClosedOnTransmit &&\n                        !isAbandoned\n                    \"\n                >\n                    Vous pouvez suivre l'avancement du traitement de votre\n                    demande en cliquant sur :\n                    <a href=\"/100002/demandes/search/MINE/IN_PROGRESS\">\n                        Mes demandes en cours de traitement\n                    </a>\n                    .\n                </p>\n            </div>\n        </div>\n    </div>\n\n    <div\n        class=\"col-md-12 list-unstyled d-md-flex p-0 mt-4\"\n        *ngIf=\"!(isConnectedCyber | async)\"\n    >\n        <div class=\"ml-0 mr-md-auto mr-md-2 mb-2 mt-2\">\n            <a\n                *ngIf=\"showDownloadPdfRecapButton\"\n                [href]=\"urlPdf\"\n                id=\"telechargerBtn\"\n                class=\"btn btn-secondary w-100\"\n                title=\"Télécharger le PDF\"\n            >\n                {{ downloadPdfRecapButtonText | fromDictionary }}\n            </a>\n        </div>\n\n        <div\n            class=\"mr-0 ml-md-auto mb-2 mt-2\"\n            *ngIf=\"closeLink | async as link\"\n        >\n            <a\n                [href]=\"link\"\n                id=\"terminerBtn\"\n                class=\"btn btn-primary w-100\"\n                title=\"Terminer\"\n            >\n                {{ closeButtonText | fromDictionary }}\n            </a>\n        </div>\n    </div>\n</div>\n\n<div class=\"container mt-5\" *ngIf=\"reference && isInProgress\">\n    <div class=\"alert alert-info text-center mb-2\">\n        <p class=\"h2\">Demande en cours</p>\n        <dl>\n            <dt class=\"font-weight-light\">\n                {{\n                    'gesdem-confirmation.reference-title.label' | fromDictionary\n                }}\n            </dt>\n            <dd id=\"numDemandeEnCours\" class=\"h4 d-block mt-3\">\n                {{ reference }}\n            </dd>\n        </dl>\n    </div>\n\n    <div class=\"col-md-12 vd-highlight\">\n        <div class=\"row\">\n            <div class=\"col-md-1\">\n                <foehn-icon-info-circle class=\"h3\"></foehn-icon-info-circle>\n            </div>\n            <div class=\"col-md-11\">\n                <p>\n                    Vous pouvez reprendre votre demande en cliquant sur le lien\n                    ci-dessous\n                </p>\n                <p>\n                    <a [routerLink]=\"firstPageLink\">Reprendre ma demande</a>\n                </p>\n            </div>\n        </div>\n    </div>\n</div>\n"]}