@datarailsshared/datarailsshared 1.3.49 → 1.3.50
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/bundles/datarailsshared-datarailsshared.umd.js +13 -17
- package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
- package/datarailsshared-datarailsshared-1.3.50.tgz +0 -0
- package/datarailsshared-datarailsshared.metadata.json +1 -1
- package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker.component.js +4 -7
- package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.js +10 -11
- package/fesm2015/datarailsshared-datarailsshared.js +12 -16
- package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
- package/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +1 -1
- package/package.json +1 -1
- package/datarailsshared-datarailsshared-1.3.49.tgz +0 -0
|
@@ -80,6 +80,7 @@ export class DrDatePickerComponent {
|
|
|
80
80
|
if (this.takeEndOfPeriod) {
|
|
81
81
|
normalizedRef.endOf(timeframe);
|
|
82
82
|
}
|
|
83
|
+
normalizedRef.set('hour', 12);
|
|
83
84
|
}
|
|
84
85
|
get value() {
|
|
85
86
|
return this.innerValue;
|
|
@@ -122,7 +123,7 @@ export class DrDatePickerComponent {
|
|
|
122
123
|
return value;
|
|
123
124
|
}
|
|
124
125
|
chosenMonthHandler(normalizedMonth, datepicker) {
|
|
125
|
-
if (this.datePickerService.timeframe
|
|
126
|
+
if (this.datePickerService.timeframe === 'month') {
|
|
126
127
|
this.tryToNormalaizeTimeframe(normalizedMonth, 'month');
|
|
127
128
|
this.writeValue(normalizedMonth);
|
|
128
129
|
this.onChangeCallback(normalizedMonth);
|
|
@@ -130,16 +131,12 @@ export class DrDatePickerComponent {
|
|
|
130
131
|
}
|
|
131
132
|
}
|
|
132
133
|
chosenYearHandler(normalizedYear, datepicker) {
|
|
133
|
-
if (this.datePickerService.timeframe
|
|
134
|
+
if (this.datePickerService.timeframe === 'year') {
|
|
134
135
|
this.tryToNormalaizeTimeframe(normalizedYear, 'year');
|
|
135
136
|
this.writeValue(normalizedYear);
|
|
136
137
|
this.onChangeCallback(normalizedYear);
|
|
137
138
|
datepicker.close();
|
|
138
139
|
}
|
|
139
|
-
else if (['quarter', 'day'].includes(this.datePickerService.timeframe)) {
|
|
140
|
-
this.writeValue(normalizedYear);
|
|
141
|
-
datepicker.close();
|
|
142
|
-
}
|
|
143
140
|
}
|
|
144
141
|
pagingClicked(forward) {
|
|
145
142
|
this.pagingSetup[this.datePickerService.timeframe] && this.pagingSetup[this.datePickerService.timeframe](forward);
|
|
@@ -183,4 +180,4 @@ DrDatePickerComponent.propDecorators = {
|
|
|
183
180
|
dp: [{ type: ViewChild, args: ['datePicker',] }]
|
|
184
181
|
};
|
|
185
182
|
export { ɵ0 };
|
|
186
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-date-picker/dr-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  Input,\r\n  ChangeDetectorRef, ViewChild, AfterViewInit, OnDestroy, Output, EventEmitter\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { MatDatepicker } from '@angular/material/datepicker';\r\nimport { MAT_DEFAULT_DATE_FORMAT, MONTH_YEAR_FORMAT, QUARTER_FORMAT, YEAR_FORMAT } from '../../models/datePicker';\r\nimport { Moment } from 'moment';\r\nimport { DrDatePickerCustomHeaderComponent } from './dr-date-picker_custom-header/dr-date-picker_custom-header.component';\r\nimport { DateAdapter } from '@angular/material/core';\r\nimport { DrDatePickerService } from './dr-date-picker.service';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nconst moment = require('moment');\r\n\r\nconst noop = () => {};\r\n\r\n@Component({\r\n  selector: 'dr-date-picker',\r\n  templateUrl: './dr-date-picker.component.html',\r\n  styleUrls: ['./dr-date-picker.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerComponent, multi: true }\r\n  ],\r\n\r\n})\r\nexport class DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\r\n  private _destroyed = new Subject<void> ();\r\n  readonly = true;\r\n  @Input() _format = MAT_DEFAULT_DATE_FORMAT;\r\n  customHeader = DrDatePickerCustomHeaderComponent;\r\n  @Output() onChangeFormat = new EventEmitter<string> ();\r\n  @Input() set format(value) {\r\n    if (value) {\r\n      value = this.normalizeValue(value);\r\n      this._format = value;\r\n      this.datePickerService.format.next(value);\r\n      this.datePickerService.setTimeframe(value);\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n  @Input() timeframeSelection: boolean = false;\r\n  @Input() takeEndOfPeriod: boolean = false;\r\n  @Input() placeholder: string = 'Select';\r\n  @Input() min: Date = null;\r\n  @Input() max: Date = null;\r\n  @ViewChild('datePicker') public dp;\r\n\r\n  ngAfterViewInit(): void {\r\n    this.datePickerService.calendarInstance = this.dp;\r\n    if (this._format === MAT_DEFAULT_DATE_FORMAT) {\r\n      return;\r\n    }\r\n      setTimeout(() => {\r\n       const popupInstance = this.dp._popupComponentRef.instance;\r\n       const calenderInstance = popupInstance._calendar._calendarHeaderPortal._attachedHost._attachedRef.instance;\r\n       calenderInstance.currentPeriodClicked = function () {\r\n          this.calendarViewSetup[this.datePickerService.timeframe] && this.calendarViewSetup[this.datePickerService.timeframe](this.calendar);\r\n        };\r\n      }, 1000);\r\n  }\r\n\r\n  calendarViewSetup = {\r\n    'year': (calendar) => calendar.currentView = 'multi-year',\r\n    'month': (calendar) => calendar.currentView = 'year',\r\n    'quarter': (calendar) => calendar.currentView = 'none',\r\n    'day': (calendar) => calendar.currentView = 'month'\r\n  }\r\n\r\n  pagingSetup = {\r\n    'year': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\r\n    'quarter': (forward) =>  this.pagingDateChange('addCalendarMonths', 3, forward),\r\n    'month': (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\r\n    'day': (forward) =>  this.pagingDateChange('addCalendarDays', 1, forward)\r\n  }\r\n\r\n  private innerValue: any = null;\r\n  private onTouchedCallback: () => void = noop;\r\n  private onChangeCallback: (_: any) => void = noop;\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private _dateAdapter: DateAdapter<any>,\r\n    private datePickerService: DrDatePickerService\r\n  ) { \r\n    datePickerService.format\r\n        .pipe(takeUntil(this._destroyed))\r\n        .subscribe((value) => {\r\n          this._format = value;\r\n          this.onChangeFormat.emit(this.normalizeValue(value));\r\n          cdr.markForCheck()\r\n        });\r\n\r\n    datePickerService.updatedQuater\r\n        .pipe(takeUntil(this._destroyed))\r\n        .subscribe((value) => {\r\n            this.tryToNormalaizeTimeframe(value, 'quarter')\r\n            this.writeValue(value);\r\n            this.onChangeCallback(value);\r\n        });\r\n  }\r\n\r\n  tryToNormalaizeTimeframe(normalizedRef: Moment, timeframe: moment.unitOfTime.StartOf) {\r\n    if (this.takeEndOfPeriod) {\r\n        normalizedRef.endOf(timeframe);\r\n    }\r\n  }\r\n\r\n  public get value(): number {\r\n    return this.innerValue;\r\n  }\r\n\r\n  public set value(v: number) {\r\n    if (v !== this.innerValue) {\r\n        this.innerValue = v;\r\n        this.onChangeCallback(v);\r\n    }\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChangeCallback = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  public writeValue(value: any): void {\r\n    if (value !== this.innerValue) {\r\n      if (value && typeof value === 'number') {\r\n        this.innerValue = moment.unix(value);\r\n      } else {\r\n        this.innerValue = value;\r\n      }\r\n      this.tryToNormalaizeTimeframe(this.innerValue, this.datePickerService.timeframe)\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  get quarterDisplay() {\r\n    return this.datePickerService.getQuarterDisplay(this.value, this._format);\r\n  }\r\n\r\n  normalizeValue(value) {\r\n    if (value.includes('d')) {\r\n      value = value.replace(/d/g, 'D');\r\n    } else if (value.includes('D')) {\r\n      value = value.replace(/D/g, 'd');\r\n    }\r\n    return value;\r\n  }\r\n\r\n  chosenMonthHandler(normalizedMonth: Moment, datepicker: MatDatepicker<any>) {\r\n    if (this.datePickerService.timeframe == 'month') {\r\n        this.tryToNormalaizeTimeframe(normalizedMonth, 'month');\r\n        this.writeValue(normalizedMonth);\r\n        this.onChangeCallback(normalizedMonth);\r\n        datepicker.close();\r\n    }\r\n  }\r\n\r\n  chosenYearHandler(normalizedYear: Moment, datepicker: MatDatepicker<any>) {\r\n    if (this.datePickerService.timeframe == 'year') {\r\n        this.tryToNormalaizeTimeframe(normalizedYear, 'year');\r\n        this.writeValue(normalizedYear);\r\n        this.onChangeCallback(normalizedYear);\r\n        datepicker.close();\r\n    } else if (['quarter', 'day'].includes(this.datePickerService.timeframe)) {\r\n        this.writeValue(normalizedYear);\r\n        datepicker.close();\r\n    }\r\n  }\r\n  \r\n  pagingClicked(forward) {\r\n    this.pagingSetup[this.datePickerService.timeframe] && this.pagingSetup[this.datePickerService.timeframe](forward);\r\n    this.datePickerService.calendarInstance.close();\r\n  }\r\n\r\n  pagingDateChange(actionCall: string, amount: number, forward: boolean) {\r\n    const newValue = this._dateAdapter[actionCall](this.innerValue, forward? amount: - amount);\r\n    this.writeValue(newValue);\r\n    this.onChangeCallback(newValue);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._destroyed.next();\r\n    this._destroyed.complete();\r\n  }\r\n}\r\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-date-picker/dr-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  Input,\r\n  ChangeDetectorRef, ViewChild, AfterViewInit, OnDestroy, Output, EventEmitter\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { MatDatepicker } from '@angular/material/datepicker';\r\nimport { MAT_DEFAULT_DATE_FORMAT, MONTH_YEAR_FORMAT, QUARTER_FORMAT, YEAR_FORMAT } from '../../models/datePicker';\r\nimport { Moment } from 'moment';\r\nimport { DrDatePickerCustomHeaderComponent } from './dr-date-picker_custom-header/dr-date-picker_custom-header.component';\r\nimport { DateAdapter } from '@angular/material/core';\r\nimport { DrDatePickerService } from './dr-date-picker.service';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nconst moment = require('moment');\r\n\r\nconst noop = () => {};\r\n\r\n@Component({\r\n  selector: 'dr-date-picker',\r\n  templateUrl: './dr-date-picker.component.html',\r\n  styleUrls: ['./dr-date-picker.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    { provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerComponent, multi: true }\r\n  ],\r\n\r\n})\r\nexport class DrDatePickerComponent implements ControlValueAccessor, AfterViewInit, OnDestroy {\r\n  private _destroyed = new Subject<void> ();\r\n  readonly = true;\r\n  @Input() _format = MAT_DEFAULT_DATE_FORMAT;\r\n  customHeader = DrDatePickerCustomHeaderComponent;\r\n  @Output() onChangeFormat = new EventEmitter<string> ();\r\n  @Input() set format(value) {\r\n    if (value) {\r\n      value = this.normalizeValue(value);\r\n      this._format = value;\r\n      this.datePickerService.format.next(value);\r\n      this.datePickerService.setTimeframe(value);\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n  @Input() timeframeSelection: boolean = false;\r\n  @Input() takeEndOfPeriod: boolean = false;\r\n  @Input() placeholder: string = 'Select';\r\n  @Input() min: Date = null;\r\n  @Input() max: Date = null;\r\n  @ViewChild('datePicker') public dp;\r\n\r\n  ngAfterViewInit(): void {\r\n    this.datePickerService.calendarInstance = this.dp;\r\n    if (this._format === MAT_DEFAULT_DATE_FORMAT) {\r\n      return;\r\n    }\r\n      setTimeout(() => {\r\n       const popupInstance = this.dp._popupComponentRef.instance;\r\n       const calenderInstance = popupInstance._calendar._calendarHeaderPortal._attachedHost._attachedRef.instance;\r\n       calenderInstance.currentPeriodClicked = function () {\r\n          this.calendarViewSetup[this.datePickerService.timeframe] && this.calendarViewSetup[this.datePickerService.timeframe](this.calendar);\r\n        };\r\n      }, 1000);\r\n  }\r\n\r\n  calendarViewSetup = {\r\n    'year': (calendar) => calendar.currentView = 'multi-year',\r\n    'month': (calendar) => calendar.currentView = 'year',\r\n    'quarter': (calendar) => calendar.currentView = 'none',\r\n    'day': (calendar) => calendar.currentView = 'month'\r\n  }\r\n\r\n  pagingSetup = {\r\n    'year': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\r\n    'quarter': (forward) =>  this.pagingDateChange('addCalendarMonths', 3, forward),\r\n    'month': (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\r\n    'day': (forward) =>  this.pagingDateChange('addCalendarDays', 1, forward)\r\n  }\r\n\r\n  private innerValue: any = null;\r\n  private onTouchedCallback: () => void = noop;\r\n  private onChangeCallback: (_: any) => void = noop;\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private _dateAdapter: DateAdapter<any>,\r\n    private datePickerService: DrDatePickerService\r\n  ) { \r\n    datePickerService.format\r\n        .pipe(takeUntil(this._destroyed))\r\n        .subscribe((value) => {\r\n          this._format = value;\r\n          this.onChangeFormat.emit(this.normalizeValue(value));\r\n          cdr.markForCheck()\r\n        });\r\n\r\n    datePickerService.updatedQuater\r\n        .pipe(takeUntil(this._destroyed))\r\n        .subscribe((value) => {\r\n            this.tryToNormalaizeTimeframe(value, 'quarter')\r\n            this.writeValue(value);\r\n            this.onChangeCallback(value);\r\n        });\r\n  }\r\n\r\n  tryToNormalaizeTimeframe(normalizedRef: Moment, timeframe: moment.unitOfTime.StartOf) {\r\n    if (this.takeEndOfPeriod) {\r\n        normalizedRef.endOf(timeframe);\r\n    }\r\n    normalizedRef.set('hour', 12);\r\n  }\r\n\r\n  public get value(): number {\r\n    return this.innerValue;\r\n  }\r\n\r\n  public set value(v: number) {\r\n    if (v !== this.innerValue) {\r\n        this.innerValue = v;\r\n        this.onChangeCallback(v);\r\n    }\r\n    this.cdr.markForCheck();\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChangeCallback = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  public writeValue(value: any): void {\r\n    if (value !== this.innerValue) {\r\n      if (value && typeof value === 'number') {\r\n        this.innerValue = moment.unix(value);\r\n      } else {\r\n        this.innerValue = value;\r\n      }\r\n      this.tryToNormalaizeTimeframe(this.innerValue, this.datePickerService.timeframe)\r\n      this.cdr.markForCheck();\r\n    }\r\n  }\r\n\r\n  get quarterDisplay() {\r\n    return this.datePickerService.getQuarterDisplay(this.value, this._format);\r\n  }\r\n\r\n  normalizeValue(value) {\r\n    if (value.includes('d')) {\r\n      value = value.replace(/d/g, 'D');\r\n    } else if (value.includes('D')) {\r\n      value = value.replace(/D/g, 'd');\r\n    }\r\n    return value;\r\n  }\r\n\r\n  chosenMonthHandler(normalizedMonth: Moment, datepicker: MatDatepicker<any>) {\r\n    if (this.datePickerService.timeframe === 'month') {\r\n        this.tryToNormalaizeTimeframe(normalizedMonth, 'month');\r\n        this.writeValue(normalizedMonth);\r\n        this.onChangeCallback(normalizedMonth);\r\n        datepicker.close();\r\n    }\r\n  }\r\n\r\n  chosenYearHandler(normalizedYear: Moment, datepicker: MatDatepicker<any>) {\r\n    if (this.datePickerService.timeframe === 'year') {\r\n        this.tryToNormalaizeTimeframe(normalizedYear, 'year');\r\n        this.writeValue(normalizedYear);\r\n        this.onChangeCallback(normalizedYear);\r\n        datepicker.close();\r\n    }\r\n  }\r\n  \r\n  pagingClicked(forward) {\r\n    this.pagingSetup[this.datePickerService.timeframe] && this.pagingSetup[this.datePickerService.timeframe](forward);\r\n    this.datePickerService.calendarInstance.close();\r\n  }\r\n\r\n  pagingDateChange(actionCall: string, amount: number, forward: boolean) {\r\n    const newValue = this._dateAdapter[actionCall](this.innerValue, forward? amount: - amount);\r\n    this.writeValue(newValue);\r\n    this.onChangeCallback(newValue);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._destroyed.next();\r\n    this._destroyed.complete();\r\n  }\r\n}\r\n"]}
|
|
@@ -53,22 +53,22 @@ export class DrDatePickerCustomHeaderComponent {
|
|
|
53
53
|
this.timeframeSelection = false;
|
|
54
54
|
this.periodMonthLabel = '';
|
|
55
55
|
this.periodYearLabel = '';
|
|
56
|
-
_calendar.stateChanges
|
|
57
|
-
.pipe(takeUntil(this._destroyed))
|
|
58
|
-
.subscribe(() => cdr.markForCheck());
|
|
56
|
+
_calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());
|
|
59
57
|
this.datePickerService.format
|
|
60
58
|
.pipe(take(1))
|
|
61
59
|
.subscribe(value => {
|
|
62
60
|
this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;
|
|
63
61
|
});
|
|
62
|
+
_calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());
|
|
64
63
|
}
|
|
65
64
|
ngOnDestroy() {
|
|
66
65
|
this._destroyed.next();
|
|
67
66
|
this._destroyed.complete();
|
|
68
67
|
}
|
|
69
|
-
setPeriodLabels(
|
|
68
|
+
setPeriodLabels() {
|
|
69
|
+
const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];
|
|
70
70
|
const fullPeriodLabel = currentTimeframeOption.periodLabel();
|
|
71
|
-
if (this.
|
|
71
|
+
if (this._calendar.currentView === 'month') {
|
|
72
72
|
this.periodMonthLabel = fullPeriodLabel.slice(0, 3);
|
|
73
73
|
this.periodYearLabel = fullPeriodLabel.slice(4);
|
|
74
74
|
}
|
|
@@ -76,12 +76,12 @@ export class DrDatePickerCustomHeaderComponent {
|
|
|
76
76
|
this.periodMonthLabel = '';
|
|
77
77
|
this.periodYearLabel = fullPeriodLabel;
|
|
78
78
|
}
|
|
79
|
+
this.cdr.markForCheck();
|
|
79
80
|
}
|
|
80
81
|
setTimeframe() {
|
|
81
82
|
this.timeframeSelection = false;
|
|
82
83
|
this._calendar.currentView = this.selectedTimeframe;
|
|
83
84
|
const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];
|
|
84
|
-
this.setPeriodLabels(chosenTimeframeOption);
|
|
85
85
|
this.datePickerService.format.next(chosenTimeframeOption.format);
|
|
86
86
|
this.datePickerService.setTimeframe(chosenTimeframeOption.format);
|
|
87
87
|
if (this.selectedTimeframe == 'none') {
|
|
@@ -103,12 +103,11 @@ export class DrDatePickerCustomHeaderComponent {
|
|
|
103
103
|
this.datePickerService.calendarInstance.close();
|
|
104
104
|
}
|
|
105
105
|
pagingClicked(forward) {
|
|
106
|
-
this.pagingSetup[this.
|
|
106
|
+
this.pagingSetup[this._calendar.currentView] && this.pagingSetup[this._calendar.currentView](forward);
|
|
107
107
|
}
|
|
108
108
|
pagingDateChange(actionCall, amount, forward) {
|
|
109
109
|
this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward ? amount : -amount);
|
|
110
|
-
|
|
111
|
-
this.setPeriodLabels(chosenTimeframeOption);
|
|
110
|
+
this.setPeriodLabels();
|
|
112
111
|
}
|
|
113
112
|
}
|
|
114
113
|
DrDatePickerCustomHeaderComponent.decorators = [
|
|
@@ -116,7 +115,7 @@ DrDatePickerCustomHeaderComponent.decorators = [
|
|
|
116
115
|
selector: 'dr-date-picker_custom-header.component',
|
|
117
116
|
template: "<div class=\"dr-datepicker__timeframe-select__wrapper\">\r\n <dr-select \r\n class=\"dr-datepicker__timeframe-select\"\r\n [(ngModel)]=\"selectedTimeframe\"\r\n [items]=\"timeframeOptions\"\r\n bindLabel=\"title\"\r\n bindValue=\"value\"\r\n (ngModelChange)=\"setTimeframe()\">\r\n </dr-select>\r\n</div>\r\n\r\n<div class=\"dr-date-paging\">\r\n <div class=\"dr-date-paging flip-page-button\"\r\n (click)=\"pagingClicked(false)\">\r\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i> \r\n </div>\r\n <span class=\"example-header-label\">\r\n <span (click)=\"switchViewOnClickOnPeriodLabel('year')\">{{periodMonthLabel + ' '}}</span> \r\n <span (click)=\"switchViewOnClickOnPeriodLabel('multi-year')\">{{periodYearLabel}}</span>\r\n </span>\r\n <div class=\"dr-date-paging flip-page-button\"\r\n (click)=\"pagingClicked(true)\">\r\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\r\n </div>\r\n</div>\r\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuater\">\r\n <div *ngFor=\"let quarter of quarters\" \r\n class=\"quarter-selector\" (click)=\"onSelectQuater(quarter)\"\r\n [class]=\"quarter == selectedQuarter ? 'selected' : ''\"\r\n >Q{{quarter}}</div>\r\n</div>\r\n\r\n",
|
|
118
117
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
119
|
-
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-date-paging{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 8px;grid-gap:4px;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}.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}\n"]
|
|
118
|
+
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-date-paging{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 8px;grid-gap:4px;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}\n"]
|
|
120
119
|
},] }
|
|
121
120
|
];
|
|
122
121
|
DrDatePickerCustomHeaderComponent.ctorParameters = () => [
|
|
@@ -126,4 +125,4 @@ DrDatePickerCustomHeaderComponent.ctorParameters = () => [
|
|
|
126
125
|
{ type: ChangeDetectorRef },
|
|
127
126
|
{ type: DrDatePickerService }
|
|
128
127
|
];
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, OnDestroy, ChangeDetectorRef, Component, Inject } from \"@angular/core\";\r\nimport { Subject } from \"rxjs\";\r\nimport { take, takeUntil } from 'rxjs/operators';\r\nimport { MatCalendar, MatCalendarView } from '@angular/material/datepicker';\r\nimport { DateAdapter, MAT_DATE_FORMATS} from '@angular/material/core';\r\nimport { CustomDateFormat, MAT_DEFAULT_DATE_FORMAT, MONTH_YEAR_FORMAT, QUARTER_FORMAT, YEAR_FORMAT } from \"../../../models/datePicker\";\r\nimport { DrDatePickerService } from \"../dr-date-picker.service\";\r\n\r\nconst moment = require('moment');\r\n\r\nexport interface ITimeframeOption {\r\n      title: string,\r\n      value: MatCalendarView,\r\n      format: string,\r\n      periodLabel: () => string\r\n}\r\n\r\n@Component({\r\n    selector: 'dr-date-picker_custom-header.component',\r\n    templateUrl: 'dr-date-picker_custom-header.component.html',\r\n    styleUrls: ['./dr-date-picker_custom-header.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n    \r\n  })\r\n\r\nexport class DrDatePickerCustomHeaderComponent<Moment> implements OnDestroy {\r\n    private _destroyed = new Subject<void>();\r\n    quarters = [1, 2, 3, 4];\r\n    selectedQuarter = 1;\r\n    timeframeOptions: ITimeframeOption[] = [{\r\n      title: 'Day',\r\n      value: 'month',\r\n      format: MAT_DEFAULT_DATE_FORMAT,\r\n      periodLabel: () => this._dateAdapter\r\n                            .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\r\n                            .toLocaleUpperCase()\r\n    },{\r\n      title: 'Month',\r\n      value: 'year',\r\n      format: MONTH_YEAR_FORMAT,\r\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\r\n    },{\r\n      title: 'Quarter',\r\n      value: <MatCalendarView> 'none',\r\n      format: QUARTER_FORMAT,\r\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\r\n    },{\r\n      title: 'Year',\r\n      value: 'multi-year',\r\n      format: YEAR_FORMAT,\r\n      periodLabel:  () => {\r\n        const currentYear = moment(this._calendar.activeDate).year();\r\n        const startPeriod = Math.floor(currentYear/24)*24;\r\n        return startPeriod + '-' + (startPeriod + 23);\r\n      }\r\n    }]\r\n\r\n    pagingSetup = {\r\n      'year': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\r\n      'none': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\r\n      'month': (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\r\n      'multi-year': (forward) =>  this.pagingDateChange('addCalendarYears', 24, forward)\r\n    }\r\n     \r\n    selectedTimeframe: MatCalendarView = 'month';\r\n    timeframeSelection = false;\r\n    periodMonthLabel = '';\r\n    periodYearLabel = '';\r\n    constructor(\r\n        private _calendar: MatCalendar<Moment>,\r\n        private _dateAdapter: DateAdapter<Moment>,\r\n        @Inject(MAT_DATE_FORMATS) private _dateFormats: CustomDateFormat,\r\n        private cdr: ChangeDetectorRef,\r\n        private datePickerService: DrDatePickerService) {\r\n          _calendar.stateChanges\r\n            .pipe(takeUntil(this._destroyed))\r\n            .subscribe(() => cdr.markForCheck());\r\n          this.datePickerService.format\r\n            .pipe(take(1))\r\n            .subscribe( value => {\r\n              this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;\r\n            })\r\n    }\r\n\r\n    ngOnDestroy() {\r\n      this._destroyed.next();\r\n      this._destroyed.complete();\r\n    }\r\n\r\n    setPeriodLabels(currentTimeframeOption) {\r\n      const fullPeriodLabel = currentTimeframeOption.periodLabel();\r\n      if (this.selectedTimeframe === 'month') {\r\n        this.periodMonthLabel = fullPeriodLabel.slice(0,3);\r\n        this.periodYearLabel = fullPeriodLabel.slice(4);\r\n      } else {\r\n        this.periodMonthLabel = '';\r\n        this.periodYearLabel = fullPeriodLabel;\r\n      }\r\n    }\r\n    \r\n    setTimeframe() {\r\n      this.timeframeSelection = false;\r\n      this._calendar.currentView = this.selectedTimeframe;\r\n      const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\r\n      this.setPeriodLabels(chosenTimeframeOption);\r\n      this.datePickerService.format.next(chosenTimeframeOption.format);  \r\n      this.datePickerService.setTimeframe(chosenTimeframeOption.format);\r\n      if (this.selectedTimeframe == <MatCalendarView>'none') {\r\n        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\r\n      }\r\n    }\r\n\r\n    get currentViewIsQuater() {\r\n      return !['month', 'year', 'multi-year'].includes(this._calendar.currentView);\r\n    }\r\n \r\n    switchViewOnClickOnPeriodLabel(view: 'year' | 'multi-year') {\r\n      this._calendar.currentView = view;\r\n    }\r\n\r\n    onSelectQuater(quarterNumber: number) {\r\n      const monthsInQuarter = 3;\r\n      this.selectedQuarter = moment(this._calendar.activeDate).quarter();\r\n\r\n      const unadaptedDate = this._dateAdapter.addCalendarMonths(this._calendar.activeDate,\r\n        monthsInQuarter * (quarterNumber - this.selectedQuarter));\r\n      this._calendar.activeDate = unadaptedDate;\r\n      this.datePickerService.updatedQuater.next(moment(unadaptedDate));\r\n      this.datePickerService.calendarInstance.close();\r\n    }\r\n\r\n    pagingClicked(forward) {\r\n      this.pagingSetup[this.selectedTimeframe] && this.pagingSetup[this.selectedTimeframe](forward);\r\n    }\r\n\r\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\r\n      this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward? amount: - amount);\r\n      const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\r\n      this.setPeriodLabels(chosenTimeframeOption);\r\n    }\r\n  }"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-date-picker_custom-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, OnDestroy, ChangeDetectorRef, Component, Inject } from \"@angular/core\";\r\nimport { Subject } from \"rxjs\";\r\nimport { take, takeUntil } from 'rxjs/operators';\r\nimport { MatCalendar, MatCalendarView } from '@angular/material/datepicker';\r\nimport { DateAdapter, MAT_DATE_FORMATS} from '@angular/material/core';\r\nimport { CustomDateFormat, MAT_DEFAULT_DATE_FORMAT, MONTH_YEAR_FORMAT, QUARTER_FORMAT, YEAR_FORMAT } from \"../../../models/datePicker\";\r\nimport { DrDatePickerService } from \"../dr-date-picker.service\";\r\n\r\nconst moment = require('moment');\r\n\r\nexport interface ITimeframeOption {\r\n      title: string,\r\n      value: MatCalendarView,\r\n      format: string,\r\n      periodLabel: () => string\r\n}\r\n\r\n@Component({\r\n    selector: 'dr-date-picker_custom-header.component',\r\n    templateUrl: 'dr-date-picker_custom-header.component.html',\r\n    styleUrls: ['./dr-date-picker_custom-header.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n    \r\n  })\r\n\r\nexport class DrDatePickerCustomHeaderComponent<Moment> implements OnDestroy {\r\n    private _destroyed = new Subject<void>();\r\n    quarters = [1, 2, 3, 4];\r\n    selectedQuarter = 1;\r\n    timeframeOptions: ITimeframeOption[] = [{\r\n      title: 'Day',\r\n      value: 'month',\r\n      format: MAT_DEFAULT_DATE_FORMAT,\r\n      periodLabel: () => this._dateAdapter\r\n                            .format(this._calendar.activeDate, this._dateFormats.display.monthYearLabel)\r\n                            .toLocaleUpperCase()\r\n    },{\r\n      title: 'Month',\r\n      value: 'year',\r\n      format: MONTH_YEAR_FORMAT,\r\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\r\n    },{\r\n      title: 'Quarter',\r\n      value: <MatCalendarView> 'none',\r\n      format: QUARTER_FORMAT,\r\n      periodLabel: () => String(moment(this._calendar.activeDate).year())\r\n    },{\r\n      title: 'Year',\r\n      value: 'multi-year',\r\n      format: YEAR_FORMAT,\r\n      periodLabel:  () => {\r\n        const currentYear = moment(this._calendar.activeDate).year();\r\n        const startPeriod = Math.floor(currentYear/24)*24;\r\n        return startPeriod + '-' + (startPeriod + 23);\r\n      }\r\n    }]\r\n\r\n    pagingSetup = {\r\n      'year': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\r\n      'none': (forward) =>  this.pagingDateChange('addCalendarYears', 1, forward),\r\n      'month': (forward) =>  this.pagingDateChange('addCalendarMonths', 1, forward),\r\n      'multi-year': (forward) =>  this.pagingDateChange('addCalendarYears', 24, forward)\r\n    }\r\n     \r\n    selectedTimeframe: MatCalendarView = 'month';\r\n    timeframeSelection = false;\r\n    periodMonthLabel = '';\r\n    periodYearLabel = '';\r\n    constructor(\r\n        private _calendar: MatCalendar<Moment>,\r\n        private _dateAdapter: DateAdapter<Moment>,\r\n        @Inject(MAT_DATE_FORMATS) private _dateFormats: CustomDateFormat,\r\n        private cdr: ChangeDetectorRef,\r\n        private datePickerService: DrDatePickerService) {\r\n          _calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\r\n          this.datePickerService.format\r\n            .pipe(take(1))\r\n            .subscribe( value => {\r\n              this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;\r\n            });\r\n          _calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());\r\n    }\r\n\r\n    ngOnDestroy() {\r\n      this._destroyed.next();\r\n      this._destroyed.complete();\r\n    }\r\n\r\n    setPeriodLabels() {\r\n      const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];\r\n      const fullPeriodLabel = currentTimeframeOption.periodLabel();\r\n      if (this._calendar.currentView === 'month') {\r\n        this.periodMonthLabel = fullPeriodLabel.slice(0,3);\r\n        this.periodYearLabel = fullPeriodLabel.slice(4);\r\n      } else {\r\n        this.periodMonthLabel = '';\r\n        this.periodYearLabel = fullPeriodLabel;\r\n      }\r\n      this.cdr.markForCheck();\r\n    }\r\n    \r\n    setTimeframe() {\r\n      this.timeframeSelection = false;\r\n      this._calendar.currentView = this.selectedTimeframe;\r\n      const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];\r\n      this.datePickerService.format.next(chosenTimeframeOption.format);  \r\n      this.datePickerService.setTimeframe(chosenTimeframeOption.format);\r\n      if (this.selectedTimeframe == <MatCalendarView>'none') {\r\n        this.selectedQuarter = moment(this._calendar.activeDate).quarter();\r\n      }\r\n    }\r\n\r\n    get currentViewIsQuater() {\r\n      return !['month', 'year', 'multi-year'].includes(this._calendar.currentView);\r\n    }\r\n \r\n    switchViewOnClickOnPeriodLabel(view: 'year' | 'multi-year') {\r\n      this._calendar.currentView = view;\r\n    }\r\n\r\n    onSelectQuater(quarterNumber: number) {\r\n      const monthsInQuarter = 3;\r\n      this.selectedQuarter = moment(this._calendar.activeDate).quarter();\r\n\r\n      const unadaptedDate = this._dateAdapter.addCalendarMonths(this._calendar.activeDate,\r\n        monthsInQuarter * (quarterNumber - this.selectedQuarter));\r\n      this._calendar.activeDate = unadaptedDate;\r\n      this.datePickerService.updatedQuater.next(moment(unadaptedDate));\r\n      this.datePickerService.calendarInstance.close();\r\n    }\r\n\r\n    pagingClicked(forward) {\r\n      this.pagingSetup[this._calendar.currentView] && this.pagingSetup[this._calendar.currentView](forward);\r\n    }\r\n\r\n    pagingDateChange(actionCall: string, amount: number, forward: boolean) {\r\n      this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward? amount: - amount);\r\n      this.setPeriodLabels();\r\n    }\r\n  }"]}
|
|
@@ -2005,22 +2005,22 @@ class DrDatePickerCustomHeaderComponent {
|
|
|
2005
2005
|
this.timeframeSelection = false;
|
|
2006
2006
|
this.periodMonthLabel = '';
|
|
2007
2007
|
this.periodYearLabel = '';
|
|
2008
|
-
_calendar.stateChanges
|
|
2009
|
-
.pipe(takeUntil(this._destroyed))
|
|
2010
|
-
.subscribe(() => cdr.markForCheck());
|
|
2008
|
+
_calendar.stateChanges.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());
|
|
2011
2009
|
this.datePickerService.format
|
|
2012
2010
|
.pipe(take(1))
|
|
2013
2011
|
.subscribe(value => {
|
|
2014
2012
|
this.selectedTimeframe = this.timeframeOptions.filter(option => option.format == value)[0].value;
|
|
2015
2013
|
});
|
|
2014
|
+
_calendar.viewChanged.pipe(takeUntil(this._destroyed)).subscribe(() => this.setPeriodLabels());
|
|
2016
2015
|
}
|
|
2017
2016
|
ngOnDestroy() {
|
|
2018
2017
|
this._destroyed.next();
|
|
2019
2018
|
this._destroyed.complete();
|
|
2020
2019
|
}
|
|
2021
|
-
setPeriodLabels(
|
|
2020
|
+
setPeriodLabels() {
|
|
2021
|
+
const currentTimeframeOption = this.timeframeOptions.filter(option => option.value === this._calendar.currentView)[0];
|
|
2022
2022
|
const fullPeriodLabel = currentTimeframeOption.periodLabel();
|
|
2023
|
-
if (this.
|
|
2023
|
+
if (this._calendar.currentView === 'month') {
|
|
2024
2024
|
this.periodMonthLabel = fullPeriodLabel.slice(0, 3);
|
|
2025
2025
|
this.periodYearLabel = fullPeriodLabel.slice(4);
|
|
2026
2026
|
}
|
|
@@ -2028,12 +2028,12 @@ class DrDatePickerCustomHeaderComponent {
|
|
|
2028
2028
|
this.periodMonthLabel = '';
|
|
2029
2029
|
this.periodYearLabel = fullPeriodLabel;
|
|
2030
2030
|
}
|
|
2031
|
+
this.cdr.markForCheck();
|
|
2031
2032
|
}
|
|
2032
2033
|
setTimeframe() {
|
|
2033
2034
|
this.timeframeSelection = false;
|
|
2034
2035
|
this._calendar.currentView = this.selectedTimeframe;
|
|
2035
2036
|
const chosenTimeframeOption = this.timeframeOptions.filter(option => option.value === this.selectedTimeframe)[0];
|
|
2036
|
-
this.setPeriodLabels(chosenTimeframeOption);
|
|
2037
2037
|
this.datePickerService.format.next(chosenTimeframeOption.format);
|
|
2038
2038
|
this.datePickerService.setTimeframe(chosenTimeframeOption.format);
|
|
2039
2039
|
if (this.selectedTimeframe == 'none') {
|
|
@@ -2055,12 +2055,11 @@ class DrDatePickerCustomHeaderComponent {
|
|
|
2055
2055
|
this.datePickerService.calendarInstance.close();
|
|
2056
2056
|
}
|
|
2057
2057
|
pagingClicked(forward) {
|
|
2058
|
-
this.pagingSetup[this.
|
|
2058
|
+
this.pagingSetup[this._calendar.currentView] && this.pagingSetup[this._calendar.currentView](forward);
|
|
2059
2059
|
}
|
|
2060
2060
|
pagingDateChange(actionCall, amount, forward) {
|
|
2061
2061
|
this._calendar.activeDate = this._dateAdapter[actionCall](this._calendar.activeDate, forward ? amount : -amount);
|
|
2062
|
-
|
|
2063
|
-
this.setPeriodLabels(chosenTimeframeOption);
|
|
2062
|
+
this.setPeriodLabels();
|
|
2064
2063
|
}
|
|
2065
2064
|
}
|
|
2066
2065
|
DrDatePickerCustomHeaderComponent.decorators = [
|
|
@@ -2068,7 +2067,7 @@ DrDatePickerCustomHeaderComponent.decorators = [
|
|
|
2068
2067
|
selector: 'dr-date-picker_custom-header.component',
|
|
2069
2068
|
template: "<div class=\"dr-datepicker__timeframe-select__wrapper\">\r\n <dr-select \r\n class=\"dr-datepicker__timeframe-select\"\r\n [(ngModel)]=\"selectedTimeframe\"\r\n [items]=\"timeframeOptions\"\r\n bindLabel=\"title\"\r\n bindValue=\"value\"\r\n (ngModelChange)=\"setTimeframe()\">\r\n </dr-select>\r\n</div>\r\n\r\n<div class=\"dr-date-paging\">\r\n <div class=\"dr-date-paging flip-page-button\"\r\n (click)=\"pagingClicked(false)\">\r\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i> \r\n </div>\r\n <span class=\"example-header-label\">\r\n <span (click)=\"switchViewOnClickOnPeriodLabel('year')\">{{periodMonthLabel + ' '}}</span> \r\n <span (click)=\"switchViewOnClickOnPeriodLabel('multi-year')\">{{periodYearLabel}}</span>\r\n </span>\r\n <div class=\"dr-date-paging flip-page-button\"\r\n (click)=\"pagingClicked(true)\">\r\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\r\n </div>\r\n</div>\r\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuater\">\r\n <div *ngFor=\"let quarter of quarters\" \r\n class=\"quarter-selector\" (click)=\"onSelectQuater(quarter)\"\r\n [class]=\"quarter == selectedQuarter ? 'selected' : ''\"\r\n >Q{{quarter}}</div>\r\n</div>\r\n\r\n",
|
|
2070
2069
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
2071
|
-
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-date-paging{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 8px;grid-gap:4px;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}.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}\n"]
|
|
2070
|
+
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-date-paging{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 8px;grid-gap:4px;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}\n"]
|
|
2072
2071
|
},] }
|
|
2073
2072
|
];
|
|
2074
2073
|
DrDatePickerCustomHeaderComponent.ctorParameters = () => [
|
|
@@ -2153,6 +2152,7 @@ class DrDatePickerComponent {
|
|
|
2153
2152
|
if (this.takeEndOfPeriod) {
|
|
2154
2153
|
normalizedRef.endOf(timeframe);
|
|
2155
2154
|
}
|
|
2155
|
+
normalizedRef.set('hour', 12);
|
|
2156
2156
|
}
|
|
2157
2157
|
get value() {
|
|
2158
2158
|
return this.innerValue;
|
|
@@ -2195,7 +2195,7 @@ class DrDatePickerComponent {
|
|
|
2195
2195
|
return value;
|
|
2196
2196
|
}
|
|
2197
2197
|
chosenMonthHandler(normalizedMonth, datepicker) {
|
|
2198
|
-
if (this.datePickerService.timeframe
|
|
2198
|
+
if (this.datePickerService.timeframe === 'month') {
|
|
2199
2199
|
this.tryToNormalaizeTimeframe(normalizedMonth, 'month');
|
|
2200
2200
|
this.writeValue(normalizedMonth);
|
|
2201
2201
|
this.onChangeCallback(normalizedMonth);
|
|
@@ -2203,16 +2203,12 @@ class DrDatePickerComponent {
|
|
|
2203
2203
|
}
|
|
2204
2204
|
}
|
|
2205
2205
|
chosenYearHandler(normalizedYear, datepicker) {
|
|
2206
|
-
if (this.datePickerService.timeframe
|
|
2206
|
+
if (this.datePickerService.timeframe === 'year') {
|
|
2207
2207
|
this.tryToNormalaizeTimeframe(normalizedYear, 'year');
|
|
2208
2208
|
this.writeValue(normalizedYear);
|
|
2209
2209
|
this.onChangeCallback(normalizedYear);
|
|
2210
2210
|
datepicker.close();
|
|
2211
2211
|
}
|
|
2212
|
-
else if (['quarter', 'day'].includes(this.datePickerService.timeframe)) {
|
|
2213
|
-
this.writeValue(normalizedYear);
|
|
2214
|
-
datepicker.close();
|
|
2215
|
-
}
|
|
2216
2212
|
}
|
|
2217
2213
|
pagingClicked(forward) {
|
|
2218
2214
|
this.pagingSetup[this.datePickerService.timeframe] && this.pagingSetup[this.datePickerService.timeframe](forward);
|