vc-layout 0.0.1 → 0.0.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/components/global-alert/global-alert/global-alert.component.mjs +180 -8
- package/esm2022/lib/components/header/business-cycle/business-cycle.component.mjs +4 -4
- package/esm2022/lib/components/header/header-container/header-container.component.mjs +27 -6
- package/esm2022/lib/components/header/search/search.component.mjs +2 -2
- package/esm2022/lib/components/product-list/module-list/module-list.component.mjs +33 -7
- package/esm2022/lib/components/product-list/preference-list/preference-list.component.mjs +26 -46
- package/esm2022/lib/components/product-list/product-list-container/product-list-container.component.mjs +2 -2
- package/esm2022/lib/components/product-list/product-list.module.mjs +5 -4
- package/esm2022/lib/constants/alerts.constant.mjs +7 -0
- package/esm2022/lib/constants/app-url.constant.mjs +9 -7
- package/esm2022/lib/constants/assets.constants.mjs +17 -17
- package/esm2022/lib/constants/product-list.constant.mjs +29 -8
- package/esm2022/lib/shared/pipe/get-module-icon.pipe.mjs +22 -0
- package/esm2022/lib/shared/pipe/pipes.module.mjs +21 -4
- package/esm2022/lib/shared/services/business-cycle.service.mjs +3 -5
- package/esm2022/lib/shared/services/layout.service.mjs +2 -1
- package/esm2022/lib/shared/services/product-list.service.mjs +7 -7
- package/fesm2022/vc-layout.mjs +390 -135
- package/fesm2022/vc-layout.mjs.map +1 -1
- package/lib/components/global-alert/global-alert/global-alert.component.d.ts +24 -5
- package/lib/components/header/header-container/header-container.component.d.ts +2 -1
- package/lib/components/product-list/module-list/module-list.component.d.ts +3 -1
- package/lib/components/product-list/preference-list/preference-list.component.d.ts +5 -2
- package/lib/components/product-list/product-list.module.d.ts +2 -1
- package/lib/constants/alerts.constant.d.ts +1 -0
- package/lib/constants/assets.constants.d.ts +1 -30
- package/lib/constants/product-list.constant.d.ts +1 -0
- package/lib/shared/pipe/get-module-icon.pipe.d.ts +7 -0
- package/lib/shared/pipe/pipes.module.d.ts +3 -2
- package/lib/shared/services/layout.service.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,13 +1,185 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { GLOBAL_ALERTS } from '../../../constants/alerts.constant';
|
|
3
|
+
import { IN_APP_URL } from '../../../constants/app-url.constant';
|
|
2
4
|
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../../shared/services/api.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
3
7
|
export class GlobalAlertComponent {
|
|
4
|
-
constructor() {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
+
constructor(apiService) {
|
|
9
|
+
this.apiService = apiService;
|
|
10
|
+
this.activeIndex = 0;
|
|
11
|
+
this.messages = [];
|
|
12
|
+
this.isNotificationVisible = false;
|
|
13
|
+
this.subscriptionStatus = new EventEmitter();
|
|
14
|
+
this.setSubscriptionInfo();
|
|
15
|
+
this.getOrgDetails();
|
|
16
|
+
}
|
|
17
|
+
setSubscriptionInfo() {
|
|
18
|
+
this.apiService.subscriptionDetail$.subscribe((res) => {
|
|
19
|
+
console.log('this.subscriptionData ==>', res);
|
|
20
|
+
if (res) {
|
|
21
|
+
this.subscriptionData = res;
|
|
22
|
+
console.log('this.subscriptionData ==>', this.subscriptionData);
|
|
23
|
+
this.setMessages(this.subscriptionData);
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
getOrgDetails() {
|
|
28
|
+
this.apiService.organizationDetail$.subscribe((res) => {
|
|
29
|
+
if (res) {
|
|
30
|
+
this.setMailAlert(res);
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
setMessages(subscriptionData) {
|
|
35
|
+
const messages = [];
|
|
36
|
+
this.activeIndex = 0;
|
|
37
|
+
if (subscriptionData) {
|
|
38
|
+
const { trial_flag, no_of_days_left, after_expired_days_allow, no_of_days_for_password_expire, } = subscriptionData;
|
|
39
|
+
if (trial_flag && no_of_days_left <= 0) {
|
|
40
|
+
messages.push({
|
|
41
|
+
message: GLOBAL_ALERTS.trialUserExpired + GLOBAL_ALERTS.contactUs,
|
|
42
|
+
class: 'HIGH',
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
else if (no_of_days_left > 0 && no_of_days_left <= 30) {
|
|
46
|
+
messages.push({
|
|
47
|
+
message: `YOUR SUBSCRIPTION EXPIRES IN ${no_of_days_left} DAYS. ${GLOBAL_ALERTS.contactUs}`,
|
|
48
|
+
class: no_of_days_left <= 10 ? 'HIGH' : 'MEDIUM',
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
else if (no_of_days_left <= 0) {
|
|
52
|
+
messages.push({
|
|
53
|
+
message: `SUBSCRIPTION EXPIRED: YOU WILL NOT BE ABLE TO LOGIN TO YOUR ACCOUNT AFTER ${after_expired_days_allow} DAYS. ${GLOBAL_ALERTS.contactUs}`,
|
|
54
|
+
class: 'HIGH',
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
if (no_of_days_for_password_expire < 1) {
|
|
58
|
+
messages.push({
|
|
59
|
+
message: `YOUR PASSWORD HAS EXPIRED. PLEASE <a href="${this.getPasswordResetUrl()}" target="_blank">CLICK HERE</a> TO RESET YOUR PASSWORD.`,
|
|
60
|
+
class: 'HIGH',
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
else if (no_of_days_for_password_expire < 30) {
|
|
64
|
+
messages.push({
|
|
65
|
+
message: `YOUR PASSWORD IS GOING TO EXPIRE IN ${no_of_days_for_password_expire} DAYS. <a href="${this.getPasswordResetUrl()}" target="_blank">CLICK HERE</a> TO RESET YOUR PASSWORD.`,
|
|
66
|
+
class: 'MEDIUM',
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
this.messages = messages;
|
|
71
|
+
this.isNotificationVisible = this.messages.length > 0;
|
|
72
|
+
this.subscriptionStatus.emit(this.isNotificationVisible);
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* If the response is true, then push the message to the array. If the response is false, then remove
|
|
76
|
+
* the message from the array.
|
|
77
|
+
* </code>
|
|
78
|
+
* @param {any} res - any = {
|
|
79
|
+
*/
|
|
80
|
+
setMailAlert(res) {
|
|
81
|
+
const emailPausedMessage = this.feature.isFeatureEnabled('ff_email_alert_update')
|
|
82
|
+
? GLOBAL_ALERTS.NOTIF_PAUSE_MESSAGE
|
|
83
|
+
: GLOBAL_ALERTS.EMAIL_PAUSE;
|
|
84
|
+
const index = this.messages.findIndex((message) => message?.message?.includes(emailPausedMessage));
|
|
85
|
+
if (res?.is_mail_block === 1 && index === -1) {
|
|
86
|
+
this.messages.push({
|
|
87
|
+
message: emailPausedMessage,
|
|
88
|
+
class: 'MEDIUM',
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
else if (res?.is_mail_block === 0 && index >= 0) {
|
|
92
|
+
this.setMessages(this.subscriptionData);
|
|
93
|
+
}
|
|
94
|
+
this.isNotificationVisible = this.messages.length > 0;
|
|
95
|
+
this.subscriptionStatus.emit(this.isNotificationVisible);
|
|
96
|
+
}
|
|
97
|
+
getPasswordResetUrl() {
|
|
98
|
+
return `https://${window.location.host}${IN_APP_URL.PASSWORD_RESET}`;
|
|
99
|
+
}
|
|
100
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GlobalAlertComponent, deps: [{ token: i1.ApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
101
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GlobalAlertComponent, selector: "vc-global-alert", inputs: { feature: "feature" }, outputs: { subscriptionStatus: "subscriptionStatus" }, ngImport: i0, template: `
|
|
102
|
+
<div
|
|
103
|
+
*ngIf="messages.length > 0"
|
|
104
|
+
class="global-alert vx-d-flex vx-align-center vx-justify-center"
|
|
105
|
+
[class.expired]="messages[activeIndex]?.class === 'HIGH'"
|
|
106
|
+
>
|
|
107
|
+
<i class="icons vx-fs-12 vx-mr-2"></i>
|
|
108
|
+
<!-- <span class="vx-fs-13"
|
|
109
|
+
>Email notifications have been paused by the Key Admin. You will not be able
|
|
110
|
+
to edit your email notifications until the Key Admin turns it back on.</span
|
|
111
|
+
> -->
|
|
112
|
+
<span
|
|
113
|
+
class="vx-fs-13"
|
|
114
|
+
[innerHTML]="messages[activeIndex]?.message"
|
|
115
|
+
></span>
|
|
116
|
+
<div class="global-alert-action vx-d-flex vx-align-center vx-lh-6">
|
|
117
|
+
<button
|
|
118
|
+
[class.disabled]="activeIndex === 0"
|
|
119
|
+
(click)="activeIndex = activeIndex - 1"
|
|
120
|
+
class="vx-fs-12 vx-p-0 vx-m-0 vx-mr-4 vx-d-flex vx-align-center disabled"
|
|
121
|
+
>
|
|
122
|
+
<i class="icons"></i>
|
|
123
|
+
</button>
|
|
124
|
+
<span class="vx-fs-13 vx-txt-white">{{ activeIndex + 1 }}</span>
|
|
125
|
+
<span class="divider vx-fs-11 vx-txt-white">/</span>
|
|
126
|
+
<span class="vx-fs-13 vx-fw-600 vx-txt-white">{{
|
|
127
|
+
messages.length
|
|
128
|
+
}}</span>
|
|
129
|
+
<button
|
|
130
|
+
(click)="activeIndex = activeIndex + 1"
|
|
131
|
+
[class.disabled]="activeIndex === messages.length - 1"
|
|
132
|
+
class="vx-fs-12 vx-p-0 vx-m-0 vx-ml-4 vx-d-flex vx-align-center"
|
|
133
|
+
>
|
|
134
|
+
<i class="icons"></i>
|
|
135
|
+
</button>
|
|
136
|
+
</div>
|
|
137
|
+
</div>
|
|
138
|
+
`, isInline: true, styles: ["@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";::ng-deep .global-alert{background:#343952;height:2.25rem;color:#f7d873}::ng-deep .global-alert.expired{color:#e38b7a}::ng-deep .global-alert.expired a{color:#fac3b7;margin-left:.5rem}::ng-deep .global-alert a{color:#f7d873}::ng-deep .global-alert-action{position:absolute;right:.75rem;top:.375rem}::ng-deep .global-alert-action span{letter-spacing:2px}::ng-deep .global-alert-action button{background:transparent;border-radius:0;border:none;color:#fff}::ng-deep .global-alert-action button.disabled{pointer-events:none;opacity:.5;color:#fff}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
8
139
|
}
|
|
9
140
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GlobalAlertComponent, decorators: [{
|
|
10
141
|
type: Component,
|
|
11
|
-
args: [{ selector: 'vc-global-alert', template:
|
|
12
|
-
|
|
13
|
-
|
|
142
|
+
args: [{ selector: 'vc-global-alert', template: `
|
|
143
|
+
<div
|
|
144
|
+
*ngIf="messages.length > 0"
|
|
145
|
+
class="global-alert vx-d-flex vx-align-center vx-justify-center"
|
|
146
|
+
[class.expired]="messages[activeIndex]?.class === 'HIGH'"
|
|
147
|
+
>
|
|
148
|
+
<i class="icons vx-fs-12 vx-mr-2"></i>
|
|
149
|
+
<!-- <span class="vx-fs-13"
|
|
150
|
+
>Email notifications have been paused by the Key Admin. You will not be able
|
|
151
|
+
to edit your email notifications until the Key Admin turns it back on.</span
|
|
152
|
+
> -->
|
|
153
|
+
<span
|
|
154
|
+
class="vx-fs-13"
|
|
155
|
+
[innerHTML]="messages[activeIndex]?.message"
|
|
156
|
+
></span>
|
|
157
|
+
<div class="global-alert-action vx-d-flex vx-align-center vx-lh-6">
|
|
158
|
+
<button
|
|
159
|
+
[class.disabled]="activeIndex === 0"
|
|
160
|
+
(click)="activeIndex = activeIndex - 1"
|
|
161
|
+
class="vx-fs-12 vx-p-0 vx-m-0 vx-mr-4 vx-d-flex vx-align-center disabled"
|
|
162
|
+
>
|
|
163
|
+
<i class="icons"></i>
|
|
164
|
+
</button>
|
|
165
|
+
<span class="vx-fs-13 vx-txt-white">{{ activeIndex + 1 }}</span>
|
|
166
|
+
<span class="divider vx-fs-11 vx-txt-white">/</span>
|
|
167
|
+
<span class="vx-fs-13 vx-fw-600 vx-txt-white">{{
|
|
168
|
+
messages.length
|
|
169
|
+
}}</span>
|
|
170
|
+
<button
|
|
171
|
+
(click)="activeIndex = activeIndex + 1"
|
|
172
|
+
[class.disabled]="activeIndex === messages.length - 1"
|
|
173
|
+
class="vx-fs-12 vx-p-0 vx-m-0 vx-ml-4 vx-d-flex vx-align-center"
|
|
174
|
+
>
|
|
175
|
+
<i class="icons"></i>
|
|
176
|
+
</button>
|
|
177
|
+
</div>
|
|
178
|
+
</div>
|
|
179
|
+
`, styles: ["@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";::ng-deep .global-alert{background:#343952;height:2.25rem;color:#f7d873}::ng-deep .global-alert.expired{color:#e38b7a}::ng-deep .global-alert.expired a{color:#fac3b7;margin-left:.5rem}::ng-deep .global-alert a{color:#f7d873}::ng-deep .global-alert-action{position:absolute;right:.75rem;top:.375rem}::ng-deep .global-alert-action span{letter-spacing:2px}::ng-deep .global-alert-action button{background:transparent;border-radius:0;border:none;color:#fff}::ng-deep .global-alert-action button.disabled{pointer-events:none;opacity:.5;color:#fff}\n"] }]
|
|
180
|
+
}], ctorParameters: function () { return [{ type: i1.ApiService }]; }, propDecorators: { feature: [{
|
|
181
|
+
type: Input
|
|
182
|
+
}], subscriptionStatus: [{
|
|
183
|
+
type: Output
|
|
184
|
+
}] } });
|
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global-alert.component.js","sourceRoot":"","sources":["../../../../../../../projects/vc-layout/src/lib/components/global-alert/global-alert/global-alert.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { GLOBAL_ALERTS } from '../../../constants/alerts.constant';\r\nimport { IN_APP_URL } from '../../../constants/app-url.constant';\r\nimport { ApiService } from '../../../shared/services/api.service';\r\n\r\n@Component({\r\n  selector: 'vc-global-alert',\r\n  template: `\r\n    <div\r\n      *ngIf=\"messages.length > 0\"\r\n      class=\"global-alert vx-d-flex vx-align-center vx-justify-center\"\r\n      [class.expired]=\"messages[activeIndex]?.class === 'HIGH'\"\r\n    >\r\n      <i class=\"icons vx-fs-12 vx-mr-2\">&#xe930;</i>\r\n      <!-- <span class=\"vx-fs-13\"\r\n    >Email notifications have been paused by the Key Admin. You will not be able\r\n    to edit your email notifications until the Key Admin turns it back on.</span\r\n  > -->\r\n      <span\r\n        class=\"vx-fs-13\"\r\n        [innerHTML]=\"messages[activeIndex]?.message\"\r\n      ></span>\r\n      <div class=\"global-alert-action vx-d-flex vx-align-center vx-lh-6\">\r\n        <button\r\n          [class.disabled]=\"activeIndex === 0\"\r\n          (click)=\"activeIndex = activeIndex - 1\"\r\n          class=\"vx-fs-12 vx-p-0 vx-m-0 vx-mr-4 vx-d-flex vx-align-center disabled\"\r\n        >\r\n          <i class=\"icons\">&#xe96b;</i>\r\n        </button>\r\n        <span class=\"vx-fs-13 vx-txt-white\">{{ activeIndex + 1 }}</span>\r\n        <span class=\"divider vx-fs-11 vx-txt-white\">/</span>\r\n        <span class=\"vx-fs-13 vx-fw-600 vx-txt-white\">{{\r\n          messages.length\r\n        }}</span>\r\n        <button\r\n          (click)=\"activeIndex = activeIndex + 1\"\r\n          [class.disabled]=\"activeIndex === messages.length - 1\"\r\n          class=\"vx-fs-12 vx-p-0 vx-m-0 vx-ml-4 vx-d-flex vx-align-center\"\r\n        >\r\n          <i class=\"icons\">&#xe970;</i>\r\n        </button>\r\n      </div>\r\n    </div>\r\n  `,\r\n  styleUrls: ['./global-alert.component.less'],\r\n})\r\nexport class GlobalAlertComponent {\r\n  activeIndex = 0;\r\n  messages: Array<any> = [];\r\n  mailAlert: any;\r\n  isNotificationVisible: boolean = false;\r\n  subscriptionData: any;\r\n  @Input() feature: any;\r\n  @Output() subscriptionStatus = new EventEmitter();\r\n\r\n  constructor(private apiService: ApiService) {\r\n    this.setSubscriptionInfo();\r\n    this.getOrgDetails();\r\n  }\r\n\r\n  setSubscriptionInfo() {\r\n    this.apiService.subscriptionDetail$.subscribe((res) => {\r\n      console.log('this.subscriptionData ==>', res);\r\n      if (res) {\r\n        this.subscriptionData = res;\r\n        console.log('this.subscriptionData ==>', this.subscriptionData);\r\n        this.setMessages(this.subscriptionData);\r\n      }\r\n    });\r\n  }\r\n\r\n  getOrgDetails() {\r\n    this.apiService.organizationDetail$.subscribe((res) => {\r\n      if (res) {\r\n        this.setMailAlert(res);\r\n      }\r\n    });\r\n  }\r\n\r\n  setMessages(subscriptionData: any) {\r\n    const messages = [];\r\n    this.activeIndex = 0;\r\n\r\n    if (subscriptionData) {\r\n      const {\r\n        trial_flag,\r\n        no_of_days_left,\r\n        after_expired_days_allow,\r\n        no_of_days_for_password_expire,\r\n      } = subscriptionData;\r\n\r\n      if (trial_flag && no_of_days_left <= 0) {\r\n        messages.push({\r\n          message: GLOBAL_ALERTS.trialUserExpired + GLOBAL_ALERTS.contactUs,\r\n          class: 'HIGH',\r\n        });\r\n      } else if (no_of_days_left > 0 && no_of_days_left <= 30) {\r\n        messages.push({\r\n          message: `YOUR SUBSCRIPTION EXPIRES IN ${no_of_days_left} DAYS. ${GLOBAL_ALERTS.contactUs}`,\r\n          class: no_of_days_left <= 10 ? 'HIGH' : 'MEDIUM',\r\n        });\r\n      } else if (no_of_days_left <= 0) {\r\n        messages.push({\r\n          message: `SUBSCRIPTION EXPIRED: YOU WILL NOT BE ABLE TO LOGIN TO YOUR ACCOUNT AFTER ${after_expired_days_allow} DAYS. ${GLOBAL_ALERTS.contactUs}`,\r\n          class: 'HIGH',\r\n        });\r\n      }\r\n\r\n      if (no_of_days_for_password_expire < 1) {\r\n        messages.push({\r\n          message: `YOUR PASSWORD HAS EXPIRED. PLEASE <a href=\"${this.getPasswordResetUrl()}\" target=\"_blank\">CLICK HERE</a> TO RESET YOUR PASSWORD.`,\r\n          class: 'HIGH',\r\n        });\r\n      } else if (no_of_days_for_password_expire < 30) {\r\n        messages.push({\r\n          message: `YOUR PASSWORD IS GOING TO EXPIRE IN ${no_of_days_for_password_expire} DAYS. <a href=\"${this.getPasswordResetUrl()}\" target=\"_blank\">CLICK HERE</a> TO RESET YOUR PASSWORD.`,\r\n          class: 'MEDIUM',\r\n        });\r\n      }\r\n    }\r\n\r\n    this.messages = messages;\r\n    this.isNotificationVisible = this.messages.length > 0;\r\n    this.subscriptionStatus.emit(this.isNotificationVisible);\r\n  }\r\n\r\n  /**\r\n   * If the response is true, then push the message to the array. If the response is false, then remove\r\n   * the message from the array.\r\n   * </code>\r\n   * @param {any} res - any = {\r\n   */\r\n  setMailAlert(res: any) {\r\n    const emailPausedMessage = this.feature.isFeatureEnabled(\r\n      'ff_email_alert_update'\r\n    )\r\n      ? GLOBAL_ALERTS.NOTIF_PAUSE_MESSAGE\r\n      : GLOBAL_ALERTS.EMAIL_PAUSE;\r\n\r\n    const index = this.messages.findIndex((message: any) =>\r\n      message?.message?.includes(emailPausedMessage)\r\n    );\r\n\r\n    if (res?.is_mail_block === 1 && index === -1) {\r\n      this.messages.push({\r\n        message: emailPausedMessage,\r\n        class: 'MEDIUM',\r\n      });\r\n    } else if (res?.is_mail_block === 0 && index >= 0) {\r\n      this.setMessages(this.subscriptionData);\r\n    }\r\n\r\n    this.isNotificationVisible = this.messages.length > 0;\r\n    this.subscriptionStatus.emit(this.isNotificationVisible);\r\n  }\r\n\r\n  getPasswordResetUrl() {\r\n    return `https://${window.location.host}${IN_APP_URL.PASSWORD_RESET}`;\r\n  }\r\n}\r\n"]}
|
|
@@ -162,7 +162,7 @@ export class BusinessCycleComponent {
|
|
|
162
162
|
});
|
|
163
163
|
}
|
|
164
164
|
else {
|
|
165
|
-
this.businessCycleList
|
|
165
|
+
this.businessCycleList?.forEach((cycle) => {
|
|
166
166
|
let isDisabled = true;
|
|
167
167
|
this.tempSelectedCycle.forEach((el) => {
|
|
168
168
|
if (cycle.start_date == el.start_date) {
|
|
@@ -266,14 +266,14 @@ export class BusinessCycleComponent {
|
|
|
266
266
|
}
|
|
267
267
|
}
|
|
268
268
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BusinessCycleComponent, deps: [{ token: i1.AuthorizerService }, { token: i2.BusinessCycleService }, { token: i3.ApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
269
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BusinessCycleComponent, selector: "vc-business-cycle", inputs: { orgDetails: "orgDetails" }, outputs: { businessCycleChange: "businessCycleChange" }, ngImport: i0, template: "<div\r\n class=\"vc-business-cycle vx-pt-2 vx-pb-2\"\r\n appPopover\r\n (click)=\"businessCyclePop.popover()\"\r\n position=\"left\"\r\n>\r\n <div class=\"heading vx-fs-9 vx-tt-uppercase vx-mb-1 vx-lh-3\">\r\n SHOWING DATA {{ cycleToShow === \"Show Future Due Dates\" ? \"For\" : \"From\" }}\r\n </div>\r\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-lh-4\">\r\n <div class=\"vx-d-flex vx-align-center\">\r\n <i class=\"icons calendar vx-fs-12 vx-mr-2\"></i>\r\n <span class=\"vx-fs-11 vx-txt-white vx-d-inline-block\">{{\r\n cycleToShow === \"Show Future Due Dates\"\r\n ? \"Future Due Dates\"\r\n : cycleToShow\r\n }}</span>\r\n </div>\r\n <i class=\"icons arrow vx-fs-10 vx-mr-2\"></i>\r\n </div>\r\n</div>\r\n\r\n<vui-popover #businessCyclePop [dontCloseonClick]=\"true\">\r\n <div class=\"vc-business-cycle-popover-container\">\r\n <div\r\n class=\"vc-business-cycle-popover-container-top vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n >\r\n <p class=\"vx-fs-11 vx-fw-400 vx-label-txt vx-p-0 vx-m-0\">\r\n You can select upto a max of two consecutive years\r\n </p>\r\n </div>\r\n <div class=\"vc-business-cycle-popover-container-body\">\r\n <ul class=\"vx-p-0 vx-m-0\">\r\n <ng-container\r\n *ngFor=\"let eachCycle of businessCycleList; let i = index\"\r\n >\r\n <li\r\n *ngIf=\"\r\n eachCycle?.business_cycle?.toLowerCase() ===\r\n 'show future due dates'\r\n \"\r\n class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n [class.future-cycle]=\"true\"\r\n >\r\n <app-cs-checkbox\r\n [ngValue]=\"
|
|
269
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BusinessCycleComponent, selector: "vc-business-cycle", inputs: { orgDetails: "orgDetails" }, outputs: { businessCycleChange: "businessCycleChange" }, ngImport: i0, template: "<div\r\n class=\"vc-business-cycle vx-pt-2 vx-pb-2\"\r\n appPopover\r\n (click)=\"businessCyclePop.popover()\"\r\n position=\"left\"\r\n>\r\n <div class=\"heading vx-fs-9 vx-tt-uppercase vx-mb-1 vx-lh-3\">\r\n SHOWING DATA {{ cycleToShow === \"Show Future Due Dates\" ? \"For\" : \"From\" }}\r\n </div>\r\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-lh-4\">\r\n <div class=\"vx-d-flex vx-align-center\">\r\n <i class=\"icons calendar vx-fs-12 vx-mr-2\"></i>\r\n <span class=\"vx-fs-11 vx-txt-white vx-d-inline-block\">{{\r\n cycleToShow === \"Show Future Due Dates\"\r\n ? \"Future Due Dates\"\r\n : cycleToShow\r\n }}</span>\r\n </div>\r\n <i class=\"icons arrow vx-fs-10 vx-mr-2\"></i>\r\n </div>\r\n</div>\r\n\r\n<vui-popover #businessCyclePop [dontCloseonClick]=\"true\">\r\n <div class=\"vc-business-cycle-popover-container\">\r\n <div\r\n class=\"vc-business-cycle-popover-container-top vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n >\r\n <p class=\"vx-fs-11 vx-fw-400 vx-label-txt vx-p-0 vx-m-0\">\r\n You can select upto a max of two consecutive years\r\n </p>\r\n </div>\r\n <div class=\"vc-business-cycle-popover-container-body\">\r\n <ul class=\"vx-p-0 vx-m-0\">\r\n <ng-container\r\n *ngFor=\"let eachCycle of businessCycleList; let i = index\"\r\n >\r\n <li\r\n *ngIf=\"\r\n eachCycle?.business_cycle?.toLowerCase() ===\r\n 'show future due dates'\r\n \"\r\n class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n [class.future-cycle]=\"true\"\r\n >\r\n <app-cs-checkbox\r\n [ngValue]=\"isSelectedCycle(tempSelectedCycle, eachCycle)\"\r\n (ngValueChange)=\"selectCycle(eachCycle, i)\"\r\n [disabled]=\"eachCycle?.isDisabled\"\r\n >Show Future Due Dates</app-cs-checkbox\r\n >\r\n <i\r\n class=\"icons info-icon vx-fs-12\"\r\n [arTooltip]=\"\r\n 'This option lets you view data that lies outside the current business cycle and are due in the future.'\r\n \"\r\n placement=\"bottom\"\r\n type=\"black\"\r\n delay=\"0\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </li>\r\n <li\r\n *ngIf=\"\r\n eachCycle?.business_cycle?.toLowerCase() !==\r\n 'show future due dates'\r\n \"\r\n class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n >\r\n <app-cs-checkbox\r\n [ngValue]=\"isSelectedCycle(tempSelectedCycle, eachCycle)\"\r\n (ngValueChange)=\"selectCycle(eachCycle, i)\"\r\n [disabled]=\"eachCycle?.isDisabled\"\r\n >{{ eachCycle?.start_date | dateFormat }} -\r\n <ng-container>\r\n {{ eachCycle?.end_date | dateFormat }}</ng-container\r\n >\r\n </app-cs-checkbox>\r\n </li>\r\n </ng-container>\r\n </ul>\r\n </div>\r\n <div\r\n class=\"vc-business-cycle-popover-container-footer vx-d-flex vx-justify-between vx-p-3\"\r\n >\r\n <button\r\n (click)=\"businessCyclePop.closePopover('top')\"\r\n class=\"white vx-fs-11 vx-fw-500 vx-d-flex vx-align-center vx-justify-center vx-tt-uppercase vx-p-0 vx-m-0 vx-txt-blue\"\r\n >\r\n CANCEL\r\n </button>\r\n <button\r\n (click)=\"setBusinessCycle(); businessCyclePop.closePopover('top')\"\r\n [class.disabled]=\"false\"\r\n class=\"blue vx-fs-11 vx-fw-500 vx-d-flex vx-align-center vx-justify-center vx-tt-uppercase vx-p-0 vx-m-0 vx-txt-white\"\r\n >\r\n APPLY\r\n </button>\r\n </div>\r\n </div>\r\n</vui-popover>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";::ng-deep .vc-business-cycle{position:relative;width:12.5rem;height:3rem;cursor:pointer;z-index:1}::ng-deep .vc-business-cycle .heading{color:#e3e3e9}::ng-deep .vc-business-cycle i.calendar{color:#e3e3e9}::ng-deep .vc-business-cycle i.arrow{color:#f1f1f1}::ng-deep .vc-business-cycle-popover-container{width:15.625rem;background:#fff;box-shadow:0 4px 8px #1e5dd326;border:1px solid #e3e3e9;border-radius:.25rem;z-index:4}::ng-deep .vc-business-cycle-popover-container-top{background:#f8f8f8}::ng-deep .vc-business-cycle-popover-container-top p{line-height:.875rem}::ng-deep .vc-business-cycle-popover-container-body{background:#fff}::ng-deep .vc-business-cycle-popover-container-body ul li{list-style:none;margin:0;position:relative}::ng-deep .vc-business-cycle-popover-container-body ul li:before{background:#f1f1f1;content:\"\";position:absolute;left:.75rem;right:.75rem;bottom:0;height:.0625rem;width:calc(100% - 1.5rem)}::ng-deep .vc-business-cycle-popover-container-body ul li:last-of-type:before{display:none}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle{background:#fadd8a}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle:before{display:none}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle app-cs-checkbox label.checkbox-item span.checkbox{background:#fff}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle app-cs-checkbox label.checkbox-item span.value i{margin-left:.375rem}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle .info-icon{margin-left:.375rem;cursor:context-menu}::ng-deep .vc-business-cycle-popover-container-body ul li app-cs-checkbox{display:flex}::ng-deep .vc-business-cycle-popover-container-body ul li app-cs-checkbox label.checkbox-item span.value{font-size:12px!important;color:#161b2f!important;max-width:100%!important}::ng-deep .vc-business-cycle-popover-container-footer{background:#f8f8f8;border-radius:0 0 .25rem .25rem}::ng-deep .vc-business-cycle-popover-container-footer button{width:calc(50% - .125rem);height:1.5rem;border:1px solid transparent;text-transform:uppercase;border-radius:.125rem;line-height:1.375rem}::ng-deep .vc-business-cycle-popover-container-footer button.white{background:#fff;border-color:#dbdbdb}::ng-deep .vc-business-cycle-popover-container-footer button.blue{background:#1e5dd3;border-color:#1e5dd3}::ng-deep .vc-business-cycle-popover-container-footer button.disabled{background:#dbdbdb;color:#747576;border:none;pointer-events:none!important}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.ToolTipDirective, selector: "[arTooltip]", inputs: ["arTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i6.PopoverComponent, selector: "vui-popover", inputs: ["dontCloseonClick"], outputs: ["closedOnOverlay"] }, { kind: "directive", type: i7.PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "position"] }, { kind: "component", type: i8.CsCheckboxComponent, selector: "app-cs-checkbox", inputs: ["disabled", "ngValue", "value"], outputs: ["ngValueChange"] }, { kind: "pipe", type: i9.DateFormatPipe, name: "dateFormat" }] }); }
|
|
270
270
|
}
|
|
271
271
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BusinessCycleComponent, decorators: [{
|
|
272
272
|
type: Component,
|
|
273
|
-
args: [{ selector: 'vc-business-cycle', template: "<div\r\n class=\"vc-business-cycle vx-pt-2 vx-pb-2\"\r\n appPopover\r\n (click)=\"businessCyclePop.popover()\"\r\n position=\"left\"\r\n>\r\n <div class=\"heading vx-fs-9 vx-tt-uppercase vx-mb-1 vx-lh-3\">\r\n SHOWING DATA {{ cycleToShow === \"Show Future Due Dates\" ? \"For\" : \"From\" }}\r\n </div>\r\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-lh-4\">\r\n <div class=\"vx-d-flex vx-align-center\">\r\n <i class=\"icons calendar vx-fs-12 vx-mr-2\"></i>\r\n <span class=\"vx-fs-11 vx-txt-white vx-d-inline-block\">{{\r\n cycleToShow === \"Show Future Due Dates\"\r\n ? \"Future Due Dates\"\r\n : cycleToShow\r\n }}</span>\r\n </div>\r\n <i class=\"icons arrow vx-fs-10 vx-mr-2\"></i>\r\n </div>\r\n</div>\r\n\r\n<vui-popover #businessCyclePop [dontCloseonClick]=\"true\">\r\n <div class=\"vc-business-cycle-popover-container\">\r\n <div\r\n class=\"vc-business-cycle-popover-container-top vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n >\r\n <p class=\"vx-fs-11 vx-fw-400 vx-label-txt vx-p-0 vx-m-0\">\r\n You can select upto a max of two consecutive years\r\n </p>\r\n </div>\r\n <div class=\"vc-business-cycle-popover-container-body\">\r\n <ul class=\"vx-p-0 vx-m-0\">\r\n <ng-container\r\n *ngFor=\"let eachCycle of businessCycleList; let i = index\"\r\n >\r\n <li\r\n *ngIf=\"\r\n eachCycle?.business_cycle?.toLowerCase() ===\r\n 'show future due dates'\r\n \"\r\n class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n [class.future-cycle]=\"true\"\r\n >\r\n <app-cs-checkbox\r\n [ngValue]=\"
|
|
273
|
+
args: [{ selector: 'vc-business-cycle', template: "<div\r\n class=\"vc-business-cycle vx-pt-2 vx-pb-2\"\r\n appPopover\r\n (click)=\"businessCyclePop.popover()\"\r\n position=\"left\"\r\n>\r\n <div class=\"heading vx-fs-9 vx-tt-uppercase vx-mb-1 vx-lh-3\">\r\n SHOWING DATA {{ cycleToShow === \"Show Future Due Dates\" ? \"For\" : \"From\" }}\r\n </div>\r\n <div class=\"vx-d-flex vx-align-center vx-justify-between vx-lh-4\">\r\n <div class=\"vx-d-flex vx-align-center\">\r\n <i class=\"icons calendar vx-fs-12 vx-mr-2\"></i>\r\n <span class=\"vx-fs-11 vx-txt-white vx-d-inline-block\">{{\r\n cycleToShow === \"Show Future Due Dates\"\r\n ? \"Future Due Dates\"\r\n : cycleToShow\r\n }}</span>\r\n </div>\r\n <i class=\"icons arrow vx-fs-10 vx-mr-2\"></i>\r\n </div>\r\n</div>\r\n\r\n<vui-popover #businessCyclePop [dontCloseonClick]=\"true\">\r\n <div class=\"vc-business-cycle-popover-container\">\r\n <div\r\n class=\"vc-business-cycle-popover-container-top vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n >\r\n <p class=\"vx-fs-11 vx-fw-400 vx-label-txt vx-p-0 vx-m-0\">\r\n You can select upto a max of two consecutive years\r\n </p>\r\n </div>\r\n <div class=\"vc-business-cycle-popover-container-body\">\r\n <ul class=\"vx-p-0 vx-m-0\">\r\n <ng-container\r\n *ngFor=\"let eachCycle of businessCycleList; let i = index\"\r\n >\r\n <li\r\n *ngIf=\"\r\n eachCycle?.business_cycle?.toLowerCase() ===\r\n 'show future due dates'\r\n \"\r\n class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n [class.future-cycle]=\"true\"\r\n >\r\n <app-cs-checkbox\r\n [ngValue]=\"isSelectedCycle(tempSelectedCycle, eachCycle)\"\r\n (ngValueChange)=\"selectCycle(eachCycle, i)\"\r\n [disabled]=\"eachCycle?.isDisabled\"\r\n >Show Future Due Dates</app-cs-checkbox\r\n >\r\n <i\r\n class=\"icons info-icon vx-fs-12\"\r\n [arTooltip]=\"\r\n 'This option lets you view data that lies outside the current business cycle and are due in the future.'\r\n \"\r\n placement=\"bottom\"\r\n type=\"black\"\r\n delay=\"0\"\r\n [tooltipMandatory]=\"true\"\r\n ></i\r\n >\r\n </li>\r\n <li\r\n *ngIf=\"\r\n eachCycle?.business_cycle?.toLowerCase() !==\r\n 'show future due dates'\r\n \"\r\n class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n >\r\n <app-cs-checkbox\r\n [ngValue]=\"isSelectedCycle(tempSelectedCycle, eachCycle)\"\r\n (ngValueChange)=\"selectCycle(eachCycle, i)\"\r\n [disabled]=\"eachCycle?.isDisabled\"\r\n >{{ eachCycle?.start_date | dateFormat }} -\r\n <ng-container>\r\n {{ eachCycle?.end_date | dateFormat }}</ng-container\r\n >\r\n </app-cs-checkbox>\r\n </li>\r\n </ng-container>\r\n </ul>\r\n </div>\r\n <div\r\n class=\"vc-business-cycle-popover-container-footer vx-d-flex vx-justify-between vx-p-3\"\r\n >\r\n <button\r\n (click)=\"businessCyclePop.closePopover('top')\"\r\n class=\"white vx-fs-11 vx-fw-500 vx-d-flex vx-align-center vx-justify-center vx-tt-uppercase vx-p-0 vx-m-0 vx-txt-blue\"\r\n >\r\n CANCEL\r\n </button>\r\n <button\r\n (click)=\"setBusinessCycle(); businessCyclePop.closePopover('top')\"\r\n [class.disabled]=\"false\"\r\n class=\"blue vx-fs-11 vx-fw-500 vx-d-flex vx-align-center vx-justify-center vx-tt-uppercase vx-p-0 vx-m-0 vx-txt-white\"\r\n >\r\n APPLY\r\n </button>\r\n </div>\r\n </div>\r\n</vui-popover>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";::ng-deep .vc-business-cycle{position:relative;width:12.5rem;height:3rem;cursor:pointer;z-index:1}::ng-deep .vc-business-cycle .heading{color:#e3e3e9}::ng-deep .vc-business-cycle i.calendar{color:#e3e3e9}::ng-deep .vc-business-cycle i.arrow{color:#f1f1f1}::ng-deep .vc-business-cycle-popover-container{width:15.625rem;background:#fff;box-shadow:0 4px 8px #1e5dd326;border:1px solid #e3e3e9;border-radius:.25rem;z-index:4}::ng-deep .vc-business-cycle-popover-container-top{background:#f8f8f8}::ng-deep .vc-business-cycle-popover-container-top p{line-height:.875rem}::ng-deep .vc-business-cycle-popover-container-body{background:#fff}::ng-deep .vc-business-cycle-popover-container-body ul li{list-style:none;margin:0;position:relative}::ng-deep .vc-business-cycle-popover-container-body ul li:before{background:#f1f1f1;content:\"\";position:absolute;left:.75rem;right:.75rem;bottom:0;height:.0625rem;width:calc(100% - 1.5rem)}::ng-deep .vc-business-cycle-popover-container-body ul li:last-of-type:before{display:none}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle{background:#fadd8a}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle:before{display:none}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle app-cs-checkbox label.checkbox-item span.checkbox{background:#fff}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle app-cs-checkbox label.checkbox-item span.value i{margin-left:.375rem}::ng-deep .vc-business-cycle-popover-container-body ul li.future-cycle .info-icon{margin-left:.375rem;cursor:context-menu}::ng-deep .vc-business-cycle-popover-container-body ul li app-cs-checkbox{display:flex}::ng-deep .vc-business-cycle-popover-container-body ul li app-cs-checkbox label.checkbox-item span.value{font-size:12px!important;color:#161b2f!important;max-width:100%!important}::ng-deep .vc-business-cycle-popover-container-footer{background:#f8f8f8;border-radius:0 0 .25rem .25rem}::ng-deep .vc-business-cycle-popover-container-footer button{width:calc(50% - .125rem);height:1.5rem;border:1px solid transparent;text-transform:uppercase;border-radius:.125rem;line-height:1.375rem}::ng-deep .vc-business-cycle-popover-container-footer button.white{background:#fff;border-color:#dbdbdb}::ng-deep .vc-business-cycle-popover-container-footer button.blue{background:#1e5dd3;border-color:#1e5dd3}::ng-deep .vc-business-cycle-popover-container-footer button.disabled{background:#dbdbdb;color:#747576;border:none;pointer-events:none!important}\n"] }]
|
|
274
274
|
}], ctorParameters: function () { return [{ type: i1.AuthorizerService }, { type: i2.BusinessCycleService }, { type: i3.ApiService }]; }, propDecorators: { businessCycleChange: [{
|
|
275
275
|
type: Output
|
|
276
276
|
}], orgDetails: [{
|
|
277
277
|
type: Input
|
|
278
278
|
}] } });
|
|
279
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"business-cycle.component.js","sourceRoot":"","sources":["../../../../../../../projects/vc-layout/src/lib/components/header/business-cycle/business-cycle.component.ts","../../../../../../../projects/vc-layout/src/lib/components/header/business-cycle/business-cycle.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;AAU/E,MAAM,OAAO,sBAAsB;IAcjC,YACU,WAA8B,EAC9B,oBAA0C,EAC1C,UAAsB;QAFtB,gBAAW,GAAX,WAAW,CAAmB;QAC9B,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,eAAU,GAAV,UAAU,CAAY;QAhBhC,gBAAW,GAAW,gBAAgB,CAAC;QACvC,qBAAgB,GAAkB,EAAE,CAAC;QACrC,gBAAW,GAAkB,EAAE,CAAC;QAChC,yBAAoB,GAAkB,EAAE,CAAC;QACzC,oBAAe,GAAkB,CAAC,CAAC,CAAC,CAAC;QACrC,uBAAkB,GAAe,EAAE,CAAC;QAEpC,sBAAiB,GAAU,EAAE,CAAC;QAC9B,WAAM,GAAW,EAAE,CAAC;QAEV,wBAAmB,GAAG,IAAI,YAAY,EAAE,CAAC;QAQjD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC;QACnD,IAAI,CAAC,oBAAoB,CAAC,wBAAwB,EAAE,CAAC;QACrD,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,QAAQ,KAAU,CAAC;IAEnB,aAAa;QACX,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACzD,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;YAChC,IAAI,GAAG,EAAE;gBACP,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;gBAClD,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACzB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,wBAAwB;QACtB,IAAI,CAAC,oBAAoB,CAAC,sBAAsB,CAAC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACtE,IAAI,GAAG,EAAE;gBACP,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;gBAC5B,IAAI,CAAC,qBAAqB,GAAG,GAAG,CAAC;gBACjC,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,CAAC;aAChC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACH,mBAAmB,CAAC,aAAkB;QACpC,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC;QACvC,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM;YAC/B,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;gBACxC,KAAK,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC;YAC9B,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;;OAMG;IACH,WAAW,CAAC,KAAU,EAAE,KAAa;QACnC,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAC9C,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,CAAC,UAAU,IAAI,KAAK,CAAC,UAAU,CAC/C,CAAC;QACF,IAAI,OAAO,IAAI,CAAC,EAAE;YAChB,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;SAC3C;aAAM,IAAI,IAAI,CAAC,iBAAiB,EAAE,MAAM,KAAK,CAAC,EAAE;YAC/C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACpC;aAAM;YACL,MAAM,aAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,CACpD,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,CAAC,UAAU,IAAI,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,UAAU,CACpE,CAAC;YACF,IAAI,aAAa,GAAG,KAAK,EAAE;gBACzB,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;aACvC;iBAAM;gBACL,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACpC;SACF;QACD,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED;;;;;;;;OAQG;IAEH,eAAe,CAAC,aAAkB,EAAE,KAAU;QAC5C,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,aAAa,CAAC,OAAO,CAAC,CAAC,EAAO,EAAO,EAAE;YACrC,IAAI,EAAE,CAAC,UAAU,IAAI,KAAK,CAAC,UAAU,EAAE;gBACrC,UAAU,GAAG,IAAI,CAAC;aACnB;QACH,CAAC,CAAC,CAAC;QACH,OAAO,UAAU,CAAC;IACpB,CAAC;IAED;;;;;;OAMG;IACH,oBAAoB,CAAC,KAAU;QAC7B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;QAC5B,IAAI,KAAK,EAAE,kBAAkB,EAAE,MAAM,KAAK,CAAC,EAAE;YAC3C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACnC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAC3B,2CAA2C;SAC5C;aAAM;YACL,KAAK,EAAE,kBAAkB,EAAE,OAAO,CAAC,CAAC,EAAO,EAAE,CAAS,EAAE,EAAE;gBACxD,IAAI,OAAO,GAAG;oBACZ,UAAU,EAAE,EAAE,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC;oBAC/B,QAAQ,EAAE,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE,MAAM,GAAG,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC;oBAClD,QAAQ,EAAE,IAAI;oBACd,cAAc,EAAE,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC;oBACxC,cAAc,EAAE,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC;oBACxC,kBAAkB,EAAE,CAAC,EAAE,CAAC;iBACzB,CAAC;gBACF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAC3B,mLAAmL;SACpL;QACD,8BAA8B;QAC9B,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED;;;;;;OAMG;IACH,qBAAqB;QACnB,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,MAAM,EAAE;YACnC,IAAI,IAAI,CAAC,iBAAiB,EAAE,MAAM;gBAChC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACxC,KAAK,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC;gBAC9B,CAAC,CAAC,CAAC;SACN;aAAM,IAAI,IAAI,CAAC,iBAAiB,EAAE,MAAM,KAAK,CAAC,EAAE;YAC/C,MAAM,KAAK,GAAG,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAC7C,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,CAAC,UAAU,IAAI,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,UAAU,CACnE,CAAC;YACF,IAAI,CAAC,iBAAiB,EAAE,OAAO,CAAC,CAAC,KAAU,EAAE,CAAS,EAAE,EAAE;gBACxD,IAAI,KAAK,GAAG,CAAC,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,IAAI,KAAK,GAAG,CAAC,KAAK,CAAC,EAAE;oBACrD,KAAK,CAAC,UAAU,GAAG,KAAK,CAAC;iBAC1B;qBAAM;oBACL,KAAK,CAAC,UAAU,GAAG,IAAI,CAAC;iBACzB;YACH,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;gBAC5C,IAAI,UAAU,GAAG,IAAI,CAAC;gBACtB,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,EAAO,EAAE,EAAE;oBACzC,IAAI,KAAK,CAAC,UAAU,IAAI,EAAE,CAAC,UAAU,EAAE;wBACrC,UAAU,GAAG,KAAK,CAAC;qBACpB;gBACH,CAAC,CAAC,CAAC;gBACH,KAAK,CAAC,UAAU,GAAG,UAAU,CAAC;YAChC,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED;;;;OAIG;IACH,gBAAgB;QACd,IAAI,mBAAmB,GAAQ,EAAE,CAAC;QAClC,IAAI,IAAI,CAAC,iBAAiB,EAAE,MAAM,KAAK,CAAC,EAAE;YACxC,mBAAmB,GAAG;gBACpB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,aAAa,EAAE;oBACb,UAAU,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,UAAU;oBACjD,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,QAAQ;oBAC7C,QAAQ,EAAE,IAAI;oBACd,cAAc,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,cAAc;oBACzD,cAAc,EACZ,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,UAAU;wBACrC,GAAG;wBACH,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,QAAQ;oBACrC,kBAAkB,EAAE;wBAClB,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,UAAU;4BACnC,GAAG;4BACH,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,QAAQ;qBACtC;iBACF;aACF,CAAC;YACF,IAAI,CAAC,cAAc,CAAC,mBAAmB,EAAE,aAAa,CAAC,CAAC;YACxD,gEAAgE;SACjE;aAAM;YACL,IAAI,cAAc,GAAQ,EAAE,CAAC;YAC7B,IAAI,kBAAkB,GAAQ,EAAE,CAAC;YACjC,IAAI,CAAC,iBAAiB,EAAE,OAAO,CAAC,CAAC,EAAO,EAAE,EAAE;gBAC1C,cAAc,CAAC,IAAI,CAAC,EAAE,EAAE,cAAc,CAAC,CAAC;gBACxC,kBAAkB,CAAC,IAAI,CAAC,EAAE,EAAE,UAAU,GAAG,GAAG,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;YAC/D,CAAC,CAAC,CAAC;YACH,mBAAmB,GAAG;gBACpB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,aAAa,EAAE;oBACb,UAAU,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,UAAU;oBACjD,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,QAAQ;oBAC7C,QAAQ,EAAE,IAAI;oBACd,cAAc,EAAE,cAAc;oBAC9B,cAAc,EACZ,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,UAAU;wBACrC,GAAG;wBACH,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,QAAQ;oBACrC,kBAAkB,EAAE,kBAAkB;iBACvC;aACF,CAAC;YACF,IAAI,CAAC,cAAc,CAAC,mBAAmB,EAAE,aAAa,CAAC,CAAC;YACxD,sJAAsJ;SACvJ;QACD,2DAA2D;QAC3D,YAAY,CAAC,OAAO,CAAC,eAAe,EAAE,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,CAAC;QAC3E,IAAI,CAAC,qBAAqB,GAAG,mBAAmB,EAAE,aAAa,CAAC;QAChE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAC1D,IAAI,CAAC,oBAAoB,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED;;;;OAIG;IACH,mBAAmB;QACjB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;IACxD,CAAC;IAED;;;;OAIG;IACH,cAAc,CAAC,KAAU;QACvB,IAAI,KAAK,EAAE,kBAAkB,EAAE,MAAM,KAAK,CAAC,EAAE;YAC3C,IAAI,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,IAAI,uBAAuB,EAAE;gBACnE,IAAI,CAAC,WAAW,GAAG,kBAAkB,CAAC;aACvC;iBAAM;gBACL,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,cAAc,CAAC;aACzC;SACF;aAAM;YACL,IACE,KAAK,EAAE,cAAc,EAAE,MAAM,GAAG,CAAC;gBACjC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,IAAI,uBAAuB,EAClE;gBACA,IAAI,CAAC,WAAW,GAAG,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;aAC/D;iBAAM,IAAI,KAAK,EAAE,cAAc,EAAE,MAAM,EAAE;gBACxC,IAAI,CAAC,WAAW;oBACd,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC;wBAC1C,KAAK;wBACL,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,SAAS,CAChC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,EAAE,MAAM,GAAG,EAAE,EACrC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,EAAE,KAAK,CAChC,CAAC;aACL;SACF;IACH,CAAC;+GAlRU,sBAAsB;mGAAtB,sBAAsB,wJCVnC,q6HAqGA;;4FD3Fa,sBAAsB;kBALlC,SAAS;+BACE,mBAAmB;oKAenB,mBAAmB;sBAA5B,MAAM;gBAEE,UAAU;sBAAlB,KAAK","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { AuthorizerService } from '@vcomply/authorizer';\r\nimport { BusinessCycleService } from '../../../shared/services/business-cycle.service';\r\nimport { ApiService } from '../../../shared/services/api.service';\r\n\r\n@Component({\r\n  selector: 'vc-business-cycle',\r\n  templateUrl: './business-cycle.component.html',\r\n  styleUrls: ['./business-cycle.component.less'],\r\n})\r\nexport class BusinessCycleComponent implements OnInit {\r\n  cycleToShow: string = 'Business Cycle';\r\n  businessCycleArr: Array<string> = [];\r\n  hiddenCycle: Array<number> = [];\r\n  tempBusinessCycleArr: Array<string> = [];\r\n  tempHiddenCycle: Array<number> = [0];\r\n  businessCyclesList: Array<any> = [];\r\n  businessCycleList!: Array<any>;\r\n  tempSelectedCycle: any[] = [];\r\n  userId: string = '';\r\n  selectedBusinessCycle!: any;\r\n  @Output() businessCycleChange = new EventEmitter();\r\n\r\n  @Input() orgDetails: any;\r\n  constructor(\r\n    private authService: AuthorizerService,\r\n    private businessCycleService: BusinessCycleService,\r\n    private apiService: ApiService\r\n  ) {\r\n    this.userId = this.authService.getMemberId() ?? '';\r\n    this.businessCycleService.isBusinessCycleAvailable();\r\n    this.setSelectedBusinessCycle();\r\n    this.getOrgDetails();\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  getOrgDetails() {\r\n    this.apiService.organizationDetail$.subscribe((res: any) => {\r\n      console.log('org Details', res);\r\n      if (res) {\r\n        this.setBusinessCycleKey(res.business_cycles_arr);\r\n        this.setBusinessCycle();\r\n      }\r\n    });\r\n  }\r\n\r\n  setSelectedBusinessCycle() {\r\n    this.businessCycleService.selectedBusinessCycle$.subscribe((res: any) => {\r\n      if (res) {\r\n        console.log('res ==>', res);\r\n        this.selectedBusinessCycle = res;\r\n        this.setTempSelectedCycle(res);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   * it will set a new key in every cycle\r\n   * key will use for disabled or enable the cycle from business cycle list.\r\n   * @param businessCycle this the business cycle list\r\n   */\r\n  setBusinessCycleKey(businessCycle: any) {\r\n    this.businessCycleList = businessCycle;\r\n    if (this.businessCycleList.length)\r\n      this.businessCycleList.map((cycle: any) => {\r\n        cycle['isDisabled'] = false;\r\n      });\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   * it will check the cycle if it is not checked.\r\n   * if it has checked then it will uncheck that cycle.\r\n   * @param cycle checked or unchecked cycle from business cycle list.\r\n   * @param index it give the index value of business cycle list which is selected.\r\n   */\r\n  selectCycle(cycle: any, index: number) {\r\n    const isExist = this.tempSelectedCycle.findIndex(\r\n      (el: any) => el.start_date == cycle.start_date\r\n    );\r\n    if (isExist >= 0) {\r\n      this.tempSelectedCycle.splice(isExist, 1);\r\n    } else if (this.tempSelectedCycle?.length === 0) {\r\n      this.tempSelectedCycle.push(cycle);\r\n    } else {\r\n      const selectedIndex = this.businessCycleList.findIndex(\r\n        (el: any) => el.start_date == this.tempSelectedCycle[0]?.start_date\r\n      );\r\n      if (selectedIndex < index) {\r\n        this.tempSelectedCycle.unshift(cycle);\r\n      } else {\r\n        this.tempSelectedCycle.push(cycle);\r\n      }\r\n    }\r\n    this.setCycleEnableDisable();\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   *\r\n   * need to check cycle includes in selected cycle array\r\n   * Determines whether selected cycle is\r\n   * @param selectedCycle selected Cycle which user checked or auto selected cycle.\r\n   * @param cycle all indivisible cycle of business cycle of the organization.\r\n   * @returns boolean value is cycle exist in selected cycle or not.\r\n   */\r\n\r\n  isSelectedCycle(selectedCycle: any, cycle: any) {\r\n    let isSelected = false;\r\n    selectedCycle.forEach((el: any): any => {\r\n      if (el.start_date == cycle.start_date) {\r\n        isSelected = true;\r\n      }\r\n    });\r\n    return isSelected;\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   *\r\n   * set selected businessCycle to temp business cycle indivisible if there is two selected cycle\r\n   * Sets temp selected cycle\r\n   * @param cycle selected business cycle from local storage\r\n   */\r\n  setTempSelectedCycle(cycle: any) {\r\n    this.tempSelectedCycle = [];\r\n    if (cycle?.selected_cycle_arr?.length === 1) {\r\n      this.tempSelectedCycle.push(cycle);\r\n      this.setCycleToShow(cycle);\r\n      // this.cycleToShow = cycle.business_cycle;\r\n    } else {\r\n      cycle?.selected_cycle_arr?.forEach((el: any, i: number) => {\r\n        let payload = {\r\n          start_date: el.substring(0, 10),\r\n          end_date: el.substring(el?.length - 10, el?.lenth),\r\n          selected: true,\r\n          business_cycle: cycle?.business_cycle[i],\r\n          selected_cycle: cycle?.selected_cycle[i],\r\n          selected_cycle_arr: [el],\r\n        };\r\n        this.tempSelectedCycle.push(payload);\r\n      });\r\n      this.setCycleToShow(cycle);\r\n      // this.cycleToShow = cycle?.business_cycle[0]?.substring(0,11) + \" - \" + cycle?.business_cycle[1].substring(cycle?.business_cycle[1]?.length-11, cycle?.business_cycle[1]?.lenth);\r\n    }\r\n    // this.setCycleToShow(cycle);\r\n    this.setCycleEnableDisable();\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   *  when user select one cycle then their besides cycles are enable and other are disabled.\r\n   *  if user select two cycles then all the cycles get disabled except selected cycles.\r\n   *\r\n   *  In businessCycleList array we set a isDisabled key, we are set it true when need to disabled the cycle.\r\n   */\r\n  setCycleEnableDisable() {\r\n    if (!this.tempSelectedCycle?.length) {\r\n      if (this.businessCycleList?.length)\r\n        this.businessCycleList.map((cycle: any) => {\r\n          cycle['isDisabled'] = false;\r\n        });\r\n    } else if (this.tempSelectedCycle?.length === 1) {\r\n      const index = this.businessCycleList?.findIndex(\r\n        (el: any) => el.start_date == this.tempSelectedCycle[0].start_date\r\n      );\r\n      this.businessCycleList?.forEach((cycle: any, i: number) => {\r\n        if (index - 1 === i || index === i || index + 1 === i) {\r\n          cycle.isDisabled = false;\r\n        } else {\r\n          cycle.isDisabled = true;\r\n        }\r\n      });\r\n    } else {\r\n      this.businessCycleList.forEach((cycle: any) => {\r\n        let isDisabled = true;\r\n        this.tempSelectedCycle.forEach((el: any) => {\r\n          if (cycle.start_date == el.start_date) {\r\n            isDisabled = false;\r\n          }\r\n        });\r\n        cycle.isDisabled = isDisabled;\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   *  When user click apply then selected cycle is set in local storage.\r\n   *\r\n   */\r\n  setBusinessCycle() {\r\n    let businessCycleObject: any = {};\r\n    if (this.tempSelectedCycle?.length === 1) {\r\n      businessCycleObject = {\r\n        userId: this.userId,\r\n        selectedCycle: {\r\n          start_date: this.tempSelectedCycle[0]?.start_date,\r\n          end_date: this.tempSelectedCycle[0]?.end_date,\r\n          selected: true,\r\n          business_cycle: this.tempSelectedCycle[0]?.business_cycle,\r\n          selected_cycle:\r\n            this.tempSelectedCycle[0]?.start_date +\r\n            '-' +\r\n            this.tempSelectedCycle[0]?.end_date,\r\n          selected_cycle_arr: [\r\n            this.tempSelectedCycle[0]?.start_date +\r\n              '-' +\r\n              this.tempSelectedCycle[0]?.end_date,\r\n          ],\r\n        },\r\n      };\r\n      this.setCycleToShow(businessCycleObject?.selectedCycle);\r\n      // this.cycleToShow = this.tempSelectedCycle[0]?.business_cycle;\r\n    } else {\r\n      let business_cycle: any = [];\r\n      let selected_cycle_arr: any = [];\r\n      this.tempSelectedCycle?.forEach((el: any) => {\r\n        business_cycle.push(el?.business_cycle);\r\n        selected_cycle_arr.push(el?.start_date + '-' + el?.end_date);\r\n      });\r\n      businessCycleObject = {\r\n        userId: this.userId,\r\n        selectedCycle: {\r\n          start_date: this.tempSelectedCycle[0]?.start_date,\r\n          end_date: this.tempSelectedCycle[1]?.end_date,\r\n          selected: true,\r\n          business_cycle: business_cycle,\r\n          selected_cycle:\r\n            this.tempSelectedCycle[0]?.start_date +\r\n            '-' +\r\n            this.tempSelectedCycle[1]?.end_date,\r\n          selected_cycle_arr: selected_cycle_arr,\r\n        },\r\n      };\r\n      this.setCycleToShow(businessCycleObject?.selectedCycle);\r\n      // this.cycleToShow = business_cycle[0].substring(0,11) + \" - \" + business_cycle[1].substring(business_cycle[1]?.length-11, business_cycle[1]?.lenth);\r\n    }\r\n    // this.setCycleToShow(businessCycleObject?.selectedCycle);\r\n    localStorage.setItem('businessCycle', JSON.stringify(businessCycleObject));\r\n    this.selectedBusinessCycle = businessCycleObject?.selectedCycle;\r\n    this.businessCycleChange.emit(this.selectedBusinessCycle);\r\n    this.businessCycleService.changeBusinessCycle$.next(true);\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   * when user click cancel then it will close the popover.\r\n   * remove temp value from term selected array and set the previous selected cycle in it.\r\n   */\r\n  cancelBusinessCycle() {\r\n    this.setTempSelectedCycle(this.selectedBusinessCycle);\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   * this will set the string of business cycle which  will display in the header.\r\n   * @param cycle object which is selected and apply. the same object will store in local storage.\r\n   */\r\n  setCycleToShow(cycle: any) {\r\n    if (cycle?.selected_cycle_arr?.length === 1) {\r\n      if (cycle?.business_cycle?.toLowerCase() == 'show future due dates') {\r\n        this.cycleToShow = 'Future Due Dates';\r\n      } else {\r\n        this.cycleToShow = cycle.business_cycle;\r\n      }\r\n    } else {\r\n      if (\r\n        cycle?.business_cycle?.length > 0 &&\r\n        cycle?.business_cycle[1]?.toLowerCase() == 'show future due dates'\r\n      ) {\r\n        this.cycleToShow = cycle?.business_cycle[0]?.substring(0, 11);\r\n      } else if (cycle?.business_cycle?.length) {\r\n        this.cycleToShow =\r\n          cycle?.business_cycle[0]?.substring(0, 11) +\r\n          ' - ' +\r\n          cycle?.business_cycle[1].substring(\r\n            cycle?.business_cycle[1]?.length - 11,\r\n            cycle?.business_cycle[1]?.lenth\r\n          );\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div\r\n  class=\"vc-business-cycle vx-pt-2 vx-pb-2\"\r\n  appPopover\r\n  (click)=\"businessCyclePop.popover()\"\r\n  position=\"left\"\r\n>\r\n  <div class=\"heading vx-fs-9 vx-tt-uppercase vx-mb-1 vx-lh-3\">\r\n    SHOWING DATA {{ cycleToShow === \"Show Future Due Dates\" ? \"For\" : \"From\" }}\r\n  </div>\r\n  <div class=\"vx-d-flex vx-align-center vx-justify-between vx-lh-4\">\r\n    <div class=\"vx-d-flex vx-align-center\">\r\n      <i class=\"icons calendar vx-fs-12 vx-mr-2\">&#xe996;</i>\r\n      <span class=\"vx-fs-11 vx-txt-white vx-d-inline-block\">{{\r\n        cycleToShow === \"Show Future Due Dates\"\r\n          ? \"Future Due Dates\"\r\n          : cycleToShow\r\n      }}</span>\r\n    </div>\r\n    <i class=\"icons arrow vx-fs-10 vx-mr-2\">&#xe9e8;</i>\r\n  </div>\r\n</div>\r\n\r\n<vui-popover #businessCyclePop [dontCloseonClick]=\"true\">\r\n  <div class=\"vc-business-cycle-popover-container\">\r\n    <div\r\n      class=\"vc-business-cycle-popover-container-top vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n    >\r\n      <p class=\"vx-fs-11 vx-fw-400 vx-label-txt vx-p-0 vx-m-0\">\r\n        You can select upto a max of two consecutive years\r\n      </p>\r\n    </div>\r\n    <div class=\"vc-business-cycle-popover-container-body\">\r\n      <ul class=\"vx-p-0 vx-m-0\">\r\n        <ng-container\r\n          *ngFor=\"let eachCycle of businessCycleList; let i = index\"\r\n        >\r\n          <li\r\n            *ngIf=\"\r\n              eachCycle?.business_cycle?.toLowerCase() ===\r\n              'show future due dates'\r\n            \"\r\n            class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n            [class.future-cycle]=\"true\"\r\n          >\r\n            <app-cs-checkbox\r\n              [ngValue]=\"businessCycleArr.includes(eachCycle?.business_cycle)\"\r\n              (ngValueChange)=\"selectCycle(eachCycle, i)\"\r\n              [disabled]=\"eachCycle?.isDisabled\"\r\n              >Show Future Due Dates</app-cs-checkbox\r\n            >\r\n            <i\r\n              class=\"icons info-icon vx-fs-12\"\r\n              [arTooltip]=\"\r\n                'This option lets you view data that lies outside the current business cycle and are due in the future.'\r\n              \"\r\n              placement=\"bottom\"\r\n              type=\"black\"\r\n              delay=\"0\"\r\n              [tooltipMandatory]=\"true\"\r\n              >&#xe91f;</i\r\n            >\r\n          </li>\r\n          <li\r\n            *ngIf=\"\r\n              eachCycle?.business_cycle?.toLowerCase() !==\r\n              'show future due dates'\r\n            \"\r\n            class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n          >\r\n            <app-cs-checkbox\r\n              [ngValue]=\"businessCycleArr.includes(eachCycle?.business_cycle)\"\r\n              (ngValueChange)=\"selectCycle(eachCycle, i)\"\r\n              [disabled]=\"eachCycle?.isDisabled\"\r\n              >{{ eachCycle?.start_date | dateFormat }} -\r\n              <ng-container>\r\n                {{ eachCycle?.end_date | dateFormat }}</ng-container\r\n              >\r\n            </app-cs-checkbox>\r\n          </li>\r\n        </ng-container>\r\n      </ul>\r\n    </div>\r\n    <div\r\n      class=\"vc-business-cycle-popover-container-footer vx-d-flex vx-justify-between vx-p-3\"\r\n    >\r\n      <button\r\n        (click)=\"businessCyclePop.closePopover('top')\"\r\n        class=\"white vx-fs-11 vx-fw-500 vx-d-flex vx-align-center vx-justify-center vx-tt-uppercase vx-p-0 vx-m-0 vx-txt-blue\"\r\n      >\r\n        CANCEL\r\n      </button>\r\n      <button\r\n        (click)=\"setBusinessCycle(); businessCyclePop.closePopover('top')\"\r\n        [class.disabled]=\"false\"\r\n        class=\"blue vx-fs-11 vx-fw-500 vx-d-flex vx-align-center vx-justify-center vx-tt-uppercase vx-p-0 vx-m-0 vx-txt-white\"\r\n      >\r\n        APPLY\r\n      </button>\r\n    </div>\r\n  </div>\r\n</vui-popover>\r\n"]}
|
|
279
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"business-cycle.component.js","sourceRoot":"","sources":["../../../../../../../projects/vc-layout/src/lib/components/header/business-cycle/business-cycle.component.ts","../../../../../../../projects/vc-layout/src/lib/components/header/business-cycle/business-cycle.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { AuthorizerService } from '@vcomply/authorizer';\r\nimport { BusinessCycleService } from '../../../shared/services/business-cycle.service';\r\nimport { ApiService } from '../../../shared/services/api.service';\r\n\r\n@Component({\r\n  selector: 'vc-business-cycle',\r\n  templateUrl: './business-cycle.component.html',\r\n  styleUrls: ['./business-cycle.component.less'],\r\n})\r\nexport class BusinessCycleComponent implements OnInit {\r\n  cycleToShow: string = 'Business Cycle';\r\n  businessCycleArr: Array<string> = [];\r\n  hiddenCycle: Array<number> = [];\r\n  tempBusinessCycleArr: Array<string> = [];\r\n  tempHiddenCycle: Array<number> = [0];\r\n  businessCyclesList: Array<any> = [];\r\n  businessCycleList!: Array<any>;\r\n  tempSelectedCycle: any[] = [];\r\n  userId: string = '';\r\n  selectedBusinessCycle!: any;\r\n  @Output() businessCycleChange = new EventEmitter();\r\n\r\n  @Input() orgDetails: any;\r\n  constructor(\r\n    private authService: AuthorizerService,\r\n    private businessCycleService: BusinessCycleService,\r\n    private apiService: ApiService\r\n  ) {\r\n    this.userId = this.authService.getMemberId() ?? '';\r\n    this.businessCycleService.isBusinessCycleAvailable();\r\n    this.setSelectedBusinessCycle();\r\n    this.getOrgDetails();\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  getOrgDetails() {\r\n    this.apiService.organizationDetail$.subscribe((res: any) => {\r\n      console.log('org Details', res);\r\n      if (res) {\r\n        this.setBusinessCycleKey(res.business_cycles_arr);\r\n        this.setBusinessCycle();\r\n      }\r\n    });\r\n  }\r\n\r\n  setSelectedBusinessCycle() {\r\n    this.businessCycleService.selectedBusinessCycle$.subscribe((res: any) => {\r\n      if (res) {\r\n        console.log('res ==>', res);\r\n        this.selectedBusinessCycle = res;\r\n        this.setTempSelectedCycle(res);\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   * it will set a new key in every cycle\r\n   * key will use for disabled or enable the cycle from business cycle list.\r\n   * @param businessCycle this the business cycle list\r\n   */\r\n  setBusinessCycleKey(businessCycle: any) {\r\n    this.businessCycleList = businessCycle;\r\n    if (this.businessCycleList.length)\r\n      this.businessCycleList.map((cycle: any) => {\r\n        cycle['isDisabled'] = false;\r\n      });\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   * it will check the cycle if it is not checked.\r\n   * if it has checked then it will uncheck that cycle.\r\n   * @param cycle checked or unchecked cycle from business cycle list.\r\n   * @param index it give the index value of business cycle list which is selected.\r\n   */\r\n  selectCycle(cycle: any, index: number) {\r\n    const isExist = this.tempSelectedCycle.findIndex(\r\n      (el: any) => el.start_date == cycle.start_date\r\n    );\r\n    if (isExist >= 0) {\r\n      this.tempSelectedCycle.splice(isExist, 1);\r\n    } else if (this.tempSelectedCycle?.length === 0) {\r\n      this.tempSelectedCycle.push(cycle);\r\n    } else {\r\n      const selectedIndex = this.businessCycleList.findIndex(\r\n        (el: any) => el.start_date == this.tempSelectedCycle[0]?.start_date\r\n      );\r\n      if (selectedIndex < index) {\r\n        this.tempSelectedCycle.unshift(cycle);\r\n      } else {\r\n        this.tempSelectedCycle.push(cycle);\r\n      }\r\n    }\r\n    this.setCycleEnableDisable();\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   *\r\n   * need to check cycle includes in selected cycle array\r\n   * Determines whether selected cycle is\r\n   * @param selectedCycle selected Cycle which user checked or auto selected cycle.\r\n   * @param cycle all indivisible cycle of business cycle of the organization.\r\n   * @returns boolean value is cycle exist in selected cycle or not.\r\n   */\r\n\r\n  isSelectedCycle(selectedCycle: any, cycle: any) {\r\n    let isSelected = false;\r\n    selectedCycle.forEach((el: any): any => {\r\n      if (el.start_date == cycle.start_date) {\r\n        isSelected = true;\r\n      }\r\n    });\r\n    return isSelected;\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   *\r\n   * set selected businessCycle to temp business cycle indivisible if there is two selected cycle\r\n   * Sets temp selected cycle\r\n   * @param cycle selected business cycle from local storage\r\n   */\r\n  setTempSelectedCycle(cycle: any) {\r\n    this.tempSelectedCycle = [];\r\n    if (cycle?.selected_cycle_arr?.length === 1) {\r\n      this.tempSelectedCycle.push(cycle);\r\n      this.setCycleToShow(cycle);\r\n      // this.cycleToShow = cycle.business_cycle;\r\n    } else {\r\n      cycle?.selected_cycle_arr?.forEach((el: any, i: number) => {\r\n        let payload = {\r\n          start_date: el.substring(0, 10),\r\n          end_date: el.substring(el?.length - 10, el?.lenth),\r\n          selected: true,\r\n          business_cycle: cycle?.business_cycle[i],\r\n          selected_cycle: cycle?.selected_cycle[i],\r\n          selected_cycle_arr: [el],\r\n        };\r\n        this.tempSelectedCycle.push(payload);\r\n      });\r\n      this.setCycleToShow(cycle);\r\n      // this.cycleToShow = cycle?.business_cycle[0]?.substring(0,11) + \" - \" + cycle?.business_cycle[1].substring(cycle?.business_cycle[1]?.length-11, cycle?.business_cycle[1]?.lenth);\r\n    }\r\n    // this.setCycleToShow(cycle);\r\n    this.setCycleEnableDisable();\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   *  when user select one cycle then their besides cycles are enable and other are disabled.\r\n   *  if user select two cycles then all the cycles get disabled except selected cycles.\r\n   *\r\n   *  In businessCycleList array we set a isDisabled key, we are set it true when need to disabled the cycle.\r\n   */\r\n  setCycleEnableDisable() {\r\n    if (!this.tempSelectedCycle?.length) {\r\n      if (this.businessCycleList?.length)\r\n        this.businessCycleList.map((cycle: any) => {\r\n          cycle['isDisabled'] = false;\r\n        });\r\n    } else if (this.tempSelectedCycle?.length === 1) {\r\n      const index = this.businessCycleList?.findIndex(\r\n        (el: any) => el.start_date == this.tempSelectedCycle[0].start_date\r\n      );\r\n      this.businessCycleList?.forEach((cycle: any, i: number) => {\r\n        if (index - 1 === i || index === i || index + 1 === i) {\r\n          cycle.isDisabled = false;\r\n        } else {\r\n          cycle.isDisabled = true;\r\n        }\r\n      });\r\n    } else {\r\n      this.businessCycleList?.forEach((cycle: any) => {\r\n        let isDisabled = true;\r\n        this.tempSelectedCycle.forEach((el: any) => {\r\n          if (cycle.start_date == el.start_date) {\r\n            isDisabled = false;\r\n          }\r\n        });\r\n        cycle.isDisabled = isDisabled;\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   *  When user click apply then selected cycle is set in local storage.\r\n   *\r\n   */\r\n  setBusinessCycle() {\r\n    let businessCycleObject: any = {};\r\n    if (this.tempSelectedCycle?.length === 1) {\r\n      businessCycleObject = {\r\n        userId: this.userId,\r\n        selectedCycle: {\r\n          start_date: this.tempSelectedCycle[0]?.start_date,\r\n          end_date: this.tempSelectedCycle[0]?.end_date,\r\n          selected: true,\r\n          business_cycle: this.tempSelectedCycle[0]?.business_cycle,\r\n          selected_cycle:\r\n            this.tempSelectedCycle[0]?.start_date +\r\n            '-' +\r\n            this.tempSelectedCycle[0]?.end_date,\r\n          selected_cycle_arr: [\r\n            this.tempSelectedCycle[0]?.start_date +\r\n              '-' +\r\n              this.tempSelectedCycle[0]?.end_date,\r\n          ],\r\n        },\r\n      };\r\n      this.setCycleToShow(businessCycleObject?.selectedCycle);\r\n      // this.cycleToShow = this.tempSelectedCycle[0]?.business_cycle;\r\n    } else {\r\n      let business_cycle: any = [];\r\n      let selected_cycle_arr: any = [];\r\n      this.tempSelectedCycle?.forEach((el: any) => {\r\n        business_cycle.push(el?.business_cycle);\r\n        selected_cycle_arr.push(el?.start_date + '-' + el?.end_date);\r\n      });\r\n      businessCycleObject = {\r\n        userId: this.userId,\r\n        selectedCycle: {\r\n          start_date: this.tempSelectedCycle[0]?.start_date,\r\n          end_date: this.tempSelectedCycle[1]?.end_date,\r\n          selected: true,\r\n          business_cycle: business_cycle,\r\n          selected_cycle:\r\n            this.tempSelectedCycle[0]?.start_date +\r\n            '-' +\r\n            this.tempSelectedCycle[1]?.end_date,\r\n          selected_cycle_arr: selected_cycle_arr,\r\n        },\r\n      };\r\n      this.setCycleToShow(businessCycleObject?.selectedCycle);\r\n      // this.cycleToShow = business_cycle[0].substring(0,11) + \" - \" + business_cycle[1].substring(business_cycle[1]?.length-11, business_cycle[1]?.lenth);\r\n    }\r\n    // this.setCycleToShow(businessCycleObject?.selectedCycle);\r\n    localStorage.setItem('businessCycle', JSON.stringify(businessCycleObject));\r\n    this.selectedBusinessCycle = businessCycleObject?.selectedCycle;\r\n    this.businessCycleChange.emit(this.selectedBusinessCycle);\r\n    this.businessCycleService.changeBusinessCycle$.next(true);\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   * when user click cancel then it will close the popover.\r\n   * remove temp value from term selected array and set the previous selected cycle in it.\r\n   */\r\n  cancelBusinessCycle() {\r\n    this.setTempSelectedCycle(this.selectedBusinessCycle);\r\n  }\r\n\r\n  /**\r\n   * #### Description\r\n   * this will set the string of business cycle which  will display in the header.\r\n   * @param cycle object which is selected and apply. the same object will store in local storage.\r\n   */\r\n  setCycleToShow(cycle: any) {\r\n    if (cycle?.selected_cycle_arr?.length === 1) {\r\n      if (cycle?.business_cycle?.toLowerCase() == 'show future due dates') {\r\n        this.cycleToShow = 'Future Due Dates';\r\n      } else {\r\n        this.cycleToShow = cycle.business_cycle;\r\n      }\r\n    } else {\r\n      if (\r\n        cycle?.business_cycle?.length > 0 &&\r\n        cycle?.business_cycle[1]?.toLowerCase() == 'show future due dates'\r\n      ) {\r\n        this.cycleToShow = cycle?.business_cycle[0]?.substring(0, 11);\r\n      } else if (cycle?.business_cycle?.length) {\r\n        this.cycleToShow =\r\n          cycle?.business_cycle[0]?.substring(0, 11) +\r\n          ' - ' +\r\n          cycle?.business_cycle[1].substring(\r\n            cycle?.business_cycle[1]?.length - 11,\r\n            cycle?.business_cycle[1]?.lenth\r\n          );\r\n      }\r\n    }\r\n  }\r\n}\r\n","<div\r\n  class=\"vc-business-cycle vx-pt-2 vx-pb-2\"\r\n  appPopover\r\n  (click)=\"businessCyclePop.popover()\"\r\n  position=\"left\"\r\n>\r\n  <div class=\"heading vx-fs-9 vx-tt-uppercase vx-mb-1 vx-lh-3\">\r\n    SHOWING DATA {{ cycleToShow === \"Show Future Due Dates\" ? \"For\" : \"From\" }}\r\n  </div>\r\n  <div class=\"vx-d-flex vx-align-center vx-justify-between vx-lh-4\">\r\n    <div class=\"vx-d-flex vx-align-center\">\r\n      <i class=\"icons calendar vx-fs-12 vx-mr-2\">&#xe996;</i>\r\n      <span class=\"vx-fs-11 vx-txt-white vx-d-inline-block\">{{\r\n        cycleToShow === \"Show Future Due Dates\"\r\n          ? \"Future Due Dates\"\r\n          : cycleToShow\r\n      }}</span>\r\n    </div>\r\n    <i class=\"icons arrow vx-fs-10 vx-mr-2\">&#xe9e8;</i>\r\n  </div>\r\n</div>\r\n\r\n<vui-popover #businessCyclePop [dontCloseonClick]=\"true\">\r\n  <div class=\"vc-business-cycle-popover-container\">\r\n    <div\r\n      class=\"vc-business-cycle-popover-container-top vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n    >\r\n      <p class=\"vx-fs-11 vx-fw-400 vx-label-txt vx-p-0 vx-m-0\">\r\n        You can select upto a max of two consecutive years\r\n      </p>\r\n    </div>\r\n    <div class=\"vc-business-cycle-popover-container-body\">\r\n      <ul class=\"vx-p-0 vx-m-0\">\r\n        <ng-container\r\n          *ngFor=\"let eachCycle of businessCycleList; let i = index\"\r\n        >\r\n          <li\r\n            *ngIf=\"\r\n              eachCycle?.business_cycle?.toLowerCase() ===\r\n              'show future due dates'\r\n            \"\r\n            class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n            [class.future-cycle]=\"true\"\r\n          >\r\n            <app-cs-checkbox\r\n              [ngValue]=\"isSelectedCycle(tempSelectedCycle, eachCycle)\"\r\n              (ngValueChange)=\"selectCycle(eachCycle, i)\"\r\n              [disabled]=\"eachCycle?.isDisabled\"\r\n              >Show Future Due Dates</app-cs-checkbox\r\n            >\r\n            <i\r\n              class=\"icons info-icon vx-fs-12\"\r\n              [arTooltip]=\"\r\n                'This option lets you view data that lies outside the current business cycle and are due in the future.'\r\n              \"\r\n              placement=\"bottom\"\r\n              type=\"black\"\r\n              delay=\"0\"\r\n              [tooltipMandatory]=\"true\"\r\n              >&#xe91f;</i\r\n            >\r\n          </li>\r\n          <li\r\n            *ngIf=\"\r\n              eachCycle?.business_cycle?.toLowerCase() !==\r\n              'show future due dates'\r\n            \"\r\n            class=\"vx-d-flex vx-align-center vx-pt-2 vx-pb-2 vx-pl-3 vx-pr-3\"\r\n          >\r\n            <app-cs-checkbox\r\n              [ngValue]=\"isSelectedCycle(tempSelectedCycle, eachCycle)\"\r\n              (ngValueChange)=\"selectCycle(eachCycle, i)\"\r\n              [disabled]=\"eachCycle?.isDisabled\"\r\n              >{{ eachCycle?.start_date | dateFormat }} -\r\n              <ng-container>\r\n                {{ eachCycle?.end_date | dateFormat }}</ng-container\r\n              >\r\n            </app-cs-checkbox>\r\n          </li>\r\n        </ng-container>\r\n      </ul>\r\n    </div>\r\n    <div\r\n      class=\"vc-business-cycle-popover-container-footer vx-d-flex vx-justify-between vx-p-3\"\r\n    >\r\n      <button\r\n        (click)=\"businessCyclePop.closePopover('top')\"\r\n        class=\"white vx-fs-11 vx-fw-500 vx-d-flex vx-align-center vx-justify-center vx-tt-uppercase vx-p-0 vx-m-0 vx-txt-blue\"\r\n      >\r\n        CANCEL\r\n      </button>\r\n      <button\r\n        (click)=\"setBusinessCycle(); businessCyclePop.closePopover('top')\"\r\n        [class.disabled]=\"false\"\r\n        class=\"blue vx-fs-11 vx-fw-500 vx-d-flex vx-align-center vx-justify-center vx-tt-uppercase vx-p-0 vx-m-0 vx-txt-white\"\r\n      >\r\n        APPLY\r\n      </button>\r\n    </div>\r\n  </div>\r\n</vui-popover>\r\n"]}
|