UNPKG

@taiga-ui/kit

Version:
131 lines 13.4 kB
import { __decorate } from "tslib"; import { Directive, HostBinding, Input } from '@angular/core'; import { AbstractTuiControl, clamp, round, tuiDefaultProp, } from '@taiga-ui/cdk'; import { maskedNumberStringToNumber, tuiCreateAutoCorrectedNumberPipe, tuiCreateNumberMask, } from '@taiga-ui/core'; import { TUI_FLOATING_PRECISION } from '@taiga-ui/kit/constants'; export function quantumAssertion(quantum) { return quantum > 0; } /** * @internal */ let AbstractTuiInputSlider = class AbstractTuiInputSlider extends AbstractTuiControl { constructor() { super(...arguments); this.min = 0; this.max = Infinity; this.minLabel = ''; this.maxLabel = ''; this.pluralize = null; this.segmentsPluralize = null; this.segments = 0; this.steps = 0; this.quantum = 1; this.keySteps = null; this.size = 'l'; this.mask = (quantum, min) => ({ mask: tuiCreateNumberMask({ allowNegative: min < 0, allowDecimal: !Number.isInteger(quantum), }), pipe: tuiCreateAutoCorrectedNumberPipe(), guide: false, }); } get segmented() { return this.segments > 0; } get hasPlaceholder() { return this.size === 'l'; } get inputMode() { return Number.isInteger(this.quantum) ? "numeric" /* Numeric */ : "decimal" /* Decimal */; } get length() { return this.max - this.min; } get computedSteps() { return this.steps || this.length / this.quantum; } get step() { return this.length / this.computedSteps; } get hostMode() { return this.modeDirective && this.modeDirective.mode; } onHovered(hovered) { this.updateHovered(hovered); } isPluralized(pluralize) { return pluralize !== null && pluralize.length === 3; } valueGuard(value) { return this.quantum ? clamp(round(Math.round(value / this.quantum) * this.quantum, TUI_FLOATING_PRECISION), this.min, this.max) : clamp(value, this.min, this.max); } capInputValue(value, max = this.max) { const capped = Math.min(maskedNumberStringToNumber(value), max); if (this.min < 0 && capped < this.min) { return this.min; } return isNaN(capped) || capped < this.min ? null : capped; } }; __decorate([ Input(), tuiDefaultProp() ], AbstractTuiInputSlider.prototype, "min", void 0); __decorate([ Input(), tuiDefaultProp() ], AbstractTuiInputSlider.prototype, "max", void 0); __decorate([ Input(), tuiDefaultProp() ], AbstractTuiInputSlider.prototype, "minLabel", void 0); __decorate([ Input(), tuiDefaultProp() ], AbstractTuiInputSlider.prototype, "maxLabel", void 0); __decorate([ Input(), tuiDefaultProp() ], AbstractTuiInputSlider.prototype, "pluralize", void 0); __decorate([ Input(), tuiDefaultProp() ], AbstractTuiInputSlider.prototype, "segmentsPluralize", void 0); __decorate([ Input(), tuiDefaultProp() ], AbstractTuiInputSlider.prototype, "segments", void 0); __decorate([ Input(), tuiDefaultProp() ], AbstractTuiInputSlider.prototype, "steps", void 0); __decorate([ Input(), tuiDefaultProp(quantumAssertion, 'Quantum must be positive') ], AbstractTuiInputSlider.prototype, "quantum", void 0); __decorate([ Input(), tuiDefaultProp() ], AbstractTuiInputSlider.prototype, "keySteps", void 0); __decorate([ Input(), HostBinding('attr.data-tui-host-size') ], AbstractTuiInputSlider.prototype, "size", void 0); __decorate([ HostBinding('class._segmented') ], AbstractTuiInputSlider.prototype, "segmented", null); __decorate([ HostBinding('attr.data-mode') ], AbstractTuiInputSlider.prototype, "hostMode", null); AbstractTuiInputSlider = __decorate([ Directive() ], AbstractTuiInputSlider); export { AbstractTuiInputSlider }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-slider.js","sourceRoot":"ng://@taiga-ui/kit/abstract/","sources":["input-slider.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, HostBinding, Input} from '@angular/core';\nimport {\n    AbstractTuiControl,\n    clamp,\n    round,\n    tuiDefaultProp,\n    TuiInputMode,\n    TuiMapper,\n} from '@taiga-ui/cdk';\nimport {\n    maskedNumberStringToNumber,\n    TuiBrightness,\n    tuiCreateAutoCorrectedNumberPipe,\n    tuiCreateNumberMask,\n    TuiModeDirective,\n    TuiPluralize,\n    TuiSizeL,\n    TuiTextMaskOptions,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TUI_FLOATING_PRECISION} from '@taiga-ui/kit/constants';\nimport {TuiKeySteps} from '@taiga-ui/kit/types';\n\nexport function quantumAssertion(quantum: number): boolean {\n    return quantum > 0;\n}\n\n/**\n * @internal\n */\n@Directive()\nexport abstract class AbstractTuiInputSlider<T>\n    extends AbstractTuiControl<T>\n    implements TuiWithOptionalMinMax<number> {\n    @Input()\n    @tuiDefaultProp()\n    min = 0;\n\n    @Input()\n    @tuiDefaultProp()\n    max = Infinity;\n\n    @Input()\n    @tuiDefaultProp()\n    minLabel = '';\n\n    @Input()\n    @tuiDefaultProp()\n    maxLabel = '';\n\n    @Input()\n    @tuiDefaultProp()\n    pluralize: TuiPluralize | null = null;\n\n    @Input()\n    @tuiDefaultProp()\n    segmentsPluralize: TuiPluralize | null = null;\n\n    @Input()\n    @tuiDefaultProp()\n    segments = 0;\n\n    @Input()\n    @tuiDefaultProp()\n    steps = 0;\n\n    @Input()\n    @tuiDefaultProp(quantumAssertion, 'Quantum must be positive')\n    quantum = 1;\n\n    @Input()\n    @tuiDefaultProp()\n    keySteps: TuiKeySteps | null = null;\n\n    @Input()\n    @HostBinding('attr.data-tui-host-size')\n    size: TuiSizeL = 'l';\n\n    mask: TuiMapper<number, TuiTextMaskOptions> = (quantum: number, min: number) => ({\n        mask: tuiCreateNumberMask({\n            allowNegative: min < 0,\n            allowDecimal: !Number.isInteger(quantum),\n        }),\n        pipe: tuiCreateAutoCorrectedNumberPipe(),\n        guide: false,\n    });\n\n    protected abstract readonly modeDirective: TuiModeDirective | null;\n\n    @HostBinding('class._segmented')\n    get segmented(): boolean {\n        return this.segments > 0;\n    }\n\n    get hasPlaceholder(): boolean {\n        return this.size === 'l';\n    }\n\n    get inputMode(): TuiInputMode {\n        return Number.isInteger(this.quantum)\n            ? TuiInputMode.Numeric\n            : TuiInputMode.Decimal;\n    }\n\n    get length(): number {\n        return this.max - this.min;\n    }\n\n    get computedSteps(): number {\n        return this.steps || this.length / this.quantum;\n    }\n\n    get step(): number {\n        return this.length / this.computedSteps;\n    }\n\n    @HostBinding('attr.data-mode')\n    get hostMode(): TuiBrightness | null {\n        return this.modeDirective && this.modeDirective.mode;\n    }\n\n    abstract get showMinLabel(): boolean;\n\n    abstract get showMaxLabel(): boolean;\n\n    onHovered(hovered: boolean) {\n        this.updateHovered(hovered);\n    }\n\n    isPluralized(pluralize: TuiPluralize | null): pluralize is TuiPluralize {\n        return pluralize !== null && pluralize.length === 3;\n    }\n\n    protected valueGuard(value: number): number {\n        return this.quantum\n            ? clamp(\n                  round(\n                      Math.round(value / this.quantum) * this.quantum,\n                      TUI_FLOATING_PRECISION,\n                  ),\n                  this.min,\n                  this.max,\n              )\n            : clamp(value, this.min, this.max);\n    }\n\n    protected capInputValue(value: string, max: number = this.max): number | null {\n        const capped = Math.min(maskedNumberStringToNumber(value), max);\n\n        if (this.min < 0 && capped < this.min) {\n            return this.min;\n        }\n\n        return isNaN(capped) || capped < this.min ? null : capped;\n    }\n}\n"]}