UNPKG

@taiga-ui/kit

Version:
266 lines • 32 kB
import { __decorate, __extends, __param } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, HostListener, Inject, Input, Optional, Self, ViewChild, } from '@angular/core'; import { NgControl } from '@angular/forms'; import { AbstractTuiNullableControl, TUI_FOCUSABLE_ITEM_ACCESSOR, tuiDefaultProp, } from '@taiga-ui/cdk'; import { formatNumber, maskedMoneyValueIsEmpty, maskedNumberStringToNumber, tuiCreateAutoCorrectedNumberPipe, tuiCreateNumberMask, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core'; var DEFAULT_MAX_LENGTH = 18; // @dynamic var TuiInputNumberComponent = /** @class */ (function (_super) { __extends(TuiInputNumberComponent, _super); function TuiInputNumberComponent(control, changeDetectorRef) { var _this = _super.call(this, control, changeDetectorRef) || this; _this.min = -Infinity; _this.max = Infinity; _this.decimal = "not-zero" /* NotZero */; _this.precision = 2; _this.postfix = ''; _this.mask = function (allowNegative, decimal, precision, nativeFocusableElement) { return ({ mask: tuiCreateNumberMask({ allowNegative: allowNegative, allowDecimal: decimal !== 'never', decimalLimit: precision, requireDecimal: decimal === 'always', }), pipe: tuiCreateAutoCorrectedNumberPipe(decimal === 'always' ? precision : 0, ',', nativeFocusableElement || undefined), guide: false, }); }; return _this; } TuiInputNumberComponent_1 = TuiInputNumberComponent; Object.defineProperty(TuiInputNumberComponent.prototype, "nativeFocusableElement", { get: function () { return !this.primitiveTextfield || this.computedDisabled ? null : this.primitiveTextfield.nativeFocusableElement; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputNumberComponent.prototype, "focused", { get: function () { return !!this.primitiveTextfield && this.primitiveTextfield.focused; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputNumberComponent.prototype, "isNegativeAllowed", { get: function () { return this.min < 0; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputNumberComponent.prototype, "inputMode", { get: function () { return this.decimal === 'never' ? "numeric" /* Numeric */ : "decimal" /* Decimal */; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputNumberComponent.prototype, "calculatedMaxLength", { get: function () { return (DEFAULT_MAX_LENGTH + (this.decimal !== "never" /* Never */ && this.nativeValue.includes(',') ? this.precision + 1 : 0)); }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputNumberComponent.prototype, "formattedValue", { get: function () { var value = this.value || 0; var absValue = Math.abs(value); var hasFraction = absValue % 1 > 0; var limit = this.decimal === 'always' || hasFraction ? this.precision : 0; var fraction = hasFraction ? value.toString().split('.')[1].substr(0, this.precision) : ''; if (this.focused && this.decimal !== 'always') { limit = fraction.length; } return formatNumber(value, limit); }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputNumberComponent.prototype, "computedValue", { get: function () { if (this.focused || !this.isNativeValueInLimit) { return this.nativeValue; } if (this.value === null) { return maskedMoneyValueIsEmpty(this.nativeValue) ? this.nativeValue : ''; } return this.formattedValue; }, enumerable: true, configurable: true }); TuiInputNumberComponent.prototype.onValue = function (value) { if (maskedMoneyValueIsEmpty(value)) { this.updateValue(null); return; } if (this.isNativeValueNotFinished) { return; } var capped = this.absoluteCapInputValue(value); if (capped === null || isNaN(capped)) { return; } this.updateValue(capped); if (capped !== maskedNumberStringToNumber(value)) { this.nativeValue = this.formattedValue; } }; TuiInputNumberComponent.prototype.onKeyDown = function (event) { if (event.key !== ',' && event.key !== '.') { return; } if (this.decimal === 'never') { event.preventDefault(); return; } if (this.nativeValue.includes(',')) { event.preventDefault(); this.setCaretAfterComma(); } }; TuiInputNumberComponent.prototype.onFocused = function (focused) { this.updateFocused(focused); if (focused) { return; } var nativeNumberValue = maskedNumberStringToNumber(this.nativeValue); if (isNaN(nativeNumberValue)) { this.clear(); return; } var clamped = Math.min(this.max, Math.max(this.min, nativeNumberValue)); this.updateValue(clamped); this.nativeValue = this.formattedValue; }; TuiInputNumberComponent.prototype.onHovered = function (hovered) { this.updateHovered(hovered); }; TuiInputNumberComponent.prototype.onPressed = function (pressed) { this.updatePressed(pressed); }; TuiInputNumberComponent.prototype.onZero = function (event) { var decimal = this.nativeValue.split(',')[1] || ''; var nativeFocusableElement = this.nativeFocusableElement; if (decimal.length < this.precision || !nativeFocusableElement || !nativeFocusableElement.selectionStart || this.nativeValue[nativeFocusableElement.selectionStart] !== '0') { return; } event.preventDefault(); nativeFocusableElement.selectionStart++; }; Object.defineProperty(TuiInputNumberComponent.prototype, "isNativeValueInLimit", { get: function () { if (this.nativeValue === '') { return true; } var nativeNumberValue = maskedNumberStringToNumber(this.nativeValue); return nativeNumberValue >= this.min && nativeNumberValue <= this.max; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputNumberComponent.prototype, "isNativeValueNotFinished", { get: function () { var nativeNumberValue = maskedNumberStringToNumber(this.nativeValue); return nativeNumberValue < 0 ? nativeNumberValue > this.max : nativeNumberValue < this.min; }, enumerable: true, configurable: true }); Object.defineProperty(TuiInputNumberComponent.prototype, "nativeValue", { get: function () { return this.nativeFocusableElement ? this.nativeFocusableElement.value : ''; }, set: function (value) { if (!this.primitiveTextfield || !this.nativeFocusableElement) { return; } this.primitiveTextfield.value = value; this.nativeFocusableElement.value = value; }, enumerable: true, configurable: true }); TuiInputNumberComponent.prototype.clear = function () { this.nativeValue = ''; this.updateValue(null); }; TuiInputNumberComponent.prototype.absoluteCapInputValue = function (inputValue) { var value = maskedNumberStringToNumber(inputValue); var capped = value < 0 ? Math.max(this.min, value) : Math.min(value, this.max); var ineligibleValue = isNaN(capped) || capped < this.min || capped > this.max; return ineligibleValue ? null : capped; }; TuiInputNumberComponent.prototype.setCaretAfterComma = function () { if (!this.nativeFocusableElement) { return; } var afterCommaPosition = this.nativeValue.length - this.precision; this.nativeFocusableElement.setSelectionRange(afterCommaPosition, afterCommaPosition); }; var TuiInputNumberComponent_1; TuiInputNumberComponent.ctorParameters = function () { return [ { type: NgControl, decorators: [{ type: Optional }, { type: Self }, { type: Inject, args: [NgControl,] }] }, { type: ChangeDetectorRef, decorators: [{ type: Inject, args: [ChangeDetectorRef,] }] } ]; }; __decorate([ Input(), tuiDefaultProp() ], TuiInputNumberComponent.prototype, "min", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputNumberComponent.prototype, "max", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputNumberComponent.prototype, "decimal", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputNumberComponent.prototype, "precision", void 0); __decorate([ Input(), tuiDefaultProp() ], TuiInputNumberComponent.prototype, "postfix", void 0); __decorate([ ViewChild(TuiPrimitiveTextfieldComponent) ], TuiInputNumberComponent.prototype, "primitiveTextfield", void 0); __decorate([ HostListener('keydown.0', ['$event']) ], TuiInputNumberComponent.prototype, "onZero", null); TuiInputNumberComponent = TuiInputNumberComponent_1 = __decorate([ Component({ selector: 'tui-input-number', template: "<tui-primitive-textfield\n class=\"textfield\"\n tuiValueAccessor\n tuiTextfieldInputMode=\"decimal\"\n [pseudoHovered]=\"pseudoHovered\"\n [pseudoFocused]=\"computedFocused\"\n [invalid]=\"computedInvalid\"\n [tuiTextfieldMaxLength]=\"calculatedMaxLength\"\n [readOnly]=\"readOnly\"\n [disabled]=\"computedDisabled\"\n [textMask]=\"isNegativeAllowed | tuiMapper: mask:decimal:precision:nativeFocusableElement\"\n [value]=\"computedValue\"\n [postfix]=\"postfix\"\n [focusable]=\"focusable\"\n (valueChange)=\"onValue($event)\"\n (hoveredChange)=\"onHovered($event)\"\n (focusedChange)=\"onFocused($event)\"\n (pressedChange)=\"onPressed($event)\"\n (keydown)=\"onKeyDown($event)\"\n>\n <ng-content></ng-content>\n</tui-primitive-textfield>\n", changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: TUI_FOCUSABLE_ITEM_ACCESSOR, useExisting: forwardRef(function () { return TuiInputNumberComponent_1; }), }, ], styles: [":host{display:block;border-radius:var(--tui-radius-m)}.textfield{border-radius:inherit}"] }), __param(0, Optional()), __param(0, Self()), __param(0, Inject(NgControl)), __param(1, Inject(ChangeDetectorRef)) ], TuiInputNumberComponent); return TuiInputNumberComponent; }(AbstractTuiNullableControl)); export { TuiInputNumberComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"ng://@taiga-ui/kit/components/input-number/","sources":["input-number.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    forwardRef,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    TUI_FOCUSABLE_ITEM_ACCESSOR,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    TuiInputMode,\n    TuiMapper,\n} from '@taiga-ui/cdk';\nimport {\n    formatNumber,\n    maskedMoneyValueIsEmpty,\n    maskedNumberStringToNumber,\n    tuiCreateAutoCorrectedNumberPipe,\n    tuiCreateNumberMask,\n    TuiDecimal,\n    TuiPrimitiveTextfieldComponent,\n    TuiTextMaskOptions,\n} from '@taiga-ui/core';\n\nconst DEFAULT_MAX_LENGTH = 18;\n\n// @dynamic\n@Component({\n    selector: 'tui-input-number',\n    templateUrl: './input-number.template.html',\n    styleUrls: ['./input-number.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: TUI_FOCUSABLE_ITEM_ACCESSOR,\n            useExisting: forwardRef(() => TuiInputNumberComponent),\n        },\n    ],\n})\nexport class TuiInputNumberComponent\n    extends AbstractTuiNullableControl<number>\n    implements TuiFocusableElementAccessor {\n    @Input()\n    @tuiDefaultProp()\n    min = -Infinity;\n\n    @Input()\n    @tuiDefaultProp()\n    max = Infinity;\n\n    @Input()\n    @tuiDefaultProp()\n    decimal: TuiDecimal = TuiDecimal.NotZero;\n\n    @Input()\n    @tuiDefaultProp()\n    precision = 2;\n\n    @Input()\n    @tuiDefaultProp()\n    postfix = '';\n\n    mask: TuiMapper<boolean, TuiTextMaskOptions> = (\n        allowNegative: boolean,\n        decimal: TuiDecimal,\n        precision: number,\n        nativeFocusableElement: HTMLInputElement | null,\n    ) => ({\n        mask: tuiCreateNumberMask({\n            allowNegative: allowNegative,\n            allowDecimal: decimal !== 'never',\n            decimalLimit: precision,\n            requireDecimal: decimal === 'always',\n        }),\n        pipe: tuiCreateAutoCorrectedNumberPipe(\n            decimal === 'always' ? precision : 0,\n            ',',\n            nativeFocusableElement || undefined,\n        ),\n        guide: false,\n    });\n\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly primitiveTextfield?: TuiPrimitiveTextfieldComponent;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return !this.primitiveTextfield || this.computedDisabled\n            ? null\n            : this.primitiveTextfield.nativeFocusableElement;\n    }\n\n    get focused(): boolean {\n        return !!this.primitiveTextfield && this.primitiveTextfield.focused;\n    }\n\n    get isNegativeAllowed(): boolean {\n        return this.min < 0;\n    }\n\n    get inputMode(): TuiInputMode {\n        return this.decimal === 'never' ? TuiInputMode.Numeric : TuiInputMode.Decimal;\n    }\n\n    get calculatedMaxLength(): number {\n        return (\n            DEFAULT_MAX_LENGTH +\n            (this.decimal !== TuiDecimal.Never && this.nativeValue.includes(',')\n                ? this.precision + 1\n                : 0)\n        );\n    }\n\n    get formattedValue(): string {\n        const value = this.value || 0;\n        const absValue = Math.abs(value);\n        const hasFraction = absValue % 1 > 0;\n        let limit = this.decimal === 'always' || hasFraction ? this.precision : 0;\n\n        const fraction = hasFraction\n            ? value.toString().split('.')[1].substr(0, this.precision)\n            : '';\n\n        if (this.focused && this.decimal !== 'always') {\n            limit = fraction.length;\n        }\n\n        return formatNumber(value, limit);\n    }\n\n    get computedValue(): string {\n        if (this.focused || !this.isNativeValueInLimit) {\n            return this.nativeValue;\n        }\n\n        if (this.value === null) {\n            return maskedMoneyValueIsEmpty(this.nativeValue) ? this.nativeValue : '';\n        }\n\n        return this.formattedValue;\n    }\n\n    onValue(value: string) {\n        if (maskedMoneyValueIsEmpty(value)) {\n            this.updateValue(null);\n\n            return;\n        }\n\n        if (this.isNativeValueNotFinished) {\n            return;\n        }\n\n        const capped = this.absoluteCapInputValue(value);\n\n        if (capped === null || isNaN(capped)) {\n            return;\n        }\n\n        this.updateValue(capped);\n\n        if (capped !== maskedNumberStringToNumber(value)) {\n            this.nativeValue = this.formattedValue;\n        }\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        if (event.key !== ',' && event.key !== '.') {\n            return;\n        }\n\n        if (this.decimal === 'never') {\n            event.preventDefault();\n\n            return;\n        }\n\n        if (this.nativeValue.includes(',')) {\n            event.preventDefault();\n            this.setCaretAfterComma();\n        }\n    }\n\n    onFocused(focused: boolean) {\n        this.updateFocused(focused);\n\n        if (focused) {\n            return;\n        }\n\n        const nativeNumberValue = maskedNumberStringToNumber(this.nativeValue);\n\n        if (isNaN(nativeNumberValue)) {\n            this.clear();\n\n            return;\n        }\n\n        const clamped = Math.min(this.max, Math.max(this.min, nativeNumberValue));\n\n        this.updateValue(clamped);\n        this.nativeValue = this.formattedValue;\n    }\n\n    onHovered(hovered: boolean) {\n        this.updateHovered(hovered);\n    }\n\n    onPressed(pressed: boolean) {\n        this.updatePressed(pressed);\n    }\n\n    @HostListener('keydown.0', ['$event'])\n    onZero(event: KeyboardEvent) {\n        const decimal = this.nativeValue.split(',')[1] || '';\n        const {nativeFocusableElement} = this;\n\n        if (\n            decimal.length < this.precision ||\n            !nativeFocusableElement ||\n            !nativeFocusableElement.selectionStart ||\n            this.nativeValue[nativeFocusableElement.selectionStart] !== '0'\n        ) {\n            return;\n        }\n\n        event.preventDefault();\n        nativeFocusableElement.selectionStart++;\n    }\n\n    private get isNativeValueInLimit(): boolean {\n        if (this.nativeValue === '') {\n            return true;\n        }\n\n        const nativeNumberValue = maskedNumberStringToNumber(this.nativeValue);\n\n        return nativeNumberValue >= this.min && nativeNumberValue <= this.max;\n    }\n\n    private get isNativeValueNotFinished(): boolean {\n        const nativeNumberValue = maskedNumberStringToNumber(this.nativeValue);\n\n        return nativeNumberValue < 0\n            ? nativeNumberValue > this.max\n            : nativeNumberValue < this.min;\n    }\n\n    private get nativeValue(): string {\n        return this.nativeFocusableElement ? this.nativeFocusableElement.value : '';\n    }\n\n    private set nativeValue(value: string) {\n        if (!this.primitiveTextfield || !this.nativeFocusableElement) {\n            return;\n        }\n\n        this.primitiveTextfield.value = value;\n        this.nativeFocusableElement.value = value;\n    }\n\n    private clear() {\n        this.nativeValue = '';\n        this.updateValue(null);\n    }\n\n    private absoluteCapInputValue(inputValue: string): number | null {\n        const value = maskedNumberStringToNumber(inputValue);\n        const capped = value < 0 ? Math.max(this.min, value) : Math.min(value, this.max);\n        const ineligibleValue = isNaN(capped) || capped < this.min || capped > this.max;\n\n        return ineligibleValue ? null : capped;\n    }\n\n    private setCaretAfterComma() {\n        if (!this.nativeFocusableElement) {\n            return;\n        }\n\n        const afterCommaPosition = this.nativeValue.length - this.precision;\n\n        this.nativeFocusableElement.setSelectionRange(\n            afterCommaPosition,\n            afterCommaPosition,\n        );\n    }\n}\n"]}