UNPKG

ng-zorro-antd-mobile

Version:

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

372 lines 30.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ 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 * as Positioning from '../core/util/position'; var PopoverDirective = /** @class */ (function () { function PopoverDirective(_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(); } /** * @return {?} */ PopoverDirective.prototype.togglePopover = /** * @return {?} */ function () { if (!this.popover) { this.showPopover(); } else { this.hidePopover(); } }; /** * @param {?} placement * @return {?} */ PopoverDirective.prototype.positionMap = /** * @param {?} placement * @return {?} */ function (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; } }; /** * @return {?} */ PopoverDirective.prototype.ngOnInit = /** * @return {?} */ function () { }; /** * @param {?} changes * @return {?} */ PopoverDirective.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { var _this = this; if (changes.visible && changes.visible.currentValue) { setTimeout((/** * @return {?} */ function () { _this.showPopover(); }), 0); } else { setTimeout((/** * @return {?} */ function () { _this.hidePopover(); }), 0); } }; /** * @return {?} */ PopoverDirective.prototype.ngOnDestroy = /** * @return {?} */ function () { this.hidePopover(); }; /** * @private * @param {?} event * @return {?} */ PopoverDirective.prototype.onDocumentClick = /** * @private * @param {?} event * @return {?} */ function (event) { if (this.popover && !this._elm.nativeElement.contains(event.target) && !this.popover.location.nativeElement.contains(event.target)) { this.hidePopover(); } }; /** * @private * @return {?} */ PopoverDirective.prototype.showPopover = /** * @private * @return {?} */ function () { var _this = this; if (!this.popover) { setTimeout((/** * @return {?} */ function () { _this._eventListeners = [ _this._renderer.listen('document', 'click', (/** * @param {?} event * @return {?} */ function (event) { return _this.onDocumentClick(event); })), _this._renderer.listen('document', 'touchend', (/** * @param {?} event * @return {?} */ function (event) { return _this.onDocumentClick(event); })), _this._renderer.listen('window', 'resize', (/** * @return {?} */ function () { return _this.positionPopover(); })) ]; })); /** @type {?} */ var options_1 = new PopoverComponentOptions(); options_1.placement = this.placement; Object.assign(options_1, this._defaultOptions, { hidePopover: (/** * @param {?} event * @return {?} */ function (event) { _this.hidePopover(); }), onAfterViewInit: (/** * @return {?} */ function () { _this.positionPopover(); /** @type {?} */ var children = document.getElementsByClassName('am-popover-inner-wrapper')[0].children; if (children.length > 0) { var _loop_1 = function (i) { children[i].id = "" + i; children[i].addEventListener('click', (/** * @return {?} */ function () { if (_this.onSelect) { _this.onSelect.emit(children[i]); if (options_1.autoClose) { _this.hidePopover(); } } }), false); }; // 首先我们检查它是否包含子节点 for (var i = 0; i < children.length; i++) { _loop_1(i); } } }) }); /** @type {?} */ var optionalParams = [ 'mask', 'showArrow', 'placement', 'appendToBody', 'overlay', 'className', 'autoClose' ]; optionalParams.forEach((/** * @param {?} param * @return {?} */ function (param) { if (typeof _this[param] !== 'undefined') { ((/** @type {?} */ (options_1)))[param] = _this[param]; } })); /** @type {?} */ var componentFactory = this._cfr.resolveComponentFactory(PopoverComponent); /** @type {?} */ var childInjector = Injector.create([ { provide: PopoverComponentOptions, useValue: options_1 } ], this._viewContainerRef.parentInjector); this.popover = this._viewContainerRef.createComponent(componentFactory, this._viewContainerRef.length, childInjector); if (options_1.appendToBody) { document.body.appendChild(this.popover.location.nativeElement); } this.onVisibleChange.emit(true); } }; /** * @private * @return {?} */ PopoverDirective.prototype.positionPopover = /** * @private * @return {?} */ function () { if (this.popover) { /** @type {?} */ var popoverElement = this.popover.location.nativeElement.children[1]; /** @type {?} */ var popoverPosition = Positioning.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"); } } }; /** * @private * @return {?} */ PopoverDirective.prototype.hidePopover = /** * @private * @return {?} */ function () { if (this.popover) { this.popover.destroy(); delete this.popover; this.onVisibleChange.emit(false); this._eventListeners.forEach((/** * @param {?} fn * @return {?} */ function (fn) { return fn(); })); this._eventListeners = []; } }; PopoverDirective.decorators = [ { type: Directive, args: [{ selector: '[Popover], [nzm-popover]', providers: [PopoverOptions] },] } ]; /** @nocollapse */ PopoverDirective.ctorParameters = function () { return [ { type: ViewContainerRef }, { type: ElementRef }, { type: PopoverOptions }, { type: ComponentFactoryResolver }, { type: Renderer2 } ]; }; PopoverDirective.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',] }] }; return PopoverDirective; }()); export { PopoverDirective }; if (false) { /** @type {?} */ PopoverDirective.prototype.popover; /** * @type {?} * @private */ PopoverDirective.prototype._eventListeners; /** @type {?} */ PopoverDirective.prototype.mask; /** @type {?} */ PopoverDirective.prototype.showArrow; /** @type {?} */ PopoverDirective.prototype.visible; /** @type {?} */ PopoverDirective.prototype.placement; /** @type {?} */ PopoverDirective.prototype.overlay; /** @type {?} */ PopoverDirective.prototype.onVisibleChange; /** @type {?} */ PopoverDirective.prototype.onSelect; /** @type {?} */ PopoverDirective.prototype.appendToBody; /** @type {?} */ PopoverDirective.prototype.className; /** @type {?} */ PopoverDirective.prototype.autoClose; /** * @type {?} * @private */ PopoverDirective.prototype._viewContainerRef; /** * @type {?} * @private */ PopoverDirective.prototype._elm; /** * @type {?} * @private */ PopoverDirective.prototype._defaultOptions; /** * @type {?} * @private */ PopoverDirective.prototype._cfr; /** * @type {?} * @private */ PopoverDirective.prototype._renderer; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.directive.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["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 * as Positioning from '../core/util/position';\n\n@Directive({\n  selector: '[Popover], [nzm-popover]',\n  providers: [PopoverOptions]\n})\nexport class PopoverDirective implements OnInit, OnChanges, OnDestroy {\n  popover: ComponentRef<PopoverComponent>;\n\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        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 = Positioning.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.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"]}