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
- // First-time display after 15 seconds
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
- const startDate = new Date(currentYear, 11, 18); // Month is 0-based, so 11 = December
84
- const endDate = new Date(currentYear, 11, 19, 23, 59, 59); // January 7 of the same year
85
- // If it's after December 21, check up to January 7 next year
86
- // const adjustedEndDate =
87
- // today.getMonth() === 11 && today.getDate() >= 17
88
- // ? new Date(currentYear + 1, 0, 7) // January 7 of next year
89
- // : new Date(currentYear, 0, 7); // January 7 of this year
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"]}
@@ -2207,22 +2207,7 @@ class HeaderContainerComponent {
2207
2207
  }
2208
2208
  ngOnInit() {
2209
2209
  this.checkXmasCapVisibility();
2210
- // First-time display after 15 seconds
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
- const startDate = new Date(currentYear, 11, 18); // Month is 0-based, so 11 = December
2253
- const endDate = new Date(currentYear, 11, 19, 23, 59, 59); // January 7 of the same year
2254
- // If it's after December 21, check up to January 7 next year
2255
- // const adjustedEndDate =
2256
- // today.getMonth() === 11 && today.getDate() >= 17
2257
- // ? new Date(currentYear + 1, 0, 7) // January 7 of next year
2258
- // : new Date(currentYear, 0, 7); // January 7 of this year
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
  }