@datarailsshared/datarailsshared 1.6.59 → 1.6.63
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/datarailsshared-datarailsshared-1.6.63.tgz +0 -0
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +16 -5
- package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +84 -55
- package/fesm2022/datarailsshared-datarailsshared.mjs +1441 -1402
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-inputs/dr-select/dr-select.component.d.ts +3 -1
- package/package.json +1 -1
- package/datarailsshared-datarailsshared-1.6.59.tgz +0 -0
|
Binary file
|
|
@@ -180,10 +180,21 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
180
180
|
restrictPagination() {
|
|
181
181
|
if (!this._min && !this._max)
|
|
182
182
|
return;
|
|
183
|
-
const
|
|
184
|
-
const
|
|
185
|
-
|
|
186
|
-
|
|
183
|
+
const timeFrame = this.datePickerService.timeframe;
|
|
184
|
+
const nextValue = this.pagingSetup[timeFrame](true);
|
|
185
|
+
const prevValue = this.pagingSetup[timeFrame](false);
|
|
186
|
+
const granularity = timeFrame;
|
|
187
|
+
/* TODO: Take into account fiscal year start and back for cases where fiscal year and quarter is true - https://datarailsteam.atlassian.net/browse/DR-35528 and
|
|
188
|
+
https://datarailsteam.atlassian.net/browse/DR-35568
|
|
189
|
+
*/
|
|
190
|
+
if (this.fiscalYearBack || this.fiscalYearMonthsModifier !== 0) {
|
|
191
|
+
this.isNextDateDisabled = this._max && nextValue && nextValue.unix() > this._max.unix();
|
|
192
|
+
this.isPrevDateDisabled = this._min && prevValue && prevValue.unix() < this._min.unix();
|
|
193
|
+
}
|
|
194
|
+
else {
|
|
195
|
+
this.isNextDateDisabled = !!(this._max && nextValue && !nextValue.isSameOrBefore(this._max, granularity));
|
|
196
|
+
this.isPrevDateDisabled = !!(this._min && prevValue && !prevValue.isSameOrAfter(this._min, granularity));
|
|
197
|
+
}
|
|
187
198
|
}
|
|
188
199
|
/** @nocollapse */ static { this.ɵfac = function DrDatePickerWithTimeframeComponent_Factory(t) { return new (t || DrDatePickerWithTimeframeComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.DateAdapter), i0.ɵɵdirectiveInject(i2.DrDatePickerService)); }; }
|
|
189
200
|
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrDatePickerWithTimeframeComponent, selectors: [["dr-date-picker-with-timeframe"]], hostVars: 2, hostBindings: function DrDatePickerWithTimeframeComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
@@ -266,4 +277,4 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
266
277
|
}], onChangePresetTag: [{
|
|
267
278
|
type: Output
|
|
268
279
|
}] }); })();
|
|
269
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker-with-timeframe.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { CustomDateAdapter, DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateTags, IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { debounceTime, map, takeUntil } from 'rxjs/operators';\nimport * as _ from 'lodash';\nimport { Subject } from 'rxjs';\nimport { Moment } from 'moment';\nimport { PRESET_TAGS_LIST } from '../../../models/constants';\nimport { TooltipPosition } from '../../../dr-tooltip/enums/tooltip-position.enum';\n\n@Component({\n    selector: 'dr-date-picker-with-timeframe',\n    templateUrl: './dr-date-picker-with-timeframe.component.html',\n    styleUrls: ['./dr-date-picker-with-timeframe.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },\n        { provide: DateAdapter, useClass: CustomDateAdapter },\n        { provide: DrDatePickerService },\n    ],\n})\nexport class DrDatePickerWithTimeframeComponent\n    extends DrDatePickerComponent\n    implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit, OnChanges\n{\n    presetTagSelected: string;\n\n    @HostBinding('class.dr-date-picker-on-dashboard') get isDashboardClassDisplayed(): boolean {\n        return this.isDashboardDatepicker;\n    }\n\n    @Input() isDashboardDatepicker = false;\n\n    @Input() set dateFormatConfig(value: IDatePickerFormatConfig) {\n        if (value) {\n            this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...value };\n            this.cdr.markForCheck();\n        }\n    }\n\n    @Input() canSelectTimeframe = true;\n\n    @Input() set availableTimeframes(value: TimeframeOption[]) {\n        if (value && value.length) {\n            this.datePickerService.availableTimeframes = value;\n        }\n    }\n    @Input() paginationDebounce;\n\n    @Input() set isUsingDateTagPresets(flag: boolean) {\n        this.datePickerService.isUsingDateTagPresets = flag;\n    }\n\n    @Input() set presetTag(tag: string) {\n        this.datePickerService.presetTag$.next(tag as DateTags);\n    }\n\n    @Input() datepickerTooltip: TemplateRef<any> | null;\n    @Input() datepickerTooltipPosition: string = TooltipPosition.TOP;\n    @Input() datepickerTooltipTimeout: number = 0;\n\n    @Input() isOpen: boolean = false;\n\n    @Output() onChangeFormat = new EventEmitter<string>();\n    @Output() onChangePresetTag = new EventEmitter<DateTags>();\n\n    private readonly pagingSetup = {\n        [TimeframeOption.YEAR]: (forward) => this.getNextDate('addCalendarYears', 1, forward),\n        [TimeframeOption.QUARTER]: (forward) => this.getNextDate('addCalendarMonths', 3, forward),\n        [TimeframeOption.MONTH]: (forward) => this.getNextDate('addCalendarMonths', 1, forward),\n        [TimeframeOption.DAY]: (forward) => this.getNextDate('addCalendarDays', 1, forward),\n        [TimeframeOption.WEEK]: (forward) => this.getNextDate('addCalendarDays', 7, forward),\n    };\n\n    public isNextDateDisabled = false;\n    public isPrevDateDisabled = false;\n\n    private onChangeDebounced$: Subject<number> = new Subject<number>();\n\n    public displayedFormattedValue$ = this.displayValue$.pipe(\n        takeUntil(this.destroyed$),\n        map((value: Moment) => {\n            if (!value) return this.placeholder;\n            return (\n                this.datePickerService.getDisplayPrefix() +\n                this.dateAdapter.format(value, this.datePickerService.getConfiguredFormat(this.datePickerService.timeframe))\n            );\n        }),\n    );\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected dateAdapter: DateAdapter<any>,\n        public datePickerService: DrDatePickerService,\n    ) {\n        super(cdr, dateAdapter, datePickerService);\n        datePickerService.isTimeframeSelectionEnabled = true;\n\n        datePickerService.format$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.onChangeFormat.emit(datePickerService.normalizeValue(value));\n        });\n\n        datePickerService.presetTag$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            let tagObj = PRESET_TAGS_LIST.find((val) => val?.key === value);\n            this.presetTagSelected = tagObj?.label;\n            this.onChangePresetTag.emit(value);\n        });\n\n        this.datePickerService.onSameDaySelectedInCalendar$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.setValueFromMoment(value);\n        });\n\n        datePickerService.updatedDateAndClose$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            if (value) {\n                this.setValueFromMoment(value);\n            } else {\n                this.onChangeCallback(this.innerValue.unix());\n            }\n            this.datePicker.close();\n        });\n    }\n\n    ngOnInit() {\n        this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;\n        this.cdr.markForCheck();\n\n        if (this.paginationDebounce) {\n            this.onChangeDebounced$.pipe(takeUntil(this.destroyed$), debounceTime(this.paginationDebounce)).subscribe((value) => {\n                this.onChangeCallback(value);\n            });\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.format?.currentValue && changes.format.currentValue !== changes.format.previousValue) {\n            this.datePickerService.updateTimeframeAndFormat(changes.format.currentValue);\n        }\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        if (this.isOpen) {\n            this.datePicker.open();\n        }\n    }\n\n    pagingClicked(forward: boolean): void {\n        if (this.pagingSetup[this.datePickerService.timeframe]) {\n            const nextValue = this.pagingSetup[this.datePickerService.timeframe](forward);\n            this.pagingDateChange(nextValue);\n        }\n        this.datePicker.close();\n    }\n\n    pagingDateChange(newValue: Moment): void {\n        if (this.paginationDebounce) {\n            // this is required for not sending extra requests when user quickly clicking on pagination\n            // here we do the same as in setValueFromMoment(newValue) with difference\n            // that updating of ngModel/formControl is debounced\n            this.datePickerService.resetPresetTag();\n            this.writeValue(newValue.unix());\n            this.onChangeDebounced$.next(this.innerValue.unix());\n        } else {\n            this.setValueFromMoment(newValue);\n        }\n    }\n\n    /**\n     * Set inner value from timestamp and propagate\n     *\n     * @param timestamp\n     */\n    protected setValue(timestamp: number): void {\n        this.datePickerService.resetPresetTag();\n        super.setValue(timestamp);\n    }\n    public writeValue(value: number): void {\n        super.writeValue(value);\n        if (!value) return;\n        this.restrictPagination();\n    }\n\n    private getNextDate(actionCall: string, amount: number, forward: boolean): Moment {\n        return this.dateAdapter[actionCall]?.(this.innerValue, forward ? amount : -amount);\n    }\n\n    private restrictPagination(): void {\n        if (!this._min && !this._max) return;\n        const nextValue = this.pagingSetup[this.datePickerService.timeframe](true);\n        const prevValue = this.pagingSetup[this.datePickerService.timeframe](false);\n        this.isNextDateDisabled = this._max && nextValue && nextValue.unix() > this._max.unix();\n        this.isPrevDateDisabled = this._min && prevValue && prevValue.unix() < this._min.unix();\n    }\n}\n","<dr-button\n    [disabled]=\"isPrevDateDisabled\"\n    *ngIf=\"!disabled\"\n    theme=\"icon\"\n    icon=\"dr-icon-arrow-left\"\n    (click)=\"pagingClicked(false)\"></dr-button>\n<div\n    [drTooltip]=\"datepickerTooltip\"\n    [drTooltipPosition]=\"datepickerTooltipPosition\"\n    [drTooltipMousleaveTimeout]=\"datepickerTooltipTimeout\"\n    class=\"dr-datepicker-input-container\">\n    <i *ngIf=\"isDashboardDatepicker\" class=\"dr-icon-date\"></i>\n\n    <div class=\"dr-datepicker-input-container__formatted-value-display\" (click)=\"datepickerInput.click()\">\n        <ng-container\n            [ngTemplateOutlet]=\"formattedValueTmpl\"\n            [ngTemplateOutletContext]=\"{\n                formattedValue: displayedFormattedValue$ | async,\n            }\">\n        </ng-container>\n        <ng-template #formattedValueTmpl let-value=\"formattedValue\">\n            <span>\n                {{\n                    datePickerService.isUsingDateTagPresets && !!presetTagSelected\n                        ? presetTagSelected + ' (' + value + ')'\n                        : value\n                }}\n            </span>\n        </ng-template>\n    </div>\n    <input\n        #datepickerInput\n        [ngModel]=\"displayValue$ | async\"\n        (ngModelChange)=\"valueChangedInCalendar($event)\"\n        (click)=\"datePicker.open()\"\n        [matDatepicker]=\"datePicker\"\n        [readonly]=\"readonly\"\n        [min]=\"_min\"\n        [max]=\"_max\" />\n</div>\n<dr-button\n    [disabled]=\"isNextDateDisabled\"\n    *ngIf=\"!disabled\"\n    theme=\"icon\"\n    icon=\"dr-icon-arrow-right\"\n    (click)=\"pagingClicked(true)\"></dr-button>\n\n<mat-datepicker\n    #datePicker\n    class=\"dr-timeframe-datepicker\"\n    [calendarHeaderComponent]=\"customHeader\"\n    (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n    (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n    (opened)=\"onOpen()\"\n    (closed)=\"onCLose()\"\n    [panelClass]=\"datePickerService.isUsingDateTagPresets ? 'date-picker-preset-tag' : 'dr-timeframe-datepicker'\">\n</mat-datepicker>\n"]}
|
|
280
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker-with-timeframe.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    TemplateRef,\n} from '@angular/core';\nimport { CustomDateAdapter, DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateTags, IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { debounceTime, map, takeUntil } from 'rxjs/operators';\nimport * as _ from 'lodash';\nimport { Subject } from 'rxjs';\nimport { Moment } from 'moment';\nimport { PRESET_TAGS_LIST } from '../../../models/constants';\nimport { TooltipPosition } from '../../../dr-tooltip/enums/tooltip-position.enum';\n\n@Component({\n    selector: 'dr-date-picker-with-timeframe',\n    templateUrl: './dr-date-picker-with-timeframe.component.html',\n    styleUrls: ['./dr-date-picker-with-timeframe.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },\n        { provide: DateAdapter, useClass: CustomDateAdapter },\n        { provide: DrDatePickerService },\n    ],\n})\nexport class DrDatePickerWithTimeframeComponent\n    extends DrDatePickerComponent\n    implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit, OnChanges\n{\n    presetTagSelected: string;\n\n    @HostBinding('class.dr-date-picker-on-dashboard') get isDashboardClassDisplayed(): boolean {\n        return this.isDashboardDatepicker;\n    }\n\n    @Input() isDashboardDatepicker = false;\n\n    @Input() set dateFormatConfig(value: IDatePickerFormatConfig) {\n        if (value) {\n            this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...value };\n            this.cdr.markForCheck();\n        }\n    }\n\n    @Input() canSelectTimeframe = true;\n\n    @Input() set availableTimeframes(value: TimeframeOption[]) {\n        if (value && value.length) {\n            this.datePickerService.availableTimeframes = value;\n        }\n    }\n    @Input() paginationDebounce;\n\n    @Input() set isUsingDateTagPresets(flag: boolean) {\n        this.datePickerService.isUsingDateTagPresets = flag;\n    }\n\n    @Input() set presetTag(tag: string) {\n        this.datePickerService.presetTag$.next(tag as DateTags);\n    }\n\n    @Input() datepickerTooltip: TemplateRef<any> | null;\n    @Input() datepickerTooltipPosition: string = TooltipPosition.TOP;\n    @Input() datepickerTooltipTimeout: number = 0;\n\n    @Input() isOpen: boolean = false;\n\n    @Output() onChangeFormat = new EventEmitter<string>();\n    @Output() onChangePresetTag = new EventEmitter<DateTags>();\n\n    private readonly pagingSetup = {\n        [TimeframeOption.YEAR]: (forward) => this.getNextDate('addCalendarYears', 1, forward),\n        [TimeframeOption.QUARTER]: (forward) => this.getNextDate('addCalendarMonths', 3, forward),\n        [TimeframeOption.MONTH]: (forward) => this.getNextDate('addCalendarMonths', 1, forward),\n        [TimeframeOption.DAY]: (forward) => this.getNextDate('addCalendarDays', 1, forward),\n        [TimeframeOption.WEEK]: (forward) => this.getNextDate('addCalendarDays', 7, forward),\n    };\n\n    public isNextDateDisabled = false;\n    public isPrevDateDisabled = false;\n\n    private onChangeDebounced$: Subject<number> = new Subject<number>();\n\n    public displayedFormattedValue$ = this.displayValue$.pipe(\n        takeUntil(this.destroyed$),\n        map((value: Moment) => {\n            if (!value) return this.placeholder;\n            return (\n                this.datePickerService.getDisplayPrefix() +\n                this.dateAdapter.format(value, this.datePickerService.getConfiguredFormat(this.datePickerService.timeframe))\n            );\n        }),\n    );\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected dateAdapter: DateAdapter<any>,\n        public datePickerService: DrDatePickerService,\n    ) {\n        super(cdr, dateAdapter, datePickerService);\n        datePickerService.isTimeframeSelectionEnabled = true;\n\n        datePickerService.format$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.onChangeFormat.emit(datePickerService.normalizeValue(value));\n        });\n\n        datePickerService.presetTag$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            let tagObj = PRESET_TAGS_LIST.find((val) => val?.key === value);\n            this.presetTagSelected = tagObj?.label;\n            this.onChangePresetTag.emit(value);\n        });\n\n        this.datePickerService.onSameDaySelectedInCalendar$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            this.setValueFromMoment(value);\n        });\n\n        datePickerService.updatedDateAndClose$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {\n            if (value) {\n                this.setValueFromMoment(value);\n            } else {\n                this.onChangeCallback(this.innerValue.unix());\n            }\n            this.datePicker.close();\n        });\n    }\n\n    ngOnInit() {\n        this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;\n        this.cdr.markForCheck();\n\n        if (this.paginationDebounce) {\n            this.onChangeDebounced$.pipe(takeUntil(this.destroyed$), debounceTime(this.paginationDebounce)).subscribe((value) => {\n                this.onChangeCallback(value);\n            });\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.format?.currentValue && changes.format.currentValue !== changes.format.previousValue) {\n            this.datePickerService.updateTimeframeAndFormat(changes.format.currentValue);\n        }\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        if (this.isOpen) {\n            this.datePicker.open();\n        }\n    }\n\n    pagingClicked(forward: boolean): void {\n        if (this.pagingSetup[this.datePickerService.timeframe]) {\n            const nextValue = this.pagingSetup[this.datePickerService.timeframe](forward);\n            this.pagingDateChange(nextValue);\n        }\n        this.datePicker.close();\n    }\n\n    pagingDateChange(newValue: Moment): void {\n        if (this.paginationDebounce) {\n            // this is required for not sending extra requests when user quickly clicking on pagination\n            // here we do the same as in setValueFromMoment(newValue) with difference\n            // that updating of ngModel/formControl is debounced\n            this.datePickerService.resetPresetTag();\n            this.writeValue(newValue.unix());\n            this.onChangeDebounced$.next(this.innerValue.unix());\n        } else {\n            this.setValueFromMoment(newValue);\n        }\n    }\n\n    /**\n     * Set inner value from timestamp and propagate\n     *\n     * @param timestamp\n     */\n    protected setValue(timestamp: number): void {\n        this.datePickerService.resetPresetTag();\n        super.setValue(timestamp);\n    }\n    public writeValue(value: number): void {\n        super.writeValue(value);\n        if (!value) return;\n        this.restrictPagination();\n    }\n\n    private getNextDate(actionCall: string, amount: number, forward: boolean): Moment {\n        return this.dateAdapter[actionCall]?.(this.innerValue, forward ? amount : -amount);\n    }\n\n    private restrictPagination(): void {\n        if (!this._min && !this._max) return;\n        const timeFrame = this.datePickerService.timeframe;\n        const nextValue = this.pagingSetup[timeFrame](true);\n        const prevValue = this.pagingSetup[timeFrame](false);\n        const granularity = timeFrame;\n        /* TODO: Take into account fiscal year start and back for cases where fiscal year and quarter is true - https://datarailsteam.atlassian.net/browse/DR-35528 and\n          https://datarailsteam.atlassian.net/browse/DR-35568\n        */\n        if (this.fiscalYearBack || this.fiscalYearMonthsModifier !== 0) {\n            this.isNextDateDisabled = this._max && nextValue && nextValue.unix() > this._max.unix();\n            this.isPrevDateDisabled = this._min && prevValue && prevValue.unix() < this._min.unix();\n        } else {\n            this.isNextDateDisabled = !!(this._max && nextValue && !nextValue.isSameOrBefore(this._max, granularity));\n            this.isPrevDateDisabled = !!(this._min && prevValue && !prevValue.isSameOrAfter(this._min, granularity));\n        }\n    }\n}\n","<dr-button\n    [disabled]=\"isPrevDateDisabled\"\n    *ngIf=\"!disabled\"\n    theme=\"icon\"\n    icon=\"dr-icon-arrow-left\"\n    (click)=\"pagingClicked(false)\"></dr-button>\n<div\n    [drTooltip]=\"datepickerTooltip\"\n    [drTooltipPosition]=\"datepickerTooltipPosition\"\n    [drTooltipMousleaveTimeout]=\"datepickerTooltipTimeout\"\n    class=\"dr-datepicker-input-container\">\n    <i *ngIf=\"isDashboardDatepicker\" class=\"dr-icon-date\"></i>\n\n    <div class=\"dr-datepicker-input-container__formatted-value-display\" (click)=\"datepickerInput.click()\">\n        <ng-container\n            [ngTemplateOutlet]=\"formattedValueTmpl\"\n            [ngTemplateOutletContext]=\"{\n                formattedValue: displayedFormattedValue$ | async,\n            }\">\n        </ng-container>\n        <ng-template #formattedValueTmpl let-value=\"formattedValue\">\n            <span>\n                {{\n                    datePickerService.isUsingDateTagPresets && !!presetTagSelected\n                        ? presetTagSelected + ' (' + value + ')'\n                        : value\n                }}\n            </span>\n        </ng-template>\n    </div>\n    <input\n        #datepickerInput\n        [ngModel]=\"displayValue$ | async\"\n        (ngModelChange)=\"valueChangedInCalendar($event)\"\n        (click)=\"datePicker.open()\"\n        [matDatepicker]=\"datePicker\"\n        [readonly]=\"readonly\"\n        [min]=\"_min\"\n        [max]=\"_max\" />\n</div>\n<dr-button\n    [disabled]=\"isNextDateDisabled\"\n    *ngIf=\"!disabled\"\n    theme=\"icon\"\n    icon=\"dr-icon-arrow-right\"\n    (click)=\"pagingClicked(true)\"></dr-button>\n\n<mat-datepicker\n    #datePicker\n    class=\"dr-timeframe-datepicker\"\n    [calendarHeaderComponent]=\"customHeader\"\n    (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n    (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n    (opened)=\"onOpen()\"\n    (closed)=\"onCLose()\"\n    [panelClass]=\"datePickerService.isUsingDateTagPresets ? 'date-picker-preset-tag' : 'dr-timeframe-datepicker'\">\n</mat-datepicker>\n"]}
|