UNPKG

ngx-slice-kit

Version:

[![npm version](https://badge.fury.io/js/ngx-slice-kit.svg)](https://badge.fury.io/js/ngx-slice-kit)

237 lines 41.3 kB
import { Component, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core'; import { Subscription } from 'rxjs'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class SliderComponent { constructor(renderer) { this.renderer = renderer; this.max = 100; this.min = 0; this.step = 1; this.color = 'var(--primary)'; this.disabled = false; this.multiple = false; this.small = false; this.isDrag = false; this.isMultipleDrag = false; this.interValue = 0; this.subscription = new Subscription(); this.changed = new EventEmitter(); this.moved = new EventEmitter(); } grab(prop, event) { this[prop] = true; if (prop === 'isDrag') { this.thumbClickOffset = event.layerX; } if (prop === 'isMultipleDrag') { this.multiThumbClickOffset = event.layerX; } } drop() { this.isDrag = false; this.isMultipleDrag = false; } pointerMove(e) { if (this.isDrag) { this.thumbCoords = this.getCoords(e.clientX - this.thumbClickOffset); if (this.thumbCoords < this.multiThumbCoords + (this.thumbSize / this.trackRects.width * 100)) { return; } this.renderer.setStyle(this.thumb.nativeElement, 'left', this.thumbCoords + '%'); this.setGradient(this.thumbCoords); this.calcValue(this.thumbCoords, this.multiple ? 'max' : null); this.moved.emit(); } if (this.isMultipleDrag) { this.multiThumbCoords = this.getCoords(e.clientX - this.multiThumbClickOffset); if (this.multiThumbCoords + (this.thumbSize / this.trackRects.width * 100) > this.thumbCoords) { return; } this.renderer.setStyle(this.thumbMultiple.nativeElement, 'left', this.multiThumbCoords + '%'); this.setGradient(this.multiThumbCoords, true); this.calcValue(this.multiThumbCoords, 'min'); this.moved.emit(); } } getCoords(mouseX) { this.trackRects = this.track.nativeElement.getBoundingClientRect(); if (mouseX < this.trackRects.left) { mouseX = this.trackRects.left; this.setValue(this.min); } if (mouseX > this.trackRects.right) { mouseX = this.trackRects.right; this.setValue(this.max); } return (mouseX - this.trackRects.left) / this.trackRects.width * 100; } moveThumb(e) { const target = e.target; if (target.classList.contains('sdk-slider__thumb')) { return; } const coords = this.getCoords(e.clientX); if (this.multiple) { const firstThumb = { thumb: this.thumbMultiple, coords: this.multiThumbCoords, position: 'left' }; const secThumb = { thumb: this.thumb, coords: this.thumbCoords, position: 'right' }; if (secThumb.coords <= firstThumb.coords) { [secThumb.coords, firstThumb.coords] = [firstThumb.coords, secThumb.coords]; } const targetThumb = this.selectTargetBlock(coords, firstThumb, secThumb); this.renderer.setStyle(targetThumb.thumb.nativeElement, 'left', coords + '%'); targetThumb.position === 'left' ? this.multiThumbCoords = coords : this.thumbCoords = coords; this.setGradient(coords, targetThumb.position === 'left'); this.calcValue(coords, targetThumb.position === 'left' ? 'min' : 'max'); } else { this.isDrag = true; this.renderer.setStyle(this.thumb.nativeElement, 'left', coords + '%'); this.setGradient(coords); this.calcValue(coords); } this.moved.emit(); } setGradient(thumbCoords, fromLeft) { if (fromLeft) { this.gradientLeftOffset = thumbCoords; } else { this.gradientSize = thumbCoords; } } selectTargetBlock(clickCoords, firstThumb, secThumb) { return Math.abs(clickCoords - firstThumb.coords) < Math.abs(clickCoords - secThumb.coords) ? firstThumb : secThumb; } calcValue(thumbCoords, rangeSide) { const diff = this.max - this.min; this.interValue = Math.round(diff / 100 * thumbCoords); const newValue = this.step * Math.ceil(this.interValue / this.step) + this.min; this.setValue(newValue, rangeSide); } setValue(newValue, rangeSide) { if (this.multiple) { if (rangeSide === 'max') { if (this.value.max !== newValue) { this.value.max = newValue; this.changed.emit(this.value); } } if (rangeSide === 'min') { if (this.value.min !== newValue) { this.value.min = newValue; this.changed.emit(this.value); } } } else { if (this.value !== newValue) { this.value = newValue; this.changed.emit(this.value); } } } setInitialThumbCoords() { this.trackRects = this.track.nativeElement.getBoundingClientRect(); // const padding = this.thumbSize; const diff = this.max - this.min; const valuePercent = this.multiple ? (this.value.max - this.min) * 100 / diff : (this.value - this.min) * 100 / diff; if (this.multiple) { setTimeout(() => { const multipleValuePercent = (this.value.min - this.min) * 100 / diff; this.multiThumbCoords = multipleValuePercent; this.setGradient(multipleValuePercent, true); this.renderer.setStyle(this.thumbMultiple.nativeElement, 'left', multipleValuePercent + '%'); }); } this.thumbCoords = valuePercent; this.setGradient(valuePercent); this.renderer.setStyle(this.thumb.nativeElement, 'left', valuePercent + '%'); } ngOnInit() { this.trackRects = this.track.nativeElement.getBoundingClientRect(); this.thumbSize = this.multiple ? 12 : this.small ? 24 : 32; if (this.min > this.max) { [this.max, this.min] = [this.min, this.max]; } if (!this.multiple) { if (this.value < this.min) { this.value = this.min; } if (this.value > this.max) { this.value = this.max; } } else { if (this.value && this.value.min < this.min) { this.value.min = this.min; } if (this.value && this.value.max > this.max) { this.value.max = this.max; } } this.value = this.value || (this.multiple ? { max: this.max, min: this.min } : this.min); if (this.value && this.value !== this.min) { this.setInitialThumbCoords(); } } ngAfterViewInit() { this.thumbCoords = this.getCoords(this.thumb.nativeElement.getBoundingClientRect().left + this.thumbSize); if (this.multiple) { this.multiThumbCoords = this.getCoords(this.thumbMultiple.nativeElement.getBoundingClientRect().left); } } } SliderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: SliderComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); SliderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: SliderComponent, selector: "sdk-slider", inputs: { max: "max", min: "min", step: "step", color: "color", value: "value", disabled: "disabled", multiple: "multiple", small: "small" }, outputs: { changed: "changed", moved: "moved" }, host: { listeners: { "document:pointerup": "drop()", "document:pointermove": "pointerMove($event)" } }, viewQueries: [{ propertyName: "thumb", first: true, predicate: ["thumb"], descendants: true, static: true }, { propertyName: "addThumb", first: true, predicate: ["addThumb"], descendants: true }, { propertyName: "thumbMultiple", first: true, predicate: ["thumbMultiple"], descendants: true }, { propertyName: "track", first: true, predicate: ["track"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"sdk-slider__wrapper\"\n [class.sdk-slider__wrapper--small]=\"small\"\n [class.sdk-slider__wrapper--multiple]=\"multiple\">\n <div class=\"sdk-slider__track-wrapper\" #track (pointerdown)=\"moveThumb($event)\">\n <div class=\"sdk-slider__thumb-wrapper sdk-slider__thumb-wrapper--multiple\" *ngIf=\"multiple\" #thumbMultiple\n [style.top]=\"'-12px'\">\n <div class=\"sdk-slider__thumb\" [class.sdk-slider__thumb--active]=\"isMultipleDrag\"\n (pointerdown)=\"grab('isMultipleDrag', $event)\"></div>\n </div>\n <div class=\"sdk-slider__thumb-wrapper\" [style.top]=\"multiple ? '-12px' : (-thumbSize/2) + thumbSize/10 + 'px'\"\n #thumb>\n <div class=\"sdk-slider__thumb\" [class.sdk-slider__thumb--active]=\"isDrag\"\n (pointerdown)=\"grab('isDrag', $event)\"></div>\n </div>\n <div class=\"sdk-slider-track__background\"></div>\n <div class=\"sdk-slider-track__fill\"\n [ngStyle]=\"{'background': 'linear-gradient(to right, transparent 0px ' + (gradientLeftOffset || 0) + '%, ' + color + ' 0px ' + gradientSize + '%, transparent ' + gradientSize + 'px)'}\"></div>\n </div>\n <div class=\"sdk-slider-track__padding\" [style.width]=\"thumbSize + 'px'\"></div>\n</div>\n\n", styles: [".sdk-slider__wrapper{width:100%;height:40px;display:flex;align-items:center;position:relative}.sdk-slider__track-wrapper{width:100%;height:8px;border-radius:3px;position:relative;display:flex}.sdk-slider-track__background{height:100%;width:100%;background-color:var(--regular-a20)}.sdk-slider__thumb{width:32px;height:32px;background-color:#fff;box-shadow:0 2px 2px #1a1a1a3d,0 1px 4px #1a1a1a29;left:0;border-radius:100%;cursor:grab;position:relative;z-index:1}.sdk-slider__thumb:active,.sdk-slider__thumb--active{cursor:grabbing}.sdk-slider__wrapper--small .sdk-slider__track-wrapper{height:4px}.sdk-slider__wrapper--small .sdk-slider__thumb{width:24px;height:24px}.sdk-slider-track__fill{background-color:var(--primary);height:100%;width:100%;position:absolute;top:0;border-radius:3px}.sdk-slider__wrapper--multiple .sdk-slider__thumb{width:12px;height:32px;border-radius:3px}.sdk-slider__wrapper--multiple.sdk-slider__wrapper--small .sdk-slider__thumb{height:24px}.sdk-slider__thumb-wrapper{position:absolute}.sdk-slider-track__padding{height:8px;background-color:var(--regular-a20)}.sdk-slider__wrapper--small .sdk-slider-track__padding{height:4px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: SliderComponent, decorators: [{ type: Component, args: [{ selector: 'sdk-slider', template: "<div class=\"sdk-slider__wrapper\"\n [class.sdk-slider__wrapper--small]=\"small\"\n [class.sdk-slider__wrapper--multiple]=\"multiple\">\n <div class=\"sdk-slider__track-wrapper\" #track (pointerdown)=\"moveThumb($event)\">\n <div class=\"sdk-slider__thumb-wrapper sdk-slider__thumb-wrapper--multiple\" *ngIf=\"multiple\" #thumbMultiple\n [style.top]=\"'-12px'\">\n <div class=\"sdk-slider__thumb\" [class.sdk-slider__thumb--active]=\"isMultipleDrag\"\n (pointerdown)=\"grab('isMultipleDrag', $event)\"></div>\n </div>\n <div class=\"sdk-slider__thumb-wrapper\" [style.top]=\"multiple ? '-12px' : (-thumbSize/2) + thumbSize/10 + 'px'\"\n #thumb>\n <div class=\"sdk-slider__thumb\" [class.sdk-slider__thumb--active]=\"isDrag\"\n (pointerdown)=\"grab('isDrag', $event)\"></div>\n </div>\n <div class=\"sdk-slider-track__background\"></div>\n <div class=\"sdk-slider-track__fill\"\n [ngStyle]=\"{'background': 'linear-gradient(to right, transparent 0px ' + (gradientLeftOffset || 0) + '%, ' + color + ' 0px ' + gradientSize + '%, transparent ' + gradientSize + 'px)'}\"></div>\n </div>\n <div class=\"sdk-slider-track__padding\" [style.width]=\"thumbSize + 'px'\"></div>\n</div>\n\n", styles: [".sdk-slider__wrapper{width:100%;height:40px;display:flex;align-items:center;position:relative}.sdk-slider__track-wrapper{width:100%;height:8px;border-radius:3px;position:relative;display:flex}.sdk-slider-track__background{height:100%;width:100%;background-color:var(--regular-a20)}.sdk-slider__thumb{width:32px;height:32px;background-color:#fff;box-shadow:0 2px 2px #1a1a1a3d,0 1px 4px #1a1a1a29;left:0;border-radius:100%;cursor:grab;position:relative;z-index:1}.sdk-slider__thumb:active,.sdk-slider__thumb--active{cursor:grabbing}.sdk-slider__wrapper--small .sdk-slider__track-wrapper{height:4px}.sdk-slider__wrapper--small .sdk-slider__thumb{width:24px;height:24px}.sdk-slider-track__fill{background-color:var(--primary);height:100%;width:100%;position:absolute;top:0;border-radius:3px}.sdk-slider__wrapper--multiple .sdk-slider__thumb{width:12px;height:32px;border-radius:3px}.sdk-slider__wrapper--multiple.sdk-slider__wrapper--small .sdk-slider__thumb{height:24px}.sdk-slider__thumb-wrapper{position:absolute}.sdk-slider-track__padding{height:8px;background-color:var(--regular-a20)}.sdk-slider__wrapper--small .sdk-slider-track__padding{height:4px}\n"] }] }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { thumb: [{ type: ViewChild, args: ['thumb', { static: true }] }], addThumb: [{ type: ViewChild, args: ['addThumb', { static: false }] }], thumbMultiple: [{ type: ViewChild, args: ['thumbMultiple', { static: false }] }], track: [{ type: ViewChild, args: ['track', { static: true }] }], max: [{ type: Input }], min: [{ type: Input }], step: [{ type: Input }], color: [{ type: Input }], value: [{ type: Input }], disabled: [{ type: Input }], multiple: [{ type: Input }], small: [{ type: Input }], changed: [{ type: Output }], moved: [{ type: Output }], drop: [{ type: HostListener, args: ['document:pointerup'] }], pointerMove: [{ type: HostListener, args: ['document:pointermove', ['$event']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../../libs/ngx-slice-kit/src/lib/layout/slider/slider.component.ts","../../../../../../libs/ngx-slice-kit/src/lib/layout/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    OnInit,\n    Output,\n    Renderer2,\n    ViewChild\n} from '@angular/core';\nimport {Subscription} from 'rxjs';\n\n@Component({\n    selector: 'sdk-slider',\n    templateUrl: './slider.component.html',\n    styleUrls: ['./slider.component.scss']\n})\nexport class SliderComponent implements OnInit, AfterViewInit {\n\n    @ViewChild('thumb', {static: true}) public thumb: ElementRef;\n    @ViewChild('addThumb', {static: false}) public addThumb: ElementRef;\n    @ViewChild('thumbMultiple', {static: false}) public thumbMultiple: ElementRef;\n    @ViewChild('track', {static: true}) public track: ElementRef;\n\n    @Input() public max: number = 100;\n    @Input() public min: number = 0;\n    @Input() public step: number = 1;\n    @Input() public color: string = 'var(--primary)';\n    @Input() public value: any;\n    @Input() public disabled: boolean = false;\n    @Input() public multiple: boolean = false;\n    @Input() public small: boolean = false;\n\n    public isDrag: boolean = false;\n    public isMultipleDrag: boolean = false;\n    public trackRects: ClientRect;\n    public thumbCoords: number;\n    public multiThumbCoords: number;\n\n    public interValue: number = 0;\n    public gradientSize: number;\n    public gradientLeftOffset: number;\n    public subscription: Subscription = new Subscription();\n\n    public thumbSize: number;\n    public thumbClickOffset: number;\n    public multiThumbClickOffset: number;\n\n    @Output() public changed = new EventEmitter();\n    @Output() public moved = new EventEmitter();\n\n    constructor(\n        private renderer: Renderer2,\n    ) {\n    }\n\n    public grab(prop, event): void {\n        this[prop] = true;\n        if (prop === 'isDrag') {\n            this.thumbClickOffset = event.layerX;\n        }\n        if (prop === 'isMultipleDrag') {\n            this.multiThumbClickOffset = event.layerX;\n        }\n    }\n\n    @HostListener('document:pointerup')\n    public drop(): void {\n        this.isDrag = false;\n        this.isMultipleDrag = false;\n    }\n\n    @HostListener('document:pointermove', ['$event'])\n    public pointerMove(e: PointerEvent): void {\n        if (this.isDrag) {\n            this.thumbCoords = this.getCoords(e.clientX - this.thumbClickOffset);\n            if (this.thumbCoords < this.multiThumbCoords + (this.thumbSize / this.trackRects.width * 100)) {\n                return;\n            }\n\n            this.renderer.setStyle(this.thumb.nativeElement, 'left', this.thumbCoords + '%');\n\n            this.setGradient(this.thumbCoords);\n            this.calcValue(this.thumbCoords, this.multiple ? 'max' : null);\n            this.moved.emit();\n        }\n\n        if (this.isMultipleDrag) {\n            this.multiThumbCoords = this.getCoords(e.clientX - this.multiThumbClickOffset);\n\n            if (this.multiThumbCoords + (this.thumbSize / this.trackRects.width * 100) > this.thumbCoords) {\n                return;\n            }\n\n            this.renderer.setStyle(this.thumbMultiple.nativeElement, 'left', this.multiThumbCoords + '%');\n\n            this.setGradient(this.multiThumbCoords, true);\n            this.calcValue(this.multiThumbCoords, 'min');\n            this.moved.emit();\n        }\n    }\n\n    public getCoords(mouseX: number): number {\n        this.trackRects = this.track.nativeElement.getBoundingClientRect();\n        if (mouseX < this.trackRects.left) {\n            mouseX = this.trackRects.left;\n            this.setValue(this.min);\n        }\n\n        if (mouseX > this.trackRects.right) {\n            mouseX = this.trackRects.right;\n            this.setValue(this.max);\n        }\n\n        return (mouseX - this.trackRects.left) / this.trackRects.width * 100;\n    }\n\n    public moveThumb(e: MouseEvent): void {\n        const target: HTMLElement = e.target as HTMLElement;\n\n        if (target.classList.contains('sdk-slider__thumb')) {\n            return;\n        }\n\n        const coords = this.getCoords(e.clientX);\n        if (this.multiple) {\n            const firstThumb = {\n                thumb: this.thumbMultiple,\n                coords: this.multiThumbCoords,\n                position: 'left'\n            };\n            const secThumb = {\n                thumb: this.thumb,\n                coords: this.thumbCoords,\n                position: 'right'\n            };\n\n            if (secThumb.coords <= firstThumb.coords) {\n                [secThumb.coords, firstThumb.coords] = [firstThumb.coords, secThumb.coords];\n            }\n\n            const targetThumb = this.selectTargetBlock(coords, firstThumb, secThumb);\n            this.renderer.setStyle(targetThumb.thumb.nativeElement, 'left', coords + '%');\n            targetThumb.position === 'left' ? this.multiThumbCoords = coords : this.thumbCoords = coords;\n            this.setGradient(coords, targetThumb.position === 'left');\n            this.calcValue(coords, targetThumb.position === 'left' ? 'min' : 'max');\n        } else {\n            this.isDrag = true;\n            this.renderer.setStyle(this.thumb.nativeElement, 'left', coords + '%');\n            this.setGradient(coords);\n            this.calcValue(coords);\n        }\n\n        this.moved.emit();\n    }\n\n    public setGradient(thumbCoords: number, fromLeft?: boolean): void {\n        if (fromLeft) {\n            this.gradientLeftOffset = thumbCoords;\n        } else {\n            this.gradientSize = thumbCoords;\n        }\n    }\n\n    public selectTargetBlock(\n        clickCoords: number,\n        firstThumb: { thumb: ElementRef, coords: number, position: string },\n        secThumb: { thumb: ElementRef, coords: number, position: string }\n    ): { thumb: ElementRef, coords: number, position: string } {\n        return Math.abs(clickCoords - firstThumb.coords) < Math.abs(clickCoords - secThumb.coords) ? firstThumb : secThumb;\n    }\n\n    public calcValue(thumbCoords: number, rangeSide?: 'min' | 'max'): void {\n        const diff = this.max - this.min;\n\n        this.interValue = Math.round(diff / 100 * thumbCoords);\n        const newValue = this.step * Math.ceil(this.interValue / this.step) + this.min;\n\n        this.setValue(newValue, rangeSide);\n    }\n\n    public setValue(newValue: number, rangeSide?: 'max' | 'min'): void {\n        if (this.multiple) {\n            if (rangeSide === 'max') {\n                if (this.value.max !== newValue) {\n                    this.value.max = newValue;\n                    this.changed.emit(this.value);\n                }\n            }\n            if (rangeSide === 'min') {\n                if (this.value.min !== newValue) {\n                    this.value.min = newValue;\n                    this.changed.emit(this.value);\n                }\n            }\n        } else {\n            if (this.value !== newValue) {\n                this.value = newValue;\n                this.changed.emit(this.value);\n            }\n        }\n    }\n\n    public setInitialThumbCoords(): void {\n        this.trackRects = this.track.nativeElement.getBoundingClientRect();\n        // const padding = this.thumbSize;\n        const diff = this.max - this.min;\n        const valuePercent = this.multiple ? (this.value.max - this.min) * 100 / diff : (this.value - this.min) * 100 / diff;\n\n        if (this.multiple) {\n            setTimeout(() => {\n                const multipleValuePercent = (this.value.min - this.min) * 100 / diff;\n\n                this.multiThumbCoords = multipleValuePercent;\n                this.setGradient(multipleValuePercent, true);\n                this.renderer.setStyle(this.thumbMultiple.nativeElement, 'left', multipleValuePercent + '%');\n            });\n        }\n\n        this.thumbCoords = valuePercent;\n        this.setGradient(valuePercent);\n        this.renderer.setStyle(this.thumb.nativeElement, 'left', valuePercent + '%');\n    }\n\n    public ngOnInit(): void {\n        this.trackRects = this.track.nativeElement.getBoundingClientRect();\n        this.thumbSize = this.multiple ? 12 : this.small ? 24 : 32;\n\n        if (this.min > this.max) {\n            [this.max, this.min] = [this.min, this.max];\n        }\n\n        if (!this.multiple) {\n            if (this.value < this.min) {\n                this.value = this.min;\n            }\n            if (this.value > this.max) {\n                this.value = this.max;\n            }\n        } else {\n            if (this.value && this.value.min < this.min) {\n                this.value.min = this.min;\n            }\n            if (this.value && this.value.max > this.max) {\n                this.value.max = this.max;\n            }\n        }\n\n        this.value = this.value || (this.multiple ? {max: this.max, min: this.min} : this.min);\n\n        if (this.value && this.value !== this.min) {\n            this.setInitialThumbCoords();\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        this.thumbCoords = this.getCoords(this.thumb.nativeElement.getBoundingClientRect().left + this.thumbSize);\n        if (this.multiple) {\n            this.multiThumbCoords = this.getCoords(this.thumbMultiple.nativeElement.getBoundingClientRect().left);\n        }\n    }\n}\n","<div class=\"sdk-slider__wrapper\"\n     [class.sdk-slider__wrapper--small]=\"small\"\n     [class.sdk-slider__wrapper--multiple]=\"multiple\">\n    <div class=\"sdk-slider__track-wrapper\" #track (pointerdown)=\"moveThumb($event)\">\n        <div class=\"sdk-slider__thumb-wrapper sdk-slider__thumb-wrapper--multiple\" *ngIf=\"multiple\" #thumbMultiple\n             [style.top]=\"'-12px'\">\n            <div class=\"sdk-slider__thumb\" [class.sdk-slider__thumb--active]=\"isMultipleDrag\"\n                 (pointerdown)=\"grab('isMultipleDrag', $event)\"></div>\n        </div>\n        <div class=\"sdk-slider__thumb-wrapper\" [style.top]=\"multiple ? '-12px' : (-thumbSize/2) + thumbSize/10 + 'px'\"\n             #thumb>\n            <div class=\"sdk-slider__thumb\" [class.sdk-slider__thumb--active]=\"isDrag\"\n                 (pointerdown)=\"grab('isDrag', $event)\"></div>\n        </div>\n        <div class=\"sdk-slider-track__background\"></div>\n        <div class=\"sdk-slider-track__fill\"\n             [ngStyle]=\"{'background': 'linear-gradient(to right, transparent 0px ' + (gradientLeftOffset || 0) + '%, ' + color + ' 0px ' + gradientSize + '%, transparent ' + gradientSize + 'px)'}\"></div>\n    </div>\n    <div class=\"sdk-slider-track__padding\" [style.width]=\"thumbSize + 'px'\"></div>\n</div>\n\n"]}