ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
278 lines • 20.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
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 { zoomBigMotion } from '../core/animation/zoom';
import { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';
import { getPlacementName, DEFAULT_TOOLTIP_POSITIONS, POSITION_MAP } from '../core/overlay/overlay-position';
import { isNotNil } from '../core/util/check';
import { toBoolean } from '../core/util/convert';
var NzToolTipComponent = /** @class */ (function () {
function NzToolTipComponent(cdr, noAnimation) {
this.cdr = cdr;
this.noAnimation = noAnimation;
this._hasBackdrop = false;
this._prefix = 'ant-tooltip-placement';
this._positions = tslib_1.__spread(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();
}
Object.defineProperty(NzToolTipComponent.prototype, "nzVisible", {
get: /**
* @return {?}
*/
function () {
return this.visibleSource.value;
},
set:
// second
/**
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var visible = toBoolean(value);
if (this.visibleSource.value !== visible) {
this.visibleSource.next(visible);
this.nzVisibleChange.emit(visible);
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzToolTipComponent.prototype, "nzTrigger", {
get: /**
* @return {?}
*/
function () {
return this._trigger;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._trigger = value;
this._hasBackdrop = this._trigger === 'click';
},
enumerable: true,
configurable: true
});
Object.defineProperty(NzToolTipComponent.prototype, "nzPlacement", {
get: /**
* @return {?}
*/
function () {
return this._placement;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
if (value !== this._placement) {
this._placement = value;
this._positions = tslib_1.__spread([POSITION_MAP[this.nzPlacement]], this._positions);
}
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
NzToolTipComponent.prototype.ngOnChanges = /**
* @return {?}
*/
function () {
var _this = this;
Promise.resolve().then((/**
* @return {?}
*/
function () {
_this.updatePosition();
}));
};
// Manually force updating current overlay's position
// Manually force updating current overlay's position
/**
* @return {?}
*/
NzToolTipComponent.prototype.updatePosition =
// Manually force updating current overlay's position
/**
* @return {?}
*/
function () {
if (this.overlay && this.overlay.overlayRef) {
this.overlay.overlayRef.updatePosition();
}
};
/**
* @param {?} position
* @return {?}
*/
NzToolTipComponent.prototype.onPositionChange = /**
* @param {?} position
* @return {?}
*/
function (position) {
this.nzPlacement = getPlacementName(position);
this.setClassMap();
this.cdr.detectChanges(); // TODO: performance?
};
/**
* @return {?}
*/
NzToolTipComponent.prototype.show = /**
* @return {?}
*/
function () {
if (!this.isContentEmpty()) {
this.nzVisible = true;
}
};
/**
* @return {?}
*/
NzToolTipComponent.prototype.hide = /**
* @return {?}
*/
function () {
this.nzVisible = false;
};
/**
* @param {?} e
* @return {?}
*/
NzToolTipComponent.prototype._afterVisibilityAnimation = /**
* @param {?} e
* @return {?}
*/
function (e) {
if (e.toState === 'false' && !this.nzVisible) {
this.nzVisibleChange.emit(false);
}
if (e.toState === 'true' && this.nzVisible) {
this.nzVisibleChange.emit(true);
}
};
/**
* @return {?}
*/
NzToolTipComponent.prototype.setClassMap = /**
* @return {?}
*/
function () {
var _a;
this._classMap = (_a = {},
_a[this.nzOverlayClassName] = true,
_a[this._prefix + "-" + this._placement] = true,
_a);
};
/**
* @param {?} origin
* @return {?}
*/
NzToolTipComponent.prototype.setOverlayOrigin = /**
* @param {?} origin
* @return {?}
*/
function (origin) {
this.overlayOrigin = origin;
};
/**
* @protected
* @return {?}
*/
NzToolTipComponent.prototype.isContentEmpty = /**
* @protected
* @return {?}
*/
function () {
return this.nzTitle instanceof TemplateRef ? false : (this.nzTitle === '' || !isNotNil(this.nzTitle));
};
NzToolTipComponent.decorators = [
{ type: Component, args: [{
selector: 'nz-tooltip',
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: ["\n .ant-tooltip {\n position: relative;\n }\n "]
}] }
];
/** @nocollapse */
NzToolTipComponent.ctorParameters = function () { return [
{ 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 }]
};
return NzToolTipComponent;
}());
export { NzToolTipComponent };
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;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-tooltip.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["tooltip/nz-tooltip.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { 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';\nimport { zoomBigMotion } from '../core/animation/zoom';\nimport { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';\nimport { getPlacementName, DEFAULT_TOOLTIP_POSITIONS, POSITION_MAP } from '../core/overlay/overlay-position';\nimport { isNotNil } from '../core/util/check';\nimport { toBoolean } from '../core/util/convert';\n\n@Component({\n  selector           : 'nz-tooltip',\n  changeDetection    : ChangeDetectionStrategy.OnPush,\n  encapsulation      : ViewEncapsulation.None,\n  animations         : [ zoomBigMotion ],\n  templateUrl        : './nz-tooltip.component.html',\n  preserveWhitespaces: false,\n  styles             : [ `\n    .ant-tooltip {\n      position: relative;\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>;\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  constructor(public cdr: ChangeDetectorRef, @Host() @Optional() public noAnimation?: NzNoAnimationDirective) {\n  }\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"]}