@datarailsshared/datarailsshared 1.4.108 → 1.4.109

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.
@@ -4,8 +4,9 @@ import { DateAdapter } from '@angular/material/core';
4
4
  import { DrDatePickerService } from '../services/dr-date-picker.service';
5
5
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
6
6
  import { TimeframeOption } from '../../../models/datePicker';
7
- import { takeUntil } from 'rxjs/operators';
7
+ import { debounceTime, takeUntil } from 'rxjs/operators';
8
8
  import * as _ from 'lodash';
9
+ import { Subject } from 'rxjs';
9
10
  export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
10
11
  constructor(cdr, dateAdapter, datePickerService) {
11
12
  super(cdr, dateAdapter, datePickerService);
@@ -23,6 +24,7 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
23
24
  [TimeframeOption.DAY]: (forward) => this.pagingDateChange('addCalendarDays', 1, forward),
24
25
  [TimeframeOption.WEEK]: (forward) => this.pagingDateChange('addCalendarDays', 7, forward)
25
26
  };
27
+ this.onChangeDebounced$ = new Subject();
26
28
  datePickerService.isTimeframeSelectionEnabled = true;
27
29
  datePickerService.format$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {
28
30
  this.onChangeFormat.emit(datePickerService.normalizeValue(value));
@@ -57,6 +59,11 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
57
59
  ngOnInit() {
58
60
  this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;
59
61
  this.cdr.markForCheck();
62
+ if (this.paginationDebounce) {
63
+ this.onChangeDebounced$.pipe(takeUntil(this.destroyed$), debounceTime(this.paginationDebounce)).subscribe((value) => {
64
+ this.onChangeCallback(value);
65
+ });
66
+ }
60
67
  }
61
68
  pagingClicked(forward) {
62
69
  if (this.pagingSetup[this.datePickerService.timeframe]) {
@@ -66,7 +73,17 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
66
73
  }
67
74
  pagingDateChange(actionCall, amount, forward) {
68
75
  const newValue = this.dateAdapter[actionCall](this.innerValue, forward ? amount : -amount);
69
- this.setValueFromMoment(newValue);
76
+ if (this.paginationDebounce) {
77
+ // this is required for not sending extra requests when user quickly clicking on pagination
78
+ // here we do the same as in setValueFromMoment(newValue) with difference
79
+ // that updating of ngModel/formControl is debounced
80
+ const timestamp = newValue.unix();
81
+ this.writeValue(timestamp);
82
+ this.onChangeDebounced$.next(this.innerValue.unix());
83
+ }
84
+ else {
85
+ this.setValueFromMoment(newValue);
86
+ }
70
87
  }
71
88
  }
72
89
  DrDatePickerWithTimeframeComponent.decorators = [
@@ -92,6 +109,7 @@ DrDatePickerWithTimeframeComponent.propDecorators = {
92
109
  dateFormatConfig: [{ type: Input }],
93
110
  canSelectTimeframe: [{ type: Input }],
94
111
  availableTimeframes: [{ type: Input }],
112
+ paginationDebounce: [{ type: Input }],
95
113
  onChangeFormat: [{ type: Output }]
96
114
  };
97
- //# 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"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output\n} from '@angular/core';\nimport { 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 { IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { takeUntil } from 'rxjs/operators';\nimport * as _ from 'lodash';\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: DrDatePickerService }\n    ],\n})\nexport class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit {\n\n    @HostBinding('class.dr-date-picker-on-dashboard') get isDashboardClassDisplayed(): boolean {\n        return this.isDashboardDatepicker;\n    };\n\n    @Input() isDashboardDatepicker = false;\n\n    @Input() set dateFormatConfig(value: IDatePickerFormatConfig) {\n        if (value) {\n            this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...value };\n            this.cdr.markForCheck();\n        }\n    }\n\n    @Input() canSelectTimeframe = true;\n\n    @Input() set availableTimeframes(value: TimeframeOption[]) {\n        if (value && value.length) {\n            this.datePickerService.availableTimeframes = value;\n        }\n    }\n\n    // eslint-disable-next-line\n    @Output() onChangeFormat = new EventEmitter<string>();\n\n    public readonly pagingSetup = {\n        [TimeframeOption.YEAR]: (forward) => this.pagingDateChange('addCalendarYears', 1, forward),\n        [TimeframeOption.QUARTER]: (forward) => this.pagingDateChange('addCalendarMonths', 3, forward),\n        [TimeframeOption.MONTH]: (forward) => this.pagingDateChange('addCalendarMonths', 1, forward),\n        [TimeframeOption.DAY]: (forward) => this.pagingDateChange('addCalendarDays', 1, forward),\n        [TimeframeOption.WEEK]: (forward) => this.pagingDateChange('addCalendarDays', 7, forward)\n    };\n\n    public get displayedFormattedValue(): string {\n        if (!this.value) {\n            return this.placeholder;\n        }\n\n        let displayValue = _.cloneDeep(this.value);\n        if (this.datePickerService.isTimeframeDependingOnFY(this.datePickerService.timeframe)) {\n            displayValue = this.datePickerService.subtractFiscalYearMonthsFromDate(displayValue);\n        }\n\n        const formatCached = this.datePickerService.format$.getValue();\n        return this.datePickerService.getDisplayPrefix() + displayValue.format(formatCached);\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\n    ngOnInit() {\n        this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;\n        this.cdr.markForCheck();\n    }\n\n    pagingClicked(forward: boolean): void {\n        if (this.pagingSetup[this.datePickerService.timeframe]) {\n            this.pagingSetup[this.datePickerService.timeframe](forward);\n        }\n        this.datePicker.close();\n    }\n\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n        const newValue = this.dateAdapter[actionCall](this.innerValue, forward ? amount : -amount);\n        this.setValueFromMoment(newValue);\n    }\n}\n"]}
115
+ //# 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"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output\n} from '@angular/core';\nimport { 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 { IDatePickerFormatConfig, TimeframeOption } from '../../../models/datePicker';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\nimport * as _ from 'lodash';\nimport { Subject } from 'rxjs';\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: DrDatePickerService }\n    ],\n})\nexport class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit {\n\n    @HostBinding('class.dr-date-picker-on-dashboard') get isDashboardClassDisplayed(): boolean {\n        return this.isDashboardDatepicker;\n    };\n\n    @Input() isDashboardDatepicker = false;\n\n    @Input() set dateFormatConfig(value: IDatePickerFormatConfig) {\n        if (value) {\n            this.datePickerService.formatConfig = { ...this.datePickerService.formatConfig, ...value };\n            this.cdr.markForCheck();\n        }\n    }\n\n    @Input() canSelectTimeframe = true;\n\n    @Input() set availableTimeframes(value: TimeframeOption[]) {\n        if (value && value.length) {\n            this.datePickerService.availableTimeframes = value;\n        }\n    }\n    @Input() paginationDebounce;\n\n    // eslint-disable-next-line\n    @Output() onChangeFormat = new EventEmitter<string>();\n\n    public readonly pagingSetup = {\n        [TimeframeOption.YEAR]: (forward) => this.pagingDateChange('addCalendarYears', 1, forward),\n        [TimeframeOption.QUARTER]: (forward) => this.pagingDateChange('addCalendarMonths', 3, forward),\n        [TimeframeOption.MONTH]: (forward) => this.pagingDateChange('addCalendarMonths', 1, forward),\n        [TimeframeOption.DAY]: (forward) => this.pagingDateChange('addCalendarDays', 1, forward),\n        [TimeframeOption.WEEK]: (forward) => this.pagingDateChange('addCalendarDays', 7, forward)\n    };\n\n    public get displayedFormattedValue(): string {\n        if (!this.value) {\n            return this.placeholder;\n        }\n\n        let displayValue = _.cloneDeep(this.value);\n        if (this.datePickerService.isTimeframeDependingOnFY(this.datePickerService.timeframe)) {\n            displayValue = this.datePickerService.subtractFiscalYearMonthsFromDate(displayValue);\n        }\n\n        const formatCached = this.datePickerService.format$.getValue();\n        return this.datePickerService.getDisplayPrefix() + displayValue.format(formatCached);\n    }\n\n    private onChangeDebounced$: Subject<number> = new Subject<number>();\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\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    pagingClicked(forward: boolean): void {\n        if (this.pagingSetup[this.datePickerService.timeframe]) {\n            this.pagingSetup[this.datePickerService.timeframe](forward);\n        }\n        this.datePicker.close();\n    }\n\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\n        const newValue = this.dateAdapter[actionCall](this.innerValue, forward ? amount : -amount);\n        if (this.paginationDebounce) {\n\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            const timestamp = newValue.unix();\n            this.writeValue(timestamp);\n            this.onChangeDebounced$.next(this.innerValue.unix());\n        } else {\n            this.setValueFromMoment(newValue);\n        }\n    }\n}\n"]}
@@ -3987,6 +3987,7 @@ class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
3987
3987
  [TimeframeOption.DAY]: (forward) => this.pagingDateChange('addCalendarDays', 1, forward),
3988
3988
  [TimeframeOption.WEEK]: (forward) => this.pagingDateChange('addCalendarDays', 7, forward)
3989
3989
  };
3990
+ this.onChangeDebounced$ = new Subject();
3990
3991
  datePickerService.isTimeframeSelectionEnabled = true;
3991
3992
  datePickerService.format$.pipe(takeUntil(this.destroyed$)).subscribe((value) => {
3992
3993
  this.onChangeFormat.emit(datePickerService.normalizeValue(value));
@@ -4021,6 +4022,11 @@ class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
4021
4022
  ngOnInit() {
4022
4023
  this.datePickerService.isTimeframeSelectionEnabled = this.canSelectTimeframe;
4023
4024
  this.cdr.markForCheck();
4025
+ if (this.paginationDebounce) {
4026
+ this.onChangeDebounced$.pipe(takeUntil(this.destroyed$), debounceTime(this.paginationDebounce)).subscribe((value) => {
4027
+ this.onChangeCallback(value);
4028
+ });
4029
+ }
4024
4030
  }
4025
4031
  pagingClicked(forward) {
4026
4032
  if (this.pagingSetup[this.datePickerService.timeframe]) {
@@ -4030,7 +4036,17 @@ class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
4030
4036
  }
4031
4037
  pagingDateChange(actionCall, amount, forward) {
4032
4038
  const newValue = this.dateAdapter[actionCall](this.innerValue, forward ? amount : -amount);
4033
- this.setValueFromMoment(newValue);
4039
+ if (this.paginationDebounce) {
4040
+ // this is required for not sending extra requests when user quickly clicking on pagination
4041
+ // here we do the same as in setValueFromMoment(newValue) with difference
4042
+ // that updating of ngModel/formControl is debounced
4043
+ const timestamp = newValue.unix();
4044
+ this.writeValue(timestamp);
4045
+ this.onChangeDebounced$.next(this.innerValue.unix());
4046
+ }
4047
+ else {
4048
+ this.setValueFromMoment(newValue);
4049
+ }
4034
4050
  }
4035
4051
  }
4036
4052
  DrDatePickerWithTimeframeComponent.decorators = [
@@ -4056,6 +4072,7 @@ DrDatePickerWithTimeframeComponent.propDecorators = {
4056
4072
  dateFormatConfig: [{ type: Input }],
4057
4073
  canSelectTimeframe: [{ type: Input }],
4058
4074
  availableTimeframes: [{ type: Input }],
4075
+ paginationDebounce: [{ type: Input }],
4059
4076
  onChangeFormat: [{ type: Output }]
4060
4077
  };
4061
4078