@doku-dev/doku-fragment
Version:
A new Angular UI library that moving away from Bootstrap and built from scratch.
103 lines • 18.8 kB
JavaScript
import { CommonModule } from '@angular/common';
import { ChangeDetectionStrategy, Component, HostBinding, Inject, LOCALE_ID, Optional, Self, ViewEncapsulation, } from '@angular/core';
import { Subject, delay, distinctUntilChanged, filter, map, skip, startWith, takeUntil, } from 'rxjs';
import { DOKU_FORM_FIELD_ACCESSOR, } from '../../form-field';
import { DokuDatePickerBase } from '../base/date-picker-base.component';
import { DokuDatePickerBasicProps } from '../common/date-picker-basic-props.component';
import * as i0 from "@angular/core";
import * as i1 from "@angular/forms";
export class DokuDatePickerInline extends DokuDatePickerBasicProps {
constructor(cdr, localeId, ngControl) {
super();
this.cdr = cdr;
this.localeId = localeId;
this.ngControl = ngControl;
this.class = 'd-date-picker-inline';
this.destroy$ = new Subject();
this.fieldOptions = { withoutInputStyle: true };
if (this.ngControl) {
this.ngControl.valueAccessor = this;
}
}
ngOnInit() {
this.notifyChange$
.pipe(filter((change) => change === 'value' || change === 'minDate' || change === 'maxDate'), startWith(this.value?.toISOString() || null), map(() => this.value?.toISOString() || null), distinctUntilChanged(), skip(1), takeUntil(this.destroy$))
.subscribe((value) => {
this.valueChange.emit(value);
});
this.valueChange.pipe(distinctUntilChanged(), takeUntil(this.destroy$)).subscribe((value) => {
this.onChange?.(value);
this.onTouched?.();
this.cdr.detectChanges();
});
}
ngAfterViewInit() {
this.ngControl?.statusChanges
?.pipe(startWith(this.ngControl.status), distinctUntilChanged(), delay(0), takeUntil(this.destroy$))
.subscribe(() => {
this.disabled = !!this.ngControl?.disabled;
});
this.ngControl?.statusChanges
?.pipe(distinctUntilChanged(), delay(0), takeUntil(this.destroy$))
.subscribe((status) => {
if (status === 'VALID') {
this.onValidate?.('valid');
}
else if (status === 'INVALID') {
this.onValidate?.('invalid');
}
else {
this.onValidate?.();
}
});
this.notifyChange$
.pipe(filter((change) => change === 'disabled' || change === 'readonly'), startWith({ disabled: this.disabled, readonly: this.readonly }), map(() => ({ disabled: this.disabled, readonly: this.readonly })), distinctUntilChanged((prev, current) => JSON.stringify(prev) === JSON.stringify(current)), delay(0), takeUntil(this.destroy$))
.subscribe(({ disabled, readonly }) => {
this.onDisable?.(disabled);
this.onReadonly?.(readonly);
this.cdr.detectChanges();
});
}
ngOnDestroy() {
this.destroy$.next(true);
this.destroy$.complete();
}
registerOnDisable(fn) {
this.onDisable = fn;
}
registerOnReadonly(fn) {
this.onReadonly = fn;
}
registerOnValidate(fn) {
this.onValidate = fn;
}
writeValue(value) {
this.value = value;
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(isDisabled) {
this.onDisable?.(isDisabled);
}
}
DokuDatePickerInline.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DokuDatePickerInline, deps: [{ token: i0.ChangeDetectorRef }, { token: LOCALE_ID }, { token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
DokuDatePickerInline.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: DokuDatePickerInline, isStandalone: true, selector: "doku-date-picker-inline", host: { properties: { "class": "this.class" } }, providers: [{ provide: DOKU_FORM_FIELD_ACCESSOR, useExisting: DokuDatePickerInline }], exportAs: ["dokuDatePickerInline"], usesInheritance: true, ngImport: i0, template: "<doku-date-picker-base\n [value]=\"value\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n (valueChange)=\"value = $event.start\"\n>\n <ng-content doku-date-picker-footer select=\"[doku-date-picker-footer]\"></ng-content>\n</doku-date-picker-base>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: DokuDatePickerBase, selector: "doku-date-picker-base", exportAs: ["dokuDatePickerBase"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DokuDatePickerInline, decorators: [{
type: Component,
args: [{ selector: 'doku-date-picker-inline', exportAs: 'dokuDatePickerInline', standalone: true, imports: [CommonModule, DokuDatePickerBase], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: DOKU_FORM_FIELD_ACCESSOR, useExisting: DokuDatePickerInline }], template: "<doku-date-picker-base\n [value]=\"value\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n (valueChange)=\"value = $event.start\"\n>\n <ng-content doku-date-picker-footer select=\"[doku-date-picker-footer]\"></ng-content>\n</doku-date-picker-base>\n" }]
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
type: Inject,
args: [LOCALE_ID]
}] }, { type: i1.NgControl, decorators: [{
type: Optional
}, {
type: Self
}] }]; }, propDecorators: { class: [{
type: HostBinding,
args: ['class']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-inline.component.js","sourceRoot":"","sources":["../../../../../../../projects/doku-fragment/src/lib/date-picker/date-picker-inline/date-picker-inline.component.ts","../../../../../../../projects/doku-fragment/src/lib/date-picker/date-picker-inline/date-picker-inline.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, NgClass } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  HostBinding,\n  Inject,\n  LOCALE_ID,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Self,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport {\n  Subject,\n  delay,\n  distinctUntilChanged,\n  filter,\n  map,\n  skip,\n  startWith,\n  takeUntil,\n} from 'rxjs';\nimport {\n  DOKU_FORM_FIELD_ACCESSOR,\n  DokuFormFieldAccessor,\n  DokuFormFieldAccessorValidateValue,\n  DokuFormFieldOptions,\n} from '../../form-field';\nimport { DokuDatePickerBase } from '../base/date-picker-base.component';\nimport { DokuDatePickerBasicProps } from '../common/date-picker-basic-props.component';\n\n@Component({\n  selector: 'doku-date-picker-inline',\n  exportAs: 'dokuDatePickerInline',\n  standalone: true,\n  imports: [CommonModule, DokuDatePickerBase],\n  templateUrl: './date-picker-inline.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [{ provide: DOKU_FORM_FIELD_ACCESSOR, useExisting: DokuDatePickerInline }],\n})\nexport class DokuDatePickerInline\n  extends DokuDatePickerBasicProps\n  implements DokuFormFieldAccessor, ControlValueAccessor, OnInit, AfterViewInit, OnDestroy\n{\n  @HostBinding('class')\n  protected readonly class: NgClass['ngClass'] = 'd-date-picker-inline';\n\n  private destroy$ = new Subject();\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    @Inject(LOCALE_ID) protected localeId: string,\n    @Optional() @Self() private ngControl?: NgControl\n  ) {\n    super();\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.notifyChange$\n      .pipe(\n        filter((change) => change === 'value' || change === 'minDate' || change === 'maxDate'),\n        startWith(this.value?.toISOString() || null),\n        map(() => this.value?.toISOString() || null),\n        distinctUntilChanged(),\n        skip(1),\n        takeUntil(this.destroy$)\n      )\n      .subscribe((value) => {\n        this.valueChange.emit(value);\n      });\n\n    this.valueChange.pipe(distinctUntilChanged(), takeUntil(this.destroy$)).subscribe((value) => {\n      this.onChange?.(value);\n      this.onTouched?.();\n      this.cdr.detectChanges();\n    });\n  }\n\n  ngAfterViewInit(): void {\n    this.ngControl?.statusChanges\n      ?.pipe(\n        startWith(this.ngControl.status),\n        distinctUntilChanged(),\n        delay(0),\n        takeUntil(this.destroy$)\n      )\n      .subscribe(() => {\n        this.disabled = !!this.ngControl?.disabled;\n      });\n\n    this.ngControl?.statusChanges\n      ?.pipe(distinctUntilChanged(), delay(0), takeUntil(this.destroy$))\n      .subscribe((status) => {\n        if (status === 'VALID') {\n          this.onValidate?.('valid');\n        } else if (status === 'INVALID') {\n          this.onValidate?.('invalid');\n        } else {\n          this.onValidate?.();\n        }\n      });\n\n    this.notifyChange$\n      .pipe(\n        filter((change) => change === 'disabled' || change === 'readonly'),\n        startWith({ disabled: this.disabled, readonly: this.readonly }),\n        map(() => ({ disabled: this.disabled, readonly: this.readonly })),\n        distinctUntilChanged((prev, current) => JSON.stringify(prev) === JSON.stringify(current)),\n        delay(0),\n        takeUntil(this.destroy$)\n      )\n      .subscribe(({ disabled, readonly }) => {\n        this.onDisable?.(disabled);\n        this.onReadonly?.(readonly);\n        this.cdr.detectChanges();\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next(true);\n    this.destroy$.complete();\n  }\n\n  fieldOptions?: DokuFormFieldOptions | undefined = { withoutInputStyle: true };\n  onDisable?: ((value: boolean) => void) | undefined;\n  onReadonly?: ((value: boolean) => void) | undefined;\n  onValidate?: ((value?: DokuFormFieldAccessorValidateValue | undefined) => void) | undefined;\n  registerOnDisable(fn: (value: boolean) => void): void {\n    this.onDisable = fn;\n  }\n  registerOnReadonly(fn: (value: boolean) => void): void {\n    this.onReadonly = fn;\n  }\n  registerOnValidate?(fn: (value?: DokuFormFieldAccessorValidateValue | undefined) => void): void {\n    this.onValidate = fn;\n  }\n\n  onChange?: (value: unknown) => void;\n  onTouched?: () => void;\n  writeValue(value?: Date | string | null): void {\n    this.value = value;\n  }\n  registerOnChange(fn: (value: unknown) => void): void {\n    this.onChange = fn;\n  }\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n  setDisabledState?(isDisabled: boolean): void {\n    this.onDisable?.(isDisabled);\n  }\n}\n","<doku-date-picker-base\n  [value]=\"value\"\n  [minDate]=\"minDate\"\n  [maxDate]=\"maxDate\"\n  [disabled]=\"disabled\"\n  [readonly]=\"readonly\"\n  (valueChange)=\"value = $event.start\"\n>\n  <ng-content doku-date-picker-footer select=\"[doku-date-picker-footer]\"></ng-content>\n</doku-date-picker-base>\n"]}