ngx-daterangepicker-material
Version:
Angular 9 and 10 date range picker (with material design theme)
413 lines • 47.6 kB
JavaScript
import { Directive, ViewContainerRef, ElementRef, HostListener, forwardRef, ChangeDetectorRef, Input, KeyValueDiffers, Output, EventEmitter, Renderer2, HostBinding } from '@angular/core';
import { DaterangepickerComponent } from './daterangepicker.component';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import dayjs from 'dayjs/esm';
import { LocaleService } from './locale.service';
import * as i0 from "@angular/core";
import * as i1 from "./locale.service";
export class DaterangepickerDirective {
constructor(viewContainerRef, ref, el, renderer, differs, localeHolderService, elementRef) {
this.viewContainerRef = viewContainerRef;
this.ref = ref;
this.el = el;
this.renderer = renderer;
this.differs = differs;
this.localeHolderService = localeHolderService;
this.elementRef = elementRef;
this.onChange = new EventEmitter();
this.rangeClicked = new EventEmitter();
this.datesUpdated = new EventEmitter();
this.startDateChanged = new EventEmitter();
this.endDateChanged = new EventEmitter();
this.clearClicked = new EventEmitter();
this.dateLimit = null;
this.showCancel = false;
this.lockStartDate = false;
this.timePicker = false;
this.timePicker24Hour = false;
this.timePickerIncrement = 1;
this.timePickerSeconds = false;
this.closeOnAutoApply = true;
this.notForChangesProperty = ['locale', 'endKey', 'startKey'];
this.onChangeFn = Function.prototype;
this.onTouched = Function.prototype;
this.validatorChange = Function.prototype;
this.localeHolder = {};
this.endKey = 'endDate';
this.startKey = 'startDate';
this.drops = 'down';
this.opens = 'auto';
viewContainerRef.clear();
const componentRef = viewContainerRef.createComponent(DaterangepickerComponent);
this.picker = componentRef.instance;
this.picker.inline = false;
}
get disabled() {
return this.disabledHolder;
}
set startKey(value) {
if (value !== null) {
this.startKeyHolder = value;
}
else {
this.startKeyHolder = 'startDate';
}
}
get locale() {
return this.localeHolder;
}
set locale(value) {
this.localeHolder = { ...this.localeHolderService.config, ...value };
}
set endKey(value) {
if (value !== null) {
this.endKeyHolder = value;
}
else {
this.endKeyHolder = 'endDate';
}
}
get value() {
return this.valueHolder || null;
}
set value(val) {
this.valueHolder = val;
this.onChangeFn(val);
this.ref.markForCheck();
}
outsideClick(event) {
if (!event.target) {
return;
}
if (event.target.classList.contains('ngx-daterangepicker-action')) {
return;
}
if (!this.elementRef.nativeElement.contains(event.target)) {
this.hide();
}
}
hide(e) {
this.picker.hide(e);
}
onBlur() {
this.onTouched();
}
inputChanged(e) {
if (e.target.tagName.toLowerCase() !== 'input') {
return;
}
if (!e.target.value.length) {
return;
}
const dateString = e.target.value.split(this.picker.locale.separator);
let start = null;
let end = null;
if (dateString.length === 2) {
start = dayjs(dateString[0], this.picker.locale.format);
end = dayjs(dateString[1], this.picker.locale.format);
}
if (this.singleDatePicker || start === null || end === null) {
start = dayjs(e.target.value, this.picker.locale.format);
end = start;
}
if (!start.isValid() || !end.isValid()) {
return;
}
this.picker.setStartDate(start);
this.picker.setEndDate(end);
this.picker.updateView();
}
open(event) {
if (this.disabled) {
return;
}
this.picker.show(event);
setTimeout(() => {
this.setPosition();
});
}
ngOnInit() {
this.picker.startDateChanged.asObservable().subscribe((itemChanged) => {
this.startDateChanged.emit(itemChanged);
});
this.picker.endDateChanged.asObservable().subscribe((itemChanged) => {
this.endDateChanged.emit(itemChanged);
});
this.picker.rangeClicked.asObservable().subscribe((range) => {
this.rangeClicked.emit(range);
});
this.picker.datesUpdated.asObservable().subscribe((range) => {
this.datesUpdated.emit(range);
});
this.picker.clearClicked.asObservable().subscribe(() => {
this.clearClicked.emit();
});
this.picker.choosedDate.asObservable().subscribe((change) => {
if (change) {
const value = {
[this.startKeyHolder]: change.startDate,
[this.endKeyHolder]: change.endDate
};
this.value = value;
this.onChange.emit(value);
if (typeof change.chosenLabel === 'string') {
this.el.nativeElement.value = change.chosenLabel;
}
}
});
this.picker.firstMonthDayClass = this.firstMonthDayClass;
this.picker.lastMonthDayClass = this.lastMonthDayClass;
this.picker.emptyWeekRowClass = this.emptyWeekRowClass;
this.picker.emptyWeekColumnClass = this.emptyWeekColumnClass;
this.picker.firstDayOfNextMonthClass = this.firstDayOfNextMonthClass;
this.picker.lastDayOfPreviousMonthClass = this.lastDayOfPreviousMonthClass;
this.picker.drops = this.drops;
this.picker.opens = this.opens;
this.localeDiffer = this.differs.find(this.locale).create();
this.picker.closeOnAutoApply = this.closeOnAutoApply;
}
ngOnChanges(changes) {
for (const change in changes) {
if (Object.prototype.hasOwnProperty.call(changes, change)) {
if (this.notForChangesProperty.indexOf(change) === -1) {
this.picker[change] = changes[change].currentValue;
}
}
}
}
ngDoCheck() {
if (this.localeDiffer) {
const changes = this.localeDiffer.diff(this.locale);
if (changes) {
this.picker.updateLocale(this.locale);
}
}
}
toggle(e) {
if (this.picker.isShown) {
this.hide(e);
}
else {
this.open(e);
}
}
clear() {
this.picker.clear();
}
writeValue(value) {
this.setValue(value);
}
registerOnChange(fn) {
this.onChangeFn = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(state) {
this.disabledHolder = state;
}
setPosition() {
let style;
let containerTop;
const container = this.picker.pickerContainer.nativeElement;
const element = this.el.nativeElement;
if (this.drops && this.drops === 'up') {
containerTop = element.offsetTop - container.clientHeight + 'px';
}
else {
containerTop = 'auto';
}
if (this.opens === 'left') {
style = {
top: containerTop,
left: element.offsetLeft - container.clientWidth + element.clientWidth + 'px',
right: 'auto'
};
}
else if (this.opens === 'center') {
style = {
top: containerTop,
left: element.offsetLeft + element.clientWidth / 2 - container.clientWidth / 2 + 'px',
right: 'auto'
};
}
else if (this.opens === 'right') {
style = {
top: containerTop,
left: element.offsetLeft + 'px',
right: 'auto'
};
}
else {
const position = element.offsetLeft + element.clientWidth / 2 - container.clientWidth / 2;
if (position < 0) {
style = {
top: containerTop,
left: element.offsetLeft + 'px',
right: 'auto'
};
}
else {
style = {
top: containerTop,
left: position + 'px',
right: 'auto'
};
}
}
if (style) {
this.renderer.setStyle(container, 'top', style.top);
this.renderer.setStyle(container, 'left', style.left);
this.renderer.setStyle(container, 'right', style.right);
}
}
setValue(val) {
if (val) {
this.value = val;
if (val[this.startKeyHolder]) {
this.picker.setStartDate(val[this.startKeyHolder]);
}
if (val[this.endKeyHolder]) {
this.picker.setEndDate(val[this.endKeyHolder]);
}
this.picker.calculateChosenLabel();
if (this.picker.chosenLabel) {
this.el.nativeElement.value = this.picker.chosenLabel;
}
}
else {
this.picker.clear();
}
}
}
DaterangepickerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DaterangepickerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.KeyValueDiffers }, { token: i1.LocaleService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
DaterangepickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: DaterangepickerDirective, selector: "input[ngxDaterangepickerMd]", inputs: { minDate: "minDate", maxDate: "maxDate", autoApply: "autoApply", alwaysShowCalendars: "alwaysShowCalendars", showCustomRangeLabel: "showCustomRangeLabel", linkedCalendars: "linkedCalendars", dateLimit: "dateLimit", singleDatePicker: "singleDatePicker", showWeekNumbers: "showWeekNumbers", showISOWeekNumbers: "showISOWeekNumbers", showDropdowns: "showDropdowns", isInvalidDate: "isInvalidDate", isCustomDate: "isCustomDate", isTooltipDate: "isTooltipDate", showClearButton: "showClearButton", customRangeDirection: "customRangeDirection", ranges: "ranges", opens: "opens", drops: "drops", firstMonthDayClass: "firstMonthDayClass", lastMonthDayClass: "lastMonthDayClass", emptyWeekRowClass: "emptyWeekRowClass", emptyWeekColumnClass: "emptyWeekColumnClass", firstDayOfNextMonthClass: "firstDayOfNextMonthClass", lastDayOfPreviousMonthClass: "lastDayOfPreviousMonthClass", keepCalendarOpeningWithRange: "keepCalendarOpeningWithRange", showRangeLabelOnInput: "showRangeLabelOnInput", showCancel: "showCancel", lockStartDate: "lockStartDate", timePicker: "timePicker", timePicker24Hour: "timePicker24Hour", timePickerIncrement: "timePickerIncrement", timePickerSeconds: "timePickerSeconds", closeOnAutoApply: "closeOnAutoApply", endKeyHolder: "endKeyHolder", startKey: "startKey", locale: "locale", endKey: "endKey" }, outputs: { onChange: "change", rangeClicked: "rangeClicked", datesUpdated: "datesUpdated", startDateChanged: "startDateChanged", endDateChanged: "endDateChanged", clearClicked: "clearClicked" }, host: { listeners: { "document:click": "outsideClick($event)", "keyup.esc": "hide($event)", "blur": "onBlur()", "keyup": "inputChanged($event)", "click": "open($event)" }, properties: { "disabled": "this.disabled" } }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => DaterangepickerDirective),
multi: true
}
], usesOnChanges: true, ngImport: i0 });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DaterangepickerDirective, decorators: [{
type: Directive,
args: [{
selector: 'input[ngxDaterangepickerMd]',
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => DaterangepickerDirective),
multi: true
}
]
}]
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.KeyValueDiffers }, { type: i1.LocaleService }, { type: i0.ElementRef }]; }, propDecorators: { onChange: [{
type: Output,
args: ['change']
}], rangeClicked: [{
type: Output,
args: ['rangeClicked']
}], datesUpdated: [{
type: Output,
args: ['datesUpdated']
}], startDateChanged: [{
type: Output
}], endDateChanged: [{
type: Output
}], clearClicked: [{
type: Output
}], minDate: [{
type: Input
}], maxDate: [{
type: Input
}], autoApply: [{
type: Input
}], alwaysShowCalendars: [{
type: Input
}], showCustomRangeLabel: [{
type: Input
}], linkedCalendars: [{
type: Input
}], dateLimit: [{
type: Input
}], singleDatePicker: [{
type: Input
}], showWeekNumbers: [{
type: Input
}], showISOWeekNumbers: [{
type: Input
}], showDropdowns: [{
type: Input
}], isInvalidDate: [{
type: Input
}], isCustomDate: [{
type: Input
}], isTooltipDate: [{
type: Input
}], showClearButton: [{
type: Input
}], customRangeDirection: [{
type: Input
}], ranges: [{
type: Input
}], opens: [{
type: Input
}], drops: [{
type: Input
}], firstMonthDayClass: [{
type: Input
}], lastMonthDayClass: [{
type: Input
}], emptyWeekRowClass: [{
type: Input
}], emptyWeekColumnClass: [{
type: Input
}], firstDayOfNextMonthClass: [{
type: Input
}], lastDayOfPreviousMonthClass: [{
type: Input
}], keepCalendarOpeningWithRange: [{
type: Input
}], showRangeLabelOnInput: [{
type: Input
}], showCancel: [{
type: Input
}], lockStartDate: [{
type: Input
}], timePicker: [{
type: Input
}], timePicker24Hour: [{
type: Input
}], timePickerIncrement: [{
type: Input
}], timePickerSeconds: [{
type: Input
}], closeOnAutoApply: [{
type: Input
}], endKeyHolder: [{
type: Input
}], disabled: [{
type: HostBinding,
args: ['disabled']
}], startKey: [{
type: Input
}], locale: [{
type: Input
}], endKey: [{
type: Input
}], outsideClick: [{
type: HostListener,
args: ['document:click', ['$event']]
}], hide: [{
type: HostListener,
args: ['keyup.esc', ['$event']]
}], onBlur: [{
type: HostListener,
args: ['blur']
}], inputChanged: [{
type: HostListener,
args: ['keyup', ['$event']]
}], open: [{
type: HostListener,
args: ['click', ['$event']]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daterangepicker.directive.js","sourceRoot":"","sources":["../../src/daterangepicker/daterangepicker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ViewContainerRef,\n  ElementRef,\n  HostListener,\n  forwardRef,\n  ChangeDetectorRef,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  Input,\n  DoCheck,\n  KeyValueDiffer,\n  KeyValueDiffers,\n  Output,\n  EventEmitter,\n  Renderer2,\n  HostBinding\n} from '@angular/core';\nimport { ChosenDate, DateRange, DaterangepickerComponent, DateRanges, EndDate, StartDate, TimePeriod } from './daterangepicker.component';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport dayjs from 'dayjs/esm';\nimport { LocaleConfig } from './daterangepicker.config';\nimport { LocaleService } from './locale.service';\n\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: 'input[ngxDaterangepickerMd]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DaterangepickerDirective),\n      multi: true\n    }\n  ]\n})\n// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\nexport class DaterangepickerDirective implements OnInit, OnChanges, DoCheck {\n  // eslint-disable-next-line @angular-eslint/no-output-on-prefix,@angular-eslint/no-output-native,@angular-eslint/no-output-rename\n  @Output('change') onChange: EventEmitter<TimePeriod | null> = new EventEmitter();\n  // eslint-disable-next-line @angular-eslint/no-output-rename\n  @Output('rangeClicked') rangeClicked: EventEmitter<DateRange> = new EventEmitter();\n  // eslint-disable-next-line @angular-eslint/no-output-rename\n  @Output('datesUpdated') datesUpdated: EventEmitter<TimePeriod> = new EventEmitter();\n  @Output() startDateChanged: EventEmitter<StartDate> = new EventEmitter();\n  @Output() endDateChanged: EventEmitter<EndDate> = new EventEmitter();\n  @Output() clearClicked: EventEmitter<void> = new EventEmitter();\n\n  @Input()\n  minDate: dayjs.Dayjs;\n\n  @Input()\n  maxDate: dayjs.Dayjs;\n\n  @Input()\n  autoApply: boolean;\n\n  @Input()\n  alwaysShowCalendars: boolean;\n\n  @Input()\n  showCustomRangeLabel: boolean;\n\n  @Input()\n  linkedCalendars: boolean;\n\n  @Input()\n  dateLimit: number = null;\n\n  @Input()\n  singleDatePicker: boolean;\n\n  @Input()\n  showWeekNumbers: boolean;\n\n  @Input()\n  showISOWeekNumbers: boolean;\n\n  @Input()\n  showDropdowns: boolean;\n\n  @Input()\n  isInvalidDate: (Dayjs) => boolean;\n\n  @Input()\n  isCustomDate: (Dayjs) => string | boolean;\n\n  @Input()\n  isTooltipDate: (Dayjs) => string | boolean | null;\n\n  @Input()\n  showClearButton: boolean;\n\n  @Input()\n  customRangeDirection: boolean;\n\n  @Input()\n  ranges: DateRanges;\n\n  @Input()\n  opens: string;\n\n  @Input()\n  drops: string;\n\n  @Input()\n  firstMonthDayClass: string;\n\n  @Input()\n  lastMonthDayClass: string;\n\n  @Input()\n  emptyWeekRowClass: string;\n\n  @Input()\n  emptyWeekColumnClass: string;\n\n  @Input()\n  firstDayOfNextMonthClass: string;\n\n  @Input()\n  lastDayOfPreviousMonthClass: string;\n\n  @Input()\n  keepCalendarOpeningWithRange: boolean;\n\n  @Input()\n  showRangeLabelOnInput: boolean;\n\n  @Input()\n  showCancel = false;\n\n  @Input()\n  lockStartDate = false;\n\n  // timepicker variables\n  @Input()\n  timePicker = false;\n\n  @Input()\n  timePicker24Hour = false;\n\n  @Input()\n  timePickerIncrement = 1;\n\n  @Input()\n  timePickerSeconds = false;\n\n  @Input() closeOnAutoApply = true;\n  @Input()\n  private endKeyHolder: string;\n\n  public picker: DaterangepickerComponent;\n  private startKeyHolder: string;\n  private notForChangesProperty: Array<string> = ['locale', 'endKey', 'startKey'];\n  private onChangeFn = Function.prototype;\n  private onTouched = Function.prototype;\n  private validatorChange = Function.prototype;\n  private disabledHolder: boolean;\n  private valueHolder: TimePeriod | null;\n  private localeDiffer: KeyValueDiffer<string, any>;\n  private localeHolder: LocaleConfig = {};\n\n  constructor(\n    public viewContainerRef: ViewContainerRef,\n    public ref: ChangeDetectorRef,\n    private el: ElementRef,\n    private renderer: Renderer2,\n    private differs: KeyValueDiffers,\n    private localeHolderService: LocaleService,\n    private elementRef: ElementRef\n  ) {\n    this.endKey = 'endDate';\n    this.startKey = 'startDate';\n    this.drops = 'down';\n    this.opens = 'auto';\n    viewContainerRef.clear();\n    const componentRef = viewContainerRef.createComponent(DaterangepickerComponent);\n    this.picker = componentRef.instance as DaterangepickerComponent;\n    this.picker.inline = false; // set inline to false for all directive usage\n  }\n\n  @HostBinding('disabled') get disabled(): boolean {\n    return this.disabledHolder;\n  }\n\n  @Input() set startKey(value: string) {\n    if (value !== null) {\n      this.startKeyHolder = value;\n    } else {\n      this.startKeyHolder = 'startDate';\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  get locale(): LocaleConfig {\n    return this.localeHolder;\n  }\n\n  @Input() set locale(value: LocaleConfig) {\n    this.localeHolder = { ...this.localeHolderService.config, ...value };\n  }\n\n  @Input() set endKey(value: string) {\n    if (value !== null) {\n      this.endKeyHolder = value;\n    } else {\n      this.endKeyHolder = 'endDate';\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/member-ordering\n  get value(): TimePeriod | null {\n    return this.valueHolder || null;\n  }\n\n  set value(val: TimePeriod | null) {\n    this.valueHolder = val;\n    this.onChangeFn(val);\n    this.ref.markForCheck();\n  }\n\n  /**\n   * For click outside the calendar's container\n   *\n   * @param event event object\n   */\n  @HostListener('document:click', ['$event'])\n  outsideClick(event: Event): void {\n    if (!event.target) {\n      return;\n    }\n\n    if ((event.target as HTMLElement).classList.contains('ngx-daterangepicker-action')) {\n      return;\n    }\n\n    if (!this.elementRef.nativeElement.contains(event.target)) {\n      this.hide();\n    }\n  }\n\n  @HostListener('keyup.esc', ['$event'])\n  hide(e?: Event): void {\n    this.picker.hide(e);\n  }\n\n  @HostListener('blur')\n  onBlur(): void {\n    this.onTouched();\n  }\n\n  @HostListener('keyup', ['$event'])\n  inputChanged(e: KeyboardEvent): void {\n    if ((e.target as HTMLElement).tagName.toLowerCase() !== 'input') {\n      return;\n    }\n    if (!(e.target as HTMLInputElement).value.length) {\n      return;\n    }\n    const dateString = (e.target as HTMLInputElement).value.split(this.picker.locale.separator);\n    let start = null;\n    let end = null;\n    if (dateString.length === 2) {\n      start = dayjs(dateString[0], this.picker.locale.format);\n      end = dayjs(dateString[1], this.picker.locale.format);\n    }\n    if (this.singleDatePicker || start === null || end === null) {\n      start = dayjs((e.target as HTMLInputElement).value, this.picker.locale.format);\n      end = start;\n    }\n    if (!start.isValid() || !end.isValid()) {\n      return;\n    }\n    this.picker.setStartDate(start);\n    this.picker.setEndDate(end);\n    this.picker.updateView();\n  }\n\n  @HostListener('click', ['$event'])\n  open(event?: Event): void {\n    if (this.disabled) {\n      return;\n    }\n    this.picker.show(event);\n    setTimeout(() => {\n      this.setPosition();\n    });\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnInit(): void {\n    this.picker.startDateChanged.asObservable().subscribe((itemChanged: StartDate) => {\n      this.startDateChanged.emit(itemChanged);\n    });\n    this.picker.endDateChanged.asObservable().subscribe((itemChanged: EndDate) => {\n      this.endDateChanged.emit(itemChanged);\n    });\n    this.picker.rangeClicked.asObservable().subscribe((range: DateRange) => {\n      this.rangeClicked.emit(range);\n    });\n    this.picker.datesUpdated.asObservable().subscribe((range: TimePeriod) => {\n      this.datesUpdated.emit(range);\n    });\n    this.picker.clearClicked.asObservable().subscribe(() => {\n      this.clearClicked.emit();\n    });\n    this.picker.choosedDate.asObservable().subscribe((change: ChosenDate) => {\n      if (change) {\n        const value = {\n          [this.startKeyHolder]: change.startDate,\n          [this.endKeyHolder]: change.endDate\n        };\n        this.value = value as TimePeriod;\n        this.onChange.emit(value as TimePeriod);\n        if (typeof change.chosenLabel === 'string') {\n          this.el.nativeElement.value = change.chosenLabel;\n        }\n      }\n    });\n    this.picker.firstMonthDayClass = this.firstMonthDayClass;\n    this.picker.lastMonthDayClass = this.lastMonthDayClass;\n    this.picker.emptyWeekRowClass = this.emptyWeekRowClass;\n    this.picker.emptyWeekColumnClass = this.emptyWeekColumnClass;\n    this.picker.firstDayOfNextMonthClass = this.firstDayOfNextMonthClass;\n    this.picker.lastDayOfPreviousMonthClass = this.lastDayOfPreviousMonthClass;\n    this.picker.drops = this.drops;\n    this.picker.opens = this.opens;\n    this.localeDiffer = this.differs.find(this.locale).create();\n    this.picker.closeOnAutoApply = this.closeOnAutoApply;\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(changes: SimpleChanges): void {\n    for (const change in changes) {\n      if (Object.prototype.hasOwnProperty.call(changes, change)) {\n        if (this.notForChangesProperty.indexOf(change) === -1) {\n          this.picker[change] = changes[change].currentValue;\n        }\n      }\n    }\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngDoCheck(): void {\n    if (this.localeDiffer) {\n      const changes = this.localeDiffer.diff(this.locale);\n      if (changes) {\n        this.picker.updateLocale(this.locale);\n      }\n    }\n  }\n\n  toggle(e?: Event): void {\n    if (this.picker.isShown) {\n      this.hide(e);\n    } else {\n      this.open(e);\n    }\n  }\n\n  clear(): void {\n    this.picker.clear();\n  }\n\n  writeValue(value: TimePeriod): void {\n    this.setValue(value);\n  }\n\n  registerOnChange(fn: () => TimePeriod | null): void {\n    this.onChangeFn = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(state: boolean): void {\n    this.disabledHolder = state;\n  }\n\n  /**\n   * Set position of the calendar\n   */\n  setPosition(): void {\n    let style;\n    let containerTop;\n    const container = this.picker.pickerContainer.nativeElement;\n    const element = this.el.nativeElement;\n    if (this.drops && this.drops === 'up') {\n      containerTop = element.offsetTop - container.clientHeight + 'px';\n    } else {\n      containerTop = 'auto';\n    }\n    if (this.opens === 'left') {\n      style = {\n        top: containerTop,\n        left: element.offsetLeft - container.clientWidth + element.clientWidth + 'px',\n        right: 'auto'\n      };\n    } else if (this.opens === 'center') {\n      style = {\n        top: containerTop,\n        left: element.offsetLeft + element.clientWidth / 2 - container.clientWidth / 2 + 'px',\n        right: 'auto'\n      };\n    } else if (this.opens === 'right') {\n      style = {\n        top: containerTop,\n        left: element.offsetLeft + 'px',\n        right: 'auto'\n      };\n    } else {\n      const position = element.offsetLeft + element.clientWidth / 2 - container.clientWidth / 2;\n      if (position < 0) {\n        style = {\n          top: containerTop,\n          left: element.offsetLeft + 'px',\n          right: 'auto'\n        };\n      } else {\n        style = {\n          top: containerTop,\n          left: position + 'px',\n          right: 'auto'\n        };\n      }\n    }\n    if (style) {\n      this.renderer.setStyle(container, 'top', style.top);\n      this.renderer.setStyle(container, 'left', style.left);\n      this.renderer.setStyle(container, 'right', style.right);\n    }\n  }\n\n  private setValue(val: TimePeriod) {\n    if (val) {\n      this.value = val;\n      if (val[this.startKeyHolder]) {\n        this.picker.setStartDate(val[this.startKeyHolder]);\n      }\n      if (val[this.endKeyHolder]) {\n        this.picker.setEndDate(val[this.endKeyHolder]);\n      }\n      this.picker.calculateChosenLabel();\n      if (this.picker.chosenLabel) {\n        this.el.nativeElement.value = this.picker.chosenLabel;\n      }\n    } else {\n      this.picker.clear();\n    }\n  }\n}\n"]}