UNPKG

ng-zorro-antd-mobile

Version:

An enterprise-class mobile UI components based on Ant Design and Angular

189 lines 19.7 kB
import { Input, Output, Injector, Directive, forwardRef, EventEmitter, HostListener, ViewContainerRef, ComponentFactoryResolver } from '@angular/core'; import { DatePickerComponent } from './date-picker.component'; import { DatePickerOptions } from './date-picker-options.provider'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import * as i0 from "@angular/core"; import * as i1 from "./date-picker-options.provider"; export class DatePickerDirective { togglePicker() { if (!this.picker) { this.showPicker(); } else { this.hidePicker(); } } constructor(_viewContainerRef, _defaultOptions, _cfr) { this._viewContainerRef = _viewContainerRef; this._defaultOptions = _defaultOptions; this._cfr = _cfr; this._eventListeners = []; this.minuteStep = 1; this.value = new Date(); this.onVisibleChange = new EventEmitter(true); this.onValueChange = new EventEmitter(); this.onOk = new EventEmitter(); this.onDismiss = new EventEmitter(); } showPicker() { if (!this.picker && !this.disabled) { setTimeout(() => { this._eventListeners = []; }); const options = new DatePickerOptions(); Object.assign(options, this._defaultOptions, { hidePicker: (event) => { this.hidePicker(); }, updateNgModel: (value) => { if (this._ngModelOnChange) { this.value = value; this._ngModelOnChange(value); } } }); const optionalParams = [ 'mode', 'minDate', 'maxDate', 'minuteStep', 'value', 'mask', 'title', 'okText', 'dismissText', 'disabled', 'locale', 'appendToBody', 'showErrorToast', 'showErrorToastInterval', 'onOk', 'onDismiss', 'onValueChange' ]; optionalParams.forEach(param => { if (typeof this[param] !== 'undefined') { options[param] = this[param]; } }); const componentFactory = this._cfr.resolveComponentFactory(DatePickerComponent); const childInjector = Injector.create([ { provide: DatePickerOptions, useValue: options } ]); this.picker = this._viewContainerRef.createComponent(componentFactory, this._viewContainerRef.length, childInjector); if (options.appendToBody) { this.appendToBodyElement = document.body.appendChild(this.picker.location.nativeElement); } this.onVisibleChange.emit(true); } } hidePicker() { if (this.appendToBodyElement) { document.body.removeChild(this.appendToBodyElement); this.appendToBodyElement = null; } if (this.picker) { this.picker.destroy(); delete this.picker; this.onVisibleChange.emit(false); this._eventListeners.forEach(fn => fn()); this._eventListeners = []; } } writeValue(value) { this.value = value; } registerOnChange(fn) { this._ngModelOnChange = fn; } registerOnTouched(fn) { this._ngModelOnTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } ngOnInit() { this.onVisibleChange.emit(false); } ngOnChanges(changes) { if (changes.isOpen) { if (changes.isOpen.currentValue === true) { this.showPicker(); } else { this.hidePicker(); } } } ngOnDestroy() { this.hidePicker(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DatePickerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i1.DatePickerOptions }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: DatePickerDirective, selector: "[DatePicker]", inputs: { isOpen: "isOpen", mode: "mode", minDate: "minDate", maxDate: "maxDate", use12Hours: "use12Hours", minuteStep: "minuteStep", value: "value", mask: "mask", title: "title", okText: "okText", dismissText: "dismissText", disabled: "disabled", locale: "locale", appendToBody: "appendToBody", showErrorToast: "showErrorToast", showErrorToastInterval: "showErrorToastInterval" }, outputs: { onVisibleChange: "onVisibleChange", onValueChange: "onValueChange", onOk: "onOk", onDismiss: "onDismiss" }, host: { listeners: { "click": "togglePicker()" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DatePickerDirective), multi: true } ], usesOnChanges: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DatePickerDirective, decorators: [{ type: Directive, args: [{ selector: '[DatePicker]', providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DatePickerDirective), multi: true } ] }] }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i1.DatePickerOptions }, { type: i0.ComponentFactoryResolver }], propDecorators: { isOpen: [{ type: Input }], mode: [{ type: Input }], minDate: [{ type: Input }], maxDate: [{ type: Input }], use12Hours: [{ type: Input }], minuteStep: [{ type: Input }], value: [{ type: Input }], mask: [{ type: Input }], title: [{ type: Input }], okText: [{ type: Input }], dismissText: [{ type: Input }], disabled: [{ type: Input }], locale: [{ type: Input }], appendToBody: [{ type: Input }], showErrorToast: [{ type: Input }], showErrorToastInterval: [{ type: Input }], onVisibleChange: [{ type: Output }], onValueChange: [{ type: Output }], onOk: [{ type: Output }], onDismiss: [{ type: Output }], togglePicker: [{ type: HostListener, args: ['click'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.directive.js","sourceRoot":"","sources":["../../../components/date-picker/date-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  Output,\n  OnInit,\n  Injector,\n  OnChanges,\n  OnDestroy,\n  Directive,\n  forwardRef,\n  EventEmitter,\n  HostListener,\n  ComponentRef,\n  SimpleChanges,\n  ComponentFactory,\n  ViewContainerRef,\n  ComponentFactoryResolver\n} from '@angular/core';\nimport { DatePickerComponent } from './date-picker.component';\nimport { DatePickerOptions } from './date-picker-options.provider';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n@Directive({\n  selector: '[DatePicker]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatePickerDirective),\n      multi: true\n    }\n  ]\n})\nexport class DatePickerDirective implements OnDestroy, OnChanges, OnInit, ControlValueAccessor {\n  picker: ComponentRef<DatePickerComponent>;\n  appendToBodyElement: HTMLElement;\n  private _eventListeners: Array<() => void> = [];\n  private _ngModelOnChange: (value: Date) => {};\n  private _ngModelOnTouched: () => {};\n\n  @Input()\n  isOpen: boolean;\n  @Input()\n  mode: string;\n  @Input()\n  minDate: string;\n  @Input()\n  maxDate: string;\n  @Input()\n  use12Hours: boolean;\n  @Input()\n  minuteStep: number = 1;\n  @Input()\n  value: Date = new Date();\n  @Input()\n  mask: boolean;\n  @Input()\n  title: string;\n  @Input()\n  okText: string;\n  @Input()\n  dismissText: string;\n  @Input()\n  disabled: boolean;\n  @Input()\n  locale: any;\n  @Input()\n  appendToBody: boolean;\n  @Input()\n  showErrorToast: boolean;\n  @Input()\n  showErrorToastInterval: number;\n  @Output()\n  onVisibleChange: EventEmitter<boolean> = new EventEmitter(true);\n  @Output()\n  onValueChange: EventEmitter<any> = new EventEmitter();\n  @Output()\n  onOk: EventEmitter<any> = new EventEmitter();\n  @Output()\n  onDismiss: EventEmitter<any> = new EventEmitter();\n\n  @HostListener('click')\n  togglePicker(): void {\n    if (!this.picker) {\n      this.showPicker();\n    } else {\n      this.hidePicker();\n    }\n  }\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _defaultOptions: DatePickerOptions,\n    private _cfr: ComponentFactoryResolver\n  ) {}\n\n  showPicker(): void {\n    if (!this.picker && !this.disabled) {\n      setTimeout(() => {\n        this._eventListeners = [];\n      });\n\n      const options = new DatePickerOptions();\n      Object.assign(options, this._defaultOptions, {\n        hidePicker: (event): void => {\n          this.hidePicker();\n        },\n        updateNgModel: (value: Date): void => {\n          if (this._ngModelOnChange) {\n            this.value = value;\n            this._ngModelOnChange(value);\n          }\n        }\n      });\n\n      const optionalParams: Array<keyof DatePickerDirective> = [\n        'mode',\n        'minDate',\n        'maxDate',\n        'minuteStep',\n        'value',\n        'mask',\n        'title',\n        'okText',\n        'dismissText',\n        'disabled',\n        'locale',\n        'appendToBody',\n        'showErrorToast',\n        'showErrorToastInterval',\n        'onOk',\n        'onDismiss',\n        'onValueChange'\n      ];\n      optionalParams.forEach(param => {\n        if (typeof this[param] !== 'undefined') {\n          (options as any)[param] = this[param];\n        }\n      });\n      const componentFactory: ComponentFactory<DatePickerComponent> = this._cfr.resolveComponentFactory(\n        DatePickerComponent\n      );\n      const childInjector = Injector.create([\n        {\n          provide: DatePickerOptions,\n          useValue: options\n        }\n      ]);\n      this.picker = this._viewContainerRef.createComponent(\n        componentFactory,\n        this._viewContainerRef.length,\n        childInjector\n      );\n      if (options.appendToBody) {\n        this.appendToBodyElement = document.body.appendChild(this.picker.location.nativeElement);\n      }\n      this.onVisibleChange.emit(true);\n    }\n  }\n\n  hidePicker(): void {\n    if (this.appendToBodyElement) {\n      document.body.removeChild(this.appendToBodyElement);\n      this.appendToBodyElement = null;\n    }\n    if (this.picker) {\n      this.picker.destroy();\n      delete this.picker;\n      this.onVisibleChange.emit(false);\n      this._eventListeners.forEach(fn => fn());\n      this._eventListeners = [];\n    }\n  }\n\n  writeValue(value: Date): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: (_: Date) => {}): void {\n    this._ngModelOnChange = fn;\n  }\n\n  registerOnTouched(fn: () => {}): void {\n    this._ngModelOnTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  ngOnInit(): void {\n    this.onVisibleChange.emit(false);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.isOpen) {\n      if (changes.isOpen.currentValue === true) {\n        this.showPicker();\n      } else {\n        this.hidePicker();\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this.hidePicker();\n  }\n}\n"]}