@datarailsshared/datarailsshared 1.6.161 → 1.6.165
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.165.tgz +0 -0
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +14 -2
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.mjs +89 -69
- package/esm2022/lib/dr-inputs/date-pickers/dr-fiscal-month-calendar-picker/dr-fiscal-month-calendar-header.component.mjs +89 -67
- package/esm2022/lib/dr-inputs/date-pickers/services/dr-date-picker.service.mjs +4 -1
- package/fesm2022/datarailsshared-datarailsshared.mjs +293 -236
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.d.ts +6 -1
- package/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +0 -4
- package/lib/dr-inputs/date-pickers/services/dr-date-picker.service.d.ts +5 -0
- package/package.json +1 -1
- package/datarailsshared-datarailsshared-1.6.161.tgz +0 -0
|
Binary file
|
|
@@ -57,9 +57,17 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
57
57
|
this.datePickerService.availableTimeframes = value;
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
|
+
set availableDateTagPresets(value) {
|
|
61
|
+
if (value && value.length) {
|
|
62
|
+
this.datePickerService.availableDateTagPresets = value;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
60
65
|
set isUsingDateTagPresets(flag) {
|
|
61
66
|
this.datePickerService.isUsingDateTagPresets = flag;
|
|
62
67
|
}
|
|
68
|
+
set isUsingTimeFrameSelect(flag) {
|
|
69
|
+
this.datePickerService.isUsingTimeFrameSelect = flag;
|
|
70
|
+
}
|
|
63
71
|
set presetTag(tag) {
|
|
64
72
|
this.datePickerService.presetTag$.next(tag);
|
|
65
73
|
}
|
|
@@ -190,7 +198,7 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
190
198
|
}
|
|
191
199
|
}
|
|
192
200
|
/** @nocollapse */ static { this.ɵfac = function DrDatePickerWithTimeframeComponent_Factory(t) { return new (t || DrDatePickerWithTimeframeComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.DateAdapter), i0.ɵɵdirectiveInject(i2.DrDatePickerService)); }; }
|
|
193
|
-
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrDatePickerWithTimeframeComponent, selectors: [["dr-date-picker-with-timeframe"]], inputs: { dateFormatConfig: "dateFormatConfig", canSelectTimeframe: "canSelectTimeframe", availableTimeframes: "availableTimeframes", paginationDebounce: "paginationDebounce", isUsingDateTagPresets: "isUsingDateTagPresets", presetTag: "presetTag", datepickerTooltip: "datepickerTooltip", datepickerTooltipPosition: "datepickerTooltipPosition", datepickerTooltipTimeout: "datepickerTooltipTimeout", isOpen: "isOpen" }, outputs: { onChangeFormat: "onChangeFormat", onChangePresetTag: "onChangePresetTag" }, features: [i0.ɵɵProvidersFeature([
|
|
201
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrDatePickerWithTimeframeComponent, selectors: [["dr-date-picker-with-timeframe"]], inputs: { dateFormatConfig: "dateFormatConfig", canSelectTimeframe: "canSelectTimeframe", availableTimeframes: "availableTimeframes", availableDateTagPresets: "availableDateTagPresets", paginationDebounce: "paginationDebounce", isUsingDateTagPresets: "isUsingDateTagPresets", isUsingTimeFrameSelect: "isUsingTimeFrameSelect", presetTag: "presetTag", datepickerTooltip: "datepickerTooltip", datepickerTooltipPosition: "datepickerTooltipPosition", datepickerTooltipTimeout: "datepickerTooltipTimeout", isOpen: "isOpen" }, outputs: { onChangeFormat: "onChangeFormat", onChangePresetTag: "onChangePresetTag" }, features: [i0.ɵɵProvidersFeature([
|
|
194
202
|
{ provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },
|
|
195
203
|
{ provide: DateAdapter, useClass: CustomDateAdapter },
|
|
196
204
|
{ provide: DrDatePickerService },
|
|
@@ -243,10 +251,14 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
243
251
|
type: Input
|
|
244
252
|
}], availableTimeframes: [{
|
|
245
253
|
type: Input
|
|
254
|
+
}], availableDateTagPresets: [{
|
|
255
|
+
type: Input
|
|
246
256
|
}], paginationDebounce: [{
|
|
247
257
|
type: Input
|
|
248
258
|
}], isUsingDateTagPresets: [{
|
|
249
259
|
type: Input
|
|
260
|
+
}], isUsingTimeFrameSelect: [{
|
|
261
|
+
type: Input
|
|
250
262
|
}], presetTag: [{
|
|
251
263
|
type: Input
|
|
252
264
|
}], datepickerTooltip: [{
|
|
@@ -262,4 +274,4 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
262
274
|
}], onChangePresetTag: [{
|
|
263
275
|
type: Output
|
|
264
276
|
}] }); })();
|
|
265
|
-
//# 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    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 { 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    @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 class=\"dr-icon-date\" (click)=\"datepickerInput.click()\"></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"]}
|
|
277
|
+
//# 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    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 { 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    @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() set availableDateTagPresets(value: Array<{ key: string; label: string }>) {\n        if (value && value.length) {\n            this.datePickerService.availableDateTagPresets = value;\n        }\n    }\n    @Input() paginationDebounce;\n\n    @Input() set isUsingDateTagPresets(flag: boolean) {\n        this.datePickerService.isUsingDateTagPresets = flag;\n    }\n\n    @Input() set isUsingTimeFrameSelect(flag: boolean) {\n        this.datePickerService.isUsingTimeFrameSelect = 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 class=\"dr-icon-date\" (click)=\"datepickerInput.click()\"></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"]}
|
|
@@ -5,7 +5,6 @@ import { MatCalendar } from '@angular/material/datepicker';
|
|
|
5
5
|
import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
|
|
6
6
|
import { CalendarView, CustomDateFormat, TimeframeOption } from '../../../models/datePicker';
|
|
7
7
|
import { DrDatePickerService } from '../services/dr-date-picker.service';
|
|
8
|
-
import { PRESET_TAGS_LIST } from '../../../models/constants';
|
|
9
8
|
import moment from 'moment';
|
|
10
9
|
import { WeekSelectorComponent } from '../week-selector/week-selector.component';
|
|
11
10
|
import * as i0 from "@angular/core";
|
|
@@ -20,65 +19,110 @@ import * as i8 from "../dr-show-timeframe.pipe";
|
|
|
20
19
|
import * as i9 from "../../../models/datePicker";
|
|
21
20
|
const _c0 = ["class", "component"];
|
|
22
21
|
const _c1 = function (a0) { return { "dr-datepicker-preset-date__tags__tag--selected": a0 }; };
|
|
23
|
-
function
|
|
24
|
-
const
|
|
25
|
-
i0.ɵɵelementStart(0, "div",
|
|
26
|
-
i0.ɵɵlistener("click", function
|
|
22
|
+
function DrDatePickerCustomHeaderComponent_div_0_div_1_div_2_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
23
|
+
const _r8 = i0.ɵɵgetCurrentView();
|
|
24
|
+
i0.ɵɵelementStart(0, "div", 16);
|
|
25
|
+
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_div_0_div_1_div_2_div_2_Template_div_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r8); const tag_r6 = restoredCtx.$implicit; const ctx_r7 = i0.ɵɵnextContext(4); return i0.ɵɵresetView(ctx_r7.onSelectPresetTag(tag_r6)); });
|
|
27
26
|
i0.ɵɵtext(1);
|
|
28
27
|
i0.ɵɵelementEnd();
|
|
29
28
|
} if (rf & 2) {
|
|
30
|
-
const
|
|
31
|
-
const
|
|
32
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(4, _c1,
|
|
29
|
+
const tag_r6 = ctx.$implicit;
|
|
30
|
+
const ctx_r5 = i0.ɵɵnextContext(4);
|
|
31
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(4, _c1, tag_r6.key === ctx_r5.selectedPresetTag))("drTooltip", ctx_r5.selectedPresetTag === tag_r6.key ? "Unselect preset" : "")("drTooltipPosition", "top");
|
|
33
32
|
i0.ɵɵadvance(1);
|
|
34
|
-
i0.ɵɵtextInterpolate1(" ",
|
|
33
|
+
i0.ɵɵtextInterpolate1(" ", tag_r6.label, " ");
|
|
35
34
|
} }
|
|
36
|
-
function
|
|
37
|
-
i0.ɵɵelementStart(0, "div",
|
|
38
|
-
i0.ɵɵ
|
|
39
|
-
i0.ɵɵ
|
|
35
|
+
function DrDatePickerCustomHeaderComponent_div_0_div_1_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
36
|
+
i0.ɵɵelementStart(0, "div", 14);
|
|
37
|
+
i0.ɵɵtext(1, " Preset dates ");
|
|
38
|
+
i0.ɵɵtemplate(2, DrDatePickerCustomHeaderComponent_div_0_div_1_div_2_div_2_Template, 2, 6, "div", 15);
|
|
39
|
+
i0.ɵɵelementEnd();
|
|
40
40
|
} if (rf & 2) {
|
|
41
|
-
const
|
|
41
|
+
const ctx_r3 = i0.ɵɵnextContext(3);
|
|
42
42
|
i0.ɵɵadvance(2);
|
|
43
|
-
i0.ɵɵproperty("ngForOf",
|
|
43
|
+
i0.ɵɵproperty("ngForOf", ctx_r3.datePickerService.availableDateTagPresets);
|
|
44
44
|
} }
|
|
45
|
-
function
|
|
46
|
-
const
|
|
47
|
-
i0.ɵɵelementStart(0, "
|
|
48
|
-
i0.ɵɵ
|
|
49
|
-
i0.ɵɵ
|
|
50
|
-
i0.ɵɵ
|
|
51
|
-
i0.ɵɵpipe(3, "drShowTimeframePipe");
|
|
52
|
-
i0.ɵɵelementEnd()();
|
|
45
|
+
function DrDatePickerCustomHeaderComponent_div_0_div_1_dr_select_3_Template(rf, ctx) { if (rf & 1) {
|
|
46
|
+
const _r10 = i0.ɵɵgetCurrentView();
|
|
47
|
+
i0.ɵɵelementStart(0, "dr-select", 17);
|
|
48
|
+
i0.ɵɵlistener("ngModelChange", function DrDatePickerCustomHeaderComponent_div_0_div_1_dr_select_3_Template_dr_select_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r10); const ctx_r9 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r9.setTimeframe($event)); });
|
|
49
|
+
i0.ɵɵpipe(1, "drShowTimeframePipe");
|
|
50
|
+
i0.ɵɵelementEnd();
|
|
53
51
|
} if (rf & 2) {
|
|
54
|
-
const
|
|
52
|
+
const ctx_r4 = i0.ɵɵnextContext(3);
|
|
53
|
+
i0.ɵɵproperty("ngModel", ctx_r4.selectedTimeframe)("items", i0.ɵɵpipeBind2(1, 2, ctx_r4.timeframeOptions, ctx_r4.datePickerService.availableTimeframes));
|
|
54
|
+
} }
|
|
55
|
+
const _c2 = function (a0) { return { "dr-datepicker-preset-date__tags--solo": a0 }; };
|
|
56
|
+
function DrDatePickerCustomHeaderComponent_div_0_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
57
|
+
i0.ɵɵelementStart(0, "div", 10)(1, "div", 11);
|
|
58
|
+
i0.ɵɵtemplate(2, DrDatePickerCustomHeaderComponent_div_0_div_1_div_2_Template, 3, 1, "div", 12);
|
|
59
|
+
i0.ɵɵelementEnd();
|
|
60
|
+
i0.ɵɵtemplate(3, DrDatePickerCustomHeaderComponent_div_0_div_1_dr_select_3_Template, 2, 5, "dr-select", 13);
|
|
61
|
+
i0.ɵɵelementEnd();
|
|
62
|
+
} if (rf & 2) {
|
|
63
|
+
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
55
64
|
i0.ɵɵadvance(1);
|
|
56
|
-
i0.ɵɵproperty("
|
|
65
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c2, ctx_r1.datePickerService.isUsingTimeFrameSelect));
|
|
66
|
+
i0.ɵɵadvance(1);
|
|
67
|
+
i0.ɵɵproperty("ngIf", ctx_r1.datePickerService.availableDateTagPresets.length > 0);
|
|
57
68
|
i0.ɵɵadvance(1);
|
|
58
|
-
i0.ɵɵproperty("
|
|
69
|
+
i0.ɵɵproperty("ngIf", ctx_r1.datePickerService.isUsingTimeFrameSelect);
|
|
59
70
|
} }
|
|
60
|
-
function
|
|
61
|
-
const
|
|
62
|
-
i0.ɵɵelementStart(0, "div",
|
|
63
|
-
i0.ɵɵlistener("click", function
|
|
71
|
+
function DrDatePickerCustomHeaderComponent_div_0_div_12_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
72
|
+
const _r15 = i0.ɵɵgetCurrentView();
|
|
73
|
+
i0.ɵɵelementStart(0, "div", 21);
|
|
74
|
+
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_div_0_div_12_div_2_Template_div_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r15); const quarter_r13 = restoredCtx.$implicit; const ctx_r14 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r14.onSelectQuarter(quarter_r13)); });
|
|
64
75
|
i0.ɵɵtext(1);
|
|
65
76
|
i0.ɵɵelementEnd();
|
|
66
77
|
} if (rf & 2) {
|
|
67
|
-
const
|
|
68
|
-
const
|
|
69
|
-
i0.ɵɵclassMap(
|
|
70
|
-
i0.ɵɵclassProp("quarter-selector--disabled",
|
|
78
|
+
const quarter_r13 = ctx.$implicit;
|
|
79
|
+
const ctx_r12 = i0.ɵɵnextContext(3);
|
|
80
|
+
i0.ɵɵclassMap(quarter_r13 === ctx_r12.selectedQuarter ? "selected" : "");
|
|
81
|
+
i0.ɵɵclassProp("quarter-selector--disabled", ctx_r12.isQuarterDisabled(quarter_r13));
|
|
71
82
|
i0.ɵɵadvance(1);
|
|
72
|
-
i0.ɵɵtextInterpolate1(" Q",
|
|
83
|
+
i0.ɵɵtextInterpolate1(" Q", quarter_r13, " ");
|
|
84
|
+
} }
|
|
85
|
+
function DrDatePickerCustomHeaderComponent_div_0_div_12_Template(rf, ctx) { if (rf & 1) {
|
|
86
|
+
i0.ɵɵelementStart(0, "div", 18, 19);
|
|
87
|
+
i0.ɵɵtemplate(2, DrDatePickerCustomHeaderComponent_div_0_div_12_div_2_Template, 2, 5, "div", 20);
|
|
88
|
+
i0.ɵɵelementEnd();
|
|
89
|
+
} if (rf & 2) {
|
|
90
|
+
const ctx_r2 = i0.ɵɵnextContext(2);
|
|
91
|
+
i0.ɵɵadvance(2);
|
|
92
|
+
i0.ɵɵproperty("ngForOf", ctx_r2.quarters);
|
|
73
93
|
} }
|
|
74
|
-
function
|
|
75
|
-
i0.ɵɵ
|
|
76
|
-
i0.ɵɵ
|
|
94
|
+
function DrDatePickerCustomHeaderComponent_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
95
|
+
const _r17 = i0.ɵɵgetCurrentView();
|
|
96
|
+
i0.ɵɵelementStart(0, "div", 1);
|
|
97
|
+
i0.ɵɵtemplate(1, DrDatePickerCustomHeaderComponent_div_0_div_1_Template, 4, 5, "div", 2);
|
|
98
|
+
i0.ɵɵelementStart(2, "div", 3)(3, "div", 4);
|
|
99
|
+
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_div_0_Template_div_click_3_listener() { i0.ɵɵrestoreView(_r17); const ctx_r16 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r16.pagingClicked(false)); });
|
|
100
|
+
i0.ɵɵelement(4, "i", 5);
|
|
101
|
+
i0.ɵɵelementEnd();
|
|
102
|
+
i0.ɵɵelementStart(5, "span", 6)(6, "span", 7);
|
|
103
|
+
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_div_0_Template_span_click_6_listener() { i0.ɵɵrestoreView(_r17); const ctx_r18 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r18.switchViewOnClickOnPeriodLabel(ctx_r18.calendarView.FOR_MONTHS)); });
|
|
104
|
+
i0.ɵɵtext(7);
|
|
105
|
+
i0.ɵɵelementEnd();
|
|
106
|
+
i0.ɵɵelementStart(8, "span", 7);
|
|
107
|
+
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_div_0_Template_span_click_8_listener() { i0.ɵɵrestoreView(_r17); const ctx_r19 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r19.switchViewOnClickOnPeriodLabel(ctx_r19.calendarView.FOR_YEARS)); });
|
|
108
|
+
i0.ɵɵtext(9);
|
|
109
|
+
i0.ɵɵelementEnd()();
|
|
110
|
+
i0.ɵɵelementStart(10, "div", 4);
|
|
111
|
+
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_div_0_Template_div_click_10_listener() { i0.ɵɵrestoreView(_r17); const ctx_r20 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r20.pagingClicked(true)); });
|
|
112
|
+
i0.ɵɵelement(11, "i", 8);
|
|
113
|
+
i0.ɵɵelementEnd()();
|
|
114
|
+
i0.ɵɵtemplate(12, DrDatePickerCustomHeaderComponent_div_0_div_12_Template, 3, 1, "div", 9);
|
|
77
115
|
i0.ɵɵelementEnd();
|
|
78
116
|
} if (rf & 2) {
|
|
79
|
-
const
|
|
117
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
118
|
+
i0.ɵɵadvance(1);
|
|
119
|
+
i0.ɵɵproperty("ngIf", ctx_r0.datePickerService.isUsingDateTagPresets);
|
|
120
|
+
i0.ɵɵadvance(6);
|
|
121
|
+
i0.ɵɵtextInterpolate(ctx_r0.periodMonthLabel + " ");
|
|
80
122
|
i0.ɵɵadvance(2);
|
|
81
|
-
i0.ɵɵ
|
|
123
|
+
i0.ɵɵtextInterpolate(ctx_r0.periodYearLabel);
|
|
124
|
+
i0.ɵɵadvance(3);
|
|
125
|
+
i0.ɵɵproperty("ngIf", ctx_r0.currentViewIsQuarter);
|
|
82
126
|
} }
|
|
83
127
|
export class DrDatePickerCustomHeaderComponent {
|
|
84
128
|
get selectedPresetTag() {
|
|
@@ -146,7 +190,6 @@ export class DrDatePickerCustomHeaderComponent {
|
|
|
146
190
|
this.timeframeSelection = false;
|
|
147
191
|
this.periodMonthLabel = '';
|
|
148
192
|
this.periodYearLabel = '';
|
|
149
|
-
this.presetTagList = PRESET_TAGS_LIST;
|
|
150
193
|
this.calendarView = CalendarView;
|
|
151
194
|
this.cfr = inject(ComponentFactoryResolver);
|
|
152
195
|
this.injector = inject(Injector);
|
|
@@ -294,40 +337,17 @@ export class DrDatePickerCustomHeaderComponent {
|
|
|
294
337
|
calendar.insertBefore(selector.location.nativeElement, calendar.firstChild);
|
|
295
338
|
}
|
|
296
339
|
/** @nocollapse */ static { this.ɵfac = function DrDatePickerCustomHeaderComponent_Factory(t) { return new (t || DrDatePickerCustomHeaderComponent)(i0.ɵɵdirectiveInject(i1.MatCalendar), i0.ɵɵdirectiveInject(i2.DateAdapter), i0.ɵɵdirectiveInject(MAT_DATE_FORMATS), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i3.DrDatePickerService)); }; }
|
|
297
|
-
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrDatePickerCustomHeaderComponent, selectors: [["dr-date-picker_custom-header", 8, "component"]], attrs: _c0, decls:
|
|
298
|
-
i0.ɵɵtemplate(0, DrDatePickerCustomHeaderComponent_div_0_Template,
|
|
299
|
-
i0.ɵɵelementStart(1, "div", 1)(2, "div", 2);
|
|
300
|
-
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_Template_div_click_2_listener() { return ctx.pagingClicked(false); });
|
|
301
|
-
i0.ɵɵelement(3, "i", 3);
|
|
302
|
-
i0.ɵɵelementEnd();
|
|
303
|
-
i0.ɵɵelementStart(4, "span", 4)(5, "span", 5);
|
|
304
|
-
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_Template_span_click_5_listener() { return ctx.switchViewOnClickOnPeriodLabel(ctx.calendarView.FOR_MONTHS); });
|
|
305
|
-
i0.ɵɵtext(6);
|
|
306
|
-
i0.ɵɵelementEnd();
|
|
307
|
-
i0.ɵɵelementStart(7, "span", 5);
|
|
308
|
-
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_Template_span_click_7_listener() { return ctx.switchViewOnClickOnPeriodLabel(ctx.calendarView.FOR_YEARS); });
|
|
309
|
-
i0.ɵɵtext(8);
|
|
310
|
-
i0.ɵɵelementEnd()();
|
|
311
|
-
i0.ɵɵelementStart(9, "div", 2);
|
|
312
|
-
i0.ɵɵlistener("click", function DrDatePickerCustomHeaderComponent_Template_div_click_9_listener() { return ctx.pagingClicked(true); });
|
|
313
|
-
i0.ɵɵelement(10, "i", 6);
|
|
314
|
-
i0.ɵɵelementEnd()();
|
|
315
|
-
i0.ɵɵtemplate(11, DrDatePickerCustomHeaderComponent_div_11_Template, 3, 1, "div", 7);
|
|
340
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrDatePickerCustomHeaderComponent, selectors: [["dr-date-picker_custom-header", 8, "component"]], attrs: _c0, decls: 1, vars: 1, consts: [["class", "dr-datepicker__timeframe-select__wrapper", 4, "ngIf"], [1, "dr-datepicker__timeframe-select__wrapper"], ["class", "dr-datepicker-preset-date", 4, "ngIf"], [1, "dr-date-paging"], [1, "dr-date-paging", "flip-page-button", 3, "click"], [1, "dr-icon-arrow-left", "presentation_buttons-navigate_input"], [1, "example-header-label"], [3, "click"], [1, "dr-icon-arrow-right", "presentation_buttons-navigate_input"], ["class", "dr-quarterly-datepicker", 4, "ngIf"], [1, "dr-datepicker-preset-date"], [1, "dr-datepicker-preset-date__tags", 3, "ngClass"], ["class", "dr-datepicker-preset-date__tags__title", 4, "ngIf"], ["class", "dr-datepicker__timeframe-select", "bindLabel", "title", "bindValue", "value", 3, "ngModel", "items", "ngModelChange", 4, "ngIf"], [1, "dr-datepicker-preset-date__tags__title"], ["id", "preset_tag", "class", "dr-datepicker-preset-date__tags__tag", 3, "ngClass", "drTooltip", "drTooltipPosition", "click", 4, "ngFor", "ngForOf"], ["id", "preset_tag", 1, "dr-datepicker-preset-date__tags__tag", 3, "ngClass", "drTooltip", "drTooltipPosition", "click"], ["bindLabel", "title", "bindValue", "value", 1, "dr-datepicker__timeframe-select", 3, "ngModel", "items", "ngModelChange"], [1, "dr-quarterly-datepicker"], ["quarterlyDatePicker", ""], ["class", "quarter-selector", 3, "class", "quarter-selector--disabled", "click", 4, "ngFor", "ngForOf"], [1, "quarter-selector", 3, "click"]], template: function DrDatePickerCustomHeaderComponent_Template(rf, ctx) { if (rf & 1) {
|
|
341
|
+
i0.ɵɵtemplate(0, DrDatePickerCustomHeaderComponent_div_0_Template, 13, 4, "div", 0);
|
|
316
342
|
} if (rf & 2) {
|
|
317
343
|
i0.ɵɵproperty("ngIf", ctx.datePickerService.isTimeframeSelectionEnabled);
|
|
318
|
-
|
|
319
|
-
i0.ɵɵtextInterpolate(ctx.periodMonthLabel + " ");
|
|
320
|
-
i0.ɵɵadvance(2);
|
|
321
|
-
i0.ɵɵtextInterpolate(ctx.periodYearLabel);
|
|
322
|
-
i0.ɵɵadvance(3);
|
|
323
|
-
i0.ɵɵproperty("ngIf", ctx.currentViewIsQuarter);
|
|
324
|
-
} }, dependencies: [i4.NgControlStatus, i4.NgModel, i5.NgClass, i5.NgForOf, i5.NgIf, i6.DrTooltipDirective, i7.DrSelectComponent, i8.DrShowTimeframePipe], styles: ["[_nghost-%COMP%]{height:54px;align-items:center;font-family:Poppins;font-style:normal;font-weight:600;font-size:14px;line-height:22px}.dr-datepicker__timeframe-select__wrapper[_ngcontent-%COMP%]{background-color:#f9faff;padding:16px 32px;border-radius:18px 18px 0 0}.dr-datepicker-preset-date[_ngcontent-%COMP%]{display:flex;flex-direction:column}.dr-datepicker-preset-date__tags[_ngcontent-%COMP%]{display:flex;padding-bottom:21px;padding-top:10px;font-size:12px}.dr-datepicker-preset-date__tags__tag[_ngcontent-%COMP%]{cursor:pointer;font-weight:400;line-height:20px!important;padding:2px 8px;border:1px solid #9ea1aa;border-radius:18px;background:#fff;margin-right:4px}.dr-datepicker-preset-date__tags__tag--selected[_ngcontent-%COMP%]{color:#4646ce;background:#f2f2fb;border:1px solid #4646ce}.dr-date-paging[_ngcontent-%COMP%]{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 32px 32px;gap:4px}.dr-date-paging.flip-page-button[_ngcontent-%COMP%]{width:20px;height:20px;padding:0;color:#4e566c}.dr-date-paging.flip-page-button[_ngcontent-%COMP%]:hover{border-radius:50%;background:#f2f2fb;color:#4646ce}.example-header-label[_ngcontent-%COMP%]{cursor:pointer}.dr-quarterly-datepicker[_ngcontent-%COMP%]{display:flex;justify-content:space-between;padding:10px}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector[_ngcontent-%COMP%]{display:block;width:74px;height:40px;text-align:center;border-radius:40px;font-weight:400;padding-top:9px}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector[_ngcontent-%COMP%]:hover{background:#f2f2fb;color:#4646ce;font-weight:600;cursor:pointer}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector.selected[_ngcontent-%COMP%]{background-color:#4646ce;color:#f3f7ff;font-weight:600}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--disabled[_ngcontent-%COMP%], .dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--disabled.selected[_ngcontent-%COMP%]{pointer-events:none;background-color:transparent;color:#aeabac;font-weight:400}"], changeDetection: 0 }); }
|
|
344
|
+
} }, dependencies: [i4.NgControlStatus, i4.NgModel, i5.NgClass, i5.NgForOf, i5.NgIf, i6.DrTooltipDirective, i7.DrSelectComponent, i8.DrShowTimeframePipe], styles: ["[_nghost-%COMP%]{height:54px;align-items:center;font-family:Poppins;font-style:normal;font-weight:600;font-size:14px;line-height:22px}.dr-datepicker__timeframe-select__wrapper[_ngcontent-%COMP%]{background-color:#f9faff;padding:16px 32px;border-radius:18px 18px 0 0}.dr-datepicker-preset-date[_ngcontent-%COMP%]{display:flex;flex-direction:column}.dr-datepicker-preset-date__tags[_ngcontent-%COMP%]{display:flex;padding-bottom:21px;padding-top:10px;font-size:12px}.dr-datepicker-preset-date__tags--solo[_ngcontent-%COMP%]{padding:16px 32px;gap:16px;justify-content:center}.dr-datepicker-preset-date__tags--solo[_ngcontent-%COMP%] .dr-datepicker-preset-date__tags__tag[_ngcontent-%COMP%]{padding:4px 8px;justify-content:center;display:flex;flex:1 0 0}.dr-datepicker-preset-date__tags__tag[_ngcontent-%COMP%]{cursor:pointer;font-weight:400;line-height:20px!important;padding:2px 8px;border:1px solid #9ea1aa;border-radius:18px;background:#fff;margin-right:4px}.dr-datepicker-preset-date__tags__tag--selected[_ngcontent-%COMP%]{color:#4646ce;background:#f2f2fb;border:1px solid #4646ce}.dr-date-paging[_ngcontent-%COMP%]{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 32px 32px;gap:4px}.dr-date-paging.flip-page-button[_ngcontent-%COMP%]{width:20px;height:20px;padding:0;color:#4e566c}.dr-date-paging.flip-page-button[_ngcontent-%COMP%]:hover{border-radius:50%;background:#f2f2fb;color:#4646ce}.example-header-label[_ngcontent-%COMP%]{cursor:pointer}.dr-quarterly-datepicker[_ngcontent-%COMP%]{display:flex;justify-content:space-between;padding:10px}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector[_ngcontent-%COMP%]{display:block;width:74px;height:40px;text-align:center;border-radius:40px;font-weight:400;padding-top:9px}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector[_ngcontent-%COMP%]:hover{background:#f2f2fb;color:#4646ce;font-weight:600;cursor:pointer}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector.selected[_ngcontent-%COMP%]{background-color:#4646ce;color:#f3f7ff;font-weight:600}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--disabled[_ngcontent-%COMP%], .dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--disabled.selected[_ngcontent-%COMP%]{pointer-events:none;background-color:transparent;color:#aeabac;font-weight:400}"], changeDetection: 0 }); }
|
|
325
345
|
}
|
|
326
346
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrDatePickerCustomHeaderComponent, [{
|
|
327
347
|
type: Component,
|
|
328
|
-
args: [{ selector: 'dr-date-picker_custom-header.component', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n <div *ngIf=\"datePickerService.isUsingDateTagPresets\" class=\"dr-datepicker-preset-date\">\n <div class=\"dr-datepicker-preset-date__tags\">\n <div\n *ngFor=\"let tag of
|
|
348
|
+
args: [{ selector: 'dr-date-picker_custom-header.component', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n <div *ngIf=\"datePickerService.isUsingDateTagPresets\" class=\"dr-datepicker-preset-date\">\n <div class=\"dr-datepicker-preset-date__tags\"\n [ngClass]=\"{ 'dr-datepicker-preset-date__tags--solo': datePickerService.isUsingTimeFrameSelect }\">\n <div\n *ngIf=\"datePickerService.availableDateTagPresets.length > 0\"\n class=\"dr-datepicker-preset-date__tags__title\">\n Preset dates\n <div\n *ngFor=\"let tag of datePickerService.availableDateTagPresets\"\n id=\"preset_tag\"\n class=\"dr-datepicker-preset-date__tags__tag\"\n (click)=\"onSelectPresetTag(tag)\"\n [ngClass]=\"{ 'dr-datepicker-preset-date__tags__tag--selected': tag.key === selectedPresetTag }\"\n [drTooltip]=\"selectedPresetTag === tag.key ? 'Unselect preset' : ''\"\n [drTooltipPosition]=\"'top'\">\n {{ tag.label }}\n </div>\n </div>\n </div>\n <dr-select\n *ngIf=\"datePickerService.isUsingTimeFrameSelect\"\n class=\"dr-datepicker__timeframe-select\"\n [ngModel]=\"selectedTimeframe\"\n [items]=\"timeframeOptions | drShowTimeframePipe: datePickerService.availableTimeframes\"\n bindLabel=\"title\"\n bindValue=\"value\"\n (ngModelChange)=\"setTimeframe($event)\">\n </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(false)\">\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n </div>\n <span class=\"example-header-label\">\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{ periodMonthLabel + ' ' }}</span>\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{ periodYearLabel }}</span>\n </span>\n <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(true)\">\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n <div\n *ngFor=\"let quarter of quarters\"\n class=\"quarter-selector\"\n (click)=\"onSelectQuarter(quarter)\"\n [class]=\"quarter === selectedQuarter ? 'selected' : ''\"\n [class.quarter-selector--disabled]=\"isQuarterDisabled(quarter)\">\n Q{{ quarter }}\n </div>\n</div>\n", styles: [":host{height:54px;align-items:center;font-family:Poppins;font-style:normal;font-weight:600;font-size:14px;line-height:22px}.dr-datepicker__timeframe-select__wrapper{background-color:#f9faff;padding:16px 32px;border-radius:18px 18px 0 0}.dr-datepicker-preset-date{display:flex;flex-direction:column}.dr-datepicker-preset-date__tags{display:flex;padding-bottom:21px;padding-top:10px;font-size:12px}.dr-datepicker-preset-date__tags--solo{padding:16px 32px;gap:16px;justify-content:center}.dr-datepicker-preset-date__tags--solo .dr-datepicker-preset-date__tags__tag{padding:4px 8px;justify-content:center;display:flex;flex:1 0 0}.dr-datepicker-preset-date__tags__tag{cursor:pointer;font-weight:400;line-height:20px!important;padding:2px 8px;border:1px solid #9ea1aa;border-radius:18px;background:#fff;margin-right:4px}.dr-datepicker-preset-date__tags__tag--selected{color:#4646ce;background:#f2f2fb;border:1px solid #4646ce}.dr-date-paging{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 32px 32px;gap:4px}.dr-date-paging.flip-page-button{width:20px;height:20px;padding:0;color:#4e566c}.dr-date-paging.flip-page-button:hover{border-radius:50%;background:#f2f2fb;color:#4646ce}.example-header-label{cursor:pointer}.dr-quarterly-datepicker{display:flex;justify-content:space-between;padding:10px}.dr-quarterly-datepicker .quarter-selector{display:block;width:74px;height:40px;text-align:center;border-radius:40px;font-weight:400;padding-top:9px}.dr-quarterly-datepicker .quarter-selector:hover{background:#f2f2fb;color:#4646ce;font-weight:600;cursor:pointer}.dr-quarterly-datepicker .quarter-selector.selected{background-color:#4646ce;color:#f3f7ff;font-weight:600}.dr-quarterly-datepicker .quarter-selector--disabled,.dr-quarterly-datepicker .quarter-selector--disabled.selected{pointer-events:none;background-color:transparent;color:#aeabac;font-weight:400}\n"] }]
|
|
329
349
|
}], function () { return [{ type: i1.MatCalendar }, { type: i2.DateAdapter }, { type: i9.CustomDateFormat, decorators: [{
|
|
330
350
|
type: Inject,
|
|
331
351
|
args: [MAT_DATE_FORMATS]
|
|
332
352
|
}] }, { type: i0.ChangeDetectorRef }, { type: i3.DrDatePickerService }]; }, null); })();
|
|
333
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,uBAAuB,EAEvB,iBAAiB,EACjB,SAAS,EACT,MAAM,EAEN,MAAM,EACN,wBAAwB,EACxB,QAAQ,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,WAAW,EAAmB,MAAM,8BAA8B,CAAC;AAC5E,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAmC,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC9H,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;;;;;;;;;;;;;;;IChBrE,+BAOgC;IAH5B,kPAAS,eAAA,gCAAsB,CAAA,IAAC;IAIhC,YACJ;IAAA,iBAAM;;;;IAJF,6FAA+F,+EAAA,4BAAA;IAG/F,eACJ;IADI,6CACJ;;;IAXR,+BAAuF,cAAA;IAE/E,+FASM;IACV,iBAAM,EAAA;;;IATkB,eAAgB;IAAhB,8CAAgB;;;;IAJhD,8BAA4G;IACxG,wFAaM;IACN,qCAM2C;IAAvC,uMAAiB,eAAA,2BAAoB,CAAA,IAAC;;IAC1C,iBAAY,EAAA;;;IArBN,eAA6C;IAA7C,qEAA6C;IAgB/C,eAA6B;IAA7B,kDAA6B,sGAAA;;;;IAqBjC,+BAKoE;IAFhE,oPAAS,eAAA,oCAAwB,CAAA,IAAC;IAGlC,YACJ;IAAA,iBAAM;;;;IAHF,wEAAuD;IACvD,oFAA+D;IAC/D,eACJ;IADI,6CACJ;;;IARJ,mCAAuF;IACnF,0FAOM;IACV,iBAAM;;;IAPsB,eAAW;IAAX,yCAAW;;ADZvC,MAAM,OAAO,iCAAiC;IA+D1C,IAAI,iBAAiB;QACjB,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IACxD,CAAC;IAOD,YACc,SAA2B,EAC3B,YAAiC,EACP,YAA8B,EACxD,GAAsB,EACzB,iBAAsC;QAJnC,cAAS,GAAT,SAAS,CAAkB;QAC3B,iBAAY,GAAZ,YAAY,CAAqB;QACP,iBAAY,GAAZ,YAAY,CAAkB;QACxD,QAAG,GAAH,GAAG,CAAmB;QACzB,sBAAiB,GAAjB,iBAAiB,CAAqB;QA5EvC,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC3C,aAAQ,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACxB,oBAAe,GAAG,CAAC,CAAC;QACpB,qBAAgB,GAAuB;YACnC;gBACI,SAAS,EAAE,eAAe,CAAC,GAAG;gBAC9B,KAAK,EAAE,KAAK;gBACZ,KAAK,EAAE,YAAY,CAAC,QAAQ;gBAC5B,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,GAAG;gBAC/C,WAAW,EAAE,GAAG,EAAE,CACd,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,iBAAiB,EAAE;aACxH;YACD;gBACI,SAAS,EAAE,eAAe,CAAC,IAAI;gBAC/B,KAAK,EAAE,MAAM;gBACb,KAAK,EAAE,YAAY,CAAC,QAAQ;gBAC5B,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI;gBAChD,WAAW,EAAE,GAAG,EAAE,CACd,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,iBAAiB,EAAE;aACxH;YACD;gBACI,SAAS,EAAE,eAAe,CAAC,KAAK;gBAChC,KAAK,EAAE,OAAO;gBACd,KAAK,EAAE,YAAY,CAAC,UAAU;gBAC9B,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,KAAK;gBACjD,WAAW,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC;aAC5E;YACD;gBACI,SAAS,EAAE,eAAe,CAAC,OAAO;gBAClC,KAAK,EAAE,SAAS;gBAChB,KAAK,EAAE,YAAY,CAAC,YAAY;gBAChC,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,OAAO;gBACnD,WAAW,EAAE,GAAG,EAAE,CACd,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,gCAAgC,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC;aACtH;YACD;gBACI,SAAS,EAAE,eAAe,CAAC,IAAI;gBAC/B,KAAK,EAAE,MAAM;gBACb,KAAK,EAAE,YAAY,CAAC,SAAS;gBAC7B,MAAM,EAAE,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI;gBAChD,WAAW,EAAE,GAAG,EAAE;oBACd,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,gCAAgC,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;yBACzG,GAAG,EAAE;yBACL,IAAI,EAAE,CAAC;oBACZ,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;oBACtD,OAAO,WAAW,GAAG,GAAG,GAAG,CAAC,WAAW,GAAG,EAAE,CAAC,CAAC;gBAClD,CAAC;aACJ;SACJ,CAAC;QAEF,gBAAW,GAAG;YACV,CAAC,YAAY,CAAC,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,CAAC,EAAE,OAAO,CAAC;YAC7F,CAAC,YAAY,CAAC,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,CAAC,EAAE,OAAO,CAAC;YAC/F,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,EAAE,CAAC,EAAE,OAAO,CAAC;YAC5F,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,EAAE,EAAE,OAAO,CAAC;SAChG,CAAC;QAEF,sBAAiB,GAAkB,YAAY,CAAC,QAAQ,CAAC;QACzD,uBAAkB,GAAG,KAAK,CAAC;QAC3B,qBAAgB,GAAG,EAAE,CAAC;QACtB,oBAAe,GAAG,EAAE,CAAC;QACrB,kBAAa,GAAG,gBAAgB,CAAC;QAKjB,iBAAY,GAAG,YAAY,CAAC;QAE3B,QAAG,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QACvC,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QASzC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QAChG,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAChF,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YAC7D,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YAC3G,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAoC,CAAC;YAClE,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,IAAI,CAAC,iBAAiB,KAAK,YAAY,CAAC,YAAY,EAAE;gBACtD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,+BAA+B,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;aAC5G;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,2BAA2B,EAAE,CAAC;QAEnC,SAAS,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACxC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,eAAe,EAAE;gBACzC,IAAI,CAAC,iBAAiB,CAAC,4BAA4B,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACxE;QACL,CAAC,CAAC,CAAC;QAEH,aAAa,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;aACnH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aAChC,SAAS,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,EAAE,EAAE;YAC7B,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;YAC5D,QAAQ,EAAE,MAAM,EAAE,EAAE,CAAC;YAErB,IAAI,SAAS,KAAK,eAAe,CAAC,IAAI,IAAI,IAAI,KAAK,OAAO,EAAE;gBACxD,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC7B;QACL,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,GAAG,SAAS,CAAC;IACxD,CAAC;IAED,QAAQ;QACJ,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE;gBAC9B,IAAI,CAAC,yCAAyC,EAAE,CAAC;aACpD;YACD,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACrC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED,eAAe;QACX,MAAM,sBAAsB,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QACxH,MAAM,eAAe,GAAG,sBAAsB,CAAC,WAAW,EAAE,CAAC;QAC7D,IAAI,IAAI,CAAC,SAAS,CAAC,WAAW,KAAK,YAAY,CAAC,QAAQ,EAAE;YACtD,IAAI,CAAC,gBAAgB,GAAG,eAAe,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,CAAC;YACxE,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,IAAI,eAAe,CAAC;SAC1F;aAAM;YACH,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;YAC3B,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;SAC1C;QACD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAED,YAAY,CAAC,KAAK;QACd,IAAI,KAAK,KAAK,IAAI,CAAC,iBAAiB,EAAE;YAClC,IAAI,CAAC,iBAAiB,CAAC,cAAc,EAAE,CAAC;SAC3C;QACD,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAoC,CAAC;QACvE,MAAM,qBAAqB,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC;QACnH,IAAI,CAAC,iBAAiB,CAAC,wBAAwB,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;QAE9E,IAAI,IAAI,CAAC,iBAAiB,KAAK,YAAY,CAAC,YAAY,EAAE;YACtD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,+BAA+B,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;SAC5G;IACL,CAAC;IAED,IAAI,oBAAoB;QACpB,OAAO,CAAC,CAAC,YAAY,CAAC,QAAQ,EAAE,YAAY,CAAC,UAAU,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC,QAAQ,CACrF,IAAI,CAAC,SAAS,CAAC,WAA2B,CAC7C,CAAC;IACN,CAAC;IAED,8BAA8B,CAAC,IAAsD;QACjF,IAAI,CAAC,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC;IACtC,CAAC;IAED,eAAe,CAAC,aAAqB;QACjC,IAAI,CAAC,eAAe,GAAG,aAAa,CAAC;QACrC,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC;QACjF,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACvE,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;IACtD,CAAC;IAED,aAAa,CAAC,OAAO;QACjB,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE;YAC9C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC;SACzD;IACL,CAAC;IAED,gBAAgB,CAAC,UAAkB,EAAE,MAAc,EAAE,OAAgB;QACjE,IAAI,CAAC,SAAS,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QACjH,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,yCAAyC;QACrC,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,aAAoB,CAAC;QAC1D,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,gCAAgC,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;QAC/G,aAAa,CAAC,aAAa,GAAG,aAAa,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;QAC/D,aAAa,CAAC,KAAK,EAAE,CAAC;QAEtB,IACI,IAAI,CAAC,iBAAiB,CAAC,wBAAwB,CAAC,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC;YACjF,CAAC,IAAI,CAAC,iBAAiB,CAAC,cAAc;YACtC,IAAI,CAAC,iBAAiB,CAAC,wBAAwB,EACjD;YACE,aAAa,CAAC,UAAU,GAAG,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YAClD,aAAqB,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;SAC5D;IACL,CAAC;IAED,iBAAiB,CAAC,GAAQ;QACtB,IAAI,GAAG,CAAC,GAAG,KAAK,IAAI,CAAC,iBAAiB,EAAE;YACpC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAChD;aAAM;YACH,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;SACnD;QACD,IAAI,CAAC,iBAAiB,CAAC,wBAAwB,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC5F,CAAC;IAED,yBAAyB;QACrB,MAAM,gBAAgB,GAClB,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU;YAClC,CAAC,eAAe,CAAC,OAAO,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;QAE/F,IAAI,gBAAgB,EAAE;YAClB,MAAM,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC;YACvF,IAAI,eAAe,EAAE;gBACjB,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,eAAe,CACnD,eAAe,EACf,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,WAAW,CACtD,CAAC;aACL;SACJ;IACL,CAAC;IAED,iBAAiB,CAAC,aAAqB;QACnC,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE;YAC3B,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;YACvD,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,YAAY,EAAE,aAAa,CAAC,CAAC;YACpE,IAAI,CAAC,iBAAiB,CAAC,8BAA8B,CAAC,YAAY,CAAC,CAAC;YAEpE,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC;YAC/C,IAAI,OAAO,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,GAAG,YAAY,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;gBAClF,OAAO,IAAI,CAAC;aACf;YACD,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;SACjE;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAES,2BAA2B;QACjC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACvE,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE;gBAC9B,IAAI,CAAC,yCAAyC,EAAE,CAAC;aACpD;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,kBAAkB;QACtB,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,qBAAqB,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE/F,MAAM,QAAQ,GAAmB,QAAQ,CAAC,aAAa,CAAC,uBAAuB,CAAC,CAAC;QACjF,QAAQ,CAAC,YAAY,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;IAChF,CAAC;qHA5PQ,iCAAiC,mGA2E9B,gBAAgB;mGA3EnB,iCAAiC;YC3B9C,kFAuBM;YAEN,8BAA4B,aAAA;YACqB,2GAAS,kBAAc,KAAK,CAAC,IAAC;YACvE,uBAAsE;YAC1E,iBAAM;YACN,+BAAmC,cAAA;YACzB,4GAAS,+DAAuD,IAAC;YAAC,YAA4B;YAAA,iBAAO;YAC3G,+BAAuE;YAAjE,4GAAS,8DAAsD,IAAC;YAAC,YAAqB;YAAA,iBAAO,EAAA;YAEvG,8BAA2E;YAA9B,2GAAS,kBAAc,IAAI,CAAC,IAAC;YACtE,wBAAuE;YAC3E,iBAAM,EAAA;YAEV,oFASM;;YA9CA,wEAAmD;YA8BuB,eAA4B;YAA5B,gDAA4B;YAC7B,eAAqB;YAArB,yCAAqB;YAMzC,eAA0B;YAA1B,+CAA0B;;;uFDVxE,iCAAiC;cAN7C,SAAS;2BACI,wCAAwC,mBAGjC,uBAAuB,CAAC,MAAM;;sBA6E1C,MAAM;uBAAC,gBAAgB","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    OnDestroy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    OnInit,\n    inject,\n    ComponentFactoryResolver,\n    Injector,\n} from '@angular/core';\nimport { combineLatest, Subject } from 'rxjs';\nimport { startWith, takeUntil } from 'rxjs/operators';\nimport { MatCalendar, MatCalendarView } from '@angular/material/datepicker';\nimport { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';\nimport { CalendarView, CustomDateFormat, ITimeframeOption, TCalendarView, TimeframeOption } from '../../../models/datePicker';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { PRESET_TAGS_LIST } from '../../../models/constants';\nimport moment from 'moment';\nimport { WeekSelectorComponent } from '../week-selector/week-selector.component';\n\n@Component({\n    selector: 'dr-date-picker_custom-header.component',\n    templateUrl: 'dr-date-picker_custom-header.component.html',\n    styleUrls: ['./dr-date-picker_custom-header.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrDatePickerCustomHeaderComponent<Moment> implements OnDestroy, OnInit {\n    protected _destroyed = new Subject<void>();\n    quarters = [1, 2, 3, 4];\n    selectedQuarter = 1;\n    timeframeOptions: ITimeframeOption[] = [\n        {\n            timeframe: TimeframeOption.DAY,\n            title: 'Day',\n            value: CalendarView.FOR_DAYS,\n            format: this.datePickerService.formatConfig.day,\n            periodLabel: () =>\n                this._dateAdapter.format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel).toLocaleUpperCase(),\n        },\n        {\n            timeframe: TimeframeOption.WEEK,\n            title: 'Week',\n            value: CalendarView.FOR_DAYS,\n            format: this.datePickerService.formatConfig.week,\n            periodLabel: () =>\n                this._dateAdapter.format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel).toLocaleUpperCase(),\n        },\n        {\n            timeframe: TimeframeOption.MONTH,\n            title: 'Month',\n            value: CalendarView.FOR_MONTHS,\n            format: this.datePickerService.formatConfig.month,\n            periodLabel: () => String(moment(this._calendar.activeDate).utc().year()),\n        },\n        {\n            timeframe: TimeframeOption.QUARTER,\n            title: 'Quarter',\n            value: CalendarView.FOR_QUARTERS,\n            format: this.datePickerService.formatConfig.quarter,\n            periodLabel: () =>\n                String(moment(this.datePickerService.subtractFiscalYearMonthsFromDate(this._calendar.activeDate)).utc().year()),\n        },\n        {\n            timeframe: TimeframeOption.YEAR,\n            title: 'Year',\n            value: CalendarView.FOR_YEARS,\n            format: this.datePickerService.formatConfig.year,\n            periodLabel: () => {\n                const currentYear = moment(this.datePickerService.subtractFiscalYearMonthsFromDate(this._calendar.activeDate))\n                    .utc()\n                    .year();\n                const startPeriod = Math.floor(currentYear / 24) * 24;\n                return startPeriod + '-' + (startPeriod + 23);\n            },\n        },\n    ];\n\n    pagingSetup = {\n        [CalendarView.FOR_MONTHS]: (forward) => this.pagingDateChange('addCalendarYears', 1, forward),\n        [CalendarView.FOR_QUARTERS]: (forward) => this.pagingDateChange('addCalendarYears', 1, forward),\n        [CalendarView.FOR_DAYS]: (forward) => this.pagingDateChange('addCalendarMonths', 1, forward),\n        [CalendarView.FOR_YEARS]: (forward) => this.pagingDateChange('addCalendarYears', 24, forward),\n    };\n\n    selectedTimeframe: TCalendarView = CalendarView.FOR_DAYS;\n    timeframeSelection = false;\n    periodMonthLabel = '';\n    periodYearLabel = '';\n    presetTagList = PRESET_TAGS_LIST;\n    get selectedPresetTag() {\n        return this.datePickerService.presetTag$.getValue();\n    }\n\n    public readonly calendarView = CalendarView;\n\n    private readonly cfr = inject(ComponentFactoryResolver);\n    private readonly injector = inject(Injector);\n\n    constructor(\n        protected _calendar: MatCalendar<any>,\n        protected _dateAdapter: DateAdapter<Moment>,\n        @Inject(MAT_DATE_FORMATS) protected _dateFormats: CustomDateFormat,\n        protected cdr: ChangeDetectorRef,\n        public datePickerService: DrDatePickerService,\n    ) {\n        _calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n        this.datePickerService.format$.pipe(takeUntil(this._destroyed)).subscribe((value) => {\n            const timeframe = this.datePickerService.getTimeframe(value);\n            this.selectedTimeframe = this.timeframeOptions.filter((option) => option.timeframe === timeframe)[0].value;\n            _calendar.currentView = this.selectedTimeframe as MatCalendarView;\n            this.setPeriodLabels();\n            if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n                this.selectedQuarter = this.datePickerService.getQuarterAccordingToFiscalYear(this._calendar.activeDate);\n            }\n        });\n\n        this.listenToCalendarViewChanges();\n\n        _calendar._userSelection.subscribe((date) => {\n            if (!this.datePickerService.isValueUpdating) {\n                this.datePickerService.onSameDaySelectedInCalendar$.next(date.value);\n            }\n        });\n\n        combineLatest([this.datePickerService.timeframe$, this._calendar.viewChanged.pipe(startWith(this._calendar.startView))])\n            .pipe(takeUntil(this._destroyed))\n            .subscribe(([timeframe, view]) => {\n                const selector = document.querySelector('dr-week-selector');\n                selector?.remove?.();\n\n                if (timeframe === TimeframeOption.WEEK && view === 'month') {\n                    this.insertWeekSelector();\n                }\n            });\n\n        this.datePickerService.calendarInstance = _calendar;\n    }\n\n    ngOnInit() {\n        setTimeout(() => {\n            if (this._calendar.multiYearView) {\n                this.transformDateInMultiyearViewAccordingToFY();\n            }\n            this.goToCurrentDateInViewByFY();\n        });\n    }\n\n    ngOnDestroy() {\n        this._destroyed.next();\n        this._destroyed.complete();\n    }\n\n    setPeriodLabels() {\n        const currentTimeframeOption = this.timeframeOptions.filter((option) => option.value === this._calendar.currentView)[0];\n        const fullPeriodLabel = currentTimeframeOption.periodLabel();\n        if (this._calendar.currentView === CalendarView.FOR_DAYS) {\n            this.periodMonthLabel = fullPeriodLabel.match(/[a-zA-Z]+/g)?.toString();\n            this.periodYearLabel = fullPeriodLabel.match(/[0-9]+/g)?.toString() ?? fullPeriodLabel;\n        } else {\n            this.periodMonthLabel = '';\n            this.periodYearLabel = fullPeriodLabel;\n        }\n        this.cdr.markForCheck();\n    }\n\n    setTimeframe(value) {\n        if (value !== this.selectedTimeframe) {\n            this.datePickerService.resetPresetTag();\n        }\n        this.selectedTimeframe = value;\n        this.timeframeSelection = false;\n        this._calendar.currentView = this.selectedTimeframe as MatCalendarView;\n        const chosenTimeframeOption = this.timeframeOptions.filter((option) => option.value === this.selectedTimeframe)[0];\n        this.datePickerService.updateTimeframeAndFormat(chosenTimeframeOption.format);\n\n        if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n            this.selectedQuarter = this.datePickerService.getQuarterAccordingToFiscalYear(this._calendar.activeDate);\n        }\n    }\n\n    get currentViewIsQuarter() {\n        return ![CalendarView.FOR_DAYS, CalendarView.FOR_MONTHS, CalendarView.FOR_YEARS].includes(\n            this._calendar.currentView as CalendarView,\n        );\n    }\n\n    switchViewOnClickOnPeriodLabel(view: CalendarView.FOR_MONTHS | CalendarView.FOR_YEARS) {\n        this._calendar.currentView = view;\n    }\n\n    onSelectQuarter(quarterNumber: number) {\n        this.selectedQuarter = quarterNumber;\n        this.datePickerService.setEndOfQuarter(this._calendar.activeDate, quarterNumber);\n        this.datePickerService.updatedQuarter$.next(this._calendar.activeDate);\n        this.datePickerService.datePickerInstance.close();\n    }\n\n    pagingClicked(forward) {\n        if (this.pagingSetup[this._calendar.currentView]) {\n            this.pagingSetup[this._calendar.currentView](forward);\n        }\n    }\n\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n        this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward ? amount : -amount);\n        this.setPeriodLabels();\n    }\n\n    transformDateInMultiyearViewAccordingToFY() {\n        const multuYearView = this._calendar.multiYearView as any;\n        multuYearView._activeDate = this.datePickerService.subtractFiscalYearMonthsFromDate(multuYearView._activeDate);\n        multuYearView._selectedYear = multuYearView._activeDate.year();\n        multuYearView._init();\n\n        if (\n            this.datePickerService.isTimeframeDependingOnFY(this.datePickerService.timeframe) &&\n            !this.datePickerService.fiscalYearBack &&\n            this.datePickerService.fiscalYearMonthsModifier\n        ) {\n            multuYearView._todayYear = moment.utc().year() + 1;\n            (multuYearView as any)._changeDetectorRef.markForCheck();\n        }\n    }\n\n    onSelectPresetTag(tag: any) {\n        if (tag.key === this.selectedPresetTag) {\n            this.datePickerService.presetTag$.next(null);\n        } else {\n            this.datePickerService.presetTag$.next(tag.key);\n        }\n        this.datePickerService.updateDatePickerByPreset(this.selectedPresetTag, this._calendar);\n    }\n\n    goToCurrentDateInViewByFY() {\n        const isNeedMoveToDate =\n            !this.datePickerService.innerValue &&\n            [TimeframeOption.QUARTER, TimeframeOption.YEAR].includes(this.datePickerService.timeframe);\n\n        if (isNeedMoveToDate) {\n            const momentWithShift = this.datePickerService.addFiscalYearShiftForYear(moment.utc());\n            if (momentWithShift) {\n                this.datePickerService.calendarInstance._goToDateInView(\n                    momentWithShift,\n                    this.datePickerService.calendarInstance.currentView,\n                );\n            }\n        }\n    }\n\n    isQuarterDisabled(quarterNumber: number): boolean {\n        if (this._calendar.activeDate) {\n            const endOfQuarter = this._calendar.activeDate.clone();\n            this.datePickerService.setEndOfQuarter(endOfQuarter, quarterNumber);\n            this.datePickerService.subtractFiscalYearShiftForYear(endOfQuarter);\n\n            const maxDate = this.datePickerService.maxDate;\n            if (maxDate && maxDate.utc().unix() < endOfQuarter.utc().subtract(3, 'month').unix()) {\n                return true;\n            }\n            return !this.datePickerService.datepickerFilter(endOfQuarter);\n        }\n        return false;\n    }\n\n    protected listenToCalendarViewChanges(): void {\n        this._calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => {\n            this.setPeriodLabels();\n            if (this._calendar.multiYearView) {\n                this.transformDateInMultiyearViewAccordingToFY();\n            }\n        });\n    }\n\n    private insertWeekSelector(): void {\n        const selector = this.cfr.resolveComponentFactory(WeekSelectorComponent).create(this.injector);\n\n        const calendar: HTMLDivElement = document.querySelector('.mat-calendar-content');\n        calendar.insertBefore(selector.location.nativeElement, calendar.firstChild);\n    }\n}\n","<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n    <div *ngIf=\"datePickerService.isUsingDateTagPresets\" class=\"dr-datepicker-preset-date\">\n        <div class=\"dr-datepicker-preset-date__tags\">\n            <div\n                *ngFor=\"let tag of presetTagList\"\n                id=\"preset_tag\"\n                class=\"dr-datepicker-preset-date__tags__tag\"\n                (click)=\"onSelectPresetTag(tag)\"\n                [ngClass]=\"{ 'dr-datepicker-preset-date__tags__tag--selected': tag.key === selectedPresetTag }\"\n                [drTooltip]=\"selectedPresetTag === tag.key ? 'Unselect preset' : ''\"\n                [drTooltipPosition]=\"'top'\">\n                {{ tag.label }}\n            </div>\n        </div>\n    </div>\n    <dr-select\n        class=\"dr-datepicker__timeframe-select\"\n        [ngModel]=\"selectedTimeframe\"\n        [items]=\"timeframeOptions | drShowTimeframePipe: datePickerService.availableTimeframes\"\n        bindLabel=\"title\"\n        bindValue=\"value\"\n        (ngModelChange)=\"setTimeframe($event)\">\n    </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n    <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(false)\">\n        <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n    </div>\n    <span class=\"example-header-label\">\n        <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{ periodMonthLabel + ' ' }}</span>\n        <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{ periodYearLabel }}</span>\n    </span>\n    <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(true)\">\n        <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n    </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n    <div\n        *ngFor=\"let quarter of quarters\"\n        class=\"quarter-selector\"\n        (click)=\"onSelectQuarter(quarter)\"\n        [class]=\"quarter === selectedQuarter ? 'selected' : ''\"\n        [class.quarter-selector--disabled]=\"isQuarterDisabled(quarter)\">\n        Q{{ quarter }}\n    </div>\n</div>\n"]}
|
|
353
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    OnDestroy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    OnInit,\n    inject,\n    ComponentFactoryResolver,\n    Injector,\n} from '@angular/core';\nimport { combineLatest, Subject } from 'rxjs';\nimport { startWith, takeUntil } from 'rxjs/operators';\nimport { MatCalendar, MatCalendarView } from '@angular/material/datepicker';\nimport { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';\nimport { CalendarView, CustomDateFormat, ITimeframeOption, TCalendarView, TimeframeOption } from '../../../models/datePicker';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport moment from 'moment';\nimport { WeekSelectorComponent } from '../week-selector/week-selector.component';\n\n@Component({\n    selector: 'dr-date-picker_custom-header.component',\n    templateUrl: 'dr-date-picker_custom-header.component.html',\n    styleUrls: ['./dr-date-picker_custom-header.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrDatePickerCustomHeaderComponent<Moment> implements OnDestroy, OnInit {\n    protected _destroyed = new Subject<void>();\n    quarters = [1, 2, 3, 4];\n    selectedQuarter = 1;\n    timeframeOptions: ITimeframeOption[] = [\n        {\n            timeframe: TimeframeOption.DAY,\n            title: 'Day',\n            value: CalendarView.FOR_DAYS,\n            format: this.datePickerService.formatConfig.day,\n            periodLabel: () =>\n                this._dateAdapter.format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel).toLocaleUpperCase(),\n        },\n        {\n            timeframe: TimeframeOption.WEEK,\n            title: 'Week',\n            value: CalendarView.FOR_DAYS,\n            format: this.datePickerService.formatConfig.week,\n            periodLabel: () =>\n                this._dateAdapter.format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel).toLocaleUpperCase(),\n        },\n        {\n            timeframe: TimeframeOption.MONTH,\n            title: 'Month',\n            value: CalendarView.FOR_MONTHS,\n            format: this.datePickerService.formatConfig.month,\n            periodLabel: () => String(moment(this._calendar.activeDate).utc().year()),\n        },\n        {\n            timeframe: TimeframeOption.QUARTER,\n            title: 'Quarter',\n            value: CalendarView.FOR_QUARTERS,\n            format: this.datePickerService.formatConfig.quarter,\n            periodLabel: () =>\n                String(moment(this.datePickerService.subtractFiscalYearMonthsFromDate(this._calendar.activeDate)).utc().year()),\n        },\n        {\n            timeframe: TimeframeOption.YEAR,\n            title: 'Year',\n            value: CalendarView.FOR_YEARS,\n            format: this.datePickerService.formatConfig.year,\n            periodLabel: () => {\n                const currentYear = moment(this.datePickerService.subtractFiscalYearMonthsFromDate(this._calendar.activeDate))\n                    .utc()\n                    .year();\n                const startPeriod = Math.floor(currentYear / 24) * 24;\n                return startPeriod + '-' + (startPeriod + 23);\n            },\n        },\n    ];\n\n    pagingSetup = {\n        [CalendarView.FOR_MONTHS]: (forward) => this.pagingDateChange('addCalendarYears', 1, forward),\n        [CalendarView.FOR_QUARTERS]: (forward) => this.pagingDateChange('addCalendarYears', 1, forward),\n        [CalendarView.FOR_DAYS]: (forward) => this.pagingDateChange('addCalendarMonths', 1, forward),\n        [CalendarView.FOR_YEARS]: (forward) => this.pagingDateChange('addCalendarYears', 24, forward),\n    };\n\n    selectedTimeframe: TCalendarView = CalendarView.FOR_DAYS;\n    timeframeSelection = false;\n    periodMonthLabel = '';\n    periodYearLabel = '';\n    get selectedPresetTag() {\n        return this.datePickerService.presetTag$.getValue();\n    }\n\n    public readonly calendarView = CalendarView;\n\n    private readonly cfr = inject(ComponentFactoryResolver);\n    private readonly injector = inject(Injector);\n\n    constructor(\n        protected _calendar: MatCalendar<any>,\n        protected _dateAdapter: DateAdapter<Moment>,\n        @Inject(MAT_DATE_FORMATS) protected _dateFormats: CustomDateFormat,\n        protected cdr: ChangeDetectorRef,\n        public datePickerService: DrDatePickerService,\n    ) {\n        _calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\n        this.datePickerService.format$.pipe(takeUntil(this._destroyed)).subscribe((value) => {\n            const timeframe = this.datePickerService.getTimeframe(value);\n            this.selectedTimeframe = this.timeframeOptions.filter((option) => option.timeframe === timeframe)[0].value;\n            _calendar.currentView = this.selectedTimeframe as MatCalendarView;\n            this.setPeriodLabels();\n            if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n                this.selectedQuarter = this.datePickerService.getQuarterAccordingToFiscalYear(this._calendar.activeDate);\n            }\n        });\n\n        this.listenToCalendarViewChanges();\n\n        _calendar._userSelection.subscribe((date) => {\n            if (!this.datePickerService.isValueUpdating) {\n                this.datePickerService.onSameDaySelectedInCalendar$.next(date.value);\n            }\n        });\n\n        combineLatest([this.datePickerService.timeframe$, this._calendar.viewChanged.pipe(startWith(this._calendar.startView))])\n            .pipe(takeUntil(this._destroyed))\n            .subscribe(([timeframe, view]) => {\n                const selector = document.querySelector('dr-week-selector');\n                selector?.remove?.();\n\n                if (timeframe === TimeframeOption.WEEK && view === 'month') {\n                    this.insertWeekSelector();\n                }\n            });\n\n        this.datePickerService.calendarInstance = _calendar;\n    }\n\n    ngOnInit() {\n        setTimeout(() => {\n            if (this._calendar.multiYearView) {\n                this.transformDateInMultiyearViewAccordingToFY();\n            }\n            this.goToCurrentDateInViewByFY();\n        });\n    }\n\n    ngOnDestroy() {\n        this._destroyed.next();\n        this._destroyed.complete();\n    }\n\n    setPeriodLabels() {\n        const currentTimeframeOption = this.timeframeOptions.filter((option) => option.value === this._calendar.currentView)[0];\n        const fullPeriodLabel = currentTimeframeOption.periodLabel();\n        if (this._calendar.currentView === CalendarView.FOR_DAYS) {\n            this.periodMonthLabel = fullPeriodLabel.match(/[a-zA-Z]+/g)?.toString();\n            this.periodYearLabel = fullPeriodLabel.match(/[0-9]+/g)?.toString() ?? fullPeriodLabel;\n        } else {\n            this.periodMonthLabel = '';\n            this.periodYearLabel = fullPeriodLabel;\n        }\n        this.cdr.markForCheck();\n    }\n\n    setTimeframe(value) {\n        if (value !== this.selectedTimeframe) {\n            this.datePickerService.resetPresetTag();\n        }\n        this.selectedTimeframe = value;\n        this.timeframeSelection = false;\n        this._calendar.currentView = this.selectedTimeframe as MatCalendarView;\n        const chosenTimeframeOption = this.timeframeOptions.filter((option) => option.value === this.selectedTimeframe)[0];\n        this.datePickerService.updateTimeframeAndFormat(chosenTimeframeOption.format);\n\n        if (this.selectedTimeframe === CalendarView.FOR_QUARTERS) {\n            this.selectedQuarter = this.datePickerService.getQuarterAccordingToFiscalYear(this._calendar.activeDate);\n        }\n    }\n\n    get currentViewIsQuarter() {\n        return ![CalendarView.FOR_DAYS, CalendarView.FOR_MONTHS, CalendarView.FOR_YEARS].includes(\n            this._calendar.currentView as CalendarView,\n        );\n    }\n\n    switchViewOnClickOnPeriodLabel(view: CalendarView.FOR_MONTHS | CalendarView.FOR_YEARS) {\n        this._calendar.currentView = view;\n    }\n\n    onSelectQuarter(quarterNumber: number) {\n        this.selectedQuarter = quarterNumber;\n        this.datePickerService.setEndOfQuarter(this._calendar.activeDate, quarterNumber);\n        this.datePickerService.updatedQuarter$.next(this._calendar.activeDate);\n        this.datePickerService.datePickerInstance.close();\n    }\n\n    pagingClicked(forward) {\n        if (this.pagingSetup[this._calendar.currentView]) {\n            this.pagingSetup[this._calendar.currentView](forward);\n        }\n    }\n\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n        this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward ? amount : -amount);\n        this.setPeriodLabels();\n    }\n\n    transformDateInMultiyearViewAccordingToFY() {\n        const multuYearView = this._calendar.multiYearView as any;\n        multuYearView._activeDate = this.datePickerService.subtractFiscalYearMonthsFromDate(multuYearView._activeDate);\n        multuYearView._selectedYear = multuYearView._activeDate.year();\n        multuYearView._init();\n\n        if (\n            this.datePickerService.isTimeframeDependingOnFY(this.datePickerService.timeframe) &&\n            !this.datePickerService.fiscalYearBack &&\n            this.datePickerService.fiscalYearMonthsModifier\n        ) {\n            multuYearView._todayYear = moment.utc().year() + 1;\n            (multuYearView as any)._changeDetectorRef.markForCheck();\n        }\n    }\n\n    onSelectPresetTag(tag: any) {\n        if (tag.key === this.selectedPresetTag) {\n            this.datePickerService.presetTag$.next(null);\n        } else {\n            this.datePickerService.presetTag$.next(tag.key);\n        }\n        this.datePickerService.updateDatePickerByPreset(this.selectedPresetTag, this._calendar);\n    }\n\n    goToCurrentDateInViewByFY() {\n        const isNeedMoveToDate =\n            !this.datePickerService.innerValue &&\n            [TimeframeOption.QUARTER, TimeframeOption.YEAR].includes(this.datePickerService.timeframe);\n\n        if (isNeedMoveToDate) {\n            const momentWithShift = this.datePickerService.addFiscalYearShiftForYear(moment.utc());\n            if (momentWithShift) {\n                this.datePickerService.calendarInstance._goToDateInView(\n                    momentWithShift,\n                    this.datePickerService.calendarInstance.currentView,\n                );\n            }\n        }\n    }\n\n    isQuarterDisabled(quarterNumber: number): boolean {\n        if (this._calendar.activeDate) {\n            const endOfQuarter = this._calendar.activeDate.clone();\n            this.datePickerService.setEndOfQuarter(endOfQuarter, quarterNumber);\n            this.datePickerService.subtractFiscalYearShiftForYear(endOfQuarter);\n\n            const maxDate = this.datePickerService.maxDate;\n            if (maxDate && maxDate.utc().unix() < endOfQuarter.utc().subtract(3, 'month').unix()) {\n                return true;\n            }\n            return !this.datePickerService.datepickerFilter(endOfQuarter);\n        }\n        return false;\n    }\n\n    protected listenToCalendarViewChanges(): void {\n        this._calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => {\n            this.setPeriodLabels();\n            if (this._calendar.multiYearView) {\n                this.transformDateInMultiyearViewAccordingToFY();\n            }\n        });\n    }\n\n    private insertWeekSelector(): void {\n        const selector = this.cfr.resolveComponentFactory(WeekSelectorComponent).create(this.injector);\n\n        const calendar: HTMLDivElement = document.querySelector('.mat-calendar-content');\n        calendar.insertBefore(selector.location.nativeElement, calendar.firstChild);\n    }\n}\n","<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n    <div *ngIf=\"datePickerService.isUsingDateTagPresets\" class=\"dr-datepicker-preset-date\">\n        <div class=\"dr-datepicker-preset-date__tags\"\n             [ngClass]=\"{ 'dr-datepicker-preset-date__tags--solo': datePickerService.isUsingTimeFrameSelect }\">\n            <div\n                *ngIf=\"datePickerService.availableDateTagPresets.length > 0\"\n                class=\"dr-datepicker-preset-date__tags__title\">\n                Preset dates\n            <div\n                *ngFor=\"let tag of datePickerService.availableDateTagPresets\"\n                id=\"preset_tag\"\n                class=\"dr-datepicker-preset-date__tags__tag\"\n                (click)=\"onSelectPresetTag(tag)\"\n                [ngClass]=\"{ 'dr-datepicker-preset-date__tags__tag--selected': tag.key === selectedPresetTag }\"\n                [drTooltip]=\"selectedPresetTag === tag.key ? 'Unselect preset' : ''\"\n                [drTooltipPosition]=\"'top'\">\n                {{ tag.label }}\n            </div>\n        </div>\n    </div>\n    <dr-select\n        *ngIf=\"datePickerService.isUsingTimeFrameSelect\"\n        class=\"dr-datepicker__timeframe-select\"\n        [ngModel]=\"selectedTimeframe\"\n        [items]=\"timeframeOptions | drShowTimeframePipe: datePickerService.availableTimeframes\"\n        bindLabel=\"title\"\n        bindValue=\"value\"\n        (ngModelChange)=\"setTimeframe($event)\">\n    </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n    <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(false)\">\n        <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n    </div>\n    <span class=\"example-header-label\">\n        <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{ periodMonthLabel + ' ' }}</span>\n        <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{ periodYearLabel }}</span>\n    </span>\n    <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(true)\">\n        <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n    </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n    <div\n        *ngFor=\"let quarter of quarters\"\n        class=\"quarter-selector\"\n        (click)=\"onSelectQuarter(quarter)\"\n        [class]=\"quarter === selectedQuarter ? 'selected' : ''\"\n        [class.quarter-selector--disabled]=\"isQuarterDisabled(quarter)\">\n        Q{{ quarter }}\n    </div>\n</div>\n"]}
|