ng-zorro-antd-yj
Version:
An enterprise-class UI components based on Ant Design and Angular
369 lines • 29.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { ComponentFactoryResolver, Directive, ElementRef, EventEmitter, Host, Input, Optional, Output, Renderer2, ViewContainerRef } from '@angular/core';
import { Subscription } from 'rxjs';
import { distinctUntilChanged } from 'rxjs/operators';
import { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';
import { isNotNil } from '../core/util/check';
import { NzToolTipComponent } from './nz-tooltip.component';
var NzTooltipDirective = /** @class */ (function () {
function NzTooltipDirective(elementRef, hostView, resolver, renderer, tooltip, noAnimation) {
this.elementRef = elementRef;
this.hostView = hostView;
this.resolver = resolver;
this.renderer = renderer;
this.tooltip = tooltip;
this.noAnimation = noAnimation;
// [NOTE] Here hard coded, and nzTitle used only under NzTooltipDirective currently.
this.isTooltipOpen = false;
this.isDynamicTooltip = false; // Indicate whether current tooltip is dynamic created
this.factory = this.resolver.resolveComponentFactory(NzToolTipComponent);
/**
* Names of properties that should be proxy to child component.
*/
this.needProxyProperties = [
'nzTitle',
'nzContent',
'nzOverlayClassName',
'nzOverlayStyle',
'nzMouseEnterDelay',
'nzMouseLeaveDelay',
'nzVisible',
'nzTrigger',
'nzPlacement'
];
this.subs_ = new Subscription();
this.nzVisibleChange = new EventEmitter();
}
Object.defineProperty(NzTooltipDirective.prototype, "setTitle", {
set: /**
* @param {?} title
* @return {?}
*/
function (title) {
this.nzTitle = title;
},
enumerable: true,
configurable: true
});
/**
* @param {?} changes
* @return {?}
*/
NzTooltipDirective.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
this.updateProxies(changes);
};
/**
* @return {?}
*/
NzTooltipDirective.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
// Support faster tooltip mode: <a nz-tooltip="xxx"></a>. [NOTE] Used only under NzTooltipDirective currently.
if (!this.tooltip) {
/** @type {?} */
var tooltipComponent = this.hostView.createComponent(this.factory);
this.tooltip = tooltipComponent.instance;
this.tooltip.noAnimation = this.noAnimation;
// Remove element when use directive https://github.com/NG-ZORRO/ng-zorro-antd/issues/1967
this.renderer.removeChild(this.renderer.parentNode(this.elementRef.nativeElement), tooltipComponent.location.nativeElement);
this.isDynamicTooltip = true;
this.needProxyProperties.forEach((/**
* @param {?} property
* @return {?}
*/
function (property) { return _this.updateCompValue(property, _this[property]); }));
/** @type {?} */
var visible_ = this.tooltip.nzVisibleChange.pipe(distinctUntilChanged()).subscribe((/**
* @param {?} data
* @return {?}
*/
function (data) {
_this.visible = data;
_this.nzVisibleChange.emit(data);
}));
this.subs_.add(visible_);
}
this.tooltip.setOverlayOrigin(this);
};
/**
* @return {?}
*/
NzTooltipDirective.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
var _this = this;
if (this.tooltip.nzTrigger === 'hover') {
/** @type {?} */
var overlayElement_1;
this.renderer.listen(this.elementRef.nativeElement, 'mouseenter', (/**
* @return {?}
*/
function () {
return _this.delayEnterLeave(true, true, _this.tooltip.nzMouseEnterDelay);
}));
this.renderer.listen(this.elementRef.nativeElement, 'mouseleave', (/**
* @return {?}
*/
function () {
_this.delayEnterLeave(true, false, _this.tooltip.nzMouseLeaveDelay);
if (_this.tooltip.overlay.overlayRef && !overlayElement_1) {
// NOTE: we bind events under "mouseleave" due to the overlayRef is only created after the overlay was completely shown up
overlayElement_1 = _this.tooltip.overlay.overlayRef.overlayElement;
_this.renderer.listen(overlayElement_1, 'mouseenter', (/**
* @return {?}
*/
function () { return _this.delayEnterLeave(false, true); }));
_this.renderer.listen(overlayElement_1, 'mouseleave', (/**
* @return {?}
*/
function () { return _this.delayEnterLeave(false, false); }));
}
}));
}
else if (this.tooltip.nzTrigger === 'focus') {
this.renderer.listen(this.elementRef.nativeElement, 'focus', (/**
* @return {?}
*/
function () { return _this.show(); }));
this.renderer.listen(this.elementRef.nativeElement, 'blur', (/**
* @return {?}
*/
function () { return _this.hide(); }));
}
else if (this.tooltip.nzTrigger === 'click') {
this.renderer.listen(this.elementRef.nativeElement, 'click', (/**
* @param {?} e
* @return {?}
*/
function (e) {
e.preventDefault();
_this.show();
}));
}
};
/**
* @return {?}
*/
NzTooltipDirective.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.subs_.unsubscribe();
};
// tslint:disable-next-line:no-any
// tslint:disable-next-line:no-any
/**
* @protected
* @param {?} key
* @param {?} value
* @return {?}
*/
NzTooltipDirective.prototype.updateCompValue =
// tslint:disable-next-line:no-any
/**
* @protected
* @param {?} key
* @param {?} value
* @return {?}
*/
function (key, value) {
if (this.isDynamicTooltip && isNotNil(value)) {
this.tooltip[key] = value;
}
};
/**
* @private
* @return {?}
*/
NzTooltipDirective.prototype.show = /**
* @private
* @return {?}
*/
function () {
this.tooltip.show();
this.isTooltipOpen = true;
};
/**
* @private
* @return {?}
*/
NzTooltipDirective.prototype.hide = /**
* @private
* @return {?}
*/
function () {
this.tooltip.hide();
this.isTooltipOpen = false;
};
/**
* @private
* @param {?} isOrigin
* @param {?} isEnter
* @param {?=} delay
* @return {?}
*/
NzTooltipDirective.prototype.delayEnterLeave = /**
* @private
* @param {?} isOrigin
* @param {?} isEnter
* @param {?=} delay
* @return {?}
*/
function (isOrigin, isEnter, delay) {
var _this = this;
if (delay === void 0) { delay = -1; }
if (this.delayTimer) {
// Clear timer during the delay time
clearTimeout(this.delayTimer);
this.delayTimer = null;
}
else if (delay > 0) {
this.delayTimer = setTimeout((/**
* @return {?}
*/
function () {
_this.delayTimer = null;
isEnter ? _this.show() : _this.hide();
}), delay * 1000);
}
else {
isEnter && isOrigin ? this.show() : this.hide(); // [Compatible] The "isOrigin" is used due to the tooltip will not hide immediately (may caused by the fade-out animation)
}
};
/**
* Set inputs of child components when this component's inputs change.
* @param changes
*/
/**
* Set inputs of child components when this component's inputs change.
* @private
* @param {?} changes
* @return {?}
*/
NzTooltipDirective.prototype.updateProxies = /**
* Set inputs of child components when this component's inputs change.
* @private
* @param {?} changes
* @return {?}
*/
function (changes) {
var _this = this;
if (this.tooltip) {
Object.keys(changes).forEach((/**
* @param {?} key
* @return {?}
*/
function (key) {
/** @type {?} */
var change = changes[key];
if (change) {
_this.updateCompValue(key, change.currentValue);
}
}));
if (changes.setTitle) {
this.nzTitle = changes.setTitle.currentValue;
this.updateCompValue('nzTitle', changes.setTitle.currentValue);
}
this.tooltip.cdr.markForCheck(); // Manually trigger change detection of component.
}
};
NzTooltipDirective.decorators = [
{ type: Directive, args: [{
selector: '[nz-tooltip]',
host: {
'[class.ant-tooltip-open]': 'isTooltipOpen'
}
},] }
];
/** @nocollapse */
NzTooltipDirective.ctorParameters = function () { return [
{ type: ElementRef },
{ type: ViewContainerRef },
{ type: ComponentFactoryResolver },
{ type: Renderer2 },
{ type: NzToolTipComponent, decorators: [{ type: Optional }] },
{ type: NzNoAnimationDirective, decorators: [{ type: Host }, { type: Optional }] }
]; };
NzTooltipDirective.propDecorators = {
nzVisibleChange: [{ type: Output }],
nzTitle: [{ type: Input, args: ['nz-tooltip',] }],
setTitle: [{ type: Input, args: ['nzTitle',] }],
nzContent: [{ type: Input }],
nzMouseEnterDelay: [{ type: Input }],
nzMouseLeaveDelay: [{ type: Input }],
nzOverlayClassName: [{ type: Input }],
nzOverlayStyle: [{ type: Input }],
nzTrigger: [{ type: Input }],
nzVisible: [{ type: Input }],
nzPlacement: [{ type: Input }]
};
return NzTooltipDirective;
}());
export { NzTooltipDirective };
if (false) {
/** @type {?} */
NzTooltipDirective.prototype.isTooltipOpen;
/** @type {?} */
NzTooltipDirective.prototype.isDynamicTooltip;
/** @type {?} */
NzTooltipDirective.prototype.delayTimer;
/** @type {?} */
NzTooltipDirective.prototype.visible;
/** @type {?} */
NzTooltipDirective.prototype.factory;
/**
* Names of properties that should be proxy to child component.
* @type {?}
* @protected
*/
NzTooltipDirective.prototype.needProxyProperties;
/**
* @type {?}
* @protected
*/
NzTooltipDirective.prototype.subs_;
/** @type {?} */
NzTooltipDirective.prototype.nzVisibleChange;
/** @type {?} */
NzTooltipDirective.prototype.nzTitle;
/** @type {?} */
NzTooltipDirective.prototype.nzContent;
/** @type {?} */
NzTooltipDirective.prototype.nzMouseEnterDelay;
/** @type {?} */
NzTooltipDirective.prototype.nzMouseLeaveDelay;
/** @type {?} */
NzTooltipDirective.prototype.nzOverlayClassName;
/** @type {?} */
NzTooltipDirective.prototype.nzOverlayStyle;
/** @type {?} */
NzTooltipDirective.prototype.nzTrigger;
/** @type {?} */
NzTooltipDirective.prototype.nzVisible;
/** @type {?} */
NzTooltipDirective.prototype.nzPlacement;
/** @type {?} */
NzTooltipDirective.prototype.elementRef;
/** @type {?} */
NzTooltipDirective.prototype.hostView;
/** @type {?} */
NzTooltipDirective.prototype.resolver;
/** @type {?} */
NzTooltipDirective.prototype.renderer;
/** @type {?} */
NzTooltipDirective.prototype.tooltip;
/** @type {?} */
NzTooltipDirective.prototype.noAnimation;
/* Skipping unhandled member: [property: string]: any;*/
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-tooltip.directive.js","sourceRoot":"ng://ng-zorro-antd-yj/","sources":["tooltip/nz-tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ComponentFactory,\n  ComponentFactoryResolver,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Host,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Renderer2,\n  SimpleChanges,\n  TemplateRef,\n  ViewContainerRef\n} from '@angular/core';\n\nimport { Subscription } from 'rxjs';\nimport { distinctUntilChanged } from 'rxjs/operators';\n\nimport { NzNoAnimationDirective } from '../core/no-animation/nz-no-animation.directive';\nimport { isNotNil } from '../core/util/check';\n\nimport { NzToolTipComponent } from './nz-tooltip.component';\n\n@Directive({\n  selector: '[nz-tooltip]',\n  host: {\n    '[class.ant-tooltip-open]': 'isTooltipOpen'\n  }\n})\nexport class NzTooltipDirective implements AfterViewInit, OnChanges, OnInit, OnDestroy {\n  // [NOTE] Here hard coded, and nzTitle used only under NzTooltipDirective currently.\n  isTooltipOpen: boolean = false;\n  isDynamicTooltip = false; // Indicate whether current tooltip is dynamic created\n  delayTimer: number | null; // Timer for delay enter/leave\n  visible: boolean;\n  factory: ComponentFactory<NzToolTipComponent> = this.resolver.resolveComponentFactory(NzToolTipComponent);\n\n  /** Names of properties that should be proxy to child component. */\n  protected needProxyProperties = [\n    'nzTitle',\n    'nzContent',\n    'nzOverlayClassName',\n    'nzOverlayStyle',\n    'nzMouseEnterDelay',\n    'nzMouseLeaveDelay',\n    'nzVisible',\n    'nzTrigger',\n    'nzPlacement'\n  ];\n\n  protected subs_ = new Subscription();\n\n  @Output() readonly nzVisibleChange = new EventEmitter<boolean>();\n\n  @Input('nz-tooltip') nzTitle: string | TemplateRef<void> | null;\n\n  @Input('nzTitle') set setTitle(title: string | TemplateRef<void> | null) {\n    this.nzTitle = title;\n  }\n\n  @Input() nzContent: string | TemplateRef<void>;\n  @Input() nzMouseEnterDelay: number;\n  @Input() nzMouseLeaveDelay: number;\n  @Input() nzOverlayClassName: string;\n  @Input() nzOverlayStyle: { [key: string]: string };\n  @Input() nzTrigger: string;\n  @Input() nzVisible: boolean;\n  @Input() nzPlacement: string;\n\n  [property: string]: any; // tslint:disable-line:no-any\n\n  constructor(\n    public elementRef: ElementRef,\n    public hostView: ViewContainerRef,\n    public resolver: ComponentFactoryResolver,\n    public renderer: Renderer2,\n    @Optional() public tooltip: NzToolTipComponent,\n    @Host() @Optional() public noAnimation?: NzNoAnimationDirective\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.updateProxies(changes);\n  }\n\n  ngOnInit(): void {\n    // Support faster tooltip mode: <a nz-tooltip=\"xxx\"></a>. [NOTE] Used only under NzTooltipDirective currently.\n    if (!this.tooltip) {\n      const tooltipComponent = this.hostView.createComponent(this.factory);\n      this.tooltip = tooltipComponent.instance;\n      this.tooltip.noAnimation = this.noAnimation;\n      // Remove element when use directive https://github.com/NG-ZORRO/ng-zorro-antd/issues/1967\n      this.renderer.removeChild(\n        this.renderer.parentNode(this.elementRef.nativeElement),\n        tooltipComponent.location.nativeElement\n      );\n      this.isDynamicTooltip = true;\n      this.needProxyProperties.forEach(property => this.updateCompValue(property, this[property]));\n      const visible_ = this.tooltip.nzVisibleChange.pipe(distinctUntilChanged()).subscribe(data => {\n        this.visible = data;\n        this.nzVisibleChange.emit(data);\n      });\n      this.subs_.add(visible_);\n    }\n    this.tooltip.setOverlayOrigin(this);\n  }\n\n  ngAfterViewInit(): void {\n    if (this.tooltip.nzTrigger === 'hover') {\n      let overlayElement: HTMLElement;\n      this.renderer.listen(this.elementRef.nativeElement, 'mouseenter', () =>\n        this.delayEnterLeave(true, true, this.tooltip.nzMouseEnterDelay)\n      );\n      this.renderer.listen(this.elementRef.nativeElement, 'mouseleave', () => {\n        this.delayEnterLeave(true, false, this.tooltip.nzMouseLeaveDelay);\n        if (this.tooltip.overlay.overlayRef && !overlayElement) {\n          // NOTE: we bind events under \"mouseleave\" due to the overlayRef is only created after the overlay was completely shown up\n          overlayElement = this.tooltip.overlay.overlayRef.overlayElement;\n          this.renderer.listen(overlayElement, 'mouseenter', () => this.delayEnterLeave(false, true));\n          this.renderer.listen(overlayElement, 'mouseleave', () => this.delayEnterLeave(false, false));\n        }\n      });\n    } else if (this.tooltip.nzTrigger === 'focus') {\n      this.renderer.listen(this.elementRef.nativeElement, 'focus', () => this.show());\n      this.renderer.listen(this.elementRef.nativeElement, 'blur', () => this.hide());\n    } else if (this.tooltip.nzTrigger === 'click') {\n      this.renderer.listen(this.elementRef.nativeElement, 'click', e => {\n        e.preventDefault();\n        this.show();\n      });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.subs_.unsubscribe();\n  }\n\n  // tslint:disable-next-line:no-any\n  protected updateCompValue(key: string, value: any): void {\n    if (this.isDynamicTooltip && isNotNil(value)) {\n      this.tooltip[key] = value;\n    }\n  }\n\n  private show(): void {\n    this.tooltip.show();\n    this.isTooltipOpen = true;\n  }\n\n  private hide(): void {\n    this.tooltip.hide();\n    this.isTooltipOpen = false;\n  }\n\n  private delayEnterLeave(isOrigin: boolean, isEnter: boolean, delay: number = -1): void {\n    if (this.delayTimer) {\n      // Clear timer during the delay time\n      clearTimeout(this.delayTimer);\n      this.delayTimer = null;\n    } else if (delay > 0) {\n      this.delayTimer = setTimeout(() => {\n        this.delayTimer = null;\n        isEnter ? this.show() : this.hide();\n      }, delay * 1000);\n    } else {\n      isEnter && isOrigin ? this.show() : this.hide(); // [Compatible] The \"isOrigin\" is used due to the tooltip will not hide immediately (may caused by the fade-out animation)\n    }\n  }\n\n  /**\n   * Set inputs of child components when this component's inputs change.\n   * @param changes\n   */\n  private updateProxies(changes: SimpleChanges): void {\n    if (this.tooltip) {\n      Object.keys(changes).forEach(key => {\n        const change = changes[key];\n        if (change) {\n          this.updateCompValue(key, change.currentValue);\n        }\n      });\n\n      if (changes.setTitle) {\n        this.nzTitle = changes.setTitle.currentValue;\n        this.updateCompValue('nzTitle', changes.setTitle.currentValue);\n      }\n\n      this.tooltip.cdr.markForCheck(); // Manually trigger change detection of component.\n    }\n  }\n}\n"]}