@taiga-ui/kit
Version:
Taiga UI Angular main components kit
131 lines • 13.4 kB
JavaScript
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"]}