@taiga-ui/kit 3.37.0 → 3.38.0
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.
- package/bundles/taiga-ui-kit-components-badged-content.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-badged-content.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-breadcrumbs.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-breadcrumbs.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-calendar-month.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-calendar-month.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-combo-box.umd.js +17 -3
- package/bundles/taiga-ui-kit-components-combo-box.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-copy.umd.js +17 -14
- package/bundles/taiga-ui-kit-components-input-copy.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-count.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-input-count.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-date-range.umd.js +19 -17
- package/bundles/taiga-ui-kit-components-input-date-range.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-date-time.umd.js +25 -19
- package/bundles/taiga-ui-kit-components-input-date-time.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-date.umd.js +17 -14
- package/bundles/taiga-ui-kit-components-input-date.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-month-range.umd.js +17 -3
- package/bundles/taiga-ui-kit-components-input-month-range.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-month.umd.js +17 -3
- package/bundles/taiga-ui-kit-components-input-month.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-number.umd.js +67 -25
- package/bundles/taiga-ui-kit-components-input-number.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-password.umd.js +13 -16
- package/bundles/taiga-ui-kit-components-input-password.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-phone-international.umd.js +18 -4
- package/bundles/taiga-ui-kit-components-input-phone-international.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-phone.umd.js +17 -3
- package/bundles/taiga-ui-kit-components-input-phone.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-range.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-input-range.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-tag.umd.js +11 -8
- package/bundles/taiga-ui-kit-components-input-tag.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-time.umd.js +17 -14
- package/bundles/taiga-ui-kit-components-input-time.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-year.umd.js +39 -12
- package/bundles/taiga-ui-kit-components-input-year.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input.umd.js +17 -3
- package/bundles/taiga-ui-kit-components-input.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-progress.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-select.umd.js +17 -3
- package/bundles/taiga-ui-kit-components-select.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-text-area.umd.js +3 -3
- package/bundles/taiga-ui-kit-components-text-area.umd.js.map +1 -1
- package/components/combo-box/combo-box.component.d.ts +5 -3
- package/components/input/input.component.d.ts +5 -3
- package/components/input-copy/input-copy.component.d.ts +3 -3
- package/components/input-date/input-date.component.d.ts +4 -4
- package/components/input-date-range/input-date-range.component.d.ts +4 -4
- package/components/input-date-time/input-date-time.component.d.ts +5 -5
- package/components/input-month/input-month.component.d.ts +5 -3
- package/components/input-month-range/input-month-range.component.d.ts +5 -3
- package/components/input-number/input-number.component.d.ts +9 -5
- package/components/input-password/input-password.component.d.ts +1 -2
- package/components/input-phone/input-phone.component.d.ts +5 -3
- package/components/input-phone-international/input-phone-international.component.d.ts +5 -3
- package/components/input-tag/input-tag.component.d.ts +1 -1
- package/components/input-time/input-time.component.d.ts +3 -3
- package/components/input-year/input-year.component.d.ts +8 -4
- package/components/input-year/input-year.directive.d.ts +1 -0
- package/components/select/select.component.d.ts +5 -3
- package/esm2015/components/badged-content/badged-content.component.js +1 -1
- package/esm2015/components/breadcrumbs/breadcrumbs.component.js +1 -1
- package/esm2015/components/calendar-month/calendar-month.component.js +1 -1
- package/esm2015/components/combo-box/combo-box.component.js +16 -6
- package/esm2015/components/input/input.component.js +16 -6
- package/esm2015/components/input-copy/input-copy.component.js +15 -12
- package/esm2015/components/input-count/input-count.component.js +1 -1
- package/esm2015/components/input-date/input-date.component.js +15 -12
- package/esm2015/components/input-date-range/input-date-range.component.js +17 -15
- package/esm2015/components/input-date-time/input-date-time.component.js +18 -12
- package/esm2015/components/input-month/input-month.component.js +16 -6
- package/esm2015/components/input-month-range/input-month-range.component.js +16 -6
- package/esm2015/components/input-number/input-number.component.js +61 -30
- package/esm2015/components/input-password/input-password.component.js +12 -16
- package/esm2015/components/input-phone/input-phone.component.js +16 -6
- package/esm2015/components/input-phone-international/input-phone-international.component.js +17 -7
- package/esm2015/components/input-range/input-range.component.js +2 -2
- package/esm2015/components/input-tag/input-tag.component.js +9 -6
- package/esm2015/components/input-time/input-time.component.js +15 -12
- package/esm2015/components/input-year/input-year.component.js +28 -13
- package/esm2015/components/input-year/input-year.directive.js +5 -1
- package/esm2015/components/progress/progress-label/progress-label.component.js +1 -1
- package/esm2015/components/select/select.component.js +16 -6
- package/esm2015/components/text-area/text-area.component.js +5 -5
- package/fesm2015/taiga-ui-kit-components-badged-content.js +1 -1
- package/fesm2015/taiga-ui-kit-components-badged-content.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-breadcrumbs.js +1 -1
- package/fesm2015/taiga-ui-kit-components-breadcrumbs.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-calendar-month.js +1 -1
- package/fesm2015/taiga-ui-kit-components-calendar-month.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-combo-box.js +15 -5
- package/fesm2015/taiga-ui-kit-components-combo-box.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-copy.js +14 -11
- package/fesm2015/taiga-ui-kit-components-input-copy.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-count.js +1 -1
- package/fesm2015/taiga-ui-kit-components-input-count.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-date-range.js +16 -14
- package/fesm2015/taiga-ui-kit-components-input-date-range.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-date-time.js +17 -11
- package/fesm2015/taiga-ui-kit-components-input-date-time.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-date.js +14 -11
- package/fesm2015/taiga-ui-kit-components-input-date.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-month-range.js +15 -5
- package/fesm2015/taiga-ui-kit-components-input-month-range.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-month.js +15 -5
- package/fesm2015/taiga-ui-kit-components-input-month.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-number.js +60 -29
- package/fesm2015/taiga-ui-kit-components-input-number.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-password.js +11 -15
- package/fesm2015/taiga-ui-kit-components-input-password.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-phone-international.js +16 -6
- package/fesm2015/taiga-ui-kit-components-input-phone-international.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-phone.js +15 -5
- package/fesm2015/taiga-ui-kit-components-input-phone.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-range.js +1 -1
- package/fesm2015/taiga-ui-kit-components-input-range.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-tag.js +8 -5
- package/fesm2015/taiga-ui-kit-components-input-tag.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-time.js +14 -11
- package/fesm2015/taiga-ui-kit-components-input-time.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-year.js +31 -12
- package/fesm2015/taiga-ui-kit-components-input-year.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input.js +15 -5
- package/fesm2015/taiga-ui-kit-components-input.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-progress.js +1 -1
- package/fesm2015/taiga-ui-kit-components-select.js +15 -5
- package/fesm2015/taiga-ui-kit-components-select.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-text-area.js +4 -4
- package/fesm2015/taiga-ui-kit-components-text-area.js.map +1 -1
- package/package.json +7 -7
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { __decorate } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, HostListener, Inject, Input, Optional, Self, ViewChild, } from '@angular/core';
|
|
1
|
+
import { __decorate, __rest } from "tslib";
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, HostBinding, HostListener, Inject, Input, Optional, Self, ViewChild, } from '@angular/core';
|
|
3
3
|
import { NgControl } from '@angular/forms';
|
|
4
|
-
import { maskitoNumberOptionsGenerator, maskitoParseNumber } from '@maskito/kit';
|
|
4
|
+
import { maskitoCaretGuard, maskitoNumberOptionsGenerator, maskitoParseNumber, } from '@maskito/kit';
|
|
5
5
|
import { AbstractTuiNullableControl, CHAR_HYPHEN, CHAR_MINUS, EMPTY_QUERY, TUI_IS_IOS, tuiAsControl, tuiAsFocusableItemAccessor, tuiClamp, tuiPure, } from '@taiga-ui/cdk';
|
|
6
|
-
import { TUI_NUMBER_FORMAT, tuiFormatNumber, tuiGetFractionPartPadded, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
|
|
6
|
+
import { TEXTFIELD_CONTROLLER_PROVIDER, TUI_NUMBER_FORMAT, TUI_TEXTFIELD_SIZE, TUI_TEXTFIELD_WATCHED_CONTROLLER, tuiFormatNumber, tuiGetFractionPartPadded, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
|
|
7
7
|
import { PolymorpheusOutletDirective } from '@tinkoff/ng-polymorpheus';
|
|
8
8
|
import { TUI_INPUT_NUMBER_OPTIONS } from './input-number.options';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
@@ -15,11 +15,13 @@ import * as i5 from "@tinkoff/ng-polymorpheus";
|
|
|
15
15
|
import * as i6 from "@angular/forms";
|
|
16
16
|
const DEFAULT_MAX_LENGTH = 18;
|
|
17
17
|
export class TuiInputNumberComponent extends AbstractTuiNullableControl {
|
|
18
|
-
constructor(control, cdr, options, numberFormat, isIOS) {
|
|
18
|
+
constructor(control, cdr, options, numberFormat, isIOS, textfieldSize, controller) {
|
|
19
19
|
super(control, cdr);
|
|
20
20
|
this.options = options;
|
|
21
21
|
this.numberFormat = numberFormat;
|
|
22
22
|
this.isIOS = isIOS;
|
|
23
|
+
this.textfieldSize = textfieldSize;
|
|
24
|
+
this.controller = controller;
|
|
23
25
|
this.unfinishedValue = '';
|
|
24
26
|
this.min = this.options.min;
|
|
25
27
|
this.max = this.options.max;
|
|
@@ -32,13 +34,17 @@ export class TuiInputNumberComponent extends AbstractTuiNullableControl {
|
|
|
32
34
|
this.postfix = '';
|
|
33
35
|
this.polymorpheusValueContent = EMPTY_QUERY;
|
|
34
36
|
}
|
|
37
|
+
get size() {
|
|
38
|
+
return this.textfieldSize.size;
|
|
39
|
+
}
|
|
35
40
|
get nativeFocusableElement() {
|
|
36
|
-
return !this.
|
|
41
|
+
return !this.textfield || this.computedDisabled
|
|
37
42
|
? null
|
|
38
|
-
: this.
|
|
43
|
+
: this.textfield.nativeFocusableElement;
|
|
39
44
|
}
|
|
40
45
|
get focused() {
|
|
41
|
-
|
|
46
|
+
var _a;
|
|
47
|
+
return !!((_a = this.textfield) === null || _a === void 0 ? void 0 : _a.focused);
|
|
42
48
|
}
|
|
43
49
|
get isNegativeAllowed() {
|
|
44
50
|
return this.min < 0;
|
|
@@ -69,8 +75,15 @@ export class TuiInputNumberComponent extends AbstractTuiNullableControl {
|
|
|
69
75
|
get canIncrement() {
|
|
70
76
|
return this.interactive && (this.value || 0) < this.max;
|
|
71
77
|
}
|
|
78
|
+
get computedPrefix() {
|
|
79
|
+
return this.prefix || this.controller.prefix;
|
|
80
|
+
}
|
|
81
|
+
get computedPostfix() {
|
|
82
|
+
const postfix = this.postfix || this.controller.postfix;
|
|
83
|
+
return postfix && ` ${postfix}`;
|
|
84
|
+
}
|
|
72
85
|
get mask() {
|
|
73
|
-
return this.calculateMask(this.precision, this.decimal, this.numberFormat.decimalSeparator, this.numberFormat.thousandSeparator, this.min, this.max);
|
|
86
|
+
return this.calculateMask(this.precision, this.decimal, this.numberFormat.decimalSeparator, this.numberFormat.thousandSeparator, this.min, this.max, this.computedPrefix, this.computedPostfix);
|
|
74
87
|
}
|
|
75
88
|
onArrow(step) {
|
|
76
89
|
if (!step) {
|
|
@@ -97,19 +110,19 @@ export class TuiInputNumberComponent extends AbstractTuiNullableControl {
|
|
|
97
110
|
}
|
|
98
111
|
onFocused(focused) {
|
|
99
112
|
this.updateFocused(focused);
|
|
100
|
-
if (focused) {
|
|
101
|
-
return;
|
|
102
|
-
}
|
|
103
113
|
const nativeNumberValue = this.unfinishedValue
|
|
104
114
|
? maskitoParseNumber(this.unfinishedValue, this.numberFormat.decimalSeparator)
|
|
105
115
|
: this.nativeNumberValue;
|
|
106
116
|
this.unfinishedValue = null;
|
|
107
117
|
if (Number.isNaN(nativeNumberValue)) {
|
|
108
|
-
this.
|
|
118
|
+
this.nativeValue = focused ? this.computedPrefix + this.computedPostfix : '';
|
|
119
|
+
this.value = null;
|
|
109
120
|
return;
|
|
110
121
|
}
|
|
111
|
-
|
|
112
|
-
|
|
122
|
+
if (!focused) {
|
|
123
|
+
this.value = nativeNumberValue;
|
|
124
|
+
this.nativeValue = this.formattedValue;
|
|
125
|
+
}
|
|
113
126
|
}
|
|
114
127
|
getFormattedValue(value) {
|
|
115
128
|
const absValue = Math.abs(value);
|
|
@@ -123,7 +136,9 @@ export class TuiInputNumberComponent extends AbstractTuiNullableControl {
|
|
|
123
136
|
if (this.focused && this.decimal !== 'always') {
|
|
124
137
|
decimalLimit = fraction.length;
|
|
125
138
|
}
|
|
126
|
-
return
|
|
139
|
+
return (this.computedPrefix +
|
|
140
|
+
tuiFormatNumber(value, Object.assign(Object.assign({}, this.numberFormat), { decimalLimit })).replace(CHAR_HYPHEN, CHAR_MINUS) +
|
|
141
|
+
this.computedPostfix);
|
|
127
142
|
}
|
|
128
143
|
get isNativeValueNotFinished() {
|
|
129
144
|
const nativeNumberValue = this.nativeNumberValue;
|
|
@@ -135,10 +150,10 @@ export class TuiInputNumberComponent extends AbstractTuiNullableControl {
|
|
|
135
150
|
return this.nativeFocusableElement ? this.nativeFocusableElement.value : '';
|
|
136
151
|
}
|
|
137
152
|
set nativeValue(value) {
|
|
138
|
-
if (!this.
|
|
153
|
+
if (!this.textfield || !this.nativeFocusableElement) {
|
|
139
154
|
return;
|
|
140
155
|
}
|
|
141
|
-
this.
|
|
156
|
+
this.textfield.value = value;
|
|
142
157
|
this.nativeFocusableElement.value = value;
|
|
143
158
|
}
|
|
144
159
|
writeValue(value) {
|
|
@@ -148,26 +163,32 @@ export class TuiInputNumberComponent extends AbstractTuiNullableControl {
|
|
|
148
163
|
get nativeNumberValue() {
|
|
149
164
|
return maskitoParseNumber(this.nativeValue, this.numberFormat.decimalSeparator);
|
|
150
165
|
}
|
|
151
|
-
calculateMask(precision, decimalMode, decimalSeparator, thousandSeparator, min, max) {
|
|
152
|
-
|
|
166
|
+
calculateMask(precision, decimalMode, decimalSeparator, thousandSeparator, min, max, prefix, postfix) {
|
|
167
|
+
const _a = maskitoNumberOptionsGenerator({
|
|
153
168
|
decimalSeparator,
|
|
154
169
|
thousandSeparator,
|
|
155
170
|
min,
|
|
156
171
|
max,
|
|
172
|
+
prefix,
|
|
173
|
+
postfix,
|
|
157
174
|
precision: decimalMode === 'never' ? 0 : precision,
|
|
158
175
|
decimalZeroPadding: decimalMode === 'always',
|
|
159
|
-
});
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
176
|
+
}), { plugins } = _a, options = __rest(_a, ["plugins"]);
|
|
177
|
+
return Object.assign(Object.assign({}, options), { plugins: [
|
|
178
|
+
...plugins,
|
|
179
|
+
maskitoCaretGuard(value => [
|
|
180
|
+
prefix.length,
|
|
181
|
+
value.length - postfix.length,
|
|
182
|
+
]),
|
|
183
|
+
] });
|
|
164
184
|
}
|
|
165
185
|
}
|
|
166
|
-
TuiInputNumberComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputNumberComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_INPUT_NUMBER_OPTIONS }, { token: TUI_NUMBER_FORMAT }, { token: TUI_IS_IOS }], target: i0.ɵɵFactoryTarget.Component });
|
|
167
|
-
TuiInputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputNumberComponent, selector: "tui-input-number", inputs: { min: "min", max: "max", decimal: "decimal", precision: "precision", step: "step", prefix: "prefix", postfix: "postfix" }, host: { listeners: { "keydown.arrowDown": "onArrow(-step)", "keydown.arrowUp": "onArrow(step)" } }, providers: [
|
|
186
|
+
TuiInputNumberComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputNumberComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_INPUT_NUMBER_OPTIONS }, { token: TUI_NUMBER_FORMAT }, { token: TUI_IS_IOS }, { token: TUI_TEXTFIELD_SIZE }, { token: TUI_TEXTFIELD_WATCHED_CONTROLLER }], target: i0.ɵɵFactoryTarget.Component });
|
|
187
|
+
TuiInputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputNumberComponent, selector: "tui-input-number", inputs: { min: "min", max: "max", decimal: "decimal", precision: "precision", step: "step", prefix: "prefix", postfix: "postfix" }, host: { listeners: { "keydown.arrowDown": "onArrow(-step)", "keydown.arrowUp": "onArrow(step)" }, properties: { "attr.data-size": "this.size" } }, providers: [
|
|
168
188
|
tuiAsFocusableItemAccessor(TuiInputNumberComponent),
|
|
169
189
|
tuiAsControl(TuiInputNumberComponent),
|
|
170
|
-
|
|
190
|
+
TEXTFIELD_CONTROLLER_PROVIDER,
|
|
191
|
+
], queries: [{ propertyName: "polymorpheusValueContent", predicate: PolymorpheusOutletDirective, descendants: true }], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-primitive-textfield\n #textfield\n tuiValueAccessor\n tuiTextfieldPrefix=\"\"\n tuiTextfieldPostfix=\"\"\n class=\"t-textfield\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoFocus]=\"computedFocused\"\n [pseudoActive]=\"pseudoActive\"\n [invalid]=\"computedInvalid\"\n [readOnly]=\"readOnly\"\n [disabled]=\"computedDisabled\"\n [maskito]=\"mask\"\n [value]=\"computedValue\"\n [focusable]=\"focusable\"\n (valueChange)=\"onValueChange($event)\"\n (focusedChange)=\"onFocused($event)\"\n>\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n <div\n *ngIf=\"polymorpheusValueContent.length\"\n ngProjectAs=\"tuiContent\"\n class=\"t-value-content\"\n >\n <ng-container *polymorpheusOutlet=\"valueContent as text\">\n {{ text }}\n </ng-container>\n </div>\n</tui-primitive-textfield>\n\n<section\n *ngIf=\"step\"\n class=\"t-buttons\"\n>\n <button\n tuiIconButton\n type=\"button\"\n size=\"s\"\n class=\"t-button\"\n [icon]=\"options.icons.up\"\n [appearance]=\"textfield.appearance\"\n [disabled]=\"!canIncrement\"\n [focusable]=\"false\"\n (mousedown.prevent)=\"nativeFocusableElement?.focus()\"\n (click.prevent)=\"onArrow(step)\"\n >\n +\n </button>\n <button\n tuiIconButton\n type=\"button\"\n size=\"s\"\n class=\"t-button\"\n [icon]=\"options.icons.down\"\n [appearance]=\"textfield.appearance\"\n [disabled]=\"!canDecrement\"\n [focusable]=\"false\"\n (mousedown.prevent)=\"nativeFocusableElement?.focus()\"\n (click.prevent)=\"onArrow(-step)\"\n >\n -\n </button>\n</section>\n\n<ng-container *ngIf=\"polymorpheusValueContent.changes | async\"></ng-container>\n\n<ng-template #valueContent>\n <ng-content select=\"tuiContent\"></ng-content>\n</ng-template>\n", styles: [":host{display:flex;border-radius:var(--tui-radius-m);text-align:left}.t-textfield{flex:1;max-width:100%;border-radius:inherit;text-align:inherit}.t-textfield:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.t-value-content{width:100%}.t-buttons{display:flex;flex-direction:column;align-items:stretch;margin-left:.125rem;border-radius:inherit}[data-size=s]+.t-buttons{flex-direction:row-reverse}[data-size=s]+.t-buttons .t-button:first-child{margin:0 0 0 .125rem;border-top-right-radius:inherit;border-bottom-right-radius:inherit}[data-size=s]+.t-buttons .t-button:last-child{border-radius:0}[data-size=m]+.t-buttons .t-button{width:calc(var(--tui-height-m) * .75)}[data-size=l]+.t-buttons .t-button{width:calc(var(--tui-height-l) * .75)}.t-button{display:flex;flex:1;height:auto;border-radius:0}.t-button:first-child{margin-bottom:.125rem;border-top-right-radius:inherit}.t-button:last-child{border-bottom-right-radius:inherit}\n"], components: [{ type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }, { type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }], directives: [{ type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i2.TuiValueAccessorDirective, selector: "[tuiValueAccessor]" }, { type: i1.TuiTextfieldPrefixDirective, selector: "[tuiTextfieldPrefix]", inputs: ["tuiTextfieldPrefix"] }, { type: i1.TuiTextfieldPostfixDirective, selector: "[tuiTextfieldPostfix]", inputs: ["tuiTextfieldPostfix"] }, { type: i3.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], pipes: { "async": i4.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
171
192
|
__decorate([
|
|
172
193
|
tuiPure
|
|
173
194
|
], TuiInputNumberComponent.prototype, "calculateMask", null);
|
|
@@ -181,6 +202,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
181
202
|
providers: [
|
|
182
203
|
tuiAsFocusableItemAccessor(TuiInputNumberComponent),
|
|
183
204
|
tuiAsControl(TuiInputNumberComponent),
|
|
205
|
+
TEXTFIELD_CONTROLLER_PROVIDER,
|
|
184
206
|
],
|
|
185
207
|
}]
|
|
186
208
|
}], ctorParameters: function () { return [{ type: i6.NgControl, decorators: [{
|
|
@@ -202,7 +224,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
202
224
|
}] }, { type: undefined, decorators: [{
|
|
203
225
|
type: Inject,
|
|
204
226
|
args: [TUI_IS_IOS]
|
|
205
|
-
}] }
|
|
227
|
+
}] }, { type: i1.TuiTextfieldSizeDirective, decorators: [{
|
|
228
|
+
type: Inject,
|
|
229
|
+
args: [TUI_TEXTFIELD_SIZE]
|
|
230
|
+
}] }, { type: i1.TuiTextfieldController, decorators: [{
|
|
231
|
+
type: Inject,
|
|
232
|
+
args: [TUI_TEXTFIELD_WATCHED_CONTROLLER]
|
|
233
|
+
}] }]; }, propDecorators: { textfield: [{
|
|
206
234
|
type: ViewChild,
|
|
207
235
|
args: [TuiPrimitiveTextfieldComponent]
|
|
208
236
|
}], min: [{
|
|
@@ -222,6 +250,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
222
250
|
}], polymorpheusValueContent: [{
|
|
223
251
|
type: ContentChildren,
|
|
224
252
|
args: [PolymorpheusOutletDirective, { descendants: true }]
|
|
253
|
+
}], size: [{
|
|
254
|
+
type: HostBinding,
|
|
255
|
+
args: ['attr.data-size']
|
|
225
256
|
}], onArrow: [{
|
|
226
257
|
type: HostListener,
|
|
227
258
|
args: ['keydown.arrowDown', ['-step']]
|
|
@@ -229,4 +260,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
229
260
|
type: HostListener,
|
|
230
261
|
args: ['keydown.arrowUp', ['step']]
|
|
231
262
|
}], calculateMask: [] } });
|
|
232
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-number/input-number.component.ts","../../../../../projects/kit/components/input-number/input-number.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {MaskitoOptions} from '@maskito/core';\nimport {maskitoNumberOptionsGenerator, maskitoParseNumber} from '@maskito/kit';\nimport {\n    AbstractTuiNullableControl,\n    CHAR_HYPHEN,\n    CHAR_MINUS,\n    EMPTY_QUERY,\n    TUI_IS_IOS,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    tuiClamp,\n    TuiFocusableElementAccessor,\n    TuiInputMode,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_NUMBER_FORMAT,\n    TuiDecimal,\n    tuiFormatNumber,\n    tuiGetFractionPartPadded,\n    TuiNumberFormatSettings,\n    TuiPrimitiveTextfieldComponent,\n} from '@taiga-ui/core';\nimport {PolymorpheusOutletDirective} from '@tinkoff/ng-polymorpheus';\n\nimport {TUI_INPUT_NUMBER_OPTIONS, TuiInputNumberOptions} from './input-number.options';\n\nconst DEFAULT_MAX_LENGTH = 18;\n\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        tuiAsFocusableItemAccessor(TuiInputNumberComponent),\n        tuiAsControl(TuiInputNumberComponent),\n    ],\n})\nexport class TuiInputNumberComponent\n    extends AbstractTuiNullableControl<number>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly primitiveTextfield?: TuiPrimitiveTextfieldComponent;\n\n    private unfinishedValue: string | null = '';\n\n    @Input()\n    min = this.options.min;\n\n    @Input()\n    max = this.options.max;\n\n    @Input()\n    decimal = this.options.decimal;\n\n    @Input()\n    precision = this.options.precision;\n\n    @Input()\n    step = this.options.step;\n\n    /** @deprecated use `tuiTextfieldPrefix` from {@link TuiTextfieldControllerModule} instead */\n    @Input()\n    prefix = '';\n\n    /** @deprecated use `tuiTextfieldPostfix` from {@link TuiTextfieldControllerModule} instead */\n    @Input()\n    postfix = '';\n\n    @ContentChildren(PolymorpheusOutletDirective, {descendants: true})\n    readonly polymorpheusValueContent: QueryList<unknown> = EMPTY_QUERY;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef)\n        cdr: ChangeDetectorRef,\n        @Inject(TUI_INPUT_NUMBER_OPTIONS)\n        readonly options: TuiInputNumberOptions,\n        @Inject(TUI_NUMBER_FORMAT)\n        private readonly numberFormat: TuiNumberFormatSettings,\n        @Inject(TUI_IS_IOS) private readonly isIOS: boolean,\n    ) {\n        super(control, cdr);\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        if (this.isIOS && this.isNegativeAllowed) {\n            // iPhone does not have minus sign if inputMode is equal to 'numeric' / 'decimal'\n            return 'text';\n        }\n\n        return this.decimal === 'never' ? 'numeric' : 'decimal';\n    }\n\n    get calculatedMaxLength(): number {\n        const decimalPart =\n            this.decimal !== 'never' &&\n            this.nativeValue.includes(this.numberFormat.decimalSeparator);\n        const precision = decimalPart ? Math.min(this.precision + 1, 20) : 0;\n        const takeThousand = this.numberFormat.thousandSeparator.repeat(5).length;\n\n        return DEFAULT_MAX_LENGTH + precision + takeThousand;\n    }\n\n    get formattedValue(): string {\n        return this.value !== null ? this.getFormattedValue(this.value || 0) : '';\n    }\n\n    get computedValue(): string {\n        return this.focused ? this.nativeValue : this.formattedValue;\n    }\n\n    get canDecrement(): boolean {\n        return this.interactive && (this.value || 0) > this.min;\n    }\n\n    get canIncrement(): boolean {\n        return this.interactive && (this.value || 0) < this.max;\n    }\n\n    get mask(): MaskitoOptions {\n        return this.calculateMask(\n            this.precision,\n            this.decimal,\n            this.numberFormat.decimalSeparator,\n            this.numberFormat.thousandSeparator,\n            this.min,\n            this.max,\n        );\n    }\n\n    @HostListener('keydown.arrowDown', ['-step'])\n    @HostListener('keydown.arrowUp', ['step'])\n    onArrow(step: number | null): void {\n        if (!step) {\n            return;\n        }\n\n        this.value = tuiClamp((this.value || 0) + step, this.min, this.max);\n        this.nativeValue = this.formattedValue;\n    }\n\n    onValueChange(nativeValue: string): void {\n        const parsedValue = maskitoParseNumber(\n            nativeValue,\n            this.numberFormat.decimalSeparator,\n        );\n\n        this.unfinishedValue = null;\n\n        if (Number.isNaN(parsedValue)) {\n            this.value = null;\n\n            return;\n        }\n\n        if (this.isNativeValueNotFinished) {\n            this.unfinishedValue = nativeValue;\n\n            return;\n        }\n\n        if (parsedValue < this.min || parsedValue > this.max) {\n            return;\n        }\n\n        this.value = parsedValue;\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n\n        if (focused) {\n            return;\n        }\n\n        const nativeNumberValue = this.unfinishedValue\n            ? maskitoParseNumber(this.unfinishedValue, this.numberFormat.decimalSeparator)\n            : this.nativeNumberValue;\n\n        this.unfinishedValue = null;\n\n        if (Number.isNaN(nativeNumberValue)) {\n            this.clear();\n\n            return;\n        }\n\n        this.value = nativeNumberValue;\n        this.nativeValue = this.formattedValue;\n    }\n\n    getFormattedValue(value: number): string {\n        const absValue = Math.abs(value);\n        const hasFraction = absValue % 1 > 0;\n        let decimalLimit =\n            this.decimal === 'always' || (hasFraction && this.decimal !== 'never')\n                ? this.precision\n                : 0;\n\n        const fraction = hasFraction\n            ? tuiGetFractionPartPadded(value, this.precision)\n            : '';\n\n        if (this.focused && this.decimal !== 'always') {\n            decimalLimit = fraction.length;\n        }\n\n        return tuiFormatNumber(value, {\n            ...this.numberFormat,\n            decimalLimit,\n        }).replace(CHAR_HYPHEN, CHAR_MINUS);\n    }\n\n    private get isNativeValueNotFinished(): boolean {\n        const nativeNumberValue = this.nativeNumberValue;\n\n        return nativeNumberValue < 0\n            ? nativeNumberValue > this.max\n            : nativeNumberValue < this.min;\n    }\n\n    get nativeValue(): string {\n        return this.nativeFocusableElement ? this.nativeFocusableElement.value : '';\n    }\n\n    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    override writeValue(value: number | null): void {\n        super.writeValue(value);\n        this.nativeValue = this.formattedValue;\n    }\n\n    private get nativeNumberValue(): number {\n        return maskitoParseNumber(this.nativeValue, this.numberFormat.decimalSeparator);\n    }\n\n    @tuiPure\n    private calculateMask(\n        precision: number,\n        decimalMode: TuiDecimal,\n        decimalSeparator: string,\n        thousandSeparator: string,\n        min: number,\n        max: number,\n    ): MaskitoOptions {\n        return maskitoNumberOptionsGenerator({\n            decimalSeparator,\n            thousandSeparator,\n            min,\n            max,\n            precision: decimalMode === 'never' ? 0 : precision,\n            decimalZeroPadding: decimalMode === 'always',\n        });\n    }\n\n    private clear(): void {\n        this.nativeValue = '';\n        this.value = null;\n    }\n}\n","<tui-primitive-textfield\n    #textfield\n    tuiValueAccessor\n    class=\"t-textfield\"\n    [pseudoHover]=\"pseudoHover\"\n    [pseudoFocus]=\"computedFocused\"\n    [pseudoActive]=\"pseudoActive\"\n    [invalid]=\"computedInvalid\"\n    [readOnly]=\"readOnly\"\n    [disabled]=\"computedDisabled\"\n    [maskito]=\"mask\"\n    [value]=\"computedValue\"\n    [prefix]=\"prefix\"\n    [postfix]=\"postfix\"\n    [focusable]=\"focusable\"\n    (valueChange)=\"onValueChange($event)\"\n    (focusedChange)=\"onFocused($event)\"\n>\n    <ng-content></ng-content>\n    <ng-content\n        select=\"input\"\n        ngProjectAs=\"input\"\n    ></ng-content>\n    <div\n        *ngIf=\"polymorpheusValueContent.length\"\n        ngProjectAs=\"tuiContent\"\n        class=\"t-value-content\"\n    >\n        <ng-container *polymorpheusOutlet=\"valueContent as text\">\n            {{ text }}\n        </ng-container>\n    </div>\n</tui-primitive-textfield>\n\n<section\n    *ngIf=\"step\"\n    class=\"t-buttons\"\n>\n    <button\n        tuiIconButton\n        type=\"button\"\n        size=\"s\"\n        class=\"t-button\"\n        [icon]=\"options.icons.up\"\n        [appearance]=\"textfield.appearance\"\n        [disabled]=\"!canIncrement\"\n        [focusable]=\"false\"\n        (mousedown.prevent)=\"nativeFocusableElement?.focus()\"\n        (click.prevent)=\"onArrow(step)\"\n    >\n        +\n    </button>\n    <button\n        tuiIconButton\n        type=\"button\"\n        size=\"s\"\n        class=\"t-button\"\n        [icon]=\"options.icons.down\"\n        [appearance]=\"textfield.appearance\"\n        [disabled]=\"!canDecrement\"\n        [focusable]=\"false\"\n        (mousedown.prevent)=\"nativeFocusableElement?.focus()\"\n        (click.prevent)=\"onArrow(-step)\"\n    >\n        -\n    </button>\n</section>\n\n<ng-container *ngIf=\"polymorpheusValueContent.changes | async\"></ng-container>\n\n<ng-template #valueContent>\n    <ng-content select=\"tuiContent\"></ng-content>\n</ng-template>\n"]}
|
|
263
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-number/input-number.component.ts","../../../../../projects/kit/components/input-number/input-number.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {MaskitoOptions} from '@maskito/core';\nimport {\n    maskitoCaretGuard,\n    maskitoNumberOptionsGenerator,\n    maskitoParseNumber,\n} from '@maskito/kit';\nimport {\n    AbstractTuiNullableControl,\n    CHAR_HYPHEN,\n    CHAR_MINUS,\n    EMPTY_QUERY,\n    TUI_IS_IOS,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    tuiClamp,\n    TuiFocusableElementAccessor,\n    TuiInputMode,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {\n    TEXTFIELD_CONTROLLER_PROVIDER,\n    TUI_NUMBER_FORMAT,\n    TUI_TEXTFIELD_SIZE,\n    TUI_TEXTFIELD_WATCHED_CONTROLLER,\n    TuiDecimal,\n    tuiFormatNumber,\n    tuiGetFractionPartPadded,\n    TuiNumberFormatSettings,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeS,\n    TuiTextfieldController,\n    TuiTextfieldSizeDirective,\n} from '@taiga-ui/core';\nimport {PolymorpheusOutletDirective} from '@tinkoff/ng-polymorpheus';\n\nimport {TUI_INPUT_NUMBER_OPTIONS, TuiInputNumberOptions} from './input-number.options';\n\nconst DEFAULT_MAX_LENGTH = 18;\n\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        tuiAsFocusableItemAccessor(TuiInputNumberComponent),\n        tuiAsControl(TuiInputNumberComponent),\n        TEXTFIELD_CONTROLLER_PROVIDER,\n    ],\n})\nexport class TuiInputNumberComponent\n    extends AbstractTuiNullableControl<number>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private unfinishedValue: string | null = '';\n\n    @Input()\n    min = this.options.min;\n\n    @Input()\n    max = this.options.max;\n\n    @Input()\n    decimal = this.options.decimal;\n\n    @Input()\n    precision = this.options.precision;\n\n    @Input()\n    step = this.options.step;\n\n    /** @deprecated use `tuiTextfieldPrefix` from {@link TuiTextfieldControllerModule} instead */\n    @Input()\n    prefix = '';\n\n    /** @deprecated use `tuiTextfieldPostfix` from {@link TuiTextfieldControllerModule} instead */\n    @Input()\n    postfix = '';\n\n    @ContentChildren(PolymorpheusOutletDirective, {descendants: true})\n    readonly polymorpheusValueContent: QueryList<unknown> = EMPTY_QUERY;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef)\n        cdr: ChangeDetectorRef,\n        @Inject(TUI_INPUT_NUMBER_OPTIONS) readonly options: TuiInputNumberOptions,\n        @Inject(TUI_NUMBER_FORMAT) private readonly numberFormat: TuiNumberFormatSettings,\n        @Inject(TUI_IS_IOS) private readonly isIOS: boolean,\n        @Inject(TUI_TEXTFIELD_SIZE)\n        private readonly textfieldSize: TuiTextfieldSizeDirective,\n        @Inject(TUI_TEXTFIELD_WATCHED_CONTROLLER)\n        readonly controller: TuiTextfieldController,\n    ) {\n        super(control, cdr);\n    }\n\n    @HostBinding('attr.data-size')\n    get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return !this.textfield || this.computedDisabled\n            ? null\n            : this.textfield.nativeFocusableElement;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield?.focused;\n    }\n\n    get isNegativeAllowed(): boolean {\n        return this.min < 0;\n    }\n\n    get inputMode(): TuiInputMode {\n        if (this.isIOS && this.isNegativeAllowed) {\n            // iPhone does not have minus sign if inputMode is equal to 'numeric' / 'decimal'\n            return 'text';\n        }\n\n        return this.decimal === 'never' ? 'numeric' : 'decimal';\n    }\n\n    get calculatedMaxLength(): number {\n        const decimalPart =\n            this.decimal !== 'never' &&\n            this.nativeValue.includes(this.numberFormat.decimalSeparator);\n        const precision = decimalPart ? Math.min(this.precision + 1, 20) : 0;\n        const takeThousand = this.numberFormat.thousandSeparator.repeat(5).length;\n\n        return DEFAULT_MAX_LENGTH + precision + takeThousand;\n    }\n\n    get formattedValue(): string {\n        return this.value !== null ? this.getFormattedValue(this.value || 0) : '';\n    }\n\n    get computedValue(): string {\n        return this.focused ? this.nativeValue : this.formattedValue;\n    }\n\n    get canDecrement(): boolean {\n        return this.interactive && (this.value || 0) > this.min;\n    }\n\n    get canIncrement(): boolean {\n        return this.interactive && (this.value || 0) < this.max;\n    }\n\n    get computedPrefix(): string {\n        return this.prefix || this.controller.prefix;\n    }\n\n    get computedPostfix(): string {\n        const postfix = this.postfix || this.controller.postfix;\n\n        return postfix && ` ${postfix}`;\n    }\n\n    get mask(): MaskitoOptions {\n        return this.calculateMask(\n            this.precision,\n            this.decimal,\n            this.numberFormat.decimalSeparator,\n            this.numberFormat.thousandSeparator,\n            this.min,\n            this.max,\n            this.computedPrefix,\n            this.computedPostfix,\n        );\n    }\n\n    @HostListener('keydown.arrowDown', ['-step'])\n    @HostListener('keydown.arrowUp', ['step'])\n    onArrow(step: number | null): void {\n        if (!step) {\n            return;\n        }\n\n        this.value = tuiClamp((this.value || 0) + step, this.min, this.max);\n        this.nativeValue = this.formattedValue;\n    }\n\n    onValueChange(nativeValue: string): void {\n        const parsedValue = maskitoParseNumber(\n            nativeValue,\n            this.numberFormat.decimalSeparator,\n        );\n\n        this.unfinishedValue = null;\n\n        if (Number.isNaN(parsedValue)) {\n            this.value = null;\n\n            return;\n        }\n\n        if (this.isNativeValueNotFinished) {\n            this.unfinishedValue = nativeValue;\n\n            return;\n        }\n\n        if (parsedValue < this.min || parsedValue > this.max) {\n            return;\n        }\n\n        this.value = parsedValue;\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n\n        const nativeNumberValue = this.unfinishedValue\n            ? maskitoParseNumber(this.unfinishedValue, this.numberFormat.decimalSeparator)\n            : this.nativeNumberValue;\n\n        this.unfinishedValue = null;\n\n        if (Number.isNaN(nativeNumberValue)) {\n            this.nativeValue = focused ? this.computedPrefix + this.computedPostfix : '';\n            this.value = null;\n\n            return;\n        }\n\n        if (!focused) {\n            this.value = nativeNumberValue;\n            this.nativeValue = this.formattedValue;\n        }\n    }\n\n    getFormattedValue(value: number): string {\n        const absValue = Math.abs(value);\n        const hasFraction = absValue % 1 > 0;\n        let decimalLimit =\n            this.decimal === 'always' || (hasFraction && this.decimal !== 'never')\n                ? this.precision\n                : 0;\n\n        const fraction = hasFraction\n            ? tuiGetFractionPartPadded(value, this.precision)\n            : '';\n\n        if (this.focused && this.decimal !== 'always') {\n            decimalLimit = fraction.length;\n        }\n\n        return (\n            this.computedPrefix +\n            tuiFormatNumber(value, {\n                ...this.numberFormat,\n                decimalLimit,\n            }).replace(CHAR_HYPHEN, CHAR_MINUS) +\n            this.computedPostfix\n        );\n    }\n\n    private get isNativeValueNotFinished(): boolean {\n        const nativeNumberValue = this.nativeNumberValue;\n\n        return nativeNumberValue < 0\n            ? nativeNumberValue > this.max\n            : nativeNumberValue < this.min;\n    }\n\n    get nativeValue(): string {\n        return this.nativeFocusableElement ? this.nativeFocusableElement.value : '';\n    }\n\n    set nativeValue(value: string) {\n        if (!this.textfield || !this.nativeFocusableElement) {\n            return;\n        }\n\n        this.textfield.value = value;\n        this.nativeFocusableElement.value = value;\n    }\n\n    override writeValue(value: number | null): void {\n        super.writeValue(value);\n        this.nativeValue = this.formattedValue;\n    }\n\n    private get nativeNumberValue(): number {\n        return maskitoParseNumber(this.nativeValue, this.numberFormat.decimalSeparator);\n    }\n\n    @tuiPure\n    private calculateMask(\n        precision: number,\n        decimalMode: TuiDecimal,\n        decimalSeparator: string,\n        thousandSeparator: string,\n        min: number,\n        max: number,\n        prefix: string,\n        postfix: string,\n    ): MaskitoOptions {\n        const {plugins, ...options} = maskitoNumberOptionsGenerator({\n            decimalSeparator,\n            thousandSeparator,\n            min,\n            max,\n            prefix,\n            postfix,\n            precision: decimalMode === 'never' ? 0 : precision,\n            decimalZeroPadding: decimalMode === 'always',\n        });\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","<tui-primitive-textfield\n    #textfield\n    tuiValueAccessor\n    tuiTextfieldPrefix=\"\"\n    tuiTextfieldPostfix=\"\"\n    class=\"t-textfield\"\n    [pseudoHover]=\"pseudoHover\"\n    [pseudoFocus]=\"computedFocused\"\n    [pseudoActive]=\"pseudoActive\"\n    [invalid]=\"computedInvalid\"\n    [readOnly]=\"readOnly\"\n    [disabled]=\"computedDisabled\"\n    [maskito]=\"mask\"\n    [value]=\"computedValue\"\n    [focusable]=\"focusable\"\n    (valueChange)=\"onValueChange($event)\"\n    (focusedChange)=\"onFocused($event)\"\n>\n    <ng-content></ng-content>\n    <ng-content\n        select=\"input\"\n        ngProjectAs=\"input\"\n    ></ng-content>\n    <div\n        *ngIf=\"polymorpheusValueContent.length\"\n        ngProjectAs=\"tuiContent\"\n        class=\"t-value-content\"\n    >\n        <ng-container *polymorpheusOutlet=\"valueContent as text\">\n            {{ text }}\n        </ng-container>\n    </div>\n</tui-primitive-textfield>\n\n<section\n    *ngIf=\"step\"\n    class=\"t-buttons\"\n>\n    <button\n        tuiIconButton\n        type=\"button\"\n        size=\"s\"\n        class=\"t-button\"\n        [icon]=\"options.icons.up\"\n        [appearance]=\"textfield.appearance\"\n        [disabled]=\"!canIncrement\"\n        [focusable]=\"false\"\n        (mousedown.prevent)=\"nativeFocusableElement?.focus()\"\n        (click.prevent)=\"onArrow(step)\"\n    >\n        +\n    </button>\n    <button\n        tuiIconButton\n        type=\"button\"\n        size=\"s\"\n        class=\"t-button\"\n        [icon]=\"options.icons.down\"\n        [appearance]=\"textfield.appearance\"\n        [disabled]=\"!canDecrement\"\n        [focusable]=\"false\"\n        (mousedown.prevent)=\"nativeFocusableElement?.focus()\"\n        (click.prevent)=\"onArrow(-step)\"\n    >\n        -\n    </button>\n</section>\n\n<ng-container *ngIf=\"polymorpheusValueContent.changes | async\"></ng-container>\n\n<ng-template #valueContent>\n    <ng-content select=\"tuiContent\"></ng-content>\n</ng-template>\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject, Optional, Self, ViewChild, } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, Inject, Optional, Self, ViewChild, } from '@angular/core';
|
|
3
2
|
import { NgControl } from '@angular/forms';
|
|
4
|
-
import { AbstractTuiControl, tuiAsControl, tuiAsFocusableItemAccessor,
|
|
3
|
+
import { AbstractTuiControl, tuiAsControl, tuiAsFocusableItemAccessor, } from '@taiga-ui/cdk';
|
|
5
4
|
import { MODE_PROVIDER, TUI_MODE, TUI_TEXTFIELD_SIZE, TuiHintOptionsDirective, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
|
|
6
5
|
import { TUI_PASSWORD_TEXTS } from '@taiga-ui/kit/tokens';
|
|
7
6
|
import { combineLatest, EMPTY } from 'rxjs';
|
|
@@ -29,6 +28,9 @@ export class TuiInputPasswordComponent extends AbstractTuiControl {
|
|
|
29
28
|
this.directive$.pipe(startWith(null), map(() => { var _a; return ((_a = this.hintOptions) === null || _a === void 0 ? void 0 : _a.appearance) || ''; })),
|
|
30
29
|
]).pipe(map(([mode, controller]) => controller || mode), startWith(''));
|
|
31
30
|
}
|
|
31
|
+
get size() {
|
|
32
|
+
return this.textfieldSize.size;
|
|
33
|
+
}
|
|
32
34
|
get nativeFocusableElement() {
|
|
33
35
|
return this.computedDisabled || !this.textfield
|
|
34
36
|
? null
|
|
@@ -40,9 +42,6 @@ export class TuiInputPasswordComponent extends AbstractTuiControl {
|
|
|
40
42
|
get icon() {
|
|
41
43
|
return this.isPasswordHidden ? this.options.icons.hide : this.options.icons.show;
|
|
42
44
|
}
|
|
43
|
-
get context() {
|
|
44
|
-
return this.getContext(this.textfieldSize.size);
|
|
45
|
-
}
|
|
46
45
|
get inputType() {
|
|
47
46
|
return this.isPasswordHidden || !this.interactive ? 'password' : 'text';
|
|
48
47
|
}
|
|
@@ -58,19 +57,13 @@ export class TuiInputPasswordComponent extends AbstractTuiControl {
|
|
|
58
57
|
getFallbackValue() {
|
|
59
58
|
return '';
|
|
60
59
|
}
|
|
61
|
-
getContext($implicit) {
|
|
62
|
-
return { $implicit };
|
|
63
|
-
}
|
|
64
60
|
}
|
|
65
61
|
TuiInputPasswordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputPasswordComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_TEXTFIELD_SIZE }, { token: TUI_PASSWORD_TEXTS }, { token: TUI_INPUT_PASSWORD_OPTIONS }, { token: TuiHintOptionsDirective, optional: true }, { token: TUI_MODE }], target: i0.ɵɵFactoryTarget.Component });
|
|
66
|
-
TuiInputPasswordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputPasswordComponent, selector: "tui-input-password", providers: [
|
|
62
|
+
TuiInputPasswordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputPasswordComponent, selector: "tui-input-password", host: { properties: { "attr.data-size": "this.size" } }, providers: [
|
|
67
63
|
tuiAsFocusableItemAccessor(TuiInputPasswordComponent),
|
|
68
64
|
tuiAsControl(TuiInputPasswordComponent),
|
|
69
65
|
MODE_PROVIDER,
|
|
70
|
-
], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-primitive-textfield\n class=\"t-textfield\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoActive]=\"pseudoActive\"\n [invalid]=\"computedInvalid\"\n [focusable]=\"focusable\"\n [nativeId]=\"nativeId\"\n [disabled]=\"computedDisabled\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldIcon]=\"interactive ? iconContent : ''\"\n [(value)]=\"value\"\n (focusedChange)=\"onFocused($event)\"\n>\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n</tui-primitive-textfield>\n\n<ng-template\n #iconContent=\"polymorpheus\"\n [polymorpheus]=\"type\"\n>\n <ng-container *ngIf=\"passwordTexts$ | async as texts\">\n <tui-svg\n *polymorpheusOutlet=\"icon as src; context:
|
|
71
|
-
__decorate([
|
|
72
|
-
tuiPure
|
|
73
|
-
], TuiInputPasswordComponent.prototype, "getContext", null);
|
|
66
|
+
], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-primitive-textfield\n class=\"t-textfield\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoActive]=\"pseudoActive\"\n [invalid]=\"computedInvalid\"\n [focusable]=\"focusable\"\n [nativeId]=\"nativeId\"\n [disabled]=\"computedDisabled\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldIcon]=\"interactive ? iconContent : ''\"\n [(value)]=\"value\"\n (focusedChange)=\"onFocused($event)\"\n>\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n</tui-primitive-textfield>\n\n<ng-template\n #iconContent=\"polymorpheus\"\n [polymorpheus]=\"type\"\n>\n <ng-container *ngIf=\"passwordTexts$ | async as texts\">\n <tui-svg\n *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n tuiWrapper\n appearance=\"icon\"\n automation-id=\"tui-password__icon\"\n class=\"t-icon\"\n [tuiHint]=\"texts[0] && texts[1] && hintContent\"\n [tuiHintDirection]=\"hintOptions?.direction || 'bottom-left'\"\n [tuiHintAppearance]=\"(computedAppearance$ | async) || ''\"\n [src]=\"src\"\n (click)=\"togglePasswordVisibility()\"\n ></tui-svg>\n\n <ng-template\n #hintContent=\"polymorpheus\"\n polymorpheus\n >\n {{ isPasswordHidden ? texts[0] : texts[1] }}\n </ng-template>\n </ng-container>\n</ng-template>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}.t-icon{cursor:pointer;pointer-events:auto}.t-textfield{border-radius:inherit;text-align:inherit}\n"], components: [{ type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }, { type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }], directives: [{ type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i1.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { type: i2.PolymorpheusTemplate, selector: "ng-template[polymorpheus]", inputs: ["polymorpheus"], exportAs: ["polymorpheus"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i1.TuiWrapperDirective, selector: "[tuiWrapper]", inputs: ["disabled", "readOnly", "hover", "active", "focus", "invalid", "appearance"] }, { type: i1.TuiHintDirective, selector: "[tuiHint]:not(ng-container)", inputs: ["tuiHint", "tuiHintContext", "tuiHintAppearance"] }, { type: i1.TuiHintDriverDirective, selector: "[tuiHint]" }, { type: i1.TuiHintHoverDirective, selector: "[tuiHint]:not(ng-container)", inputs: ["tuiHintShowDelay", "tuiHintHideDelay"], exportAs: ["tuiHintHover"] }, { type: i1.TuiHintPositionDirective, selector: "[tuiHint]:not([tuiHintCustomPosition])", inputs: ["tuiHintDirection"] }], pipes: { "async": i3.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
74
67
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputPasswordComponent, decorators: [{
|
|
75
68
|
type: Component,
|
|
76
69
|
args: [{
|
|
@@ -114,5 +107,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
114
107
|
}] }]; }, propDecorators: { textfield: [{
|
|
115
108
|
type: ViewChild,
|
|
116
109
|
args: [TuiPrimitiveTextfieldComponent]
|
|
117
|
-
}],
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-password.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-password/input-password.component.ts","../../../../../projects/kit/components/input-password/input-password.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    Inject,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiControl,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    TuiFocusableElementAccessor,\n    TuiInputType,\n    TuiNativeFocusableElement,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {\n    MODE_PROVIDER,\n    TUI_MODE,\n    TUI_TEXTFIELD_SIZE,\n    TuiBrightness,\n    TuiHintOptionsDirective,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeS,\n    TuiTextfieldSizeDirective,\n} from '@taiga-ui/core';\nimport {TUI_PASSWORD_TEXTS} from '@taiga-ui/kit/tokens';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {combineLatest, EMPTY, Observable} from 'rxjs';\nimport {map, startWith} from 'rxjs/operators';\n\nimport {\n    TUI_INPUT_PASSWORD_OPTIONS,\n    TuiInputPasswordOptions,\n} from './input-password.options';\n\n@Component({\n    selector: 'tui-input-password',\n    templateUrl: './input-password.template.html',\n    styleUrls: ['./input-password.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputPasswordComponent),\n        tuiAsControl(TuiInputPasswordComponent),\n        MODE_PROVIDER,\n    ],\n})\nexport class TuiInputPasswordComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private readonly directive$: Observable<any> = this.hintOptions?.change$ || EMPTY;\n\n    isPasswordHidden = true;\n\n    readonly computedAppearance$: Observable<string> = combineLatest([\n        this.mode$.pipe(map(val => (val === 'onDark' ? 'onDark' : ''))),\n        this.directive$.pipe(\n            startWith(null),\n            map(() => this.hintOptions?.appearance || ''),\n        ),\n    ]).pipe(\n        map(([mode, controller]) => controller || mode),\n        startWith(''),\n    );\n\n    readonly type!: TuiContextWithImplicit<TuiSizeL | TuiSizeS>;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(TUI_TEXTFIELD_SIZE)\n        private readonly textfieldSize: TuiTextfieldSizeDirective,\n        @Inject(TUI_PASSWORD_TEXTS)\n        readonly passwordTexts$: Observable<[string, string]>,\n        @Inject(TUI_INPUT_PASSWORD_OPTIONS)\n        readonly options: TuiInputPasswordOptions,\n        @Optional()\n        @Inject(TuiHintOptionsDirective)\n        readonly hintOptions: TuiHintOptionsDirective | null,\n        @Inject(TUI_MODE)\n        private readonly mode$: Observable<TuiBrightness | null>,\n    ) {\n        super(control, cdr);\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return this.computedDisabled || !this.textfield\n            ? null\n            : this.textfield.nativeFocusableElement;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield && this.textfield.focused;\n    }\n\n    get icon(): PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>> {\n        return this.isPasswordHidden ? this.options.icons.hide : this.options.icons.show;\n    }\n\n    get context(): TuiContextWithImplicit<TuiSizeL | TuiSizeS> {\n        return this.getContext(this.textfieldSize.size);\n    }\n\n    get inputType(): TuiInputType {\n        return this.isPasswordHidden || !this.interactive ? 'password' : 'text';\n    }\n\n    onValueChange(textValue: string): void {\n        this.value = textValue;\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    togglePasswordVisibility(): void {\n        this.isPasswordHidden = !this.isPasswordHidden;\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n\n    @tuiPure\n    private getContext(\n        $implicit: TuiSizeL | TuiSizeS,\n    ): TuiContextWithImplicit<TuiSizeL | TuiSizeS> {\n        return {$implicit};\n    }\n}\n","<tui-primitive-textfield\n    class=\"t-textfield\"\n    [pseudoFocus]=\"pseudoFocus\"\n    [pseudoHover]=\"pseudoHover\"\n    [pseudoActive]=\"pseudoActive\"\n    [invalid]=\"computedInvalid\"\n    [focusable]=\"focusable\"\n    [nativeId]=\"nativeId\"\n    [disabled]=\"computedDisabled\"\n    [readOnly]=\"readOnly\"\n    [tuiTextfieldIcon]=\"interactive ? iconContent : ''\"\n    [(value)]=\"value\"\n    (focusedChange)=\"onFocused($event)\"\n>\n    <ng-content></ng-content>\n    <ng-content\n        select=\"input\"\n        ngProjectAs=\"input\"\n    ></ng-content>\n</tui-primitive-textfield>\n\n<ng-template\n    #iconContent=\"polymorpheus\"\n    [polymorpheus]=\"type\"\n>\n    <ng-container *ngIf=\"passwordTexts$ | async as texts\">\n        <tui-svg\n            *polymorpheusOutlet=\"icon as src; context: context\"\n            tuiWrapper\n            appearance=\"icon\"\n            automation-id=\"tui-password__icon\"\n            class=\"t-icon\"\n            [tuiHint]=\"texts[0] && texts[1] && hintContent\"\n            [tuiHintDirection]=\"hintOptions?.direction || 'bottom-left'\"\n            [tuiHintAppearance]=\"(computedAppearance$ | async) || ''\"\n            [src]=\"src\"\n            (click)=\"togglePasswordVisibility()\"\n        ></tui-svg>\n\n        <ng-template\n            #hintContent=\"polymorpheus\"\n            polymorpheus\n        >\n            {{ isPasswordHidden ? texts[0] : texts[1] }}\n        </ng-template>\n    </ng-container>\n</ng-template>\n"]}
|
|
110
|
+
}], size: [{
|
|
111
|
+
type: HostBinding,
|
|
112
|
+
args: ['attr.data-size']
|
|
113
|
+
}] } });
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-password.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-password/input-password.component.ts","../../../../../projects/kit/components/input-password/input-password.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    Inject,\n    Optional,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiControl,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    TuiFocusableElementAccessor,\n    TuiInputType,\n    TuiNativeFocusableElement,\n} from '@taiga-ui/cdk';\nimport {\n    MODE_PROVIDER,\n    TUI_MODE,\n    TUI_TEXTFIELD_SIZE,\n    TuiBrightness,\n    TuiHintOptionsDirective,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeS,\n    TuiTextfieldSizeDirective,\n} from '@taiga-ui/core';\nimport {TUI_PASSWORD_TEXTS} from '@taiga-ui/kit/tokens';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {combineLatest, EMPTY, Observable} from 'rxjs';\nimport {map, startWith} from 'rxjs/operators';\n\nimport {\n    TUI_INPUT_PASSWORD_OPTIONS,\n    TuiInputPasswordOptions,\n} from './input-password.options';\n\n@Component({\n    selector: 'tui-input-password',\n    templateUrl: './input-password.template.html',\n    styleUrls: ['./input-password.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputPasswordComponent),\n        tuiAsControl(TuiInputPasswordComponent),\n        MODE_PROVIDER,\n    ],\n})\nexport class TuiInputPasswordComponent\n    extends AbstractTuiControl<string>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private readonly directive$: Observable<any> = this.hintOptions?.change$ || EMPTY;\n\n    isPasswordHidden = true;\n\n    readonly computedAppearance$: Observable<string> = combineLatest([\n        this.mode$.pipe(map(val => (val === 'onDark' ? 'onDark' : ''))),\n        this.directive$.pipe(\n            startWith(null),\n            map(() => this.hintOptions?.appearance || ''),\n        ),\n    ]).pipe(\n        map(([mode, controller]) => controller || mode),\n        startWith(''),\n    );\n\n    readonly type!: TuiContextWithImplicit<TuiSizeL | TuiSizeS>;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(TUI_TEXTFIELD_SIZE)\n        private readonly textfieldSize: TuiTextfieldSizeDirective,\n        @Inject(TUI_PASSWORD_TEXTS)\n        readonly passwordTexts$: Observable<[string, string]>,\n        @Inject(TUI_INPUT_PASSWORD_OPTIONS)\n        readonly options: TuiInputPasswordOptions,\n        @Optional()\n        @Inject(TuiHintOptionsDirective)\n        readonly hintOptions: TuiHintOptionsDirective | null,\n        @Inject(TUI_MODE)\n        private readonly mode$: Observable<TuiBrightness | null>,\n    ) {\n        super(control, cdr);\n    }\n\n    @HostBinding('attr.data-size')\n    get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return this.computedDisabled || !this.textfield\n            ? null\n            : this.textfield.nativeFocusableElement;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield && this.textfield.focused;\n    }\n\n    get icon(): PolymorpheusContent<TuiContextWithImplicit<TuiSizeL | TuiSizeS>> {\n        return this.isPasswordHidden ? this.options.icons.hide : this.options.icons.show;\n    }\n\n    get inputType(): TuiInputType {\n        return this.isPasswordHidden || !this.interactive ? 'password' : 'text';\n    }\n\n    onValueChange(textValue: string): void {\n        this.value = textValue;\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    togglePasswordVisibility(): void {\n        this.isPasswordHidden = !this.isPasswordHidden;\n    }\n\n    protected getFallbackValue(): string {\n        return '';\n    }\n}\n","<tui-primitive-textfield\n    class=\"t-textfield\"\n    [pseudoFocus]=\"pseudoFocus\"\n    [pseudoHover]=\"pseudoHover\"\n    [pseudoActive]=\"pseudoActive\"\n    [invalid]=\"computedInvalid\"\n    [focusable]=\"focusable\"\n    [nativeId]=\"nativeId\"\n    [disabled]=\"computedDisabled\"\n    [readOnly]=\"readOnly\"\n    [tuiTextfieldIcon]=\"interactive ? iconContent : ''\"\n    [(value)]=\"value\"\n    (focusedChange)=\"onFocused($event)\"\n>\n    <ng-content></ng-content>\n    <ng-content\n        select=\"input\"\n        ngProjectAs=\"input\"\n    ></ng-content>\n</tui-primitive-textfield>\n\n<ng-template\n    #iconContent=\"polymorpheus\"\n    [polymorpheus]=\"type\"\n>\n    <ng-container *ngIf=\"passwordTexts$ | async as texts\">\n        <tui-svg\n            *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n            tuiWrapper\n            appearance=\"icon\"\n            automation-id=\"tui-password__icon\"\n            class=\"t-icon\"\n            [tuiHint]=\"texts[0] && texts[1] && hintContent\"\n            [tuiHintDirection]=\"hintOptions?.direction || 'bottom-left'\"\n            [tuiHintAppearance]=\"(computedAppearance$ | async) || ''\"\n            [src]=\"src\"\n            (click)=\"togglePasswordVisibility()\"\n        ></tui-svg>\n\n        <ng-template\n            #hintContent=\"polymorpheus\"\n            polymorpheus\n        >\n            {{ isPasswordHidden ? texts[0] : texts[1] }}\n        </ng-template>\n    </ng-container>\n</ng-template>\n"]}
|