ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
249 lines • 19.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: handle.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __decorate, __metadata } from "tslib";
/**
* 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, ElementRef, Input, ViewChild, ViewEncapsulation } from '@angular/core';
import { InputBoolean } from 'ng-zorro-antd/core/util';
import { NzTooltipDirective } from 'ng-zorro-antd/tooltip';
import { NzSliderService } from './slider.service';
var NzSliderHandleComponent = /** @class */ (function () {
function NzSliderHandleComponent(sliderService, cdr) {
var _this = this;
this.sliderService = sliderService;
this.cdr = cdr;
this.tooltipVisible = 'default';
this.active = false;
this.style = {};
this.enterHandle = (/**
* @return {?}
*/
function () {
if (!_this.sliderService.isDragging) {
_this.toggleTooltip(true);
_this.updateTooltipPosition();
_this.cdr.detectChanges();
}
});
this.leaveHandle = (/**
* @return {?}
*/
function () {
if (!_this.sliderService.isDragging) {
_this.toggleTooltip(false);
_this.cdr.detectChanges();
}
});
}
/**
* @param {?} changes
* @return {?}
*/
NzSliderHandleComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
var _this = this;
var offset = changes.offset, value = changes.value, active = changes.active, tooltipVisible = changes.tooltipVisible, reverse = changes.reverse;
if (offset || reverse) {
this.updateStyle();
}
if (value) {
this.updateTooltipTitle();
this.updateTooltipPosition();
}
if (active) {
if (active.currentValue) {
this.toggleTooltip(true);
}
else {
this.toggleTooltip(false);
}
}
if ((tooltipVisible === null || tooltipVisible === void 0 ? void 0 : tooltipVisible.currentValue) === 'always') {
Promise.resolve().then((/**
* @return {?}
*/
function () { return _this.toggleTooltip(true, true); }));
}
};
/**
* @return {?}
*/
NzSliderHandleComponent.prototype.focus = /**
* @return {?}
*/
function () {
var _a;
(_a = this.handleEl) === null || _a === void 0 ? void 0 : _a.nativeElement.focus();
};
/**
* @private
* @param {?} show
* @param {?=} force
* @return {?}
*/
NzSliderHandleComponent.prototype.toggleTooltip = /**
* @private
* @param {?} show
* @param {?=} force
* @return {?}
*/
function (show, force) {
if (force === void 0) { force = false; }
var _a, _b;
if (!force && (this.tooltipVisible !== 'default' || !this.tooltip)) {
return;
}
if (show) {
(_a = this.tooltip) === null || _a === void 0 ? void 0 : _a.show();
}
else {
(_b = this.tooltip) === null || _b === void 0 ? void 0 : _b.hide();
}
};
/**
* @private
* @return {?}
*/
NzSliderHandleComponent.prototype.updateTooltipTitle = /**
* @private
* @return {?}
*/
function () {
this.tooltipTitle = this.tooltipFormatter ? this.tooltipFormatter((/** @type {?} */ (this.value))) : "" + this.value;
};
/**
* @private
* @return {?}
*/
NzSliderHandleComponent.prototype.updateTooltipPosition = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (this.tooltip) {
Promise.resolve().then((/**
* @return {?}
*/
function () { var _a; return (_a = _this.tooltip) === null || _a === void 0 ? void 0 : _a.updatePosition(); }));
}
};
/**
* @private
* @return {?}
*/
NzSliderHandleComponent.prototype.updateStyle = /**
* @private
* @return {?}
*/
function () {
var _a, _b;
/** @type {?} */
var vertical = this.vertical;
/** @type {?} */
var reverse = this.reverse;
/** @type {?} */
var offset = this.offset;
/** @type {?} */
var positionStyle = vertical
? (_a = {},
_a[reverse ? 'top' : 'bottom'] = offset + "%",
_a[reverse ? 'bottom' : 'top'] = 'auto',
_a.transform = reverse ? null : "translateY(+50%)",
_a) : (_b = {},
_b[reverse ? 'right' : 'left'] = offset + "%",
_b[reverse ? 'left' : 'right'] = 'auto',
_b.transform = "translateX(" + (reverse ? '+' : '-') + "50%)",
_b);
this.style = positionStyle;
this.cdr.markForCheck();
};
NzSliderHandleComponent.decorators = [
{ type: Component, args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None,
selector: 'nz-slider-handle',
exportAs: 'nzSliderHandle',
preserveWhitespaces: false,
template: "\n <div\n #handle\n class=\"ant-slider-handle\"\n tabindex=\"0\"\n nz-tooltip\n [ngStyle]=\"style\"\n [nzTooltipTitle]=\"tooltipFormatter === null || tooltipVisible === 'never' ? null : tooltipTitle\"\n [nzTooltipTrigger]=\"null\"\n [nzTooltipPlacement]=\"tooltipPlacement\"\n ></div>\n ",
host: {
'(mouseenter)': 'enterHandle()',
'(mouseleave)': 'leaveHandle()'
}
}] }
];
/** @nocollapse */
NzSliderHandleComponent.ctorParameters = function () { return [
{ type: NzSliderService },
{ type: ChangeDetectorRef }
]; };
NzSliderHandleComponent.propDecorators = {
handleEl: [{ type: ViewChild, args: ['handle', { static: false },] }],
tooltip: [{ type: ViewChild, args: [NzTooltipDirective, { static: false },] }],
vertical: [{ type: Input }],
reverse: [{ type: Input }],
offset: [{ type: Input }],
value: [{ type: Input }],
tooltipVisible: [{ type: Input }],
tooltipPlacement: [{ type: Input }],
tooltipFormatter: [{ type: Input }],
active: [{ type: Input }]
};
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzSliderHandleComponent.prototype, "active", void 0);
return NzSliderHandleComponent;
}());
export { NzSliderHandleComponent };
if (false) {
/** @type {?} */
NzSliderHandleComponent.ngAcceptInputType_active;
/** @type {?} */
NzSliderHandleComponent.prototype.handleEl;
/** @type {?} */
NzSliderHandleComponent.prototype.tooltip;
/** @type {?} */
NzSliderHandleComponent.prototype.vertical;
/** @type {?} */
NzSliderHandleComponent.prototype.reverse;
/** @type {?} */
NzSliderHandleComponent.prototype.offset;
/** @type {?} */
NzSliderHandleComponent.prototype.value;
/** @type {?} */
NzSliderHandleComponent.prototype.tooltipVisible;
/** @type {?} */
NzSliderHandleComponent.prototype.tooltipPlacement;
/** @type {?} */
NzSliderHandleComponent.prototype.tooltipFormatter;
/** @type {?} */
NzSliderHandleComponent.prototype.active;
/** @type {?} */
NzSliderHandleComponent.prototype.tooltipTitle;
/** @type {?} */
NzSliderHandleComponent.prototype.style;
/** @type {?} */
NzSliderHandleComponent.prototype.enterHandle;
/** @type {?} */
NzSliderHandleComponent.prototype.leaveHandle;
/**
* @type {?}
* @private
*/
NzSliderHandleComponent.prototype.sliderService;
/**
* @type {?}
* @private
*/
NzSliderHandleComponent.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"handle.component.js","sourceRoot":"ng://ng-zorro-antd/slider/","sources":["handle.component.ts"],"names":[],"mappings":";;;;;;;;;;AAKA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,KAAK,EAGL,SAAS,EACT,iBAAiB,EAClB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;AAC3D,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAGnD;IAyCE,iCAAoB,aAA8B,EAAU,GAAsB;QAAlF,iBAAsF;QAAlE,kBAAa,GAAb,aAAa,CAAiB;QAAU,QAAG,GAAH,GAAG,CAAmB;QARzE,mBAAc,GAAwB,SAAS,CAAC;QAGhC,WAAM,GAAG,KAAK,CAAC;QAGxC,UAAK,GAAqB,EAAE,CAAC;QA6B7B,gBAAW;;;QAAG;YACZ,IAAI,CAAC,KAAI,CAAC,aAAa,CAAC,UAAU,EAAE;gBAClC,KAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;gBACzB,KAAI,CAAC,qBAAqB,EAAE,CAAC;gBAC7B,KAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;aAC1B;QACH,CAAC,EAAC;QAEF,gBAAW;;;QAAG;YACZ,IAAI,CAAC,KAAI,CAAC,aAAa,CAAC,UAAU,EAAE;gBAClC,KAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAC1B,KAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;aAC1B;QACH,CAAC,EAAC;IAxCmF,CAAC;;;;;IAEtF,6CAAW;;;;IAAX,UAAY,OAAsB;QAAlC,iBAuBC;QAtBS,IAAA,uBAAM,EAAE,qBAAK,EAAE,uBAAM,EAAE,uCAAc,EAAE,yBAAO;QAEtD,IAAI,MAAM,IAAI,OAAO,EAAE;YACrB,IAAI,CAAC,WAAW,EAAE,CAAC;SACpB;QAED,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;QAED,IAAI,MAAM,EAAE;YACV,IAAI,MAAM,CAAC,YAAY,EAAE;gBACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;aAC1B;iBAAM;gBACL,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;aAC3B;SACF;QAED,IAAI,CAAA,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,YAAY,MAAK,QAAQ,EAAE;YAC7C,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI;;;YAAC,cAAM,OAAA,KAAI,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,EAA9B,CAA8B,EAAC,CAAC;SAC9D;IACH,CAAC;;;;IAiBD,uCAAK;;;IAAL;;QACE,MAAA,IAAI,CAAC,QAAQ,0CAAE,aAAa,CAAC,KAAK,GAAG;IACvC,CAAC;;;;;;;IAEO,+CAAa;;;;;;IAArB,UAAsB,IAAa,EAAE,KAAsB;QAAtB,sBAAA,EAAA,aAAsB;;QACzD,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,cAAc,KAAK,SAAS,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAClE,OAAO;SACR;QAED,IAAI,IAAI,EAAE;YACR,MAAA,IAAI,CAAC,OAAO,0CAAE,IAAI,GAAG;SACtB;aAAM;YACL,MAAA,IAAI,CAAC,OAAO,0CAAE,IAAI,GAAG;SACtB;IACH,CAAC;;;;;IAEO,oDAAkB;;;;IAA1B;QACE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,mBAAA,IAAI,CAAC,KAAK,EAAC,CAAC,CAAC,CAAC,CAAC,KAAG,IAAI,CAAC,KAAO,CAAC;IACnG,CAAC;;;;;IAEO,uDAAqB;;;;IAA7B;QAAA,iBAIC;QAHC,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI;;;YAAC,mCAAM,KAAI,CAAC,OAAO,0CAAE,cAAc,KAAE,EAAC,CAAC;SAC9D;IACH,CAAC;;;;;IAEO,6CAAW;;;;IAAnB;;;YACQ,QAAQ,GAAG,IAAI,CAAC,QAAQ;;YACxB,OAAO,GAAG,IAAI,CAAC,OAAO;;YACtB,MAAM,GAAG,IAAI,CAAC,MAAM;;YAEpB,aAAa,GAAG,QAAQ;YAC5B,CAAC;gBACG,GAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,IAAM,MAAM,MAAG;gBAC1C,GAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,IAAG,MAAM;gBACpC,YAAS,GAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,kBAAkB;oBAElD,CAAC;YACG,GAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,IAAM,MAAM,MAAG;YAC1C,GAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,IAAG,MAAM;YACpC,YAAS,GAAE,iBAAc,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,UAAM;eACnD;QAEL,IAAI,CAAC,KAAK,GAAG,aAAa,CAAC;QAC3B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;;gBAhIF,SAAS,SAAC;oBACT,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,QAAQ,EAAE,kBAAkB;oBAC5B,QAAQ,EAAE,gBAAgB;oBAC1B,mBAAmB,EAAE,KAAK;oBAC1B,QAAQ,EAAE,gVAWT;oBACD,IAAI,EAAE;wBACJ,cAAc,EAAE,eAAe;wBAC/B,cAAc,EAAE,eAAe;qBAChC;iBACF;;;;gBAzBQ,eAAe;gBAbtB,iBAAiB;;;2BA0ChB,SAAS,SAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;0BACrC,SAAS,SAAC,kBAAkB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;2BAE/C,KAAK;0BACL,KAAK;yBACL,KAAK;wBACL,KAAK;iCACL,KAAK;mCACL,KAAK;mCACL,KAAK;yBACL,KAAK;;IAAmB;QAAf,YAAY,EAAE;;2DAAgB;IA6F1C,8BAAC;CAAA,AAjID,IAiIC;SA1GY,uBAAuB;;;IAClC,iDAA8C;;IAE9C,2CAA8D;;IAC9D,0CAA+E;;IAE/E,2CAA4B;;IAC5B,0CAA2B;;IAC3B,yCAAyB;;IACzB,wCAAwB;;IACxB,iDAAyD;;IACzD,mDAAmC;;IACnC,mDAA+D;;IAC/D,yCAAwC;;IAExC,+CAAsB;;IACtB,wCAA6B;;IA6B7B,8CAME;;IAEF,8CAKE;;;;;IAxCU,gDAAsC;;;;;IAAE,sCAA8B","sourcesContent":["/**\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  ElementRef,\n  Input,\n  OnChanges,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { BooleanInput, NgStyleInterface } from 'ng-zorro-antd/core/types';\nimport { InputBoolean } from 'ng-zorro-antd/core/util';\n\nimport { NzTooltipDirective } from 'ng-zorro-antd/tooltip';\nimport { NzSliderService } from './slider.service';\nimport { NzSliderShowTooltip } from './typings';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  selector: 'nz-slider-handle',\n  exportAs: 'nzSliderHandle',\n  preserveWhitespaces: false,\n  template: `\n    <div\n      #handle\n      class=\"ant-slider-handle\"\n      tabindex=\"0\"\n      nz-tooltip\n      [ngStyle]=\"style\"\n      [nzTooltipTitle]=\"tooltipFormatter === null || tooltipVisible === 'never' ? null : tooltipTitle\"\n      [nzTooltipTrigger]=\"null\"\n      [nzTooltipPlacement]=\"tooltipPlacement\"\n    ></div>\n  `,\n  host: {\n    '(mouseenter)': 'enterHandle()',\n    '(mouseleave)': 'leaveHandle()'\n  }\n})\nexport class NzSliderHandleComponent implements OnChanges {\n  static ngAcceptInputType_active: BooleanInput;\n\n  @ViewChild('handle', { static: false }) handleEl?: ElementRef;\n  @ViewChild(NzTooltipDirective, { static: false }) tooltip?: NzTooltipDirective;\n\n  @Input() vertical?: boolean;\n  @Input() reverse?: boolean;\n  @Input() offset?: number;\n  @Input() value?: number;\n  @Input() tooltipVisible: NzSliderShowTooltip = 'default';\n  @Input() tooltipPlacement?: string;\n  @Input() tooltipFormatter?: null | ((value: number) => string);\n  @Input() @InputBoolean() active = false;\n\n  tooltipTitle?: string;\n  style: NgStyleInterface = {};\n\n  constructor(private sliderService: NzSliderService, private cdr: ChangeDetectorRef) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { offset, value, active, tooltipVisible, reverse } = changes;\n\n    if (offset || reverse) {\n      this.updateStyle();\n    }\n\n    if (value) {\n      this.updateTooltipTitle();\n      this.updateTooltipPosition();\n    }\n\n    if (active) {\n      if (active.currentValue) {\n        this.toggleTooltip(true);\n      } else {\n        this.toggleTooltip(false);\n      }\n    }\n\n    if (tooltipVisible?.currentValue === 'always') {\n      Promise.resolve().then(() => this.toggleTooltip(true, true));\n    }\n  }\n\n  enterHandle = () => {\n    if (!this.sliderService.isDragging) {\n      this.toggleTooltip(true);\n      this.updateTooltipPosition();\n      this.cdr.detectChanges();\n    }\n  };\n\n  leaveHandle = () => {\n    if (!this.sliderService.isDragging) {\n      this.toggleTooltip(false);\n      this.cdr.detectChanges();\n    }\n  };\n\n  focus(): void {\n    this.handleEl?.nativeElement.focus();\n  }\n\n  private toggleTooltip(show: boolean, force: boolean = false): void {\n    if (!force && (this.tooltipVisible !== '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.tooltipFormatter ? this.tooltipFormatter(this.value!) : `${this.value}`;\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    const vertical = this.vertical;\n    const reverse = this.reverse;\n    const offset = this.offset;\n\n    const positionStyle = vertical\n      ? {\n          [reverse ? 'top' : 'bottom']: `${offset}%`,\n          [reverse ? 'bottom' : 'top']: 'auto',\n          transform: reverse ? null : `translateY(+50%)`\n        }\n      : {\n          [reverse ? 'right' : 'left']: `${offset}%`,\n          [reverse ? 'left' : 'right']: 'auto',\n          transform: `translateX(${reverse ? '+' : '-'}50%)`\n        };\n\n    this.style = positionStyle;\n    this.cdr.markForCheck();\n  }\n}\n"]}