ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
205 lines • 27.6 kB
JavaScript
import { Directive, Input, Output, EventEmitter, HostListener, ViewContainerRef, ElementRef, Injector, ComponentFactoryResolver, Renderer2, TemplateRef } from '@angular/core';
import { PopoverComponent } from './popover.component';
import { PopoverOptions } from './popover-options.provider';
import { PopoverComponentOptions } from './popover-component-options.provider';
import { getPositionElements } from 'ng-zorro-antd-mobile/core';
import * as i0 from "@angular/core";
import * as i1 from "./popover-options.provider";
export class PopoverDirective {
togglePopover() {
if (!this.popover) {
this.showPopover();
}
else {
this.hidePopover();
}
}
constructor(_viewContainerRef, _elm, _defaultOptions, _cfr, _renderer) {
this._viewContainerRef = _viewContainerRef;
this._elm = _elm;
this._defaultOptions = _defaultOptions;
this._cfr = _cfr;
this._renderer = _renderer;
this._eventListeners = [];
this.onVisibleChange = new EventEmitter(true);
this.onSelect = new EventEmitter();
}
positionMap(placement) {
switch (placement) {
case 'topLeft':
return 'top-left';
case 'topRight':
return 'top-right';
case 'bottomLeft':
return 'bottom-left';
case 'bottomRight':
return 'bottom-right';
case 'leftTop':
return 'left-top';
case 'leftBottom':
return 'left-bottom';
case 'rightTop':
return 'right-top';
case 'rightBottom':
return 'right-bottom';
case 'fullScreen':
case 'landScape':
return 'bottom';
default:
return placement;
}
}
ngOnInit() { }
ngOnChanges(changes) {
if (changes.visible && changes.visible.currentValue) {
setTimeout(() => {
this.showPopover();
}, 0);
}
else {
setTimeout(() => {
this.hidePopover();
}, 0);
}
}
ngOnDestroy() {
this.hidePopover();
}
onDocumentClick(event) {
if (this.popover &&
!this._elm.nativeElement.contains(event.target) &&
!this.popover.location.nativeElement.contains(event.target)) {
this.hidePopover();
}
}
showPopover() {
if (!this.popover) {
setTimeout(() => {
this._eventListeners = [
this._renderer.listen('document', 'click', (event) => this.onDocumentClick(event)),
this._renderer.listen('document', 'touchend', (event) => this.onDocumentClick(event)),
this._renderer.listen('window', 'resize', () => this.positionPopover())
];
});
const options = new PopoverComponentOptions();
options.placement = this.placement;
Object.assign(options, this._defaultOptions, {
hidePopover: (event) => {
this.hidePopover();
},
onAfterViewInit: () => {
this.positionPopover();
const children = document.getElementsByClassName('am-popover-inner-wrapper')[0].children;
if (children.length > 0) {
// 首先我们检查它是否包含子节点
for (let i = 0; i < children.length; i++) {
children[i].id = `${i}`;
children[i].addEventListener('click', () => {
if (this.onSelect) {
this.onSelect.emit(children[i]);
if (options.autoClose) {
this.hidePopover();
}
}
}, false);
}
}
}
});
const optionalParams = [
'mask',
'showArrow',
'placement',
'appendToBody',
'overlay',
'className',
'autoClose'
];
optionalParams.forEach(param => {
if (typeof this[param] !== 'undefined') {
options[param] = this[param];
}
});
const componentFactory = this._cfr.resolveComponentFactory(PopoverComponent);
const childInjector = Injector.create([
{
provide: PopoverComponentOptions,
useValue: options
}
], this._viewContainerRef.parentInjector);
this.popover = this._viewContainerRef.createComponent(componentFactory, this._viewContainerRef.length, childInjector);
if (options.appendToBody) {
this.appendToBodyElement = document.body.appendChild(this.popover.location.nativeElement);
}
this.onVisibleChange.emit(true);
}
}
positionPopover() {
if (this.popover) {
const popoverElement = this.popover.location.nativeElement.children[1];
const popoverPosition = getPositionElements(this._elm.nativeElement, popoverElement, this.positionMap(this.placement) || this._defaultOptions.placement, this.appendToBody || this._defaultOptions.appendToBody);
if (this.placement === 'landScape') {
this._renderer.setStyle(popoverElement, 'top', `${popoverPosition.top}px`);
this._renderer.setStyle(popoverElement, 'left', `0px`);
this._renderer.setStyle(popoverElement, 'width', `${window.innerWidth}px`);
this._renderer.setStyle(popoverElement, 'max-height', `${window.innerHeight - popoverPosition.height}px`);
}
else if (this.placement === 'fullScreen') {
this._renderer.setStyle(popoverElement, 'top', `${0}px`);
this._renderer.setStyle(popoverElement, 'left', `0px`);
this._renderer.setStyle(popoverElement, 'width', `${window.innerWidth}px`);
this._renderer.setStyle(popoverElement, 'max-height', `${window.innerHeight - popoverPosition.height}px`);
}
else {
this._renderer.setStyle(popoverElement, 'top', `${popoverPosition.top}px`);
this._renderer.setStyle(popoverElement, 'left', `${popoverPosition.left}px`);
}
}
}
hidePopover() {
if (this.appendToBodyElement) {
document.body.removeChild(this.appendToBodyElement);
this.appendToBodyElement = null;
}
if (this.popover) {
this.popover.destroy();
delete this.popover;
this.onVisibleChange.emit(false);
this._eventListeners.forEach(fn => fn());
this._eventListeners = [];
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: PopoverDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ElementRef }, { token: i1.PopoverOptions }, { token: i0.ComponentFactoryResolver }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: PopoverDirective, selector: "[Popover], [nzm-popover]", inputs: { mask: "mask", showArrow: "showArrow", visible: "visible", placement: "placement", overlay: "overlay", appendToBody: "appendToBody", className: "className", autoClose: "autoClose" }, outputs: { onVisibleChange: "onVisibleChange", onSelect: "onSelect" }, host: { listeners: { "click": "togglePopover()" } }, providers: [PopoverOptions], usesOnChanges: true, ngImport: i0 }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: PopoverDirective, decorators: [{
type: Directive,
args: [{
selector: '[Popover], [nzm-popover]',
providers: [PopoverOptions]
}]
}], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ElementRef }, { type: i1.PopoverOptions }, { type: i0.ComponentFactoryResolver }, { type: i0.Renderer2 }], propDecorators: { mask: [{
type: Input
}], showArrow: [{
type: Input
}], visible: [{
type: Input
}], placement: [{
type: Input
}], overlay: [{
type: Input
}], onVisibleChange: [{
type: Output
}], onSelect: [{
type: Output
}], appendToBody: [{
type: Input
}], className: [{
type: Input
}], autoClose: [{
type: Input
}], togglePopover: [{
type: HostListener,
args: ['click']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.directive.js","sourceRoot":"","sources":["../../../components/popover/popover.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  Input,\n  Output,\n  EventEmitter,\n  HostListener,\n  ViewContainerRef,\n  ComponentRef,\n  OnDestroy,\n  ElementRef,\n  OnInit,\n  Injector,\n  ComponentFactoryResolver,\n  Renderer2,\n  TemplateRef,\n  ComponentFactory,\n  OnChanges,\n  SimpleChanges\n} from '@angular/core';\nimport { PopoverComponent } from './popover.component';\nimport { PopoverOptions } from './popover-options.provider';\nimport { PopoverComponentOptions } from './popover-component-options.provider';\nimport { getPositionElements } from 'ng-zorro-antd-mobile/core';\n\n@Directive({\n  selector: '[Popover], [nzm-popover]',\n  providers: [PopoverOptions]\n})\nexport class PopoverDirective implements OnInit, OnChanges, OnDestroy {\n  popover: ComponentRef<PopoverComponent>;\n  appendToBodyElement: HTMLElement;\n  private _eventListeners: Array<() => void> = [];\n\n  @Input()\n  mask: boolean;\n  @Input()\n  showArrow: boolean;\n  @Input()\n  visible: boolean;\n  @Input()\n  placement: string;\n  @Input()\n  overlay: TemplateRef<any>;\n  @Output()\n  onVisibleChange: EventEmitter<boolean> = new EventEmitter(true);\n  @Output()\n  onSelect: EventEmitter<any> = new EventEmitter();\n  @Input()\n  appendToBody: boolean;\n  @Input()\n  className: string;\n  @Input()\n  autoClose: boolean;\n\n  @HostListener('click')\n  togglePopover(): void {\n    if (!this.popover) {\n      this.showPopover();\n    } else {\n      this.hidePopover();\n    }\n  }\n\n  constructor(\n    private _viewContainerRef: ViewContainerRef,\n    private _elm: ElementRef,\n    private _defaultOptions: PopoverOptions,\n    private _cfr: ComponentFactoryResolver,\n    private _renderer: Renderer2\n  ) {}\n\n  positionMap(placement): string {\n    switch (placement) {\n      case 'topLeft':\n        return 'top-left';\n      case 'topRight':\n        return 'top-right';\n      case 'bottomLeft':\n        return 'bottom-left';\n      case 'bottomRight':\n        return 'bottom-right';\n      case 'leftTop':\n        return 'left-top';\n      case 'leftBottom':\n        return 'left-bottom';\n      case 'rightTop':\n        return 'right-top';\n      case 'rightBottom':\n        return 'right-bottom';\n      case 'fullScreen':\n      case 'landScape':\n        return 'bottom';\n      default:\n        return placement;\n    }\n  }\n\n  ngOnInit(): void {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.visible && changes.visible.currentValue) {\n      setTimeout(() => {\n        this.showPopover();\n      }, 0);\n    } else {\n      setTimeout(() => {\n        this.hidePopover();\n      }, 0);\n    }\n  }\n\n  ngOnDestroy() {\n    this.hidePopover();\n  }\n\n  private onDocumentClick(event: Event): void {\n    if (\n      this.popover &&\n      !this._elm.nativeElement.contains(event.target) &&\n      !this.popover.location.nativeElement.contains(event.target)\n    ) {\n      this.hidePopover();\n    }\n  }\n\n  private showPopover(): void {\n    if (!this.popover) {\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          this._renderer.listen('window', 'resize', () => this.positionPopover())\n        ];\n      });\n\n      const options = new PopoverComponentOptions();\n      options.placement = this.placement;\n      Object.assign(options, this._defaultOptions, {\n        hidePopover: (event): void => {\n          this.hidePopover();\n        },\n        onAfterViewInit: (): void => {\n          this.positionPopover();\n          const children = document.getElementsByClassName('am-popover-inner-wrapper')[0].children;\n          if (children.length > 0) {\n            // 首先我们检查它是否包含子节点\n            for (let i = 0; i < children.length; i++) {\n              children[i].id = `${i}`;\n              children[i].addEventListener(\n                'click',\n                () => {\n                  if (this.onSelect) {\n                    this.onSelect.emit(children[i]);\n                    if (options.autoClose) {\n                      this.hidePopover();\n                    }\n                  }\n                },\n                false\n              );\n            }\n          }\n        }\n      });\n\n      const optionalParams: Array<keyof PopoverDirective> = [\n        'mask',\n        'showArrow',\n        'placement',\n        'appendToBody',\n        'overlay',\n        'className',\n        'autoClose'\n      ];\n      optionalParams.forEach(param => {\n        if (typeof this[param] !== 'undefined') {\n          (options as any)[param] = this[param];\n        }\n      });\n\n      const componentFactory: ComponentFactory<PopoverComponent> = this._cfr.resolveComponentFactory(PopoverComponent);\n      const childInjector = Injector.create(\n        [\n          {\n            provide: PopoverComponentOptions,\n            useValue: options\n          }\n        ],\n        this._viewContainerRef.parentInjector\n      );\n      this.popover = this._viewContainerRef.createComponent(\n        componentFactory,\n        this._viewContainerRef.length,\n        childInjector\n      );\n      if (options.appendToBody) {\n        this.appendToBodyElement = document.body.appendChild(this.popover.location.nativeElement);\n      }\n      this.onVisibleChange.emit(true);\n    }\n  }\n\n  private positionPopover(): void {\n    if (this.popover) {\n      const popoverElement = this.popover.location.nativeElement.children[1];\n      const popoverPosition = getPositionElements(\n        this._elm.nativeElement,\n        popoverElement,\n        this.positionMap(this.placement) || this._defaultOptions.placement,\n        this.appendToBody || this._defaultOptions.appendToBody\n      );\n      if (this.placement === 'landScape') {\n        this._renderer.setStyle(popoverElement, 'top', `${popoverPosition.top}px`);\n        this._renderer.setStyle(popoverElement, 'left', `0px`);\n        this._renderer.setStyle(popoverElement, 'width', `${window.innerWidth}px`);\n        this._renderer.setStyle(popoverElement, 'max-height', `${window.innerHeight - popoverPosition.height}px`);\n      } else if (this.placement === 'fullScreen') {\n        this._renderer.setStyle(popoverElement, 'top', `${0}px`);\n        this._renderer.setStyle(popoverElement, 'left', `0px`);\n        this._renderer.setStyle(popoverElement, 'width', `${window.innerWidth}px`);\n        this._renderer.setStyle(popoverElement, 'max-height', `${window.innerHeight - popoverPosition.height}px`);\n      } else {\n        this._renderer.setStyle(popoverElement, 'top', `${popoverPosition.top}px`);\n        this._renderer.setStyle(popoverElement, 'left', `${popoverPosition.left}px`);\n      }\n    }\n  }\n\n  private hidePopover(): void {\n    if (this.appendToBodyElement) {\n      document.body.removeChild(this.appendToBodyElement);\n      this.appendToBodyElement = null;\n    }\n    if (this.popover) {\n      this.popover.destroy();\n      delete this.popover;\n      this.onVisibleChange.emit(false);\n      this._eventListeners.forEach(fn => fn());\n      this._eventListeners = [];\n    }\n  }\n}\n"]}