@doku-dev/doku-fragment
Version:
A new Angular UI library that moving away from Bootstrap and built from scratch.
132 lines • 24.5 kB
JavaScript
import { CommonModule } from '@angular/common';
import { ChangeDetectionStrategy, Component, ContentChild, HostBinding, Input, ViewEncapsulation, } from '@angular/core';
import { BehaviorSubject, Subject, combineLatest, distinctUntilChanged, filter, iif, map, merge, of, skip, startWith, takeUntil, tap, } from 'rxjs';
import { DokuEndDate } from './end-date.directive';
import { DokuStartDate } from './start-date.directive';
import * as i0 from "@angular/core";
export class DokuDateRangePickerInput {
constructor() {
this.class = 'd-date-range-picker-input';
this.destroy$ = new Subject();
this.dateChange$ = new BehaviorSubject({ start: null, end: null });
}
ngOnInit() {
if (this.rangePicker) {
this.rangePicker['dateChangeHandler'] = (value) => this.dateChange$.next(value);
}
}
ngAfterContentInit() {
this.hideInputs();
this.listenToDateChange();
}
ngOnDestroy() {
this.destroy$.next(true);
this.destroy$.complete();
}
hideInputs() {
if (this.startDate) {
this.startDate['elementRef'].nativeElement.style.display = 'none';
}
if (this.endDate) {
this.endDate['elementRef'].nativeElement.style.display = 'none';
}
}
listenToDateChange() {
const startDateControl = this.startDate?.['ngControl']?.control;
const endDateControl = this.endDate?.['ngControl']?.control;
const startDate$ = iif(() => !!startDateControl, startDateControl?.valueChanges.pipe(startWith(this.normalizeDate(startDateControl.getRawValue())), map(this.normalizeDate), distinctUntilChanged(this.distinct)) || of(), of(this.startDate?.['elementRef']).pipe(map((ref) => ref?.nativeElement), map((el) => this.normalizeDate(el.value)), startWith(this.normalizeDate(this.startDate?.['elementRef']?.nativeElement?.target?.value || null))));
const endDate$ = iif(() => !!endDateControl, endDateControl?.valueChanges.pipe(startWith(this.normalizeDate(endDateControl.getRawValue())), map(this.normalizeDate), distinctUntilChanged(this.distinct)) || of(), of(this.endDate?.['elementRef']).pipe(map((ref) => ref?.nativeElement), map((el) => this.normalizeDate(el.value)), startWith(this.normalizeDate(this.endDate?.['elementRef']?.nativeElement?.target?.value || null))));
const dateRange$ = combineLatest([startDate$, endDate$]).pipe(map(([start, end]) => ({ start, end })), distinctUntilChanged(this.distinct), filter((value) => {
// Skip if start date is null but end date is exists.
if (!value.start && !!value.end)
return false;
// Skip when choosing start date but end date value still there.
if (this.dateChange$.value.start && !this.dateChange$.value.end && value.end)
return false;
// Skip when resetting value but end date value still the same.
if (value.start &&
value.end &&
JSON.stringify(value.start) !== JSON.stringify(this.dateChange$.value.start) &&
JSON.stringify(value.end) === JSON.stringify(this.dateChange$.value.end)) {
return false;
}
return true;
}));
merge(this.dateChange$.pipe(skip(1)), dateRange$)
.pipe(
// Set initial value to the date range picker
distinctUntilChanged(this.distinct), tap((value) => {
if (!this.rangePicker)
return;
this.rangePicker['value'] = value;
this.rangePicker['_cdr'].detectChanges();
}), skip(1), takeUntil(this.destroy$))
.subscribe((value) => {
this.emitDateChangeToViewOrControl(value);
if (!this.rangePicker)
return;
this.rangePicker['valueChange'].emit({
start: value.start?.toISOString() || null,
end: value.end?.toISOString() || null,
});
});
}
emitDateChangeToViewOrControl(value) {
const startDate = value?.start?.toISOString() || null;
const endDate = value?.end?.toISOString() || null;
const startDateElement = this.startDate?.['elementRef'].nativeElement;
const endDateElement = this.endDate?.['elementRef'].nativeElement;
if (startDateElement.value !== startDate) {
startDateElement.value = startDate || '';
startDateElement.dispatchEvent(new Event('change'));
}
if (endDateElement.value !== endDate) {
endDateElement.value = endDate || '';
endDateElement.dispatchEvent(new Event('change'));
}
const startDateControl = this.startDate?.['ngControl']?.control;
const endDateControl = this.endDate?.['ngControl']?.control;
if (startDateControl && startDateControl.value !== startDate) {
startDateControl?.setValue(startDate);
}
if (endDateControl && endDateControl.value !== endDate) {
endDateControl?.setValue(endDate);
}
}
normalizeDate(date) {
if (!date)
return null;
if (!(date instanceof Date || typeof date === 'string'))
return null;
return date instanceof Date ? date : new Date(date);
}
distinct(prev, current) {
return JSON.stringify(prev) === JSON.stringify(current);
}
}
DokuDateRangePickerInput.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DokuDateRangePickerInput, deps: [], target: i0.ɵɵFactoryTarget.Component });
DokuDateRangePickerInput.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: DokuDateRangePickerInput, isStandalone: true, selector: "doku-date-range-picker-input", inputs: { rangePicker: "rangePicker" }, host: { properties: { "class": "this.class" } }, queries: [{ propertyName: "startDate", first: true, predicate: DokuStartDate, descendants: true }, { propertyName: "endDate", first: true, predicate: DokuEndDate, descendants: true }], exportAs: ["dokuDateRangePickerInput"], ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DokuDateRangePickerInput, decorators: [{
type: Component,
args: [{
selector: 'doku-date-range-picker-input',
exportAs: 'dokuDateRangePickerInput',
standalone: true,
imports: [CommonModule],
template: `<ng-content></ng-content>`,
encapsulation: ViewEncapsulation.None,
changeDetection: ChangeDetectionStrategy.OnPush,
}]
}], propDecorators: { class: [{
type: HostBinding,
args: ['class']
}], rangePicker: [{
type: Input
}], startDate: [{
type: ContentChild,
args: [DokuStartDate]
}], endDate: [{
type: ContentChild,
args: [DokuEndDate]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker-input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/doku-fragment/src/lib/date-picker/common/date-range-picker-input/date-range-picker-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, NgClass } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  HostBinding,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  BehaviorSubject,\n  Subject,\n  combineLatest,\n  distinctUntilChanged,\n  filter,\n  iif,\n  map,\n  merge,\n  of,\n  skip,\n  startWith,\n  takeUntil,\n  tap,\n} from 'rxjs';\nimport { DateValue } from '../../base/date-picker-base-props.component';\nimport { DokuDateRangePicker } from '../../date-range-picker-float/date-range-picker.component';\nimport { DokuDateRangePickerInline } from '../../date-range-picker-inline/date-range-picker-inline.component';\nimport { DokuEndDate } from './end-date.directive';\nimport { DokuStartDate } from './start-date.directive';\n\n@Component({\n  selector: 'doku-date-range-picker-input',\n  exportAs: 'dokuDateRangePickerInput',\n  standalone: true,\n  imports: [CommonModule],\n  template: `<ng-content></ng-content>`,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DokuDateRangePickerInput implements OnInit, AfterContentInit, OnDestroy {\n  @HostBinding('class')\n  protected readonly class: NgClass['ngClass'] = 'd-date-range-picker-input';\n\n  @Input() rangePicker?: DokuDateRangePicker | DokuDateRangePickerInline;\n\n  @ContentChild(DokuStartDate) startDate?: DokuStartDate;\n  @ContentChild(DokuEndDate) endDate?: DokuEndDate;\n\n  private destroy$ = new Subject();\n\n  private dateChange$ = new BehaviorSubject<DateValue>({ start: null, end: null });\n\n  ngOnInit(): void {\n    if (this.rangePicker) {\n      this.rangePicker['dateChangeHandler'] = (value) => this.dateChange$.next(value);\n    }\n  }\n\n  ngAfterContentInit(): void {\n    this.hideInputs();\n    this.listenToDateChange();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next(true);\n    this.destroy$.complete();\n  }\n\n  private hideInputs() {\n    if (this.startDate) {\n      (this.startDate['elementRef'].nativeElement as HTMLElement).style.display = 'none';\n    }\n    if (this.endDate) {\n      (this.endDate['elementRef'].nativeElement as HTMLElement).style.display = 'none';\n    }\n  }\n\n  private listenToDateChange() {\n    const startDateControl = this.startDate?.['ngControl']?.control;\n    const endDateControl = this.endDate?.['ngControl']?.control;\n\n    const startDate$ = iif(\n      () => !!startDateControl,\n      startDateControl?.valueChanges.pipe(\n        startWith(this.normalizeDate(startDateControl.getRawValue())),\n        map(this.normalizeDate),\n        distinctUntilChanged(this.distinct)\n      ) || of(),\n      of(this.startDate?.['elementRef']).pipe(\n        map((ref) => ref?.nativeElement as HTMLInputElement),\n        map((el) => this.normalizeDate(el.value)),\n        startWith(\n          this.normalizeDate(this.startDate?.['elementRef']?.nativeElement?.target?.value || null)\n        )\n      )\n    );\n\n    const endDate$ = iif(\n      () => !!endDateControl,\n      endDateControl?.valueChanges.pipe(\n        startWith(this.normalizeDate(endDateControl.getRawValue())),\n        map(this.normalizeDate),\n        distinctUntilChanged(this.distinct)\n      ) || of(),\n      of(this.endDate?.['elementRef']).pipe(\n        map((ref) => ref?.nativeElement as HTMLInputElement),\n        map((el) => this.normalizeDate(el.value)),\n        startWith(\n          this.normalizeDate(this.endDate?.['elementRef']?.nativeElement?.target?.value || null)\n        )\n      )\n    );\n\n    const dateRange$ = combineLatest([startDate$, endDate$]).pipe(\n      map(([start, end]) => <DateValue>{ start, end }),\n      distinctUntilChanged(this.distinct),\n      filter((value) => {\n        // Skip if start date is null but end date is exists.\n        if (!value.start && !!value.end) return false;\n        // Skip when choosing start date but end date value still there.\n        if (this.dateChange$.value.start && !this.dateChange$.value.end && value.end) return false;\n        // Skip when resetting value but end date value still the same.\n        if (\n          value.start &&\n          value.end &&\n          JSON.stringify(value.start) !== JSON.stringify(this.dateChange$.value.start) &&\n          JSON.stringify(value.end) === JSON.stringify(this.dateChange$.value.end)\n        ) {\n          return false;\n        }\n\n        return true;\n      })\n    );\n\n    merge(this.dateChange$.pipe(skip(1)), dateRange$)\n      .pipe(\n        // Set initial value to the date range picker\n        distinctUntilChanged(this.distinct),\n        tap((value) => {\n          if (!this.rangePicker) return;\n          this.rangePicker['value'] = value;\n          this.rangePicker['_cdr'].detectChanges();\n        }),\n        skip(1),\n        takeUntil(this.destroy$)\n      )\n      .subscribe((value) => {\n        this.emitDateChangeToViewOrControl(value);\n\n        if (!this.rangePicker) return;\n        this.rangePicker['valueChange'].emit({\n          start: value.start?.toISOString() || null,\n          end: value.end?.toISOString() || null,\n        });\n      });\n  }\n\n  private emitDateChangeToViewOrControl(value: DateValue) {\n    const startDate = value?.start?.toISOString() || null;\n    const endDate = value?.end?.toISOString() || null;\n\n    const startDateElement = this.startDate?.['elementRef'].nativeElement as HTMLInputElement;\n    const endDateElement = this.endDate?.['elementRef'].nativeElement as HTMLInputElement;\n\n    if (startDateElement.value !== startDate) {\n      startDateElement.value = startDate || '';\n      startDateElement.dispatchEvent(new Event('change'));\n    }\n\n    if (endDateElement.value !== endDate) {\n      endDateElement.value = endDate || '';\n      endDateElement.dispatchEvent(new Event('change'));\n    }\n\n    const startDateControl = this.startDate?.['ngControl']?.control;\n    const endDateControl = this.endDate?.['ngControl']?.control;\n\n    if (startDateControl && startDateControl.value !== startDate) {\n      startDateControl?.setValue(startDate);\n    }\n\n    if (endDateControl && endDateControl.value !== endDate) {\n      endDateControl?.setValue(endDate);\n    }\n  }\n\n  private normalizeDate(date?: Date | string | null): Date | null {\n    if (!date) return null;\n    if (!(date instanceof Date || typeof date === 'string')) return null;\n    return date instanceof Date ? date : new Date(date);\n  }\n\n  private distinct<P, C>(prev: P, current: C): boolean {\n    return JSON.stringify(prev) === JSON.stringify(current);\n  }\n}\n"]}