@taiga-ui/kit 4.50.0 → 4.51.0-canary.2b42d75

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. package/components/index.d.ts +2 -0
  2. package/components/input-number/quantum.directive.d.ts +9 -2
  3. package/components/input-range/index.d.ts +2 -0
  4. package/components/input-range/input-range.component.d.ts +75 -0
  5. package/components/input-range/input-range.d.ts +3 -0
  6. package/components/range/range.component.d.ts +6 -0
  7. package/components/slider/helpers/slider-key-steps.directive.d.ts +2 -1
  8. package/components/slides/index.d.ts +1 -0
  9. package/components/slides/slides.directive.d.ts +11 -0
  10. package/directives/fade/fade.directive.d.ts +2 -1
  11. package/esm2022/components/avatar/avatar.component.mjs +3 -3
  12. package/esm2022/components/badged-content/badged-content.component.mjs +2 -3
  13. package/esm2022/components/combo-box/combo-box.directive.mjs +7 -3
  14. package/esm2022/components/confirm/confirm.component.mjs +3 -3
  15. package/esm2022/components/filter/filter.component.mjs +2 -3
  16. package/esm2022/components/index.mjs +3 -1
  17. package/esm2022/components/input-date-time/input-date-time.directive.mjs +7 -3
  18. package/esm2022/components/input-number/input-number.directive.mjs +8 -4
  19. package/esm2022/components/input-number/quantum.directive.mjs +23 -11
  20. package/esm2022/components/input-range/index.mjs +3 -0
  21. package/esm2022/components/input-range/input-range.component.mjs +166 -0
  22. package/esm2022/components/input-range/input-range.mjs +4 -0
  23. package/esm2022/components/input-range/taiga-ui-kit-components-input-range.mjs +5 -0
  24. package/esm2022/components/input-time/input-time.directive.mjs +7 -3
  25. package/esm2022/components/radio-list/radio-list.component.mjs +3 -10
  26. package/esm2022/components/range/range.component.mjs +18 -7
  27. package/esm2022/components/slider/helpers/slider-key-steps.directive.mjs +3 -2
  28. package/esm2022/components/slides/index.mjs +2 -0
  29. package/esm2022/components/slides/slides.directive.mjs +51 -0
  30. package/esm2022/components/slides/taiga-ui-kit-components-slides.mjs +5 -0
  31. package/esm2022/components/stepper/step.component.mjs +3 -2
  32. package/esm2022/components/switch/switch.component.mjs +2 -2
  33. package/esm2022/components/textarea/textarea.component.mjs +3 -3
  34. package/esm2022/directives/fade/fade.directive.mjs +5 -2
  35. package/esm2022/directives/skeleton/skeleton.directive.mjs +2 -2
  36. package/fesm2022/taiga-ui-kit-components-avatar.mjs +2 -2
  37. package/fesm2022/taiga-ui-kit-components-avatar.mjs.map +1 -1
  38. package/fesm2022/taiga-ui-kit-components-badged-content.mjs +19 -19
  39. package/fesm2022/taiga-ui-kit-components-badged-content.mjs.map +1 -1
  40. package/fesm2022/taiga-ui-kit-components-combo-box.mjs +6 -2
  41. package/fesm2022/taiga-ui-kit-components-combo-box.mjs.map +1 -1
  42. package/fesm2022/taiga-ui-kit-components-confirm.mjs +2 -2
  43. package/fesm2022/taiga-ui-kit-components-confirm.mjs.map +1 -1
  44. package/fesm2022/taiga-ui-kit-components-filter.mjs +1 -2
  45. package/fesm2022/taiga-ui-kit-components-filter.mjs.map +1 -1
  46. package/fesm2022/taiga-ui-kit-components-input-date-time.mjs +6 -2
  47. package/fesm2022/taiga-ui-kit-components-input-date-time.mjs.map +1 -1
  48. package/fesm2022/taiga-ui-kit-components-input-number.mjs +28 -13
  49. package/fesm2022/taiga-ui-kit-components-input-number.mjs.map +1 -1
  50. package/fesm2022/taiga-ui-kit-components-input-range.mjs +175 -0
  51. package/fesm2022/taiga-ui-kit-components-input-range.mjs.map +1 -0
  52. package/fesm2022/taiga-ui-kit-components-input-time.mjs +6 -2
  53. package/fesm2022/taiga-ui-kit-components-input-time.mjs.map +1 -1
  54. package/fesm2022/taiga-ui-kit-components-radio-list.mjs +2 -9
  55. package/fesm2022/taiga-ui-kit-components-radio-list.mjs.map +1 -1
  56. package/fesm2022/taiga-ui-kit-components-range.mjs +17 -6
  57. package/fesm2022/taiga-ui-kit-components-range.mjs.map +1 -1
  58. package/fesm2022/taiga-ui-kit-components-slider.mjs +2 -1
  59. package/fesm2022/taiga-ui-kit-components-slider.mjs.map +1 -1
  60. package/fesm2022/taiga-ui-kit-components-slides.mjs +57 -0
  61. package/fesm2022/taiga-ui-kit-components-slides.mjs.map +1 -0
  62. package/fesm2022/taiga-ui-kit-components-stepper.mjs +2 -1
  63. package/fesm2022/taiga-ui-kit-components-stepper.mjs.map +1 -1
  64. package/fesm2022/taiga-ui-kit-components-switch.mjs +2 -2
  65. package/fesm2022/taiga-ui-kit-components-switch.mjs.map +1 -1
  66. package/fesm2022/taiga-ui-kit-components-textarea.mjs +2 -2
  67. package/fesm2022/taiga-ui-kit-components-textarea.mjs.map +1 -1
  68. package/fesm2022/taiga-ui-kit-components.mjs +2 -0
  69. package/fesm2022/taiga-ui-kit-components.mjs.map +1 -1
  70. package/fesm2022/taiga-ui-kit-directives-fade.mjs +4 -1
  71. package/fesm2022/taiga-ui-kit-directives-fade.mjs.map +1 -1
  72. package/fesm2022/taiga-ui-kit-directives-skeleton.mjs +1 -1
  73. package/fesm2022/taiga-ui-kit-directives-skeleton.mjs.map +1 -1
  74. package/package.json +34 -22
  75. package/styles/components/switch.less +2 -1
@@ -72,8 +72,12 @@ class TuiInputDateTimeDirective extends TuiInputDateBase {
72
72
  setTimeout((caretIndex = DATE_FILLER_LENGTH + this.options.dateTimeSeparator.length) => this.el.setSelectionRange(caretIndex, caretIndex));
73
73
  }
74
74
  writeValue(value) {
75
- super.writeValue(value);
76
- untracked(() => this.textfield.value.set(this.stringify(this.value())));
75
+ const reset = this.control.pristine && this.control.untouched && !value;
76
+ const changed = untracked(() => value !== this.value());
77
+ if (changed || reset) {
78
+ super.writeValue(value);
79
+ untracked(() => this.textfield.value.set(this.stringify(this.value())));
80
+ }
77
81
  }
78
82
  processCalendar(calendar) {
79
83
  super.processCalendar(calendar);
@@ -171,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
171
175
  type: Input,
172
176
  args: ['max']
173
177
  }] } });
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-time.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date-time/input-date-time.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    computed,\n    Directive,\n    effect,\n    inject,\n    Input,\n    signal,\n    untracked,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {type MaskitoOptions} from '@maskito/core';\nimport {\n    maskitoDateTimeOptionsGenerator,\n    type MaskitoDateTimeParams,\n    maskitoSelectionChangeHandler,\n    type MaskitoTimeMode,\n} from '@maskito/kit';\nimport {tuiAsControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {\n    DATE_FILLER_LENGTH,\n    MILLISECONDS_IN_DAY,\n    TuiDay,\n    TuiTime,\n} from '@taiga-ui/cdk/date-time';\nimport {tuiClamp, tuiSum} from '@taiga-ui/cdk/utils/math';\nimport {tuiDirectiveBinding} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {type TuiCalendar} from '@taiga-ui/core/components/calendar';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport {\n    tuiAsTextfieldAccessor,\n    type TuiTextfieldAccessor,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {TuiDropdownAuto} from '@taiga-ui/core/directives/dropdown';\nimport {TuiItemsHandlersValidator} from '@taiga-ui/core/directives/items-handlers';\nimport {\n    TUI_DATE_ADAPTER,\n    TuiInputDateBase,\n    tuiWithDateFiller,\n} from '@taiga-ui/kit/components/input-date';\nimport {TuiSelectOption} from '@taiga-ui/kit/components/select';\nimport {TUI_TIME_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\nimport {noop} from 'rxjs';\n\nimport {TUI_INPUT_DATE_TIME_OPTIONS} from './input-date-time.options';\n\nconst MIN_TIME = new TuiTime(0, 0);\nconst MAX_TIME = TuiTime.fromAbsoluteMilliseconds(MILLISECONDS_IN_DAY - 1);\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputDateTime]',\n    providers: [\n        tuiAsOptionContent(TuiSelectOption),\n        tuiAsControl(TuiInputDateTimeDirective),\n        tuiAsTextfieldAccessor(TuiInputDateTimeDirective),\n        tuiValueTransformerFrom(TUI_INPUT_DATE_TIME_OPTIONS),\n    ],\n    hostDirectives: [\n        MaskitoDirective,\n        TuiDropdownAuto,\n        TuiItemsHandlersValidator,\n        TuiWithTextfield,\n    ],\n})\nexport class TuiInputDateTimeDirective\n    extends TuiInputDateBase<readonly [TuiDay, TuiTime | null]>\n    implements TuiTextfieldAccessor<readonly [TuiDay, TuiTime | null]>\n{\n    private readonly timeFillers = toSignal(inject(TUI_TIME_TEXTS));\n\n    protected override readonly options = inject(TUI_INPUT_DATE_TIME_OPTIONS);\n\n    protected override readonly filler = tuiWithDateFiller((date) => {\n        const time = this.timeFillers()?.[this.timeMode()] ?? '';\n\n        return `${date}${this.options.dateTimeSeparator}${time}`;\n    });\n\n    protected override valueEffect = effect(noop);\n\n    protected readonly identity = this.handlers.identityMatcher.set(\n        (a, b) => tuiSum(...a.map(Number)) === tuiSum(...b.map(Number)),\n    );\n\n    protected readonly disabledItemHandler = tuiDirectiveBinding(\n        TuiItemsHandlersValidator,\n        'disabledItemHandler',\n        (value: readonly [TuiDay, TuiTime | null] | null) =>\n            Boolean(value && this.handlers.disabledItemHandler()(value)),\n    );\n\n    protected readonly mask = tuiMaskito(\n        computed(() =>\n            this.computeMask({\n                dateMode: TUI_DATE_ADAPTER[this.format().mode],\n                timeMode: this.timeMode(),\n                min: this.toNativeDate([this.min(), this.minTime()]),\n                max: this.toNativeDate([this.max(), this.maxTime()]),\n                dateSeparator: this.format().separator,\n                dateTimeSeparator: this.options.dateTimeSeparator,\n            }),\n        ),\n    );\n\n    public readonly timeMode = signal(this.options.timeMode);\n    public readonly minTime = signal(MIN_TIME);\n    public readonly maxTime = signal(MAX_TIME);\n\n    // TODO(v5): use signal inputs\n    @Input('timeMode')\n    public set timeModeSetter(x: MaskitoTimeMode) {\n        this.timeMode.set(x);\n    }\n\n    @Input('min')\n    public override set minSetter(\n        min: TuiDay | readonly [TuiDay, TuiTime | null] | null,\n    ) {\n        const [date, time] = Array.isArray(min) ? min : [min, null];\n\n        this.min.set(date || this.options.min);\n        this.minTime.set(time ?? MIN_TIME);\n    }\n\n    @Input('max')\n    public override set maxSetter(\n        max: TuiDay | readonly [TuiDay, TuiTime | null] | null,\n    ) {\n        const [date, time] = Array.isArray(max) ? max : [max, null];\n\n        this.max.set(date || this.options.max);\n        this.maxTime.set(time ?? MAX_TIME);\n    }\n\n    public setValue(value: readonly [TuiDay, TuiTime | null] | null): void {\n        this.onChange(value);\n        this.textfield.value.set(this.stringify(value));\n    }\n\n    public override setDate(newDate: TuiDay): void {\n        const [date, time] = this.clampTime([newDate, this.value()?.[1] ?? null]);\n\n        this.setValue([date, time]);\n        this.open.set(false);\n        setTimeout(\n            (caretIndex = DATE_FILLER_LENGTH + this.options.dateTimeSeparator.length) =>\n                this.el.setSelectionRange(caretIndex, caretIndex),\n        );\n    }\n\n    public override writeValue(value: [TuiDay, TuiTime | null] | null): void {\n        super.writeValue(value);\n        untracked(() => this.textfield.value.set(this.stringify(this.value())));\n    }\n\n    protected override processCalendar(calendar: TuiCalendar): void {\n        super.processCalendar(calendar);\n        calendar.disabledItemHandler = (day: TuiDay) =>\n            this.handlers.disabledItemHandler()([day, null]);\n    }\n\n    protected override onValueChange(value: string): void {\n        this.textfield.value.set(value);\n        this.control?.control?.updateValueAndValidity({emitEvent: false});\n\n        const [date = '', time = ''] = value.split(this.options.dateTimeSeparator);\n        const parsedDate =\n            date.length >= DATE_FILLER_LENGTH\n                ? TuiDay.normalizeParse(date, this.format().mode)\n                : null;\n        const parsedTime =\n            time.length === this.timeMode().length ? TuiTime.fromString(time) : null;\n\n        if (!parsedDate || (time && !parsedTime)) {\n            return this.onChange(null);\n        }\n\n        const [prevDate, prevTime = null] = this.value() ?? [];\n\n        if (!prevDate?.daySame(parsedDate) || Number(parsedTime) !== Number(prevTime)) {\n            this.onChange([parsedDate, parsedTime]);\n        }\n    }\n\n    protected override stringify(\n        value: readonly [TuiDay, TuiTime | null] | null,\n    ): string {\n        const [date, time] = value ?? [];\n\n        const dateString =\n            date?.toString(this.format().mode, this.format().separator) ?? '';\n        const timeString = time?.toString(this.timeMode());\n\n        return timeString\n            ? `${dateString}${this.options.dateTimeSeparator}${timeString}`\n            : dateString;\n    }\n\n    private clampTime([date, time]: [TuiDay, TuiTime | null]): [TuiDay, TuiTime | null] {\n        const min = date.daySame(this.min())\n            ? this.minTime().toAbsoluteMilliseconds()\n            : -Infinity;\n        const max = date.daySame(this.max())\n            ? this.maxTime().toAbsoluteMilliseconds()\n            : Infinity;\n\n        return [\n            date,\n            time &&\n                TuiTime.fromAbsoluteMilliseconds(\n                    tuiClamp(time.toAbsoluteMilliseconds(), min, max),\n                ),\n        ];\n    }\n\n    private computeMask(\n        params: Omit<Required<MaskitoDateTimeParams>, 'timeStep'>,\n    ): MaskitoOptions {\n        const options = maskitoDateTimeOptionsGenerator(params);\n        const {timeMode, dateMode, dateTimeSeparator} = params;\n        const inputModeSwitchPlugin = maskitoSelectionChangeHandler((element) => {\n            element.inputMode =\n                element.selectionStart! >=\n                dateMode.length + dateTimeSeparator.length + timeMode.indexOf(' AA')\n                    ? 'text'\n                    : 'numeric';\n        });\n\n        return {\n            ...options,\n            plugins: options.plugins.concat(\n                timeMode.includes('AA') ? inputModeSwitchPlugin : [],\n            ),\n        };\n    }\n\n    private toNativeDate([{year, month, day}, {hours, minutes, seconds, ms}]: readonly [\n        TuiDay,\n        TuiTime,\n    ]): Date {\n        return new Date(year, month, day, hours, minutes, seconds, ms);\n    }\n}\n"]}
178
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-time.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date-time/input-date-time.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    computed,\n    Directive,\n    effect,\n    inject,\n    Input,\n    signal,\n    untracked,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {type MaskitoOptions} from '@maskito/core';\nimport {\n    maskitoDateTimeOptionsGenerator,\n    type MaskitoDateTimeParams,\n    maskitoSelectionChangeHandler,\n    type MaskitoTimeMode,\n} from '@maskito/kit';\nimport {tuiAsControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {\n    DATE_FILLER_LENGTH,\n    MILLISECONDS_IN_DAY,\n    TuiDay,\n    TuiTime,\n} from '@taiga-ui/cdk/date-time';\nimport {tuiClamp, tuiSum} from '@taiga-ui/cdk/utils/math';\nimport {tuiDirectiveBinding} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {type TuiCalendar} from '@taiga-ui/core/components/calendar';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport {\n    tuiAsTextfieldAccessor,\n    type TuiTextfieldAccessor,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {TuiDropdownAuto} from '@taiga-ui/core/directives/dropdown';\nimport {TuiItemsHandlersValidator} from '@taiga-ui/core/directives/items-handlers';\nimport {\n    TUI_DATE_ADAPTER,\n    TuiInputDateBase,\n    tuiWithDateFiller,\n} from '@taiga-ui/kit/components/input-date';\nimport {TuiSelectOption} from '@taiga-ui/kit/components/select';\nimport {TUI_TIME_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\nimport {noop} from 'rxjs';\n\nimport {TUI_INPUT_DATE_TIME_OPTIONS} from './input-date-time.options';\n\nconst MIN_TIME = new TuiTime(0, 0);\nconst MAX_TIME = TuiTime.fromAbsoluteMilliseconds(MILLISECONDS_IN_DAY - 1);\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputDateTime]',\n    providers: [\n        tuiAsOptionContent(TuiSelectOption),\n        tuiAsControl(TuiInputDateTimeDirective),\n        tuiAsTextfieldAccessor(TuiInputDateTimeDirective),\n        tuiValueTransformerFrom(TUI_INPUT_DATE_TIME_OPTIONS),\n    ],\n    hostDirectives: [\n        MaskitoDirective,\n        TuiDropdownAuto,\n        TuiItemsHandlersValidator,\n        TuiWithTextfield,\n    ],\n})\nexport class TuiInputDateTimeDirective\n    extends TuiInputDateBase<readonly [TuiDay, TuiTime | null]>\n    implements TuiTextfieldAccessor<readonly [TuiDay, TuiTime | null]>\n{\n    private readonly timeFillers = toSignal(inject(TUI_TIME_TEXTS));\n\n    protected override readonly options = inject(TUI_INPUT_DATE_TIME_OPTIONS);\n\n    protected override readonly filler = tuiWithDateFiller((date) => {\n        const time = this.timeFillers()?.[this.timeMode()] ?? '';\n\n        return `${date}${this.options.dateTimeSeparator}${time}`;\n    });\n\n    protected override valueEffect = effect(noop);\n\n    protected readonly identity = this.handlers.identityMatcher.set(\n        (a, b) => tuiSum(...a.map(Number)) === tuiSum(...b.map(Number)),\n    );\n\n    protected readonly disabledItemHandler = tuiDirectiveBinding(\n        TuiItemsHandlersValidator,\n        'disabledItemHandler',\n        (value: readonly [TuiDay, TuiTime | null] | null) =>\n            Boolean(value && this.handlers.disabledItemHandler()(value)),\n    );\n\n    protected readonly mask = tuiMaskito(\n        computed(() =>\n            this.computeMask({\n                dateMode: TUI_DATE_ADAPTER[this.format().mode],\n                timeMode: this.timeMode(),\n                min: this.toNativeDate([this.min(), this.minTime()]),\n                max: this.toNativeDate([this.max(), this.maxTime()]),\n                dateSeparator: this.format().separator,\n                dateTimeSeparator: this.options.dateTimeSeparator,\n            }),\n        ),\n    );\n\n    public readonly timeMode = signal(this.options.timeMode);\n    public readonly minTime = signal(MIN_TIME);\n    public readonly maxTime = signal(MAX_TIME);\n\n    // TODO(v5): use signal inputs\n    @Input('timeMode')\n    public set timeModeSetter(x: MaskitoTimeMode) {\n        this.timeMode.set(x);\n    }\n\n    @Input('min')\n    public override set minSetter(\n        min: TuiDay | readonly [TuiDay, TuiTime | null] | null,\n    ) {\n        const [date, time] = Array.isArray(min) ? min : [min, null];\n\n        this.min.set(date || this.options.min);\n        this.minTime.set(time ?? MIN_TIME);\n    }\n\n    @Input('max')\n    public override set maxSetter(\n        max: TuiDay | readonly [TuiDay, TuiTime | null] | null,\n    ) {\n        const [date, time] = Array.isArray(max) ? max : [max, null];\n\n        this.max.set(date || this.options.max);\n        this.maxTime.set(time ?? MAX_TIME);\n    }\n\n    public setValue(value: readonly [TuiDay, TuiTime | null] | null): void {\n        this.onChange(value);\n        this.textfield.value.set(this.stringify(value));\n    }\n\n    public override setDate(newDate: TuiDay): void {\n        const [date, time] = this.clampTime([newDate, this.value()?.[1] ?? null]);\n\n        this.setValue([date, time]);\n        this.open.set(false);\n        setTimeout(\n            (caretIndex = DATE_FILLER_LENGTH + this.options.dateTimeSeparator.length) =>\n                this.el.setSelectionRange(caretIndex, caretIndex),\n        );\n    }\n\n    public override writeValue(value: [TuiDay, TuiTime | null] | null): void {\n        const reset = this.control.pristine && this.control.untouched && !value;\n        const changed = untracked(() => value !== this.value());\n\n        if (changed || reset) {\n            super.writeValue(value);\n            untracked(() => this.textfield.value.set(this.stringify(this.value())));\n        }\n    }\n\n    protected override processCalendar(calendar: TuiCalendar): void {\n        super.processCalendar(calendar);\n        calendar.disabledItemHandler = (day: TuiDay) =>\n            this.handlers.disabledItemHandler()([day, null]);\n    }\n\n    protected override onValueChange(value: string): void {\n        this.textfield.value.set(value);\n        this.control?.control?.updateValueAndValidity({emitEvent: false});\n\n        const [date = '', time = ''] = value.split(this.options.dateTimeSeparator);\n        const parsedDate =\n            date.length >= DATE_FILLER_LENGTH\n                ? TuiDay.normalizeParse(date, this.format().mode)\n                : null;\n        const parsedTime =\n            time.length === this.timeMode().length ? TuiTime.fromString(time) : null;\n\n        if (!parsedDate || (time && !parsedTime)) {\n            return this.onChange(null);\n        }\n\n        const [prevDate, prevTime = null] = this.value() ?? [];\n\n        if (!prevDate?.daySame(parsedDate) || Number(parsedTime) !== Number(prevTime)) {\n            this.onChange([parsedDate, parsedTime]);\n        }\n    }\n\n    protected override stringify(\n        value: readonly [TuiDay, TuiTime | null] | null,\n    ): string {\n        const [date, time] = value ?? [];\n\n        const dateString =\n            date?.toString(this.format().mode, this.format().separator) ?? '';\n        const timeString = time?.toString(this.timeMode());\n\n        return timeString\n            ? `${dateString}${this.options.dateTimeSeparator}${timeString}`\n            : dateString;\n    }\n\n    private clampTime([date, time]: [TuiDay, TuiTime | null]): [TuiDay, TuiTime | null] {\n        const min = date.daySame(this.min())\n            ? this.minTime().toAbsoluteMilliseconds()\n            : -Infinity;\n        const max = date.daySame(this.max())\n            ? this.maxTime().toAbsoluteMilliseconds()\n            : Infinity;\n\n        return [\n            date,\n            time &&\n                TuiTime.fromAbsoluteMilliseconds(\n                    tuiClamp(time.toAbsoluteMilliseconds(), min, max),\n                ),\n        ];\n    }\n\n    private computeMask(\n        params: Omit<Required<MaskitoDateTimeParams>, 'timeStep'>,\n    ): MaskitoOptions {\n        const options = maskitoDateTimeOptionsGenerator(params);\n        const {timeMode, dateMode, dateTimeSeparator} = params;\n        const inputModeSwitchPlugin = maskitoSelectionChangeHandler((element) => {\n            element.inputMode =\n                element.selectionStart! >=\n                dateMode.length + dateTimeSeparator.length + timeMode.indexOf(' AA')\n                    ? 'text'\n                    : 'numeric';\n        });\n\n        return {\n            ...options,\n            plugins: options.plugins.concat(\n                timeMode.includes('AA') ? inputModeSwitchPlugin : [],\n            ),\n        };\n    }\n\n    private toNativeDate([{year, month, day}, {hours, minutes, seconds, ms}]: readonly [\n        TuiDay,\n        TuiTime,\n    ]): Date {\n        return new Date(year, month, day, hours, minutes, seconds, ms);\n    }\n}\n"]}
@@ -29,7 +29,7 @@ class TuiInputNumberDirective extends TuiControl {
29
29
  initialValue: TUI_DEFAULT_NUMBER_FORMAT,
30
30
  });
31
31
  this.formatted = computed(() => maskitoParseNumber(this.textfield.value(), this.numberFormat()));
32
- this.precision = computed(() => Number.isNaN(this.numberFormat().precision) ? 2 : this.numberFormat().precision);
32
+ this.precision = computed((precision = this.numberFormat().precision) => Number.isNaN(precision) ? 2 : precision);
33
33
  this.unfinished = computed((value = this.formatted()) => value < 0 ? value > this.max() : value < this.min());
34
34
  this.element = tuiInjectElement();
35
35
  this.mask = tuiMaskito(computed(() => this.computeMask(this.maskParams)));
@@ -94,8 +94,12 @@ class TuiInputNumberDirective extends TuiControl {
94
94
  this.postfix.set(x);
95
95
  }
96
96
  writeValue(value) {
97
- super.writeValue(value);
98
- untracked(() => this.setValue(this.value()));
97
+ const reset = this.control.pristine && this.control.untouched && !value;
98
+ const changed = untracked(() => value !== this.value());
99
+ if (changed || reset) {
100
+ super.writeValue(value);
101
+ untracked(() => this.setValue(this.value()));
102
+ }
99
103
  }
100
104
  setValue(value) {
101
105
  this.textfield.value.set(this.formatNumber(value));
@@ -189,4 +193,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
189
193
  type: Input,
190
194
  args: ['postfix']
191
195
  }] } });
192
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-number/input-number.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    computed,\n    Directive,\n    effect,\n    inject,\n    Input,\n    signal,\n    untracked,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {type MaskitoOptions, maskitoTransform} from '@maskito/core';\nimport {\n    maskitoCaretGuard,\n    maskitoNumberOptionsGenerator,\n    type MaskitoNumberParams,\n    maskitoParseNumber,\n} from '@maskito/kit';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {CHAR_HYPHEN, CHAR_MINUS, TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport {TUI_IS_IOS} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsSafeToRound} from '@taiga-ui/cdk/utils/math';\nimport {\n    TuiTextfieldDirective,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {TUI_DEFAULT_NUMBER_FORMAT, TUI_NUMBER_FORMAT} from '@taiga-ui/core/tokens';\nimport {tuiFormatNumber} from '@taiga-ui/core/utils/format';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_NUMBER_OPTIONS} from './input-number.options';\n\nconst DEFAULT_MAX_LENGTH = 18;\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputNumber]',\n    providers: [\n        tuiAsControl(TuiInputNumberDirective),\n        tuiValueTransformerFrom(TUI_INPUT_NUMBER_OPTIONS),\n    ],\n    hostDirectives: [TuiWithTextfield, MaskitoDirective],\n    host: {\n        '[disabled]': 'disabled()',\n        '[attr.inputMode]': 'inputMode()',\n        '[attr.maxLength]':\n            'element.maxLength > 0 ? element.maxLength : defaultMaxLength()',\n        '(blur)': 'setValue(transformer.fromControlValue(control.value))',\n        '(focus)': 'onFocus()',\n    },\n})\nexport class TuiInputNumberDirective extends TuiControl<number | null> {\n    private readonly options = inject(TUI_INPUT_NUMBER_OPTIONS);\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly isIOS = inject(TUI_IS_IOS);\n    private readonly minRaw = signal(this.options.min);\n    private readonly maxRaw = signal(this.options.max);\n    private readonly numberFormat = toSignal(inject(TUI_NUMBER_FORMAT), {\n        initialValue: TUI_DEFAULT_NUMBER_FORMAT,\n    });\n\n    private readonly formatted = computed(() =>\n        maskitoParseNumber(this.textfield.value(), this.numberFormat()),\n    );\n\n    private readonly precision = computed(() =>\n        Number.isNaN(this.numberFormat().precision) ? 2 : this.numberFormat().precision,\n    );\n\n    private readonly unfinished = computed((value = this.formatted()) =>\n        value < 0 ? value > this.max() : value < this.min(),\n    );\n\n    protected readonly element = tuiInjectElement<HTMLInputElement>();\n    protected readonly mask = tuiMaskito(\n        computed(() => this.computeMask(this.maskParams)),\n    );\n\n    protected readonly inputMode = computed(() => {\n        if (this.isIOS) {\n            return this.min() < 0\n                ? 'text' // iPhone does not have minus sign if inputMode equals to 'numeric' / 'decimal'\n                : 'decimal';\n        }\n\n        /**\n         * Samsung Keyboard does not minus sign for `inputmode=decimal`\n         * @see https://github.com/taiga-family/taiga-ui/issues/11061#issuecomment-2939103792\n         */\n        return 'numeric';\n    });\n\n    protected readonly defaultMaxLength = computed(() => {\n        const {decimalSeparator, thousandSeparator} = this.numberFormat();\n        const decimalPart =\n            !!this.precision() && this.textfield.value().includes(decimalSeparator);\n        const precision = decimalPart ? Math.min(this.precision() + 1, 20) : 0;\n        const takeThousand = thousandSeparator.repeat(5).length;\n\n        return DEFAULT_MAX_LENGTH + precision + takeThousand;\n    });\n\n    protected readonly onChangeEffect = effect(() => {\n        const value = this.formatted();\n\n        if (Number.isNaN(value)) {\n            this.onChange(null);\n\n            return;\n        }\n\n        if (\n            this.unfinished() ||\n            value < this.min() ||\n            value > this.max() ||\n            this.value() === value\n        ) {\n            return;\n        }\n\n        this.onChange(value);\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected maskInitialCalibrationEffect = effect(() => {\n        const options = maskitoNumberOptionsGenerator({\n            ...this.maskParams,\n            min: Number.MIN_SAFE_INTEGER,\n            max: Number.MAX_SAFE_INTEGER,\n        });\n\n        this.textfield.value.update((x) => maskitoTransform(x, options));\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    public readonly min = computed(() => Math.min(this.minRaw(), this.maxRaw()));\n    public readonly max = computed(() => Math.max(this.minRaw(), this.maxRaw()));\n    public readonly prefix = signal(this.options.prefix);\n    public readonly postfix = signal(this.options.postfix);\n\n    @Input('min')\n    public set minSetter(x: number | null) {\n        this.minRaw.set(this.transformer.fromControlValue(x ?? this.options.min));\n    }\n\n    @Input('max')\n    public set maxSetter(x: number | null) {\n        this.maxRaw.set(this.transformer.fromControlValue(x ?? this.options.max));\n    }\n\n    // TODO(v5): replace with signal input\n    @Input('prefix')\n    public set prefixSetter(x: string) {\n        this.prefix.set(x);\n    }\n\n    // TODO(v5): replace with signal input\n    @Input('postfix')\n    public set postfixSetter(x: string) {\n        this.postfix.set(x);\n    }\n\n    public override writeValue(value: number | null): void {\n        super.writeValue(value);\n        untracked(() => this.setValue(this.value()));\n    }\n\n    public setValue(value: number | null): void {\n        this.textfield.value.set(this.formatNumber(value));\n    }\n\n    protected onFocus(): void {\n        if (Number.isNaN(this.formatted()) && !this.readOnly()) {\n            this.textfield.value.set(this.prefix() + this.postfix());\n        }\n    }\n\n    private get maskParams(): MaskitoNumberParams {\n        const {decimalMode, ...numberFormat} = this.numberFormat();\n        const maximumFractionDigits = this.precision();\n\n        return {\n            ...numberFormat,\n            maximumFractionDigits,\n            min: this.min(),\n            max: this.max(),\n            prefix: this.prefix(),\n            postfix: this.postfix(),\n            minimumFractionDigits: decimalMode === 'always' ? maximumFractionDigits : 0,\n        };\n    }\n\n    private formatNumber(value: number | null): string {\n        if (value === null || Number.isNaN(value)) {\n            return '';\n        }\n\n        return (\n            (this.prefix() !== CHAR_MINUS ? this.prefix() : '') +\n            tuiFormatNumber(value, {\n                ...this.numberFormat(),\n                /**\n                 * Number can satisfy interval [Number.MIN_SAFE_INTEGER; Number.MAX_SAFE_INTEGER]\n                 * but its rounding can violate it.\n                 * Before BigInt support there is no perfect solution – only trade off.\n                 * No rounding is better than lose precision and incorrect mutation of already valid value.\n                 */\n                precision: tuiIsSafeToRound(value, this.precision())\n                    ? this.precision()\n                    : Infinity,\n            }).replace(CHAR_HYPHEN, CHAR_MINUS) +\n            this.postfix()\n        );\n    }\n\n    private computeMask(params: MaskitoNumberParams): MaskitoOptions {\n        const {prefix = '', postfix = ''} = params;\n        const {plugins, ...options} = maskitoNumberOptionsGenerator(params);\n\n        return {\n            ...options,\n            plugins: [\n                ...plugins,\n                maskitoCaretGuard((value) => [\n                    prefix.length,\n                    value.length - postfix.length,\n                ]),\n            ],\n        };\n    }\n}\n"]}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-number/input-number.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    computed,\n    Directive,\n    effect,\n    inject,\n    Input,\n    signal,\n    untracked,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {type MaskitoOptions, maskitoTransform} from '@maskito/core';\nimport {\n    maskitoCaretGuard,\n    maskitoNumberOptionsGenerator,\n    type MaskitoNumberParams,\n    maskitoParseNumber,\n} from '@maskito/kit';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {CHAR_HYPHEN, CHAR_MINUS, TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport {TUI_IS_IOS} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsSafeToRound} from '@taiga-ui/cdk/utils/math';\nimport {\n    TuiTextfieldDirective,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {TUI_DEFAULT_NUMBER_FORMAT, TUI_NUMBER_FORMAT} from '@taiga-ui/core/tokens';\nimport {tuiFormatNumber} from '@taiga-ui/core/utils/format';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_NUMBER_OPTIONS} from './input-number.options';\n\nconst DEFAULT_MAX_LENGTH = 18;\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputNumber]',\n    providers: [\n        tuiAsControl(TuiInputNumberDirective),\n        tuiValueTransformerFrom(TUI_INPUT_NUMBER_OPTIONS),\n    ],\n    hostDirectives: [TuiWithTextfield, MaskitoDirective],\n    host: {\n        '[disabled]': 'disabled()',\n        '[attr.inputMode]': 'inputMode()',\n        '[attr.maxLength]':\n            'element.maxLength > 0 ? element.maxLength : defaultMaxLength()',\n        '(blur)': 'setValue(transformer.fromControlValue(control.value))',\n        '(focus)': 'onFocus()',\n    },\n})\nexport class TuiInputNumberDirective extends TuiControl<number | null> {\n    private readonly options = inject(TUI_INPUT_NUMBER_OPTIONS);\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly isIOS = inject(TUI_IS_IOS);\n    private readonly minRaw = signal(this.options.min);\n    private readonly maxRaw = signal(this.options.max);\n    private readonly numberFormat = toSignal(inject(TUI_NUMBER_FORMAT), {\n        initialValue: TUI_DEFAULT_NUMBER_FORMAT,\n    });\n\n    private readonly formatted = computed(() =>\n        maskitoParseNumber(this.textfield.value(), this.numberFormat()),\n    );\n\n    private readonly precision = computed((precision = this.numberFormat().precision) =>\n        Number.isNaN(precision) ? 2 : precision,\n    );\n\n    private readonly unfinished = computed((value = this.formatted()) =>\n        value < 0 ? value > this.max() : value < this.min(),\n    );\n\n    protected readonly element = tuiInjectElement<HTMLInputElement>();\n    protected readonly mask = tuiMaskito(\n        computed(() => this.computeMask(this.maskParams)),\n    );\n\n    protected readonly inputMode = computed(() => {\n        if (this.isIOS) {\n            return this.min() < 0\n                ? 'text' // iPhone does not have minus sign if inputMode equals to 'numeric' / 'decimal'\n                : 'decimal';\n        }\n\n        /**\n         * Samsung Keyboard does not minus sign for `inputmode=decimal`\n         * @see https://github.com/taiga-family/taiga-ui/issues/11061#issuecomment-2939103792\n         */\n        return 'numeric';\n    });\n\n    protected readonly defaultMaxLength = computed(() => {\n        const {decimalSeparator, thousandSeparator} = this.numberFormat();\n        const decimalPart =\n            !!this.precision() && this.textfield.value().includes(decimalSeparator);\n        const precision = decimalPart ? Math.min(this.precision() + 1, 20) : 0;\n        const takeThousand = thousandSeparator.repeat(5).length;\n\n        return DEFAULT_MAX_LENGTH + precision + takeThousand;\n    });\n\n    protected readonly onChangeEffect = effect(() => {\n        const value = this.formatted();\n\n        if (Number.isNaN(value)) {\n            this.onChange(null);\n\n            return;\n        }\n\n        if (\n            this.unfinished() ||\n            value < this.min() ||\n            value > this.max() ||\n            this.value() === value\n        ) {\n            return;\n        }\n\n        this.onChange(value);\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected maskInitialCalibrationEffect = effect(() => {\n        const options = maskitoNumberOptionsGenerator({\n            ...this.maskParams,\n            min: Number.MIN_SAFE_INTEGER,\n            max: Number.MAX_SAFE_INTEGER,\n        });\n\n        this.textfield.value.update((x) => maskitoTransform(x, options));\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    public readonly min = computed(() => Math.min(this.minRaw(), this.maxRaw()));\n    public readonly max = computed(() => Math.max(this.minRaw(), this.maxRaw()));\n    public readonly prefix = signal(this.options.prefix);\n    public readonly postfix = signal(this.options.postfix);\n\n    @Input('min')\n    public set minSetter(x: number | null) {\n        this.minRaw.set(this.transformer.fromControlValue(x ?? this.options.min));\n    }\n\n    @Input('max')\n    public set maxSetter(x: number | null) {\n        this.maxRaw.set(this.transformer.fromControlValue(x ?? this.options.max));\n    }\n\n    // TODO(v5): replace with signal input\n    @Input('prefix')\n    public set prefixSetter(x: string) {\n        this.prefix.set(x);\n    }\n\n    // TODO(v5): replace with signal input\n    @Input('postfix')\n    public set postfixSetter(x: string) {\n        this.postfix.set(x);\n    }\n\n    public override writeValue(value: number | null): void {\n        const reset = this.control.pristine && this.control.untouched && !value;\n        const changed = untracked(() => value !== this.value());\n\n        if (changed || reset) {\n            super.writeValue(value);\n            untracked(() => this.setValue(this.value()));\n        }\n    }\n\n    public setValue(value: number | null): void {\n        this.textfield.value.set(this.formatNumber(value));\n    }\n\n    protected onFocus(): void {\n        if (Number.isNaN(this.formatted()) && !this.readOnly()) {\n            this.textfield.value.set(this.prefix() + this.postfix());\n        }\n    }\n\n    private get maskParams(): MaskitoNumberParams {\n        const {decimalMode, ...numberFormat} = this.numberFormat();\n        const maximumFractionDigits = this.precision();\n\n        return {\n            ...numberFormat,\n            maximumFractionDigits,\n            min: this.min(),\n            max: this.max(),\n            prefix: this.prefix(),\n            postfix: this.postfix(),\n            minimumFractionDigits: decimalMode === 'always' ? maximumFractionDigits : 0,\n        };\n    }\n\n    private formatNumber(value: number | null): string {\n        if (value === null || Number.isNaN(value)) {\n            return '';\n        }\n\n        return (\n            (this.prefix() !== CHAR_MINUS ? this.prefix() : '') +\n            tuiFormatNumber(value, {\n                ...this.numberFormat(),\n                /**\n                 * Number can satisfy interval [Number.MIN_SAFE_INTEGER; Number.MAX_SAFE_INTEGER]\n                 * but its rounding can violate it.\n                 * Before BigInt support there is no perfect solution – only trade off.\n                 * No rounding is better than lose precision and incorrect mutation of already valid value.\n                 */\n                precision: tuiIsSafeToRound(value, this.precision())\n                    ? this.precision()\n                    : Infinity,\n            }).replace(CHAR_HYPHEN, CHAR_MINUS) +\n            this.postfix()\n        );\n    }\n\n    private computeMask(params: MaskitoNumberParams): MaskitoOptions {\n        const {prefix = '', postfix = ''} = params;\n        const {plugins, ...options} = maskitoNumberOptionsGenerator(params);\n\n        return {\n            ...options,\n            plugins: [\n                ...plugins,\n                maskitoCaretGuard((value) => [\n                    prefix.length,\n                    value.length - postfix.length,\n                ]),\n            ],\n        };\n    }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { Directive, inject, Input } from '@angular/core';
1
+ import { Directive, inject } from '@angular/core';
2
2
  import { TuiValueTransformer } from '@taiga-ui/cdk/classes';
3
3
  import { tuiIsSafeToRound, tuiRound } from '@taiga-ui/cdk/utils/math';
4
4
  import { tuiProvide } from '@taiga-ui/cdk/utils/miscellaneous';
@@ -6,11 +6,12 @@ import { tuiGetFractionPartPadded } from '@taiga-ui/core/utils/format';
6
6
  import { TUI_FLOATING_PRECISION } from '@taiga-ui/kit/components/slider';
7
7
  import { TUI_INPUT_NUMBER_OPTIONS } from './input-number.options';
8
8
  import * as i0 from "@angular/core";
9
- class TuiQuantumValueTransformer extends TuiValueTransformer {
10
- constructor() {
11
- super(...arguments);
12
- this.parent = inject(TUI_INPUT_NUMBER_OPTIONS).valueTransformer;
13
- this.quantum = 1;
9
+ class TuiQuantumValueTransformerBase extends TuiValueTransformer {
10
+ // eslint-disable-next-line @typescript-eslint/parameter-properties
11
+ constructor(quantum = 1) {
12
+ super();
13
+ this.quantum = quantum;
14
+ this.parent = null;
14
15
  }
15
16
  fromControlValue(controlValue) {
16
17
  return this.parent?.fromControlValue(controlValue) ?? controlValue;
@@ -22,7 +23,19 @@ class TuiQuantumValueTransformer extends TuiValueTransformer {
22
23
  ? tuiRound(Math.round(value / this.quantum) * this.quantum, TUI_FLOATING_PRECISION)
23
24
  : value;
24
25
  }
25
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiQuantumValueTransformer, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
26
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiQuantumValueTransformerBase, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
27
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiQuantumValueTransformerBase, usesInheritance: true, ngImport: i0 }); }
28
+ }
29
+ export { TuiQuantumValueTransformerBase };
30
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiQuantumValueTransformerBase, decorators: [{
31
+ type: Directive
32
+ }], ctorParameters: function () { return [{ type: undefined }]; } });
33
+ class TuiQuantumValueTransformer extends TuiQuantumValueTransformerBase {
34
+ constructor() {
35
+ super(1);
36
+ this.parent = inject(TUI_INPUT_NUMBER_OPTIONS).valueTransformer;
37
+ }
38
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiQuantumValueTransformer, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
26
39
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiQuantumValueTransformer, isStandalone: true, selector: "[tuiInputNumber][quantum], [tuiInputSlider][quantum]", inputs: { quantum: "quantum" }, providers: [tuiProvide(TuiValueTransformer, TuiQuantumValueTransformer)], usesInheritance: true, ngImport: i0 }); }
27
40
  }
28
41
  export { TuiQuantumValueTransformer };
@@ -31,11 +44,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
31
44
  args: [{
32
45
  standalone: true,
33
46
  selector: '[tuiInputNumber][quantum], [tuiInputSlider][quantum]',
47
+ inputs: ['quantum'],
34
48
  providers: [tuiProvide(TuiValueTransformer, TuiQuantumValueTransformer)],
35
49
  }]
36
- }], propDecorators: { quantum: [{
37
- type: Input
38
- }] } });
50
+ }], ctorParameters: function () { return []; } });
39
51
  class TuiWithQuantumValueTransformer {
40
52
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiWithQuantumValueTransformer, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
41
53
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiWithQuantumValueTransformer, isStandalone: true, hostDirectives: [{ directive: TuiQuantumValueTransformer, inputs: ["quantum", "quantum"] }], ngImport: i0 }); }
@@ -53,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
53
65
  ],
54
66
  }]
55
67
  }] });
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVhbnR1bS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1udW1iZXIvcXVhbnR1bS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQzFELE9BQU8sRUFBQyxnQkFBZ0IsRUFBRSxRQUFRLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUNwRSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDN0QsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDckUsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFFdkUsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sd0JBQXdCLENBQUM7O0FBRWhFLE1BS2EsMEJBQTJCLFNBQVEsbUJBRy9DO0lBUkQ7O1FBU3FCLFdBQU0sR0FBRyxNQUFNLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQztRQUdyRSxZQUFPLEdBQUcsQ0FBQyxDQUFDO0tBaUJ0QjtJQWZtQixnQkFBZ0IsQ0FBQyxZQUEyQjtRQUN4RCxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsZ0JBQWdCLENBQUMsWUFBWSxDQUFDLElBQUksWUFBWSxDQUFDO0lBQ3ZFLENBQUM7SUFFTSxjQUFjLENBQUMsYUFBNEI7UUFDOUMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxjQUFjLENBQUMsYUFBYSxDQUFDLElBQUksYUFBYSxDQUFDO1FBRTFFLE9BQU8sS0FBSyxJQUFJLElBQUk7WUFDaEIsZ0JBQWdCLENBQUMsS0FBSyxFQUFFLHdCQUF3QixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFNLENBQUM7WUFDdEUsQ0FBQyxDQUFDLFFBQVEsQ0FDSixJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sRUFDL0Msc0JBQXNCLENBQ3pCO1lBQ0gsQ0FBQyxDQUFDLEtBQUssQ0FBQztJQUNoQixDQUFDOytHQXZCUSwwQkFBMEI7bUdBQTFCLDBCQUEwQixtSUFGeEIsQ0FBQyxVQUFVLENBQUMsbUJBQW1CLEVBQUUsMEJBQTBCLENBQUMsQ0FBQzs7U0FFL0QsMEJBQTBCOzRGQUExQiwwQkFBMEI7a0JBTHRDLFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxzREFBc0Q7b0JBQ2hFLFNBQVMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxtQkFBbUIsNkJBQTZCLENBQUM7aUJBQzNFOzhCQVFVLE9BQU87c0JBRGIsS0FBSzs7QUFvQlYsTUFTYSw4QkFBOEI7K0dBQTlCLDhCQUE4QjttR0FBOUIsOEJBQThCLG9EQW5DOUIsMEJBQTBCOztTQW1DMUIsOEJBQThCOzRGQUE5Qiw4QkFBOEI7a0JBVDFDLFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLGNBQWMsRUFBRTt3QkFDWjs0QkFDSSxTQUFTLEVBQUUsMEJBQTBCOzRCQUNyQyxNQUFNLEVBQUUsQ0FBQyxTQUFTLENBQUM7eUJBQ3RCO3FCQUNKO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIGluamVjdCwgSW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlWYWx1ZVRyYW5zZm9ybWVyfSBmcm9tICdAdGFpZ2EtdWkvY2RrL2NsYXNzZXMnO1xuaW1wb3J0IHt0dWlJc1NhZmVUb1JvdW5kLCB0dWlSb3VuZH0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9tYXRoJztcbmltcG9ydCB7dHVpUHJvdmlkZX0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9taXNjZWxsYW5lb3VzJztcbmltcG9ydCB7dHVpR2V0RnJhY3Rpb25QYXJ0UGFkZGVkfSBmcm9tICdAdGFpZ2EtdWkvY29yZS91dGlscy9mb3JtYXQnO1xuaW1wb3J0IHtUVUlfRkxPQVRJTkdfUFJFQ0lTSU9OfSBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvc2xpZGVyJztcblxuaW1wb3J0IHtUVUlfSU5QVVRfTlVNQkVSX09QVElPTlN9IGZyb20gJy4vaW5wdXQtbnVtYmVyLm9wdGlvbnMnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAnW3R1aUlucHV0TnVtYmVyXVtxdWFudHVtXSwgW3R1aUlucHV0U2xpZGVyXVtxdWFudHVtXScsXG4gICAgcHJvdmlkZXJzOiBbdHVpUHJvdmlkZShUdWlWYWx1ZVRyYW5zZm9ybWVyLCBUdWlRdWFudHVtVmFsdWVUcmFuc2Zvcm1lcildLFxufSlcbmV4cG9ydCBjbGFzcyBUdWlRdWFudHVtVmFsdWVUcmFuc2Zvcm1lciBleHRlbmRzIFR1aVZhbHVlVHJhbnNmb3JtZXI8XG4gICAgbnVtYmVyIHwgbnVsbCxcbiAgICBudW1iZXIgfCBudWxsXG4+IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHBhcmVudCA9IGluamVjdChUVUlfSU5QVVRfTlVNQkVSX09QVElPTlMpLnZhbHVlVHJhbnNmb3JtZXI7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBxdWFudHVtID0gMTtcblxuICAgIHB1YmxpYyBvdmVycmlkZSBmcm9tQ29udHJvbFZhbHVlKGNvbnRyb2xWYWx1ZTogbnVtYmVyIHwgbnVsbCk6IG51bWJlciB8IG51bGwge1xuICAgICAgICByZXR1cm4gdGhpcy5wYXJlbnQ/LmZyb21Db250cm9sVmFsdWUoY29udHJvbFZhbHVlKSA/PyBjb250cm9sVmFsdWU7XG4gICAgfVxuXG4gICAgcHVibGljIHRvQ29udHJvbFZhbHVlKGludGVybmFsVmFsdWU6IG51bWJlciB8IG51bGwpOiBudW1iZXIgfCBudWxsIHtcbiAgICAgICAgY29uc3QgdmFsdWUgPSB0aGlzLnBhcmVudD8udG9Db250cm9sVmFsdWUoaW50ZXJuYWxWYWx1ZSkgPz8gaW50ZXJuYWxWYWx1ZTtcblxuICAgICAgICByZXR1cm4gdmFsdWUgIT0gbnVsbCAmJlxuICAgICAgICAgICAgdHVpSXNTYWZlVG9Sb3VuZCh2YWx1ZSwgdHVpR2V0RnJhY3Rpb25QYXJ0UGFkZGVkKHRoaXMucXVhbnR1bSkubGVuZ3RoKVxuICAgICAgICAgICAgPyB0dWlSb3VuZChcbiAgICAgICAgICAgICAgICAgIE1hdGgucm91bmQodmFsdWUgLyB0aGlzLnF1YW50dW0pICogdGhpcy5xdWFudHVtLFxuICAgICAgICAgICAgICAgICAgVFVJX0ZMT0FUSU5HX1BSRUNJU0lPTixcbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgOiB2YWx1ZTtcbiAgICB9XG59XG5cbkBEaXJlY3RpdmUoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgZGlyZWN0aXZlOiBUdWlRdWFudHVtVmFsdWVUcmFuc2Zvcm1lcixcbiAgICAgICAgICAgIGlucHV0czogWydxdWFudHVtJ10sXG4gICAgICAgIH0sXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpV2l0aFF1YW50dW1WYWx1ZVRyYW5zZm9ybWVyIHt9XG4iXX0=
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicXVhbnR1bS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1udW1iZXIvcXVhbnR1bS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFDLGdCQUFnQixFQUFFLFFBQVEsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBQ3BFLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUM3RCxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQztBQUNyRSxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQztBQUV2RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQzs7QUFFaEUsTUFDYSw4QkFBK0IsU0FBUSxtQkFHbkQ7SUFHRyxtRUFBbUU7SUFDbkUsWUFBbUIsVUFBVSxDQUFDO1FBQzFCLEtBQUssRUFBRSxDQUFDO1FBRE8sWUFBTyxHQUFQLE9BQU8sQ0FBSTtRQUhwQixXQUFNLEdBQW1ELElBQUksQ0FBQztJQUt4RSxDQUFDO0lBRWUsZ0JBQWdCLENBQUMsWUFBMkI7UUFDeEQsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLGdCQUFnQixDQUFDLFlBQVksQ0FBQyxJQUFJLFlBQVksQ0FBQztJQUN2RSxDQUFDO0lBRU0sY0FBYyxDQUFDLGFBQTRCO1FBQzlDLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsY0FBYyxDQUFDLGFBQWEsQ0FBQyxJQUFJLGFBQWEsQ0FBQztRQUUxRSxPQUFPLEtBQUssSUFBSSxJQUFJO1lBQ2hCLGdCQUFnQixDQUFDLEtBQUssRUFBRSx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUMsTUFBTSxDQUFDO1lBQ3RFLENBQUMsQ0FBQyxRQUFRLENBQ0osSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQy9DLHNCQUFzQixDQUN6QjtZQUNILENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDaEIsQ0FBQzsrR0F6QlEsOEJBQThCO21HQUE5Qiw4QkFBOEI7O1NBQTlCLDhCQUE4Qjs0RkFBOUIsOEJBQThCO2tCQUQxQyxTQUFTOztBQTZCVixNQU1hLDBCQUEyQixTQUFRLDhCQUE4QjtJQUcxRTtRQUNJLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUhNLFdBQU0sR0FBRyxNQUFNLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQztJQUk5RSxDQUFDOytHQUxRLDBCQUEwQjttR0FBMUIsMEJBQTBCLG1JQUZ4QixDQUFDLFVBQVUsQ0FBQyxtQkFBbUIsRUFBRSwwQkFBMEIsQ0FBQyxDQUFDOztTQUUvRCwwQkFBMEI7NEZBQTFCLDBCQUEwQjtrQkFOdEMsU0FBUzttQkFBQztvQkFDUCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLHNEQUFzRDtvQkFDaEUsTUFBTSxFQUFFLENBQUMsU0FBUyxDQUFDO29CQUNuQixTQUFTLEVBQUUsQ0FBQyxVQUFVLENBQUMsbUJBQW1CLDZCQUE2QixDQUFDO2lCQUMzRTs7QUFTRCxNQVNhLDhCQUE4QjsrR0FBOUIsOEJBQThCO21HQUE5Qiw4QkFBOEIsb0RBakI5QiwwQkFBMEI7O1NBaUIxQiw4QkFBOEI7NEZBQTlCLDhCQUE4QjtrQkFUMUMsU0FBUzttQkFBQztvQkFDUCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsY0FBYyxFQUFFO3dCQUNaOzRCQUNJLFNBQVMsRUFBRSwwQkFBMEI7NEJBQ3JDLE1BQU0sRUFBRSxDQUFDLFNBQVMsQ0FBQzt5QkFDdEI7cUJBQ0o7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0RpcmVjdGl2ZSwgaW5qZWN0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VHVpVmFsdWVUcmFuc2Zvcm1lcn0gZnJvbSAnQHRhaWdhLXVpL2Nkay9jbGFzc2VzJztcbmltcG9ydCB7dHVpSXNTYWZlVG9Sb3VuZCwgdHVpUm91bmR9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvbWF0aCc7XG5pbXBvcnQge3R1aVByb3ZpZGV9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5pbXBvcnQge3R1aUdldEZyYWN0aW9uUGFydFBhZGRlZH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdXRpbHMvZm9ybWF0JztcbmltcG9ydCB7VFVJX0ZMT0FUSU5HX1BSRUNJU0lPTn0gZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3NsaWRlcic7XG5cbmltcG9ydCB7VFVJX0lOUFVUX05VTUJFUl9PUFRJT05TfSBmcm9tICcuL2lucHV0LW51bWJlci5vcHRpb25zJztcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgY2xhc3MgVHVpUXVhbnR1bVZhbHVlVHJhbnNmb3JtZXJCYXNlIGV4dGVuZHMgVHVpVmFsdWVUcmFuc2Zvcm1lcjxcbiAgICBudW1iZXIgfCBudWxsLFxuICAgIG51bWJlciB8IG51bGxcbj4ge1xuICAgIHByb3RlY3RlZCBwYXJlbnQ6IFR1aVZhbHVlVHJhbnNmb3JtZXI8bnVtYmVyIHwgbnVsbCwgYW55PiB8IG51bGwgPSBudWxsO1xuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9wYXJhbWV0ZXItcHJvcGVydGllc1xuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBxdWFudHVtID0gMSkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIHB1YmxpYyBvdmVycmlkZSBmcm9tQ29udHJvbFZhbHVlKGNvbnRyb2xWYWx1ZTogbnVtYmVyIHwgbnVsbCk6IG51bWJlciB8IG51bGwge1xuICAgICAgICByZXR1cm4gdGhpcy5wYXJlbnQ/LmZyb21Db250cm9sVmFsdWUoY29udHJvbFZhbHVlKSA/PyBjb250cm9sVmFsdWU7XG4gICAgfVxuXG4gICAgcHVibGljIHRvQ29udHJvbFZhbHVlKGludGVybmFsVmFsdWU6IG51bWJlciB8IG51bGwpOiBudW1iZXIgfCBudWxsIHtcbiAgICAgICAgY29uc3QgdmFsdWUgPSB0aGlzLnBhcmVudD8udG9Db250cm9sVmFsdWUoaW50ZXJuYWxWYWx1ZSkgPz8gaW50ZXJuYWxWYWx1ZTtcblxuICAgICAgICByZXR1cm4gdmFsdWUgIT0gbnVsbCAmJlxuICAgICAgICAgICAgdHVpSXNTYWZlVG9Sb3VuZCh2YWx1ZSwgdHVpR2V0RnJhY3Rpb25QYXJ0UGFkZGVkKHRoaXMucXVhbnR1bSkubGVuZ3RoKVxuICAgICAgICAgICAgPyB0dWlSb3VuZChcbiAgICAgICAgICAgICAgICAgIE1hdGgucm91bmQodmFsdWUgLyB0aGlzLnF1YW50dW0pICogdGhpcy5xdWFudHVtLFxuICAgICAgICAgICAgICAgICAgVFVJX0ZMT0FUSU5HX1BSRUNJU0lPTixcbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgOiB2YWx1ZTtcbiAgICB9XG59XG5cbkBEaXJlY3RpdmUoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICdbdHVpSW5wdXROdW1iZXJdW3F1YW50dW1dLCBbdHVpSW5wdXRTbGlkZXJdW3F1YW50dW1dJyxcbiAgICBpbnB1dHM6IFsncXVhbnR1bSddLFxuICAgIHByb3ZpZGVyczogW3R1aVByb3ZpZGUoVHVpVmFsdWVUcmFuc2Zvcm1lciwgVHVpUXVhbnR1bVZhbHVlVHJhbnNmb3JtZXIpXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpUXVhbnR1bVZhbHVlVHJhbnNmb3JtZXIgZXh0ZW5kcyBUdWlRdWFudHVtVmFsdWVUcmFuc2Zvcm1lckJhc2Uge1xuICAgIHByb3RlY3RlZCBvdmVycmlkZSBwYXJlbnQgPSBpbmplY3QoVFVJX0lOUFVUX05VTUJFUl9PUFRJT05TKS52YWx1ZVRyYW5zZm9ybWVyO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIHN1cGVyKDEpO1xuICAgIH1cbn1cblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBob3N0RGlyZWN0aXZlczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBkaXJlY3RpdmU6IFR1aVF1YW50dW1WYWx1ZVRyYW5zZm9ybWVyLFxuICAgICAgICAgICAgaW5wdXRzOiBbJ3F1YW50dW0nXSxcbiAgICAgICAgfSxcbiAgICBdLFxufSlcbmV4cG9ydCBjbGFzcyBUdWlXaXRoUXVhbnR1bVZhbHVlVHJhbnNmb3JtZXIge31cbiJdfQ==
@@ -0,0 +1,3 @@
1
+ export * from './input-range';
2
+ export * from './input-range.component';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1yYW5nZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1yYW5nZSc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LXJhbmdlLmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,166 @@
1
+ import { NgIf } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, computed, ElementRef, inject, Input, signal, ViewChild, ViewChildren, } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { TUI_IDENTITY_VALUE_TRANSFORMER, tuiAsControl, TuiControl, } from '@taiga-ui/cdk/classes';
5
+ import { EMPTY_QUERY } from '@taiga-ui/cdk/constants';
6
+ import { TUI_IS_MOBILE, tuiFallbackValueProvider } from '@taiga-ui/cdk/tokens';
7
+ import { tuiIsNativeFocused } from '@taiga-ui/cdk/utils/focus';
8
+ import { TUI_TEXTFIELD_OPTIONS, TuiTextfield } from '@taiga-ui/core/components/textfield';
9
+ import { TuiInputNumber, TuiInputNumberDirective, TuiQuantumValueTransformerBase, } from '@taiga-ui/kit/components/input-number';
10
+ import { TuiRange } from '@taiga-ui/kit/components/range';
11
+ import { tuiSliderOptionsProvider, } from '@taiga-ui/kit/components/slider';
12
+ import { PolymorpheusOutlet } from '@taiga-ui/polymorpheus';
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "@angular/forms";
15
+ import * as i2 from "@taiga-ui/kit/components/input-number";
16
+ import * as i3 from "@taiga-ui/core/components/textfield";
17
+ class TuiInputRangeComponent extends TuiControl {
18
+ constructor() {
19
+ super(...arguments);
20
+ this.inputNumberRefs = EMPTY_QUERY;
21
+ this.isMobile = inject(TUI_IS_MOBILE);
22
+ this.quantum = signal(0);
23
+ this.quantumTransformer = computed((quantum = this.quantum()) => quantum
24
+ ? new TuiQuantumValueTransformerBase(quantum)
25
+ : TUI_IDENTITY_VALUE_TRANSFORMER);
26
+ this.size = inject(TUI_TEXTFIELD_OPTIONS).size;
27
+ this.textfieldValueStart = this.value()[0];
28
+ this.textfieldValueEnd = this.value()[1];
29
+ this.lastActiveSide = 'start';
30
+ this.min = 0;
31
+ this.max = 100;
32
+ this.step = 1;
33
+ this.segments = 1;
34
+ this.keySteps = null;
35
+ this.content = ['', ''];
36
+ this.prefix = ['', ''];
37
+ this.postfix = ['', ''];
38
+ }
39
+ // TODO(v5): use signal inputs
40
+ set quantumSetter(x) {
41
+ this.quantum.set(x);
42
+ }
43
+ writeValue(value) {
44
+ super.writeValue(value);
45
+ this.setTextfieldValues(this.value());
46
+ }
47
+ ngAfterViewInit() {
48
+ if (this.range) {
49
+ this.range.legacyMode = false; // TODO(v5): remove backward compatibility
50
+ }
51
+ }
52
+ get hideStartContent() {
53
+ return !this.content[0] || tuiIsNativeFocused(this.textfieldStart);
54
+ }
55
+ get hideEndContent() {
56
+ return !this.content[1] || tuiIsNativeFocused(this.textfieldEnd);
57
+ }
58
+ takeStep(event, coefficients) {
59
+ if (!this.interactive() || !this.range) {
60
+ return;
61
+ }
62
+ event.preventDefault();
63
+ const [start, end] = this.value();
64
+ const newValue = this.valueGuard(this.range.takeStep(coefficients));
65
+ if (newValue[0] !== start || newValue[1] !== end) {
66
+ this.onExternalValueUpdate(newValue);
67
+ }
68
+ }
69
+ onInput([start, end]) {
70
+ const [prevStart, prevEnd] = this.value();
71
+ this.setValue([start ?? prevStart, end ?? prevEnd]);
72
+ }
73
+ onExternalValueUpdate(value) {
74
+ this.setValue(value);
75
+ this.setTextfieldValues(this.value());
76
+ setTimeout((end = Number.MAX_SAFE_INTEGER) => {
77
+ if (tuiIsNativeFocused(this.activeTextfield)) {
78
+ this.activeTextfield?.setSelectionRange(end, end);
79
+ }
80
+ });
81
+ }
82
+ focusToTextfield() {
83
+ if (!this.isMobile) {
84
+ this.activeTextfield?.focus();
85
+ }
86
+ }
87
+ onActiveThumbChange(activeThumb) {
88
+ // TODO(v5): remove backward compatibility
89
+ this.lastActiveSide = activeThumb === 'left' ? 'start' : 'end';
90
+ }
91
+ setTextfieldValues([start, end]) {
92
+ this.textfieldValueStart = start;
93
+ this.textfieldValueEnd = end;
94
+ }
95
+ get textfieldStart() {
96
+ return this.inputNumberRefs.first?.nativeElement || null;
97
+ }
98
+ get textfieldEnd() {
99
+ return this.inputNumberRefs.last?.nativeElement || null;
100
+ }
101
+ get activeTextfield() {
102
+ return this.lastActiveSide === 'start' ? this.textfieldStart : this.textfieldEnd;
103
+ }
104
+ setValue(value) {
105
+ this.onChange(this.valueGuard(value));
106
+ }
107
+ valueGuard(value) {
108
+ const [prevStart, prevEnd] = this.value();
109
+ const [start, end] = value.map((x) => this.quantumTransformer().toControlValue(x) ?? x);
110
+ return [Math.min(start, prevEnd), Math.max(end, prevStart)];
111
+ }
112
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputRangeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
113
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "16.2.12", type: TuiInputRangeComponent, isStandalone: true, selector: "tui-input-range", inputs: { min: "min", max: "max", step: "step", segments: "segments", keySteps: "keySteps", content: "content", prefix: ["prefix", "prefix", (x) => x ?? ['', '']], postfix: ["postfix", "postfix", (x) => x ?? ['', '']], quantumSetter: ["quantum", "quantumSetter"] }, host: { attributes: { "new": "" }, properties: { "attr.data-size": "size()" } }, providers: [
114
+ tuiAsControl(TuiInputRangeComponent),
115
+ tuiSliderOptionsProvider({ trackColor: 'transparent' }),
116
+ tuiFallbackValueProvider([0, 0]),
117
+ ], viewQueries: [{ propertyName: "range", first: true, predicate: TuiRange, descendants: true }, { propertyName: "inputNumberRefs", predicate: TuiInputNumberDirective, descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0, template: "<tui-textfield [content]=\"hideStartContent ? '' : content[0]\">\n <ng-container ngProjectAs=\"label\">\n <ng-content select=\"label\" />\n </ng-container>\n\n <input\n tuiInputNumber\n [disabled]=\"disabled()\"\n [invalid]=\"invalid()\"\n [max]=\"value()[1]\"\n [min]=\"min\"\n [postfix]=\"postfix[0]\"\n [prefix]=\"prefix[0]\"\n [readOnly]=\"readOnly()\"\n [(ngModel)]=\"textfieldValueStart\"\n (blur)=\"textfieldValueStart = value()[0]\"\n (keydown.arrowDown)=\"takeStep($event, [-1, 0])\"\n (keydown.arrowUp)=\"takeStep($event, [1, 0])\"\n (ngModelChange)=\"onInput([$event, null])\"\n />\n\n <input\n tuiInputNumber\n tuiTextfieldAppearance=\"none\"\n class=\"t-end\"\n [class._hidden]=\"!hideEndContent\"\n [disabled]=\"disabled()\"\n [invalid]=\"invalid()\"\n [max]=\"max\"\n [min]=\"value()[0]\"\n [postfix]=\"postfix[1]\"\n [prefix]=\"prefix[1]\"\n [readOnly]=\"readOnly()\"\n [(ngModel)]=\"textfieldValueEnd\"\n (blur)=\"textfieldValueEnd = value()[1]\"\n (keydown.arrowDown)=\"takeStep($event, [0, -1])\"\n (keydown.arrowUp)=\"takeStep($event, [0, 1])\"\n (ngModelChange)=\"onInput([null, $event])\"\n />\n\n <div\n class=\"t-content-end\"\n [class._hidden]=\"hideEndContent\"\n >\n <ng-container *polymorpheusOutlet=\"content[1] as text; context: {$implicit: value()[1]}\">\n {{ text }}\n </ng-container>\n </div>\n</tui-textfield>\n\n<tui-range\n *ngIf=\"interactive()\"\n [focusable]=\"false\"\n [keySteps]=\"keySteps\"\n [max]=\"max\"\n [min]=\"min\"\n [ngModel]=\"value()\"\n [segments]=\"segments\"\n [step]=\"step\"\n (activeThumbChange)=\"onActiveThumbChange($event)\"\n (mousedown.prevent)=\"focusToTextfield()\"\n (ngModelChange)=\"onExternalValueUpdate($event)\"\n/>\n", styles: [":host{position:relative;display:block}.t-end{position:absolute;top:0;bottom:0;right:0;left:50%;display:flex;inline-size:50%;text-align:end;outline:none!important;border:none;padding-inline-end:var(--t-padding);color:var(--tui-text-primary);transition:none}.t-end:dir(rtl){right:unset;inset-inline-end:0}.t-content-end{color:var(--tui-text-primary)}tui-textfield:has(label:not(:empty)) .t-content-end{padding-block-start:calc(var(--t-height) / 3)}tui-textfield._with-label .t-content-end{padding-block-start:calc(var(--t-height) / 3)}._hidden{opacity:0}tui-range{position:absolute;top:100%;left:1rem;right:1rem;z-index:1;margin:calc(-1 * var(--tui-thickness)) 0 0}:host[data-size=m] tui-range{right:.75rem;left:.75rem}:host[data-size=s] tui-range{right:.625rem;left:.625rem}tui-textfield::ng-deep .t-clear{display:none!important}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "directive", type: i2.TuiInputNumberDirective, selector: "input[tuiInputNumber]", inputs: ["min", "max", "prefix", "postfix"] }, { kind: "component", type: TuiRange, selector: "tui-range", inputs: ["min", "max", "step", "size", "segments", "keySteps", "focusable", "margin", "limit"] }, { kind: "component", type: i3.TuiTextfieldComponent, selector: "tui-textfield:not([multi])" }, { kind: "directive", type: i3.TuiTextfieldOptionsDirective, selector: "[tuiTextfieldAppearance],[tuiTextfieldSize],[tuiTextfieldCleaner]", inputs: ["tuiTextfieldAppearance", "tuiTextfieldSize", "tuiTextfieldCleaner"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
118
+ }
119
+ export { TuiInputRangeComponent };
120
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputRangeComponent, decorators: [{
121
+ type: Component,
122
+ args: [{ standalone: true, selector: 'tui-input-range', imports: [
123
+ FormsModule,
124
+ NgIf,
125
+ PolymorpheusOutlet,
126
+ TuiInputNumber,
127
+ TuiRange,
128
+ TuiTextfield,
129
+ ], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
130
+ tuiAsControl(TuiInputRangeComponent),
131
+ tuiSliderOptionsProvider({ trackColor: 'transparent' }),
132
+ tuiFallbackValueProvider([0, 0]),
133
+ ], host: {
134
+ new: '',
135
+ // TODO: use css :host:has(tui-textfield[data-size]) after browser bump
136
+ '[attr.data-size]': 'size()',
137
+ }, template: "<tui-textfield [content]=\"hideStartContent ? '' : content[0]\">\n <ng-container ngProjectAs=\"label\">\n <ng-content select=\"label\" />\n </ng-container>\n\n <input\n tuiInputNumber\n [disabled]=\"disabled()\"\n [invalid]=\"invalid()\"\n [max]=\"value()[1]\"\n [min]=\"min\"\n [postfix]=\"postfix[0]\"\n [prefix]=\"prefix[0]\"\n [readOnly]=\"readOnly()\"\n [(ngModel)]=\"textfieldValueStart\"\n (blur)=\"textfieldValueStart = value()[0]\"\n (keydown.arrowDown)=\"takeStep($event, [-1, 0])\"\n (keydown.arrowUp)=\"takeStep($event, [1, 0])\"\n (ngModelChange)=\"onInput([$event, null])\"\n />\n\n <input\n tuiInputNumber\n tuiTextfieldAppearance=\"none\"\n class=\"t-end\"\n [class._hidden]=\"!hideEndContent\"\n [disabled]=\"disabled()\"\n [invalid]=\"invalid()\"\n [max]=\"max\"\n [min]=\"value()[0]\"\n [postfix]=\"postfix[1]\"\n [prefix]=\"prefix[1]\"\n [readOnly]=\"readOnly()\"\n [(ngModel)]=\"textfieldValueEnd\"\n (blur)=\"textfieldValueEnd = value()[1]\"\n (keydown.arrowDown)=\"takeStep($event, [0, -1])\"\n (keydown.arrowUp)=\"takeStep($event, [0, 1])\"\n (ngModelChange)=\"onInput([null, $event])\"\n />\n\n <div\n class=\"t-content-end\"\n [class._hidden]=\"hideEndContent\"\n >\n <ng-container *polymorpheusOutlet=\"content[1] as text; context: {$implicit: value()[1]}\">\n {{ text }}\n </ng-container>\n </div>\n</tui-textfield>\n\n<tui-range\n *ngIf=\"interactive()\"\n [focusable]=\"false\"\n [keySteps]=\"keySteps\"\n [max]=\"max\"\n [min]=\"min\"\n [ngModel]=\"value()\"\n [segments]=\"segments\"\n [step]=\"step\"\n (activeThumbChange)=\"onActiveThumbChange($event)\"\n (mousedown.prevent)=\"focusToTextfield()\"\n (ngModelChange)=\"onExternalValueUpdate($event)\"\n/>\n", styles: [":host{position:relative;display:block}.t-end{position:absolute;top:0;bottom:0;right:0;left:50%;display:flex;inline-size:50%;text-align:end;outline:none!important;border:none;padding-inline-end:var(--t-padding);color:var(--tui-text-primary);transition:none}.t-end:dir(rtl){right:unset;inset-inline-end:0}.t-content-end{color:var(--tui-text-primary)}tui-textfield:has(label:not(:empty)) .t-content-end{padding-block-start:calc(var(--t-height) / 3)}tui-textfield._with-label .t-content-end{padding-block-start:calc(var(--t-height) / 3)}._hidden{opacity:0}tui-range{position:absolute;top:100%;left:1rem;right:1rem;z-index:1;margin:calc(-1 * var(--tui-thickness)) 0 0}:host[data-size=m] tui-range{right:.75rem;left:.75rem}:host[data-size=s] tui-range{right:.625rem;left:.625rem}tui-textfield::ng-deep .t-clear{display:none!important}\n"] }]
138
+ }], propDecorators: { inputNumberRefs: [{
139
+ type: ViewChildren,
140
+ args: [TuiInputNumberDirective, { read: ElementRef }]
141
+ }], range: [{
142
+ type: ViewChild,
143
+ args: [TuiRange]
144
+ }], min: [{
145
+ type: Input
146
+ }], max: [{
147
+ type: Input
148
+ }], step: [{
149
+ type: Input
150
+ }], segments: [{
151
+ type: Input
152
+ }], keySteps: [{
153
+ type: Input
154
+ }], content: [{
155
+ type: Input
156
+ }], prefix: [{
157
+ type: Input,
158
+ args: [{ transform: (x) => x ?? ['', ''] }]
159
+ }], postfix: [{
160
+ type: Input,
161
+ args: [{ transform: (x) => x ?? ['', ''] }]
162
+ }], quantumSetter: [{
163
+ type: Input,
164
+ args: ['quantum']
165
+ }] } });
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-range.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-range/input-range.component.ts","../../../../../projects/kit/components/input-range/input-range.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgIf} from '@angular/common';\nimport {\n    type AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    ElementRef,\n    inject,\n    Input,\n    type QueryList,\n    signal,\n    ViewChild,\n    ViewChildren,\n} from '@angular/core';\nimport {FormsModule} from '@angular/forms';\nimport {\n    TUI_IDENTITY_VALUE_TRANSFORMER,\n    tuiAsControl,\n    TuiControl,\n} from '@taiga-ui/cdk/classes';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TUI_IS_MOBILE, tuiFallbackValueProvider} from '@taiga-ui/cdk/tokens';\nimport {type TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiIsNativeFocused} from '@taiga-ui/cdk/utils/focus';\nimport {TUI_TEXTFIELD_OPTIONS, TuiTextfield} from '@taiga-ui/core/components/textfield';\nimport {\n    TuiInputNumber,\n    TuiInputNumberDirective,\n    TuiQuantumValueTransformerBase,\n} from '@taiga-ui/kit/components/input-number';\nimport {TuiRange} from '@taiga-ui/kit/components/range';\nimport {\n    type TuiKeySteps,\n    tuiSliderOptionsProvider,\n} from '@taiga-ui/kit/components/slider';\nimport {type PolymorpheusContent, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\n@Component({\n    standalone: true,\n    selector: 'tui-input-range',\n    imports: [\n        FormsModule,\n        NgIf,\n        PolymorpheusOutlet,\n        TuiInputNumber,\n        TuiRange,\n        TuiTextfield,\n    ],\n    templateUrl: './input-range.template.html',\n    styleUrls: ['./input-range.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsControl(TuiInputRangeComponent),\n        tuiSliderOptionsProvider({trackColor: 'transparent'}),\n        tuiFallbackValueProvider([0, 0]),\n    ],\n    host: {\n        new: '', // TODO(v5): remove after deletion of legacy control\n        // TODO: use css :host:has(tui-textfield[data-size]) after browser bump\n        '[attr.data-size]': 'size()',\n    },\n})\nexport class TuiInputRangeComponent\n    extends TuiControl<readonly [number, number]>\n    implements AfterViewInit\n{\n    @ViewChildren(TuiInputNumberDirective, {read: ElementRef})\n    private readonly inputNumberRefs: QueryList<ElementRef<HTMLInputElement>> =\n        EMPTY_QUERY;\n\n    @ViewChild(TuiRange)\n    private readonly range?: TuiRange;\n\n    private readonly isMobile = inject(TUI_IS_MOBILE);\n    private readonly quantum = signal(0);\n    private readonly quantumTransformer = computed((quantum = this.quantum()) =>\n        quantum\n            ? new TuiQuantumValueTransformerBase(quantum)\n            : TUI_IDENTITY_VALUE_TRANSFORMER,\n    );\n\n    protected readonly size = inject(TUI_TEXTFIELD_OPTIONS).size;\n    protected textfieldValueStart = this.value()[0];\n    protected textfieldValueEnd = this.value()[1];\n    protected lastActiveSide: 'end' | 'start' = 'start';\n\n    @Input()\n    public min = 0;\n\n    @Input()\n    public max = 100;\n\n    @Input()\n    public step = 1;\n\n    @Input()\n    public segments = 1;\n\n    @Input()\n    public keySteps: TuiKeySteps | null = null;\n\n    @Input()\n    public content: readonly [\n        PolymorpheusContent<TuiContext<number>>,\n        PolymorpheusContent<TuiContext<number>>,\n    ] = ['', ''];\n\n    @Input({transform: (x: readonly [string, string] | null) => x ?? ['', '']})\n    public prefix: readonly [string, string] = ['', ''];\n\n    @Input({transform: (x: readonly [string, string] | null) => x ?? ['', '']})\n    public postfix: readonly [string, string] = ['', ''];\n\n    // TODO(v5): use signal inputs\n    @Input('quantum')\n    public set quantumSetter(x: number) {\n        this.quantum.set(x);\n    }\n\n    public override writeValue(value: [number, number]): void {\n        super.writeValue(value);\n        this.setTextfieldValues(this.value());\n    }\n\n    public ngAfterViewInit(): void {\n        if (this.range) {\n            this.range.legacyMode = false; // TODO(v5): remove backward compatibility\n        }\n    }\n\n    protected get hideStartContent(): boolean {\n        return !this.content[0] || tuiIsNativeFocused(this.textfieldStart);\n    }\n\n    protected get hideEndContent(): boolean {\n        return !this.content[1] || tuiIsNativeFocused(this.textfieldEnd);\n    }\n\n    protected takeStep(\n        event: Event | KeyboardEvent,\n        coefficients: readonly [number, number],\n    ): void {\n        if (!this.interactive() || !this.range) {\n            return;\n        }\n\n        event.preventDefault();\n\n        const [start, end] = this.value();\n        const newValue = this.valueGuard(this.range.takeStep(coefficients));\n\n        if (newValue[0] !== start || newValue[1] !== end) {\n            this.onExternalValueUpdate(newValue);\n        }\n    }\n\n    protected onInput([start, end]: [number | null, number | null]): void {\n        const [prevStart, prevEnd] = this.value();\n\n        this.setValue([start ?? prevStart, end ?? prevEnd]);\n    }\n\n    protected onExternalValueUpdate(value: readonly [number, number]): void {\n        this.setValue(value);\n        this.setTextfieldValues(this.value());\n\n        setTimeout((end = Number.MAX_SAFE_INTEGER) => {\n            if (tuiIsNativeFocused(this.activeTextfield)) {\n                this.activeTextfield?.setSelectionRange(end, end);\n            }\n        });\n    }\n\n    protected focusToTextfield(): void {\n        if (!this.isMobile) {\n            this.activeTextfield?.focus();\n        }\n    }\n\n    protected onActiveThumbChange(activeThumb: 'left' | 'right'): void {\n        // TODO(v5): remove backward compatibility\n        this.lastActiveSide = activeThumb === 'left' ? 'start' : 'end';\n    }\n\n    protected setTextfieldValues([start, end]: readonly [number, number]): void {\n        this.textfieldValueStart = start;\n        this.textfieldValueEnd = end;\n    }\n\n    private get textfieldStart(): HTMLInputElement | null {\n        return this.inputNumberRefs.first?.nativeElement || null;\n    }\n\n    private get textfieldEnd(): HTMLInputElement | null {\n        return this.inputNumberRefs.last?.nativeElement || null;\n    }\n\n    private get activeTextfield(): HTMLInputElement | null {\n        return this.lastActiveSide === 'start' ? this.textfieldStart : this.textfieldEnd;\n    }\n\n    private setValue(value: readonly [number, number]): void {\n        this.onChange(this.valueGuard(value));\n    }\n\n    private valueGuard(value: readonly [number, number]): readonly [number, number] {\n        const [prevStart, prevEnd] = this.value();\n        const [start, end] = value.map(\n            (x) => this.quantumTransformer().toControlValue(x) ?? x,\n        ) as unknown as readonly [number, number];\n\n        return [Math.min(start, prevEnd), Math.max(end, prevStart)];\n    }\n}\n","<tui-textfield [content]=\"hideStartContent ? '' : content[0]\">\n    <ng-container ngProjectAs=\"label\">\n        <ng-content select=\"label\" />\n    </ng-container>\n\n    <input\n        tuiInputNumber\n        [disabled]=\"disabled()\"\n        [invalid]=\"invalid()\"\n        [max]=\"value()[1]\"\n        [min]=\"min\"\n        [postfix]=\"postfix[0]\"\n        [prefix]=\"prefix[0]\"\n        [readOnly]=\"readOnly()\"\n        [(ngModel)]=\"textfieldValueStart\"\n        (blur)=\"textfieldValueStart = value()[0]\"\n        (keydown.arrowDown)=\"takeStep($event, [-1, 0])\"\n        (keydown.arrowUp)=\"takeStep($event, [1, 0])\"\n        (ngModelChange)=\"onInput([$event, null])\"\n    />\n\n    <input\n        tuiInputNumber\n        tuiTextfieldAppearance=\"none\"\n        class=\"t-end\"\n        [class._hidden]=\"!hideEndContent\"\n        [disabled]=\"disabled()\"\n        [invalid]=\"invalid()\"\n        [max]=\"max\"\n        [min]=\"value()[0]\"\n        [postfix]=\"postfix[1]\"\n        [prefix]=\"prefix[1]\"\n        [readOnly]=\"readOnly()\"\n        [(ngModel)]=\"textfieldValueEnd\"\n        (blur)=\"textfieldValueEnd = value()[1]\"\n        (keydown.arrowDown)=\"takeStep($event, [0, -1])\"\n        (keydown.arrowUp)=\"takeStep($event, [0, 1])\"\n        (ngModelChange)=\"onInput([null, $event])\"\n    />\n\n    <div\n        class=\"t-content-end\"\n        [class._hidden]=\"hideEndContent\"\n    >\n        <ng-container *polymorpheusOutlet=\"content[1] as text; context: {$implicit: value()[1]}\">\n            {{ text }}\n        </ng-container>\n    </div>\n</tui-textfield>\n\n<tui-range\n    *ngIf=\"interactive()\"\n    [focusable]=\"false\"\n    [keySteps]=\"keySteps\"\n    [max]=\"max\"\n    [min]=\"min\"\n    [ngModel]=\"value()\"\n    [segments]=\"segments\"\n    [step]=\"step\"\n    (activeThumbChange)=\"onActiveThumbChange($event)\"\n    (mousedown.prevent)=\"focusToTextfield()\"\n    (ngModelChange)=\"onExternalValueUpdate($event)\"\n/>\n"]}
@@ -0,0 +1,4 @@
1
+ import { TuiLabel } from '@taiga-ui/core/components/label';
2
+ import { TuiInputRangeComponent } from './input-range.component';
3
+ export const TuiInputRange = [TuiInputRangeComponent, TuiLabel];
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtcmFuZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1yYW5nZS9pbnB1dC1yYW5nZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFFekQsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFFL0QsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLENBQUMsc0JBQXNCLEVBQUUsUUFBUSxDQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1R1aUxhYmVsfSBmcm9tICdAdGFpZ2EtdWkvY29yZS9jb21wb25lbnRzL2xhYmVsJztcblxuaW1wb3J0IHtUdWlJbnB1dFJhbmdlQ29tcG9uZW50fSBmcm9tICcuL2lucHV0LXJhbmdlLmNvbXBvbmVudCc7XG5cbmV4cG9ydCBjb25zdCBUdWlJbnB1dFJhbmdlID0gW1R1aUlucHV0UmFuZ2VDb21wb25lbnQsIFR1aUxhYmVsXSBhcyBjb25zdDtcbiJdfQ==
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWkta2l0LWNvbXBvbmVudHMtaW5wdXQtcmFuZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1yYW5nZS90YWlnYS11aS1raXQtY29tcG9uZW50cy1pbnB1dC1yYW5nZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==