vc-layout 1.0.3 → 1.0.4
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.
|
@@ -178,65 +178,54 @@ export class BusinessCycleComponent {
|
|
|
178
178
|
*
|
|
179
179
|
*/
|
|
180
180
|
setBusinessCycle() {
|
|
181
|
-
|
|
181
|
+
const combinedDates = this.businessCycleService.convertNumericAlpha(this.businessCycleList[0]?.start_date +
|
|
182
|
+
this.businessCycleList[0]?.end_date);
|
|
183
|
+
const isFutureDates = (cycle) => cycle?.business_cycle === combinedDates &&
|
|
184
|
+
this.businessCycleList[0]?.business_cycle === FUTURE_DATES;
|
|
185
|
+
let businessCycleObject = {
|
|
186
|
+
userId: this.userId,
|
|
187
|
+
selectedCycle: {
|
|
188
|
+
selected: true,
|
|
189
|
+
business_cycle: [],
|
|
190
|
+
selected_cycle_arr: [],
|
|
191
|
+
},
|
|
192
|
+
};
|
|
182
193
|
if (this.tempSelectedCycle?.length === 1) {
|
|
183
|
-
businessCycleObject
|
|
184
|
-
userId: this.userId,
|
|
185
|
-
selectedCycle: {
|
|
186
|
-
start_date: this.tempSelectedCycle[0]?.start_date,
|
|
187
|
-
end_date: this.tempSelectedCycle[0]?.end_date,
|
|
188
|
-
selected: true,
|
|
189
|
-
business_cycle: this.tempSelectedCycle[0]?.business_cycle,
|
|
190
|
-
selected_cycle: this.tempSelectedCycle[0]?.start_date +
|
|
191
|
-
'-' +
|
|
192
|
-
this.tempSelectedCycle[0]?.end_date,
|
|
193
|
-
selected_cycle_arr: [
|
|
194
|
-
this.tempSelectedCycle[0]?.start_date +
|
|
195
|
-
'-' +
|
|
196
|
-
this.tempSelectedCycle[0]?.end_date,
|
|
197
|
-
],
|
|
198
|
-
},
|
|
199
|
-
};
|
|
200
|
-
this.setCycleToShow(businessCycleObject?.selectedCycle);
|
|
201
|
-
// this.cycleToShow = this.tempSelectedCycle[0]?.business_cycle;
|
|
194
|
+
this.setSingleSelectedCycle(businessCycleObject, isFutureDates);
|
|
202
195
|
}
|
|
203
196
|
else {
|
|
204
|
-
|
|
205
|
-
let selected_cycle_arr = [];
|
|
206
|
-
const combinedDates = this.businessCycleService.convertNumericAlpha(this.businessCycleList[0]?.start_date +
|
|
207
|
-
this.businessCycleList[0]?.end_date);
|
|
208
|
-
this.tempSelectedCycle?.forEach((el) => {
|
|
209
|
-
if (el?.business_cycle === combinedDates &&
|
|
210
|
-
this.businessCycleList[0]?.business_cycle === FUTURE_DATES) {
|
|
211
|
-
business_cycle.push(FUTURE_DATES);
|
|
212
|
-
}
|
|
213
|
-
else {
|
|
214
|
-
business_cycle.push(el?.business_cycle);
|
|
215
|
-
}
|
|
216
|
-
selected_cycle_arr.push(el?.start_date + '-' + el?.end_date);
|
|
217
|
-
});
|
|
218
|
-
businessCycleObject = {
|
|
219
|
-
userId: this.userId,
|
|
220
|
-
selectedCycle: {
|
|
221
|
-
start_date: this.tempSelectedCycle[0]?.start_date,
|
|
222
|
-
end_date: this.tempSelectedCycle[1]?.end_date,
|
|
223
|
-
selected: true,
|
|
224
|
-
business_cycle: business_cycle,
|
|
225
|
-
selected_cycle: this.tempSelectedCycle[0]?.start_date +
|
|
226
|
-
'-' +
|
|
227
|
-
this.tempSelectedCycle[1]?.end_date,
|
|
228
|
-
selected_cycle_arr: selected_cycle_arr,
|
|
229
|
-
},
|
|
230
|
-
};
|
|
231
|
-
this.setCycleToShow(businessCycleObject?.selectedCycle);
|
|
232
|
-
// this.cycleToShow = business_cycle[0].substring(0,11) + " - " + business_cycle[1].substring(business_cycle[1]?.length-11, business_cycle[1]?.lenth);
|
|
197
|
+
this.setMultipleSelectedCycles(businessCycleObject, isFutureDates);
|
|
233
198
|
}
|
|
234
|
-
|
|
199
|
+
this.setCycleToShow(businessCycleObject?.selectedCycle);
|
|
235
200
|
localStorage.setItem('businessCycle', JSON.stringify(businessCycleObject));
|
|
236
201
|
this.selectedBusinessCycle = businessCycleObject?.selectedCycle;
|
|
237
202
|
this.businessCycleChange.emit(this.selectedBusinessCycle);
|
|
238
203
|
this.businessCycleService.changeBusinessCycle$.next(true);
|
|
239
204
|
}
|
|
205
|
+
setSingleSelectedCycle(businessCycleObject, isFutureDates) {
|
|
206
|
+
const cycle = this.tempSelectedCycle[0];
|
|
207
|
+
if (isFutureDates(cycle)) {
|
|
208
|
+
cycle.business_cycle = FUTURE_DATES;
|
|
209
|
+
}
|
|
210
|
+
Object.assign(businessCycleObject?.selectedCycle, {
|
|
211
|
+
start_date: cycle?.start_date,
|
|
212
|
+
end_date: cycle?.end_date,
|
|
213
|
+
business_cycle: cycle?.business_cycle,
|
|
214
|
+
selected_cycle: `${cycle?.start_date}-${cycle?.end_date}`,
|
|
215
|
+
selected_cycle_arr: [`${cycle?.start_date}-${cycle?.end_date}`],
|
|
216
|
+
});
|
|
217
|
+
}
|
|
218
|
+
setMultipleSelectedCycles(businessCycleObject, isFutureDates) {
|
|
219
|
+
this.tempSelectedCycle?.forEach((cycle) => {
|
|
220
|
+
businessCycleObject?.selectedCycle.business_cycle?.push(isFutureDates(cycle) ? FUTURE_DATES : cycle?.business_cycle);
|
|
221
|
+
businessCycleObject?.selectedCycle.selected_cycle_arr?.push(`${cycle?.start_date}-${cycle?.end_date}`);
|
|
222
|
+
});
|
|
223
|
+
businessCycleObject.selectedCycle.start_date =
|
|
224
|
+
this.tempSelectedCycle[0]?.start_date;
|
|
225
|
+
businessCycleObject.selectedCycle.end_date =
|
|
226
|
+
this.tempSelectedCycle[1]?.end_date;
|
|
227
|
+
businessCycleObject.selectedCycle.selected_cycle = `${businessCycleObject?.selectedCycle?.start_date}-${businessCycleObject?.selectedCycle?.end_date}`;
|
|
228
|
+
}
|
|
240
229
|
/**
|
|
241
230
|
* #### Description
|
|
242
231
|
* when user click cancel then it will close the popover.
|
|
@@ -283,4 +272,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
283
272
|
}], orgDetails: [{
|
|
284
273
|
type: Input
|
|
285
274
|
}] } });
|
|
286
|
-
//# 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\nimport { FUTURE_DATES } from '../../../constants/business-cycle.constant';\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: number = 0;\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.getUserId() ?? 0;\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      if (res) {\r\n        this.setBusinessCycleKey(res.business_cycles_arr);\r\n        this.setBusinessCycle();\r\n        this.setCycleEnableDisable();\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        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.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      const combinedDates = this.businessCycleService.convertNumericAlpha(\r\n        this.businessCycleList[0]?.start_date +\r\n          this.businessCycleList[0]?.end_date\r\n      );\r\n      this.tempSelectedCycle?.forEach((el: any) => {\r\n        if (\r\n          el?.business_cycle === combinedDates &&\r\n          this.businessCycleList[0]?.business_cycle === FUTURE_DATES\r\n        ) {\r\n          business_cycle.push(FUTURE_DATES);\r\n        } else {\r\n          business_cycle.push(el?.business_cycle);\r\n        }\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"]}
|
|
275
|
+
//# 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\nimport { FUTURE_DATES } from '../../../constants/business-cycle.constant';\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: number = 0;\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.getUserId() ?? 0;\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      if (res) {\r\n        this.setBusinessCycleKey(res.business_cycles_arr);\r\n        this.setBusinessCycle();\r\n        this.setCycleEnableDisable();\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        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.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    const combinedDates = this.businessCycleService.convertNumericAlpha(\r\n      this.businessCycleList[0]?.start_date +\r\n        this.businessCycleList[0]?.end_date\r\n    );\r\n    const isFutureDates = (cycle: any) =>\r\n      cycle?.business_cycle === combinedDates &&\r\n      this.businessCycleList[0]?.business_cycle === FUTURE_DATES;\r\n\r\n    let businessCycleObject: any = {\r\n      userId: this.userId,\r\n      selectedCycle: {\r\n        selected: true,\r\n        business_cycle: [],\r\n        selected_cycle_arr: [],\r\n      },\r\n    };\r\n\r\n    if (this.tempSelectedCycle?.length === 1) {\r\n      this.setSingleSelectedCycle(businessCycleObject, isFutureDates);\r\n    } else {\r\n      this.setMultipleSelectedCycles(businessCycleObject, isFutureDates);\r\n    }\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  setSingleSelectedCycle(\r\n    businessCycleObject: any,\r\n    isFutureDates: (cycle: any) => boolean\r\n  ) {\r\n    const cycle = this.tempSelectedCycle[0];\r\n    if (isFutureDates(cycle)) {\r\n      cycle.business_cycle = FUTURE_DATES;\r\n    }\r\n    Object.assign(businessCycleObject?.selectedCycle, {\r\n      start_date: cycle?.start_date,\r\n      end_date: cycle?.end_date,\r\n      business_cycle: cycle?.business_cycle,\r\n      selected_cycle: `${cycle?.start_date}-${cycle?.end_date}`,\r\n      selected_cycle_arr: [`${cycle?.start_date}-${cycle?.end_date}`],\r\n    });\r\n  }\r\n\r\n  setMultipleSelectedCycles(\r\n    businessCycleObject: any,\r\n    isFutureDates: (cycle: any) => boolean\r\n  ) {\r\n    this.tempSelectedCycle?.forEach((cycle: any) => {\r\n      businessCycleObject?.selectedCycle.business_cycle?.push(\r\n        isFutureDates(cycle) ? FUTURE_DATES : cycle?.business_cycle\r\n      );\r\n      businessCycleObject?.selectedCycle.selected_cycle_arr?.push(\r\n        `${cycle?.start_date}-${cycle?.end_date}`\r\n      );\r\n    });\r\n\r\n    businessCycleObject.selectedCycle.start_date =\r\n      this.tempSelectedCycle[0]?.start_date;\r\n    businessCycleObject.selectedCycle.end_date =\r\n      this.tempSelectedCycle[1]?.end_date;\r\n    businessCycleObject.selectedCycle.selected_cycle = `${businessCycleObject?.selectedCycle?.start_date}-${businessCycleObject?.selectedCycle?.end_date}`;\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"]}
|
package/fesm2022/vc-layout.mjs
CHANGED
|
@@ -1768,65 +1768,54 @@ class BusinessCycleComponent {
|
|
|
1768
1768
|
*
|
|
1769
1769
|
*/
|
|
1770
1770
|
setBusinessCycle() {
|
|
1771
|
-
|
|
1771
|
+
const combinedDates = this.businessCycleService.convertNumericAlpha(this.businessCycleList[0]?.start_date +
|
|
1772
|
+
this.businessCycleList[0]?.end_date);
|
|
1773
|
+
const isFutureDates = (cycle) => cycle?.business_cycle === combinedDates &&
|
|
1774
|
+
this.businessCycleList[0]?.business_cycle === FUTURE_DATES;
|
|
1775
|
+
let businessCycleObject = {
|
|
1776
|
+
userId: this.userId,
|
|
1777
|
+
selectedCycle: {
|
|
1778
|
+
selected: true,
|
|
1779
|
+
business_cycle: [],
|
|
1780
|
+
selected_cycle_arr: [],
|
|
1781
|
+
},
|
|
1782
|
+
};
|
|
1772
1783
|
if (this.tempSelectedCycle?.length === 1) {
|
|
1773
|
-
businessCycleObject
|
|
1774
|
-
userId: this.userId,
|
|
1775
|
-
selectedCycle: {
|
|
1776
|
-
start_date: this.tempSelectedCycle[0]?.start_date,
|
|
1777
|
-
end_date: this.tempSelectedCycle[0]?.end_date,
|
|
1778
|
-
selected: true,
|
|
1779
|
-
business_cycle: this.tempSelectedCycle[0]?.business_cycle,
|
|
1780
|
-
selected_cycle: this.tempSelectedCycle[0]?.start_date +
|
|
1781
|
-
'-' +
|
|
1782
|
-
this.tempSelectedCycle[0]?.end_date,
|
|
1783
|
-
selected_cycle_arr: [
|
|
1784
|
-
this.tempSelectedCycle[0]?.start_date +
|
|
1785
|
-
'-' +
|
|
1786
|
-
this.tempSelectedCycle[0]?.end_date,
|
|
1787
|
-
],
|
|
1788
|
-
},
|
|
1789
|
-
};
|
|
1790
|
-
this.setCycleToShow(businessCycleObject?.selectedCycle);
|
|
1791
|
-
// this.cycleToShow = this.tempSelectedCycle[0]?.business_cycle;
|
|
1784
|
+
this.setSingleSelectedCycle(businessCycleObject, isFutureDates);
|
|
1792
1785
|
}
|
|
1793
1786
|
else {
|
|
1794
|
-
|
|
1795
|
-
let selected_cycle_arr = [];
|
|
1796
|
-
const combinedDates = this.businessCycleService.convertNumericAlpha(this.businessCycleList[0]?.start_date +
|
|
1797
|
-
this.businessCycleList[0]?.end_date);
|
|
1798
|
-
this.tempSelectedCycle?.forEach((el) => {
|
|
1799
|
-
if (el?.business_cycle === combinedDates &&
|
|
1800
|
-
this.businessCycleList[0]?.business_cycle === FUTURE_DATES) {
|
|
1801
|
-
business_cycle.push(FUTURE_DATES);
|
|
1802
|
-
}
|
|
1803
|
-
else {
|
|
1804
|
-
business_cycle.push(el?.business_cycle);
|
|
1805
|
-
}
|
|
1806
|
-
selected_cycle_arr.push(el?.start_date + '-' + el?.end_date);
|
|
1807
|
-
});
|
|
1808
|
-
businessCycleObject = {
|
|
1809
|
-
userId: this.userId,
|
|
1810
|
-
selectedCycle: {
|
|
1811
|
-
start_date: this.tempSelectedCycle[0]?.start_date,
|
|
1812
|
-
end_date: this.tempSelectedCycle[1]?.end_date,
|
|
1813
|
-
selected: true,
|
|
1814
|
-
business_cycle: business_cycle,
|
|
1815
|
-
selected_cycle: this.tempSelectedCycle[0]?.start_date +
|
|
1816
|
-
'-' +
|
|
1817
|
-
this.tempSelectedCycle[1]?.end_date,
|
|
1818
|
-
selected_cycle_arr: selected_cycle_arr,
|
|
1819
|
-
},
|
|
1820
|
-
};
|
|
1821
|
-
this.setCycleToShow(businessCycleObject?.selectedCycle);
|
|
1822
|
-
// this.cycleToShow = business_cycle[0].substring(0,11) + " - " + business_cycle[1].substring(business_cycle[1]?.length-11, business_cycle[1]?.lenth);
|
|
1787
|
+
this.setMultipleSelectedCycles(businessCycleObject, isFutureDates);
|
|
1823
1788
|
}
|
|
1824
|
-
|
|
1789
|
+
this.setCycleToShow(businessCycleObject?.selectedCycle);
|
|
1825
1790
|
localStorage.setItem('businessCycle', JSON.stringify(businessCycleObject));
|
|
1826
1791
|
this.selectedBusinessCycle = businessCycleObject?.selectedCycle;
|
|
1827
1792
|
this.businessCycleChange.emit(this.selectedBusinessCycle);
|
|
1828
1793
|
this.businessCycleService.changeBusinessCycle$.next(true);
|
|
1829
1794
|
}
|
|
1795
|
+
setSingleSelectedCycle(businessCycleObject, isFutureDates) {
|
|
1796
|
+
const cycle = this.tempSelectedCycle[0];
|
|
1797
|
+
if (isFutureDates(cycle)) {
|
|
1798
|
+
cycle.business_cycle = FUTURE_DATES;
|
|
1799
|
+
}
|
|
1800
|
+
Object.assign(businessCycleObject?.selectedCycle, {
|
|
1801
|
+
start_date: cycle?.start_date,
|
|
1802
|
+
end_date: cycle?.end_date,
|
|
1803
|
+
business_cycle: cycle?.business_cycle,
|
|
1804
|
+
selected_cycle: `${cycle?.start_date}-${cycle?.end_date}`,
|
|
1805
|
+
selected_cycle_arr: [`${cycle?.start_date}-${cycle?.end_date}`],
|
|
1806
|
+
});
|
|
1807
|
+
}
|
|
1808
|
+
setMultipleSelectedCycles(businessCycleObject, isFutureDates) {
|
|
1809
|
+
this.tempSelectedCycle?.forEach((cycle) => {
|
|
1810
|
+
businessCycleObject?.selectedCycle.business_cycle?.push(isFutureDates(cycle) ? FUTURE_DATES : cycle?.business_cycle);
|
|
1811
|
+
businessCycleObject?.selectedCycle.selected_cycle_arr?.push(`${cycle?.start_date}-${cycle?.end_date}`);
|
|
1812
|
+
});
|
|
1813
|
+
businessCycleObject.selectedCycle.start_date =
|
|
1814
|
+
this.tempSelectedCycle[0]?.start_date;
|
|
1815
|
+
businessCycleObject.selectedCycle.end_date =
|
|
1816
|
+
this.tempSelectedCycle[1]?.end_date;
|
|
1817
|
+
businessCycleObject.selectedCycle.selected_cycle = `${businessCycleObject?.selectedCycle?.start_date}-${businessCycleObject?.selectedCycle?.end_date}`;
|
|
1818
|
+
}
|
|
1830
1819
|
/**
|
|
1831
1820
|
* #### Description
|
|
1832
1821
|
* when user click cancel then it will close the popover.
|