ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
231 lines • 16.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: nz-slider-handle.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
/**
* @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 { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, ViewChild, ViewEncapsulation } from '@angular/core';
import { Subscription } from 'rxjs';
import { InputBoolean } from 'ng-zorro-antd/core';
import { NzTooltipDirective } from 'ng-zorro-antd/tooltip';
import { NzSliderComponent } from './nz-slider.component';
var NzSliderHandleComponent = /** @class */ (function () {
function NzSliderHandleComponent(sliderComponent, cdr) {
var _this = this;
this.sliderComponent = sliderComponent;
this.cdr = cdr;
this.nzTooltipVisible = 'default';
this.nzActive = false;
this.style = {};
this.hovers_ = new Subscription();
this.enterHandle = (/**
* @return {?}
*/
function () {
if (!_this.sliderComponent.isDragging) {
_this.toggleTooltip(true);
_this.updateTooltipPosition();
_this.cdr.detectChanges();
}
});
this.leaveHandle = (/**
* @return {?}
*/
function () {
if (!_this.sliderComponent.isDragging) {
_this.toggleTooltip(false);
_this.cdr.detectChanges();
}
});
}
/**
* @param {?} changes
* @return {?}
*/
NzSliderHandleComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var _this = this;
var nzOffset = changes.nzOffset, nzValue = changes.nzValue, nzActive = changes.nzActive, nzTooltipVisible = changes.nzTooltipVisible;
if (nzOffset) {
this.updateStyle();
}
if (nzValue) {
this.updateTooltipTitle();
this.updateTooltipPosition();
}
if (nzActive) {
if (nzActive.currentValue) {
this.toggleTooltip(true);
}
else {
this.toggleTooltip(false);
}
}
if (nzTooltipVisible && nzTooltipVisible.currentValue === 'always') {
Promise.resolve().then((/**
* @return {?}
*/
function () { return _this.toggleTooltip(true, true); }));
}
};
/**
* @return {?}
*/
NzSliderHandleComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.hovers_.unsubscribe();
};
/**
* @private
* @param {?} show
* @param {?=} force
* @return {?}
*/
NzSliderHandleComponent.prototype.toggleTooltip = /**
* @private
* @param {?} show
* @param {?=} force
* @return {?}
*/
function (show, force) {
if (force === void 0) { force = false; }
if (!force && (this.nzTooltipVisible !== 'default' || !this.tooltip)) {
return;
}
if (show) {
this.tooltip.show();
}
else {
this.tooltip.hide();
}
};
/**
* @private
* @return {?}
*/
NzSliderHandleComponent.prototype.updateTooltipTitle = /**
* @private
* @return {?}
*/
function () {
this.tooltipTitle = this.nzTipFormatter ? this.nzTipFormatter(this.nzValue) : "" + this.nzValue;
};
/**
* @private
* @return {?}
*/
NzSliderHandleComponent.prototype.updateTooltipPosition = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (this.tooltip) {
Promise.resolve().then((/**
* @return {?}
*/
function () { return _this.tooltip.updatePosition(); }));
}
};
/**
* @private
* @return {?}
*/
NzSliderHandleComponent.prototype.updateStyle = /**
* @private
* @return {?}
*/
function () {
this.style[this.nzVertical ? 'bottom' : 'left'] = this.nzOffset + "%";
this.cdr.markForCheck();
};
NzSliderHandleComponent.decorators = [
{ type: Component, args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
selector: 'nz-slider-handle',
exportAs: 'nzSliderHandle',
preserveWhitespaces: false,
template: "<div nz-tooltip\n *ngIf=\"nzTipFormatter !== null && nzTooltipVisible !== 'never'\"\n class=\"ant-slider-handle\"\n [ngStyle]=\"style\"\n [nzTitle]=\"tooltipTitle\"\n [nzTrigger]=\"null\"\n [nzPlacement]=\"nzTooltipPlacement\"></div>\n<div *ngIf=\"nzTipFormatter === null || nzTooltipVisible === 'never'\"\n class=\"ant-slider-handle\"\n [ngStyle]=\"style\"></div>\n",
host: {
'(mouseenter)': 'enterHandle()',
'(mouseleave)': 'leaveHandle()'
}
}] }
];
/** @nocollapse */
NzSliderHandleComponent.ctorParameters = function () { return [
{ type: NzSliderComponent },
{ type: ChangeDetectorRef }
]; };
NzSliderHandleComponent.propDecorators = {
tooltip: [{ type: ViewChild, args: [NzTooltipDirective, { static: false },] }],
nzVertical: [{ type: Input }],
nzOffset: [{ type: Input }],
nzValue: [{ type: Input }],
nzTooltipVisible: [{ type: Input }],
nzTooltipPlacement: [{ type: Input }],
nzTipFormatter: [{ type: Input }],
nzActive: [{ type: Input }]
};
tslib_1.__decorate([
InputBoolean(),
tslib_1.__metadata("design:type", Object)
], NzSliderHandleComponent.prototype, "nzActive", void 0);
return NzSliderHandleComponent;
}());
export { NzSliderHandleComponent };
if (false) {
/** @type {?} */
NzSliderHandleComponent.prototype.tooltip;
/** @type {?} */
NzSliderHandleComponent.prototype.nzVertical;
/** @type {?} */
NzSliderHandleComponent.prototype.nzOffset;
/** @type {?} */
NzSliderHandleComponent.prototype.nzValue;
/** @type {?} */
NzSliderHandleComponent.prototype.nzTooltipVisible;
/** @type {?} */
NzSliderHandleComponent.prototype.nzTooltipPlacement;
/** @type {?} */
NzSliderHandleComponent.prototype.nzTipFormatter;
/** @type {?} */
NzSliderHandleComponent.prototype.nzActive;
/** @type {?} */
NzSliderHandleComponent.prototype.tooltipTitle;
/** @type {?} */
NzSliderHandleComponent.prototype.style;
/**
* @type {?}
* @private
*/
NzSliderHandleComponent.prototype.hovers_;
/** @type {?} */
NzSliderHandleComponent.prototype.enterHandle;
/** @type {?} */
NzSliderHandleComponent.prototype.leaveHandle;
/**
* @type {?}
* @private
*/
NzSliderHandleComponent.prototype.sliderComponent;
/**
* @type {?}
* @private
*/
NzSliderHandleComponent.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-slider-handle.component.js","sourceRoot":"ng://ng-zorro-antd/slider/","sources":["nz-slider-handle.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 {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { InputBoolean, NgStyleInterface } from 'ng-zorro-antd/core';\nimport { NzTooltipDirective } from 'ng-zorro-antd/tooltip';\n\nimport { SliderShowTooltip } from './nz-slider-definitions';\nimport { NzSliderComponent } from './nz-slider.component';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  selector: 'nz-slider-handle',\n  exportAs: 'nzSliderHandle',\n  preserveWhitespaces: false,\n  templateUrl: './nz-slider-handle.component.html',\n  host: {\n    '(mouseenter)': 'enterHandle()',\n    '(mouseleave)': 'leaveHandle()'\n  }\n})\nexport class NzSliderHandleComponent implements OnChanges, OnDestroy {\n  @ViewChild(NzTooltipDirective, { static: false }) tooltip: NzTooltipDirective;\n\n  @Input() nzVertical: string;\n  @Input() nzOffset: number;\n  @Input() nzValue: number;\n  @Input() nzTooltipVisible: SliderShowTooltip = 'default';\n  @Input() nzTooltipPlacement: string;\n  @Input() nzTipFormatter: (value: number) => string;\n  @Input() @InputBoolean() nzActive = false;\n\n  tooltipTitle: string;\n  style: NgStyleInterface = {};\n\n  private hovers_ = new Subscription();\n\n  constructor(private sliderComponent: NzSliderComponent, private cdr: ChangeDetectorRef) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { nzOffset, nzValue, nzActive, nzTooltipVisible } = changes;\n\n    if (nzOffset) {\n      this.updateStyle();\n    }\n    if (nzValue) {\n      this.updateTooltipTitle();\n      this.updateTooltipPosition();\n    }\n    if (nzActive) {\n      if (nzActive.currentValue) {\n        this.toggleTooltip(true);\n      } else {\n        this.toggleTooltip(false);\n      }\n    }\n    if (nzTooltipVisible && nzTooltipVisible.currentValue === 'always') {\n      Promise.resolve().then(() => this.toggleTooltip(true, true));\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.hovers_.unsubscribe();\n  }\n\n  enterHandle = () => {\n    if (!this.sliderComponent.isDragging) {\n      this.toggleTooltip(true);\n      this.updateTooltipPosition();\n      this.cdr.detectChanges();\n    }\n  };\n\n  leaveHandle = () => {\n    if (!this.sliderComponent.isDragging) {\n      this.toggleTooltip(false);\n      this.cdr.detectChanges();\n    }\n  };\n\n  private toggleTooltip(show: boolean, force: boolean = false): void {\n    if (!force && (this.nzTooltipVisible !== 'default' || !this.tooltip)) {\n      return;\n    }\n\n    if (show) {\n      this.tooltip.show();\n    } else {\n      this.tooltip.hide();\n    }\n  }\n\n  private updateTooltipTitle(): void {\n    this.tooltipTitle = this.nzTipFormatter ? this.nzTipFormatter(this.nzValue) : `${this.nzValue}`;\n  }\n\n  private updateTooltipPosition(): void {\n    if (this.tooltip) {\n      Promise.resolve().then(() => this.tooltip.updatePosition());\n    }\n  }\n\n  private updateStyle(): void {\n    this.style[this.nzVertical ? 'bottom' : 'left'] = `${this.nzOffset}%`;\n    this.cdr.markForCheck();\n  }\n}\n"]}