igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
367 lines • 23.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { NgModule, Component, Input, HostListener, ElementRef, HostBinding, Output, EventEmitter, TemplateRef } from '@angular/core';
import { CommonModule } from '@angular/common';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { SliderHandle } from '../slider.component';
/**
* @hidden
*/
var IgxSliderThumbComponent = /** @class */ (function () {
function IgxSliderThumbComponent(_elementRef) {
this._elementRef = _elementRef;
this._isActiveLabel = false;
this._destroy$ = new Subject();
this.isActive = false;
this.onThumbValueChange = new EventEmitter();
this.onChange = new EventEmitter();
this.tabindex = 0;
}
Object.defineProperty(IgxSliderThumbComponent.prototype, "thumbFromClass", {
get: /**
* @return {?}
*/
function () {
return this.fromHandler;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSliderThumbComponent.prototype, "thumbToClass", {
get: /**
* @return {?}
*/
function () {
return !this.fromHandler;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSliderThumbComponent.prototype, "thumbFromActiveClass", {
get: /**
* @return {?}
*/
function () {
return this.fromHandler && this._isActiveLabel;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSliderThumbComponent.prototype, "thumbToActiveClass", {
get: /**
* @return {?}
*/
function () {
return !this.fromHandler && this._isActiveLabel;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSliderThumbComponent.prototype, "nativeElement", {
get: /**
* @return {?}
*/
function () {
return this._elementRef.nativeElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSliderThumbComponent.prototype, "thumbPositionX", {
get: /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var thumbBounderies = this.nativeElement.getBoundingClientRect();
/** @type {?} */
var thumbCenter = (thumbBounderies.right - thumbBounderies.left) / 2;
return thumbBounderies.left + thumbCenter;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSliderThumbComponent.prototype, "destroy", {
get: /**
* @return {?}
*/
function () {
return this._destroy$;
},
enumerable: true,
configurable: true
});
/**
* @hidden
*/
/**
* @hidden
* @return {?}
*/
IgxSliderThumbComponent.prototype.ngOnInit = /**
* @hidden
* @return {?}
*/
function () {
var _this = this;
this.onPan
.pipe(takeUntil(this._destroy$))
.subscribe(function (mouseX) {
return _this.updateThumbValue(mouseX);
});
};
/**
* @hidden
*/
/**
* @hidden
* @return {?}
*/
IgxSliderThumbComponent.prototype.ngOnDestroy = /**
* @hidden
* @return {?}
*/
function () {
this._destroy$.next(true);
this._destroy$.complete();
};
/**
* @param {?} event
* @return {?}
*/
IgxSliderThumbComponent.prototype.onKeyDown = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.disabled) {
return;
}
/** @type {?} */
var increment = 0;
if (event.key.endsWith('Left')) {
increment = this.step * -1;
}
else if (event.key.endsWith('Right')) {
increment = this.step;
}
else {
return;
}
this.onChange.emit();
this.onThumbValueChange.emit(increment);
};
/**
* @return {?}
*/
IgxSliderThumbComponent.prototype.onBlur = /**
* @return {?}
*/
function () {
this.isActive = false;
};
/**
* @return {?}
*/
IgxSliderThumbComponent.prototype.onFocusListener = /**
* @return {?}
*/
function () {
this.isActive = true;
};
/**
* @return {?}
*/
IgxSliderThumbComponent.prototype.showThumbLabel = /**
* @return {?}
*/
function () {
if (this.disabled) {
return;
}
if (this.continuous) {
return;
}
if (this._timer !== null) {
clearTimeout(this._timer);
}
this._isActiveLabel = true;
};
/**
* @return {?}
*/
IgxSliderThumbComponent.prototype.hideThumbLabel = /**
* @return {?}
*/
function () {
var _this = this;
if (this.disabled) {
return;
}
if (this.continuous) {
return;
}
this._timer = setTimeout(function () { return _this._isActiveLabel = false; }, this.thumbLabelVisibilityDuration);
};
/**
* @private
* @param {?} mouseX
* @return {?}
*/
IgxSliderThumbComponent.prototype.updateThumbValue = /**
* @private
* @param {?} mouseX
* @return {?}
*/
function (mouseX) {
/** @type {?} */
var updateValue = this.calculateTrackUpdate(mouseX);
if (this.isActive && updateValue !== 0) {
this.onThumbValueChange.emit(updateValue);
}
};
/**
* @private
* @param {?} mouseX
* @return {?}
*/
IgxSliderThumbComponent.prototype.calculateTrackUpdate = /**
* @private
* @param {?} mouseX
* @return {?}
*/
function (mouseX) {
/** @type {?} */
var scaleX = mouseX - this.thumbPositionX;
/** @type {?} */
var stepDistanceCenter = this.stepDistance / 2;
// If the thumb scale range (slider update) is less thàn a half step,
// the position stays the same.
/** @type {?} */
var scaleXPositive = Math.abs(scaleX);
if (scaleXPositive < stepDistanceCenter) {
return 0;
}
return this.stepToProceed(scaleX, this.stepDistance);
};
/**
* @private
* @param {?} scaleX
* @param {?} stepDist
* @return {?}
*/
IgxSliderThumbComponent.prototype.stepToProceed = /**
* @private
* @param {?} scaleX
* @param {?} stepDist
* @return {?}
*/
function (scaleX, stepDist) {
return Math.round(scaleX / stepDist) * this.step;
};
IgxSliderThumbComponent.decorators = [
{ type: Component, args: [{
selector: 'igx-thumb',
template: "<span class=\"label\">\n <ng-container *ngTemplateOutlet=\"templateRef ? templateRef : thumbFromDefaultTemplate; context: context\"></ng-container>\n</span>\n<span class=\"dot\"></span>\n\n\n<ng-template #thumbFromDefaultTemplate>\n {{ value }}\n</ng-template>\n"
}] }
];
/** @nocollapse */
IgxSliderThumbComponent.ctorParameters = function () { return [
{ type: ElementRef }
]; };
IgxSliderThumbComponent.propDecorators = {
value: [{ type: Input }],
continuous: [{ type: Input }],
thumbLabelVisibilityDuration: [{ type: Input }],
disabled: [{ type: Input }],
onPan: [{ type: Input }],
stepDistance: [{ type: Input }],
step: [{ type: Input }],
fromHandler: [{ type: Input }],
templateRef: [{ type: Input }],
context: [{ type: Input }],
type: [{ type: Input }],
onThumbValueChange: [{ type: Output }],
onChange: [{ type: Output }],
tabindex: [{ type: HostBinding, args: ['attr.tabindex',] }],
thumbFromClass: [{ type: HostBinding, args: ['class.igx-slider__thumb-from',] }],
thumbToClass: [{ type: HostBinding, args: ['class.igx-slider__thumb-to',] }],
thumbFromActiveClass: [{ type: HostBinding, args: ['class.igx-slider__thumb-from--active',] }],
thumbToActiveClass: [{ type: HostBinding, args: ['class.igx-slider__thumb-to--active',] }],
onKeyDown: [{ type: HostListener, args: ['keydown', ['$event'],] }],
onBlur: [{ type: HostListener, args: ['blur',] }],
onFocusListener: [{ type: HostListener, args: ['focus',] }]
};
return IgxSliderThumbComponent;
}());
export { IgxSliderThumbComponent };
if (false) {
/**
* @type {?}
* @private
*/
IgxSliderThumbComponent.prototype._timer;
/**
* @type {?}
* @private
*/
IgxSliderThumbComponent.prototype._isActiveLabel;
/**
* @type {?}
* @private
*/
IgxSliderThumbComponent.prototype._destroy$;
/** @type {?} */
IgxSliderThumbComponent.prototype.isActive;
/** @type {?} */
IgxSliderThumbComponent.prototype.value;
/** @type {?} */
IgxSliderThumbComponent.prototype.continuous;
/** @type {?} */
IgxSliderThumbComponent.prototype.thumbLabelVisibilityDuration;
/** @type {?} */
IgxSliderThumbComponent.prototype.disabled;
/** @type {?} */
IgxSliderThumbComponent.prototype.onPan;
/** @type {?} */
IgxSliderThumbComponent.prototype.stepDistance;
/** @type {?} */
IgxSliderThumbComponent.prototype.step;
/** @type {?} */
IgxSliderThumbComponent.prototype.fromHandler;
/** @type {?} */
IgxSliderThumbComponent.prototype.templateRef;
/** @type {?} */
IgxSliderThumbComponent.prototype.context;
/** @type {?} */
IgxSliderThumbComponent.prototype.type;
/** @type {?} */
IgxSliderThumbComponent.prototype.onThumbValueChange;
/** @type {?} */
IgxSliderThumbComponent.prototype.onChange;
/** @type {?} */
IgxSliderThumbComponent.prototype.tabindex;
/**
* @type {?}
* @private
*/
IgxSliderThumbComponent.prototype._elementRef;
}
var IgxSliderThumbModule = /** @class */ (function () {
function IgxSliderThumbModule() {
}
IgxSliderThumbModule.decorators = [
{ type: NgModule, args: [{
declarations: [IgxSliderThumbComponent],
imports: [CommonModule],
exports: [IgxSliderThumbComponent]
},] }
];
return IgxSliderThumbModule;
}());
export { IgxSliderThumbModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"thumb-slider.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/slider/thumb/thumb-slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    NgModule,\n    Component,\n    Input,\n    HostListener,\n    ElementRef,\n    HostBinding,\n    Output,\n    EventEmitter,\n    OnInit,\n    OnDestroy,\n    TemplateRef} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { SliderHandle } from '../slider.component';\n\n/**\n * @hidden\n */\n@Component({\n    selector: 'igx-thumb',\n    templateUrl: 'thumb-slider.component.html',\n})\nexport class IgxSliderThumbComponent implements OnInit, OnDestroy {\n\n    private _timer;\n    private _isActiveLabel = false;\n    private _destroy$ = new Subject<boolean>();\n\n    public isActive = false;\n\n    @Input()\n    public value: number;\n\n    @Input()\n    public continuous: boolean;\n\n    @Input()\n    public thumbLabelVisibilityDuration;\n\n    @Input()\n    public disabled: boolean;\n\n    @Input()\n    public onPan: Subject<number>;\n\n    @Input()\n    public stepDistance: number;\n\n    @Input()\n    public step: number;\n\n    @Input()\n    public fromHandler: boolean;\n\n    @Input()\n    public templateRef: TemplateRef<any>;\n\n    @Input()\n    public context: any;\n\n    @Input()\n    public type: SliderHandle;\n\n    @Output()\n    public onThumbValueChange = new EventEmitter<number>();\n\n    @Output()\n    public onChange = new EventEmitter<any>();\n\n    @HostBinding('attr.tabindex')\n    public tabindex = 0;\n\n    @HostBinding('class.igx-slider__thumb-from')\n    public get thumbFromClass() {\n        return this.fromHandler;\n    }\n\n    @HostBinding('class.igx-slider__thumb-to')\n    public get thumbToClass() {\n        return !this.fromHandler;\n    }\n\n    @HostBinding('class.igx-slider__thumb-from--active')\n    public get thumbFromActiveClass() {\n        return this.fromHandler && this._isActiveLabel;\n    }\n\n    @HostBinding('class.igx-slider__thumb-to--active')\n    public get thumbToActiveClass() {\n        return !this.fromHandler && this._isActiveLabel;\n    }\n\n    public get nativeElement() {\n        return this._elementRef.nativeElement;\n    }\n\n    private get thumbPositionX() {\n        const thumbBounderies = this.nativeElement.getBoundingClientRect();\n        const thumbCenter = (thumbBounderies.right - thumbBounderies.left) / 2;\n        return thumbBounderies.left + thumbCenter;\n    }\n\n    public get destroy(): Subject<boolean> {\n        return this._destroy$;\n    }\n\n    constructor (private _elementRef: ElementRef) { }\n\n    /**\n     * @hidden\n     */\n    public ngOnInit() {\n        this.onPan\n            .pipe(takeUntil(this._destroy$))\n            .subscribe(mouseX =>\n                this.updateThumbValue(mouseX)\n            );\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnDestroy() {\n        this._destroy$.next(true);\n        this._destroy$.complete();\n    }\n\n    @HostListener('keydown', ['$event'])\n    public onKeyDown(event: KeyboardEvent) {\n        if (this.disabled) {\n            return;\n        }\n\n        let increment = 0;\n        if (event.key.endsWith('Left')) {\n            increment = this.step * - 1;\n        } else if (event.key.endsWith('Right')) {\n            increment = this.step;\n        } else {\n            return;\n        }\n\n        this.onChange.emit();\n        this.onThumbValueChange.emit(increment);\n    }\n\n    @HostListener('blur')\n    public onBlur() {\n        this.isActive = false;\n    }\n\n    @HostListener('focus')\n    public onFocusListener() {\n        this.isActive = true;\n    }\n\n    public showThumbLabel() {\n        if (this.disabled) {\n            return;\n        }\n\n        if (this.continuous) {\n            return;\n        }\n\n        if (this._timer !== null) {\n            clearTimeout(this._timer);\n        }\n\n        this._isActiveLabel = true;\n    }\n\n\n    public hideThumbLabel() {\n        if (this.disabled) {\n            return;\n        }\n\n        if (this.continuous) {\n            return;\n        }\n\n        this._timer = setTimeout(\n            () => this._isActiveLabel = false,\n            this.thumbLabelVisibilityDuration\n        );\n    }\n\n    private updateThumbValue(mouseX: number) {\n        const updateValue = this.calculateTrackUpdate(mouseX);\n        if (this.isActive && updateValue !== 0) {\n            this.onThumbValueChange.emit(updateValue);\n        }\n    }\n\n    private calculateTrackUpdate(mouseX: number): number {\n        const scaleX = mouseX - this.thumbPositionX;\n        const stepDistanceCenter = this.stepDistance / 2;\n\n        // If the thumb scale range (slider update) is less thàn a half step,\n        // the position stays the same.\n        const scaleXPositive = Math.abs(scaleX);\n        if (scaleXPositive < stepDistanceCenter) {\n            return 0;\n        }\n\n        return this.stepToProceed(scaleX, this.stepDistance);\n    }\n\n    private stepToProceed(scaleX, stepDist) {\n        return Math.round(scaleX / stepDist) * this.step;\n    }\n}\n@NgModule({\n    declarations: [IgxSliderThumbComponent],\n    imports: [CommonModule],\n    exports: [IgxSliderThumbComponent]\n})\nexport class IgxSliderThumbModule {}\n"]}