UNPKG

ng-zorro-antd-mobile

Version:

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

220 lines 25.4 kB
import { Input, Output, NgZone, Injector, Renderer2, Directive, ElementRef, forwardRef, HostListener, EventEmitter, ViewContainerRef, ComponentFactoryResolver } from '@angular/core'; import { PickerComponent } from './picker.component'; import { PickerOptions } from './picker-options.provider'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import * as i0 from "@angular/core"; import * as i1 from "./picker-options.provider"; export class PickerDirective { togglePicker() { if (!this.picker) { this.showPicker(); } else { this.hidePicker(); } } constructor(_viewContainerRef, _elm, _defaultOptions, _cfr, _renderer, _zone) { this._viewContainerRef = _viewContainerRef; this._elm = _elm; this._defaultOptions = _defaultOptions; this._cfr = _cfr; this._renderer = _renderer; this._zone = _zone; this._eventListeners = []; this.onVisibleChange = new EventEmitter(true); this.onPickerChange = new EventEmitter(); this.onDismiss = new EventEmitter(); this.onChange = () => null; this.onTouched = () => null; } ngOnInit() { this.onVisibleChange.emit(false); } ngOnChanges(value) { if (value.cols && this.picker) { this.picker.instance.options.cols = value.cols.currentValue; } if (value.data && this.picker) { if (!this.isPickerDataEqual(this.picker.instance.options.data, value.data.currentValue)) { this.picker.instance.options.data = value.data.currentValue; this.showPicker(); } } } ngOnDestroy() { this.hidePicker(); } onDocumentClick(event) { if (this.picker && !this._elm.nativeElement.contains(event.target) && !this.picker.location.nativeElement.contains(event.target)) { this.hidePicker(); } } showPicker() { if (this.picker) { this._zone.run(() => { this.picker.instance.init(); }); } else if (!this.picker && !this.disabled) { setTimeout(() => { this._eventListeners = [ this._renderer.listen('document', 'click', (event) => this.onDocumentClick(event)), this._renderer.listen('document', 'touchend', (event) => this.onDocumentClick(event)) ]; }); const options = new PickerOptions(); Object.assign(options, this._defaultOptions, { hidePicker: (event) => { this.hidePicker(); }, updateNgModel: (value) => { this.value = value; this.onChange(value); } }); const optionalParams = [ 'data', 'value', 'cols', 'mask', 'title', 'okText', 'dismissText', 'disabled', 'cascade', 'appendToBody', 'indicatorStyle', 'onPickerChange', 'onVisibleChange', 'onDismiss' ]; optionalParams.forEach(param => { if (typeof this[param] !== 'undefined') { options[param] = this[param]; } }); const componentFactory = this._cfr.resolveComponentFactory(PickerComponent); const childInjector = Injector.create([ { provide: PickerOptions, 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 = Array.isArray(value) ? value : []; if (this.picker) { this.picker.instance.options.value = this.value; this.showPicker(); this.picker.instance.reloadPicker(); } } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } isPickerDataEqual(data1, data2) { if (!data1 && !data2) { return true; } if (!Array.isArray(data1) || !Array.isArray(data2) || data1.length !== data2.length) { return false; } for (let i = 0; i < data1.length; i++) { const item1 = data1[i]; const item2 = data2[i]; if ((item1 && !item2) || (!item1 && item2)) { return false; } if (item1.value !== item2.value) { return false; } if (item1.label !== item2.label) { return false; } if (item1.children && item2.children) { return this.isPickerDataEqual(item1.children, item2.children); } } return true; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: PickerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ElementRef }, { token: i1.PickerOptions }, { token: i0.ComponentFactoryResolver }, { token: i0.Renderer2 }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: PickerDirective, selector: "[Picker], [nzm-picker]", inputs: { data: "data", cols: "cols", mask: "mask", title: "title", visible: "visible", okText: "okText", dismissText: "dismissText", disabled: "disabled", cascade: "cascade", appendToBody: "appendToBody", indicatorStyle: "indicatorStyle" }, outputs: { onVisibleChange: "onVisibleChange", onPickerChange: "onPickerChange", onDismiss: "onDismiss" }, host: { listeners: { "click": "togglePicker()" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => PickerDirective), multi: true } ], usesOnChanges: true, ngImport: i0 }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: PickerDirective, decorators: [{ type: Directive, args: [{ selector: '[Picker], [nzm-picker]', providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => PickerDirective), multi: true } ] }] }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ElementRef }, { type: i1.PickerOptions }, { type: i0.ComponentFactoryResolver }, { type: i0.Renderer2 }, { type: i0.NgZone }], propDecorators: { data: [{ type: Input }], cols: [{ type: Input }], mask: [{ type: Input }], title: [{ type: Input }], visible: [{ type: Input }], okText: [{ type: Input }], dismissText: [{ type: Input }], disabled: [{ type: Input }], cascade: [{ type: Input }], appendToBody: [{ type: Input }], indicatorStyle: [{ type: Input }], onVisibleChange: [{ type: Output }], onPickerChange: [{ type: Output }], onDismiss: [{ type: Output }], togglePicker: [{ type: HostListener, args: ['click'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picker.directive.js","sourceRoot":"","sources":["../../../components/picker/picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  Output,\n  OnInit,\n  NgZone,\n  Injector,\n  Renderer2,\n  OnChanges,\n  OnDestroy,\n  Directive,\n  ElementRef,\n  forwardRef,\n  HostListener,\n  EventEmitter,\n  ComponentRef,\n  ViewContainerRef,\n  ComponentFactory,\n  ComponentFactoryResolver\n} from '@angular/core';\nimport { PickerComponent } from './picker.component';\nimport { PickerOptions } from './picker-options.provider';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Directive({\n  selector: '[Picker], [nzm-picker]',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PickerDirective),\n      multi: true\n    }\n  ]\n})\nexport class PickerDirective implements OnDestroy, OnInit, OnChanges, ControlValueAccessor {\n  picker: ComponentRef<PickerComponent>;\n  appendToBodyElement: HTMLElement;\n  value: Array<any>;\n  private _eventListeners: Array<() => void> = [];\n\n  @Input()\n  data: Array<any>;\n  @Input()\n  cols: Number;\n  @Input()\n  mask: boolean;\n  @Input()\n  title: string;\n  @Input()\n  visible: boolean;\n  @Input()\n  okText: string;\n  @Input()\n  dismissText: string;\n  @Input()\n  disabled: boolean;\n  @Input()\n  cascade: boolean;\n  @Input()\n  appendToBody: boolean;\n  @Input()\n  indicatorStyle: object;\n  @Output()\n  onVisibleChange: EventEmitter<boolean> = new EventEmitter(true);\n  @Output()\n  onPickerChange: EventEmitter<any> = new EventEmitter();\n  @Output()\n  onDismiss: EventEmitter<any> = new EventEmitter();\n\n  onChange: (value: any[]) => void = () => null;\n  onTouched: () => void = () => null;\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 _elm: ElementRef,\n    private _defaultOptions: PickerOptions,\n    private _cfr: ComponentFactoryResolver,\n    private _renderer: Renderer2,\n    private _zone: NgZone\n  ) {}\n\n  ngOnInit(): void {\n    this.onVisibleChange.emit(false);\n  }\n\n  ngOnChanges(value) {\n    if (value.cols && this.picker) {\n      this.picker.instance.options.cols = value.cols.currentValue;\n    }\n    if (value.data && this.picker) {\n      if (!this.isPickerDataEqual(this.picker.instance.options.data, value.data.currentValue)) {\n        this.picker.instance.options.data = value.data.currentValue;\n        this.showPicker();\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this.hidePicker();\n  }\n\n  private onDocumentClick(event: Event): void {\n    if (\n      this.picker &&\n      !this._elm.nativeElement.contains(event.target) &&\n      !this.picker.location.nativeElement.contains(event.target)\n    ) {\n      this.hidePicker();\n    }\n  }\n\n  private showPicker(): void {\n    if (this.picker) {\n      this._zone.run(() => {\n        this.picker.instance.init();\n      });\n    } else if (!this.picker && !this.disabled) {\n      setTimeout(() => {\n        this._eventListeners = [\n          this._renderer.listen('document', 'click', (event: Event) => this.onDocumentClick(event)),\n          this._renderer.listen('document', 'touchend', (event: Event) => this.onDocumentClick(event))\n        ];\n      });\n\n      const options = new PickerOptions();\n      Object.assign(options, this._defaultOptions, {\n        hidePicker: (event): void => {\n          this.hidePicker();\n        },\n        updateNgModel: (value: any[]): void => {\n          this.value = value;\n          this.onChange(value);\n        }\n      });\n\n      const optionalParams: Array<keyof PickerDirective> = [\n        'data',\n        'value',\n        'cols',\n        'mask',\n        'title',\n        'okText',\n        'dismissText',\n        'disabled',\n        'cascade',\n        'appendToBody',\n        'indicatorStyle',\n        'onPickerChange',\n        'onVisibleChange',\n        'onDismiss'\n      ];\n      optionalParams.forEach(param => {\n        if (typeof this[param] !== 'undefined') {\n          (options as any)[param] = this[param];\n        }\n      });\n      const componentFactory: ComponentFactory<PickerComponent> = this._cfr.resolveComponentFactory(PickerComponent);\n      const childInjector = Injector.create([\n        {\n          provide: PickerOptions,\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  private 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: any[]): void {\n    this.value = Array.isArray(value) ? value : [];\n    if (this.picker) {\n      this.picker.instance.options.value = this.value;\n      this.showPicker();\n      this.picker.instance.reloadPicker();\n    }\n  }\n\n  registerOnChange(fn: (value: any[]) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  isPickerDataEqual(data1, data2) {\n    if (!data1 && !data2) {\n      return true;\n    }\n    if (!Array.isArray(data1) || !Array.isArray(data2) || data1.length !== data2.length) {\n      return false;\n    }\n    for (let i = 0; i < data1.length; i++) {\n      const item1 = data1[i];\n      const item2 = data2[i];\n      if ((item1 && !item2) || (!item1 && item2)) {\n        return false;\n      }\n      if (item1.value !== item2.value) {\n        return false;\n      }\n      if (item1.label !== item2.label) {\n        return false;\n      }\n      if (item1.children && item2.children) {\n        return this.isPickerDataEqual(item1.children, item2.children);\n      }\n    }\n    return true;\n  }\n}\n"]}