@hxui/angular
Version:
An Angular library based on the [HXUI design system](https://hxui.io).
176 lines • 34.4 kB
JavaScript
import { DatePipe } from '@angular/common';
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
import { DropdownDirective } from '../dropdown/dropdown.directive';
import { DateRangePickerConfig } from './date-range-picker.config';
import { DateSelectionType, DisplayMode } from './date-range-picker.model';
import { fullIntervalList, IntervalItem } from './interval-option-model';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "./date-range-picker.config";
import * as i3 from "../tabs/tabset.component";
import * as i4 from "./date-range-picker-interval/date-range-picker-interval.component";
import * as i5 from "./date-range-picker-custom/date-range-picker-custom.component";
import * as i6 from "../dropdown/dropdown.directive";
import * as i7 from "../dropdown/dropdown-toggle.directive";
import * as i8 from "../dropdown/dropdown-menu.directive";
import * as i9 from "../tabs/tab.directive";
export class DateRangePickerComponent {
constructor(datePipe, dateRangePickerConfig) {
this.datePipe = datePipe;
this.dateRangePickerConfig = dateRangePickerConfig;
/** This attribute specifies the placeholder value of the components input element. */
this.placeholder = 'Date';
/** Adds the disabled html attribute to the components dropdown element. */
this.disabled = false;
/**
* Indicates that dropdown will be closed on item or document
* click, and after pressing ESC.
*/
this.autoClose = true;
/** Specifies the position the datepicker opens against the input element */
this.placement = 'bottom';
/** Specifies how tab(s) will be displayed. */
this.displayMode = DisplayMode.showTab;
/**
* A JavaScript Date object formatting string, formats the display
* of components current value.
*/
this.dateFormat = 'dd/MM/yyyy';
this.defaultDateRange = {
fromDate: new Date(),
toDate: new Date()
};
/** Specifies whether caret down icon is displayed to right of input */
this.showCaretDown = true;
/**
* Emits a Date Range Object containing fromDate and toDate
* selected from the DateRangePicker.
*/
this.onDateRangeSelected = new EventEmitter();
// import to DateSElectionType into the instance of this class
this.DateSelectionType = DateSelectionType;
this.currentTab = DateSelectionType.interval;
this.fromDate = new Date();
this.toDate = new Date();
this.selectedInterval = new IntervalItem('Today', 'day', 0, 'today');
}
ngOnInit() {
this.setInitialDateRange();
this.showTab = this.displayMode === DisplayMode.showTab;
this.showIntervalOnly = this.displayMode === DisplayMode.showIntervalOnly;
this.showCustomOnly = this.displayMode === DisplayMode.showCustomOnly;
this.generateIntervalOptionItems(this.intervalOptions || []);
}
setInitialDateRange() {
this.defaultDateRange = this.defaultDateRange || {
fromDate: new Date(),
toDate: new Date()
};
this.dateFormat = this.dateFormat || 'dd/MM/yyyy';
this.fromDate = this.defaultDateRange.fromDate;
this.toDate = this.defaultDateRange.toDate;
this._displayRange = this.createDateRange();
}
resetDateRange() {
this.fromDate = new Date();
this.toDate = new Date();
this._displayRange = this.createDateRange();
}
generateIntervalOptionItems(itemList) {
this.intervalList = fullIntervalList.filter(item => itemList.includes(item.displayName));
}
hide(closeDropdown) {
if (closeDropdown) {
this.dropdown.hide();
}
}
toggle() {
this.dropdown.toggle();
}
onCustomDateSelection(newCustomDate) {
// do not update range if undefined, null[], from > to
if (!newCustomDate ||
newCustomDate[0] == null ||
newCustomDate[1] == null ||
newCustomDate[0] > newCustomDate[1]) {
return null;
}
this.fromDate = newCustomDate[0];
this.toDate = newCustomDate[1];
this._displayRange = this.createDateRange();
this.onDateRangeSelected.emit({
fromDate: this.fromDate,
toDate: this.toDate
});
this.currentTab = DateSelectionType.custom;
this.selectedInterval = null;
}
onIntervalSelection(selectedItem) {
if (selectedItem) {
this.selectedInterval = selectedItem;
const today = new Date();
let calculatedDate;
if (selectedItem.unit === 'day') {
calculatedDate = new Date(today.getFullYear(), today.getMonth(), today.getDate() + selectedItem.count);
}
else if (selectedItem.unit === 'month') {
calculatedDate = new Date(today.getFullYear(), today.getMonth() + selectedItem.count, today.getDate());
}
else if (selectedItem.unit === 'year') {
calculatedDate = new Date(today.getFullYear() + selectedItem.count, today.getMonth(), today.getDate());
}
if (calculatedDate >= today) {
this.fromDate = today;
this.toDate = calculatedDate;
}
else {
this.fromDate = calculatedDate;
this.toDate = today;
}
this._displayRange = this.createDateRange();
this.onDateRangeSelected.emit({
fromDate: this.fromDate,
toDate: this.toDate
});
this.currentTab = DateSelectionType.interval;
}
}
createDateRange() {
const fromDateStr = this.datePipe.transform(this.fromDate, this.dateFormat);
const toDateStr = this.datePipe.transform(this.toDate, this.dateFormat);
if (fromDateStr === toDateStr) {
return fromDateStr;
}
return `${fromDateStr} - ${toDateStr}`;
}
}
DateRangePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DateRangePickerComponent, deps: [{ token: i1.DatePipe }, { token: i2.DateRangePickerConfig }], target: i0.ɵɵFactoryTarget.Component });
DateRangePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DateRangePickerComponent, selector: "hxa-date-range-picker", inputs: { intervalOptions: "intervalOptions", placeholder: "placeholder", disabled: "disabled", autoClose: "autoClose", placement: "placement", displayMode: "displayMode", dateFormat: "dateFormat", defaultDateRange: "defaultDateRange", showCaretDown: "showCaretDown" }, outputs: { onDateRangeSelected: "onDateRangeSelected" }, viewQueries: [{ propertyName: "dropdown", first: true, predicate: ["dropdown"], descendants: true, static: true }], ngImport: i0, template: "<div\r\n class=\"hx-dropdown\"\r\n hxDropdown\r\n #dropdown=\"hx-dropdown\"\r\n [autoClose]=\"autoClose\"\r\n [isDisabled]=\"disabled\"\r\n [placement]=\"placement\"\r\n>\r\n <button class=\"hx-button\" hxDropdownToggle type=\"button\">\r\n <span>\r\n <span class=\"is-text-weight-light\" *ngIf=\"!!placeholder\">\r\n {{ placeholder }}: \r\n </span>\r\n <span class=\"is-text-weight-bolder\">{{ _displayRange }}</span>\r\n </span>\r\n <span class=\"hx-icon-control\" *ngIf=\"showCaretDown\">\r\n <i class=\"icon icon-caret-down\"></i>\r\n </span>\r\n </button>\r\n <div \r\n class=\"hx-dropdown-menu dropdown-menu-wider py-0 px-0\" \r\n *hxDropdownMenu\r\n >\r\n <div class=\"hxa-tabs\" *ngIf=\"showTab\">\r\n <hx-tabset [justified]=\"true\" contentCustomClass=\"pa-0\">\r\n <hx-tab\r\n heading=\"INTERVAL\"\r\n [active]=\"currentTab === DateSelectionType.interval\"\r\n >\r\n <hxa-date-range-picker-interval\r\n [intervalOptionList]=\"intervalList\"\r\n [currentSelectedInterval]=\"selectedInterval\"\r\n (newSelectedInterval)=\"onIntervalSelection($event)\"\r\n (closeDropdown)=\"hide($event)\"\r\n ></hxa-date-range-picker-interval>\r\n </hx-tab>\r\n <hx-tab\r\n heading=\"CUSTOM\"\r\n [active]=\"currentTab === DateSelectionType.custom\"\r\n >\r\n <hxa-date-range-picker-custom\r\n [currentFromDate]=\"fromDate\"\r\n [currentToDate]=\"toDate\"\r\n [dateFormat]=\"dateFormat\"\r\n (newSelectedCustomDate)=\"onCustomDateSelection($event)\"\r\n (closeDropdown)=\"hide($event)\"\r\n ></hxa-date-range-picker-custom>\r\n </hx-tab>\r\n </hx-tabset>\r\n </div>\r\n <div \r\n *ngIf=\"!showTab && showIntervalOnly\" \r\n class=\"internal-custom-tab pa-0\"\r\n >\r\n <hxa-date-range-picker-interval\r\n [intervalOptionList]=\"intervalList\"\r\n [currentSelectedInterval]=\"selectedInterval\"\r\n (newSelectedInterval)=\"onIntervalSelection($event)\"\r\n (closeDropdown)=\"hide($event)\"\r\n ></hxa-date-range-picker-interval>\r\n </div>\r\n <div\r\n *ngIf=\"!showTab && showCustomOnly\"\r\n class=\"internal-custom-tab px-0 pb-0\"\r\n >\r\n <hxa-date-range-picker-custom\r\n [currentFromDate]=\"fromDate\"\r\n [currentToDate]=\"toDate\"\r\n [dateFormat]=\"dateFormat\"\r\n (newSelectedCustomDate)=\"onCustomDateSelection($event)\"\r\n (closeDropdown)=\"hide($event)\"\r\n ></hxa-date-range-picker-custom>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".internal-custom-tab{padding:1rem}.dropdown-menu-wider{width:320px}\n"], components: [{ type: i3.TabsetComponent, selector: "hx-tabset", inputs: ["vertical", "justified", "hasInfo", "type", "contentCustomClass", "stickyHeader", "stickyHeaderOffset", "tag", "changeFn"] }, { type: i4.DateRangePickerIntervalComponent, selector: "hxa-date-range-picker-interval", inputs: ["intervalOptionList", "currentSelectedInterval"], outputs: ["newSelectedInterval", "closeDropdown"] }, { type: i5.DateRangePickerCustomComponent, selector: "hxa-date-range-picker-custom", inputs: ["currentFromDate", "currentToDate", "dateFormat"], outputs: ["newSelectedCustomDate", "closeDropdown"] }], directives: [{ type: i6.DropdownDirective, selector: "[hxaDropdown],[hxDropdown]", inputs: ["placement", "autoClose", "isDisabled", "showDelay", "hideDelay", "maxWidthRelativeTo", "minWidthRelativeTo", "offsetY", "offsetX", "createClipPathMask"], outputs: ["isOpenChange", "onShown", "onHidden"], exportAs: ["hx-dropdown", "hxa-dropdown"] }, { type: i7.DropdownToggleDirective, selector: "[hxDropdownToggle],[hxaDropdownToggle]", exportAs: ["hx-dropdown-toggle"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.DropdownMenuDirective, selector: "[hxDropdownMenu],[hxaDropdownMenu]", exportAs: ["hx-dropdown-menu"] }, { type: i9.TabDirective, selector: "hx-tab, [hx-tab]", inputs: ["heading", "id", "disabled", "removable", "customClass", "active"], outputs: ["select", "deselect", "removed"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DateRangePickerComponent, decorators: [{
type: Component,
args: [{ selector: 'hxa-date-range-picker', template: "<div\r\n class=\"hx-dropdown\"\r\n hxDropdown\r\n #dropdown=\"hx-dropdown\"\r\n [autoClose]=\"autoClose\"\r\n [isDisabled]=\"disabled\"\r\n [placement]=\"placement\"\r\n>\r\n <button class=\"hx-button\" hxDropdownToggle type=\"button\">\r\n <span>\r\n <span class=\"is-text-weight-light\" *ngIf=\"!!placeholder\">\r\n {{ placeholder }}: \r\n </span>\r\n <span class=\"is-text-weight-bolder\">{{ _displayRange }}</span>\r\n </span>\r\n <span class=\"hx-icon-control\" *ngIf=\"showCaretDown\">\r\n <i class=\"icon icon-caret-down\"></i>\r\n </span>\r\n </button>\r\n <div \r\n class=\"hx-dropdown-menu dropdown-menu-wider py-0 px-0\" \r\n *hxDropdownMenu\r\n >\r\n <div class=\"hxa-tabs\" *ngIf=\"showTab\">\r\n <hx-tabset [justified]=\"true\" contentCustomClass=\"pa-0\">\r\n <hx-tab\r\n heading=\"INTERVAL\"\r\n [active]=\"currentTab === DateSelectionType.interval\"\r\n >\r\n <hxa-date-range-picker-interval\r\n [intervalOptionList]=\"intervalList\"\r\n [currentSelectedInterval]=\"selectedInterval\"\r\n (newSelectedInterval)=\"onIntervalSelection($event)\"\r\n (closeDropdown)=\"hide($event)\"\r\n ></hxa-date-range-picker-interval>\r\n </hx-tab>\r\n <hx-tab\r\n heading=\"CUSTOM\"\r\n [active]=\"currentTab === DateSelectionType.custom\"\r\n >\r\n <hxa-date-range-picker-custom\r\n [currentFromDate]=\"fromDate\"\r\n [currentToDate]=\"toDate\"\r\n [dateFormat]=\"dateFormat\"\r\n (newSelectedCustomDate)=\"onCustomDateSelection($event)\"\r\n (closeDropdown)=\"hide($event)\"\r\n ></hxa-date-range-picker-custom>\r\n </hx-tab>\r\n </hx-tabset>\r\n </div>\r\n <div \r\n *ngIf=\"!showTab && showIntervalOnly\" \r\n class=\"internal-custom-tab pa-0\"\r\n >\r\n <hxa-date-range-picker-interval\r\n [intervalOptionList]=\"intervalList\"\r\n [currentSelectedInterval]=\"selectedInterval\"\r\n (newSelectedInterval)=\"onIntervalSelection($event)\"\r\n (closeDropdown)=\"hide($event)\"\r\n ></hxa-date-range-picker-interval>\r\n </div>\r\n <div\r\n *ngIf=\"!showTab && showCustomOnly\"\r\n class=\"internal-custom-tab px-0 pb-0\"\r\n >\r\n <hxa-date-range-picker-custom\r\n [currentFromDate]=\"fromDate\"\r\n [currentToDate]=\"toDate\"\r\n [dateFormat]=\"dateFormat\"\r\n (newSelectedCustomDate)=\"onCustomDateSelection($event)\"\r\n (closeDropdown)=\"hide($event)\"\r\n ></hxa-date-range-picker-custom>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".internal-custom-tab{padding:1rem}.dropdown-menu-wider{width:320px}\n"] }]
}], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i2.DateRangePickerConfig }]; }, propDecorators: { dropdown: [{
type: ViewChild,
args: ['dropdown', { static: true }]
}], intervalOptions: [{
type: Input
}], placeholder: [{
type: Input
}], disabled: [{
type: Input
}], autoClose: [{
type: Input
}], placement: [{
type: Input
}], displayMode: [{
type: Input
}], dateFormat: [{
type: Input
}], defaultDateRange: [{
type: Input
}], showCaretDown: [{
type: Input
}], onDateRangeSelected: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker.component.js","sourceRoot":"","sources":["../../../../../projects/hx-ui/src/lib/date-range-picker/date-range-picker.component.ts","../../../../../projects/hx-ui/src/lib/date-range-picker/date-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\r\nimport {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { DropdownDirective } from '../dropdown/dropdown.directive';\r\nimport { DateRangePickerConfig } from './date-range-picker.config';\r\nimport {\r\n  DateRange,\r\n  DateSelectionType,\r\n  DisplayMode\r\n} from './date-range-picker.model';\r\nimport { fullIntervalList, IntervalItem } from './interval-option-model';\r\n\r\n@Component({\r\n  selector: 'hxa-date-range-picker',\r\n  templateUrl: './date-range-picker.component.html',\r\n  styleUrls: ['./date-range-picker.component.scss']\r\n})\r\nexport class DateRangePickerComponent implements OnInit {\r\n  @ViewChild('dropdown', { static: true }) dropdown: DropdownDirective;\r\n\r\n  /** Specifies interval options displayed under interval selection tab. */\r\n  @Input() intervalOptions: string[];\r\n\r\n  /** This attribute specifies the placeholder value of the components input element. */\r\n  @Input() placeholder = 'Date';\r\n\r\n  /** Adds the disabled html attribute to the components dropdown element. */\r\n  @Input() disabled = false;\r\n\r\n  /**\r\n   * Indicates that dropdown will be closed on item or document\r\n   * click, and after pressing ESC.\r\n   */\r\n  @Input() autoClose = true;\r\n\r\n  /** Specifies the position the datepicker opens against the input element */\r\n  @Input() placement: 'top' | 'bottom' | 'left' | 'right' = 'bottom';\r\n\r\n  /** Specifies how tab(s) will be displayed. */\r\n  @Input() displayMode: DisplayMode = DisplayMode.showTab;\r\n\r\n  /**\r\n   * A JavaScript Date object formatting string, formats the display\r\n   * of components current value.\r\n   */\r\n  @Input() dateFormat = 'dd/MM/yyyy';\r\n\r\n  @Input() defaultDateRange: DateRange = {\r\n    fromDate: new Date(),\r\n    toDate: new Date()\r\n  };\r\n\r\n  /** Specifies whether caret down icon is displayed to right of input */\r\n  @Input() showCaretDown = true;\r\n\r\n  /**\r\n   * Emits a Date Range Object containing fromDate and toDate\r\n   * selected from the DateRangePicker.\r\n   */\r\n  @Output() onDateRangeSelected = new EventEmitter<DateRange>();\r\n\r\n  constructor(\r\n    private datePipe: DatePipe,\r\n    private dateRangePickerConfig: DateRangePickerConfig\r\n  ) {}\r\n\r\n  // import to DateSElectionType into the instance of this class\r\n  DateSelectionType = DateSelectionType;\r\n  currentTab: DateSelectionType = DateSelectionType.interval;\r\n  fromDate: Date = new Date();\r\n  toDate: Date = new Date();\r\n  _displayRange: string;\r\n\r\n  showIntervalOnly: boolean;\r\n  showCustomOnly: boolean;\r\n  showTab: boolean;\r\n\r\n  selectedInterval = new IntervalItem('Today', 'day', 0, 'today');\r\n\r\n  intervalList: IntervalItem[];\r\n\r\n  ngOnInit() {\r\n    this.setInitialDateRange();\r\n    this.showTab = this.displayMode === DisplayMode.showTab;\r\n    this.showIntervalOnly = this.displayMode === DisplayMode.showIntervalOnly;\r\n    this.showCustomOnly = this.displayMode === DisplayMode.showCustomOnly;\r\n    this.generateIntervalOptionItems(this.intervalOptions || []);\r\n  }\r\n\r\n  setInitialDateRange() {\r\n    this.defaultDateRange = this.defaultDateRange || {\r\n      fromDate: new Date(),\r\n      toDate: new Date()\r\n    };\r\n    this.dateFormat = this.dateFormat || 'dd/MM/yyyy';\r\n    this.fromDate = this.defaultDateRange.fromDate;\r\n    this.toDate = this.defaultDateRange.toDate;\r\n    this._displayRange = this.createDateRange();\r\n  }\r\n\r\n  resetDateRange() {\r\n    this.fromDate = new Date();\r\n    this.toDate = new Date();\r\n    this._displayRange = this.createDateRange();\r\n  }\r\n\r\n  generateIntervalOptionItems(itemList: string[]) {\r\n    this.intervalList = fullIntervalList.filter(item =>\r\n      itemList.includes(item.displayName)\r\n    );\r\n  }\r\n\r\n  hide(closeDropdown: boolean) {\r\n    if (closeDropdown) {\r\n      this.dropdown.hide();\r\n    }\r\n  }\r\n\r\n  toggle() {\r\n    this.dropdown.toggle();\r\n  }\r\n\r\n  onCustomDateSelection(newCustomDate: Date[]) {\r\n    // do not update range if undefined, null[], from > to\r\n    if (\r\n      !newCustomDate ||\r\n      newCustomDate[0] == null ||\r\n      newCustomDate[1] == null ||\r\n      newCustomDate[0] > newCustomDate[1]\r\n    ) {\r\n      return null;\r\n    }\r\n\r\n    this.fromDate = newCustomDate[0];\r\n    this.toDate = newCustomDate[1];\r\n    this._displayRange = this.createDateRange();\r\n    this.onDateRangeSelected.emit(<DateRange>{\r\n      fromDate: this.fromDate,\r\n      toDate: this.toDate\r\n    });\r\n    this.currentTab = DateSelectionType.custom;\r\n    this.selectedInterval = null;\r\n  }\r\n\r\n  onIntervalSelection(selectedItem: IntervalItem) {\r\n    if (selectedItem) {\r\n      this.selectedInterval = selectedItem;\r\n      const today: Date = new Date();\r\n      let calculatedDate: Date;\r\n      if (selectedItem.unit === 'day') {\r\n        calculatedDate = new Date(\r\n          today.getFullYear(),\r\n          today.getMonth(),\r\n          today.getDate() + selectedItem.count\r\n        );\r\n      } else if (selectedItem.unit === 'month') {\r\n        calculatedDate = new Date(\r\n          today.getFullYear(),\r\n          today.getMonth() + selectedItem.count,\r\n          today.getDate()\r\n        );\r\n      } else if (selectedItem.unit === 'year') {\r\n        calculatedDate = new Date(\r\n          today.getFullYear() + selectedItem.count,\r\n          today.getMonth(),\r\n          today.getDate()\r\n        );\r\n      }\r\n\r\n      if (calculatedDate >= today) {\r\n        this.fromDate = today;\r\n        this.toDate = calculatedDate;\r\n      } else {\r\n        this.fromDate = calculatedDate;\r\n        this.toDate = today;\r\n      }\r\n      this._displayRange = this.createDateRange();\r\n\r\n      this.onDateRangeSelected.emit(<DateRange>{\r\n        fromDate: this.fromDate,\r\n        toDate: this.toDate\r\n      });\r\n      this.currentTab = DateSelectionType.interval;\r\n    }\r\n  }\r\n\r\n  createDateRange(): string {\r\n    const fromDateStr = this.datePipe.transform(this.fromDate, this.dateFormat);\r\n    const toDateStr = this.datePipe.transform(this.toDate, this.dateFormat);\r\n    if (fromDateStr === toDateStr) {\r\n      return fromDateStr;\r\n    }\r\n    return `${fromDateStr} - ${toDateStr}`;\r\n  }\r\n}\r\n","<div\r\n  class=\"hx-dropdown\"\r\n  hxDropdown\r\n  #dropdown=\"hx-dropdown\"\r\n  [autoClose]=\"autoClose\"\r\n  [isDisabled]=\"disabled\"\r\n  [placement]=\"placement\"\r\n>\r\n  <button class=\"hx-button\" hxDropdownToggle type=\"button\">\r\n    <span>\r\n      <span class=\"is-text-weight-light\" *ngIf=\"!!placeholder\">\r\n        {{ placeholder }}: \r\n      </span>\r\n      <span class=\"is-text-weight-bolder\">{{ _displayRange }}</span>\r\n    </span>\r\n    <span class=\"hx-icon-control\" *ngIf=\"showCaretDown\">\r\n      <i class=\"icon icon-caret-down\"></i>\r\n    </span>\r\n  </button>\r\n  <div \r\n    class=\"hx-dropdown-menu dropdown-menu-wider py-0 px-0\" \r\n    *hxDropdownMenu\r\n  >\r\n    <div class=\"hxa-tabs\" *ngIf=\"showTab\">\r\n      <hx-tabset [justified]=\"true\" contentCustomClass=\"pa-0\">\r\n        <hx-tab\r\n          heading=\"INTERVAL\"\r\n          [active]=\"currentTab === DateSelectionType.interval\"\r\n        >\r\n          <hxa-date-range-picker-interval\r\n            [intervalOptionList]=\"intervalList\"\r\n            [currentSelectedInterval]=\"selectedInterval\"\r\n            (newSelectedInterval)=\"onIntervalSelection($event)\"\r\n            (closeDropdown)=\"hide($event)\"\r\n          ></hxa-date-range-picker-interval>\r\n        </hx-tab>\r\n        <hx-tab\r\n          heading=\"CUSTOM\"\r\n          [active]=\"currentTab === DateSelectionType.custom\"\r\n        >\r\n          <hxa-date-range-picker-custom\r\n            [currentFromDate]=\"fromDate\"\r\n            [currentToDate]=\"toDate\"\r\n            [dateFormat]=\"dateFormat\"\r\n            (newSelectedCustomDate)=\"onCustomDateSelection($event)\"\r\n            (closeDropdown)=\"hide($event)\"\r\n          ></hxa-date-range-picker-custom>\r\n        </hx-tab>\r\n      </hx-tabset>\r\n    </div>\r\n    <div \r\n      *ngIf=\"!showTab && showIntervalOnly\" \r\n      class=\"internal-custom-tab pa-0\"\r\n    >\r\n      <hxa-date-range-picker-interval\r\n        [intervalOptionList]=\"intervalList\"\r\n        [currentSelectedInterval]=\"selectedInterval\"\r\n        (newSelectedInterval)=\"onIntervalSelection($event)\"\r\n        (closeDropdown)=\"hide($event)\"\r\n      ></hxa-date-range-picker-interval>\r\n    </div>\r\n    <div\r\n      *ngIf=\"!showTab && showCustomOnly\"\r\n      class=\"internal-custom-tab px-0 pb-0\"\r\n    >\r\n      <hxa-date-range-picker-custom\r\n        [currentFromDate]=\"fromDate\"\r\n        [currentToDate]=\"toDate\"\r\n        [dateFormat]=\"dateFormat\"\r\n        (newSelectedCustomDate)=\"onCustomDateSelection($event)\"\r\n        (closeDropdown)=\"hide($event)\"\r\n      ></hxa-date-range-picker-custom>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}