@huntsman-cancer-institute/authentication 16.0.1 → 17.0.1

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.
@@ -1,53 +1,53 @@
1
- /*
2
- * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary
3
- */
4
- import { Component } from "@angular/core";
5
- import { animate, state, style, transition, trigger } from "@angular/animations";
6
- import { timer } from "rxjs";
7
- import { map, takeWhile } from "rxjs/operators";
8
- import { AuthenticationService } from "./authentication.service";
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "./authentication.service";
11
- import * as i2 from "@angular/common";
12
- export class TimeoutNotificationComponent {
13
- constructor(authenticationService) {
14
- this.authenticationService = authenticationService;
15
- this.openState = "hidden";
16
- authenticationService.isAboutToTimeOut().subscribe((isAboutToTimeOut) => {
17
- if (isAboutToTimeOut) {
18
- this.openState = "opened";
19
- this.startCountdown();
20
- }
21
- else {
22
- this.openState = "hidden";
23
- //If something changed mid-timeout, cancel the timeout/logout.
24
- if (this.subscription != null && !this.subscription.closed) {
25
- this.subscription.unsubscribe();
26
- }
27
- }
28
- });
29
- }
30
- startCountdown() {
31
- this.seconds = timer(0, 1000)
32
- .pipe(map(() => {
33
- const elapsed = Math.round((Date.now() - this.authenticationService.getTimeoutStart()) / 1000);
34
- return this.authenticationService.userCountdownSeconds - elapsed;
35
- }),
36
- // The true argument emits the final value that completed the observable
37
- takeWhile((value) => value > 0, true));
38
- this.subscription = this.seconds.subscribe((value) => {
39
- if (value < 1) {
40
- this.subscription.unsubscribe();
41
- this.authenticationService.logout(true);
42
- }
43
- });
44
- }
45
- click() {
46
- this.subscription.unsubscribe();
47
- this.authenticationService.updateUserActivity();
48
- }
49
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TimeoutNotificationComponent, deps: [{ token: i1.AuthenticationService }], target: i0.ɵɵFactoryTarget.Component }); }
50
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TimeoutNotificationComponent, selector: "timeout-notification", ngImport: i0, template: `
1
+ /*
2
+ * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary
3
+ */
4
+ import { Component } from "@angular/core";
5
+ import { animate, state, style, transition, trigger } from "@angular/animations";
6
+ import { timer } from "rxjs";
7
+ import { map, takeWhile } from "rxjs/operators";
8
+ import { AuthenticationService } from "./authentication.service";
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "./authentication.service";
11
+ import * as i2 from "@angular/common";
12
+ export class TimeoutNotificationComponent {
13
+ constructor(authenticationService) {
14
+ this.authenticationService = authenticationService;
15
+ this.openState = "hidden";
16
+ authenticationService.isAboutToTimeOut().subscribe((isAboutToTimeOut) => {
17
+ if (isAboutToTimeOut) {
18
+ this.openState = "opened";
19
+ this.startCountdown();
20
+ }
21
+ else {
22
+ this.openState = "hidden";
23
+ //If something changed mid-timeout, cancel the timeout/logout.
24
+ if (this.subscription != null && !this.subscription.closed) {
25
+ this.subscription.unsubscribe();
26
+ }
27
+ }
28
+ });
29
+ }
30
+ startCountdown() {
31
+ this.seconds = timer(0, 1000)
32
+ .pipe(map(() => {
33
+ const elapsed = Math.round((Date.now() - this.authenticationService.getTimeoutStart()) / 1000);
34
+ return this.authenticationService.userCountdownSeconds - elapsed;
35
+ }),
36
+ // The true argument emits the final value that completed the observable
37
+ takeWhile((value) => value > 0, true));
38
+ this.subscription = this.seconds.subscribe((value) => {
39
+ if (value < 1) {
40
+ this.subscription.unsubscribe();
41
+ this.authenticationService.logout(true);
42
+ }
43
+ });
44
+ }
45
+ click() {
46
+ this.subscription.unsubscribe();
47
+ this.authenticationService.updateUserActivity();
48
+ }
49
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TimeoutNotificationComponent, deps: [{ token: i1.AuthenticationService }], target: i0.ɵɵFactoryTarget.Component }); }
50
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: TimeoutNotificationComponent, selector: "timeout-notification", ngImport: i0, template: `
51
51
  <div class="flyout-max" [@openBacksplash]="openState">
52
52
  <div class="modal-dialog" [@openModal]="openState" role="document">
53
53
  <div class="modal-header">
@@ -63,40 +63,40 @@ export class TimeoutNotificationComponent {
63
63
  </div>
64
64
  </div>
65
65
  </div>
66
- `, isInline: true, styles: [".flyout-max{position:fixed;z-index:9999;top:0;bottom:0;background-color:#0006;width:100vw}.modal-dialog{position:fixed;max-width:50vw;min-width:50vw;left:-50vw;top:25vw;margin:0;background-color:#fff;border:black 1px solid;border-left:none;border-radius:20px;pointer-events:all}.modal-body{width:100%;display:inline-block}.modal-body-left{display:inline-block;overflow-y:auto;overflow-x:hidden;min-height:300px;max-height:300px}.modal-body-right{width:70%;vertical-align:top;padding-left:15px;border-left:black 1px solid;margin-left:15px;display:inline-block;overflow-y:auto;min-height:300px;max-height:300px}\n"], dependencies: [{ kind: "pipe", type: i2.AsyncPipe, name: "async" }], animations: [
67
- trigger("openBacksplash", [
68
- state("in", style({
69
- "display": "none"
70
- })),
71
- state("hidden", style({
72
- "display": "none"
73
- })),
74
- state("opened", style({
75
- "display": "inherit"
76
- })),
77
- transition("hidden => opened", animate(100)),
78
- transition("opened => hidden", animate(200))
79
- ]),
80
- trigger("openModal", [
81
- state("in", style({
82
- "opacity": "0",
83
- "left": "-50vw"
84
- })),
85
- state("hidden", style({
86
- "opacity": "0",
87
- "left": "-50vw"
88
- })),
89
- state("opened", style({
90
- "opacity": "1",
91
- "left": "25vw"
92
- })),
93
- transition("hidden => opened", animate(500)),
94
- transition("opened => hidden", animate(300))
95
- ])
96
- ] }); }
97
- }
98
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TimeoutNotificationComponent, decorators: [{
99
- type: Component,
66
+ `, isInline: true, styles: [".flyout-max{position:fixed;z-index:9999;top:0;bottom:0;background-color:#0006;width:100vw}.modal-dialog{position:fixed;max-width:50vw;min-width:50vw;left:-50vw;top:25vw;margin:0;background-color:#fff;border:black 1px solid;border-left:none;border-radius:20px;pointer-events:all}.modal-body{width:100%;display:inline-block}.modal-body-left{display:inline-block;overflow-y:auto;overflow-x:hidden;min-height:300px;max-height:300px}.modal-body-right{width:70%;vertical-align:top;padding-left:15px;border-left:black 1px solid;margin-left:15px;display:inline-block;overflow-y:auto;min-height:300px;max-height:300px}\n"], dependencies: [{ kind: "pipe", type: i2.AsyncPipe, name: "async" }], animations: [
67
+ trigger("openBacksplash", [
68
+ state("in", style({
69
+ "display": "none"
70
+ })),
71
+ state("hidden", style({
72
+ "display": "none"
73
+ })),
74
+ state("opened", style({
75
+ "display": "inherit"
76
+ })),
77
+ transition("hidden => opened", animate(100)),
78
+ transition("opened => hidden", animate(200))
79
+ ]),
80
+ trigger("openModal", [
81
+ state("in", style({
82
+ "opacity": "0",
83
+ "left": "-50vw"
84
+ })),
85
+ state("hidden", style({
86
+ "opacity": "0",
87
+ "left": "-50vw"
88
+ })),
89
+ state("opened", style({
90
+ "opacity": "1",
91
+ "left": "25vw"
92
+ })),
93
+ transition("hidden => opened", animate(500)),
94
+ transition("opened => hidden", animate(300))
95
+ ])
96
+ ] }); }
97
+ }
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TimeoutNotificationComponent, decorators: [{
99
+ type: Component,
100
100
  args: [{ selector: "timeout-notification", template: `
101
101
  <div class="flyout-max" [@openBacksplash]="openState">
102
102
  <div class="modal-dialog" [@openModal]="openState" role="document">
@@ -113,36 +113,36 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
113
113
  </div>
114
114
  </div>
115
115
  </div>
116
- `, animations: [
117
- trigger("openBacksplash", [
118
- state("in", style({
119
- "display": "none"
120
- })),
121
- state("hidden", style({
122
- "display": "none"
123
- })),
124
- state("opened", style({
125
- "display": "inherit"
126
- })),
127
- transition("hidden => opened", animate(100)),
128
- transition("opened => hidden", animate(200))
129
- ]),
130
- trigger("openModal", [
131
- state("in", style({
132
- "opacity": "0",
133
- "left": "-50vw"
134
- })),
135
- state("hidden", style({
136
- "opacity": "0",
137
- "left": "-50vw"
138
- })),
139
- state("opened", style({
140
- "opacity": "1",
141
- "left": "25vw"
142
- })),
143
- transition("hidden => opened", animate(500)),
144
- transition("opened => hidden", animate(300))
145
- ])
146
- ], styles: [".flyout-max{position:fixed;z-index:9999;top:0;bottom:0;background-color:#0006;width:100vw}.modal-dialog{position:fixed;max-width:50vw;min-width:50vw;left:-50vw;top:25vw;margin:0;background-color:#fff;border:black 1px solid;border-left:none;border-radius:20px;pointer-events:all}.modal-body{width:100%;display:inline-block}.modal-body-left{display:inline-block;overflow-y:auto;overflow-x:hidden;min-height:300px;max-height:300px}.modal-body-right{width:70%;vertical-align:top;padding-left:15px;border-left:black 1px solid;margin-left:15px;display:inline-block;overflow-y:auto;min-height:300px;max-height:300px}\n"] }]
147
- }], ctorParameters: function () { return [{ type: i1.AuthenticationService }]; } });
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timeout-notification.component.js","sourceRoot":"","sources":["../../../projects/authentication/src/timeout-notification.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\n * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary\r\n */\r\nimport {Component} from \"@angular/core\";\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\n\r\nimport {Observable, Subscription, timer} from \"rxjs\";\r\nimport {map, takeWhile} from \"rxjs/operators\";\r\n\r\nimport {AuthenticationService} from \"./authentication.service\";\r\n\r\n@Component({\r\n  selector: \"timeout-notification\",\r\n  template: `\r\n    <div class=\"flyout-max\" [@openBacksplash]=\"openState\">\r\n      <div class=\"modal-dialog\" [@openModal]=\"openState\" role=\"document\">\r\n        <div class=\"modal-header\">\r\n          <h4 class=\"modal-title\">Your Session Is About To Expire</h4>\r\n        </div>\r\n        <div class=\"modal-body\">\r\n          <p>For your security, your session is about to automatically time out in the next <b>{{seconds | async}}</b> seconds. Would you like to stay signed in?</p>\r\n        </div>\r\n        <div class=\"modal-footer\">\r\n          <ng-container>\r\n            <button id=\"updateBtn\" type=\"button\" class=\"btn btn-secondary\" (click)=\"click()\">Yes, Keep me signed in</button>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  animations: [\r\n    trigger(\"openBacksplash\",\r\n      [\r\n        state(\"in\", style({\r\n          \"display\": \"none\"\r\n        })),\r\n        state(\"hidden\", style({\r\n          \"display\": \"none\"\r\n        })),\r\n        state(\"opened\", style({\r\n          \"display\": \"inherit\"\r\n        })),\r\n        transition(\"hidden => opened\", animate(100)),\r\n        transition(\"opened => hidden\", animate(200))\r\n      ]\r\n    ),\r\n    trigger(\"openModal\",\r\n      [\r\n        state(\"in\", style({\r\n          \"opacity\": \"0\",\r\n          \"left\": \"-50vw\"\r\n        })),\r\n        state(\"hidden\", style({\r\n          \"opacity\": \"0\",\r\n          \"left\": \"-50vw\"\r\n        })),\r\n        state(\"opened\", style({\r\n          \"opacity\": \"1\",\r\n          \"left\": \"25vw\"\r\n        })),\r\n        transition(\"hidden => opened\", animate(500)),\r\n        transition(\"opened => hidden\", animate(300))\r\n      ]\r\n    )\r\n  ],\r\n  styles: [`\r\n\r\n    .flyout-max {\r\n      position: fixed;\r\n      z-index: 9999;\r\n      top: 0;\r\n      bottom: 0;\r\n      background-color: rgba(0, 0, 0, 0.4);\r\n      width: 100vw;\r\n    }\r\n    \r\n    .modal-dialog {\r\n      position: fixed;\r\n      max-width: 50vw;\r\n      min-width: 50vw;\r\n      left: -50vw;\r\n      top: 25vw;\r\n      margin: 0;\r\n      background-color: white;\r\n      border: black 1px solid;\r\n      border-left: none;\r\n      border-top-right-radius: 20px;\r\n      border-bottom-right-radius: 20px;\r\n      border-top-left-radius: 20px;\r\n      border-bottom-left-radius: 20px;\r\n      pointer-events: all;\r\n    }\r\n    \r\n    .modal-body {\r\n      width: 100%;\r\n      display: inline-block;\r\n    }\r\n    \r\n    .modal-body-left {\r\n      display: inline-block;\r\n      overflow-y: auto;\r\n      overflow-x: hidden;\r\n      min-height: 300px;\r\n      max-height: 300px;\r\n    }\r\n    \r\n    .modal-body-right {\r\n      width: 70%;\r\n      vertical-align: top;\r\n      padding-left: 15px;\r\n      border-left: black 1px solid;\r\n      margin-left: 15px;\r\n      display: inline-block;\r\n      overflow-y: auto;\r\n      min-height: 300px;\r\n      max-height: 300px;\r\n    }\r\n  `]\r\n})\r\nexport class TimeoutNotificationComponent {\r\n  public seconds: Observable<number>;\r\n  public openState: string = \"hidden\";\r\n\r\n  private subscription: Subscription;\r\n\r\n  constructor(private authenticationService: AuthenticationService) {\r\n    authenticationService.isAboutToTimeOut().subscribe((isAboutToTimeOut) => {\r\n\r\n      if (isAboutToTimeOut) {\r\n        this.openState = \"opened\";\r\n        this.startCountdown();\r\n      } else {\r\n        this.openState = \"hidden\";\r\n        //If something changed mid-timeout, cancel the timeout/logout.\r\n        if (this.subscription != null && !this.subscription.closed) {\r\n          this.subscription.unsubscribe();\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  startCountdown(): void {\r\n    this.seconds = timer(0, 1000)\r\n      .pipe(\r\n        map(() => {\r\n          const elapsed: number = Math.round((Date.now() - this.authenticationService.getTimeoutStart()) / 1000);\r\n          return this.authenticationService.userCountdownSeconds - elapsed;\r\n        }),\r\n        // The true argument emits the final value that completed the observable\r\n        takeWhile((value) => value > 0, true),\r\n      );\r\n\r\n    this.subscription = this.seconds.subscribe((value) => {\r\n       if (value < 1) {\r\n         this.subscription.unsubscribe();\r\n         this.authenticationService.logout(true);\r\n       }\r\n    });\r\n  }\r\n\r\n  click(): void {\r\n    this.subscription.unsubscribe();\r\n    this.authenticationService.updateUserActivity();\r\n  }\r\n}\r\n"]}
116
+ `, animations: [
117
+ trigger("openBacksplash", [
118
+ state("in", style({
119
+ "display": "none"
120
+ })),
121
+ state("hidden", style({
122
+ "display": "none"
123
+ })),
124
+ state("opened", style({
125
+ "display": "inherit"
126
+ })),
127
+ transition("hidden => opened", animate(100)),
128
+ transition("opened => hidden", animate(200))
129
+ ]),
130
+ trigger("openModal", [
131
+ state("in", style({
132
+ "opacity": "0",
133
+ "left": "-50vw"
134
+ })),
135
+ state("hidden", style({
136
+ "opacity": "0",
137
+ "left": "-50vw"
138
+ })),
139
+ state("opened", style({
140
+ "opacity": "1",
141
+ "left": "25vw"
142
+ })),
143
+ transition("hidden => opened", animate(500)),
144
+ transition("opened => hidden", animate(300))
145
+ ])
146
+ ], styles: [".flyout-max{position:fixed;z-index:9999;top:0;bottom:0;background-color:#0006;width:100vw}.modal-dialog{position:fixed;max-width:50vw;min-width:50vw;left:-50vw;top:25vw;margin:0;background-color:#fff;border:black 1px solid;border-left:none;border-radius:20px;pointer-events:all}.modal-body{width:100%;display:inline-block}.modal-body-left{display:inline-block;overflow-y:auto;overflow-x:hidden;min-height:300px;max-height:300px}.modal-body-right{width:70%;vertical-align:top;padding-left:15px;border-left:black 1px solid;margin-left:15px;display:inline-block;overflow-y:auto;min-height:300px;max-height:300px}\n"] }]
147
+ }], ctorParameters: () => [{ type: i1.AuthenticationService }] });
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timeout-notification.component.js","sourceRoot":"","sources":["../../../projects/authentication/src/timeout-notification.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\n * Copyright (c) 2016 Huntsman Cancer Institute at the University of Utah, Confidential and Proprietary\r\n */\r\nimport {Component} from \"@angular/core\";\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\n\r\nimport {Observable, Subscription, timer} from \"rxjs\";\r\nimport {map, takeWhile} from \"rxjs/operators\";\r\n\r\nimport {AuthenticationService} from \"./authentication.service\";\r\n\r\n@Component({\r\n  selector: \"timeout-notification\",\r\n  template: `\r\n    <div class=\"flyout-max\" [@openBacksplash]=\"openState\">\r\n      <div class=\"modal-dialog\" [@openModal]=\"openState\" role=\"document\">\r\n        <div class=\"modal-header\">\r\n          <h4 class=\"modal-title\">Your Session Is About To Expire</h4>\r\n        </div>\r\n        <div class=\"modal-body\">\r\n          <p>For your security, your session is about to automatically time out in the next <b>{{seconds | async}}</b> seconds. Would you like to stay signed in?</p>\r\n        </div>\r\n        <div class=\"modal-footer\">\r\n          <ng-container>\r\n            <button id=\"updateBtn\" type=\"button\" class=\"btn btn-secondary\" (click)=\"click()\">Yes, Keep me signed in</button>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  animations: [\r\n    trigger(\"openBacksplash\",\r\n      [\r\n        state(\"in\", style({\r\n          \"display\": \"none\"\r\n        })),\r\n        state(\"hidden\", style({\r\n          \"display\": \"none\"\r\n        })),\r\n        state(\"opened\", style({\r\n          \"display\": \"inherit\"\r\n        })),\r\n        transition(\"hidden => opened\", animate(100)),\r\n        transition(\"opened => hidden\", animate(200))\r\n      ]\r\n    ),\r\n    trigger(\"openModal\",\r\n      [\r\n        state(\"in\", style({\r\n          \"opacity\": \"0\",\r\n          \"left\": \"-50vw\"\r\n        })),\r\n        state(\"hidden\", style({\r\n          \"opacity\": \"0\",\r\n          \"left\": \"-50vw\"\r\n        })),\r\n        state(\"opened\", style({\r\n          \"opacity\": \"1\",\r\n          \"left\": \"25vw\"\r\n        })),\r\n        transition(\"hidden => opened\", animate(500)),\r\n        transition(\"opened => hidden\", animate(300))\r\n      ]\r\n    )\r\n  ],\r\n  styles: [`\r\n\r\n    .flyout-max {\r\n      position: fixed;\r\n      z-index: 9999;\r\n      top: 0;\r\n      bottom: 0;\r\n      background-color: rgba(0, 0, 0, 0.4);\r\n      width: 100vw;\r\n    }\r\n    \r\n    .modal-dialog {\r\n      position: fixed;\r\n      max-width: 50vw;\r\n      min-width: 50vw;\r\n      left: -50vw;\r\n      top: 25vw;\r\n      margin: 0;\r\n      background-color: white;\r\n      border: black 1px solid;\r\n      border-left: none;\r\n      border-top-right-radius: 20px;\r\n      border-bottom-right-radius: 20px;\r\n      border-top-left-radius: 20px;\r\n      border-bottom-left-radius: 20px;\r\n      pointer-events: all;\r\n    }\r\n    \r\n    .modal-body {\r\n      width: 100%;\r\n      display: inline-block;\r\n    }\r\n    \r\n    .modal-body-left {\r\n      display: inline-block;\r\n      overflow-y: auto;\r\n      overflow-x: hidden;\r\n      min-height: 300px;\r\n      max-height: 300px;\r\n    }\r\n    \r\n    .modal-body-right {\r\n      width: 70%;\r\n      vertical-align: top;\r\n      padding-left: 15px;\r\n      border-left: black 1px solid;\r\n      margin-left: 15px;\r\n      display: inline-block;\r\n      overflow-y: auto;\r\n      min-height: 300px;\r\n      max-height: 300px;\r\n    }\r\n  `]\r\n})\r\nexport class TimeoutNotificationComponent {\r\n  public seconds: Observable<number>;\r\n  public openState: string = \"hidden\";\r\n\r\n  private subscription: Subscription;\r\n\r\n  constructor(private authenticationService: AuthenticationService) {\r\n    authenticationService.isAboutToTimeOut().subscribe((isAboutToTimeOut) => {\r\n\r\n      if (isAboutToTimeOut) {\r\n        this.openState = \"opened\";\r\n        this.startCountdown();\r\n      } else {\r\n        this.openState = \"hidden\";\r\n        //If something changed mid-timeout, cancel the timeout/logout.\r\n        if (this.subscription != null && !this.subscription.closed) {\r\n          this.subscription.unsubscribe();\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  startCountdown(): void {\r\n    this.seconds = timer(0, 1000)\r\n      .pipe(\r\n        map(() => {\r\n          const elapsed: number = Math.round((Date.now() - this.authenticationService.getTimeoutStart()) / 1000);\r\n          return this.authenticationService.userCountdownSeconds - elapsed;\r\n        }),\r\n        // The true argument emits the final value that completed the observable\r\n        takeWhile((value) => value > 0, true),\r\n      );\r\n\r\n    this.subscription = this.seconds.subscribe((value) => {\r\n       if (value < 1) {\r\n         this.subscription.unsubscribe();\r\n         this.authenticationService.logout(true);\r\n       }\r\n    });\r\n  }\r\n\r\n  click(): void {\r\n    this.subscription.unsubscribe();\r\n    this.authenticationService.updateUserActivity();\r\n  }\r\n}\r\n"]}