@taiga-ui/kit
Version:
Taiga UI Angular main components kit
163 lines • 15.3 kB
JavaScript
import { __decorate, __extends } 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
*/
var AbstractTuiInputSlider = /** @class */ (function (_super) {
__extends(AbstractTuiInputSlider, _super);
function AbstractTuiInputSlider() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_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 = function (quantum, min) { return ({
mask: tuiCreateNumberMask({
allowNegative: min < 0,
allowDecimal: !Number.isInteger(quantum),
}),
pipe: tuiCreateAutoCorrectedNumberPipe(),
guide: false,
}); };
return _this;
}
Object.defineProperty(AbstractTuiInputSlider.prototype, "segmented", {
get: function () {
return this.segments > 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(AbstractTuiInputSlider.prototype, "hasPlaceholder", {
get: function () {
return this.size === 'l';
},
enumerable: true,
configurable: true
});
Object.defineProperty(AbstractTuiInputSlider.prototype, "inputMode", {
get: function () {
return Number.isInteger(this.quantum)
? "numeric" /* Numeric */
: "decimal" /* Decimal */;
},
enumerable: true,
configurable: true
});
Object.defineProperty(AbstractTuiInputSlider.prototype, "length", {
get: function () {
return this.max - this.min;
},
enumerable: true,
configurable: true
});
Object.defineProperty(AbstractTuiInputSlider.prototype, "computedSteps", {
get: function () {
return this.steps || this.length / this.quantum;
},
enumerable: true,
configurable: true
});
Object.defineProperty(AbstractTuiInputSlider.prototype, "step", {
get: function () {
return this.length / this.computedSteps;
},
enumerable: true,
configurable: true
});
Object.defineProperty(AbstractTuiInputSlider.prototype, "hostMode", {
get: function () {
return this.modeDirective && this.modeDirective.mode;
},
enumerable: true,
configurable: true
});
AbstractTuiInputSlider.prototype.onHovered = function (hovered) {
this.updateHovered(hovered);
};
AbstractTuiInputSlider.prototype.isPluralized = function (pluralize) {
return pluralize !== null && pluralize.length === 3;
};
AbstractTuiInputSlider.prototype.valueGuard = function (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);
};
AbstractTuiInputSlider.prototype.capInputValue = function (value, max) {
if (max === void 0) { max = this.max; }
var 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);
return AbstractTuiInputSlider;
}(AbstractTuiControl));
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"]}