vc-layout 1.0.55 → 1.0.57
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,4 +1,4 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
2
|
import { ASSETS } from '../../../constants/assets.constants';
|
|
3
3
|
import { BUSINESS_CYCLE_URL } from '../../../constants/business-cycle.constant';
|
|
4
4
|
import { IN_APP_URL } from '../../../constants/app-url.constant';
|
|
@@ -38,22 +38,7 @@ export class HeaderContainerComponent {
|
|
|
38
38
|
}
|
|
39
39
|
ngOnInit() {
|
|
40
40
|
this.checkXmasCapVisibility();
|
|
41
|
-
|
|
42
|
-
setTimeout(() => {
|
|
43
|
-
this.showAnimation = true;
|
|
44
|
-
// Hide after 15 seconds
|
|
45
|
-
setTimeout(() => {
|
|
46
|
-
this.showAnimation = false;
|
|
47
|
-
}, 15000);
|
|
48
|
-
}, 0);
|
|
49
|
-
// Repeated display every 5 minutes
|
|
50
|
-
this.animationInterval = setInterval(() => {
|
|
51
|
-
this.showAnimation = true;
|
|
52
|
-
// Hide the animation after 15 seconds
|
|
53
|
-
setTimeout(() => {
|
|
54
|
-
this.showAnimation = false;
|
|
55
|
-
}, 15000); // Show duration: 15 seconds
|
|
56
|
-
}, 300000); // Repeat every 5 minutes (300,000 ms)
|
|
41
|
+
this.checkSnowFallVisibility();
|
|
57
42
|
}
|
|
58
43
|
ngOnDestroy() {
|
|
59
44
|
// Clear interval to prevent memory leaks
|
|
@@ -76,17 +61,38 @@ export class HeaderContainerComponent {
|
|
|
76
61
|
return currentUrl.includes(url);
|
|
77
62
|
});
|
|
78
63
|
}
|
|
64
|
+
checkSnowFallVisibility() {
|
|
65
|
+
// First-time display after 20 seconds
|
|
66
|
+
setTimeout(() => {
|
|
67
|
+
this.showAnimation = true;
|
|
68
|
+
// Hide after 20 seconds
|
|
69
|
+
setTimeout(() => {
|
|
70
|
+
this.showAnimation = false;
|
|
71
|
+
}, 20000);
|
|
72
|
+
}, 0);
|
|
73
|
+
// Repeated display every 5 minutes
|
|
74
|
+
this.animationInterval = setInterval(() => {
|
|
75
|
+
this.showAnimation = true;
|
|
76
|
+
// Hide the animation after 20 seconds
|
|
77
|
+
setTimeout(() => {
|
|
78
|
+
this.showAnimation = false;
|
|
79
|
+
}, 20000); // Show duration: 20 seconds
|
|
80
|
+
}, 300000); // Repeat every 5 minutes (300,000 ms)
|
|
81
|
+
}
|
|
79
82
|
checkXmasCapVisibility() {
|
|
80
83
|
const today = new Date();
|
|
81
|
-
// December 21 of current year
|
|
82
84
|
const currentYear = today.getFullYear();
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
85
|
+
let startDate, endDate;
|
|
86
|
+
// If today is after December 20, use January 7 of next year as the end date
|
|
87
|
+
if (today.getMonth() === 11 && today.getDate() >= 20) {
|
|
88
|
+
startDate = new Date(currentYear, 11, 20); // December 20 of current year
|
|
89
|
+
endDate = new Date(currentYear + 1, 0, 7, 23, 59, 59); // January 7 of next year
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
// Otherwise, use December 20 of the previous year and January 7 of the current year
|
|
93
|
+
startDate = new Date(currentYear - 1, 11, 20); // December 20 of previous year
|
|
94
|
+
endDate = new Date(currentYear, 0, 7, 23, 59, 59); // January 7 of current year
|
|
95
|
+
}
|
|
90
96
|
// Check if today is within the range
|
|
91
97
|
this.isXmasCapVisible = today >= startDate && today <= endDate;
|
|
92
98
|
}
|
|
@@ -109,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
109
115
|
}], onSearchAction: [{
|
|
110
116
|
type: Output
|
|
111
117
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/vc-layout/src/lib/components/header/header-container/header-container.component.ts","../../../../../../../projects/vc-layout/src/lib/components/header/header-container/header-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { ASSETS } from '../../../constants/assets.constants';\r\nimport { ApiService } from '../../../shared/services/api.service';\r\nimport { BUSINESS_CYCLE_URL } from '../../../constants/business-cycle.constant';\r\nimport { LayoutService } from '../../../shared/services/layout.service';\r\nimport { IN_APP_URL } from '../../../constants/app-url.constant';\r\nimport { ActivatedRoute } from '@angular/router';\r\n\r\n@Component({\r\n  selector: 'vc-header-container',\r\n  templateUrl: './header-container.component.html',\r\n  styleUrls: ['./header-container.component.less'],\r\n})\r\nexport class HeaderContainerComponent {\r\n  ASSETS: any = ASSETS;\r\n  isXmasCapVisible: boolean = false;\r\n  showAnimation: boolean = false;\r\n  private animationInterval: any;\r\n  showBusinessCycle: string[] = BUSINESS_CYCLE_URL;\r\n  currentUrl: string = '';\r\n  defaultURL: string = '';\r\n\r\n  @Input() showSearch: boolean = false;\r\n  @Input() featureFlag: any;\r\n  @Input() isAdvanceSearch: boolean = false;\r\n\r\n  @Output() businessCycleChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() openDialog: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() onSearchAction: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  constructor(\r\n    public apiService: ApiService,\r\n    private layoutService: LayoutService,\r\n    private router: ActivatedRoute\r\n  ) {\r\n    this.currentUrl = window.location.pathname;\r\n    this.defaultURL = this.layoutService.baseUrl + IN_APP_URL.DEFAULT;\r\n    this.onRouterChange();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.checkXmasCapVisibility();\r\n\r\n    // First-time display after 15 seconds\r\n    setTimeout(() => {\r\n      this.showAnimation = true;\r\n\r\n      // Hide after 15 seconds\r\n      setTimeout(() => {\r\n        this.showAnimation = false;\r\n      }, 15000);\r\n    }, 0);\r\n\r\n    // Repeated display every 5 minutes\r\n    this.animationInterval = setInterval(() => {\r\n      this.showAnimation = true;\r\n\r\n      // Hide the animation after 15 seconds\r\n      setTimeout(() => {\r\n        this.showAnimation = false;\r\n      }, 15000); // Show duration: 15 seconds\r\n    }, 300000); // Repeat every 5 minutes (300,000 ms)\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    // Clear interval to prevent memory leaks\r\n    if (this.animationInterval) {\r\n      clearInterval(this.animationInterval);\r\n    }\r\n  }\r\n\r\n  businessCycleChangeHandler(event: any) {\r\n    this.businessCycleChange.emit(event);\r\n  }\r\n\r\n  onRouterChange() {\r\n    this.router.url.subscribe((url) => {\r\n      console.log('url', url);\r\n      this.currentUrl = window.location.pathname;\r\n    });\r\n  }\r\n\r\n  get isBusinessCycleVisible(): boolean {\r\n    const currentUrl = window.location.href;\r\n    return this.showBusinessCycle.some((url) => {\r\n      return currentUrl.includes(url);\r\n    });\r\n  }\r\n\r\n  checkXmasCapVisibility(): void {\r\n    const today = new Date();\r\n\r\n    // December 21 of current year\r\n    const currentYear = today.getFullYear();\r\n    const startDate = new Date(currentYear, 11, 18); // Month is 0-based, so 11 = December\r\n    const endDate = new Date(currentYear, 11, 19, 23, 59, 59); // January 7 of the same year\r\n\r\n    // If it's after December 21, check up to January 7 next year\r\n    // const adjustedEndDate =\r\n    //   today.getMonth() === 11 && today.getDate() >= 17\r\n    //     ? new Date(currentYear + 1, 0, 7) // January 7 of next year\r\n    //     : new Date(currentYear, 0, 7); // January 7 of this year\r\n\r\n    // Check if today is within the range\r\n    this.isXmasCapVisible = today >= startDate && today <= endDate;\r\n  }\r\n}\r\n","<vc-global-alert [feature]=\"featureFlag\"></vc-global-alert>\r\n<div\r\n  class=\"header-container vx-d-flex vx-align-center vx-justify-between vx-pr-3\"\r\n>\r\n  <div id=\"snowfall\" *ngIf=\"isXmasCapVisible\" [class.animate]=\"showAnimation\">\r\n    <div class=\"snow\"></div>\r\n    <div class=\"snow1\"></div>\r\n    <div class=\"snow2\"></div>\r\n  </div>\r\n  <div class=\"header-container-left vx-d-flex vx-align-center\">\r\n    <a\r\n      class=\"product-logo vx-d-flex vx-align-center vx-justify-center vx-mr-3\"\r\n      [arTooltip]=\"'Go to Dashboard'\"\r\n      placement=\"right\"\r\n      type=\"white\"\r\n      delay=\"0\"\r\n      [tooltipMandatory]=\"true\"\r\n      [animate]=\"true\"\r\n      [href]=\"defaultURL\"\r\n    >\r\n      <img\r\n        *ngIf=\"isXmasCapVisible\"\r\n        class=\"xmas-cap\"\r\n        [src]=\"ASSETS.xmas_cap\"\r\n        alt=\"Santa Cap\"\r\n        width=\"20\"\r\n        height=\"20\" />\r\n      <img [src]=\"ASSETS.v_icon\" alt=\"VComply\" width=\"24\" height=\"24\"\r\n    /></a>\r\n    <vc-business-cycle\r\n      *ngIf=\"isBusinessCycleVisible\"\r\n      (businessCycleChange)=\"businessCycleChangeHandler($event)\"\r\n    ></vc-business-cycle>\r\n  </div>\r\n  <div class=\"search-area\">\r\n    <vc-search\r\n      *ngIf=\"showSearch\"\r\n      [isAdvanceSearch]=\"isAdvanceSearch\"\r\n      (onSearchAction)=\"onSearchAction.emit($event)\"\r\n    ></vc-search>\r\n  </div>\r\n  <div class=\"vx-d-flex vx-align-center\">\r\n    <vc-support (openSupport)=\"openDialog.emit('SUPPORT')\"></vc-support>\r\n    <vc-create-workflow\r\n      *ngIf=\"apiService.loggedUserDetail$ | async | checkPermission\"\r\n      (openWorkflow)=\"openDialog.emit('WORKFLOW')\"\r\n    ></vc-create-workflow>\r\n    <vc-queue></vc-queue>\r\n    <vc-user-details\r\n      [userDetails]=\"apiService.loggedUserDetail$ | async\"\r\n      [subscriptionDetails]=\"apiService.subscriptionDetail$ | async\"\r\n    ></vc-user-details>\r\n  </div>\r\n</div>\r\n"]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/vc-layout/src/lib/components/header/header-container/header-container.component.ts","../../../../../../../projects/vc-layout/src/lib/components/header/header-container/header-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport { ASSETS } from '../../../constants/assets.constants';\r\nimport { ApiService } from '../../../shared/services/api.service';\r\nimport { BUSINESS_CYCLE_URL } from '../../../constants/business-cycle.constant';\r\nimport { LayoutService } from '../../../shared/services/layout.service';\r\nimport { IN_APP_URL } from '../../../constants/app-url.constant';\r\nimport { ActivatedRoute } from '@angular/router';\r\n\r\n@Component({\r\n  selector: 'vc-header-container',\r\n  templateUrl: './header-container.component.html',\r\n  styleUrls: ['./header-container.component.less'],\r\n})\r\nexport class HeaderContainerComponent implements OnInit, OnDestroy {\r\n  ASSETS: any = ASSETS;\r\n  isXmasCapVisible: boolean = false;\r\n  showAnimation: boolean = false;\r\n  private animationInterval: any;\r\n  showBusinessCycle: string[] = BUSINESS_CYCLE_URL;\r\n  currentUrl: string = '';\r\n  defaultURL: string = '';\r\n\r\n  @Input() showSearch: boolean = false;\r\n  @Input() featureFlag: any;\r\n  @Input() isAdvanceSearch: boolean = false;\r\n\r\n  @Output() businessCycleChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() openDialog: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() onSearchAction: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  constructor(\r\n    public apiService: ApiService,\r\n    private layoutService: LayoutService,\r\n    private router: ActivatedRoute\r\n  ) {\r\n    this.currentUrl = window.location.pathname;\r\n    this.defaultURL = this.layoutService.baseUrl + IN_APP_URL.DEFAULT;\r\n    this.onRouterChange();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.checkXmasCapVisibility();\r\n    this.checkSnowFallVisibility();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    // Clear interval to prevent memory leaks\r\n    if (this.animationInterval) {\r\n      clearInterval(this.animationInterval);\r\n    }\r\n  }\r\n\r\n  businessCycleChangeHandler(event: any) {\r\n    this.businessCycleChange.emit(event);\r\n  }\r\n\r\n  onRouterChange() {\r\n    this.router.url.subscribe((url) => {\r\n      console.log('url', url);\r\n      this.currentUrl = window.location.pathname;\r\n    });\r\n  }\r\n\r\n  get isBusinessCycleVisible(): boolean {\r\n    const currentUrl = window.location.href;\r\n    return this.showBusinessCycle.some((url) => {\r\n      return currentUrl.includes(url);\r\n    });\r\n  }\r\n\r\n  checkSnowFallVisibility(): void {\r\n    // First-time display after 20 seconds\r\n    setTimeout(() => {\r\n      this.showAnimation = true;\r\n\r\n      // Hide after 20 seconds\r\n      setTimeout(() => {\r\n        this.showAnimation = false;\r\n      }, 20000);\r\n    }, 0);\r\n\r\n    // Repeated display every 5 minutes\r\n    this.animationInterval = setInterval(() => {\r\n      this.showAnimation = true;\r\n\r\n      // Hide the animation after 20 seconds\r\n      setTimeout(() => {\r\n        this.showAnimation = false;\r\n      }, 20000); // Show duration: 20 seconds\r\n    }, 300000); // Repeat every 5 minutes (300,000 ms)\r\n  }\r\n\r\n  checkXmasCapVisibility(): void {\r\n    const today = new Date();\r\n    const currentYear = today.getFullYear();\r\n    let startDate, endDate;\r\n\r\n    // If today is after December 20, use January 7 of next year as the end date\r\n    if (today.getMonth() === 11 && today.getDate() >= 20) {\r\n      startDate = new Date(currentYear, 11, 20); // December 20 of current year\r\n      endDate = new Date(currentYear + 1, 0, 7, 23, 59, 59); // January 7 of next year\r\n    } else {\r\n      // Otherwise, use December 20 of the previous year and January 7 of the current year\r\n      startDate = new Date(currentYear - 1, 11, 20); // December 20 of previous year\r\n      endDate = new Date(currentYear, 0, 7, 23, 59, 59); // January 7 of current year\r\n    }\r\n\r\n    // Check if today is within the range\r\n    this.isXmasCapVisible = today >= startDate && today <= endDate;\r\n  }\r\n}\r\n","<vc-global-alert [feature]=\"featureFlag\"></vc-global-alert>\r\n<div\r\n  class=\"header-container vx-d-flex vx-align-center vx-justify-between vx-pr-3\"\r\n>\r\n  <div id=\"snowfall\" *ngIf=\"isXmasCapVisible\" [class.animate]=\"showAnimation\">\r\n    <div class=\"snow\"></div>\r\n    <div class=\"snow1\"></div>\r\n    <div class=\"snow2\"></div>\r\n  </div>\r\n  <div class=\"header-container-left vx-d-flex vx-align-center\">\r\n    <a\r\n      class=\"product-logo vx-d-flex vx-align-center vx-justify-center vx-mr-3\"\r\n      [arTooltip]=\"'Go to Dashboard'\"\r\n      placement=\"right\"\r\n      type=\"white\"\r\n      delay=\"0\"\r\n      [tooltipMandatory]=\"true\"\r\n      [animate]=\"true\"\r\n      [href]=\"defaultURL\"\r\n    >\r\n      <img\r\n        *ngIf=\"isXmasCapVisible\"\r\n        class=\"xmas-cap\"\r\n        [src]=\"ASSETS.xmas_cap\"\r\n        alt=\"Santa Cap\"\r\n        width=\"20\"\r\n        height=\"20\" />\r\n      <img [src]=\"ASSETS.v_icon\" alt=\"VComply\" width=\"24\" height=\"24\"\r\n    /></a>\r\n    <vc-business-cycle\r\n      *ngIf=\"isBusinessCycleVisible\"\r\n      (businessCycleChange)=\"businessCycleChangeHandler($event)\"\r\n    ></vc-business-cycle>\r\n  </div>\r\n  <div class=\"search-area\">\r\n    <vc-search\r\n      *ngIf=\"showSearch\"\r\n      [isAdvanceSearch]=\"isAdvanceSearch\"\r\n      (onSearchAction)=\"onSearchAction.emit($event)\"\r\n    ></vc-search>\r\n  </div>\r\n  <div class=\"vx-d-flex vx-align-center\">\r\n    <vc-support (openSupport)=\"openDialog.emit('SUPPORT')\"></vc-support>\r\n    <vc-create-workflow\r\n      *ngIf=\"apiService.loggedUserDetail$ | async | checkPermission\"\r\n      (openWorkflow)=\"openDialog.emit('WORKFLOW')\"\r\n    ></vc-create-workflow>\r\n    <vc-queue></vc-queue>\r\n    <vc-user-details\r\n      [userDetails]=\"apiService.loggedUserDetail$ | async\"\r\n      [subscriptionDetails]=\"apiService.subscriptionDetail$ | async\"\r\n    ></vc-user-details>\r\n  </div>\r\n</div>\r\n"]}
|
package/fesm2022/vc-layout.mjs
CHANGED
|
@@ -2207,22 +2207,7 @@ class HeaderContainerComponent {
|
|
|
2207
2207
|
}
|
|
2208
2208
|
ngOnInit() {
|
|
2209
2209
|
this.checkXmasCapVisibility();
|
|
2210
|
-
|
|
2211
|
-
setTimeout(() => {
|
|
2212
|
-
this.showAnimation = true;
|
|
2213
|
-
// Hide after 15 seconds
|
|
2214
|
-
setTimeout(() => {
|
|
2215
|
-
this.showAnimation = false;
|
|
2216
|
-
}, 15000);
|
|
2217
|
-
}, 0);
|
|
2218
|
-
// Repeated display every 5 minutes
|
|
2219
|
-
this.animationInterval = setInterval(() => {
|
|
2220
|
-
this.showAnimation = true;
|
|
2221
|
-
// Hide the animation after 15 seconds
|
|
2222
|
-
setTimeout(() => {
|
|
2223
|
-
this.showAnimation = false;
|
|
2224
|
-
}, 15000); // Show duration: 15 seconds
|
|
2225
|
-
}, 300000); // Repeat every 5 minutes (300,000 ms)
|
|
2210
|
+
this.checkSnowFallVisibility();
|
|
2226
2211
|
}
|
|
2227
2212
|
ngOnDestroy() {
|
|
2228
2213
|
// Clear interval to prevent memory leaks
|
|
@@ -2245,17 +2230,38 @@ class HeaderContainerComponent {
|
|
|
2245
2230
|
return currentUrl.includes(url);
|
|
2246
2231
|
});
|
|
2247
2232
|
}
|
|
2233
|
+
checkSnowFallVisibility() {
|
|
2234
|
+
// First-time display after 20 seconds
|
|
2235
|
+
setTimeout(() => {
|
|
2236
|
+
this.showAnimation = true;
|
|
2237
|
+
// Hide after 20 seconds
|
|
2238
|
+
setTimeout(() => {
|
|
2239
|
+
this.showAnimation = false;
|
|
2240
|
+
}, 20000);
|
|
2241
|
+
}, 0);
|
|
2242
|
+
// Repeated display every 5 minutes
|
|
2243
|
+
this.animationInterval = setInterval(() => {
|
|
2244
|
+
this.showAnimation = true;
|
|
2245
|
+
// Hide the animation after 20 seconds
|
|
2246
|
+
setTimeout(() => {
|
|
2247
|
+
this.showAnimation = false;
|
|
2248
|
+
}, 20000); // Show duration: 20 seconds
|
|
2249
|
+
}, 300000); // Repeat every 5 minutes (300,000 ms)
|
|
2250
|
+
}
|
|
2248
2251
|
checkXmasCapVisibility() {
|
|
2249
2252
|
const today = new Date();
|
|
2250
|
-
// December 21 of current year
|
|
2251
2253
|
const currentYear = today.getFullYear();
|
|
2252
|
-
|
|
2253
|
-
|
|
2254
|
-
|
|
2255
|
-
|
|
2256
|
-
|
|
2257
|
-
|
|
2258
|
-
|
|
2254
|
+
let startDate, endDate;
|
|
2255
|
+
// If today is after December 20, use January 7 of next year as the end date
|
|
2256
|
+
if (today.getMonth() === 11 && today.getDate() >= 20) {
|
|
2257
|
+
startDate = new Date(currentYear, 11, 20); // December 20 of current year
|
|
2258
|
+
endDate = new Date(currentYear + 1, 0, 7, 23, 59, 59); // January 7 of next year
|
|
2259
|
+
}
|
|
2260
|
+
else {
|
|
2261
|
+
// Otherwise, use December 20 of the previous year and January 7 of the current year
|
|
2262
|
+
startDate = new Date(currentYear - 1, 11, 20); // December 20 of previous year
|
|
2263
|
+
endDate = new Date(currentYear, 0, 7, 23, 59, 59); // January 7 of current year
|
|
2264
|
+
}
|
|
2259
2265
|
// Check if today is within the range
|
|
2260
2266
|
this.isXmasCapVisible = today >= startDate && today <= endDate;
|
|
2261
2267
|
}
|