@taiga-ui/legacy 4.9.0 → 4.11.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/classes/control.d.ts +1 -1
- package/components/combo-box/combo-box.component.d.ts +2 -1
- package/components/input-phone/input-phone.component.d.ts +2 -1
- package/components/input-phone-international/input-phone-international.component.d.ts +2 -1
- package/components/input-tag/input-tag.component.d.ts +2 -1
- package/components/input-time/input-time.component.d.ts +2 -1
- package/components/multi-select/multi-select.component.d.ts +6 -1
- package/components/select/select.component.d.ts +2 -1
- package/esm2022/classes/control.mjs +5 -5
- package/esm2022/components/arrow/arrow.component.mjs +3 -4
- package/esm2022/components/color-selector/color-edit/color-edit.component.mjs +3 -5
- package/esm2022/components/color-selector/color-picker/color-picker.component.mjs +3 -5
- package/esm2022/components/color-selector/color-selector.component.mjs +3 -5
- package/esm2022/components/color-selector/flat-picker/flat-picker.component.mjs +3 -5
- package/esm2022/components/color-selector/linear-multi-picker/linear-multi-picker.component.mjs +2 -3
- package/esm2022/components/color-selector/linear-picker/linear-picker.component.mjs +3 -5
- package/esm2022/components/color-selector/palette/palette.component.mjs +3 -5
- package/esm2022/components/combo-box/combo-box.component.mjs +11 -13
- package/esm2022/components/input/input.component.mjs +6 -8
- package/esm2022/components/input-color/input-color.component.mjs +3 -4
- package/esm2022/components/input-copy/input-copy.component.mjs +4 -5
- package/esm2022/components/input-date/input-date.component.mjs +4 -5
- package/esm2022/components/input-date-multi/input-date-multi.component.mjs +4 -5
- package/esm2022/components/input-date-range/input-date-range.component.mjs +4 -5
- package/esm2022/components/input-date-time/input-date-time.component.mjs +4 -5
- package/esm2022/components/input-date-time/input-date-time.directive.mjs +2 -2
- package/esm2022/components/input-month/input-month.component.mjs +4 -5
- package/esm2022/components/input-month-range/input-month-range.component.mjs +4 -5
- package/esm2022/components/input-number/input-number.component.mjs +4 -5
- package/esm2022/components/input-password/input-password.component.mjs +4 -5
- package/esm2022/components/input-phone/input-phone.component.mjs +10 -12
- package/esm2022/components/input-phone-international/input-phone-international.component.mjs +11 -12
- package/esm2022/components/input-range/input-range.component.mjs +4 -5
- package/esm2022/components/input-slider/input-slider.component.mjs +4 -5
- package/esm2022/components/input-tag/input-tag.component.mjs +22 -20
- package/esm2022/components/input-time/input-time.component.mjs +14 -15
- package/esm2022/components/input-time/native-time/native-time.component.mjs +2 -3
- package/esm2022/components/input-year/input-year.component.mjs +4 -5
- package/esm2022/components/multi-select/multi-select-group/multi-select-group.component.mjs +2 -3
- package/esm2022/components/multi-select/multi-select.component.mjs +42 -15
- package/esm2022/components/multi-select/native-multi-select/native-multi-select-group.component.mjs +2 -3
- package/esm2022/components/multi-select/native-multi-select/native-multi-select.component.mjs +2 -3
- package/esm2022/components/multi-select-option/multi-select-option.component.mjs +3 -5
- package/esm2022/components/primitive-textfield/primitive-textfield.component.mjs +4 -5
- package/esm2022/components/primitive-textfield/textfield/textfield.component.mjs +2 -3
- package/esm2022/components/primitive-textfield/value-decoration/value-decoration.component.mjs +2 -3
- package/esm2022/components/select/native-select/native-select-group.component.mjs +2 -3
- package/esm2022/components/select/native-select/native-select.component.mjs +2 -3
- package/esm2022/components/select/select.component.mjs +11 -13
- package/esm2022/components/select-option/select-option.component.mjs +3 -5
- package/esm2022/components/sheet/components/sheet/sheet.component.mjs +2 -3
- package/esm2022/components/sheet/components/sheet-bar/sheet-bar.component.mjs +3 -5
- package/esm2022/components/sheet/components/sheet-heading/sheet-heading.component.mjs +3 -5
- package/esm2022/components/sheet/components/sheets-host/sheets-host.component.mjs +3 -5
- package/esm2022/components/svg/svg.component.mjs +3 -5
- package/esm2022/components/table-bar/table-bar.component.mjs +2 -3
- package/esm2022/components/table-bar/table-bars-host.component.mjs +3 -5
- package/esm2022/components/tag/tag.component.mjs +4 -5
- package/esm2022/components/textarea/textarea.component.mjs +4 -5
- package/esm2022/components/tooltip/tooltip.component.mjs +3 -4
- package/esm2022/tokens/is-apple.mjs +3 -3
- package/esm2022/utils/is-apple.mjs +3 -6
- package/fesm2022/taiga-ui-legacy-classes.mjs +4 -4
- package/fesm2022/taiga-ui-legacy-classes.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-arrow.mjs +2 -3
- package/fesm2022/taiga-ui-legacy-components-arrow.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-color-selector.mjs +13 -26
- package/fesm2022/taiga-ui-legacy-components-color-selector.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-combo-box.mjs +13 -15
- package/fesm2022/taiga-ui-legacy-components-combo-box.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-color.mjs +2 -3
- package/fesm2022/taiga-ui-legacy-components-input-color.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-copy.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-copy.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-date-multi.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-date-multi.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-date-range.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-date-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-date-time.mjs +4 -5
- package/fesm2022/taiga-ui-legacy-components-input-date-time.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-date.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-date.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-month-range.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-month-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-month.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-month.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-number.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-number.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-password.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-password.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-phone-international.mjs +10 -11
- package/fesm2022/taiga-ui-legacy-components-input-phone-international.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-phone.mjs +12 -14
- package/fesm2022/taiga-ui-legacy-components-input-phone.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-range.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-slider.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-slider.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-tag.mjs +23 -21
- package/fesm2022/taiga-ui-legacy-components-input-tag.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-time.mjs +18 -21
- package/fesm2022/taiga-ui-legacy-components-input-time.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-year.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-input-year.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input.mjs +5 -7
- package/fesm2022/taiga-ui-legacy-components-input.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-multi-select-option.mjs +2 -4
- package/fesm2022/taiga-ui-legacy-components-multi-select-option.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-multi-select.mjs +51 -27
- package/fesm2022/taiga-ui-legacy-components-multi-select.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-primitive-textfield.mjs +5 -8
- package/fesm2022/taiga-ui-legacy-components-primitive-textfield.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-select-option.mjs +2 -4
- package/fesm2022/taiga-ui-legacy-components-select-option.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-select.mjs +10 -14
- package/fesm2022/taiga-ui-legacy-components-select.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-sheet.mjs +7 -14
- package/fesm2022/taiga-ui-legacy-components-sheet.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-svg.mjs +2 -4
- package/fesm2022/taiga-ui-legacy-components-svg.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-table-bar.mjs +3 -6
- package/fesm2022/taiga-ui-legacy-components-table-bar.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-tag.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-tag.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-textarea.mjs +3 -4
- package/fesm2022/taiga-ui-legacy-components-textarea.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-tooltip.mjs +2 -3
- package/fesm2022/taiga-ui-legacy-components-tooltip.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-tokens.mjs +2 -2
- package/fesm2022/taiga-ui-legacy-tokens.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-utils.mjs +2 -5
- package/fesm2022/taiga-ui-legacy-utils.mjs.map +1 -1
- package/package.json +25 -25
- package/styles/mixins/textfield.less +5 -1
- package/utils/icons-path-factory.d.ts +1 -1
- package/utils/is-apple.d.ts +2 -1
|
@@ -9,24 +9,24 @@ import { tuiIsElement, tuiIsInput } from '@taiga-ui/cdk/utils/dom';
|
|
|
9
9
|
import { tuiIsNativeFocused } from '@taiga-ui/cdk/utils/focus';
|
|
10
10
|
import { tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
11
11
|
import { tuiAsDataListHost, tuiAsOptionContent } from '@taiga-ui/core/components/data-list';
|
|
12
|
+
import { TuiDropdownFixed } from '@taiga-ui/core/directives/dropdown';
|
|
12
13
|
import { TUI_TIME_TEXTS, TUI_TIME_VALUE_TRANSFORMER } from '@taiga-ui/kit/tokens';
|
|
13
14
|
import { AbstractTuiNullableControl, tuiAsControl } from '@taiga-ui/legacy/classes';
|
|
14
15
|
import { TuiPrimitiveTextfieldComponent } from '@taiga-ui/legacy/components/primitive-textfield';
|
|
15
16
|
import { TUI_SELECT_OPTION } from '@taiga-ui/legacy/components/select-option';
|
|
16
17
|
import { TUI_TEXTFIELD_SIZE } from '@taiga-ui/legacy/directives';
|
|
17
18
|
import { tuiAsFocusableItemAccessor } from '@taiga-ui/legacy/tokens';
|
|
18
|
-
import { FIXED_DROPDOWN_CONTROLLER_PROVIDER } from '@taiga-ui/legacy/utils';
|
|
19
19
|
import { map, timer } from 'rxjs';
|
|
20
20
|
import { TUI_INPUT_TIME_OPTIONS } from './input-time.options';
|
|
21
21
|
import * as i0 from "@angular/core";
|
|
22
|
-
import * as i1 from "@
|
|
23
|
-
import * as i2 from "@
|
|
24
|
-
import * as i3 from "@
|
|
25
|
-
import * as i4 from "@taiga-ui/legacy/
|
|
26
|
-
import * as i5 from "@taiga-ui/
|
|
27
|
-
import * as i6 from "@taiga-ui/
|
|
28
|
-
import * as i7 from "@taiga-ui/core/
|
|
29
|
-
import * as i8 from "@taiga-ui/core/directives/
|
|
22
|
+
import * as i1 from "@taiga-ui/core/directives/dropdown";
|
|
23
|
+
import * as i2 from "@angular/common";
|
|
24
|
+
import * as i3 from "@maskito/angular";
|
|
25
|
+
import * as i4 from "@taiga-ui/legacy/components/primitive-textfield";
|
|
26
|
+
import * as i5 from "@taiga-ui/legacy/directives";
|
|
27
|
+
import * as i6 from "@taiga-ui/polymorpheus";
|
|
28
|
+
import * as i7 from "@taiga-ui/core/components/icon";
|
|
29
|
+
import * as i8 from "@taiga-ui/core/directives/appearance";
|
|
30
30
|
import * as i9 from "@taiga-ui/core/components/data-list";
|
|
31
31
|
import * as i10 from "./native-time/native-time.component";
|
|
32
32
|
class TuiInputTimeComponent extends AbstractTuiNullableControl {
|
|
@@ -233,12 +233,12 @@ class TuiInputTimeComponent extends AbstractTuiNullableControl {
|
|
|
233
233
|
}
|
|
234
234
|
}
|
|
235
235
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputTimeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
236
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputTimeComponent, selector: "tui-input-time", inputs: { disabledItemHandler: "disabledItemHandler", items: "items", itemSize: "itemSize", strict: "strict", mode: "mode" }, host: {
|
|
236
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputTimeComponent, selector: "tui-input-time", inputs: { disabledItemHandler: "disabledItemHandler", items: "items", itemSize: "itemSize", strict: "strict", mode: "mode" }, host: { listeners: { "click": "onClick()" }, properties: { "attr.data-size": "size" } }, providers: [
|
|
237
237
|
tuiAsFocusableItemAccessor(TuiInputTimeComponent),
|
|
238
238
|
tuiAsControl(TuiInputTimeComponent),
|
|
239
239
|
tuiAsDataListHost(TuiInputTimeComponent),
|
|
240
240
|
tuiAsOptionContent(TUI_SELECT_OPTION),
|
|
241
|
-
], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div\n tuiDropdownOpenMonitor\n class=\"t-wrapper\"\n [tuiDropdown]=\"dropdownContent\"\n [tuiDropdownEnabled]=\"canOpen && !nativeDatalist\"\n [tuiDropdownOpen]=\"canOpen && open\"\n (tuiActiveZoneChange)=\"onFocused($event)\"\n (tuiDropdownOpenChange)=\"onOpen($event)\"\n>\n <tui-primitive-textfield\n tuiValueAccessor\n class=\"t-textfield\"\n [disabled]=\"disabled\"\n [focusable]=\"focusable\"\n [invalid]=\"computedInvalid\"\n [maskito]=\"maskOptions\"\n [nativeId]=\"nativeId\"\n [pseudoActive]=\"pseudoActive\"\n [pseudoFocus]=\"innerPseudoFocused\"\n [pseudoHover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldFiller]=\"(getFiller$(mode) | async) || ''\"\n [tuiTextfieldIcon]=\"iconContent\"\n [value]=\"computedValue\"\n (keydown.arrowDown)=\"onArrowDown($event)\"\n (keydown.arrowUp)=\"onArrowUp($event)\"\n (valueChange)=\"onValueChange($event)\"\n >\n <ng-content />\n <input\n inputmode=\"numeric\"\n tuiTextfieldLegacy\n />\n </tui-primitive-textfield>\n</div>\n<ng-template #dropdownContent>\n <tui-data-list\n automation-id=\"tui-input-time__dropdown\"\n [size]=\"itemSize\"\n >\n <button\n *ngFor=\"let item of filtered\"\n automation-id=\"tui-input-time__item\"\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n >\n {{ item }}\n </button>\n </tui-data-list>\n</ng-template>\n\n<ng-template #iconContent>\n <tui-icon\n *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n tuiAppearance=\"icon\"\n [class.t-icon_small]=\"size === 's'\"\n [icon]=\"src.toString()\"\n />\n <input\n *ngIf=\"showNativePicker\"\n tuiTime\n />\n</ng-template>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:start}:host._disabled{pointer-events:none}.t-wrapper{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}.t-icon_small{border:.25rem
|
|
241
|
+
], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, hostDirectives: [{ directive: i1.TuiDropdownFixed }], ngImport: i0, template: "<div\n tuiDropdownOpenMonitor\n class=\"t-wrapper\"\n [tuiDropdown]=\"dropdownContent\"\n [tuiDropdownEnabled]=\"canOpen && !nativeDatalist\"\n [tuiDropdownOpen]=\"canOpen && open\"\n (tuiActiveZoneChange)=\"onFocused($event)\"\n (tuiDropdownOpenChange)=\"onOpen($event)\"\n>\n <tui-primitive-textfield\n tuiValueAccessor\n class=\"t-textfield\"\n [disabled]=\"disabled\"\n [focusable]=\"focusable\"\n [invalid]=\"computedInvalid\"\n [maskito]=\"maskOptions\"\n [nativeId]=\"nativeId\"\n [pseudoActive]=\"pseudoActive\"\n [pseudoFocus]=\"innerPseudoFocused\"\n [pseudoHover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldFiller]=\"(getFiller$(mode) | async) || ''\"\n [tuiTextfieldIcon]=\"iconContent\"\n [value]=\"computedValue\"\n (keydown.arrowDown)=\"onArrowDown($event)\"\n (keydown.arrowUp)=\"onArrowUp($event)\"\n (valueChange)=\"onValueChange($event)\"\n >\n <ng-content />\n <input\n inputmode=\"numeric\"\n tuiTextfieldLegacy\n />\n </tui-primitive-textfield>\n</div>\n<ng-template #dropdownContent>\n <tui-data-list\n automation-id=\"tui-input-time__dropdown\"\n [size]=\"itemSize\"\n >\n <button\n *ngFor=\"let item of filtered\"\n automation-id=\"tui-input-time__item\"\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n >\n {{ item }}\n </button>\n </tui-data-list>\n</ng-template>\n\n<ng-template #iconContent>\n <tui-icon\n *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n tuiAppearance=\"icon\"\n [class.t-icon_small]=\"size === 's'\"\n [icon]=\"src.toString()\"\n />\n <input\n *ngIf=\"showNativePicker\"\n tuiTime\n />\n</ng-template>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:start}:host._disabled,:host :host-context(*:disabled){pointer-events:none}.t-wrapper{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}.t-icon_small{border-width:.25rem}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { kind: "component", type: i4.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "iconCleaner", "readOnly", "invalid", "disabled", "value"], outputs: ["valueChange"] }, { kind: "directive", type: i4.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { kind: "component", type: i4.TuiTextfieldComponent, selector: "input[tuiTextfieldLegacy], textarea[tuiTextfieldLegacy]" }, { kind: "directive", type: i5.TuiValueAccessorDirective, selector: "[tuiValueAccessor]" }, { kind: "directive", type: i5.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { kind: "directive", type: i5.TuiTextfieldFillerDirective, selector: "[tuiTextfieldFiller]", inputs: ["tuiTextfieldFiller"] }, { kind: "directive", type: i6.PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "directive", type: i5.TuiLegacyDropdownOpenMonitorDirective, selector: "[tuiDropdownOpenMonitor]" }, { kind: "component", type: i7.TuiIcon, selector: "tui-icon", inputs: ["icon", "background"] }, { kind: "directive", type: i8.TuiAppearance, selector: "[tuiAppearance]", inputs: ["tuiAppearance", "tuiAppearanceState", "tuiAppearanceFocus", "tuiAppearanceMode"] }, { kind: "directive", type: i1.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container):not(ng-template)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }, { kind: "directive", type: i1.TuiDropdownOpen, selector: "[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]", inputs: ["tuiDropdownEnabled", "tuiDropdownOpen"], outputs: ["tuiDropdownOpenChange"] }, { kind: "component", type: i9.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "component", type: i9.TuiOption, selector: "button[tuiOption], a[tuiOption], label[tuiOption]", inputs: ["disabled", "value"] }, { kind: "component", type: i10.TuiNativeTimeComponent, selector: "input[tuiTime]" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
242
242
|
}
|
|
243
243
|
__decorate([
|
|
244
244
|
tuiPure
|
|
@@ -257,11 +257,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
257
257
|
tuiAsControl(TuiInputTimeComponent),
|
|
258
258
|
tuiAsDataListHost(TuiInputTimeComponent),
|
|
259
259
|
tuiAsOptionContent(TUI_SELECT_OPTION),
|
|
260
|
-
],
|
|
261
|
-
ngSkipHydration: 'true',
|
|
260
|
+
], hostDirectives: [TuiDropdownFixed], host: {
|
|
262
261
|
'(click)': 'onClick()',
|
|
263
262
|
'[attr.data-size]': 'size',
|
|
264
|
-
}, template: "<div\n tuiDropdownOpenMonitor\n class=\"t-wrapper\"\n [tuiDropdown]=\"dropdownContent\"\n [tuiDropdownEnabled]=\"canOpen && !nativeDatalist\"\n [tuiDropdownOpen]=\"canOpen && open\"\n (tuiActiveZoneChange)=\"onFocused($event)\"\n (tuiDropdownOpenChange)=\"onOpen($event)\"\n>\n <tui-primitive-textfield\n tuiValueAccessor\n class=\"t-textfield\"\n [disabled]=\"disabled\"\n [focusable]=\"focusable\"\n [invalid]=\"computedInvalid\"\n [maskito]=\"maskOptions\"\n [nativeId]=\"nativeId\"\n [pseudoActive]=\"pseudoActive\"\n [pseudoFocus]=\"innerPseudoFocused\"\n [pseudoHover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldFiller]=\"(getFiller$(mode) | async) || ''\"\n [tuiTextfieldIcon]=\"iconContent\"\n [value]=\"computedValue\"\n (keydown.arrowDown)=\"onArrowDown($event)\"\n (keydown.arrowUp)=\"onArrowUp($event)\"\n (valueChange)=\"onValueChange($event)\"\n >\n <ng-content />\n <input\n inputmode=\"numeric\"\n tuiTextfieldLegacy\n />\n </tui-primitive-textfield>\n</div>\n<ng-template #dropdownContent>\n <tui-data-list\n automation-id=\"tui-input-time__dropdown\"\n [size]=\"itemSize\"\n >\n <button\n *ngFor=\"let item of filtered\"\n automation-id=\"tui-input-time__item\"\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n >\n {{ item }}\n </button>\n </tui-data-list>\n</ng-template>\n\n<ng-template #iconContent>\n <tui-icon\n *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n tuiAppearance=\"icon\"\n [class.t-icon_small]=\"size === 's'\"\n [icon]=\"src.toString()\"\n />\n <input\n *ngIf=\"showNativePicker\"\n tuiTime\n />\n</ng-template>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:start}:host._disabled{pointer-events:none}.t-wrapper{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}.t-icon_small{border:.25rem
|
|
263
|
+
}, template: "<div\n tuiDropdownOpenMonitor\n class=\"t-wrapper\"\n [tuiDropdown]=\"dropdownContent\"\n [tuiDropdownEnabled]=\"canOpen && !nativeDatalist\"\n [tuiDropdownOpen]=\"canOpen && open\"\n (tuiActiveZoneChange)=\"onFocused($event)\"\n (tuiDropdownOpenChange)=\"onOpen($event)\"\n>\n <tui-primitive-textfield\n tuiValueAccessor\n class=\"t-textfield\"\n [disabled]=\"disabled\"\n [focusable]=\"focusable\"\n [invalid]=\"computedInvalid\"\n [maskito]=\"maskOptions\"\n [nativeId]=\"nativeId\"\n [pseudoActive]=\"pseudoActive\"\n [pseudoFocus]=\"innerPseudoFocused\"\n [pseudoHover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldFiller]=\"(getFiller$(mode) | async) || ''\"\n [tuiTextfieldIcon]=\"iconContent\"\n [value]=\"computedValue\"\n (keydown.arrowDown)=\"onArrowDown($event)\"\n (keydown.arrowUp)=\"onArrowUp($event)\"\n (valueChange)=\"onValueChange($event)\"\n >\n <ng-content />\n <input\n inputmode=\"numeric\"\n tuiTextfieldLegacy\n />\n </tui-primitive-textfield>\n</div>\n<ng-template #dropdownContent>\n <tui-data-list\n automation-id=\"tui-input-time__dropdown\"\n [size]=\"itemSize\"\n >\n <button\n *ngFor=\"let item of filtered\"\n automation-id=\"tui-input-time__item\"\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n >\n {{ item }}\n </button>\n </tui-data-list>\n</ng-template>\n\n<ng-template #iconContent>\n <tui-icon\n *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n tuiAppearance=\"icon\"\n [class.t-icon_small]=\"size === 's'\"\n [icon]=\"src.toString()\"\n />\n <input\n *ngIf=\"showNativePicker\"\n tuiTime\n />\n</ng-template>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:start}:host._disabled,:host :host-context(*:disabled){pointer-events:none}.t-wrapper{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}.t-icon_small{border-width:.25rem}\n"] }]
|
|
265
264
|
}], propDecorators: { textfield: [{
|
|
266
265
|
type: ViewChild,
|
|
267
266
|
args: [TuiPrimitiveTextfieldComponent]
|
|
@@ -276,4 +275,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
276
275
|
}], mode: [{
|
|
277
276
|
type: Input
|
|
278
277
|
}], getFiller$: [], calculateMask: [], filter: [] } });
|
|
279
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-time.component.js","sourceRoot":"","sources":["../../../../../projects/legacy/components/input-time/input-time.component.ts","../../../../../projects/legacy/components/input-time/input-time.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    inject,\n    Input,\n    ViewChild,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport type {MaskitoOptions} from '@maskito/core';\nimport {maskitoTimeOptionsGenerator} from '@maskito/kit';\nimport type {TuiValueTransformer} from '@taiga-ui/cdk/classes';\nimport {TUI_FALSE_HANDLER, TUI_STRICT_MATCHER} from '@taiga-ui/cdk/constants';\nimport type {TuiTimeLike, TuiTimeMode} from '@taiga-ui/cdk/date-time';\nimport {TuiTime} from '@taiga-ui/cdk/date-time';\nimport {TUI_IS_IOS, TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport type {TuiBooleanHandler, TuiIdentityMatcher} from '@taiga-ui/cdk/types';\nimport {tuiIsElement, tuiIsInput} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocused} from '@taiga-ui/cdk/utils/focus';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiDataListHost} from '@taiga-ui/core/components/data-list';\nimport {tuiAsDataListHost, tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport type {TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport {TUI_TIME_TEXTS, TUI_TIME_VALUE_TRANSFORMER} from '@taiga-ui/kit/tokens';\nimport {AbstractTuiNullableControl, tuiAsControl} from '@taiga-ui/legacy/classes';\nimport {TuiPrimitiveTextfieldComponent} from '@taiga-ui/legacy/components/primitive-textfield';\nimport {TUI_SELECT_OPTION} from '@taiga-ui/legacy/components/select-option';\nimport {TUI_TEXTFIELD_SIZE} from '@taiga-ui/legacy/directives';\nimport type {TuiFocusableElementAccessor} from '@taiga-ui/legacy/tokens';\nimport {tuiAsFocusableItemAccessor} from '@taiga-ui/legacy/tokens';\nimport {FIXED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/legacy/utils';\nimport type {Observable} from 'rxjs';\nimport {map, timer} from 'rxjs';\n\nimport type {TuiInputTimeOptions} from './input-time.options';\nimport {TUI_INPUT_TIME_OPTIONS} from './input-time.options';\n\n@Component({\n    standalone: false,\n    selector: 'tui-input-time',\n    templateUrl: './input-time.template.html',\n    styleUrls: ['./input-time.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputTimeComponent),\n        tuiAsControl(TuiInputTimeComponent),\n        tuiAsDataListHost(TuiInputTimeComponent),\n        tuiAsOptionContent(TUI_SELECT_OPTION),\n    ],\n    viewProviders: [FIXED_DROPDOWN_CONTROLLER_PROVIDER],\n    host: {\n        ngSkipHydration: 'true',\n        '(click)': 'onClick()',\n        '[attr.data-size]': 'size',\n    },\n})\nexport class TuiInputTimeComponent\n    extends AbstractTuiNullableControl<TuiTime>\n    implements TuiFocusableElementAccessor, TuiDataListHost<TuiTime>\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private readonly timeTexts$ = inject(TUI_TIME_TEXTS);\n    private readonly options = inject(TUI_INPUT_TIME_OPTIONS);\n    private readonly isMobile = inject(TUI_IS_MOBILE);\n    private readonly isIOS: boolean = inject(TUI_IS_IOS);\n    private readonly textfieldSize = inject(TUI_TEXTFIELD_SIZE);\n\n    protected override readonly valueTransformer: TuiValueTransformer<TuiTime | null> | null =\n        inject(TUI_TIME_VALUE_TRANSFORMER, {optional: true});\n\n    protected open = false;\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<TuiTime> = TUI_FALSE_HANDLER;\n\n    @Input()\n    public items: readonly TuiTime[] = [];\n\n    @Input()\n    public itemSize: TuiInputTimeOptions['itemSize'] = this.options.itemSize;\n\n    @Input()\n    public strict = false;\n\n    @Input()\n    public mode: TuiInputTimeOptions['mode'] = this.options.mode;\n\n    public get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    public get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield?.nativeFocusableElement ?? null;\n    }\n\n    public get focused(): boolean {\n        return tuiIsNativeFocused(this.nativeFocusableElement);\n    }\n\n    public get computedValue(): string {\n        return this.value ? this.value.toString(this.mode) : this.nativeValue;\n    }\n\n    public get nativeValue(): string {\n        return this.nativeFocusableElement?.value || '';\n    }\n\n    public set nativeValue(value: string) {\n        if (!this.nativeFocusableElement) {\n            return;\n        }\n\n        this.nativeFocusableElement.value = value;\n    }\n\n    public readonly identityMatcher: TuiIdentityMatcher<TuiTime> = (\n        controlValue: TuiTime,\n        dropdownValue: TuiTime,\n    ) =>\n        controlValue instanceof TuiTime &&\n        controlValue.valueOf() === dropdownValue.valueOf();\n\n    public checkOption(option: TuiTime): void {\n        if (option.valueOf() === this.value?.valueOf()) {\n            this.value = option;\n        }\n    }\n\n    public handleOption(item: TuiTime): void {\n        this.focusInput();\n        this.value = item;\n    }\n\n    public override writeValue(value: TuiTime | null): void {\n        super.writeValue(value);\n        this.nativeValue = value ? this.computedValue : '';\n    }\n\n    public onValueChange(value: string): void {\n        this.open = !!this.items.length;\n\n        if (this.control) {\n            this.control.updateValueAndValidity({emitEvent: false});\n        }\n\n        const match = this.getMatch(value);\n\n        if (match !== undefined) {\n            this.value = match;\n\n            return;\n        }\n\n        if (value.length !== this.mode.length) {\n            this.value = null;\n\n            return;\n        }\n\n        const time = TuiTime.fromString(value);\n\n        this.value = this.strict ? this.findNearestTimeFromItems(time) : time;\n    }\n\n    protected get canOpen(): boolean {\n        return this.interactive && !!this.filtered.length;\n    }\n\n    protected get filtered(): readonly TuiTime[] {\n        return this.filter(this.items, this.mode, this.computedSearch);\n    }\n\n    protected get showNativePicker(): boolean {\n        return (\n            this.nativePicker &&\n            (!this.isIOS || (this.mode === 'HH:MM' && !this.items.length))\n        );\n    }\n\n    protected get nativeDatalist(): boolean {\n        return this.nativePicker && !this.isIOS;\n    }\n\n    protected get maskOptions(): MaskitoOptions {\n        return this.calculateMask(this.mode);\n    }\n\n    protected get computedSearch(): string {\n        return this.computedValue.length !== this.mode.length ? this.computedValue : '';\n    }\n\n    protected get innerPseudoFocused(): boolean | null {\n        if (this.pseudoFocus === false) {\n            return false;\n        }\n\n        if ((this.open && this.canOpen) || this.computedFocused) {\n            return true;\n        }\n\n        return null;\n    }\n\n    protected get icon(): TuiInputTimeOptions['icon'] {\n        return this.options.icon;\n    }\n\n    @tuiPure\n    protected getFiller$(mode: TuiTimeMode): Observable<string> {\n        return this.timeTexts$.pipe(map((texts) => texts[mode]));\n    }\n\n    protected onClick(): void {\n        this.open = !this.open;\n    }\n\n    protected onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n\n        if (focused || this.value !== null || this.nativeValue === '') {\n            return;\n        }\n\n        this.value = TuiTime.fromString(this.nativeValue);\n\n        timer(0)\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe(() => {\n                if (this.nativeValue.endsWith('.') || this.nativeValue.endsWith(':')) {\n                    this.nativeValue = this.nativeValue.slice(0, -1);\n                }\n            });\n    }\n\n    protected onArrowUp(event: Event): void {\n        if (this.items.length) {\n            return;\n        }\n\n        this.processArrow(event, 1);\n    }\n\n    protected onArrowDown(event: Event): void {\n        if (this.items.length) {\n            return;\n        }\n\n        this.processArrow(event, -1);\n    }\n\n    protected onOpen(open: boolean): void {\n        this.open = open;\n    }\n\n    private get nativePicker(): boolean {\n        return !!this.options.nativePicker && this.isMobile;\n    }\n\n    @tuiPure\n    private calculateMask(mode: TuiTimeMode): MaskitoOptions {\n        const {HH, MM, SS, MS} = this.options.maxValues;\n\n        return maskitoTimeOptionsGenerator({\n            mode,\n            timeSegmentMaxValues: {\n                hours: HH,\n                minutes: MM,\n                seconds: SS,\n                milliseconds: MS,\n            },\n        });\n    }\n\n    @tuiPure\n    private filter(\n        items: readonly TuiTime[],\n        mode: TuiTimeMode,\n        search: string,\n    ): readonly TuiTime[] {\n        return items.filter((item) => item.toString(mode).includes(search));\n    }\n\n    private findNearestTimeFromItems(value: TuiTime): TuiTime | null {\n        // eslint-disable-next-line no-restricted-syntax\n        return this.items.reduce((previous, current) =>\n            Math.abs(current.valueOf() - value.valueOf()) <\n            Math.abs(previous.valueOf() - value.valueOf())\n                ? current\n                : previous,\n        );\n    }\n\n    private getMatch(value: string): TuiTime | undefined {\n        return this.items.find((item) => TUI_STRICT_MATCHER(item, value));\n    }\n\n    private close(): void {\n        this.open = false;\n    }\n\n    private processArrow(event: Event, shift: -1 | 1): void {\n        const {target} = event;\n\n        if (this.readOnly || !tuiIsElement(target) || !tuiIsInput(target)) {\n            return;\n        }\n\n        const selectionStart = target.selectionStart || 0;\n\n        this.shiftTime(this.calculateShift(selectionStart, shift));\n\n        target.setSelectionRange(selectionStart, selectionStart);\n        event.preventDefault();\n    }\n\n    private calculateShift(selectionStart: number, shift: number): TuiTimeLike {\n        if (selectionStart <= 2) {\n            return {hours: shift};\n        }\n\n        if (selectionStart <= 5) {\n            return {minutes: shift};\n        }\n\n        if (selectionStart <= 8) {\n            return {seconds: shift};\n        }\n\n        return {ms: shift};\n    }\n\n    private shiftTime(shift: TuiTimeLike): void {\n        if (this.value === null) {\n            return;\n        }\n\n        const increasedTime = this.value.shift(shift);\n\n        // Manual update so we can set caret position properly\n        this.nativeValue = increasedTime.toString(this.mode);\n        this.value = increasedTime;\n    }\n\n    private focusInput(preventScroll = false): void {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.focus({preventScroll});\n            this.close();\n        }\n    }\n}\n","<div\n    tuiDropdownOpenMonitor\n    class=\"t-wrapper\"\n    [tuiDropdown]=\"dropdownContent\"\n    [tuiDropdownEnabled]=\"canOpen && !nativeDatalist\"\n    [tuiDropdownOpen]=\"canOpen && open\"\n    (tuiActiveZoneChange)=\"onFocused($event)\"\n    (tuiDropdownOpenChange)=\"onOpen($event)\"\n>\n    <tui-primitive-textfield\n        tuiValueAccessor\n        class=\"t-textfield\"\n        [disabled]=\"disabled\"\n        [focusable]=\"focusable\"\n        [invalid]=\"computedInvalid\"\n        [maskito]=\"maskOptions\"\n        [nativeId]=\"nativeId\"\n        [pseudoActive]=\"pseudoActive\"\n        [pseudoFocus]=\"innerPseudoFocused\"\n        [pseudoHover]=\"pseudoHover\"\n        [readOnly]=\"readOnly\"\n        [tuiTextfieldFiller]=\"(getFiller$(mode) | async) || ''\"\n        [tuiTextfieldIcon]=\"iconContent\"\n        [value]=\"computedValue\"\n        (keydown.arrowDown)=\"onArrowDown($event)\"\n        (keydown.arrowUp)=\"onArrowUp($event)\"\n        (valueChange)=\"onValueChange($event)\"\n    >\n        <ng-content />\n        <input\n            inputmode=\"numeric\"\n            tuiTextfieldLegacy\n        />\n    </tui-primitive-textfield>\n</div>\n<ng-template #dropdownContent>\n    <tui-data-list\n        automation-id=\"tui-input-time__dropdown\"\n        [size]=\"itemSize\"\n    >\n        <button\n            *ngFor=\"let item of filtered\"\n            automation-id=\"tui-input-time__item\"\n            tuiOption\n            type=\"button\"\n            [disabled]=\"disabledItemHandler(item)\"\n            [value]=\"item\"\n        >\n            {{ item }}\n        </button>\n    </tui-data-list>\n</ng-template>\n\n<ng-template #iconContent>\n    <tui-icon\n        *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n        tuiAppearance=\"icon\"\n        [class.t-icon_small]=\"size === 's'\"\n        [icon]=\"src.toString()\"\n    />\n    <input\n        *ngIf=\"showNativePicker\"\n        tuiTime\n    />\n</ng-template>\n"]}
|
|
278
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-time.component.js","sourceRoot":"","sources":["../../../../../projects/legacy/components/input-time/input-time.component.ts","../../../../../projects/legacy/components/input-time/input-time.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    inject,\n    Input,\n    ViewChild,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport type {MaskitoOptions} from '@maskito/core';\nimport {maskitoTimeOptionsGenerator} from '@maskito/kit';\nimport type {TuiValueTransformer} from '@taiga-ui/cdk/classes';\nimport {TUI_FALSE_HANDLER, TUI_STRICT_MATCHER} from '@taiga-ui/cdk/constants';\nimport type {TuiTimeLike, TuiTimeMode} from '@taiga-ui/cdk/date-time';\nimport {TuiTime} from '@taiga-ui/cdk/date-time';\nimport {TUI_IS_IOS, TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport type {TuiBooleanHandler, TuiIdentityMatcher} from '@taiga-ui/cdk/types';\nimport {tuiIsElement, tuiIsInput} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocused} from '@taiga-ui/cdk/utils/focus';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiDataListHost} from '@taiga-ui/core/components/data-list';\nimport {tuiAsDataListHost, tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport {TuiDropdownFixed} from '@taiga-ui/core/directives/dropdown';\nimport type {TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport {TUI_TIME_TEXTS, TUI_TIME_VALUE_TRANSFORMER} from '@taiga-ui/kit/tokens';\nimport {AbstractTuiNullableControl, tuiAsControl} from '@taiga-ui/legacy/classes';\nimport {TuiPrimitiveTextfieldComponent} from '@taiga-ui/legacy/components/primitive-textfield';\nimport {TUI_SELECT_OPTION} from '@taiga-ui/legacy/components/select-option';\nimport {TUI_TEXTFIELD_SIZE} from '@taiga-ui/legacy/directives';\nimport type {TuiFocusableElementAccessor} from '@taiga-ui/legacy/tokens';\nimport {tuiAsFocusableItemAccessor} from '@taiga-ui/legacy/tokens';\nimport type {Observable} from 'rxjs';\nimport {map, timer} from 'rxjs';\n\nimport type {TuiInputTimeOptions} from './input-time.options';\nimport {TUI_INPUT_TIME_OPTIONS} from './input-time.options';\n\n@Component({\n    standalone: false,\n    selector: 'tui-input-time',\n    templateUrl: './input-time.template.html',\n    styleUrls: ['./input-time.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputTimeComponent),\n        tuiAsControl(TuiInputTimeComponent),\n        tuiAsDataListHost(TuiInputTimeComponent),\n        tuiAsOptionContent(TUI_SELECT_OPTION),\n    ],\n    hostDirectives: [TuiDropdownFixed],\n    host: {\n        '(click)': 'onClick()',\n        '[attr.data-size]': 'size',\n    },\n})\nexport class TuiInputTimeComponent\n    extends AbstractTuiNullableControl<TuiTime>\n    implements TuiFocusableElementAccessor, TuiDataListHost<TuiTime>\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private readonly timeTexts$ = inject(TUI_TIME_TEXTS);\n    private readonly options = inject(TUI_INPUT_TIME_OPTIONS);\n    private readonly isMobile = inject(TUI_IS_MOBILE);\n    private readonly isIOS: boolean = inject(TUI_IS_IOS);\n    private readonly textfieldSize = inject(TUI_TEXTFIELD_SIZE);\n\n    protected override readonly valueTransformer: TuiValueTransformer<TuiTime | null> | null =\n        inject(TUI_TIME_VALUE_TRANSFORMER, {optional: true});\n\n    protected open = false;\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<TuiTime> = TUI_FALSE_HANDLER;\n\n    @Input()\n    public items: readonly TuiTime[] = [];\n\n    @Input()\n    public itemSize: TuiInputTimeOptions['itemSize'] = this.options.itemSize;\n\n    @Input()\n    public strict = false;\n\n    @Input()\n    public mode: TuiInputTimeOptions['mode'] = this.options.mode;\n\n    public get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    public get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield?.nativeFocusableElement ?? null;\n    }\n\n    public get focused(): boolean {\n        return tuiIsNativeFocused(this.nativeFocusableElement);\n    }\n\n    public get computedValue(): string {\n        return this.value ? this.value.toString(this.mode) : this.nativeValue;\n    }\n\n    public get nativeValue(): string {\n        return this.nativeFocusableElement?.value || '';\n    }\n\n    public set nativeValue(value: string) {\n        if (!this.nativeFocusableElement) {\n            return;\n        }\n\n        this.nativeFocusableElement.value = value;\n    }\n\n    public readonly identityMatcher: TuiIdentityMatcher<TuiTime> = (\n        controlValue: TuiTime,\n        dropdownValue: TuiTime,\n    ) =>\n        controlValue instanceof TuiTime &&\n        controlValue.valueOf() === dropdownValue.valueOf();\n\n    public checkOption(option: TuiTime): void {\n        if (option.valueOf() === this.value?.valueOf()) {\n            this.value = option;\n        }\n    }\n\n    public handleOption(item: TuiTime): void {\n        this.focusInput();\n        this.value = item;\n    }\n\n    public override writeValue(value: TuiTime | null): void {\n        super.writeValue(value);\n        this.nativeValue = value ? this.computedValue : '';\n    }\n\n    public onValueChange(value: string): void {\n        this.open = !!this.items.length;\n\n        if (this.control) {\n            this.control.updateValueAndValidity({emitEvent: false});\n        }\n\n        const match = this.getMatch(value);\n\n        if (match !== undefined) {\n            this.value = match;\n\n            return;\n        }\n\n        if (value.length !== this.mode.length) {\n            this.value = null;\n\n            return;\n        }\n\n        const time = TuiTime.fromString(value);\n\n        this.value = this.strict ? this.findNearestTimeFromItems(time) : time;\n    }\n\n    protected get canOpen(): boolean {\n        return this.interactive && !!this.filtered.length;\n    }\n\n    protected get filtered(): readonly TuiTime[] {\n        return this.filter(this.items, this.mode, this.computedSearch);\n    }\n\n    protected get showNativePicker(): boolean {\n        return (\n            this.nativePicker &&\n            (!this.isIOS || (this.mode === 'HH:MM' && !this.items.length))\n        );\n    }\n\n    protected get nativeDatalist(): boolean {\n        return this.nativePicker && !this.isIOS;\n    }\n\n    protected get maskOptions(): MaskitoOptions {\n        return this.calculateMask(this.mode);\n    }\n\n    protected get computedSearch(): string {\n        return this.computedValue.length !== this.mode.length ? this.computedValue : '';\n    }\n\n    protected get innerPseudoFocused(): boolean | null {\n        if (this.pseudoFocus === false) {\n            return false;\n        }\n\n        if ((this.open && this.canOpen) || this.computedFocused) {\n            return true;\n        }\n\n        return null;\n    }\n\n    protected get icon(): TuiInputTimeOptions['icon'] {\n        return this.options.icon;\n    }\n\n    @tuiPure\n    protected getFiller$(mode: TuiTimeMode): Observable<string> {\n        return this.timeTexts$.pipe(map((texts) => texts[mode]));\n    }\n\n    protected onClick(): void {\n        this.open = !this.open;\n    }\n\n    protected onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n\n        if (focused || this.value !== null || this.nativeValue === '') {\n            return;\n        }\n\n        this.value = TuiTime.fromString(this.nativeValue);\n\n        timer(0)\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe(() => {\n                if (this.nativeValue.endsWith('.') || this.nativeValue.endsWith(':')) {\n                    this.nativeValue = this.nativeValue.slice(0, -1);\n                }\n            });\n    }\n\n    protected onArrowUp(event: Event): void {\n        if (this.items.length) {\n            return;\n        }\n\n        this.processArrow(event, 1);\n    }\n\n    protected onArrowDown(event: Event): void {\n        if (this.items.length) {\n            return;\n        }\n\n        this.processArrow(event, -1);\n    }\n\n    protected onOpen(open: boolean): void {\n        this.open = open;\n    }\n\n    private get nativePicker(): boolean {\n        return !!this.options.nativePicker && this.isMobile;\n    }\n\n    @tuiPure\n    private calculateMask(mode: TuiTimeMode): MaskitoOptions {\n        const {HH, MM, SS, MS} = this.options.maxValues;\n\n        return maskitoTimeOptionsGenerator({\n            mode,\n            timeSegmentMaxValues: {\n                hours: HH,\n                minutes: MM,\n                seconds: SS,\n                milliseconds: MS,\n            },\n        });\n    }\n\n    @tuiPure\n    private filter(\n        items: readonly TuiTime[],\n        mode: TuiTimeMode,\n        search: string,\n    ): readonly TuiTime[] {\n        return items.filter((item) => item.toString(mode).includes(search));\n    }\n\n    private findNearestTimeFromItems(value: TuiTime): TuiTime | null {\n        // eslint-disable-next-line no-restricted-syntax\n        return this.items.reduce((previous, current) =>\n            Math.abs(current.valueOf() - value.valueOf()) <\n            Math.abs(previous.valueOf() - value.valueOf())\n                ? current\n                : previous,\n        );\n    }\n\n    private getMatch(value: string): TuiTime | undefined {\n        return this.items.find((item) => TUI_STRICT_MATCHER(item, value));\n    }\n\n    private close(): void {\n        this.open = false;\n    }\n\n    private processArrow(event: Event, shift: -1 | 1): void {\n        const {target} = event;\n\n        if (this.readOnly || !tuiIsElement(target) || !tuiIsInput(target)) {\n            return;\n        }\n\n        const selectionStart = target.selectionStart || 0;\n\n        this.shiftTime(this.calculateShift(selectionStart, shift));\n\n        target.setSelectionRange(selectionStart, selectionStart);\n        event.preventDefault();\n    }\n\n    private calculateShift(selectionStart: number, shift: number): TuiTimeLike {\n        if (selectionStart <= 2) {\n            return {hours: shift};\n        }\n\n        if (selectionStart <= 5) {\n            return {minutes: shift};\n        }\n\n        if (selectionStart <= 8) {\n            return {seconds: shift};\n        }\n\n        return {ms: shift};\n    }\n\n    private shiftTime(shift: TuiTimeLike): void {\n        if (this.value === null) {\n            return;\n        }\n\n        const increasedTime = this.value.shift(shift);\n\n        // Manual update so we can set caret position properly\n        this.nativeValue = increasedTime.toString(this.mode);\n        this.value = increasedTime;\n    }\n\n    private focusInput(preventScroll = false): void {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.focus({preventScroll});\n            this.close();\n        }\n    }\n}\n","<div\n    tuiDropdownOpenMonitor\n    class=\"t-wrapper\"\n    [tuiDropdown]=\"dropdownContent\"\n    [tuiDropdownEnabled]=\"canOpen && !nativeDatalist\"\n    [tuiDropdownOpen]=\"canOpen && open\"\n    (tuiActiveZoneChange)=\"onFocused($event)\"\n    (tuiDropdownOpenChange)=\"onOpen($event)\"\n>\n    <tui-primitive-textfield\n        tuiValueAccessor\n        class=\"t-textfield\"\n        [disabled]=\"disabled\"\n        [focusable]=\"focusable\"\n        [invalid]=\"computedInvalid\"\n        [maskito]=\"maskOptions\"\n        [nativeId]=\"nativeId\"\n        [pseudoActive]=\"pseudoActive\"\n        [pseudoFocus]=\"innerPseudoFocused\"\n        [pseudoHover]=\"pseudoHover\"\n        [readOnly]=\"readOnly\"\n        [tuiTextfieldFiller]=\"(getFiller$(mode) | async) || ''\"\n        [tuiTextfieldIcon]=\"iconContent\"\n        [value]=\"computedValue\"\n        (keydown.arrowDown)=\"onArrowDown($event)\"\n        (keydown.arrowUp)=\"onArrowUp($event)\"\n        (valueChange)=\"onValueChange($event)\"\n    >\n        <ng-content />\n        <input\n            inputmode=\"numeric\"\n            tuiTextfieldLegacy\n        />\n    </tui-primitive-textfield>\n</div>\n<ng-template #dropdownContent>\n    <tui-data-list\n        automation-id=\"tui-input-time__dropdown\"\n        [size]=\"itemSize\"\n    >\n        <button\n            *ngFor=\"let item of filtered\"\n            automation-id=\"tui-input-time__item\"\n            tuiOption\n            type=\"button\"\n            [disabled]=\"disabledItemHandler(item)\"\n            [value]=\"item\"\n        >\n            {{ item }}\n        </button>\n    </tui-data-list>\n</ng-template>\n\n<ng-template #iconContent>\n    <tui-icon\n        *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n        tuiAppearance=\"icon\"\n        [class.t-icon_small]=\"size === 's'\"\n        [icon]=\"src.toString()\"\n    />\n    <input\n        *ngIf=\"showNativePicker\"\n        tuiTime\n    />\n</ng-template>\n"]}
|
|
@@ -28,7 +28,7 @@ class TuiNativeTimeComponent {
|
|
|
28
28
|
this.host.onValueChange(value);
|
|
29
29
|
}
|
|
30
30
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiNativeTimeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
31
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiNativeTimeComponent, selector: "input[tuiTime]", host: { attributes: { "
|
|
31
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiNativeTimeComponent, selector: "input[tuiTime]", host: { attributes: { "type": "time" }, listeners: { "change.stop": "onChange($event.target.value)", "click.stop.silent": "0", "mousedown.stop.silent": "0" }, properties: { "attr.list": "autoId", "tabIndex": "-1", "value": "value", "step": "step" } }, ngImport: i0, template: `
|
|
32
32
|
<datalist
|
|
33
33
|
*ngIf="items.length"
|
|
34
34
|
[id]="autoId"
|
|
@@ -54,7 +54,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
54
54
|
></option>
|
|
55
55
|
</datalist>
|
|
56
56
|
`, changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
57
|
-
ngSkipHydration: 'true',
|
|
58
57
|
type: 'time',
|
|
59
58
|
'[attr.list]': 'autoId',
|
|
60
59
|
'[tabIndex]': '-1',
|
|
@@ -65,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
65
64
|
'(mousedown.stop.silent)': '0',
|
|
66
65
|
}, styles: [":host{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;opacity:0;pointer-events:auto;font-size:2rem}\n"] }]
|
|
67
66
|
}] });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF0aXZlLXRpbWUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGVnYWN5L2NvbXBvbmVudHMvaW5wdXQtdGltZS9uYXRpdmUtdGltZS9uYXRpdmUtdGltZS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ25ELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLHlCQUF5QixDQUFDOzs7QUFJM0QsTUEyQmEsc0JBQXNCO0lBM0JuQztRQTRCdUIsU0FBSSxHQUFHLE1BQU0sQ0FBd0Isa0JBQWtCLENBQUMsQ0FBQztRQUV6RCxXQUFNLEdBQUcsV0FBVyxFQUFFLENBQUM7S0F3QjdDO0lBdEJHLElBQWMsS0FBSztRQUNmLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUN4RSxDQUFDO0lBRUQsSUFBYyxLQUFLO1FBQ2YsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQ25GLENBQUM7SUFFRCxJQUFjLElBQUk7UUFDZCxRQUFRLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ3BCLEtBQUssVUFBVTtnQkFDWCxPQUFPLENBQUMsQ0FBQztZQUNiLEtBQUssY0FBYztnQkFDZixPQUFPLEtBQUssQ0FBQztZQUNqQjtnQkFDSSxPQUFPLEVBQUUsQ0FBQztTQUNqQjtJQUNMLENBQUM7SUFFUyxRQUFRLENBQUMsS0FBYTtRQUM1QixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDOytHQTFCUSxzQkFBc0I7bUdBQXRCLHNCQUFzQixrVEF4QnJCOzs7Ozs7Ozs7O0tBVVQ7O1NBY1Esc0JBQXNCOzRGQUF0QixzQkFBc0I7a0JBM0JsQyxTQUFTO2lDQUNNLEtBQUssWUFDUCxnQkFBZ0IsWUFDaEI7Ozs7Ozs7Ozs7S0FVVCxtQkFFZ0IsdUJBQXVCLENBQUMsTUFBTSxRQUN6Qzt3QkFDRixJQUFJLEVBQUUsTUFBTTt3QkFDWixhQUFhLEVBQUUsUUFBUTt3QkFDdkIsWUFBWSxFQUFFLElBQUk7d0JBQ2xCLFNBQVMsRUFBRSxPQUFPO3dCQUNsQixRQUFRLEVBQUUsTUFBTTt3QkFDaEIsZUFBZSxFQUFFLCtCQUErQjt3QkFDaEQscUJBQXFCLEVBQUUsR0FBRzt3QkFDMUIseUJBQXlCLEVBQUUsR0FBRztxQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge3R1aUluamVjdElkfSBmcm9tICdAdGFpZ2EtdWkvY2RrL3NlcnZpY2VzJztcbmltcG9ydCB7VFVJX1RFWFRGSUVMRF9IT1NUfSBmcm9tICdAdGFpZ2EtdWkvbGVnYWN5L3Rva2Vucyc7XG5cbmltcG9ydCB0eXBlIHtUdWlJbnB1dFRpbWVEaXJlY3RpdmV9IGZyb20gJy4uL2lucHV0LXRpbWUuZGlyZWN0aXZlJztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogZmFsc2UsXG4gICAgc2VsZWN0b3I6ICdpbnB1dFt0dWlUaW1lXScsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPGRhdGFsaXN0XG4gICAgICAgICAgICAqbmdJZj1cIml0ZW1zLmxlbmd0aFwiXG4gICAgICAgICAgICBbaWRdPVwiYXV0b0lkXCJcbiAgICAgICAgPlxuICAgICAgICAgICAgPG9wdGlvblxuICAgICAgICAgICAgICAgICpuZ0Zvcj1cImxldCBpdGVtIG9mIGl0ZW1zXCJcbiAgICAgICAgICAgICAgICB2YWx1ZT1cInt7IGl0ZW0gfX1cIlxuICAgICAgICAgICAgPjwvb3B0aW9uPlxuICAgICAgICA8L2RhdGFsaXN0PlxuICAgIGAsXG4gICAgc3R5bGVVcmxzOiBbJy4vbmF0aXZlLXRpbWUuc3R5bGUubGVzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgdHlwZTogJ3RpbWUnLFxuICAgICAgICAnW2F0dHIubGlzdF0nOiAnYXV0b0lkJyxcbiAgICAgICAgJ1t0YWJJbmRleF0nOiAnLTEnLFxuICAgICAgICAnW3ZhbHVlXSc6ICd2YWx1ZScsXG4gICAgICAgICdbc3RlcF0nOiAnc3RlcCcsXG4gICAgICAgICcoY2hhbmdlLnN0b3ApJzogJ29uQ2hhbmdlKCRldmVudC50YXJnZXQudmFsdWUpJyxcbiAgICAgICAgJyhjbGljay5zdG9wLnNpbGVudCknOiAnMCcsXG4gICAgICAgICcobW91c2Vkb3duLnN0b3Auc2lsZW50KSc6ICcwJyxcbiAgICB9LFxufSlcbmV4cG9ydCBjbGFzcyBUdWlOYXRpdmVUaW1lQ29tcG9uZW50IHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaG9zdCA9IGluamVjdDxUdWlJbnB1dFRpbWVEaXJlY3RpdmU+KFRVSV9URVhURklFTERfSE9TVCk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgYXV0b0lkID0gdHVpSW5qZWN0SWQoKTtcblxuICAgIHByb3RlY3RlZCBnZXQgaXRlbXMoKTogc3RyaW5nW10ge1xuICAgICAgICByZXR1cm4gdGhpcy5ob3N0Lml0ZW1zLm1hcCgoaXRlbSkgPT4gaXRlbS50b1N0cmluZyh0aGlzLmhvc3QubW9kZSkpO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBnZXQgdmFsdWUoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaG9zdC52YWx1ZS5sZW5ndGggPT09IHRoaXMuaG9zdC5tb2RlLmxlbmd0aCA/IHRoaXMuaG9zdC52YWx1ZSA6ICcnO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBnZXQgc3RlcCgpOiBudW1iZXIge1xuICAgICAgICBzd2l0Y2ggKHRoaXMuaG9zdC5tb2RlKSB7XG4gICAgICAgICAgICBjYXNlICdISDpNTTpTUyc6XG4gICAgICAgICAgICAgICAgcmV0dXJuIDE7XG4gICAgICAgICAgICBjYXNlICdISDpNTTpTUy5NU1MnOlxuICAgICAgICAgICAgICAgIHJldHVybiAwLjAwMTtcbiAgICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAgICAgcmV0dXJuIDYwO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIG9uQ2hhbmdlKHZhbHVlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5ob3N0Lm9uVmFsdWVDaGFuZ2UodmFsdWUpO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -76,10 +76,10 @@ class TuiInputYearComponent extends AbstractTuiNullableControl {
|
|
|
76
76
|
this.nativeValue = value?.toString() || '';
|
|
77
77
|
}
|
|
78
78
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputYearComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
79
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputYearComponent, selector: "tui-input-year", inputs: { min: "min", max: "max", disabledItemHandler: "disabledItemHandler" }, host: {
|
|
79
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputYearComponent, selector: "tui-input-year", inputs: { min: "min", max: "max", disabledItemHandler: "disabledItemHandler" }, host: { properties: { "attr.data-size": "size" } }, providers: [
|
|
80
80
|
tuiAsFocusableItemAccessor(TuiInputYearComponent),
|
|
81
81
|
tuiAsControl(TuiInputYearComponent),
|
|
82
|
-
], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-primitive-textfield\n class=\"t-textfield\"\n [disabled]=\"computedDisabled\"\n [invalid]=\"computedInvalid\"\n [maskito]=\"getMaskOptions(min, max)\"\n [nativeId]=\"nativeId\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [tuiDropdown]=\"dropdown\"\n [tuiDropdownEnabled]=\"interactive\"\n [tuiDropdownOpen]=\"open && interactive\"\n [tuiTextfieldIcon]=\"calendarIcon\"\n [(value)]=\"nativeValue\"\n (click)=\"toggle()\"\n (focusedChange)=\"onFocused($event)\"\n (tuiDropdownOpenChange)=\"onOpenChange($event)\"\n (valueChange)=\"onValueChange($event)\"\n>\n <ng-content />\n <ng-content\n ngProjectAs=\"input\"\n select=\"input\"\n />\n</tui-primitive-textfield>\n\n<ng-template #dropdown>\n <div class=\"t-container\">\n <tui-scrollbar class=\"t-scrollbar\">\n <tui-calendar-year\n [disabledItemHandler]=\"disabledItemHandler\"\n [initialItem]=\"value || initialItem\"\n [max]=\"max\"\n [min]=\"min\"\n [value]=\"value === null ? null : value\"\n (mousedown.prevent.silent)=\"(0)\"\n (yearClick)=\"onYearClick($event)\"\n />\n </tui-scrollbar>\n </div>\n</ng-template>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:start}.t-container{inline-size:15.75rem;padding:1rem 1.125rem}.t-scrollbar{max-block-size:18.25rem;inline-size:16.875rem}.t-textfield{border-radius:inherit;text-align:inherit}\n"], dependencies: [{ kind: "directive", type: i1.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { kind: "directive", type: i2.TuiDropdownOpen, selector: "[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]", inputs: ["tuiDropdownEnabled", "tuiDropdownOpen"], outputs: ["tuiDropdownOpenChange"] }, { kind: "component", type: i3.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "iconCleaner", "readOnly", "invalid", "disabled", "value"], outputs: ["valueChange"] }, { kind: "directive", type: i3.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { kind: "component", type: i4.TuiScrollbar, selector: "tui-scrollbar", inputs: ["hidden"] }, { kind: "component", type: i5.TuiCalendarYear, selector: "tui-calendar-year", inputs: ["value", "initialItem", "min", "max", "disabledItemHandler"], outputs: ["yearClick"] }, { kind: "directive", type: i6.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { kind: "directive", type: i2.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container):not(ng-template)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
82
|
+
], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-primitive-textfield\n class=\"t-textfield\"\n [disabled]=\"computedDisabled\"\n [invalid]=\"computedInvalid\"\n [maskito]=\"getMaskOptions(min, max)\"\n [nativeId]=\"nativeId\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [tuiDropdown]=\"dropdown\"\n [tuiDropdownEnabled]=\"interactive\"\n [tuiDropdownOpen]=\"open && interactive\"\n [tuiTextfieldIcon]=\"calendarIcon\"\n [(value)]=\"nativeValue\"\n (click)=\"toggle()\"\n (focusedChange)=\"onFocused($event)\"\n (tuiDropdownOpenChange)=\"onOpenChange($event)\"\n (valueChange)=\"onValueChange($event)\"\n>\n <ng-content />\n <ng-content\n ngProjectAs=\"input\"\n select=\"input\"\n />\n</tui-primitive-textfield>\n\n<ng-template #dropdown>\n <div class=\"t-container\">\n <tui-scrollbar class=\"t-scrollbar\">\n <tui-calendar-year\n [disabledItemHandler]=\"disabledItemHandler\"\n [initialItem]=\"value || initialItem\"\n [max]=\"max\"\n [min]=\"min\"\n [value]=\"value === null ? null : value\"\n (mousedown.prevent.silent)=\"(0)\"\n (yearClick)=\"onYearClick($event)\"\n />\n </tui-scrollbar>\n </div>\n</ng-template>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:start}:host :host-context(*:disabled){pointer-events:none}.t-container{inline-size:15.75rem;padding:1rem 1.125rem}.t-scrollbar{max-block-size:18.25rem;inline-size:16.875rem}.t-textfield{border-radius:inherit;text-align:inherit}\n"], dependencies: [{ kind: "directive", type: i1.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { kind: "directive", type: i2.TuiDropdownOpen, selector: "[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]", inputs: ["tuiDropdownEnabled", "tuiDropdownOpen"], outputs: ["tuiDropdownOpenChange"] }, { kind: "component", type: i3.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "iconCleaner", "readOnly", "invalid", "disabled", "value"], outputs: ["valueChange"] }, { kind: "directive", type: i3.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { kind: "component", type: i4.TuiScrollbar, selector: "tui-scrollbar", inputs: ["hidden"] }, { kind: "component", type: i5.TuiCalendarYear, selector: "tui-calendar-year", inputs: ["value", "initialItem", "min", "max", "disabledItemHandler"], outputs: ["yearClick"] }, { kind: "directive", type: i6.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { kind: "directive", type: i2.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container):not(ng-template)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
83
83
|
}
|
|
84
84
|
__decorate([
|
|
85
85
|
tuiPure
|
|
@@ -91,9 +91,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
91
91
|
tuiAsFocusableItemAccessor(TuiInputYearComponent),
|
|
92
92
|
tuiAsControl(TuiInputYearComponent),
|
|
93
93
|
], host: {
|
|
94
|
-
ngSkipHydration: 'true',
|
|
95
94
|
'[attr.data-size]': 'size',
|
|
96
|
-
}, template: "<tui-primitive-textfield\n class=\"t-textfield\"\n [disabled]=\"computedDisabled\"\n [invalid]=\"computedInvalid\"\n [maskito]=\"getMaskOptions(min, max)\"\n [nativeId]=\"nativeId\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [tuiDropdown]=\"dropdown\"\n [tuiDropdownEnabled]=\"interactive\"\n [tuiDropdownOpen]=\"open && interactive\"\n [tuiTextfieldIcon]=\"calendarIcon\"\n [(value)]=\"nativeValue\"\n (click)=\"toggle()\"\n (focusedChange)=\"onFocused($event)\"\n (tuiDropdownOpenChange)=\"onOpenChange($event)\"\n (valueChange)=\"onValueChange($event)\"\n>\n <ng-content />\n <ng-content\n ngProjectAs=\"input\"\n select=\"input\"\n />\n</tui-primitive-textfield>\n\n<ng-template #dropdown>\n <div class=\"t-container\">\n <tui-scrollbar class=\"t-scrollbar\">\n <tui-calendar-year\n [disabledItemHandler]=\"disabledItemHandler\"\n [initialItem]=\"value || initialItem\"\n [max]=\"max\"\n [min]=\"min\"\n [value]=\"value === null ? null : value\"\n (mousedown.prevent.silent)=\"(0)\"\n (yearClick)=\"onYearClick($event)\"\n />\n </tui-scrollbar>\n </div>\n</ng-template>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:start}.t-container{inline-size:15.75rem;padding:1rem 1.125rem}.t-scrollbar{max-block-size:18.25rem;inline-size:16.875rem}.t-textfield{border-radius:inherit;text-align:inherit}\n"] }]
|
|
95
|
+
}, template: "<tui-primitive-textfield\n class=\"t-textfield\"\n [disabled]=\"computedDisabled\"\n [invalid]=\"computedInvalid\"\n [maskito]=\"getMaskOptions(min, max)\"\n [nativeId]=\"nativeId\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [tuiDropdown]=\"dropdown\"\n [tuiDropdownEnabled]=\"interactive\"\n [tuiDropdownOpen]=\"open && interactive\"\n [tuiTextfieldIcon]=\"calendarIcon\"\n [(value)]=\"nativeValue\"\n (click)=\"toggle()\"\n (focusedChange)=\"onFocused($event)\"\n (tuiDropdownOpenChange)=\"onOpenChange($event)\"\n (valueChange)=\"onValueChange($event)\"\n>\n <ng-content />\n <ng-content\n ngProjectAs=\"input\"\n select=\"input\"\n />\n</tui-primitive-textfield>\n\n<ng-template #dropdown>\n <div class=\"t-container\">\n <tui-scrollbar class=\"t-scrollbar\">\n <tui-calendar-year\n [disabledItemHandler]=\"disabledItemHandler\"\n [initialItem]=\"value || initialItem\"\n [max]=\"max\"\n [min]=\"min\"\n [value]=\"value === null ? null : value\"\n (mousedown.prevent.silent)=\"(0)\"\n (yearClick)=\"onYearClick($event)\"\n />\n </tui-scrollbar>\n </div>\n</ng-template>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:start}:host :host-context(*:disabled){pointer-events:none}.t-container{inline-size:15.75rem;padding:1rem 1.125rem}.t-scrollbar{max-block-size:18.25rem;inline-size:16.875rem}.t-textfield{border-radius:inherit;text-align:inherit}\n"] }]
|
|
97
96
|
}], propDecorators: { textfield: [{
|
|
98
97
|
type: ViewChild,
|
|
99
98
|
args: [TuiPrimitiveTextfieldComponent]
|
|
@@ -104,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
104
103
|
}], disabledItemHandler: [{
|
|
105
104
|
type: Input
|
|
106
105
|
}], getMaskOptions: [] } });
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-year.component.js","sourceRoot":"","sources":["../../../../../projects/legacy/components/input-year/input-year.component.ts","../../../../../projects/legacy/components/input-year/input-year.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    inject,\n    Input,\n    ViewChild,\n} from '@angular/core';\nimport type {MaskitoOptions} from '@maskito/core';\nimport {maskitoNumberOptionsGenerator} from '@maskito/kit';\nimport {TUI_FALSE_HANDLER} from '@taiga-ui/cdk/constants';\nimport {MAX_YEAR, MIN_YEAR} from '@taiga-ui/cdk/date-time';\nimport type {TuiBooleanHandler} from '@taiga-ui/cdk/types';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport type {TuiInputDateOptions} from '@taiga-ui/kit/tokens';\nimport {TUI_INPUT_DATE_OPTIONS} from '@taiga-ui/kit/tokens';\nimport {AbstractTuiNullableControl, tuiAsControl} from '@taiga-ui/legacy/classes';\nimport {TuiPrimitiveTextfieldComponent} from '@taiga-ui/legacy/components/primitive-textfield';\nimport {TUI_TEXTFIELD_SIZE} from '@taiga-ui/legacy/directives';\nimport type {TuiFocusableElementAccessor} from '@taiga-ui/legacy/tokens';\nimport {tuiAsFocusableItemAccessor} from '@taiga-ui/legacy/tokens';\n\nconst UP_TO_4_DIGITS_REG = /^\\d{0,4}$/;\n\n@Component({\n    standalone: false,\n    selector: 'tui-input-year',\n    templateUrl: './input-year.template.html',\n    styleUrls: ['./input-year.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputYearComponent),\n        tuiAsControl(TuiInputYearComponent),\n    ],\n    host: {\n        ngSkipHydration: 'true',\n        '[attr.data-size]': 'size',\n    },\n})\nexport class TuiInputYearComponent\n    extends AbstractTuiNullableControl<number>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private readonly options = inject(TUI_INPUT_DATE_OPTIONS);\n    private readonly textfieldSize = inject(TUI_TEXTFIELD_SIZE);\n\n    protected open = false;\n    protected readonly initialItem = new Date().getFullYear();\n\n    @Input()\n    public min: number | null = this.options.min.year;\n\n    @Input()\n    public max: number | null = this.options.max.year;\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<number> = TUI_FALSE_HANDLER;\n\n    public nativeValue = '';\n\n    public get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield?.nativeFocusableElement || null;\n    }\n\n    public get focused(): boolean {\n        return !!this.textfield?.focused;\n    }\n\n    public onValueChange(value: string): void {\n        this.value = value ? Number(value) : null;\n    }\n\n    public override writeValue(value: number | null): void {\n        super.writeValue(value);\n        this.updateNativeValue(value);\n    }\n\n    protected get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    protected get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    @tuiPure\n    protected getMaskOptions(min: number | null, max: number | null): MaskitoOptions {\n        return {\n            ...maskitoNumberOptionsGenerator({\n                min: min ?? MIN_YEAR,\n                max: max ?? MAX_YEAR,\n                thousandSeparator: '',\n            }),\n            mask: UP_TO_4_DIGITS_REG,\n        };\n    }\n\n    protected onYearClick(year: number): void {\n        this.value = year;\n        this.updateNativeValue(year);\n        this.onOpenChange(false);\n    }\n\n    protected onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    protected onOpenChange(open: boolean): void {\n        this.open = open;\n    }\n\n    protected toggle(): void {\n        this.open = !this.open;\n    }\n\n    private updateNativeValue(value: number | null): void {\n        this.nativeValue = value?.toString() || '';\n    }\n}\n","<tui-primitive-textfield\n    class=\"t-textfield\"\n    [disabled]=\"computedDisabled\"\n    [invalid]=\"computedInvalid\"\n    [maskito]=\"getMaskOptions(min, max)\"\n    [nativeId]=\"nativeId\"\n    [pseudoFocus]=\"pseudoFocus\"\n    [pseudoHover]=\"pseudoHover\"\n    [readOnly]=\"readOnly\"\n    [tuiDropdown]=\"dropdown\"\n    [tuiDropdownEnabled]=\"interactive\"\n    [tuiDropdownOpen]=\"open && interactive\"\n    [tuiTextfieldIcon]=\"calendarIcon\"\n    [(value)]=\"nativeValue\"\n    (click)=\"toggle()\"\n    (focusedChange)=\"onFocused($event)\"\n    (tuiDropdownOpenChange)=\"onOpenChange($event)\"\n    (valueChange)=\"onValueChange($event)\"\n>\n    <ng-content />\n    <ng-content\n        ngProjectAs=\"input\"\n        select=\"input\"\n    />\n</tui-primitive-textfield>\n\n<ng-template #dropdown>\n    <div class=\"t-container\">\n        <tui-scrollbar class=\"t-scrollbar\">\n            <tui-calendar-year\n                [disabledItemHandler]=\"disabledItemHandler\"\n                [initialItem]=\"value || initialItem\"\n                [max]=\"max\"\n                [min]=\"min\"\n                [value]=\"value === null ? null : value\"\n                (mousedown.prevent.silent)=\"(0)\"\n                (yearClick)=\"onYearClick($event)\"\n            />\n        </tui-scrollbar>\n    </div>\n</ng-template>\n"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-year.component.js","sourceRoot":"","sources":["../../../../../projects/legacy/components/input-year/input-year.component.ts","../../../../../projects/legacy/components/input-year/input-year.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    inject,\n    Input,\n    ViewChild,\n} from '@angular/core';\nimport type {MaskitoOptions} from '@maskito/core';\nimport {maskitoNumberOptionsGenerator} from '@maskito/kit';\nimport {TUI_FALSE_HANDLER} from '@taiga-ui/cdk/constants';\nimport {MAX_YEAR, MIN_YEAR} from '@taiga-ui/cdk/date-time';\nimport type {TuiBooleanHandler} from '@taiga-ui/cdk/types';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiSizeL, TuiSizeS} from '@taiga-ui/core/types';\nimport type {TuiInputDateOptions} from '@taiga-ui/kit/tokens';\nimport {TUI_INPUT_DATE_OPTIONS} from '@taiga-ui/kit/tokens';\nimport {AbstractTuiNullableControl, tuiAsControl} from '@taiga-ui/legacy/classes';\nimport {TuiPrimitiveTextfieldComponent} from '@taiga-ui/legacy/components/primitive-textfield';\nimport {TUI_TEXTFIELD_SIZE} from '@taiga-ui/legacy/directives';\nimport type {TuiFocusableElementAccessor} from '@taiga-ui/legacy/tokens';\nimport {tuiAsFocusableItemAccessor} from '@taiga-ui/legacy/tokens';\n\nconst UP_TO_4_DIGITS_REG = /^\\d{0,4}$/;\n\n@Component({\n    standalone: false,\n    selector: 'tui-input-year',\n    templateUrl: './input-year.template.html',\n    styleUrls: ['./input-year.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputYearComponent),\n        tuiAsControl(TuiInputYearComponent),\n    ],\n    host: {\n        '[attr.data-size]': 'size',\n    },\n})\nexport class TuiInputYearComponent\n    extends AbstractTuiNullableControl<number>\n    implements TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private readonly options = inject(TUI_INPUT_DATE_OPTIONS);\n    private readonly textfieldSize = inject(TUI_TEXTFIELD_SIZE);\n\n    protected open = false;\n    protected readonly initialItem = new Date().getFullYear();\n\n    @Input()\n    public min: number | null = this.options.min.year;\n\n    @Input()\n    public max: number | null = this.options.max.year;\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<number> = TUI_FALSE_HANDLER;\n\n    public nativeValue = '';\n\n    public get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield?.nativeFocusableElement || null;\n    }\n\n    public get focused(): boolean {\n        return !!this.textfield?.focused;\n    }\n\n    public onValueChange(value: string): void {\n        this.value = value ? Number(value) : null;\n    }\n\n    public override writeValue(value: number | null): void {\n        super.writeValue(value);\n        this.updateNativeValue(value);\n    }\n\n    protected get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    protected get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    @tuiPure\n    protected getMaskOptions(min: number | null, max: number | null): MaskitoOptions {\n        return {\n            ...maskitoNumberOptionsGenerator({\n                min: min ?? MIN_YEAR,\n                max: max ?? MAX_YEAR,\n                thousandSeparator: '',\n            }),\n            mask: UP_TO_4_DIGITS_REG,\n        };\n    }\n\n    protected onYearClick(year: number): void {\n        this.value = year;\n        this.updateNativeValue(year);\n        this.onOpenChange(false);\n    }\n\n    protected onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    protected onOpenChange(open: boolean): void {\n        this.open = open;\n    }\n\n    protected toggle(): void {\n        this.open = !this.open;\n    }\n\n    private updateNativeValue(value: number | null): void {\n        this.nativeValue = value?.toString() || '';\n    }\n}\n","<tui-primitive-textfield\n    class=\"t-textfield\"\n    [disabled]=\"computedDisabled\"\n    [invalid]=\"computedInvalid\"\n    [maskito]=\"getMaskOptions(min, max)\"\n    [nativeId]=\"nativeId\"\n    [pseudoFocus]=\"pseudoFocus\"\n    [pseudoHover]=\"pseudoHover\"\n    [readOnly]=\"readOnly\"\n    [tuiDropdown]=\"dropdown\"\n    [tuiDropdownEnabled]=\"interactive\"\n    [tuiDropdownOpen]=\"open && interactive\"\n    [tuiTextfieldIcon]=\"calendarIcon\"\n    [(value)]=\"nativeValue\"\n    (click)=\"toggle()\"\n    (focusedChange)=\"onFocused($event)\"\n    (tuiDropdownOpenChange)=\"onOpenChange($event)\"\n    (valueChange)=\"onValueChange($event)\"\n>\n    <ng-content />\n    <ng-content\n        ngProjectAs=\"input\"\n        select=\"input\"\n    />\n</tui-primitive-textfield>\n\n<ng-template #dropdown>\n    <div class=\"t-container\">\n        <tui-scrollbar class=\"t-scrollbar\">\n            <tui-calendar-year\n                [disabledItemHandler]=\"disabledItemHandler\"\n                [initialItem]=\"value || initialItem\"\n                [max]=\"max\"\n                [min]=\"min\"\n                [value]=\"value === null ? null : value\"\n                (mousedown.prevent.silent)=\"(0)\"\n                (yearClick)=\"onYearClick($event)\"\n            />\n        </tui-scrollbar>\n    </div>\n</ng-template>\n"]}
|
|
@@ -63,7 +63,7 @@ class TuiMultiSelectGroupComponent {
|
|
|
63
63
|
return items.map(({ value }) => value).filter(tuiIsPresent);
|
|
64
64
|
}
|
|
65
65
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
66
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiMultiSelectGroupComponent, selector: "tui-opt-group[tuiMultiSelectGroup]", inputs: { label: "label" }, host: {
|
|
66
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiMultiSelectGroupComponent, selector: "tui-opt-group[tuiMultiSelectGroup]", inputs: { label: "label" }, host: { properties: { "class._label": "label" } }, queries: [{ propertyName: "options", predicate: TuiOption }], ngImport: i0, template: "<span\n *tuiLet=\"value$ | async as value\"\n class=\"t-wrapper\"\n>\n <span class=\"t-label\">{{ label }}</span>\n <button\n *ngIf=\"label && !(empty$ | async)\"\n tuiLink\n type=\"button\"\n class=\"t-button\"\n [disabled]=\"!!(disabled$ | async)\"\n (click)=\"onClick(value)\"\n >\n {{ (multiSelectTexts$ | async)?.[value ? 'none' : 'all'] }}\n </button>\n</span>\n<ng-content />\n", styles: [":host._label:before{display:none}:host:not(:first-of-type) .t-label:not(:empty){padding-top:1.25rem}:host:not(:first-of-type) .t-button{margin-top:1.25rem}.t-wrapper{display:flex;align-items:flex-start}.t-label:not(:empty){flex:1;padding:.75rem 1rem .25rem .625rem}.t-button{margin:.75rem 1rem 0 auto}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.TuiLet, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "directive", type: i3.TuiLink, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
67
67
|
}
|
|
68
68
|
__decorate([
|
|
69
69
|
tuiPure
|
|
@@ -87,7 +87,6 @@ export { TuiMultiSelectGroupComponent };
|
|
|
87
87
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiMultiSelectGroupComponent, decorators: [{
|
|
88
88
|
type: Component,
|
|
89
89
|
args: [{ standalone: false, selector: 'tui-opt-group[tuiMultiSelectGroup]', changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
90
|
-
ngSkipHydration: 'true',
|
|
91
90
|
'[class._label]': 'label',
|
|
92
91
|
}, template: "<span\n *tuiLet=\"value$ | async as value\"\n class=\"t-wrapper\"\n>\n <span class=\"t-label\">{{ label }}</span>\n <button\n *ngIf=\"label && !(empty$ | async)\"\n tuiLink\n type=\"button\"\n class=\"t-button\"\n [disabled]=\"!!(disabled$ | async)\"\n (click)=\"onClick(value)\"\n >\n {{ (multiSelectTexts$ | async)?.[value ? 'none' : 'all'] }}\n </button>\n</span>\n<ng-content />\n", styles: [":host._label:before{display:none}:host:not(:first-of-type) .t-label:not(:empty){padding-top:1.25rem}:host:not(:first-of-type) .t-button{margin-top:1.25rem}.t-wrapper{display:flex;align-items:flex-start}.t-label:not(:empty){flex:1;padding:.75rem 1rem .25rem .625rem}.t-button{margin:.75rem 1rem 0 auto}\n"] }]
|
|
93
92
|
}], propDecorators: { options: [{
|
|
@@ -96,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
96
95
|
}], label: [{
|
|
97
96
|
type: Input
|
|
98
97
|
}], empty$: [], disabled$: [], value$: [], items$: [], valueChanges$: [], filter: [] } });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-group.component.js","sourceRoot":"","sources":["../../../../../../projects/legacy/components/multi-select/multi-select-group/multi-select-group.component.ts","../../../../../../projects/legacy/components/multi-select/multi-select-group/multi-select-group.template.html"],"names":[],"mappings":"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","sourcesContent":["import type {QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    inject,\n    Input,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {EMPTY_QUERY, TUI_DEFAULT_IDENTITY_MATCHER} from '@taiga-ui/cdk/constants';\nimport {tuiControlValue, tuiQueryListChanges} from '@taiga-ui/cdk/observables';\nimport type {TuiIdentityMatcher} from '@taiga-ui/cdk/types';\nimport {\n    tuiGetOriginalArrayFromQueryList,\n    tuiIsPresent,\n    tuiPure,\n} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiDataListHost} from '@taiga-ui/core/components/data-list';\nimport {TUI_DATA_LIST_HOST, TuiOption} from '@taiga-ui/core/components/data-list';\nimport {TUI_MULTI_SELECT_TEXTS} from '@taiga-ui/kit/tokens';\nimport type {Observable} from 'rxjs';\nimport {combineLatest, map} from 'rxjs';\n\n@Component({\n    standalone: false,\n    selector: 'tui-opt-group[tuiMultiSelectGroup]',\n    templateUrl: './multi-select-group.template.html',\n    styleUrls: ['./multi-select-group.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        ngSkipHydration: 'true',\n        '[class._label]': 'label',\n    },\n})\nexport class TuiMultiSelectGroupComponent<T> {\n    @ContentChildren(TuiOption)\n    private readonly options: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    private readonly host = inject<TuiDataListHost<T>>(TUI_DATA_LIST_HOST);\n    private readonly control = inject(NgControl);\n\n    protected readonly multiSelectTexts$ = inject(TUI_MULTI_SELECT_TEXTS);\n\n    @Input()\n    public label = '';\n\n    @tuiPure\n    protected get empty$(): Observable<boolean> {\n        return tuiQueryListChanges(this.options).pipe(map(({length}) => !length));\n    }\n\n    @tuiPure\n    protected get disabled$(): Observable<boolean> {\n        return tuiQueryListChanges(this.options).pipe(\n            map((items) => items.every(({disabled}) => disabled)),\n        );\n    }\n\n    @tuiPure\n    protected get value$(): Observable<boolean | null> {\n        return combineLatest([this.items$, this.valueChanges$]).pipe(\n            map(([items, current]) => {\n                let result = false;\n\n                for (let i = 0; i < items.length; i++) {\n                    const selected = current.some((selected) =>\n                        this.matcher(selected, items[i]!),\n                    );\n\n                    if ((!selected && result) || (selected && !result && i)) {\n                        return null;\n                    }\n\n                    result = selected;\n                }\n\n                return result;\n            }),\n        );\n    }\n\n    protected onClick(checked: boolean | null): void {\n        if (!this.control.control) {\n            return;\n        }\n\n        const controlValue: readonly T[] = this.control.value || [];\n        const {values} = this;\n        const filtered = controlValue.filter((current) =>\n            values.every((item) => !this.matcher(current, item)),\n        );\n\n        this.control.control.setValue(checked ? filtered : [...filtered, ...values]);\n    }\n\n    @tuiPure\n    private get items$(): Observable<readonly T[]> {\n        return tuiQueryListChanges(this.options).pipe(\n            map((options) => options.map(({value}) => value).filter(tuiIsPresent)),\n        );\n    }\n\n    @tuiPure\n    private get valueChanges$(): Observable<readonly T[]> {\n        return tuiControlValue<readonly T[]>(this.control).pipe(\n            map((value) => value || []),\n        );\n    }\n\n    private get values(): readonly T[] {\n        return this.filter(tuiGetOriginalArrayFromQueryList(this.options));\n    }\n\n    private get matcher(): TuiIdentityMatcher<T> {\n        return this.host.identityMatcher || TUI_DEFAULT_IDENTITY_MATCHER;\n    }\n\n    @tuiPure\n    private filter(items: ReadonlyArray<TuiOption<T>>): readonly T[] {\n        return items.map(({value}) => value).filter(tuiIsPresent);\n    }\n}\n","<span\n    *tuiLet=\"value$ | async as value\"\n    class=\"t-wrapper\"\n>\n    <span class=\"t-label\">{{ label }}</span>\n    <button\n        *ngIf=\"label && !(empty$ | async)\"\n        tuiLink\n        type=\"button\"\n        class=\"t-button\"\n        [disabled]=\"!!(disabled$ | async)\"\n        (click)=\"onClick(value)\"\n    >\n        {{ (multiSelectTexts$ | async)?.[value ? 'none' : 'all'] }}\n    </button>\n</span>\n<ng-content />\n"]}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-group.component.js","sourceRoot":"","sources":["../../../../../../projects/legacy/components/multi-select/multi-select-group/multi-select-group.component.ts","../../../../../../projects/legacy/components/multi-select/multi-select-group/multi-select-group.template.html"],"names":[],"mappings":";AACA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,MAAM,EACN,KAAK,GACR,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAC,WAAW,EAAE,4BAA4B,EAAC,MAAM,yBAAyB,CAAC;AAClF,OAAO,EAAC,eAAe,EAAE,mBAAmB,EAAC,MAAM,2BAA2B,CAAC;AAE/E,OAAO,EACH,gCAAgC,EAChC,YAAY,EACZ,OAAO,GACV,MAAM,mCAAmC,CAAC;AAE3C,OAAO,EAAC,kBAAkB,EAAE,SAAS,EAAC,MAAM,qCAAqC,CAAC;AAClF,OAAO,EAAC,sBAAsB,EAAC,MAAM,sBAAsB,CAAC;AAE5D,OAAO,EAAC,aAAa,EAAE,GAAG,EAAC,MAAM,MAAM,CAAC;;;;;AAExC,MAUa,4BAA4B;IAVzC;QAYqB,YAAO,GAA4B,WAAW,CAAC;QAE/C,SAAI,GAAG,MAAM,CAAqB,kBAAkB,CAAC,CAAC;QACtD,YAAO,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAE1B,sBAAiB,GAAG,MAAM,CAAC,sBAAsB,CAAC,CAAC;QAG/D,UAAK,GAAG,EAAE,CAAC;KA6ErB;IA1EG,IAAc,MAAM;QAChB,OAAO,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAC,MAAM,EAAC,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IAC9E,CAAC;IAGD,IAAc,SAAS;QACnB,OAAO,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CACzC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAC,QAAQ,EAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CACxD,CAAC;IACN,CAAC;IAGD,IAAc,MAAM;QAChB,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CACxD,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,OAAO,CAAC,EAAE,EAAE;YACrB,IAAI,MAAM,GAAG,KAAK,CAAC;YAEnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACnC,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CACvC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAE,CAAC,CACpC,CAAC;gBAEF,IAAI,CAAC,CAAC,QAAQ,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,EAAE;oBACrD,OAAO,IAAI,CAAC;iBACf;gBAED,MAAM,GAAG,QAAQ,CAAC;aACrB;YAED,OAAO,MAAM,CAAC;QAClB,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAES,OAAO,CAAC,OAAuB;QACrC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;YACvB,OAAO;SACV;QAED,MAAM,YAAY,GAAiB,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC;QAC5D,MAAM,EAAC,MAAM,EAAC,GAAG,IAAI,CAAC;QACtB,MAAM,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CAC7C,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CACvD,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,QAAQ,EAAE,GAAG,MAAM,CAAC,CAAC,CAAC;IACjF,CAAC;IAGD,IAAY,MAAM;QACd,OAAO,mBAAmB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CACzC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAC,KAAK,EAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CACzE,CAAC;IACN,CAAC;IAGD,IAAY,aAAa;QACrB,OAAO,eAAe,CAAe,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CACnD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,CAC9B,CAAC;IACN,CAAC;IAED,IAAY,MAAM;QACd,OAAO,IAAI,CAAC,MAAM,CAAC,gCAAgC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,IAAY,OAAO;QACf,OAAO,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,4BAA4B,CAAC;IACrE,CAAC;IAGO,MAAM,CAAC,KAAkC;QAC7C,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,EAAC,KAAK,EAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IAC9D,CAAC;+GAtFQ,4BAA4B;mGAA5B,4BAA4B,iLACpB,SAAS,6BClC9B,qcAiBA;;AD6BI;IADC,OAAO;0DAGP;AAGD;IADC,OAAO;6DAKP;AAGD;IADC,OAAO;0DAqBP;AAiBD;IADC,OAAO;0DAKP;AAGD;IADC,OAAO;iEAKP;AAWO;IADP,OAAO;0DAGP;SAtFQ,4BAA4B;4FAA5B,4BAA4B;kBAVxC,SAAS;iCACM,KAAK,YACP,oCAAoC,mBAG7B,uBAAuB,CAAC,MAAM,QACzC;wBACF,gBAAgB,EAAE,OAAO;qBAC5B;8BAIgB,OAAO;sBADvB,eAAe;uBAAC,SAAS;gBASnB,KAAK;sBADX,KAAK;gBAIQ,MAAM,MAKN,SAAS,MAOT,MAAM,MAqCR,MAAM,MAON,aAAa,MAejB,MAAM","sourcesContent":["import type {QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    inject,\n    Input,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {EMPTY_QUERY, TUI_DEFAULT_IDENTITY_MATCHER} from '@taiga-ui/cdk/constants';\nimport {tuiControlValue, tuiQueryListChanges} from '@taiga-ui/cdk/observables';\nimport type {TuiIdentityMatcher} from '@taiga-ui/cdk/types';\nimport {\n    tuiGetOriginalArrayFromQueryList,\n    tuiIsPresent,\n    tuiPure,\n} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiDataListHost} from '@taiga-ui/core/components/data-list';\nimport {TUI_DATA_LIST_HOST, TuiOption} from '@taiga-ui/core/components/data-list';\nimport {TUI_MULTI_SELECT_TEXTS} from '@taiga-ui/kit/tokens';\nimport type {Observable} from 'rxjs';\nimport {combineLatest, map} from 'rxjs';\n\n@Component({\n    standalone: false,\n    selector: 'tui-opt-group[tuiMultiSelectGroup]',\n    templateUrl: './multi-select-group.template.html',\n    styleUrls: ['./multi-select-group.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class._label]': 'label',\n    },\n})\nexport class TuiMultiSelectGroupComponent<T> {\n    @ContentChildren(TuiOption)\n    private readonly options: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    private readonly host = inject<TuiDataListHost<T>>(TUI_DATA_LIST_HOST);\n    private readonly control = inject(NgControl);\n\n    protected readonly multiSelectTexts$ = inject(TUI_MULTI_SELECT_TEXTS);\n\n    @Input()\n    public label = '';\n\n    @tuiPure\n    protected get empty$(): Observable<boolean> {\n        return tuiQueryListChanges(this.options).pipe(map(({length}) => !length));\n    }\n\n    @tuiPure\n    protected get disabled$(): Observable<boolean> {\n        return tuiQueryListChanges(this.options).pipe(\n            map((items) => items.every(({disabled}) => disabled)),\n        );\n    }\n\n    @tuiPure\n    protected get value$(): Observable<boolean | null> {\n        return combineLatest([this.items$, this.valueChanges$]).pipe(\n            map(([items, current]) => {\n                let result = false;\n\n                for (let i = 0; i < items.length; i++) {\n                    const selected = current.some((selected) =>\n                        this.matcher(selected, items[i]!),\n                    );\n\n                    if ((!selected && result) || (selected && !result && i)) {\n                        return null;\n                    }\n\n                    result = selected;\n                }\n\n                return result;\n            }),\n        );\n    }\n\n    protected onClick(checked: boolean | null): void {\n        if (!this.control.control) {\n            return;\n        }\n\n        const controlValue: readonly T[] = this.control.value || [];\n        const {values} = this;\n        const filtered = controlValue.filter((current) =>\n            values.every((item) => !this.matcher(current, item)),\n        );\n\n        this.control.control.setValue(checked ? filtered : [...filtered, ...values]);\n    }\n\n    @tuiPure\n    private get items$(): Observable<readonly T[]> {\n        return tuiQueryListChanges(this.options).pipe(\n            map((options) => options.map(({value}) => value).filter(tuiIsPresent)),\n        );\n    }\n\n    @tuiPure\n    private get valueChanges$(): Observable<readonly T[]> {\n        return tuiControlValue<readonly T[]>(this.control).pipe(\n            map((value) => value || []),\n        );\n    }\n\n    private get values(): readonly T[] {\n        return this.filter(tuiGetOriginalArrayFromQueryList(this.options));\n    }\n\n    private get matcher(): TuiIdentityMatcher<T> {\n        return this.host.identityMatcher || TUI_DEFAULT_IDENTITY_MATCHER;\n    }\n\n    @tuiPure\n    private filter(items: ReadonlyArray<TuiOption<T>>): readonly T[] {\n        return items.map(({value}) => value).filter(tuiIsPresent);\n    }\n}\n","<span\n    *tuiLet=\"value$ | async as value\"\n    class=\"t-wrapper\"\n>\n    <span class=\"t-label\">{{ label }}</span>\n    <button\n        *ngIf=\"label && !(empty$ | async)\"\n        tuiLink\n        type=\"button\"\n        class=\"t-button\"\n        [disabled]=\"!!(disabled$ | async)\"\n        (click)=\"onClick(value)\"\n    >\n        {{ (multiSelectTexts$ | async)?.[value ? 'none' : 'all'] }}\n    </button>\n</span>\n<ng-content />\n"]}
|