ngx-histaff-alpha 1.9.1 → 1.9.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/app/enum/EnumIconClass.mjs +3 -3
- package/esm2022/lib/app/libraries/animated-text/animated-text/animated-text.component.mjs +23 -24
- package/fesm2022/ngx-histaff-alpha.mjs +24 -25
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/enum/EnumIconClass.d.ts +2 -2
- package/lib/app/libraries/animated-text/animated-text/animated-text.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -44,7 +44,7 @@ export var EnumIconClass;
|
|
|
44
44
|
EnumIconClass["CUSTOM_REVERT"] = "custom_revert";
|
|
45
45
|
EnumIconClass["CUSTOM_RECRUIT"] = "custom_recruit";
|
|
46
46
|
EnumIconClass["FEATHER_INFORMATION"] = "feather-info";
|
|
47
|
-
EnumIconClass["HEADER_ICON_CHANGE_MANAGER"] = "
|
|
48
|
-
EnumIconClass["HEADER_ICON_VACANCY_FILTER"] = "
|
|
47
|
+
EnumIconClass["HEADER_ICON_CHANGE_MANAGER"] = "header-icon-change-manager";
|
|
48
|
+
EnumIconClass["HEADER_ICON_VACANCY_FILTER"] = "header-icon-vacancy-filter";
|
|
49
49
|
})(EnumIconClass || (EnumIconClass = {}));
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRW51bUljb25DbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1oaXN0YWZmLWFscGhhL3NyYy9saWIvYXBwL2VudW0vRW51bUljb25DbGFzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxhQStDWDtBQS9DRCxXQUFZLGFBQWE7SUFDckIsNkNBQTRCLENBQUE7SUFDNUIsOENBQTZCLENBQUE7SUFDN0IsOENBQTZCLENBQUE7SUFDN0Isb0RBQW1DLENBQUE7SUFDbkMsc0RBQXFDLENBQUE7SUFDckMsNkNBQTRCLENBQUE7SUFDNUIsb0RBQW1DLENBQUE7SUFDbkMsOENBQTZCLENBQUE7SUFDN0IsNkNBQTRCLENBQUE7SUFDNUIsOENBQTZCLENBQUE7SUFDN0IsbURBQWtDLENBQUE7SUFDbEMsbURBQWtDLENBQUE7SUFDbEMsdURBQXNDLENBQUE7SUFDdEMsdURBQXNDLENBQUE7SUFDdEMsaURBQWdDLENBQUE7SUFDaEMsbUVBQWtELENBQUE7SUFDbEQsOERBQTZDLENBQUE7SUFDN0MsNERBQTJDLENBQUE7SUFDM0Msd0VBQXVELENBQUE7SUFDdkQsbUVBQWtELENBQUE7SUFDbEQsdURBQXNDLENBQUE7SUFDdEMsc0NBQXFCLENBQUE7SUFDckIscUNBQW9CLENBQUE7SUFDcEIsa0RBQWlDLENBQUE7SUFDakMsdURBQXNDLENBQUE7SUFDdEMsMERBQXlDLENBQUE7SUFDekMsc0RBQXFDLENBQUE7SUFDckMsOENBQTZCLENBQUE7SUFDN0Isa0RBQWlDLENBQUE7SUFDakMsOERBQTZDLENBQUE7SUFDN0MsOERBQTZDLENBQUE7SUFDN0Msb0RBQW1DLENBQUE7SUFDbkMsOENBQTZCLENBQUE7SUFDN0Isb0RBQW1DLENBQUE7SUFDbkMsa0RBQWlDLENBQUE7SUFDakMsbURBQWtDLENBQUE7SUFDbEMsdURBQXNDLENBQUE7SUFDdEMsd0RBQXVDLENBQUE7SUFDdkMsb0RBQW1DLENBQUE7SUFDbkMsa0RBQWlDLENBQUE7SUFDakMsMkVBQTBELENBQUE7SUFDMUQsZ0RBQStCLENBQUE7SUFDL0Isa0RBQWlDLENBQUE7SUFDakMscURBQW9DLENBQUE7SUFDcEMsMEVBQXlELENBQUE7SUFDekQsMEVBQXlELENBQUE7QUFDN0QsQ0FBQyxFQS9DVyxhQUFhLEtBQWIsYUFBYSxRQStDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBFbnVtSWNvbkNsYXNzIHtcclxuICAgIEZFQVRIRVJfVklFVyA9IFwiZmVhdGhlci1leWVcIixcclxuICAgIEZFQVRIRVJfVVNFUiA9IFwiZmVhdGhlci11c2VyXCIsXHJcbiAgICBGRUFUSEVSX0xPQ0sgPSBcImZlYXRoZXItbG9ja1wiLFxyXG4gICAgRkVBVEhFUl9MT0dfT1VUID0gXCJmZWF0aGVyLWxvZy1vdXRcIixcclxuICAgIEZFQVRIRVJfU0VUVElOR1MgPSBcImZlYXRoZXItc2V0dGluZ3NcIixcclxuICAgIEZFQVRIRVJfQUREID0gXCJmZWF0aGVyLXBsdXNcIixcclxuICAgIEZFQVRIRVJfRURJVCA9IFwiY3VzdG9tLWJ1dHRvbi1lZGl0XCIsXHJcbiAgICBGRUFUSEVSX1NBVkUgPSBcImZlYXRoZXItc2F2ZVwiLFxyXG4gICAgRkVBVEhFUl9DQU5DRUwgPSBcImZlYXRoZXIteFwiLFxyXG4gICAgRkVBVEhFUl9DT1BZID0gXCJmZWF0aGVyLWNvcHlcIixcclxuICAgIEZFQVRIRVJfREVMRVRFID0gXCJmZWF0aGVyLXRyYXNoLTJcIixcclxuICAgIEZFQVRIRVJfQVBQUk9WRSA9IFwiY3VzdG9tLWFwcHJvdmVcIixcclxuICAgIEZFQVRIRVJfVU5BUFBST1ZFID0gXCJjdXN0b20tdW5hcHByb3ZlXCIsXHJcbiAgICBGRUFUSEVSX0NBTENVTEFURSA9IFwiY3VzdG9tLWNhbGN1bGF0ZVwiLFxyXG4gICAgRkVBVEhFUl9VUERBVEUgPSBcImN1c3RvbS11cGRhdGVcIixcclxuICAgIEZFQVRIRVJfUEVORElOR19BUFBST1ZFID0gXCJjdXN0b20tcGVuZGluZy1hcHByb3ZlXCIsXHJcbiAgICBDVVNUT01fSEVBREVSX0hBTkRMRSA9IFwiY3VzdG9tLWhlYWRlci1oYW5kbGVcIixcclxuICAgIENVU1RPTV9IRUFERVJfUkVTRVQgPSBcImN1c3RvbS1oZWFkZXItcmVzZXRcIixcclxuICAgIENVU1RPTV9IRUFERVJfU1lOQ0hST05PVVMgPSBcImN1c3RvbS1oZWFkZXItc3luY2hyb25vdXNcIixcclxuICAgIENVU1RPTV9IRUFERVJfVVBFUk1JU1NJT05fREVMRVRFID0gXCJmZWF0aGVyLXRyYXNoXCIsXHJcbiAgICBGRUFUSEVSX1JFSkVDVCA9IFwiZmVhdGhlci10aHVtYnMtZG93blwiLFxyXG4gICAgRkxBR19PRl9WSUVUTkFNRSA9IFwiXCIsXHJcbiAgICBGTEFHX09GX0VOR0xBTkQgPSBcIlwiLFxyXG4gICAgRkVBVEhFUl9QUklOVCA9IFwiZmVhdGhlci1wcmludGVyXCIsXHJcbiAgICBGRUFUSEVSX1BSSU5UXzJDID0gXCJjdXN0b20tcHJpbnRlcl8yY1wiLFxyXG4gICAgRkVBVEhFUl9ET1dOTE9BRCA9IFwiY3VzdG9tLWRvd25sb2FkLWZpbGVcIixcclxuICAgIEZFQVRIRVJfVVBMT0FEID0gXCJjdXN0b20tdXBsb2FkLWZpbGVcIixcclxuICAgIENVU1RPTV9DSEVDSyA9ICdjdXN0b20tY2hlY2snLFxyXG4gICAgQ1VTVE9NX1VOQ0hFQ0sgPSAnY3VzdG9tLXVuY2hlY2snLFxyXG4gICAgQ1VTVE9NX0RPV05MT0FEX0VYRUwgPSAnY3VzdG9tLWRvd25sb2FkLWV4ZWwnLFxyXG4gICAgRkVBVEhFUl9NSU5VU19DSVJDTEUgPSAnZmVhdGhlci1taW51cy1jaXJjbGUnLFxyXG4gICAgRkVBVEhFUl9EUk9QID0gJ2ZlYXRoZXItYXJyb3ctZG93bicsXHJcbiAgICBGRUFUSEVSX0ZJTEUgPSAnZmVhdGhlci1maWxlJyxcclxuICAgIEZFQVRIRVJfU1dBUCA9ICdmZWF0aGVyLXJlZnJlc2gtY3cnLFxyXG4gICAgRkVBVEhFUl9VTkxPQ0sgPSAnZmVhdGhlci11bmxvY2snLFxyXG4gICAgRkVBVEhFUl9DT05GSVJNID0gJ2N1c3RvbS1jb25maXJtJyxcclxuICAgIEZFQVRIRVJfVU5DT05GSVJNID0gJ2N1c3RvbS11bmNvbmZpcm0nLFxyXG4gICAgRkVBVEhFUl9MSVFVSURBVEUgPSBcImZlYXRoZXItbGlxdWlkYXRlXCIsXHJcbiAgICBDVVNUT01fVFJBTlNGRVIgPSAnY3VzdG9tX3RyYW5zZmVyJyxcclxuICAgIENVU1RPTV9DTE9OSU5HID0gJ2N1c3RvbV9jbG9uaW5nJyxcclxuICAgIENVU1RPTV9QT1NJVElPTl9UUkFOU0ZFUiA9ICdjdXN0b21fcG9zaXRpb25fdHJhbnNmZXJfc2F2ZScsXHJcbiAgICBDVVNUT01fUkVWRVJUID0gJ2N1c3RvbV9yZXZlcnQnLFxyXG4gICAgQ1VTVE9NX1JFQ1JVSVQgPSAnY3VzdG9tX3JlY3J1aXQnLFxyXG4gICAgRkVBVEhFUl9JTkZPUk1BVElPTiA9ICdmZWF0aGVyLWluZm8nLFxyXG4gICAgSEVBREVSX0lDT05fQ0hBTkdFX01BTkFHRVIgPSAnaGVhZGVyLWljb24tY2hhbmdlLW1hbmFnZXInLFxyXG4gICAgSEVBREVSX0lDT05fVkFDQU5DWV9GSUxURVIgPSAnaGVhZGVyLWljb24tdmFjYW5jeS1maWx0ZXInLFxyXG59Il19
|
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
import { Component, ViewChild } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
+
import * as d3 from 'd3';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "../animated-text.service";
|
|
6
|
+
const d3_select = d3.select;
|
|
7
|
+
const d3_shuffle = d3.shuffle;
|
|
5
8
|
export class AnimatedTextComponent {
|
|
6
9
|
constructor(animatedTextService) {
|
|
7
10
|
this.animatedTextService = animatedTextService;
|
|
@@ -19,15 +22,12 @@ export class AnimatedTextComponent {
|
|
|
19
22
|
}));
|
|
20
23
|
}
|
|
21
24
|
ngAfterViewInit() {
|
|
22
|
-
/*
|
|
23
25
|
this.svg = d3_select(this.letters.nativeElement).append('svg')
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
26
|
+
.attr('width', this.WIDTH)
|
|
27
|
+
.attr('height', this.HEIGHT)
|
|
28
|
+
.append('g')
|
|
29
|
+
.attr('transform', 'translate(0,' + (this.HEIGHT / 2) + ')');
|
|
29
30
|
this.loop();
|
|
30
|
-
*/
|
|
31
31
|
}
|
|
32
32
|
update(data) {
|
|
33
33
|
const text = this.svg.selectAll('text').data(data, (d) => d.index);
|
|
@@ -41,26 +41,25 @@ export class AnimatedTextComponent {
|
|
|
41
41
|
.transition().duration(1000)
|
|
42
42
|
.attr('x', (d, _) => this.LETTER_WIDTH * d.pos);
|
|
43
43
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
this.update(this.data);
|
|
48
|
-
setTimeout(() => {
|
|
49
|
-
this.data = d3_shuffle(this.data).map((d: ILetterItem, i: number) => {
|
|
50
|
-
d.pos = i;
|
|
51
|
-
return d;
|
|
52
|
-
});
|
|
44
|
+
loop() {
|
|
45
|
+
if (!!!this.allowLoop)
|
|
46
|
+
return;
|
|
53
47
|
this.update(this.data);
|
|
54
48
|
setTimeout(() => {
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
49
|
+
this.data = d3_shuffle(this.data).map((d, i) => {
|
|
50
|
+
d.pos = i;
|
|
51
|
+
return d;
|
|
52
|
+
});
|
|
53
|
+
this.update(this.data);
|
|
54
|
+
setTimeout(() => {
|
|
55
|
+
this.data = this.data.map((d, _) => {
|
|
56
|
+
d.pos = d.index;
|
|
57
|
+
return d;
|
|
58
|
+
});
|
|
59
|
+
this.loop();
|
|
60
|
+
}, 2000);
|
|
60
61
|
}, 2000);
|
|
61
|
-
}, 2000);
|
|
62
62
|
}
|
|
63
|
-
*/
|
|
64
63
|
ngOnDestroy() {
|
|
65
64
|
this.allowLoop = false;
|
|
66
65
|
this.subscriptions.map(x => x?.unsubscribe());
|
|
@@ -75,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
75
74
|
type: ViewChild,
|
|
76
75
|
args: ['letters']
|
|
77
76
|
}] } });
|
|
78
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-text.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/animated-text/animated-text/animated-text.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/animated-text/animated-text/animated-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, ViewChild, ElementRef, OnDestroy } from '@angular/core';\r\nimport { AnimatedTextService } from '../animated-text.service';\r\nimport { Subscription } from 'rxjs';\r\nimport { CommonModule } from '@angular/common';\r\n\r\nimport * as d3 from 'd3';\r\n\r\nconst d3_select = d3.select;\r\nconst d3_shuffle = d3.shuffle;\r\n\r\n\r\ninterface ILetterItem {\r\n  letter: string;\r\n  pos: number;\r\n  index: number;\r\n}\r\n\r\n@Component({\r\n  selector: 'app-animated-text',\r\n  standalone: true,\r\n  imports: [CommonModule],\r\n  templateUrl: './animated-text.component.html',\r\n  styleUrls: ['./animated-text.component.scss']\r\n})\r\nexport class AnimatedTextComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @ViewChild('letters') letters!: ElementRef;\r\n\r\n  subscriptions: Subscription[] = [];\r\n\r\n  data!: ILetterItem[];\r\n  allowLoop: boolean = true;\r\n\r\n  LETTER_WIDTH: number = 22;\r\n  WIDTH!: number;\r\n  HEIGHT: number = 80;\r\n\r\n  svg!: any;\r\n\r\n  constructor(private animatedTextService: AnimatedTextService) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    this.subscriptions.push(\r\n      this.animatedTextService.text$.subscribe(newText => {\r\n        const newData: ILetterItem[] = [];\r\n        newText.split('').map((x, i) => newData.push({ letter: x, pos: i, index: i }))\r\n        this.data = newData;\r\n        this.WIDTH = this.LETTER_WIDTH * this.data.length;\r\n      })\r\n    );\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    \r\n    this.svg = d3_select(this.letters.nativeElement).append('svg')\r\n      .attr('width', this.WIDTH)\r\n      .attr('height', this.HEIGHT)\r\n      .append('g')\r\n      .attr('transform', 'translate(0,' + (this.HEIGHT / 2) + ')');\r\n\r\n    this.loop();\r\n    \r\n  }\r\n\r\n  update(data: ILetterItem[]): void {\r\n    const text = this.svg.selectAll('text').data(data, (d: ILetterItem) => d.index);\r\n    text.enter().append('text')\r\n      .attr('fill', (d: ILetterItem) => ['!', '?', '.'].includes(d.letter)  ? 'tomato' : '#FFFFFF')\r\n      .attr('x', (d: ILetterItem, _: number) => this.LETTER_WIDTH * d.pos)\r\n      .style('font-size', '40px')\r\n      .style('font-family', 'monospace')\r\n      .text((d: ILetterItem) => d.letter)\r\n      .merge(text)\r\n      .transition().duration(1000)\r\n      .attr('x', (d: ILetterItem, _: number) => this.LETTER_WIDTH * d.pos);\r\n  }\r\n\r\n  \r\n  loop(): void {\r\n    if (!!!this.allowLoop) return;\r\n    this.update(this.data);\r\n    setTimeout(() => {\r\n      this.data = d3_shuffle(this.data).map((d: ILetterItem, i: number) => {\r\n        d.pos = i;\r\n        return d;\r\n      });\r\n      this.update(this.data);\r\n      setTimeout(() => {\r\n        this.data = this.data.map((d: ILetterItem, _: number) => {\r\n          d.pos = d.index;\r\n          return d;\r\n        });\r\n        this.loop();\r\n      }, 2000);\r\n    }, 2000);\r\n  }\r\n  \r\n\r\n  ngOnDestroy(): void {\r\n    this.allowLoop = false;\r\n    this.subscriptions.map(x => x?.unsubscribe());\r\n  }\r\n\r\n}\r\n","<div #letters></div>\r\n"]}
|
|
@@ -13,6 +13,7 @@ import * as i1$1 from '@angular/router';
|
|
|
13
13
|
import { Router, RouterModule, NavigationStart, NavigationEnd, NavigationCancel, NavigationError } from '@angular/router';
|
|
14
14
|
import * as i1$2 from '@angular/service-worker';
|
|
15
15
|
import { HubConnectionBuilder, LogLevel } from '@microsoft/signalr';
|
|
16
|
+
import * as d3 from 'd3';
|
|
16
17
|
|
|
17
18
|
class NgxHistaffAlphaService {
|
|
18
19
|
constructor() { }
|
|
@@ -571,8 +572,8 @@ var EnumIconClass;
|
|
|
571
572
|
EnumIconClass["CUSTOM_REVERT"] = "custom_revert";
|
|
572
573
|
EnumIconClass["CUSTOM_RECRUIT"] = "custom_recruit";
|
|
573
574
|
EnumIconClass["FEATHER_INFORMATION"] = "feather-info";
|
|
574
|
-
EnumIconClass["HEADER_ICON_CHANGE_MANAGER"] = "
|
|
575
|
-
EnumIconClass["HEADER_ICON_VACANCY_FILTER"] = "
|
|
575
|
+
EnumIconClass["HEADER_ICON_CHANGE_MANAGER"] = "header-icon-change-manager";
|
|
576
|
+
EnumIconClass["HEADER_ICON_VACANCY_FILTER"] = "header-icon-vacancy-filter";
|
|
576
577
|
})(EnumIconClass || (EnumIconClass = {}));
|
|
577
578
|
|
|
578
579
|
var EnumStyleButtonClass;
|
|
@@ -7276,6 +7277,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
7276
7277
|
}]
|
|
7277
7278
|
}], ctorParameters: () => [] });
|
|
7278
7279
|
|
|
7280
|
+
const d3_select = d3.select;
|
|
7281
|
+
const d3_shuffle = d3.shuffle;
|
|
7279
7282
|
class AnimatedTextComponent {
|
|
7280
7283
|
constructor(animatedTextService) {
|
|
7281
7284
|
this.animatedTextService = animatedTextService;
|
|
@@ -7293,15 +7296,12 @@ class AnimatedTextComponent {
|
|
|
7293
7296
|
}));
|
|
7294
7297
|
}
|
|
7295
7298
|
ngAfterViewInit() {
|
|
7296
|
-
/*
|
|
7297
7299
|
this.svg = d3_select(this.letters.nativeElement).append('svg')
|
|
7298
|
-
|
|
7299
|
-
|
|
7300
|
-
|
|
7301
|
-
|
|
7302
|
-
|
|
7300
|
+
.attr('width', this.WIDTH)
|
|
7301
|
+
.attr('height', this.HEIGHT)
|
|
7302
|
+
.append('g')
|
|
7303
|
+
.attr('transform', 'translate(0,' + (this.HEIGHT / 2) + ')');
|
|
7303
7304
|
this.loop();
|
|
7304
|
-
*/
|
|
7305
7305
|
}
|
|
7306
7306
|
update(data) {
|
|
7307
7307
|
const text = this.svg.selectAll('text').data(data, (d) => d.index);
|
|
@@ -7315,26 +7315,25 @@ class AnimatedTextComponent {
|
|
|
7315
7315
|
.transition().duration(1000)
|
|
7316
7316
|
.attr('x', (d, _) => this.LETTER_WIDTH * d.pos);
|
|
7317
7317
|
}
|
|
7318
|
-
|
|
7319
|
-
|
|
7320
|
-
|
|
7321
|
-
this.update(this.data);
|
|
7322
|
-
setTimeout(() => {
|
|
7323
|
-
this.data = d3_shuffle(this.data).map((d: ILetterItem, i: number) => {
|
|
7324
|
-
d.pos = i;
|
|
7325
|
-
return d;
|
|
7326
|
-
});
|
|
7318
|
+
loop() {
|
|
7319
|
+
if (!!!this.allowLoop)
|
|
7320
|
+
return;
|
|
7327
7321
|
this.update(this.data);
|
|
7328
7322
|
setTimeout(() => {
|
|
7329
|
-
|
|
7330
|
-
|
|
7331
|
-
|
|
7332
|
-
|
|
7333
|
-
|
|
7323
|
+
this.data = d3_shuffle(this.data).map((d, i) => {
|
|
7324
|
+
d.pos = i;
|
|
7325
|
+
return d;
|
|
7326
|
+
});
|
|
7327
|
+
this.update(this.data);
|
|
7328
|
+
setTimeout(() => {
|
|
7329
|
+
this.data = this.data.map((d, _) => {
|
|
7330
|
+
d.pos = d.index;
|
|
7331
|
+
return d;
|
|
7332
|
+
});
|
|
7333
|
+
this.loop();
|
|
7334
|
+
}, 2000);
|
|
7334
7335
|
}, 2000);
|
|
7335
|
-
}, 2000);
|
|
7336
7336
|
}
|
|
7337
|
-
*/
|
|
7338
7337
|
ngOnDestroy() {
|
|
7339
7338
|
this.allowLoop = false;
|
|
7340
7339
|
this.subscriptions.map(x => x?.unsubscribe());
|