File
Implements
Index
Properties
|
|
Methods
|
|
Inputs
|
|
showDefaultContactLink
|
Type : boolean
|
Default value : true
|
|
If set to 'false', hide the default Contact link.
|
showDefaultGuideLink
|
Type : boolean
|
Default value : true
|
|
If set to 'false', hide the default Guide link.
|
showDefaultSecurityBestPracticeLink
|
Type : boolean
|
Default value : true
|
|
If set to 'false', hide the default Security Best Practice link.
|
showDefaultTermOfUseLink
|
Type : boolean
|
Default value : true
|
|
If set to 'false', hide the default Terms of use link.
|
Methods
Private
getContactLink
|
getContactLink(contactFormTitle: string, contactFormUrl: string, reference: string)
|
|
Parameters :
Name |
Type |
Optional |
contactFormTitle |
string
|
No
|
contactFormUrl |
string
|
No
|
reference |
string
|
No
|
|
Private
getDefaultLinks
|
getDefaultLinks(contactFormTitle: string, contactFormUrl: string, reference: string)
|
|
Parameters :
Name |
Type |
Optional |
contactFormTitle |
string
|
No
|
contactFormUrl |
string
|
No
|
reference |
string
|
No
|
|
Private
getGuideLink
|
getGuideLink()
|
|
|
Private
getSecurityBestPracticeLink
|
getSecurityBestPracticeLink()
|
|
|
Private
getTermOfUseLink
|
getTermOfUseLink()
|
|
|
gotToTop
|
gotToTop(e: Event)
|
|
Parameters :
Name |
Type |
Optional |
e |
Event
|
No
|
|
ngOnChanges
|
ngOnChanges()
|
|
|
Private
inputChanged
|
Default value : new BehaviorSubject<number>(0)
|
|
import { Component, Input, OnChanges, OnInit } from '@angular/core';
import { BehaviorSubject, combineLatest, merge, Observable, of } from 'rxjs';
import { map } from 'rxjs/operators';
import { GesdemEventService } from '../gesdem/gesdem-event.service';
import { GesdemHandlerService } from '../gesdem/gesdem-handler.service';
import { ApplicationInfo } from '../sdk-appinfo/application-info';
import { ApplicationInfoService } from '../sdk-appinfo/application-info.service';
import { FooterLink } from './footer-link.type';
const GUIDE_URL = 'https://www.vd.ch/index.php?id=67827';
const TERM_OF_USE_URL = 'https://www.vd.ch/index.php?id=2015321';
const SECURITY_BEST_PRACTICE_URL = 'https://www.vd.ch/index.php?id=2015320';
@Component({
selector: 'foehn-footer',
templateUrl: './foehn-footer.component.html',
styleUrls: ['./foehn-footer.component.css']
})
export class FoehnFooterComponent implements OnInit, OnChanges {
@Input()
links: FooterLink[];
/**
* If set to 'false', hide the default Contact link.
*/
@Input()
showDefaultContactLink = true;
/**
* If set to 'false', hide the default Guide link.
*/
@Input()
showDefaultGuideLink = true;
/**
* If set to 'false', hide the default Terms of use link.
*/
@Input()
showDefaultTermOfUseLink = true;
/**
* If set to 'false', hide the default Security Best Practice link.
*/
@Input()
showDefaultSecurityBestPracticeLink = true;
applicationInfo: Observable<ApplicationInfo>;
allLinks: Observable<FooterLink[]>;
readonly applicationInfoService: ApplicationInfoService;
readonly gesdemEventService: GesdemEventService;
readonly gesdemService: GesdemHandlerService;
private inputChanged = new BehaviorSubject<number>(0);
constructor(
applicationInfoService: ApplicationInfoService,
gesdemEventService: GesdemEventService,
gesdemService: GesdemHandlerService
) {
this.gesdemService = gesdemService;
this.gesdemEventService = gesdemEventService;
this.applicationInfoService = applicationInfoService;
}
ngOnInit(): void {
this.applicationInfo = this.applicationInfoService.data;
const referenceObservable = this.gesdemEventService
.formInitializationObservable()
.pipe(
map(
() =>
this.gesdemService.lastResponse &&
this.gesdemService.lastResponse.meta.reference
)
);
combineLatest([
this.applicationInfoService.getSafeSupportFormUrl(),
this.applicationInfoService.getSafeSupportFormTitle()
// eslint-disable-next-line rxjs-angular/prefer-async-pipe
]).subscribe(([url, title]) => {
this.allLinks = combineLatest([
merge(of(null), referenceObservable),
this.inputChanged
]).pipe(
map(([reference]) => [
...this.getDefaultLinks(title, url, reference),
...(this.links || [])
])
);
});
}
ngOnChanges(): void {
this.inputChanged.next(this.inputChanged.getValue() + 1);
}
gotToTop(e: Event): void {
if (e) {
e.preventDefault();
}
window.scrollTo(0, 0);
}
private getDefaultLinks(
contactFormTitle: string,
contactFormUrl: string,
reference: string
): FooterLink[] {
return [
this.getContactLink(contactFormTitle, contactFormUrl, reference),
this.getGuideLink(),
this.getTermOfUseLink(),
this.getSecurityBestPracticeLink()
].filter(value => !!value);
}
private getContactLink(
contactFormTitle: string,
contactFormUrl: string,
reference: string
): FooterLink | null {
if (!this.showDefaultContactLink) {
return null;
}
const referenceQueryParam = !!reference
? `?concernedReference=${reference}`
: '';
const fullSupportAppUrl = contactFormUrl + referenceQueryParam;
return {
label: contactFormTitle,
url: fullSupportAppUrl
};
}
private getGuideLink(): FooterLink | null {
if (!this.showDefaultGuideLink) {
return null;
}
return {
label: "Guide d'utilisation du portail sécurisé",
url: GUIDE_URL
};
}
private getTermOfUseLink(): FooterLink | null {
if (!this.showDefaultTermOfUseLink) {
return null;
}
return {
label: "Conditions d'utilisation",
url: TERM_OF_USE_URL
};
}
private getSecurityBestPracticeLink(): FooterLink | null {
if (!this.showDefaultSecurityBestPracticeLink) {
return null;
}
return {
label: 'Bonnes pratiques en matière de sécurité informatique et de protection des données personnelles',
url: SECURITY_BEST_PRACTICE_URL
};
}
}
<footer id="foehn_footerContainer" class="mt-5">
<div class="container">
<div class="text-end">
<a
href=""
class="btn btn-sm btn-dark"
title="Retour vers le haut de la page"
(click)="gotToTop($event)"
>
Haut
<foehn-icon-chevron-up></foehn-icon-chevron-up>
</a>
</div>
</div>
<div class="footer">
<div class="container">
<div class="row">
<div class="col-xs-10" *ngIf="allLinks | async as links">
<nav
class="row"
aria-label="pied de page"
*ngIf="!!links && !!links.length"
>
<div class="col-sm">
<ul class="list-unstyled">
<li *ngFor="let link of links">
<a
class="footer-link"
target="_blank"
[href]="link.url"
>
{{ link.label }}
</a>
</li>
</ul>
</div>
</nav>
</div>
<div class="col-xs-2">
<div class="d-flex align-items-end flex-column h-100">
<div class="mt-auto w-100 text-end">
<a href="https://www.vd.ch" class="d-inline-block">
<span class="visually-hidden">
Retour à la page d'accueil
</span>
<img
aria-hidden="true"
class="img-fluid footer-logo"
src=""
alt="Canton de Vaud"
/>
</a>
</div>
</div>
</div>
</div>
</div>
<span id="version-for-user" *ngIf="applicationInfo | async as appInfo">
{{ appInfo.version }}
</span>
</div>
<!-- Numéros de version de l'appli -->
<!-- On les met en hidden pour tous pour éviter des problèmes d'accessibilité -->
<span
id="appinfo"
aria-hidden="true"
class="d-none"
*ngIf="applicationInfo | async as appInfo"
>
<span id="environment" aria-hidden="true" class="d-none">
{{ appInfo.environment }}
</span>
<span id="version" aria-hidden="true" class="d-none">
{{ appInfo.version }}
</span>
<span id="buildtime" aria-hidden="true" class="d-none">
{{ appInfo.buildtime }}
</span>
<span id="contextPath" aria-hidden="true" class="d-none">
{{ appInfo.contextPath }}
</span>
</span>
</footer>
#version-for-user {
position: absolute;
bottom: -23px;
right: 5px;
color: var(--white);
font-size: 0.8rem;
}
Legend
Html element with directive