@libs-ui/components-datetime-picker 0.2.306-4 → 0.2.306-6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,10 +1,10 @@
1
- import { ChangeDetectionStrategy, Component, computed, effect, input, model, output, signal, untracked } from "@angular/core";
2
- import { LibsUiComponentsLabelComponent } from "@libs-ui/components-label";
3
- import { LibsUiComponentsPopoverComponent } from "@libs-ui/components-popover";
4
- import { ERROR_MESSAGE_EMPTY_VALID, getDayjs } from "@libs-ui/utils";
5
- import { TranslateModule } from "@ngx-translate/core";
6
- import { LibsUiComponentsDatetimePickerCustomRangesComponent } from "./custom-ranges/custom-ranges.component";
7
- import { getDateOptionsDefault } from "./defines/date-options.define";
1
+ import { ChangeDetectionStrategy, Component, computed, effect, input, model, output, signal, untracked } from '@angular/core';
2
+ import { LibsUiComponentsLabelComponent } from '@libs-ui/components-label';
3
+ import { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';
4
+ import { ERROR_MESSAGE_EMPTY_VALID, getDayjs } from '@libs-ui/utils';
5
+ import { TranslateModule } from '@ngx-translate/core';
6
+ import { LibsUiComponentsDatetimePickerCustomRangesComponent } from './custom-ranges/custom-ranges.component';
7
+ import { getDateOptionsDefault } from './defines/date-options.define';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "@ngx-translate/core";
10
10
  export class LibsUiComponentsDatetimePickerComponent {
@@ -37,7 +37,7 @@ export class LibsUiComponentsDatetimePickerComponent {
37
37
  hasTimePicker = input(true);
38
38
  allowReset = input(true);
39
39
  widthByLabel = input(true, { transform: (value) => value ?? true });
40
- directionPopover = input('bottom', { transform: value => value ?? 'bottom' });
40
+ directionPopover = input('bottom', { transform: (value) => value ?? 'bottom' });
41
41
  defaultWidth = input(undefined);
42
42
  isSingle = input(false);
43
43
  extendRanges = input([]);
@@ -68,10 +68,11 @@ export class LibsUiComponentsDatetimePickerComponent {
68
68
  outFunctionsControl = output();
69
69
  constructor() {
70
70
  effect(() => {
71
- if (this.singleDateSelected()?.date) {
71
+ const date = this.singleDateSelected()?.date;
72
+ if (date) {
72
73
  untracked(() => {
73
74
  const formatDate = this.hasTimePicker() ? 'DD/MM/YYYY HH:mm' : 'DD/MM/YYYY';
74
- const startTime = getDayjs({ date: this.singleDateSelected()?.date })?.format(formatDate);
75
+ const startTime = getDayjs({ date }).format(formatDate);
75
76
  this.chosenDateFromRanges.set({ selectedLabel: startTime });
76
77
  });
77
78
  }
@@ -85,11 +86,14 @@ export class LibsUiComponentsDatetimePickerComponent {
85
86
  });
86
87
  }
87
88
  ngOnInit() {
88
- this.outFunctionsControl.emit({
89
+ this.outFunctionsControl.emit(this.FunctionsControl);
90
+ }
91
+ get FunctionsControl() {
92
+ return {
89
93
  checkIsValid: this.checkIsValid.bind(this),
90
94
  resetError: this.resetError.bind(this),
91
- reset: this.reset.bind(this)
92
- });
95
+ reset: this.reset.bind(this),
96
+ };
93
97
  }
94
98
  handlerSelectRanges(event) {
95
99
  event.stopPropagation();
@@ -116,7 +120,7 @@ export class LibsUiComponentsDatetimePickerComponent {
116
120
  this.chosenDateFromRanges.set({ selectedLabel: data.displayLabel });
117
121
  if (this.hasTimePicker()) {
118
122
  const startTime = getDayjs({ date: data.date, returnDayjsIfConfigDateNotExist: true }).format('DD/MM/YYYY HH:mm');
119
- this.chosenDateFromRanges.update(current => {
123
+ this.chosenDateFromRanges.update((current) => {
120
124
  current.selectedLabel = `${startTime}`;
121
125
  return current;
122
126
  });
@@ -136,15 +140,15 @@ export class LibsUiComponentsDatetimePickerComponent {
136
140
  if (this.hasTimePicker()) {
137
141
  const startTime = getDayjs({ date: data.startDate, returnDayjsIfConfigDateNotExist: true }).format('DD/MM/YYYY HH:mm');
138
142
  const endTime = getDayjs({ date: data.endDate, returnDayjsIfConfigDateNotExist: true }).format('DD/MM/YYYY HH:mm');
139
- this.chosenDateFromRanges.update(current => {
143
+ this.chosenDateFromRanges.update((current) => {
140
144
  current.selectedLabel = `${startTime} - ${endTime}`;
141
145
  return current;
142
146
  });
143
147
  }
144
148
  // this.moDatePicker.emit(this.singleDatePicker ? { chosenLabel: this.dateValue.chosenLabel, singleDate: this.dateValue.startDate?.utc(), startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() } : { chosenLabel: this.dateValue.chosenLabel, startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() });
145
- const showViewExternalRangeLabel = this.extendRanges()?.find(item => item.id === this.chosenDateFromRanges().selectedLabel);
149
+ const showViewExternalRangeLabel = this.extendRanges()?.find((item) => item.id === this.chosenDateFromRanges().selectedLabel);
146
150
  if (this.extendRanges() && showViewExternalRangeLabel) {
147
- this.chosenDateFromRanges.update(current => {
151
+ this.chosenDateFromRanges.update((current) => {
148
152
  current.selectedLabel = showViewExternalRangeLabel && showViewExternalRangeLabel.label;
149
153
  return current;
150
154
  });
@@ -157,7 +161,7 @@ export class LibsUiComponentsDatetimePickerComponent {
157
161
  updateChosenDateFromRangesFromDateRangeSelected(dateRangeSelected) {
158
162
  untracked(() => {
159
163
  if (dateRangeSelected?.quickRangeId) {
160
- const findKeyRange = Object.keys(this.dateOptions().ranges).find(key => key === dateRangeSelected?.quickRangeId);
164
+ const findKeyRange = Object.keys(this.dateOptions().ranges).find((key) => key === dateRangeSelected?.quickRangeId);
161
165
  if (findKeyRange) {
162
166
  this.chosenDateFromRanges.set({ selectedLabel: this.dateOptions().ranges[findKeyRange] });
163
167
  return;
@@ -210,7 +214,7 @@ export class LibsUiComponentsDatetimePickerComponent {
210
214
  if (this.validRequired() && !this.chosenDateFromRanges().selectedLabel) {
211
215
  this.singleError.set({
212
216
  message: this.validRequired()?.message || ERROR_MESSAGE_EMPTY_VALID,
213
- interpolateParams: this.validRequired()?.interpolateParams || {}
217
+ interpolateParams: this.validRequired()?.interpolateParams || {},
214
218
  });
215
219
  return;
216
220
  }
@@ -234,15 +238,10 @@ export class LibsUiComponentsDatetimePickerComponent {
234
238
  return;
235
239
  }
236
240
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
237
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsDatetimePickerComponent, isStandalone: true, selector: "libs_ui-components-datetime-picker", inputs: { dateOptions: { classPropertyName: "dateOptions", publicName: "dateOptions", isSignal: true, isRequired: false, transformFunction: null }, showCustomRangeLabel: { classPropertyName: "showCustomRangeLabel", publicName: "showCustomRangeLabel", isSignal: true, isRequired: false, transformFunction: null }, labelConfig: { classPropertyName: "labelConfig", publicName: "labelConfig", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, classPickerInclude: { classPropertyName: "classPickerInclude", publicName: "classPickerInclude", isSignal: true, isRequired: false, transformFunction: null }, classPickerContentInclude: { classPropertyName: "classPickerContentInclude", publicName: "classPickerContentInclude", isSignal: true, isRequired: false, transformFunction: null }, ignoreBorderQuickRange: { classPropertyName: "ignoreBorderQuickRange", publicName: "ignoreBorderQuickRange", isSignal: true, isRequired: false, transformFunction: null }, useColorModeExist: { classPropertyName: "useColorModeExist", publicName: "useColorModeExist", isSignal: true, isRequired: false, transformFunction: null }, hasTimePicker: { classPropertyName: "hasTimePicker", publicName: "hasTimePicker", isSignal: true, isRequired: false, transformFunction: null }, allowReset: { classPropertyName: "allowReset", publicName: "allowReset", isSignal: true, isRequired: false, transformFunction: null }, widthByLabel: { classPropertyName: "widthByLabel", publicName: "widthByLabel", isSignal: true, isRequired: false, transformFunction: null }, directionPopover: { classPropertyName: "directionPopover", publicName: "directionPopover", isSignal: true, isRequired: false, transformFunction: null }, defaultWidth: { classPropertyName: "defaultWidth", publicName: "defaultWidth", isSignal: true, isRequired: false, transformFunction: null }, isSingle: { classPropertyName: "isSingle", publicName: "isSingle", isSignal: true, isRequired: false, transformFunction: null }, extendRanges: { classPropertyName: "extendRanges", publicName: "extendRanges", isSignal: true, isRequired: false, transformFunction: null }, isBorderError: { classPropertyName: "isBorderError", publicName: "isBorderError", isSignal: true, isRequired: false, transformFunction: null }, minDate: { classPropertyName: "minDate", publicName: "minDate", isSignal: true, isRequired: false, transformFunction: null }, maxDate: { classPropertyName: "maxDate", publicName: "maxDate", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, listYearHiddenInputSearch: { classPropertyName: "listYearHiddenInputSearch", publicName: "listYearHiddenInputSearch", isSignal: true, isRequired: false, transformFunction: null }, validRequired: { classPropertyName: "validRequired", publicName: "validRequired", isSignal: true, isRequired: false, transformFunction: null }, ignoreStopPropagationEvent: { classPropertyName: "ignoreStopPropagationEvent", publicName: "ignoreStopPropagationEvent", isSignal: true, isRequired: false, transformFunction: null }, flagMouse: { classPropertyName: "flagMouse", publicName: "flagMouse", isSignal: true, isRequired: false, transformFunction: null }, widthByParent: { classPropertyName: "widthByParent", publicName: "widthByParent", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, rangesPopoverPosition: { classPropertyName: "rangesPopoverPosition", publicName: "rangesPopoverPosition", isSignal: true, isRequired: false, transformFunction: null }, rangesPopoverPositionDistance: { classPropertyName: "rangesPopoverPositionDistance", publicName: "rangesPopoverPositionDistance", isSignal: true, isRequired: false, transformFunction: null }, isNgContent: { classPropertyName: "isNgContent", publicName: "isNgContent", isSignal: true, isRequired: false, transformFunction: null }, classIncludeCustomRanges: { classPropertyName: "classIncludeCustomRanges", publicName: "classIncludeCustomRanges", isSignal: true, isRequired: false, transformFunction: null }, autoApply: { classPropertyName: "autoApply", publicName: "autoApply", isSignal: true, isRequired: false, transformFunction: null }, positionQuickRanges: { classPropertyName: "positionQuickRanges", publicName: "positionQuickRanges", isSignal: true, isRequired: false, transformFunction: null }, trackDateRageUpdateLabel: { classPropertyName: "trackDateRageUpdateLabel", publicName: "trackDateRageUpdateLabel", isSignal: true, isRequired: false, transformFunction: null }, singleDateSelected: { classPropertyName: "singleDateSelected", publicName: "singleDateSelected", isSignal: true, isRequired: false, transformFunction: null }, dateRangeSelected: { classPropertyName: "dateRangeSelected", publicName: "dateRangeSelected", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { flagMouse: "flagMouseChange", singleDateSelected: "singleDateSelectedChange", dateRangeSelected: "dateRangeSelectedChange", outChangStageFlagMouse: "outChangStageFlagMouse", outReset: "outReset", outSelectSingleDate: "outSelectSingleDate", outSelectDateRange: "outSelectDateRange", outFunctionsControl: "outFunctionsControl" }, ngImport: i0, template: "<div class=\"libs-ui-date-picker {{ classInclude() }}\">\n @if (labelConfig(); as labelConfig) {\n <libs_ui-components-label [classInclude]=\"labelConfig.classInclude\"\n [labelLeft]=\"labelConfig.labelLeft\"\n [labelLeftClass]=\"labelConfig.labelLeftClass\"\n [required]=\"labelConfig.required \"\n [description]=\"labelConfig.description\"\n [descriptionClass]=\"labelConfig.descriptionClass\"\n [labelRight]=\"labelConfig.labelRight\"\n [labelRightClass]=\"labelConfig.labelRightClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [buttonsLeft]=\"labelConfig.buttonsLeft\"\n [buttonsRight]=\"labelConfig.buttonsRight\"\n [disableButtonsLeft]=\"labelConfig.disableButtonsLeft || disable()\"\n [disableButtonsRight]=\"labelConfig.disableButtonsRight || disable()\"\n [hasToggle]=\"labelConfig.hasToggle\"\n [toggleActive]=\"labelConfig.toggleActive\"\n [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n [popover]=\"labelConfig.popover\"\n [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [limitLength]=\"labelConfig.limitLength\"\n [buttonsDescription]=\"labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"labelConfig.disableButtonsDescription || disable()\"\n [buttonsDescriptionContainerClass]=\"labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"labelConfig.count\" />\n }\n <div class=\"flex w-full\">\n <libs_ui-components-popover [class]=\"classPickerInclude()\"\n [ignoreShowPopover]=\"disable() || readonly()\"\n [mode]=\"'click'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n [flagMouse]=\"flagMouse()\"\n [config]=\"{\n animationConfig:{},\n maxWidth: 770,\n maxHeight: 425,\n directionDistance:2,\n template: customRangesRef,\n widthByParent: widthByParent(),\n whiteTheme: true,\n ignoreArrow: true,\n zIndex: zIndex(),\n classInclude: 'rounded-[4px] ',\n direction:directionPopover(),\n position: {mode: rangesPopoverPosition(),distance: rangesPopoverPositionDistance()}}\"\n (outChangStageFlagMouse)=\"handlerChangStagePopoverFlagMouse($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\"\n (outEvent)=\"handlerPopoverEvent($event)\">\n @if (!isNgContent()) {\n <div #containerRef\n class=\"flex items-center px-[12px] h-[32px] rounded-[4px] bg-[#ffffff] cursor-pointer libs-ui-font-h5r {{ classPickerContentInclude() }}\"\n [class.libs-ui-disable]=\"disable()\"\n [class.libs-ui-disable-background]=\"disable()\"\n [class.!border-none]=\"ignoreBorderQuickRange()\"\n [class.libs-ui-border-general]=\"!singleError().message && !ignoreBorderQuickRange()\"\n [class.libs-ui-border-error-general]=\"(singleError().message || isBorderError()) && !ignoreBorderQuickRange()\"\n [class.min-w-[284px]]=\"!chosenDateFromRanges().selectedLabel && !isSingle() && hasTimePicker()\"\n [class.!border]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.!border-[#4e8cf7]]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.libs-ui-readonly]=\"readonly()\"\n [class.libs-ui-readonly-background]=\"readonly()\"\n [style.width.px]=\"width()\"\n (click)=\"handlerSelectRanges($event)\">\n <div class=\"libs-ui-icon-calendar text-[#9ca2ad] text-[16px]\"></div>\n <div class=\"ml-[8px] libs-ui-date-picker-label\"\n [class.!text-[#071631]]=\"!disable()\"\n [class.!text-[#9ca2ad]]=\"disable()\">\n @if (!chosenDateFromRanges().selectedLabel) {\n @if (!isSingle()) {\n @if (!placeholder()) {\n <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>} -\n dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>}</span>\n } @else {\n <span class=\"text-[#9ca2ad]\">{{ (placeholder() || ' ') |translate }} </span>\n }\n }\n @if (isSingle()) {\n @if (!placeholder()) {\n <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>}</span>\n } @else {\n <span class=\"text-[#9ca2ad]\">{{ (placeholder() || ' ') |translate }} </span>\n }\n\n }\n }\n @if (chosenDateFromRanges().selectedLabel && !isSingle()) {\n {{ displayRangeTitle() }}\n }\n @if (chosenDateFromRanges().selectedLabel && isSingle()) {\n <span [class.text-[#29c7cc]]=\"useColorModeExist() || false\">\n {{ chosenDateFromRanges().selectedLabel }}\n </span>\n }\n </div>\n @if (chosenDateFromRanges().selectedLabel && allowReset() && !disable() && !readonly()) {\n <div class=\"pl-[12px] ml-auto h-full flex items-center\">\n <i class=\"libs-ui-icon-close-circle-solid text-[16px] text-[#cdd0d6]\"\n (click)=\"handlerReset($event)\"></i>\n </div>\n }\n </div>\n }\n @if (isNgContent()) {\n <div (click)=\"handlerSelectRanges($event)\">\n <ng-content></ng-content>\n </div>\n }\n </libs_ui-components-popover>\n </div>\n @if (singleError().message && !validRequired()?.ignoreMessage) {\n <div class=\"mt-[8px] text-[#ee2d41] libs-ui-font-h7r libs-ui-text-error\"\n [innerHTML]=\"(singleError().message || ERROR_MESSAGE_EMPTY_VALID)| translate:validRequired()?.interpolateParams\">\n </div>\n }\n</div>\n\n<ng-template #customRangesRef>\n <libs_ui-components-datetime-picker-custom_ranges [zIndex]=\"zIndex()\"\n [classInclude]=\"classIncludeCustomRanges()\"\n [widthByParent]=\"widthByParent()\"\n [dateOptions]=\"dateOptions()\"\n [positionQuickRanges]=\"positionQuickRanges()\"\n [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n [autoApply]=\"autoApply()\"\n [isSingle]=\"isSingle()\"\n [minDate]=\"minDate()\"\n [maxDate]=\"maxDate()\"\n [listYearHiddenInputSearch]=\"listYearHiddenInputSearch()\"\n [singleDateSelected]=\"singleDateSelected()\"\n [dateRangeSelected]=\"dateRangeSelected()\"\n [extendRanges]=\"extendRanges()\"\n [hasTimePicker]=\"hasTimePicker()\"\n (outUpdateWidth)=\"handlerUpdateWidth()\"\n (outCancel)=\"handlerCancel()\"\n (outSelectSingleDate)=\"handlerPickerSingleDate($event)\"\n (outSelectDateRange)=\"handlerPickerDateRange($event)\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\"\n (outClickMenuRangeCustom)=\"handlerUpdateWidth()\" />\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsLabelComponent, selector: "libs_ui-components-label", inputs: ["iconPopoverClass", "classInclude", "labelLeft", "labelLeftClass", "labelLeftBehindToggleButton", "popover", "required", "buttonsLeft", "disableButtonsLeft", "buttonsRight", "disableButtonsRight", "labelRight", "labelRightClass", "labelRightRequired", "hasToggle", "toggleSize", "toggleActive", "toggleDisable", "description", "descriptionClass", "buttonsDescription", "disableButtonsDescription", "buttonsDescriptionContainerClass", "onlyShowCount", "zIndexPopover", "timerDestroyPopover", "count", "limitLength"], outputs: ["outClickButton", "outSwitchEvent", "outLabelRightClick", "outLabelLeftClick"] }, { kind: "component", type: LibsUiComponentsPopoverComponent, selector: "libs_ui-components-popover,[LibsUiComponentsPopoverDirective]", inputs: ["debugId", "flagMouse", "type", "mode", "config", "ignoreShowPopover", "elementRefCustom", "initEventInElementRefCustom", "classInclude", "ignoreHiddenPopoverContentWhenMouseLeave", "ignoreStopPropagationEvent", "ignoreCursorPointerModeLikeClick", "isAddContentToParentDocument", "ignoreClickOutside"], outputs: ["outEvent", "outChangStageFlagMouse", "outEventPopoverContent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsDatetimePickerCustomRangesComponent, selector: "libs_ui-components-datetime-picker-custom_ranges", inputs: ["zIndex", "classInclude", "extendRanges", "widthByParent", "autoApply", "minDate", "maxDate", "listYearHiddenInputSearch", "positionQuickRanges", "isSingle", "hasTimePicker", "flagMouse", "dateOptions", "alwaysShowCalendars", "startDate", "endDate", "showCustomRangeLabel", "keepCalendarOpeningWithRange", "singleDateSelected", "dateRangeSelected"], outputs: ["startDateChange", "endDateChange", "outChangStageFlagMouse", "outUpdateWidth", "outCancel", "outSelectSingleDate", "outSelectDateRange", "outClickMenuRangeCustom"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
241
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsDatetimePickerComponent, isStandalone: true, selector: "libs_ui-components-datetime-picker", inputs: { dateOptions: { classPropertyName: "dateOptions", publicName: "dateOptions", isSignal: true, isRequired: false, transformFunction: null }, showCustomRangeLabel: { classPropertyName: "showCustomRangeLabel", publicName: "showCustomRangeLabel", isSignal: true, isRequired: false, transformFunction: null }, labelConfig: { classPropertyName: "labelConfig", publicName: "labelConfig", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, classPickerInclude: { classPropertyName: "classPickerInclude", publicName: "classPickerInclude", isSignal: true, isRequired: false, transformFunction: null }, classPickerContentInclude: { classPropertyName: "classPickerContentInclude", publicName: "classPickerContentInclude", isSignal: true, isRequired: false, transformFunction: null }, ignoreBorderQuickRange: { classPropertyName: "ignoreBorderQuickRange", publicName: "ignoreBorderQuickRange", isSignal: true, isRequired: false, transformFunction: null }, useColorModeExist: { classPropertyName: "useColorModeExist", publicName: "useColorModeExist", isSignal: true, isRequired: false, transformFunction: null }, hasTimePicker: { classPropertyName: "hasTimePicker", publicName: "hasTimePicker", isSignal: true, isRequired: false, transformFunction: null }, allowReset: { classPropertyName: "allowReset", publicName: "allowReset", isSignal: true, isRequired: false, transformFunction: null }, widthByLabel: { classPropertyName: "widthByLabel", publicName: "widthByLabel", isSignal: true, isRequired: false, transformFunction: null }, directionPopover: { classPropertyName: "directionPopover", publicName: "directionPopover", isSignal: true, isRequired: false, transformFunction: null }, defaultWidth: { classPropertyName: "defaultWidth", publicName: "defaultWidth", isSignal: true, isRequired: false, transformFunction: null }, isSingle: { classPropertyName: "isSingle", publicName: "isSingle", isSignal: true, isRequired: false, transformFunction: null }, extendRanges: { classPropertyName: "extendRanges", publicName: "extendRanges", isSignal: true, isRequired: false, transformFunction: null }, isBorderError: { classPropertyName: "isBorderError", publicName: "isBorderError", isSignal: true, isRequired: false, transformFunction: null }, minDate: { classPropertyName: "minDate", publicName: "minDate", isSignal: true, isRequired: false, transformFunction: null }, maxDate: { classPropertyName: "maxDate", publicName: "maxDate", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, listYearHiddenInputSearch: { classPropertyName: "listYearHiddenInputSearch", publicName: "listYearHiddenInputSearch", isSignal: true, isRequired: false, transformFunction: null }, validRequired: { classPropertyName: "validRequired", publicName: "validRequired", isSignal: true, isRequired: false, transformFunction: null }, ignoreStopPropagationEvent: { classPropertyName: "ignoreStopPropagationEvent", publicName: "ignoreStopPropagationEvent", isSignal: true, isRequired: false, transformFunction: null }, flagMouse: { classPropertyName: "flagMouse", publicName: "flagMouse", isSignal: true, isRequired: false, transformFunction: null }, widthByParent: { classPropertyName: "widthByParent", publicName: "widthByParent", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, rangesPopoverPosition: { classPropertyName: "rangesPopoverPosition", publicName: "rangesPopoverPosition", isSignal: true, isRequired: false, transformFunction: null }, rangesPopoverPositionDistance: { classPropertyName: "rangesPopoverPositionDistance", publicName: "rangesPopoverPositionDistance", isSignal: true, isRequired: false, transformFunction: null }, isNgContent: { classPropertyName: "isNgContent", publicName: "isNgContent", isSignal: true, isRequired: false, transformFunction: null }, classIncludeCustomRanges: { classPropertyName: "classIncludeCustomRanges", publicName: "classIncludeCustomRanges", isSignal: true, isRequired: false, transformFunction: null }, autoApply: { classPropertyName: "autoApply", publicName: "autoApply", isSignal: true, isRequired: false, transformFunction: null }, positionQuickRanges: { classPropertyName: "positionQuickRanges", publicName: "positionQuickRanges", isSignal: true, isRequired: false, transformFunction: null }, trackDateRageUpdateLabel: { classPropertyName: "trackDateRageUpdateLabel", publicName: "trackDateRageUpdateLabel", isSignal: true, isRequired: false, transformFunction: null }, singleDateSelected: { classPropertyName: "singleDateSelected", publicName: "singleDateSelected", isSignal: true, isRequired: false, transformFunction: null }, dateRangeSelected: { classPropertyName: "dateRangeSelected", publicName: "dateRangeSelected", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { flagMouse: "flagMouseChange", singleDateSelected: "singleDateSelectedChange", dateRangeSelected: "dateRangeSelectedChange", outChangStageFlagMouse: "outChangStageFlagMouse", outReset: "outReset", outSelectSingleDate: "outSelectSingleDate", outSelectDateRange: "outSelectDateRange", outFunctionsControl: "outFunctionsControl" }, ngImport: i0, template: "<div class=\"libs-ui-date-picker {{ classInclude() }}\">\n @if (labelConfig(); as labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"labelConfig.classInclude\"\n [labelLeft]=\"labelConfig.labelLeft\"\n [labelLeftClass]=\"labelConfig.labelLeftClass\"\n [required]=\"labelConfig.required\"\n [description]=\"labelConfig.description\"\n [descriptionClass]=\"labelConfig.descriptionClass\"\n [labelRight]=\"labelConfig.labelRight\"\n [labelRightClass]=\"labelConfig.labelRightClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [buttonsLeft]=\"labelConfig.buttonsLeft\"\n [buttonsRight]=\"labelConfig.buttonsRight\"\n [disableButtonsLeft]=\"labelConfig.disableButtonsLeft || disable()\"\n [disableButtonsRight]=\"labelConfig.disableButtonsRight || disable()\"\n [hasToggle]=\"labelConfig.hasToggle\"\n [toggleActive]=\"labelConfig.toggleActive\"\n [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n [popover]=\"labelConfig.popover\"\n [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [limitLength]=\"labelConfig.limitLength\"\n [buttonsDescription]=\"labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"labelConfig.disableButtonsDescription || disable()\"\n [buttonsDescriptionContainerClass]=\"labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"labelConfig.count\" />\n }\n <div class=\"flex w-full\">\n <libs_ui-components-popover\n [class]=\"classPickerInclude()\"\n [ignoreShowPopover]=\"disable() || readonly()\"\n [mode]=\"'click'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n [flagMouse]=\"flagMouse()\"\n [config]=\"{\n animationConfig: {},\n maxWidth: 770,\n maxHeight: 425,\n directionDistance: 2,\n template: customRangesRef,\n widthByParent: widthByParent(),\n whiteTheme: true,\n ignoreArrow: true,\n zIndex: zIndex(),\n classInclude: 'rounded-[4px] ',\n direction: directionPopover(),\n position: { mode: rangesPopoverPosition(), distance: rangesPopoverPositionDistance() },\n }\"\n (outChangStageFlagMouse)=\"handlerChangStagePopoverFlagMouse($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\"\n (outEvent)=\"handlerPopoverEvent($event)\">\n @if (!isNgContent()) {\n <div\n #containerRef\n class=\"flex items-center px-[12px] h-[32px] rounded-[4px] bg-[#ffffff] cursor-pointer libs-ui-font-h5r {{ classPickerContentInclude() }}\"\n [class.libs-ui-disable]=\"disable()\"\n [class.libs-ui-disable-background]=\"disable()\"\n [class.!border-none]=\"ignoreBorderQuickRange()\"\n [class.libs-ui-border-general]=\"!singleError().message && !ignoreBorderQuickRange()\"\n [class.libs-ui-border-error-general]=\"(singleError().message || isBorderError()) && !ignoreBorderQuickRange()\"\n [class.min-w-[284px]]=\"!chosenDateFromRanges().selectedLabel && !isSingle() && hasTimePicker()\"\n [class.!border]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.!border-[#4e8cf7]]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.libs-ui-readonly]=\"readonly()\"\n [class.libs-ui-readonly-background]=\"readonly()\"\n [style.width.px]=\"width()\"\n (click)=\"handlerSelectRanges($event)\">\n <div class=\"libs-ui-icon-calendar text-[#9ca2ad] text-[16px]\"></div>\n <div\n class=\"ml-[8px] libs-ui-date-picker-label\"\n [class.!text-[#071631]]=\"!disable()\"\n [class.!text-[#9ca2ad]]=\"disable()\">\n @if (!chosenDateFromRanges().selectedLabel) {\n @if (!isSingle()) {\n @if (!placeholder()) {\n <span class=\"text-[#9ca2ad]\">\n dd/mm/yyyy\n @if (hasTimePicker()) {\n <span>&nbsp;hh:mm</span>\n }\n - dd/mm/yyyy\n @if (hasTimePicker()) {\n <span>&nbsp;hh:mm</span>\n }\n </span>\n } @else {\n <span class=\"text-[#9ca2ad]\">{{ placeholder() || ' ' | translate }}</span>\n }\n }\n @if (isSingle()) {\n @if (!placeholder()) {\n <span class=\"text-[#9ca2ad]\">\n dd/mm/yyyy\n @if (hasTimePicker()) {\n <span>&nbsp;hh:mm</span>\n }\n </span>\n } @else {\n <span class=\"text-[#9ca2ad]\">{{ placeholder() || ' ' | translate }}</span>\n }\n }\n }\n @if (chosenDateFromRanges().selectedLabel && !isSingle()) {\n {{ displayRangeTitle() }}\n }\n @if (chosenDateFromRanges().selectedLabel && isSingle()) {\n <span [class.text-[#29c7cc]]=\"useColorModeExist() || false\">\n {{ chosenDateFromRanges().selectedLabel }}\n </span>\n }\n </div>\n @if (chosenDateFromRanges().selectedLabel && allowReset() && !disable() && !readonly()) {\n <div class=\"pl-[12px] ml-auto h-full flex items-center\">\n <i\n class=\"libs-ui-icon-close-circle-solid text-[16px] text-[#cdd0d6]\"\n (click)=\"handlerReset($event)\"></i>\n </div>\n }\n </div>\n }\n @if (isNgContent()) {\n <div (click)=\"handlerSelectRanges($event)\">\n <ng-content></ng-content>\n </div>\n }\n </libs_ui-components-popover>\n </div>\n @if (singleError().message && !validRequired()?.ignoreMessage) {\n <div\n class=\"mt-[8px] text-[#ee2d41] libs-ui-font-h7r libs-ui-text-error\"\n [innerHTML]=\"singleError().message || ERROR_MESSAGE_EMPTY_VALID | translate: validRequired()?.interpolateParams\"></div>\n }\n</div>\n\n<ng-template #customRangesRef>\n <libs_ui-components-datetime-picker-custom_ranges\n [zIndex]=\"zIndex()\"\n [classInclude]=\"classIncludeCustomRanges()\"\n [widthByParent]=\"widthByParent()\"\n [dateOptions]=\"dateOptions()\"\n [positionQuickRanges]=\"positionQuickRanges()\"\n [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n [autoApply]=\"autoApply()\"\n [isSingle]=\"isSingle()\"\n [minDate]=\"minDate()\"\n [maxDate]=\"maxDate()\"\n [listYearHiddenInputSearch]=\"listYearHiddenInputSearch()\"\n [singleDateSelected]=\"singleDateSelected()\"\n [dateRangeSelected]=\"dateRangeSelected()\"\n [extendRanges]=\"extendRanges()\"\n [hasTimePicker]=\"hasTimePicker()\"\n (outUpdateWidth)=\"handlerUpdateWidth()\"\n (outCancel)=\"handlerCancel()\"\n (outSelectSingleDate)=\"handlerPickerSingleDate($event)\"\n (outSelectDateRange)=\"handlerPickerDateRange($event)\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\"\n (outClickMenuRangeCustom)=\"handlerUpdateWidth()\" />\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsLabelComponent, selector: "libs_ui-components-label", inputs: ["iconPopoverClass", "classInclude", "labelLeft", "labelLeftClass", "labelLeftBehindToggleButton", "popover", "required", "buttonsLeft", "disableButtonsLeft", "buttonsRight", "disableButtonsRight", "labelRight", "labelRightClass", "labelRightRequired", "hasToggle", "toggleSize", "toggleActive", "toggleDisable", "description", "descriptionClass", "buttonsDescription", "disableButtonsDescription", "buttonsDescriptionContainerClass", "onlyShowCount", "zIndexPopover", "timerDestroyPopover", "count", "limitLength"], outputs: ["outClickButton", "outSwitchEvent", "outLabelRightClick", "outLabelLeftClick"] }, { kind: "component", type: LibsUiComponentsPopoverComponent, selector: "libs_ui-components-popover,[LibsUiComponentsPopoverDirective]", inputs: ["debugId", "flagMouse", "type", "mode", "config", "ignoreShowPopover", "elementRefCustom", "initEventInElementRefCustom", "classInclude", "ignoreHiddenPopoverContentWhenMouseLeave", "ignoreStopPropagationEvent", "ignoreCursorPointerModeLikeClick", "isAddContentToParentDocument", "ignoreClickOutside"], outputs: ["outEvent", "outChangStageFlagMouse", "outEventPopoverContent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsDatetimePickerCustomRangesComponent, selector: "libs_ui-components-datetime-picker-custom_ranges", inputs: ["zIndex", "classInclude", "extendRanges", "widthByParent", "autoApply", "minDate", "maxDate", "listYearHiddenInputSearch", "positionQuickRanges", "isSingle", "hasTimePicker", "flagMouse", "dateOptions", "alwaysShowCalendars", "startDate", "endDate", "showCustomRangeLabel", "keepCalendarOpeningWithRange", "singleDateSelected", "dateRangeSelected"], outputs: ["startDateChange", "endDateChange", "outChangStageFlagMouse", "outUpdateWidth", "outCancel", "outSelectSingleDate", "outSelectDateRange", "outClickMenuRangeCustom"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
238
242
  }
239
243
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimePickerComponent, decorators: [{
240
244
  type: Component,
241
- args: [{ selector: 'libs_ui-components-datetime-picker', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
242
- TranslateModule,
243
- LibsUiComponentsLabelComponent,
244
- LibsUiComponentsPopoverComponent,
245
- LibsUiComponentsDatetimePickerCustomRangesComponent
246
- ], template: "<div class=\"libs-ui-date-picker {{ classInclude() }}\">\n @if (labelConfig(); as labelConfig) {\n <libs_ui-components-label [classInclude]=\"labelConfig.classInclude\"\n [labelLeft]=\"labelConfig.labelLeft\"\n [labelLeftClass]=\"labelConfig.labelLeftClass\"\n [required]=\"labelConfig.required \"\n [description]=\"labelConfig.description\"\n [descriptionClass]=\"labelConfig.descriptionClass\"\n [labelRight]=\"labelConfig.labelRight\"\n [labelRightClass]=\"labelConfig.labelRightClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [buttonsLeft]=\"labelConfig.buttonsLeft\"\n [buttonsRight]=\"labelConfig.buttonsRight\"\n [disableButtonsLeft]=\"labelConfig.disableButtonsLeft || disable()\"\n [disableButtonsRight]=\"labelConfig.disableButtonsRight || disable()\"\n [hasToggle]=\"labelConfig.hasToggle\"\n [toggleActive]=\"labelConfig.toggleActive\"\n [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n [popover]=\"labelConfig.popover\"\n [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [limitLength]=\"labelConfig.limitLength\"\n [buttonsDescription]=\"labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"labelConfig.disableButtonsDescription || disable()\"\n [buttonsDescriptionContainerClass]=\"labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"labelConfig.count\" />\n }\n <div class=\"flex w-full\">\n <libs_ui-components-popover [class]=\"classPickerInclude()\"\n [ignoreShowPopover]=\"disable() || readonly()\"\n [mode]=\"'click'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n [flagMouse]=\"flagMouse()\"\n [config]=\"{\n animationConfig:{},\n maxWidth: 770,\n maxHeight: 425,\n directionDistance:2,\n template: customRangesRef,\n widthByParent: widthByParent(),\n whiteTheme: true,\n ignoreArrow: true,\n zIndex: zIndex(),\n classInclude: 'rounded-[4px] ',\n direction:directionPopover(),\n position: {mode: rangesPopoverPosition(),distance: rangesPopoverPositionDistance()}}\"\n (outChangStageFlagMouse)=\"handlerChangStagePopoverFlagMouse($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\"\n (outEvent)=\"handlerPopoverEvent($event)\">\n @if (!isNgContent()) {\n <div #containerRef\n class=\"flex items-center px-[12px] h-[32px] rounded-[4px] bg-[#ffffff] cursor-pointer libs-ui-font-h5r {{ classPickerContentInclude() }}\"\n [class.libs-ui-disable]=\"disable()\"\n [class.libs-ui-disable-background]=\"disable()\"\n [class.!border-none]=\"ignoreBorderQuickRange()\"\n [class.libs-ui-border-general]=\"!singleError().message && !ignoreBorderQuickRange()\"\n [class.libs-ui-border-error-general]=\"(singleError().message || isBorderError()) && !ignoreBorderQuickRange()\"\n [class.min-w-[284px]]=\"!chosenDateFromRanges().selectedLabel && !isSingle() && hasTimePicker()\"\n [class.!border]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.!border-[#4e8cf7]]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.libs-ui-readonly]=\"readonly()\"\n [class.libs-ui-readonly-background]=\"readonly()\"\n [style.width.px]=\"width()\"\n (click)=\"handlerSelectRanges($event)\">\n <div class=\"libs-ui-icon-calendar text-[#9ca2ad] text-[16px]\"></div>\n <div class=\"ml-[8px] libs-ui-date-picker-label\"\n [class.!text-[#071631]]=\"!disable()\"\n [class.!text-[#9ca2ad]]=\"disable()\">\n @if (!chosenDateFromRanges().selectedLabel) {\n @if (!isSingle()) {\n @if (!placeholder()) {\n <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>} -\n dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>}</span>\n } @else {\n <span class=\"text-[#9ca2ad]\">{{ (placeholder() || ' ') |translate }} </span>\n }\n }\n @if (isSingle()) {\n @if (!placeholder()) {\n <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>}</span>\n } @else {\n <span class=\"text-[#9ca2ad]\">{{ (placeholder() || ' ') |translate }} </span>\n }\n\n }\n }\n @if (chosenDateFromRanges().selectedLabel && !isSingle()) {\n {{ displayRangeTitle() }}\n }\n @if (chosenDateFromRanges().selectedLabel && isSingle()) {\n <span [class.text-[#29c7cc]]=\"useColorModeExist() || false\">\n {{ chosenDateFromRanges().selectedLabel }}\n </span>\n }\n </div>\n @if (chosenDateFromRanges().selectedLabel && allowReset() && !disable() && !readonly()) {\n <div class=\"pl-[12px] ml-auto h-full flex items-center\">\n <i class=\"libs-ui-icon-close-circle-solid text-[16px] text-[#cdd0d6]\"\n (click)=\"handlerReset($event)\"></i>\n </div>\n }\n </div>\n }\n @if (isNgContent()) {\n <div (click)=\"handlerSelectRanges($event)\">\n <ng-content></ng-content>\n </div>\n }\n </libs_ui-components-popover>\n </div>\n @if (singleError().message && !validRequired()?.ignoreMessage) {\n <div class=\"mt-[8px] text-[#ee2d41] libs-ui-font-h7r libs-ui-text-error\"\n [innerHTML]=\"(singleError().message || ERROR_MESSAGE_EMPTY_VALID)| translate:validRequired()?.interpolateParams\">\n </div>\n }\n</div>\n\n<ng-template #customRangesRef>\n <libs_ui-components-datetime-picker-custom_ranges [zIndex]=\"zIndex()\"\n [classInclude]=\"classIncludeCustomRanges()\"\n [widthByParent]=\"widthByParent()\"\n [dateOptions]=\"dateOptions()\"\n [positionQuickRanges]=\"positionQuickRanges()\"\n [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n [autoApply]=\"autoApply()\"\n [isSingle]=\"isSingle()\"\n [minDate]=\"minDate()\"\n [maxDate]=\"maxDate()\"\n [listYearHiddenInputSearch]=\"listYearHiddenInputSearch()\"\n [singleDateSelected]=\"singleDateSelected()\"\n [dateRangeSelected]=\"dateRangeSelected()\"\n [extendRanges]=\"extendRanges()\"\n [hasTimePicker]=\"hasTimePicker()\"\n (outUpdateWidth)=\"handlerUpdateWidth()\"\n (outCancel)=\"handlerCancel()\"\n (outSelectSingleDate)=\"handlerPickerSingleDate($event)\"\n (outSelectDateRange)=\"handlerPickerDateRange($event)\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\"\n (outClickMenuRangeCustom)=\"handlerUpdateWidth()\" />\n</ng-template>\n" }]
245
+ args: [{ selector: 'libs_ui-components-datetime-picker', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [TranslateModule, LibsUiComponentsLabelComponent, LibsUiComponentsPopoverComponent, LibsUiComponentsDatetimePickerCustomRangesComponent], template: "<div class=\"libs-ui-date-picker {{ classInclude() }}\">\n @if (labelConfig(); as labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"labelConfig.classInclude\"\n [labelLeft]=\"labelConfig.labelLeft\"\n [labelLeftClass]=\"labelConfig.labelLeftClass\"\n [required]=\"labelConfig.required\"\n [description]=\"labelConfig.description\"\n [descriptionClass]=\"labelConfig.descriptionClass\"\n [labelRight]=\"labelConfig.labelRight\"\n [labelRightClass]=\"labelConfig.labelRightClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [buttonsLeft]=\"labelConfig.buttonsLeft\"\n [buttonsRight]=\"labelConfig.buttonsRight\"\n [disableButtonsLeft]=\"labelConfig.disableButtonsLeft || disable()\"\n [disableButtonsRight]=\"labelConfig.disableButtonsRight || disable()\"\n [hasToggle]=\"labelConfig.hasToggle\"\n [toggleActive]=\"labelConfig.toggleActive\"\n [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n [popover]=\"labelConfig.popover\"\n [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [limitLength]=\"labelConfig.limitLength\"\n [buttonsDescription]=\"labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"labelConfig.disableButtonsDescription || disable()\"\n [buttonsDescriptionContainerClass]=\"labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"labelConfig.count\" />\n }\n <div class=\"flex w-full\">\n <libs_ui-components-popover\n [class]=\"classPickerInclude()\"\n [ignoreShowPopover]=\"disable() || readonly()\"\n [mode]=\"'click'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n [flagMouse]=\"flagMouse()\"\n [config]=\"{\n animationConfig: {},\n maxWidth: 770,\n maxHeight: 425,\n directionDistance: 2,\n template: customRangesRef,\n widthByParent: widthByParent(),\n whiteTheme: true,\n ignoreArrow: true,\n zIndex: zIndex(),\n classInclude: 'rounded-[4px] ',\n direction: directionPopover(),\n position: { mode: rangesPopoverPosition(), distance: rangesPopoverPositionDistance() },\n }\"\n (outChangStageFlagMouse)=\"handlerChangStagePopoverFlagMouse($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\"\n (outEvent)=\"handlerPopoverEvent($event)\">\n @if (!isNgContent()) {\n <div\n #containerRef\n class=\"flex items-center px-[12px] h-[32px] rounded-[4px] bg-[#ffffff] cursor-pointer libs-ui-font-h5r {{ classPickerContentInclude() }}\"\n [class.libs-ui-disable]=\"disable()\"\n [class.libs-ui-disable-background]=\"disable()\"\n [class.!border-none]=\"ignoreBorderQuickRange()\"\n [class.libs-ui-border-general]=\"!singleError().message && !ignoreBorderQuickRange()\"\n [class.libs-ui-border-error-general]=\"(singleError().message || isBorderError()) && !ignoreBorderQuickRange()\"\n [class.min-w-[284px]]=\"!chosenDateFromRanges().selectedLabel && !isSingle() && hasTimePicker()\"\n [class.!border]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.!border-[#4e8cf7]]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n [class.libs-ui-readonly]=\"readonly()\"\n [class.libs-ui-readonly-background]=\"readonly()\"\n [style.width.px]=\"width()\"\n (click)=\"handlerSelectRanges($event)\">\n <div class=\"libs-ui-icon-calendar text-[#9ca2ad] text-[16px]\"></div>\n <div\n class=\"ml-[8px] libs-ui-date-picker-label\"\n [class.!text-[#071631]]=\"!disable()\"\n [class.!text-[#9ca2ad]]=\"disable()\">\n @if (!chosenDateFromRanges().selectedLabel) {\n @if (!isSingle()) {\n @if (!placeholder()) {\n <span class=\"text-[#9ca2ad]\">\n dd/mm/yyyy\n @if (hasTimePicker()) {\n <span>&nbsp;hh:mm</span>\n }\n - dd/mm/yyyy\n @if (hasTimePicker()) {\n <span>&nbsp;hh:mm</span>\n }\n </span>\n } @else {\n <span class=\"text-[#9ca2ad]\">{{ placeholder() || ' ' | translate }}</span>\n }\n }\n @if (isSingle()) {\n @if (!placeholder()) {\n <span class=\"text-[#9ca2ad]\">\n dd/mm/yyyy\n @if (hasTimePicker()) {\n <span>&nbsp;hh:mm</span>\n }\n </span>\n } @else {\n <span class=\"text-[#9ca2ad]\">{{ placeholder() || ' ' | translate }}</span>\n }\n }\n }\n @if (chosenDateFromRanges().selectedLabel && !isSingle()) {\n {{ displayRangeTitle() }}\n }\n @if (chosenDateFromRanges().selectedLabel && isSingle()) {\n <span [class.text-[#29c7cc]]=\"useColorModeExist() || false\">\n {{ chosenDateFromRanges().selectedLabel }}\n </span>\n }\n </div>\n @if (chosenDateFromRanges().selectedLabel && allowReset() && !disable() && !readonly()) {\n <div class=\"pl-[12px] ml-auto h-full flex items-center\">\n <i\n class=\"libs-ui-icon-close-circle-solid text-[16px] text-[#cdd0d6]\"\n (click)=\"handlerReset($event)\"></i>\n </div>\n }\n </div>\n }\n @if (isNgContent()) {\n <div (click)=\"handlerSelectRanges($event)\">\n <ng-content></ng-content>\n </div>\n }\n </libs_ui-components-popover>\n </div>\n @if (singleError().message && !validRequired()?.ignoreMessage) {\n <div\n class=\"mt-[8px] text-[#ee2d41] libs-ui-font-h7r libs-ui-text-error\"\n [innerHTML]=\"singleError().message || ERROR_MESSAGE_EMPTY_VALID | translate: validRequired()?.interpolateParams\"></div>\n }\n</div>\n\n<ng-template #customRangesRef>\n <libs_ui-components-datetime-picker-custom_ranges\n [zIndex]=\"zIndex()\"\n [classInclude]=\"classIncludeCustomRanges()\"\n [widthByParent]=\"widthByParent()\"\n [dateOptions]=\"dateOptions()\"\n [positionQuickRanges]=\"positionQuickRanges()\"\n [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n [autoApply]=\"autoApply()\"\n [isSingle]=\"isSingle()\"\n [minDate]=\"minDate()\"\n [maxDate]=\"maxDate()\"\n [listYearHiddenInputSearch]=\"listYearHiddenInputSearch()\"\n [singleDateSelected]=\"singleDateSelected()\"\n [dateRangeSelected]=\"dateRangeSelected()\"\n [extendRanges]=\"extendRanges()\"\n [hasTimePicker]=\"hasTimePicker()\"\n (outUpdateWidth)=\"handlerUpdateWidth()\"\n (outCancel)=\"handlerCancel()\"\n (outSelectSingleDate)=\"handlerPickerSingleDate($event)\"\n (outSelectDateRange)=\"handlerPickerDateRange($event)\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\"\n (outClickMenuRangeCustom)=\"handlerUpdateWidth()\" />\n</ng-template>\n" }]
247
246
  }], ctorParameters: () => [] });
248
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picker.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/datetime/picker/src/picker.component.ts","../../../../../../libs-ui/components/datetime/picker/src/picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, input, model, OnDestroy, OnInit, output, signal, untracked } from \"@angular/core\";\nimport { ILabel, LibsUiComponentsLabelComponent } from \"@libs-ui/components-label\";\nimport { IFlagMouse, IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_DIRECTION, TYPE_POPOVER_EVENT } from \"@libs-ui/components-popover\";\nimport { TYPE_OBJECT } from \"@libs-ui/interfaces-types\";\nimport { ERROR_MESSAGE_EMPTY_VALID, getDayjs } from \"@libs-ui/utils\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport { Dayjs } from 'dayjs';\nimport { LibsUiComponentsDatetimePickerCustomRangesComponent } from \"./custom-ranges/custom-ranges.component\";\nimport { getDateOptionsDefault } from \"./defines/date-options.define\";\nimport { IEmitDateRange, IEmitSingleDate } from \"./interfaces/calendar-emit.interface\";\nimport { IDateRange } from \"./interfaces/calendar-variables.interface\";\nimport { IDateTimePickerFunctionControlEvent } from \"./interfaces/function-control.interface\";\nimport { IChosenDate, LocalizationConfig, TYPE_RANGE_KEY } from \"./interfaces/picker.interface\";\nimport { IDateTimeValid } from \"./interfaces/valid.interface\";\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-datetime-picker',\n  templateUrl: './picker.component.html',\n  styleUrls: ['./picker.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    TranslateModule,\n    LibsUiComponentsLabelComponent,\n    LibsUiComponentsPopoverComponent,\n    LibsUiComponentsDatetimePickerCustomRangesComponent\n  ]\n})\nexport class LibsUiComponentsDatetimePickerComponent implements OnInit, OnDestroy {\n  /** PROPERTY */\n  protected readonly ERROR_MESSAGE_EMPTY_VALID = ERROR_MESSAGE_EMPTY_VALID;\n  protected showRangesPopup = signal<boolean>(false);\n  protected width = computed(this.computedWidth.bind(this));\n  protected singleError = signal<IDateTimeValid>({ message: undefined });\n  protected chosenDateFromRanges = signal<IChosenDate>({});\n  protected selectedDateFromCalendar!: { start?: Dayjs, end?: Dayjs };\n  protected displayRangeTitle = computed(() => {\n    const selectedLabel = this.chosenDateFromRanges().selectedLabel as TYPE_RANGE_KEY;\n\n    if (this.isSingle() || !selectedLabel) {\n      return;\n    }\n\n    return selectedLabel;\n  });\n  \n  private popoverFunctionControlEvent = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n  \n  /** INPUT */\n  readonly dateOptions = input<LocalizationConfig,LocalizationConfig | undefined>(getDateOptionsDefault(), { transform: (value) => value ?? getDateOptionsDefault() });\n  readonly showCustomRangeLabel = input<boolean, boolean>(true, { transform: (value) => value ?? true });\n  readonly labelConfig = input<ILabel>();\n  readonly disable = input<boolean>(false);\n  readonly readonly = input<boolean>(false);\n  readonly classInclude = input<string>('');\n  readonly classPickerInclude = input<string>('');\n  readonly classPickerContentInclude = input<string>('');\n  readonly ignoreBorderQuickRange = input<boolean>(false);\n  readonly useColorModeExist = input<boolean>(false);\n  readonly hasTimePicker = input<boolean>(true);\n  readonly allowReset = input<boolean>(true);\n  readonly widthByLabel = input<boolean, boolean>(true, { transform: (value) => value ?? true });\n  readonly directionPopover = input<TYPE_POPOVER_DIRECTION, TYPE_POPOVER_DIRECTION | undefined>('bottom', { transform: value => value ?? 'bottom' });\n  readonly defaultWidth = input<number | undefined>(undefined);\n  readonly isSingle = input<boolean>(false);\n  readonly extendRanges = input<Array<IDateRange>>([]);\n  readonly isBorderError = input<boolean>(false);\n  readonly minDate = input<Dayjs | string | undefined>();\n  readonly maxDate = input<Dayjs | string | undefined>();\n  readonly placeholder = input<string>();\n  readonly listYearHiddenInputSearch = input<boolean, boolean | undefined>(false, { transform: (value) => value ?? false });\n\n  readonly validRequired = input<IDateTimeValid | undefined>(undefined);\n  readonly ignoreStopPropagationEvent = input<boolean>(false);\n  readonly flagMouse = model<IFlagMouse>({ isMouseEnter: false, isMouseEnterContent: false });\n  readonly widthByParent = input<boolean>(false);\n  readonly zIndex = input<number, number>(1200, { transform: (value) => value ?? 1200 });\n  readonly rangesPopoverPosition = input<'start' | 'center' | 'end', 'start' | 'center' | 'end'>('start', { transform: (value) => value ?? 'start' });\n  readonly rangesPopoverPositionDistance = input<number, number>(0, { transform: (value) => value ?? 0 });\n  readonly isNgContent = input<boolean>(false);\n  readonly classIncludeCustomRanges = input<string>('');\n  readonly autoApply = input<boolean>(false);\n  readonly positionQuickRanges = input<'left' | 'right'>('left'); // vị trí list chọn nhanh khoảng thời gian\n  readonly trackDateRageUpdateLabel = input<boolean>(false);\n\n  readonly singleDateSelected = model<IEmitSingleDate>();\n  readonly dateRangeSelected = model<IEmitDateRange>();\n\n  /** OUTPUT */\n  readonly outChangStageFlagMouse = output<IFlagMouse>();\n  readonly outReset = output<IEmitDateRange | IEmitSingleDate | undefined>();\n  readonly outSelectSingleDate = output<IEmitSingleDate>();\n  readonly outSelectDateRange = output<IEmitDateRange>();\n  readonly outFunctionsControl = output<IDateTimePickerFunctionControlEvent>();\n\n  constructor() {\n    effect(() => {\n      if (this.singleDateSelected()?.date) {\n        untracked(() => {\n          const formatDate = this.hasTimePicker() ? 'DD/MM/YYYY HH:mm' : 'DD/MM/YYYY';\n          const startTime = getDayjs({ date: this.singleDateSelected()?.date })?.format(formatDate);\n          this.chosenDateFromRanges.set({ selectedLabel: startTime });\n        });\n      }\n    });\n    effect(() => {\n      if(this.trackDateRageUpdateLabel()){\n        this.updateChosenDateFromRangesFromDateRangeSelected(this.dateRangeSelected() as IEmitDateRange);\n      \n        return;\n      }\n      untracked(() => this.updateChosenDateFromRangesFromDateRangeSelected(this.dateRangeSelected() as IEmitDateRange));\n      \n    });\n  }\n\n  ngOnInit() {\n    this.outFunctionsControl.emit({\n      checkIsValid: this.checkIsValid.bind(this),\n      resetError: this.resetError.bind(this),\n      reset: this.reset.bind(this)\n    });\n  }\n\n  protected handlerSelectRanges(event: Event) {\n    event.stopPropagation();\n  }\n\n  protected handlerChangStageFlagMouse(flagMouse: IFlagMouse) {\n    this.flagMouse.set(flagMouse)\n  }\n\n  protected handlerChangStagePopoverFlagMouse(flagMouse: IFlagMouse) {\n    if (this.flagMouse()?.isMouseEnterContent) {\n      flagMouse.isMouseEnterContent = true;\n    }\n    this.outChangStageFlagMouse.emit(flagMouse);\n  }\n\n\n  protected handlerFunctionControl(event: IPopoverFunctionControlEvent) {\n    this.popoverFunctionControlEvent.set(event);\n  }\n\n  protected handlerPopoverEvent(event: TYPE_POPOVER_EVENT) {\n    if (event === 'remove') {\n      this.showRangesPopup.set(false);\n    }\n  }\n\n  protected async handlerPickerSingleDate(data: IEmitSingleDate) {\n    this.outSelectSingleDate.emit(data);\n    this.chosenDateFromRanges.set({ selectedLabel: data.displayLabel });\n    if (this.hasTimePicker()) {\n      const startTime = getDayjs<Dayjs>({ date: data.date, returnDayjsIfConfigDateNotExist: true }).format('DD/MM/YYYY HH:mm');\n\n      this.chosenDateFromRanges.update(current => {\n        current.selectedLabel = `${startTime}`;\n        return current;\n      });\n    }\n    this.singleDateSelected.set(data);\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n    await this.checkIsValid();\n  }\n\n  protected async handlerPickerDateRange(data: IEmitDateRange) {\n    if ((data.displayLabel?.indexOf('Invalid Date') ?? -1) > -1) {\n      return;\n    }\n    // this.selectedKey = data.selectedLabel;\n    this.chosenDateFromRanges.set({ selectedLabel: data.displayLabel });\n\n    // this.selected.start = getDayjs<Dayjs>({date:data.startDate});\n    // this.selected.end = getDayjs<Dayjs>({date:data.endDate});\n    if (this.hasTimePicker()) {\n      const startTime = getDayjs<Dayjs>({ date: data.startDate, returnDayjsIfConfigDateNotExist: true }).format('DD/MM/YYYY HH:mm');\n      const endTime = getDayjs<Dayjs>({ date: data.endDate, returnDayjsIfConfigDateNotExist: true }).format('DD/MM/YYYY HH:mm');\n\n      this.chosenDateFromRanges.update(current => {\n        current.selectedLabel = `${startTime} - ${endTime}`;\n        return current;\n      });\n    }\n    // this.moDatePicker.emit(this.singleDatePicker ? { chosenLabel: this.dateValue.chosenLabel, singleDate: this.dateValue.startDate?.utc(), startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() } : { chosenLabel: this.dateValue.chosenLabel, startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() });\n    const showViewExternalRangeLabel = this.extendRanges()?.find(item => item.id === this.chosenDateFromRanges().selectedLabel);\n\n    if (this.extendRanges() && showViewExternalRangeLabel) {\n      this.chosenDateFromRanges.update(current => {\n        current.selectedLabel = showViewExternalRangeLabel && showViewExternalRangeLabel.label;\n        return current;\n      });\n    }\n\n    this.dateRangeSelected.set({ quickRangeId: data.quickRangeId, displayLabel: data.displayLabel, startDate: data.startDate, endDate: data.endDate });\n    this.outSelectDateRange.emit({ quickRangeId: data.quickRangeId, displayLabel: data.displayLabel, startDate: data.startDate, endDate: data.endDate });\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n    await this.checkIsValid();\n  }\n\n  private updateChosenDateFromRangesFromDateRangeSelected(dateRangeSelected?: IEmitDateRange) {\n    untracked(()=>{\n      if (dateRangeSelected?.quickRangeId) {\n        const findKeyRange = Object.keys(this.dateOptions().ranges).find(key => key === dateRangeSelected?.quickRangeId);\n        if (findKeyRange) {\n          this.chosenDateFromRanges.set({ selectedLabel: this.dateOptions().ranges[findKeyRange] });\n          return;\n        }\n      }\n      if (dateRangeSelected?.startDate && dateRangeSelected?.endDate) {\n        const formatDate = this.hasTimePicker() ? 'DD/MM/YYYY HH:mm' : 'DD/MM/YYYY';\n        const startTime = getDayjs({ date: dateRangeSelected?.startDate })?.format(formatDate);\n        const endTime = getDayjs({ date: dateRangeSelected?.endDate })?.format(formatDate);\n  \n        this.chosenDateFromRanges.set({ selectedLabel: `${startTime} - ${endTime}` });\n      }\n    });\n  }\n\n  protected async handlerReset(event?: Event) {\n    event?.stopPropagation();\n    await this.reset(true);\n  }\n\n  private async reset(checkIsValid?: boolean, dateRangeReset?: IEmitDateRange, singleDateReset?: IEmitSingleDate) {\n    this.chosenDateFromRanges.set({});\n    this.dateRangeSelected.set(dateRangeReset);\n    if (dateRangeReset) {\n      this.updateChosenDateFromRangesFromDateRangeSelected(dateRangeReset);\n    }\n    if (singleDateReset) {\n      this.singleDateSelected.set(singleDateReset);\n    }\n    this.outReset.emit(dateRangeReset || singleDateReset);\n    if (checkIsValid && this.validRequired()) {\n      await this.checkIsValid();\n    }\n  }\n\n  protected handlerUpdateWidth() {\n    this.popoverFunctionControlEvent()?.updatePopoverOverlayPosition();\n  }\n\n  protected handlerCancel() {\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n  }\n\n  private async checkIsValid() {\n    if (this.readonly() || this.disable()) {\n      return true;\n    }\n    await this.validate();\n\n    return this.singleError().message ? false : true;\n  }\n\n  private async validate() {\n    this.singleError.set({ message: undefined });\n\n    if (!this.validRequired()) {\n      return;\n    }\n\n    if (this.validRequired() && !this.chosenDateFromRanges().selectedLabel) {\n      this.singleError.set({\n        message: this.validRequired()?.message || ERROR_MESSAGE_EMPTY_VALID,\n        interpolateParams: this.validRequired()?.interpolateParams || {}\n      });\n\n      return;\n    }\n  }\n\n  private async resetError(message?:string,interpolateParams?:TYPE_OBJECT) {\n    this.singleError.set({ message, interpolateParams });\n  }\n\n  private computedWidth() {\n    if (this.widthByLabel()) {\n      return;\n    }\n\n    if (this.defaultWidth()) {\n      return this.defaultWidth();\n    }\n\n    if (this.hasTimePicker()) {\n      return !this.isSingle() ? 322 : 190;\n    }\n    return !this.isSingle() ? 232 : 152;\n  }\n\n  ngOnDestroy() {\n    return;\n  }\n}\n\n","<div class=\"libs-ui-date-picker {{ classInclude() }}\">\n  @if (labelConfig(); as labelConfig) {\n    <libs_ui-components-label [classInclude]=\"labelConfig.classInclude\"\n      [labelLeft]=\"labelConfig.labelLeft\"\n      [labelLeftClass]=\"labelConfig.labelLeftClass\"\n      [required]=\"labelConfig.required \"\n      [description]=\"labelConfig.description\"\n      [descriptionClass]=\"labelConfig.descriptionClass\"\n      [labelRight]=\"labelConfig.labelRight\"\n      [labelRightClass]=\"labelConfig.labelRightClass\"\n      [onlyShowCount]=\"labelConfig.onlyShowCount\"\n      [buttonsLeft]=\"labelConfig.buttonsLeft\"\n      [buttonsRight]=\"labelConfig.buttonsRight\"\n      [disableButtonsLeft]=\"labelConfig.disableButtonsLeft || disable()\"\n      [disableButtonsRight]=\"labelConfig.disableButtonsRight || disable()\"\n      [hasToggle]=\"labelConfig.hasToggle\"\n      [toggleActive]=\"labelConfig.toggleActive\"\n      [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n      [popover]=\"labelConfig.popover\"\n      [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n      [onlyShowCount]=\"labelConfig.onlyShowCount\"\n      [limitLength]=\"labelConfig.limitLength\"\n      [buttonsDescription]=\"labelConfig.buttonsDescription\"\n      [disableButtonsDescription]=\"labelConfig.disableButtonsDescription || disable()\"\n      [buttonsDescriptionContainerClass]=\"labelConfig.buttonsDescriptionContainerClass\"\n      [count]=\"labelConfig.count\" />\n  }\n  <div class=\"flex w-full\">\n    <libs_ui-components-popover [class]=\"classPickerInclude()\"\n      [ignoreShowPopover]=\"disable() || readonly()\"\n      [mode]=\"'click'\"\n      [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n      [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n      [flagMouse]=\"flagMouse()\"\n      [config]=\"{\n        animationConfig:{},\n        maxWidth: 770,\n        maxHeight: 425,\n        directionDistance:2,\n        template: customRangesRef,\n        widthByParent: widthByParent(),\n        whiteTheme: true,\n        ignoreArrow: true,\n        zIndex: zIndex(),\n        classInclude: 'rounded-[4px] ',\n        direction:directionPopover(),\n        position: {mode: rangesPopoverPosition(),distance: rangesPopoverPositionDistance()}}\"\n      (outChangStageFlagMouse)=\"handlerChangStagePopoverFlagMouse($event)\"\n      (outFunctionsControl)=\"handlerFunctionControl($event)\"\n      (outEvent)=\"handlerPopoverEvent($event)\">\n      @if (!isNgContent()) {\n        <div #containerRef\n          class=\"flex items-center px-[12px] h-[32px] rounded-[4px] bg-[#ffffff] cursor-pointer libs-ui-font-h5r {{ classPickerContentInclude() }}\"\n          [class.libs-ui-disable]=\"disable()\"\n          [class.libs-ui-disable-background]=\"disable()\"\n          [class.!border-none]=\"ignoreBorderQuickRange()\"\n          [class.libs-ui-border-general]=\"!singleError().message && !ignoreBorderQuickRange()\"\n          [class.libs-ui-border-error-general]=\"(singleError().message || isBorderError()) && !ignoreBorderQuickRange()\"\n          [class.min-w-[284px]]=\"!chosenDateFromRanges().selectedLabel && !isSingle() && hasTimePicker()\"\n          [class.!border]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n          [class.!border-[#4e8cf7]]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n          [class.libs-ui-readonly]=\"readonly()\"\n          [class.libs-ui-readonly-background]=\"readonly()\"\n          [style.width.px]=\"width()\"\n          (click)=\"handlerSelectRanges($event)\">\n          <div class=\"libs-ui-icon-calendar text-[#9ca2ad] text-[16px]\"></div>\n          <div class=\"ml-[8px] libs-ui-date-picker-label\"\n            [class.!text-[#071631]]=\"!disable()\"\n            [class.!text-[#9ca2ad]]=\"disable()\">\n            @if (!chosenDateFromRanges().selectedLabel) {\n              @if (!isSingle()) {\n                @if (!placeholder()) {\n                  <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>} -\n                  dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>}</span>\n                } @else {\n                  <span class=\"text-[#9ca2ad]\">{{ (placeholder() || ' ') |translate }} </span>\n                }\n              }\n              @if (isSingle()) {\n                @if (!placeholder()) {\n                  <span class=\"text-[#9ca2ad]\">dd/mm/yyyy@if (hasTimePicker()) {<span>&nbsp;hh:mm</span>}</span>\n                } @else {\n                  <span class=\"text-[#9ca2ad]\">{{ (placeholder() || ' ') |translate }} </span>\n                }\n\n                }\n                }\n                @if (chosenDateFromRanges().selectedLabel && !isSingle()) {\n                  {{ displayRangeTitle() }}\n                }\n                @if (chosenDateFromRanges().selectedLabel && isSingle()) {\n                  <span [class.text-[#29c7cc]]=\"useColorModeExist() || false\">\n                    {{ chosenDateFromRanges().selectedLabel }}\n                  </span>\n                }\n          </div>\n          @if (chosenDateFromRanges().selectedLabel && allowReset() && !disable() && !readonly()) {\n            <div class=\"pl-[12px] ml-auto h-full flex items-center\">\n              <i class=\"libs-ui-icon-close-circle-solid text-[16px] text-[#cdd0d6]\"\n                (click)=\"handlerReset($event)\"></i>\n            </div>\n          }\n        </div>\n        }\n        @if (isNgContent()) {\n          <div (click)=\"handlerSelectRanges($event)\">\n            <ng-content></ng-content>\n          </div>\n        }\n    </libs_ui-components-popover>\n  </div>\n  @if (singleError().message && !validRequired()?.ignoreMessage) {\n    <div class=\"mt-[8px] text-[#ee2d41] libs-ui-font-h7r libs-ui-text-error\"\n      [innerHTML]=\"(singleError().message || ERROR_MESSAGE_EMPTY_VALID)| translate:validRequired()?.interpolateParams\">\n    </div>\n  }\n</div>\n\n<ng-template #customRangesRef>\n  <libs_ui-components-datetime-picker-custom_ranges [zIndex]=\"zIndex()\"\n    [classInclude]=\"classIncludeCustomRanges()\"\n    [widthByParent]=\"widthByParent()\"\n    [dateOptions]=\"dateOptions()\"\n    [positionQuickRanges]=\"positionQuickRanges()\"\n    [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n    [autoApply]=\"autoApply()\"\n    [isSingle]=\"isSingle()\"\n    [minDate]=\"minDate()\"\n    [maxDate]=\"maxDate()\"\n    [listYearHiddenInputSearch]=\"listYearHiddenInputSearch()\"\n    [singleDateSelected]=\"singleDateSelected()\"\n    [dateRangeSelected]=\"dateRangeSelected()\"\n    [extendRanges]=\"extendRanges()\"\n    [hasTimePicker]=\"hasTimePicker()\"\n    (outUpdateWidth)=\"handlerUpdateWidth()\"\n    (outCancel)=\"handlerCancel()\"\n    (outSelectSingleDate)=\"handlerPickerSingleDate($event)\"\n    (outSelectDateRange)=\"handlerPickerDateRange($event)\"\n    (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\"\n    (outClickMenuRangeCustom)=\"handlerUpdateWidth()\" />\n</ng-template>\n"]}
247
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picker.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/datetime/picker/src/picker.component.ts","../../../../../../libs-ui/components/datetime/picker/src/picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, input, model, OnDestroy, OnInit, output, signal, untracked } from '@angular/core';\nimport { ILabel, LibsUiComponentsLabelComponent } from '@libs-ui/components-label';\nimport { IFlagMouse, IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_DIRECTION, TYPE_POPOVER_EVENT } from '@libs-ui/components-popover';\nimport { TYPE_OBJECT } from '@libs-ui/interfaces-types';\nimport { ERROR_MESSAGE_EMPTY_VALID, getDayjs } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { Dayjs } from 'dayjs';\nimport { LibsUiComponentsDatetimePickerCustomRangesComponent } from './custom-ranges/custom-ranges.component';\nimport { getDateOptionsDefault } from './defines/date-options.define';\nimport { IEmitDateRange, IEmitSingleDate } from './interfaces/calendar-emit.interface';\nimport { IDateRange } from './interfaces/calendar-variables.interface';\nimport { IDateTimePickerFunctionControlEvent } from './interfaces/function-control.interface';\nimport { IChosenDate, LocalizationConfig, TYPE_RANGE_KEY } from './interfaces/picker.interface';\nimport { IDateTimeValid } from './interfaces/valid.interface';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-datetime-picker',\n  templateUrl: './picker.component.html',\n  styleUrls: ['./picker.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [TranslateModule, LibsUiComponentsLabelComponent, LibsUiComponentsPopoverComponent, LibsUiComponentsDatetimePickerCustomRangesComponent],\n})\nexport class LibsUiComponentsDatetimePickerComponent implements OnInit, OnDestroy {\n  /** PROPERTY */\n  protected readonly ERROR_MESSAGE_EMPTY_VALID = ERROR_MESSAGE_EMPTY_VALID;\n  protected showRangesPopup = signal<boolean>(false);\n  protected width = computed(this.computedWidth.bind(this));\n  protected singleError = signal<IDateTimeValid>({ message: undefined });\n  protected chosenDateFromRanges = signal<IChosenDate>({});\n  protected selectedDateFromCalendar!: { start?: Dayjs; end?: Dayjs };\n  protected displayRangeTitle = computed(() => {\n    const selectedLabel = this.chosenDateFromRanges().selectedLabel as TYPE_RANGE_KEY;\n\n    if (this.isSingle() || !selectedLabel) {\n      return;\n    }\n\n    return selectedLabel;\n  });\n\n  private popoverFunctionControlEvent = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n\n  /** INPUT */\n  readonly dateOptions = input<LocalizationConfig, LocalizationConfig | undefined>(getDateOptionsDefault(), { transform: (value) => value ?? getDateOptionsDefault() });\n  readonly showCustomRangeLabel = input<boolean, boolean>(true, { transform: (value) => value ?? true });\n  readonly labelConfig = input<ILabel>();\n  readonly disable = input<boolean>(false);\n  readonly readonly = input<boolean>(false);\n  readonly classInclude = input<string>('');\n  readonly classPickerInclude = input<string>('');\n  readonly classPickerContentInclude = input<string>('');\n  readonly ignoreBorderQuickRange = input<boolean>(false);\n  readonly useColorModeExist = input<boolean>(false);\n  readonly hasTimePicker = input<boolean>(true);\n  readonly allowReset = input<boolean>(true);\n  readonly widthByLabel = input<boolean, boolean>(true, { transform: (value) => value ?? true });\n  readonly directionPopover = input<TYPE_POPOVER_DIRECTION, TYPE_POPOVER_DIRECTION | undefined>('bottom', { transform: (value) => value ?? 'bottom' });\n  readonly defaultWidth = input<number | undefined>(undefined);\n  readonly isSingle = input<boolean>(false);\n  readonly extendRanges = input<Array<IDateRange>>([]);\n  readonly isBorderError = input<boolean>(false);\n  readonly minDate = input<Dayjs | string | undefined>();\n  readonly maxDate = input<Dayjs | string | undefined>();\n  readonly placeholder = input<string>();\n  readonly listYearHiddenInputSearch = input<boolean, boolean | undefined>(false, { transform: (value) => value ?? false });\n\n  readonly validRequired = input<IDateTimeValid | undefined>(undefined);\n  readonly ignoreStopPropagationEvent = input<boolean>(false);\n  readonly flagMouse = model<IFlagMouse>({ isMouseEnter: false, isMouseEnterContent: false });\n  readonly widthByParent = input<boolean>(false);\n  readonly zIndex = input<number, number>(1200, { transform: (value) => value ?? 1200 });\n  readonly rangesPopoverPosition = input<'start' | 'center' | 'end', 'start' | 'center' | 'end'>('start', { transform: (value) => value ?? 'start' });\n  readonly rangesPopoverPositionDistance = input<number, number>(0, { transform: (value) => value ?? 0 });\n  readonly isNgContent = input<boolean>(false);\n  readonly classIncludeCustomRanges = input<string>('');\n  readonly autoApply = input<boolean>(false);\n  readonly positionQuickRanges = input<'left' | 'right'>('left'); // vị trí list chọn nhanh khoảng thời gian\n  readonly trackDateRageUpdateLabel = input<boolean>(false);\n\n  readonly singleDateSelected = model<IEmitSingleDate>();\n  readonly dateRangeSelected = model<IEmitDateRange>();\n\n  /** OUTPUT */\n  readonly outChangStageFlagMouse = output<IFlagMouse>();\n  readonly outReset = output<IEmitDateRange | IEmitSingleDate | undefined>();\n  readonly outSelectSingleDate = output<IEmitSingleDate>();\n  readonly outSelectDateRange = output<IEmitDateRange>();\n  readonly outFunctionsControl = output<IDateTimePickerFunctionControlEvent>();\n\n  constructor() {\n    effect(() => {\n      const date = this.singleDateSelected()?.date;\n\n      if (date) {\n        untracked(() => {\n          const formatDate = this.hasTimePicker() ? 'DD/MM/YYYY HH:mm' : 'DD/MM/YYYY';\n          const startTime = getDayjs({ date }).format(formatDate);\n          this.chosenDateFromRanges.set({ selectedLabel: startTime });\n        });\n      }\n    });\n    effect(() => {\n      if (this.trackDateRageUpdateLabel()) {\n        this.updateChosenDateFromRangesFromDateRangeSelected(this.dateRangeSelected() as IEmitDateRange);\n\n        return;\n      }\n      untracked(() => this.updateChosenDateFromRangesFromDateRangeSelected(this.dateRangeSelected() as IEmitDateRange));\n    });\n  }\n\n  ngOnInit() {\n    this.outFunctionsControl.emit(this.FunctionsControl);\n  }\n\n  public get FunctionsControl(): IDateTimePickerFunctionControlEvent {\n    return {\n      checkIsValid: this.checkIsValid.bind(this),\n      resetError: this.resetError.bind(this),\n      reset: this.reset.bind(this),\n    };\n  }\n\n  protected handlerSelectRanges(event: Event) {\n    event.stopPropagation();\n  }\n\n  protected handlerChangStageFlagMouse(flagMouse: IFlagMouse) {\n    this.flagMouse.set(flagMouse);\n  }\n\n  protected handlerChangStagePopoverFlagMouse(flagMouse: IFlagMouse) {\n    if (this.flagMouse()?.isMouseEnterContent) {\n      flagMouse.isMouseEnterContent = true;\n    }\n    this.outChangStageFlagMouse.emit(flagMouse);\n  }\n\n  protected handlerFunctionControl(event: IPopoverFunctionControlEvent) {\n    this.popoverFunctionControlEvent.set(event);\n  }\n\n  protected handlerPopoverEvent(event: TYPE_POPOVER_EVENT) {\n    if (event === 'remove') {\n      this.showRangesPopup.set(false);\n    }\n  }\n\n  protected async handlerPickerSingleDate(data: IEmitSingleDate) {\n    this.outSelectSingleDate.emit(data);\n    this.chosenDateFromRanges.set({ selectedLabel: data.displayLabel });\n    if (this.hasTimePicker()) {\n      const startTime = getDayjs({ date: data.date, returnDayjsIfConfigDateNotExist: true }).format('DD/MM/YYYY HH:mm');\n\n      this.chosenDateFromRanges.update((current) => {\n        current.selectedLabel = `${startTime}`;\n        return current;\n      });\n    }\n    this.singleDateSelected.set(data);\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n    await this.checkIsValid();\n  }\n\n  protected async handlerPickerDateRange(data: IEmitDateRange) {\n    if ((data.displayLabel?.indexOf('Invalid Date') ?? -1) > -1) {\n      return;\n    }\n    // this.selectedKey = data.selectedLabel;\n    this.chosenDateFromRanges.set({ selectedLabel: data.displayLabel });\n\n    // this.selected.start = getDayjs<Dayjs>({date:data.startDate});\n    // this.selected.end = getDayjs<Dayjs>({date:data.endDate});\n    if (this.hasTimePicker()) {\n      const startTime = getDayjs({ date: data.startDate, returnDayjsIfConfigDateNotExist: true }).format('DD/MM/YYYY HH:mm');\n      const endTime = getDayjs({ date: data.endDate, returnDayjsIfConfigDateNotExist: true }).format('DD/MM/YYYY HH:mm');\n\n      this.chosenDateFromRanges.update((current) => {\n        current.selectedLabel = `${startTime} - ${endTime}`;\n        return current;\n      });\n    }\n    // this.moDatePicker.emit(this.singleDatePicker ? { chosenLabel: this.dateValue.chosenLabel, singleDate: this.dateValue.startDate?.utc(), startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() } : { chosenLabel: this.dateValue.chosenLabel, startDate: this.dateValue.startDate?.utc(), endDate: this.dateValue.endDate?.utc() });\n    const showViewExternalRangeLabel = this.extendRanges()?.find((item) => item.id === this.chosenDateFromRanges().selectedLabel);\n\n    if (this.extendRanges() && showViewExternalRangeLabel) {\n      this.chosenDateFromRanges.update((current) => {\n        current.selectedLabel = showViewExternalRangeLabel && showViewExternalRangeLabel.label;\n        return current;\n      });\n    }\n\n    this.dateRangeSelected.set({ quickRangeId: data.quickRangeId, displayLabel: data.displayLabel, startDate: data.startDate, endDate: data.endDate });\n    this.outSelectDateRange.emit({ quickRangeId: data.quickRangeId, displayLabel: data.displayLabel, startDate: data.startDate, endDate: data.endDate });\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n    await this.checkIsValid();\n  }\n\n  private updateChosenDateFromRangesFromDateRangeSelected(dateRangeSelected?: IEmitDateRange) {\n    untracked(() => {\n      if (dateRangeSelected?.quickRangeId) {\n        const findKeyRange = Object.keys(this.dateOptions().ranges).find((key) => key === dateRangeSelected?.quickRangeId);\n        if (findKeyRange) {\n          this.chosenDateFromRanges.set({ selectedLabel: this.dateOptions().ranges[findKeyRange] });\n          return;\n        }\n      }\n      if (dateRangeSelected?.startDate && dateRangeSelected?.endDate) {\n        const formatDate = this.hasTimePicker() ? 'DD/MM/YYYY HH:mm' : 'DD/MM/YYYY';\n        const startTime = getDayjs({ date: dateRangeSelected?.startDate })?.format(formatDate);\n        const endTime = getDayjs({ date: dateRangeSelected?.endDate })?.format(formatDate);\n\n        this.chosenDateFromRanges.set({ selectedLabel: `${startTime} - ${endTime}` });\n      }\n    });\n  }\n\n  protected async handlerReset(event?: Event) {\n    event?.stopPropagation();\n    await this.reset(true);\n  }\n\n  private async reset(checkIsValid?: boolean, dateRangeReset?: IEmitDateRange, singleDateReset?: IEmitSingleDate) {\n    this.chosenDateFromRanges.set({});\n    this.dateRangeSelected.set(dateRangeReset);\n    if (dateRangeReset) {\n      this.updateChosenDateFromRangesFromDateRangeSelected(dateRangeReset);\n    }\n    if (singleDateReset) {\n      this.singleDateSelected.set(singleDateReset);\n    }\n    this.outReset.emit(dateRangeReset || singleDateReset);\n    if (checkIsValid && this.validRequired()) {\n      await this.checkIsValid();\n    }\n  }\n\n  protected handlerUpdateWidth() {\n    this.popoverFunctionControlEvent()?.updatePopoverOverlayPosition();\n  }\n\n  protected handlerCancel() {\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n  }\n\n  private async checkIsValid() {\n    if (this.readonly() || this.disable()) {\n      return true;\n    }\n    await this.validate();\n\n    return this.singleError().message ? false : true;\n  }\n\n  private async validate() {\n    this.singleError.set({ message: undefined });\n\n    if (!this.validRequired()) {\n      return;\n    }\n\n    if (this.validRequired() && !this.chosenDateFromRanges().selectedLabel) {\n      this.singleError.set({\n        message: this.validRequired()?.message || ERROR_MESSAGE_EMPTY_VALID,\n        interpolateParams: this.validRequired()?.interpolateParams || {},\n      });\n\n      return;\n    }\n  }\n\n  private async resetError(message?: string, interpolateParams?: TYPE_OBJECT) {\n    this.singleError.set({ message, interpolateParams });\n  }\n\n  private computedWidth() {\n    if (this.widthByLabel()) {\n      return;\n    }\n\n    if (this.defaultWidth()) {\n      return this.defaultWidth();\n    }\n\n    if (this.hasTimePicker()) {\n      return !this.isSingle() ? 322 : 190;\n    }\n    return !this.isSingle() ? 232 : 152;\n  }\n\n  ngOnDestroy() {\n    return;\n  }\n}\n","<div class=\"libs-ui-date-picker {{ classInclude() }}\">\n  @if (labelConfig(); as labelConfig) {\n    <libs_ui-components-label\n      [classInclude]=\"labelConfig.classInclude\"\n      [labelLeft]=\"labelConfig.labelLeft\"\n      [labelLeftClass]=\"labelConfig.labelLeftClass\"\n      [required]=\"labelConfig.required\"\n      [description]=\"labelConfig.description\"\n      [descriptionClass]=\"labelConfig.descriptionClass\"\n      [labelRight]=\"labelConfig.labelRight\"\n      [labelRightClass]=\"labelConfig.labelRightClass\"\n      [onlyShowCount]=\"labelConfig.onlyShowCount\"\n      [buttonsLeft]=\"labelConfig.buttonsLeft\"\n      [buttonsRight]=\"labelConfig.buttonsRight\"\n      [disableButtonsLeft]=\"labelConfig.disableButtonsLeft || disable()\"\n      [disableButtonsRight]=\"labelConfig.disableButtonsRight || disable()\"\n      [hasToggle]=\"labelConfig.hasToggle\"\n      [toggleActive]=\"labelConfig.toggleActive\"\n      [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n      [popover]=\"labelConfig.popover\"\n      [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n      [onlyShowCount]=\"labelConfig.onlyShowCount\"\n      [limitLength]=\"labelConfig.limitLength\"\n      [buttonsDescription]=\"labelConfig.buttonsDescription\"\n      [disableButtonsDescription]=\"labelConfig.disableButtonsDescription || disable()\"\n      [buttonsDescriptionContainerClass]=\"labelConfig.buttonsDescriptionContainerClass\"\n      [count]=\"labelConfig.count\" />\n  }\n  <div class=\"flex w-full\">\n    <libs_ui-components-popover\n      [class]=\"classPickerInclude()\"\n      [ignoreShowPopover]=\"disable() || readonly()\"\n      [mode]=\"'click'\"\n      [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n      [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n      [flagMouse]=\"flagMouse()\"\n      [config]=\"{\n        animationConfig: {},\n        maxWidth: 770,\n        maxHeight: 425,\n        directionDistance: 2,\n        template: customRangesRef,\n        widthByParent: widthByParent(),\n        whiteTheme: true,\n        ignoreArrow: true,\n        zIndex: zIndex(),\n        classInclude: 'rounded-[4px] ',\n        direction: directionPopover(),\n        position: { mode: rangesPopoverPosition(), distance: rangesPopoverPositionDistance() },\n      }\"\n      (outChangStageFlagMouse)=\"handlerChangStagePopoverFlagMouse($event)\"\n      (outFunctionsControl)=\"handlerFunctionControl($event)\"\n      (outEvent)=\"handlerPopoverEvent($event)\">\n      @if (!isNgContent()) {\n        <div\n          #containerRef\n          class=\"flex items-center px-[12px] h-[32px] rounded-[4px] bg-[#ffffff] cursor-pointer libs-ui-font-h5r {{ classPickerContentInclude() }}\"\n          [class.libs-ui-disable]=\"disable()\"\n          [class.libs-ui-disable-background]=\"disable()\"\n          [class.!border-none]=\"ignoreBorderQuickRange()\"\n          [class.libs-ui-border-general]=\"!singleError().message && !ignoreBorderQuickRange()\"\n          [class.libs-ui-border-error-general]=\"(singleError().message || isBorderError()) && !ignoreBorderQuickRange()\"\n          [class.min-w-[284px]]=\"!chosenDateFromRanges().selectedLabel && !isSingle() && hasTimePicker()\"\n          [class.!border]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n          [class.!border-[#4e8cf7]]=\"showRangesPopup() && !ignoreBorderQuickRange() && !readonly()\"\n          [class.libs-ui-readonly]=\"readonly()\"\n          [class.libs-ui-readonly-background]=\"readonly()\"\n          [style.width.px]=\"width()\"\n          (click)=\"handlerSelectRanges($event)\">\n          <div class=\"libs-ui-icon-calendar text-[#9ca2ad] text-[16px]\"></div>\n          <div\n            class=\"ml-[8px] libs-ui-date-picker-label\"\n            [class.!text-[#071631]]=\"!disable()\"\n            [class.!text-[#9ca2ad]]=\"disable()\">\n            @if (!chosenDateFromRanges().selectedLabel) {\n              @if (!isSingle()) {\n                @if (!placeholder()) {\n                  <span class=\"text-[#9ca2ad]\">\n                    dd/mm/yyyy\n                    @if (hasTimePicker()) {\n                      <span>&nbsp;hh:mm</span>\n                    }\n                    - dd/mm/yyyy\n                    @if (hasTimePicker()) {\n                      <span>&nbsp;hh:mm</span>\n                    }\n                  </span>\n                } @else {\n                  <span class=\"text-[#9ca2ad]\">{{ placeholder() || ' ' | translate }}</span>\n                }\n              }\n              @if (isSingle()) {\n                @if (!placeholder()) {\n                  <span class=\"text-[#9ca2ad]\">\n                    dd/mm/yyyy\n                    @if (hasTimePicker()) {\n                      <span>&nbsp;hh:mm</span>\n                    }\n                  </span>\n                } @else {\n                  <span class=\"text-[#9ca2ad]\">{{ placeholder() || ' ' | translate }}</span>\n                }\n              }\n            }\n            @if (chosenDateFromRanges().selectedLabel && !isSingle()) {\n              {{ displayRangeTitle() }}\n            }\n            @if (chosenDateFromRanges().selectedLabel && isSingle()) {\n              <span [class.text-[#29c7cc]]=\"useColorModeExist() || false\">\n                {{ chosenDateFromRanges().selectedLabel }}\n              </span>\n            }\n          </div>\n          @if (chosenDateFromRanges().selectedLabel && allowReset() && !disable() && !readonly()) {\n            <div class=\"pl-[12px] ml-auto h-full flex items-center\">\n              <i\n                class=\"libs-ui-icon-close-circle-solid text-[16px] text-[#cdd0d6]\"\n                (click)=\"handlerReset($event)\"></i>\n            </div>\n          }\n        </div>\n      }\n      @if (isNgContent()) {\n        <div (click)=\"handlerSelectRanges($event)\">\n          <ng-content></ng-content>\n        </div>\n      }\n    </libs_ui-components-popover>\n  </div>\n  @if (singleError().message && !validRequired()?.ignoreMessage) {\n    <div\n      class=\"mt-[8px] text-[#ee2d41] libs-ui-font-h7r libs-ui-text-error\"\n      [innerHTML]=\"singleError().message || ERROR_MESSAGE_EMPTY_VALID | translate: validRequired()?.interpolateParams\"></div>\n  }\n</div>\n\n<ng-template #customRangesRef>\n  <libs_ui-components-datetime-picker-custom_ranges\n    [zIndex]=\"zIndex()\"\n    [classInclude]=\"classIncludeCustomRanges()\"\n    [widthByParent]=\"widthByParent()\"\n    [dateOptions]=\"dateOptions()\"\n    [positionQuickRanges]=\"positionQuickRanges()\"\n    [showCustomRangeLabel]=\"showCustomRangeLabel()\"\n    [autoApply]=\"autoApply()\"\n    [isSingle]=\"isSingle()\"\n    [minDate]=\"minDate()\"\n    [maxDate]=\"maxDate()\"\n    [listYearHiddenInputSearch]=\"listYearHiddenInputSearch()\"\n    [singleDateSelected]=\"singleDateSelected()\"\n    [dateRangeSelected]=\"dateRangeSelected()\"\n    [extendRanges]=\"extendRanges()\"\n    [hasTimePicker]=\"hasTimePicker()\"\n    (outUpdateWidth)=\"handlerUpdateWidth()\"\n    (outCancel)=\"handlerCancel()\"\n    (outSelectSingleDate)=\"handlerPickerSingleDate($event)\"\n    (outSelectDateRange)=\"handlerPickerDateRange($event)\"\n    (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\"\n    (outClickMenuRangeCustom)=\"handlerUpdateWidth()\" />\n</ng-template>\n"]}