This project was generated with Angular CLI version 7.3.8.
This Project is used for EXUI team as a common library.
All the common libraries are located at projects/exui-common-lib
.
Run ng serve
(or yarn start:no-open
) for a dev server. Navigate to http://localhost:4200/
. The app will automatically reload if you change any of the source files.
The main project is only a base to run projects/exui-common-lib
.
Run ng generate component component-name
to generate a new component. You can also use ng generate directive|pipe|service|class|guard|interface|enum|module
.
Run ng build exui-common-lib
(or yarn build
) to build the exui-common-lib project. The build artifacts will be stored in the dist/
directory.
Run ng test exui-common-lib
(or yarn test
) to execute the unit tests via Karma.
It will run the tests for exui-common-lib.
Run ng e2e
to execute the end-to-end tests via Protractor.
To get more help on the Angular CLI use ng help
or go check out the Angular CLI README.
The Timeout Notification Service allows your application to receive notifications when a User is approaching the the total time that a User has been idle for.
This can be set by your application using the Timeout Notification Config object.
Your application will then have to listen to events coming from the Timeout Notification Service, and handle these events within your application.
- Step 1. Import the TimeoutNotificationsService from rpx-xui-common-lib
import { TimeoutNotificationsService } from '@hmcts/rpx-xui-common-lib';
- Step 2. Add the TimeoutNotificationService to the constructor.
constructor(
private readonly timeoutNotificationsService: TimeoutNotificationsService
) {
- Step 3. Add a Handler, to handle the TimeoutNotificationService events.
public timeoutNotificationEventHandler(event) {
switch (event.eventType) {
case 'countdown': {
// Implement application countdown logic, here we are using
// our timeout modal, which is another re-usable UI component.
this.updateTimeoutModal(event.readableCountdown, true);
return;
}
case 'sign-out': {
// Implement application signout logic
this.updateTimeoutModal(undefined, false);
return;
}
case 'keep-alive': {
// Implement application keep alive logic
return;
}
default: {
throw new Error('Invalid Timeout Notification Event');
}
}
}
- Step 4. Listen for the TimeoutNotificationService events, and send them onto the Handler.
this.timeoutNotificationsService.notificationOnChange().subscribe(event => {
this.timeoutNotificationEventHandler(event);
});
- Step 5. Create a configuration object and pass the object to configure the service.
/**
* Timeout Notification Config
*
* Note that idleModalDisplayTime and totalIdleTime should be passed in
* in milliseconds.
*/
const timeoutNotificationConfig: any = {
idleModalDisplayTime: idleModalDisplayTimeInMilliseconds,
totalIdleTime: totalIdleTimeInMilliseconds,
idleServiceName: 'idleSession'
};
this.timeoutNotificationsService.initialise(timeoutNotificationConfig);
@see app.component.ts @see https://github.com/hmcts/rpx-xui-webapp @see https://github.com/hmcts/rpx-xui-manage-organisations
The Timeout Notification Service currently has three events that you can handle. These are:
The 'countdown' event. This event dispatches a readable countdown timer in it's event payload. the countdown timer is a readable version of the countdown time ie. '10 seconds' or '1 minute'. Note that this dispatches once per second when the timer has reached less than 60 seconds till the 'sign-out' event is fired.
If the 'countdown' timer is above a minute this event is dispatched every minute.
The 'keep-alive' event dispatches when the User has interacted with the page again.
The 'sign-out' event dispatches when the countdown timer has come to an end - when the User should be signed out.
totalIdleTime
is the total amount of time in milliseconds that the User is idle for. ie.
A User is working, they then stop interacting with the page. When the User stops interacting
with the page is when the totalIdleTime begins.
The Users Total Idle Time, includes the time in which we show the Timeout Modal to a User.
idleModalDisplayTime
is the total amount of time in milliseconds to display a Session Timeout Modal.
Note that our xui re-usable Session Timeout Modal can be used.
Important note: The idleModalDisplayTime IS PART of the totalIdleTime. The idleModalDisplayTime does not get added to the end of the totalIdleTime.
An example:
totalIdleTime: 120000
idleModalDisplayTime: 60000
,
totalIdleTime is 2 minutes. idleModalDisplayTime is 1 minute.
This would lead to:
- On the User being idle for 1 minute, 'countdown' events are thrown.
- When the User is Idle for 2 minutes a 'sign-out' event is thrown.
- If the User interacts with the page within this time a 'keep-alive' event is thrown.
- By default when the User is idle for under 1 minute, countdown events are thrown each second.
When the User is in the final minute of them being idle, countdown events are thrown every second. So that you can display a 60 second countdown, within your modal dialog.
To implement the XUI Timeout Notification Service Modal, which is the view that goes along with the Timeout Notification Service.
Step 1. Add the latest '@hmcts/rpx-xui-common-lib' into your project.
Step 2. Add the following component into any parent Angular component where you wish to see the modal dialog. Within the XUI projects we've added this into our app.component.html file.
<xuilib-session-dialog positionTop="300px" *ngIf="timeoutModalConfig.isVisible" (close)="staySignedInHandler()">
<h3 class="govuk-heading-m">We are about to sign you out</h3>
<p class="govuk-body">For your security, we will sign you out of your account in
<strong>{{timeoutModalConfig.countdown}}</strong>
</p>
<p>Any information you have not saved will be lost</p>
<button type="submit" class="govuk-button" (click)="staySignedInHandler()">
Stay signed in
</button>
<div>
<a (click)="signOutHandler()" [routerLink]="">Sign out</a>
</div>
</xuilib-session-dialog>
@see app.component.html @see app.component.ts @see https://github.com/hmcts/rpx-xui-webapp @see https://github.com/hmcts/rpx-xui-manage-organisations
END