UNPKG

ng-zorro-antd

Version:

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

240 lines 19 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Alibaba.com All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { CdkConnectedOverlay } from '@angular/cdk/overlay'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, Host, Input, Optional, Output, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core'; import { BehaviorSubject } from 'rxjs'; import { getPlacementName, isNotNil, toBoolean, zoomBigMotion, DEFAULT_TOOLTIP_POSITIONS, NzNoAnimationDirective, POSITION_MAP } from 'ng-zorro-antd/core'; export class NzToolTipComponent { // tslint:disable-line:no-any /** * @param {?} cdr * @param {?=} noAnimation */ constructor(cdr, noAnimation) { this.cdr = cdr; this.noAnimation = noAnimation; this._hasBackdrop = false; this._prefix = 'ant-tooltip-placement'; this._positions = [...DEFAULT_TOOLTIP_POSITIONS]; this._classMap = {}; this._placement = 'top'; this._trigger = 'hover'; this.visibleSource = new BehaviorSubject(false); this.visible$ = this.visibleSource.asObservable(); this.nzOverlayClassName = ''; this.nzOverlayStyle = {}; this.nzMouseEnterDelay = 0.15; // second // second this.nzMouseLeaveDelay = 0.1; // second this.nzVisibleChange = new EventEmitter(); } // second /** * @param {?} value * @return {?} */ set nzVisible(value) { /** @type {?} */ const visible = toBoolean(value); if (this.visibleSource.value !== visible) { this.visibleSource.next(visible); this.nzVisibleChange.emit(visible); } } /** * @return {?} */ get nzVisible() { return this.visibleSource.value; } /** * @param {?} value * @return {?} */ set nzTrigger(value) { this._trigger = value; this._hasBackdrop = this._trigger === 'click'; } /** * @return {?} */ get nzTrigger() { return this._trigger; } /** * @param {?} value * @return {?} */ set nzPlacement(value) { if (value !== this._placement) { this._placement = value; this._positions = [POSITION_MAP[this.nzPlacement], ...this._positions]; } } /** * @return {?} */ get nzPlacement() { return this._placement; } /** * @return {?} */ ngOnChanges() { Promise.resolve().then((/** * @return {?} */ () => { this.updatePosition(); })); } // Manually force updating current overlay's position /** * @return {?} */ updatePosition() { if (this.overlay && this.overlay.overlayRef) { this.overlay.overlayRef.updatePosition(); } } /** * @param {?} position * @return {?} */ onPositionChange(position) { this.nzPlacement = (/** @type {?} */ (getPlacementName(position))); this.setClassMap(); this.cdr.detectChanges(); // TODO: performance? } /** * @return {?} */ show() { if (!this.isContentEmpty()) { this.nzVisible = true; } } /** * @return {?} */ hide() { this.nzVisible = false; } /** * @param {?} e * @return {?} */ _afterVisibilityAnimation(e) { if (e.toState === 'false' && !this.nzVisible) { this.nzVisibleChange.emit(false); } if (e.toState === 'true' && this.nzVisible) { this.nzVisibleChange.emit(true); } } /** * @return {?} */ setClassMap() { this._classMap = { [this.nzOverlayClassName]: true, [`${this._prefix}-${this._placement}`]: true }; } /** * @param {?} origin * @return {?} */ setOverlayOrigin(origin) { this.overlayOrigin = origin; } /** * @protected * @return {?} */ isContentEmpty() { return this.nzTitle instanceof TemplateRef ? false : this.nzTitle === '' || !isNotNil(this.nzTitle); } } NzToolTipComponent.decorators = [ { type: Component, args: [{ selector: 'nz-tooltip', exportAs: 'nzTooltipComponent', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, animations: [zoomBigMotion], template: "<ng-content></ng-content>\n<ng-template\n #overlay=\"cdkConnectedOverlay\"\n cdkConnectedOverlay\n nzConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"overlayOrigin\"\n [cdkConnectedOverlayOpen]=\"visible$ | async\"\n [cdkConnectedOverlayHasBackdrop]=\"_hasBackdrop\"\n [cdkConnectedOverlayPositions]=\"_positions\"\n (backdropClick)=\"hide()\"\n (detach)=\"hide()\"\n (positionChange)=\"onPositionChange($event)\">\n <div\n class=\"ant-tooltip\"\n [ngClass]=\"_classMap\"\n [ngStyle]=\"nzOverlayStyle\"\n [nzNoAnimation]=\"noAnimation?.nzNoAnimation\"\n [@zoomBigMotion]=\"'active'\"\n (@zoomBigMotion.done)=\"_afterVisibilityAnimation($event)\">\n <div class=\"ant-tooltip-content\">\n <div class=\"ant-tooltip-arrow\"></div>\n <div class=\"ant-tooltip-inner\">\n <ng-container *nzStringTemplateOutlet=\"nzTitle\">{{ nzTitle }}</ng-container>\n </div>\n </div>\n </div>\n</ng-template>", preserveWhitespaces: false, styles: [` .ant-tooltip { position: relative; } `] }] } ]; /** @nocollapse */ NzToolTipComponent.ctorParameters = () => [ { type: ChangeDetectorRef }, { type: NzNoAnimationDirective, decorators: [{ type: Host }, { type: Optional }] } ]; NzToolTipComponent.propDecorators = { overlay: [{ type: ViewChild, args: ['overlay',] }], nzTitle: [{ type: Input }, { type: ContentChild, args: ['nzTemplate',] }], nzOverlayClassName: [{ type: Input }], nzOverlayStyle: [{ type: Input }], nzMouseEnterDelay: [{ type: Input }], nzMouseLeaveDelay: [{ type: Input }], nzVisible: [{ type: Input }], nzTrigger: [{ type: Input }], nzPlacement: [{ type: Input }], nzVisibleChange: [{ type: Output }] }; if (false) { /** @type {?} */ NzToolTipComponent.prototype._hasBackdrop; /** @type {?} */ NzToolTipComponent.prototype._prefix; /** @type {?} */ NzToolTipComponent.prototype._positions; /** @type {?} */ NzToolTipComponent.prototype._classMap; /** @type {?} */ NzToolTipComponent.prototype._placement; /** @type {?} */ NzToolTipComponent.prototype._trigger; /** @type {?} */ NzToolTipComponent.prototype.overlayOrigin; /** @type {?} */ NzToolTipComponent.prototype.visibleSource; /** @type {?} */ NzToolTipComponent.prototype.visible$; /** @type {?} */ NzToolTipComponent.prototype.overlay; /** @type {?} */ NzToolTipComponent.prototype.nzTitle; /** @type {?} */ NzToolTipComponent.prototype.nzOverlayClassName; /** @type {?} */ NzToolTipComponent.prototype.nzOverlayStyle; /** @type {?} */ NzToolTipComponent.prototype.nzMouseEnterDelay; /** @type {?} */ NzToolTipComponent.prototype.nzMouseLeaveDelay; /** @type {?} */ NzToolTipComponent.prototype.nzVisibleChange; /** @type {?} */ NzToolTipComponent.prototype.cdr; /** @type {?} */ NzToolTipComponent.prototype.noAnimation; /* Skipping unhandled member: [property: string]: any;*/ } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-tooltip.component.js","sourceRoot":"ng://ng-zorro-antd/tooltip/","sources":["nz-tooltip.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { AnimationEvent } from '@angular/animations';\nimport {\n  CdkConnectedOverlay,\n  CdkOverlayOrigin,\n  ConnectedOverlayPositionChange,\n  ConnectionPositionPair\n} from '@angular/cdk/overlay';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Host,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { BehaviorSubject, Observable } from 'rxjs';\n\nimport {\n  getPlacementName,\n  isNotNil,\n  toBoolean,\n  zoomBigMotion,\n  DEFAULT_TOOLTIP_POSITIONS,\n  NzNoAnimationDirective,\n  POSITION_MAP\n} from 'ng-zorro-antd/core';\n\n@Component({\n  selector: 'nz-tooltip',\n  exportAs: 'nzTooltipComponent',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  animations: [zoomBigMotion],\n  templateUrl: './nz-tooltip.component.html',\n  preserveWhitespaces: false,\n  styles: [\n    `\n      .ant-tooltip {\n        position: relative;\n      }\n    `\n  ]\n})\nexport class NzToolTipComponent implements OnChanges {\n  _hasBackdrop = false;\n  _prefix = 'ant-tooltip-placement';\n  _positions: ConnectionPositionPair[] = [...DEFAULT_TOOLTIP_POSITIONS];\n  _classMap = {};\n  _placement = 'top';\n  _trigger = 'hover';\n  overlayOrigin: CdkOverlayOrigin;\n  visibleSource = new BehaviorSubject<boolean>(false);\n  visible$: Observable<boolean> = this.visibleSource.asObservable();\n  @ViewChild('overlay') overlay: CdkConnectedOverlay;\n  @Input() @ContentChild('nzTemplate') nzTitle: string | TemplateRef<void> | null;\n  @Input() nzOverlayClassName = '';\n  @Input() nzOverlayStyle: { [key: string]: string } = {};\n  @Input() nzMouseEnterDelay = 0.15; // second\n  @Input() nzMouseLeaveDelay = 0.1; // second\n\n  @Input()\n  set nzVisible(value: boolean) {\n    const visible = toBoolean(value);\n    if (this.visibleSource.value !== visible) {\n      this.visibleSource.next(visible);\n      this.nzVisibleChange.emit(visible);\n    }\n  }\n\n  get nzVisible(): boolean {\n    return this.visibleSource.value;\n  }\n\n  @Input()\n  set nzTrigger(value: string) {\n    this._trigger = value;\n    this._hasBackdrop = this._trigger === 'click';\n  }\n\n  get nzTrigger(): string {\n    return this._trigger;\n  }\n\n  @Input()\n  set nzPlacement(value: string) {\n    if (value !== this._placement) {\n      this._placement = value;\n      this._positions = [POSITION_MAP[this.nzPlacement], ...this._positions];\n    }\n  }\n\n  get nzPlacement(): string {\n    return this._placement;\n  }\n\n  @Output() readonly nzVisibleChange = new EventEmitter<boolean>();\n\n  [property: string]: any; // tslint:disable-line:no-any\n\n  constructor(public cdr: ChangeDetectorRef, @Host() @Optional() public noAnimation?: NzNoAnimationDirective) {}\n\n  ngOnChanges(): void {\n    Promise.resolve().then(() => {\n      this.updatePosition();\n    });\n  }\n\n  // Manually force updating current overlay's position\n  updatePosition(): void {\n    if (this.overlay && this.overlay.overlayRef) {\n      this.overlay.overlayRef.updatePosition();\n    }\n  }\n\n  onPositionChange(position: ConnectedOverlayPositionChange): void {\n    this.nzPlacement = getPlacementName(position)!;\n    this.setClassMap();\n    this.cdr.detectChanges(); // TODO: performance?\n  }\n\n  show(): void {\n    if (!this.isContentEmpty()) {\n      this.nzVisible = true;\n    }\n  }\n\n  hide(): void {\n    this.nzVisible = false;\n  }\n\n  _afterVisibilityAnimation(e: AnimationEvent): void {\n    if (e.toState === 'false' && !this.nzVisible) {\n      this.nzVisibleChange.emit(false);\n    }\n    if (e.toState === 'true' && this.nzVisible) {\n      this.nzVisibleChange.emit(true);\n    }\n  }\n\n  setClassMap(): void {\n    this._classMap = {\n      [this.nzOverlayClassName]: true,\n      [`${this._prefix}-${this._placement}`]: true\n    };\n  }\n\n  setOverlayOrigin(origin: CdkOverlayOrigin): void {\n    this.overlayOrigin = origin;\n  }\n\n  protected isContentEmpty(): boolean {\n    return this.nzTitle instanceof TemplateRef ? false : this.nzTitle === '' || !isNotNil(this.nzTitle);\n  }\n}\n"]}