@taiga-ui/kit 3.75.0 → 3.77.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taiga-ui-kit-components-accordion.umd.js +2 -5
- package/bundles/taiga-ui-kit-components-accordion.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-checkbox.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-checkbox.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-date-multi.umd.js +24 -43
- package/bundles/taiga-ui-kit-components-input-date-multi.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-date-range.umd.js +25 -43
- package/bundles/taiga-ui-kit-components-input-date-range.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-date.umd.js +29 -46
- package/bundles/taiga-ui-kit-components-input-date.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-slider.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-input-slider.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-tag.umd.js +9 -5
- package/bundles/taiga-ui-kit-components-input-tag.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-multi-select-option.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-multi-select-option.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-multi-select.umd.js +5 -2
- package/bundles/taiga-ui-kit-components-multi-select.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-radio.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-radio.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-tag.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-tag.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-textarea.umd.js +2 -2
- package/bundles/taiga-ui-kit-components-textarea.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-toggle.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-toggle.umd.js.map +1 -1
- package/components/accordion/accordion-item/accordion-item.component.d.ts +0 -1
- package/components/input-date/input-date.component.d.ts +7 -7
- package/components/input-date-multi/input-date-multi.component.d.ts +4 -7
- package/components/input-date-range/input-date-range.component.d.ts +4 -7
- package/components/input-tag/input-tag.component.d.ts +2 -1
- package/components/input-tag/input-tag.options.d.ts +1 -0
- package/components/multi-select/multi-select.component.d.ts +2 -1
- package/esm2015/components/accordion/accordion-item/accordion-item.component.js +2 -5
- package/esm2015/components/accordion/accordion.component.js +1 -1
- package/esm2015/components/checkbox/checkbox.component.js +1 -1
- package/esm2015/components/input-date/input-date.component.js +28 -41
- package/esm2015/components/input-date-multi/input-date-multi.component.js +23 -38
- package/esm2015/components/input-date-range/input-date-range.component.js +24 -38
- package/esm2015/components/input-slider/input-slider.component.js +1 -1
- package/esm2015/components/input-tag/input-tag.component.js +8 -5
- package/esm2015/components/input-tag/input-tag.options.js +3 -2
- package/esm2015/components/multi-select/multi-select.component.js +6 -3
- package/esm2015/components/multi-select-option/multi-select-option.component.js +1 -1
- package/esm2015/components/radio/radio.component.js +1 -1
- package/esm2015/components/tag/tag.component.js +1 -1
- package/esm2015/components/textarea/deprecated.js +1 -1
- package/esm2015/components/textarea/textarea.component.js +1 -1
- package/esm2015/components/toggle/toggle.component.js +1 -1
- package/fesm2015/taiga-ui-kit-components-accordion.js +2 -5
- package/fesm2015/taiga-ui-kit-components-accordion.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-checkbox.js +1 -1
- package/fesm2015/taiga-ui-kit-components-checkbox.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-date-multi.js +24 -38
- package/fesm2015/taiga-ui-kit-components-input-date-multi.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-date-range.js +25 -38
- package/fesm2015/taiga-ui-kit-components-input-date-range.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-date.js +29 -41
- package/fesm2015/taiga-ui-kit-components-input-date.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-slider.js +1 -1
- package/fesm2015/taiga-ui-kit-components-input-slider.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-tag.js +9 -5
- package/fesm2015/taiga-ui-kit-components-input-tag.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-multi-select-option.js +1 -1
- package/fesm2015/taiga-ui-kit-components-multi-select-option.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-multi-select.js +5 -2
- package/fesm2015/taiga-ui-kit-components-multi-select.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-radio.js +1 -1
- package/fesm2015/taiga-ui-kit-components-radio.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-tag.js +1 -1
- package/fesm2015/taiga-ui-kit-components-tag.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-textarea.js +2 -2
- package/fesm2015/taiga-ui-kit-components-textarea.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-toggle.js +1 -1
- package/fesm2015/taiga-ui-kit-components-toggle.js.map +1 -1
- package/package.json +8 -8
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, Inject,
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, Inject, inject, InjectFlags, Input, Optional, Self, ViewChild, } from '@angular/core';
|
|
3
3
|
import { NgControl } from '@angular/forms';
|
|
4
4
|
import { MASKITO_DEFAULT_OPTIONS } from '@maskito/core';
|
|
5
5
|
import { maskitoDateOptionsGenerator } from '@maskito/kit';
|
|
6
6
|
import { AbstractTuiNullableControl, ALWAYS_FALSE_HANDLER, changeDateSeparator, DATE_FILLER_LENGTH, TUI_DATE_FORMAT, TUI_DATE_SEPARATOR, TUI_IS_MOBILE, tuiAsControl, tuiAsFocusableItemAccessor, tuiDateClamp, TuiDay, TuiMonth, tuiNullableSame, tuiPure, } from '@taiga-ui/cdk';
|
|
7
|
-
import { TUI_DEFAULT_MARKER_HANDLER,
|
|
7
|
+
import { TUI_DEFAULT_MARKER_HANDLER, TUI_DROPDOWN_COMPONENT, TUI_TEXTFIELD_SIZE, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
|
|
8
8
|
import { TUI_DATE_MODE_MASKITO_ADAPTER } from '@taiga-ui/kit/constants';
|
|
9
9
|
import { TUI_DATE_TEXTS, TUI_DATE_VALUE_TRANSFORMER, TUI_INPUT_DATE_OPTIONS, TUI_MOBILE_CALENDAR, tuiDateStreamWithTransformer, } from '@taiga-ui/kit/tokens';
|
|
10
|
-
import {
|
|
11
|
-
import { map, takeUntil } from 'rxjs/operators';
|
|
10
|
+
import { map } from 'rxjs/operators';
|
|
12
11
|
import * as i0 from "@angular/core";
|
|
13
12
|
import * as i1 from "@taiga-ui/core";
|
|
14
13
|
import * as i2 from "@taiga-ui/cdk";
|
|
@@ -20,11 +19,9 @@ import * as i7 from "./native-date/native-date.component";
|
|
|
20
19
|
import * as i8 from "@angular/forms";
|
|
21
20
|
import * as i9 from "rxjs";
|
|
22
21
|
export class TuiInputDateComponent extends AbstractTuiNullableControl {
|
|
23
|
-
constructor(control, cdr,
|
|
22
|
+
constructor(control, cdr, isMobile, mobileCalendar, dateFormat, dateSeparator, dateTexts$, valueTransformer, options, textfieldSize) {
|
|
24
23
|
super(control, cdr, valueTransformer);
|
|
25
|
-
this.injector = injector;
|
|
26
24
|
this.isMobile = isMobile;
|
|
27
|
-
this.dialogs = dialogs;
|
|
28
25
|
this.mobileCalendar = mobileCalendar;
|
|
29
26
|
this.dateFormat = dateFormat;
|
|
30
27
|
this.dateSeparator = dateSeparator;
|
|
@@ -61,6 +58,9 @@ export class TuiInputDateComponent extends AbstractTuiNullableControl {
|
|
|
61
58
|
var _a;
|
|
62
59
|
return !!((_a = this.textfield) === null || _a === void 0 ? void 0 : _a.focused);
|
|
63
60
|
}
|
|
61
|
+
/**
|
|
62
|
+
* @deprecated
|
|
63
|
+
*/
|
|
64
64
|
get computedMobile() {
|
|
65
65
|
return this.isMobile && (!!this.mobileCalendar || this.nativePicker);
|
|
66
66
|
}
|
|
@@ -90,13 +90,9 @@ export class TuiInputDateComponent extends AbstractTuiNullableControl {
|
|
|
90
90
|
return ((_a = this.nativeFocusableElement) === null || _a === void 0 ? void 0 : _a.value) || '';
|
|
91
91
|
}
|
|
92
92
|
set nativeValue(value) {
|
|
93
|
-
if (
|
|
94
|
-
|
|
93
|
+
if (this.nativeFocusableElement) {
|
|
94
|
+
this.nativeFocusableElement.value = value;
|
|
95
95
|
}
|
|
96
|
-
this.nativeFocusableElement.value = value;
|
|
97
|
-
}
|
|
98
|
-
get canOpen() {
|
|
99
|
-
return this.interactive && !this.computedMobile;
|
|
100
96
|
}
|
|
101
97
|
get computedMask() {
|
|
102
98
|
return this.activeItem
|
|
@@ -108,7 +104,7 @@ export class TuiInputDateComponent extends AbstractTuiNullableControl {
|
|
|
108
104
|
return (value && this.items.find(item => item.day.daySame(value))) || null;
|
|
109
105
|
}
|
|
110
106
|
onClick() {
|
|
111
|
-
if (!this.isMobile) {
|
|
107
|
+
if (!this.isMobile && this.interactive) {
|
|
112
108
|
this.open = !this.open;
|
|
113
109
|
}
|
|
114
110
|
}
|
|
@@ -124,30 +120,15 @@ export class TuiInputDateComponent extends AbstractTuiNullableControl {
|
|
|
124
120
|
this.onIconClick();
|
|
125
121
|
}
|
|
126
122
|
onIconClick() {
|
|
127
|
-
if (
|
|
128
|
-
|
|
123
|
+
if (this.isMobile && this.interactive) {
|
|
124
|
+
this.open = true;
|
|
129
125
|
}
|
|
130
|
-
this.dialogs
|
|
131
|
-
.open(new PolymorpheusComponent(this.mobileCalendar, this.injector), {
|
|
132
|
-
size: 'fullscreen',
|
|
133
|
-
closeable: false,
|
|
134
|
-
data: {
|
|
135
|
-
single: true,
|
|
136
|
-
min: this.min,
|
|
137
|
-
max: this.max,
|
|
138
|
-
disabledItemHandler: this.disabledItemHandler,
|
|
139
|
-
},
|
|
140
|
-
})
|
|
141
|
-
.pipe(takeUntil(this.destroy$))
|
|
142
|
-
.subscribe(value => {
|
|
143
|
-
this.value = value;
|
|
144
|
-
});
|
|
145
126
|
}
|
|
146
127
|
onValueChange(value) {
|
|
147
128
|
if (this.control) {
|
|
148
129
|
this.control.updateValueAndValidity({ emitEvent: false });
|
|
149
130
|
}
|
|
150
|
-
if (!value) {
|
|
131
|
+
if (!value && !this.mobileCalendar) {
|
|
151
132
|
this.onOpenChange(true);
|
|
152
133
|
}
|
|
153
134
|
this.value =
|
|
@@ -188,12 +169,18 @@ export class TuiInputDateComponent extends AbstractTuiNullableControl {
|
|
|
188
169
|
});
|
|
189
170
|
}
|
|
190
171
|
}
|
|
191
|
-
TuiInputDateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputDateComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token:
|
|
172
|
+
TuiInputDateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputDateComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_IS_MOBILE }, { token: TUI_MOBILE_CALENDAR, optional: true }, { token: TUI_DATE_FORMAT }, { token: TUI_DATE_SEPARATOR }, { token: TUI_DATE_TEXTS }, { token: TUI_DATE_VALUE_TRANSFORMER, optional: true }, { token: TUI_INPUT_DATE_OPTIONS }, { token: TUI_TEXTFIELD_SIZE }], target: i0.ɵɵFactoryTarget.Component });
|
|
192
173
|
TuiInputDateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputDateComponent, selector: "tui-input-date", inputs: { min: "min", max: "max", disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", items: "items", defaultActiveYearMonth: "defaultActiveYearMonth" }, host: { listeners: { "click": "onClick()" }, properties: { "attr.data-size": "this.size" } }, providers: [
|
|
193
174
|
tuiAsFocusableItemAccessor(TuiInputDateComponent),
|
|
194
175
|
tuiAsControl(TuiInputDateComponent),
|
|
195
176
|
tuiDateStreamWithTransformer(TUI_DATE_VALUE_TRANSFORMER),
|
|
196
|
-
|
|
177
|
+
{
|
|
178
|
+
provide: TUI_DROPDOWN_COMPONENT,
|
|
179
|
+
useFactory: () => (inject(TUI_IS_MOBILE) &&
|
|
180
|
+
inject(TUI_MOBILE_CALENDAR, InjectFlags.Optional)) ||
|
|
181
|
+
inject(TUI_DROPDOWN_COMPONENT, InjectFlags.SkipSelf),
|
|
182
|
+
},
|
|
183
|
+
], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"interactive && !nativePicker\"\n [content]=\"dropdown\"\n [open]=\"open && interactive && !nativePicker\"\n (openChange)=\"onOpenChange($event)\"\n>\n <tui-primitive-textfield\n *tuiLet=\"filler$ | async as filler\"\n automation-id=\"tui-input-date-range__textfield\"\n tuiValueAccessor\n class=\"t-textfield\"\n [disabled]=\"computedDisabled\"\n [focusable]=\"computedFocusable\"\n [invalid]=\"computedInvalid\"\n [maskito]=\"computedMask\"\n [nativeId]=\"nativeId\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [readOnly]=\"readOnly\"\n [tuiTextfieldFiller]=\"getComputedFiller(filler || '')\"\n [tuiTextfieldIcon]=\"calendarIcon && iconContent\"\n [value]=\"computedValue\"\n (focusedChange)=\"onFocused($event)\"\n (valueChange)=\"onValueChange($event)\"\n >\n <ng-content></ng-content>\n <ng-content\n ngProjectAs=\"input\"\n select=\"input\"\n ></ng-content>\n </tui-primitive-textfield>\n\n <ng-template #iconContent>\n <tui-svg\n *polymorpheusOutlet=\"calendarIcon as src; context: {$implicit: size}\"\n appearance=\"icon\"\n automation-id=\"tui-input-date-range__icon\"\n tuiWrapper\n [class.t-icon]=\"!computedDisabled\"\n [src]=\"src\"\n (click)=\"onIconClick()\"\n ></tui-svg>\n <input\n *ngIf=\"isMobile && nativePicker\"\n tuiDate\n class=\"t-native-input\"\n />\n </ng-template>\n\n <ng-template\n #dropdown=\"polymorpheus\"\n [polymorpheus]=\"type\"\n >\n <tui-calendar\n automation-id=\"tui-input-date__calendar\"\n tuiPreventDefault=\"mousedown\"\n [disabledItemHandler]=\"disabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"computedMax\"\n [min]=\"computedMin\"\n [month]=\"computedActiveYearMonth\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event)\"\n ></tui-calendar>\n <div\n *ngIf=\"items.length === 1\"\n tuiPreventDefault=\"mousedown\"\n class=\"t-button\"\n >\n <button\n tuiLink\n type=\"button\"\n (click)=\"onDayClick(items[0].day)\"\n >\n {{ items[0] }}\n </button>\n </div>\n </ng-template>\n</tui-hosted-dropdown>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}.t-hosted{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}.t-icon{pointer-events:auto}.t-button{display:flex;height:2.75rem;justify-content:center;box-shadow:inset 0 1px var(--tui-base-03)}.t-button button{flex:1;text-align:center}.t-native-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;pointer-events:auto;font-size:2rem}\n"], components: [{ type: i1.TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: ["content", "sided", "canOpen", "open"], outputs: ["openChange", "focusedChange"] }, { type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }, { type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { type: i1.TuiCalendarComponent, selector: "tui-calendar", inputs: ["initialView", "month", "disabledItemHandler", "min", "max", "minViewedMonth", "maxViewedMonth", "hoveredItem", "showAdjacent", "markerHandler", "value"], outputs: ["dayClick", "monthChange", "hoveredItemChange"] }, { type: i1.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }], directives: [{ type: i2.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i3.TuiValueAccessorDirective, selector: "[tuiValueAccessor]" }, { type: i4.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { type: i1.TuiTextfieldFillerDirective, selector: "[tuiTextfieldFiller]", inputs: ["tuiTextfieldFiller"] }, { type: i1.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { type: i5.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i1.TuiWrapperDirective, selector: "[tuiWrapper]", inputs: ["disabled", "readOnly", "hover", "active", "focus", "invalid", "appearance"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.TuiNativeDateDirective, selector: "input[tuiDate]" }, { type: i5.PolymorpheusTemplate, selector: "ng-template[polymorpheus]", inputs: ["polymorpheus"], exportAs: ["polymorpheus"] }, { type: i2.TuiPreventDefaultDirective, selector: "[tuiPreventDefault]", inputs: ["tuiPreventDefault"] }], pipes: { "async": i6.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
197
184
|
__decorate([
|
|
198
185
|
tuiPure
|
|
199
186
|
], TuiInputDateComponent.prototype, "computeMaskOptions", null);
|
|
@@ -208,6 +195,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
208
195
|
tuiAsFocusableItemAccessor(TuiInputDateComponent),
|
|
209
196
|
tuiAsControl(TuiInputDateComponent),
|
|
210
197
|
tuiDateStreamWithTransformer(TUI_DATE_VALUE_TRANSFORMER),
|
|
198
|
+
{
|
|
199
|
+
provide: TUI_DROPDOWN_COMPONENT,
|
|
200
|
+
useFactory: () => (inject(TUI_IS_MOBILE) &&
|
|
201
|
+
inject(TUI_MOBILE_CALENDAR, InjectFlags.Optional)) ||
|
|
202
|
+
inject(TUI_DROPDOWN_COMPONENT, InjectFlags.SkipSelf),
|
|
203
|
+
},
|
|
211
204
|
],
|
|
212
205
|
}]
|
|
213
206
|
}], ctorParameters: function () { return [{ type: i8.NgControl, decorators: [{
|
|
@@ -220,15 +213,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
220
213
|
}] }, { type: i0.ChangeDetectorRef, decorators: [{
|
|
221
214
|
type: Inject,
|
|
222
215
|
args: [ChangeDetectorRef]
|
|
223
|
-
}] }, { type: i0.Injector, decorators: [{
|
|
224
|
-
type: Inject,
|
|
225
|
-
args: [Injector]
|
|
226
216
|
}] }, { type: undefined, decorators: [{
|
|
227
217
|
type: Inject,
|
|
228
218
|
args: [TUI_IS_MOBILE]
|
|
229
|
-
}] }, { type: i1.TuiDialogService, decorators: [{
|
|
230
|
-
type: Inject,
|
|
231
|
-
args: [TuiDialogService]
|
|
232
219
|
}] }, { type: i0.Type, decorators: [{
|
|
233
220
|
type: Optional
|
|
234
221
|
}, {
|
|
@@ -276,4 +263,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
276
263
|
type: HostListener,
|
|
277
264
|
args: ['click']
|
|
278
265
|
}], computeMaskOptions: [] } });
|
|
279
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date/input-date.component.ts","../../../../../projects/kit/components/input-date/input-date.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    HostListener,\n    Inject,\n    Injector,\n    Input,\n    Optional,\n    Self,\n    Type,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {MASKITO_DEFAULT_OPTIONS, MaskitoOptions} from '@maskito/core';\nimport {maskitoDateOptionsGenerator} from '@maskito/kit';\nimport {\n    AbstractTuiNullableControl,\n    AbstractTuiValueTransformer,\n    ALWAYS_FALSE_HANDLER,\n    changeDateSeparator,\n    DATE_FILLER_LENGTH,\n    TUI_DATE_FORMAT,\n    TUI_DATE_SEPARATOR,\n    TUI_IS_MOBILE,\n    TuiActiveZoneDirective,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiBooleanHandler,\n    TuiContextWithImplicit,\n    tuiDateClamp,\n    TuiDateMode,\n    TuiDay,\n    TuiFocusableElementAccessor,\n    TuiMonth,\n    tuiNullableSame,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_DEFAULT_MARKER_HANDLER,\n    TUI_TEXTFIELD_SIZE,\n    TuiDialogService,\n    TuiMarkerHandler,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeS,\n    TuiTextfieldSizeDirective,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TuiNamedDay} from '@taiga-ui/kit/classes';\nimport {TUI_DATE_MODE_MASKITO_ADAPTER} from '@taiga-ui/kit/constants';\nimport {\n    TUI_DATE_TEXTS,\n    TUI_DATE_VALUE_TRANSFORMER,\n    TUI_INPUT_DATE_OPTIONS,\n    TUI_MOBILE_CALENDAR,\n    tuiDateStreamWithTransformer,\n    TuiInputDateOptions,\n} from '@taiga-ui/kit/tokens';\nimport {PolymorpheusComponent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\n\n@Component({\n    selector: 'tui-input-date',\n    templateUrl: './input-date.template.html',\n    styleUrls: ['./input-date.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputDateComponent),\n        tuiAsControl(TuiInputDateComponent),\n        tuiDateStreamWithTransformer(TUI_DATE_VALUE_TRANSFORMER),\n    ],\n})\nexport class TuiInputDateComponent\n    extends AbstractTuiNullableControl<TuiDay>\n    implements TuiWithOptionalMinMax<TuiDay>, TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private month: TuiMonth | null = null;\n\n    @Input()\n    min: TuiDay | null = this.options.min;\n\n    @Input()\n    max: TuiDay | null = this.options.max;\n\n    @Input()\n    disabledItemHandler: TuiBooleanHandler<TuiDay> = ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    markerHandler: TuiMarkerHandler = TUI_DEFAULT_MARKER_HANDLER;\n\n    @Input()\n    items: readonly TuiNamedDay[] = [];\n\n    @Input()\n    defaultActiveYearMonth = TuiMonth.currentLocal();\n\n    open = false;\n\n    readonly type!: TuiContextWithImplicit<TuiActiveZoneDirective>;\n\n    readonly filler$: Observable<string> = this.dateTexts$.pipe(\n        map(dateTexts =>\n            changeDateSeparator(dateTexts[this.dateFormat], this.dateSeparator),\n        ),\n    );\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(Injector) private readonly injector: Injector,\n        @Inject(TUI_IS_MOBILE) readonly isMobile: boolean,\n        @Inject(TuiDialogService)\n        private readonly dialogs: TuiDialogService,\n        @Optional()\n        @Inject(TUI_MOBILE_CALENDAR)\n        private readonly mobileCalendar: Type<Record<string, any>> | null,\n        @Inject(TUI_DATE_FORMAT) readonly dateFormat: TuiDateMode,\n        @Inject(TUI_DATE_SEPARATOR) readonly dateSeparator: string,\n        @Inject(TUI_DATE_TEXTS)\n        readonly dateTexts$: Observable<Record<TuiDateMode, string>>,\n        @Optional()\n        @Inject(TUI_DATE_VALUE_TRANSFORMER)\n        override readonly valueTransformer: AbstractTuiValueTransformer<TuiDay | null> | null,\n        @Inject(TUI_INPUT_DATE_OPTIONS) private readonly options: TuiInputDateOptions,\n        @Inject(TUI_TEXTFIELD_SIZE)\n        private readonly textfieldSize: TuiTextfieldSizeDirective,\n    ) {\n        super(control, cdr, valueTransformer);\n    }\n\n    @HostBinding('attr.data-size')\n    get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    get computedMin(): TuiDay {\n        return this.min ?? this.options.min;\n    }\n\n    get computedMax(): TuiDay {\n        return this.max ?? this.options.max;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield?.nativeFocusableElement ?? null;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield?.focused;\n    }\n\n    get computedMobile(): boolean {\n        return this.isMobile && (!!this.mobileCalendar || this.nativePicker);\n    }\n\n    get nativePicker(): boolean {\n        return this.options.nativePicker;\n    }\n\n    get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    get computedValue(): string {\n        const {value, nativeValue, activeItem} = this;\n\n        if (activeItem) {\n            return String(activeItem);\n        }\n\n        return value ? value.toString(this.dateFormat, this.dateSeparator) : nativeValue;\n    }\n\n    get computedActiveYearMonth(): TuiMonth {\n        if (this.items[0] && this.value && this.value.daySame(this.items[0].day)) {\n            return this.items[0].displayDay;\n        }\n\n        return (\n            this.month ||\n            this.value ||\n            tuiDateClamp(this.defaultActiveYearMonth, this.computedMin, this.computedMax)\n        );\n    }\n\n    get nativeValue(): string {\n        return this.nativeFocusableElement?.value || '';\n    }\n\n    set nativeValue(value: string) {\n        if (!this.nativeFocusableElement) {\n            return;\n        }\n\n        this.nativeFocusableElement.value = value;\n    }\n\n    get canOpen(): boolean {\n        return this.interactive && !this.computedMobile;\n    }\n\n    get computedMask(): MaskitoOptions {\n        return this.activeItem\n            ? MASKITO_DEFAULT_OPTIONS\n            : this.computeMaskOptions(\n                  this.dateFormat,\n                  this.dateSeparator,\n                  this.computedMin,\n                  this.computedMax,\n              );\n    }\n\n    get activeItem(): TuiNamedDay | null {\n        const {value} = this;\n\n        return (value && this.items.find(item => item.day.daySame(value))) || null;\n    }\n\n    @HostListener('click')\n    onClick(): void {\n        if (!this.isMobile) {\n            this.open = !this.open;\n        }\n    }\n\n    getComputedFiller(filler: string): string {\n        return this.activeItem ? '' : filler;\n    }\n\n    // noinspection JSUnusedGlobalSymbols\n    /**\n     * TODO: Remove in 4.0\n     * @deprecated: use {@link onIconClick} instead\n     */\n    onMobileClick(): void {\n        this.onIconClick();\n    }\n\n    onIconClick(): void {\n        if (!this.computedMobile || !this.mobileCalendar || this.readOnly) {\n            return;\n        }\n\n        this.dialogs\n            .open<TuiDay>(new PolymorpheusComponent(this.mobileCalendar, this.injector), {\n                size: 'fullscreen',\n                closeable: false,\n                data: {\n                    single: true,\n                    min: this.min,\n                    max: this.max,\n                    disabledItemHandler: this.disabledItemHandler,\n                },\n            })\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(value => {\n                this.value = value;\n            });\n    }\n\n    onValueChange(value: string): void {\n        if (this.control) {\n            this.control.updateValueAndValidity({emitEvent: false});\n        }\n\n        if (!value) {\n            this.onOpenChange(true);\n        }\n\n        this.value =\n            value.length !== DATE_FILLER_LENGTH\n                ? null\n                : TuiDay.normalizeParse(value, this.dateFormat);\n    }\n\n    onDayClick(value: TuiDay): void {\n        this.value = value;\n        this.open = false;\n    }\n\n    onMonthChange(month: TuiMonth): void {\n        this.month = month;\n    }\n\n    onOpenChange(open: boolean): void {\n        this.open = open;\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.open = false;\n    }\n\n    override writeValue(value: TuiDay | null): void {\n        super.writeValue(value);\n        this.nativeValue = value ? this.computedValue : '';\n    }\n\n    protected override valueIdenticalComparator(\n        oldValue: TuiDay | null,\n        newValue: TuiDay | null,\n    ): boolean {\n        return tuiNullableSame(oldValue, newValue, (a, b) => a.daySame(b));\n    }\n\n    @tuiPure\n    private computeMaskOptions(\n        mode: TuiDateMode,\n        separator: string,\n        min: TuiDay,\n        max: TuiDay,\n    ): MaskitoOptions {\n        return maskitoDateOptionsGenerator({\n            separator,\n            mode: TUI_DATE_MODE_MASKITO_ADAPTER[mode],\n            min: min.toLocalNativeDate(),\n            max: max.toLocalNativeDate(),\n        });\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"canOpen\"\n    [content]=\"dropdown\"\n    [open]=\"open && canOpen\"\n    (openChange)=\"onOpenChange($event)\"\n>\n    <tui-primitive-textfield\n        *tuiLet=\"filler$ | async as filler\"\n        automation-id=\"tui-input-date-range__textfield\"\n        tuiValueAccessor\n        class=\"t-textfield\"\n        [disabled]=\"computedDisabled\"\n        [focusable]=\"computedFocusable\"\n        [invalid]=\"computedInvalid\"\n        [maskito]=\"computedMask\"\n        [nativeId]=\"nativeId\"\n        [pseudoFocus]=\"pseudoFocus\"\n        [pseudoHover]=\"pseudoHover\"\n        [readOnly]=\"readOnly\"\n        [tuiTextfieldFiller]=\"getComputedFiller(filler || '')\"\n        [tuiTextfieldIcon]=\"calendarIcon && iconContent\"\n        [value]=\"computedValue\"\n        (focusedChange)=\"onFocused($event)\"\n        (valueChange)=\"onValueChange($event)\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            ngProjectAs=\"input\"\n            select=\"input\"\n        ></ng-content>\n    </tui-primitive-textfield>\n\n    <ng-template #iconContent>\n        <tui-svg\n            *polymorpheusOutlet=\"calendarIcon as src; context: {$implicit: size}\"\n            appearance=\"icon\"\n            automation-id=\"tui-input-date-range__icon\"\n            tuiWrapper\n            [class.t-icon]=\"!computedDisabled\"\n            [src]=\"src\"\n            (click)=\"onIconClick()\"\n        ></tui-svg>\n        <input\n            *ngIf=\"isMobile && nativePicker\"\n            tuiDate\n            class=\"t-native-input\"\n        />\n    </ng-template>\n\n    <ng-template\n        #dropdown=\"polymorpheus\"\n        [polymorpheus]=\"type\"\n    >\n        <tui-calendar\n            automation-id=\"tui-input-date__calendar\"\n            tuiPreventDefault=\"mousedown\"\n            [disabledItemHandler]=\"disabledItemHandler\"\n            [markerHandler]=\"markerHandler\"\n            [max]=\"computedMax\"\n            [min]=\"computedMin\"\n            [month]=\"computedActiveYearMonth\"\n            [value]=\"value\"\n            (dayClick)=\"onDayClick($event)\"\n            (monthChange)=\"onMonthChange($event)\"\n        ></tui-calendar>\n        <div\n            *ngIf=\"items.length === 1\"\n            tuiPreventDefault=\"mousedown\"\n            class=\"t-button\"\n        >\n            <button\n                tuiLink\n                type=\"button\"\n                (click)=\"onDayClick(items[0].day)\"\n            >\n                {{ items[0] }}\n            </button>\n        </div>\n    </ng-template>\n</tui-hosted-dropdown>\n"]}
|
|
266
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date/input-date.component.ts","../../../../../projects/kit/components/input-date/input-date.template.html"],"names":[],"mappings":";AAAA,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,WAAW,EACX,YAAY,EACZ,MAAM,EACN,MAAM,EACN,WAAW,EACX,KAAK,EACL,QAAQ,EACR,IAAI,EAEJ,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAC,uBAAuB,EAAiB,MAAM,eAAe,CAAC;AACtE,OAAO,EAAC,2BAA2B,EAAC,MAAM,cAAc,CAAC;AACzD,OAAO,EACH,0BAA0B,EAE1B,oBAAoB,EACpB,mBAAmB,EACnB,kBAAkB,EAClB,eAAe,EACf,kBAAkB,EAClB,aAAa,EAEb,YAAY,EACZ,0BAA0B,EAG1B,YAAY,EAEZ,MAAM,EAEN,QAAQ,EACR,eAAe,EACf,OAAO,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,0BAA0B,EAC1B,sBAAsB,EACtB,kBAAkB,EAElB,8BAA8B,GAKjC,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAC,6BAA6B,EAAC,MAAM,yBAAyB,CAAC;AACtE,OAAO,EACH,cAAc,EACd,0BAA0B,EAC1B,sBAAsB,EACtB,mBAAmB,EACnB,4BAA4B,GAE/B,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;;;;;;;;;;;AAoBnC,MAAM,OAAO,qBACT,SAAQ,0BAAkC;IAoC1C,YAII,OAAyB,EACE,GAAsB,EACjB,QAAiB,EAGhC,cAAgD,EAC/B,UAAuB,EACpB,aAAqB,EAEjD,UAAmD,EAG1C,gBAAmE,EACpC,OAA4B,EAE5D,aAAwC;QAEzD,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,gBAAgB,CAAC,CAAC;QAfN,aAAQ,GAAR,QAAQ,CAAS;QAGhC,mBAAc,GAAd,cAAc,CAAkC;QAC/B,eAAU,GAAV,UAAU,CAAa;QACpB,kBAAa,GAAb,aAAa,CAAQ;QAEjD,eAAU,GAAV,UAAU,CAAyC;QAG1C,qBAAgB,GAAhB,gBAAgB,CAAmD;QACpC,YAAO,GAAP,OAAO,CAAqB;QAE5D,kBAAa,GAAb,aAAa,CAA2B;QAjDrD,UAAK,GAAoB,IAAI,CAAC;QAGtC,QAAG,GAAkB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;QAGtC,QAAG,GAAkB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;QAGtC,wBAAmB,GAA8B,oBAAoB,CAAC;QAGtE,kBAAa,GAAqB,0BAA0B,CAAC;QAG7D,UAAK,GAA2B,EAAE,CAAC;QAGnC,2BAAsB,GAAG,QAAQ,CAAC,YAAY,EAAE,CAAC;QAEjD,SAAI,GAAG,KAAK,CAAC;QAIJ,YAAO,GAAuB,IAAI,CAAC,UAAU,CAAC,IAAI,CACvD,GAAG,CAAC,SAAS,CAAC,EAAE,CACZ,mBAAmB,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC,CACtE,CACJ,CAAC;IAwBF,CAAC;IAED,IACI,IAAI;QACJ,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;IACnC,CAAC;IAED,IAAI,WAAW;;QACX,OAAO,MAAA,IAAI,CAAC,GAAG,mCAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;IACxC,CAAC;IAED,IAAI,WAAW;;QACX,OAAO,MAAA,IAAI,CAAC,GAAG,mCAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;IACxC,CAAC;IAED,IAAI,sBAAsB;;QACtB,OAAO,MAAA,MAAA,IAAI,CAAC,SAAS,0CAAE,sBAAsB,mCAAI,IAAI,CAAC;IAC1D,CAAC;IAED,IAAI,OAAO;;QACP,OAAO,CAAC,CAAC,CAAA,MAAA,IAAI,CAAC,SAAS,0CAAE,OAAO,CAAA,CAAC;IACrC,CAAC;IAED;;OAEG;IACH,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC;IACzE,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC;IACrC,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;IAC7B,CAAC;IAED,IAAI,aAAa;QACb,MAAM,EAAC,KAAK,EAAE,WAAW,EAAE,UAAU,EAAC,GAAG,IAAI,CAAC;QAE9C,IAAI,UAAU,EAAE;YACZ,OAAO,MAAM,CAAC,UAAU,CAAC,CAAC;SAC7B;QAED,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;IACrF,CAAC;IAED,IAAI,uBAAuB;QACvB,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE;YACtE,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;SACnC;QAED,OAAO,CACH,IAAI,CAAC,KAAK;YACV,IAAI,CAAC,KAAK;YACV,YAAY,CAAC,IAAI,CAAC,sBAAsB,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAChF,CAAC;IACN,CAAC;IAED,IAAI,WAAW;;QACX,OAAO,CAAA,MAAA,IAAI,CAAC,sBAAsB,0CAAE,KAAK,KAAI,EAAE,CAAC;IACpD,CAAC;IAED,IAAI,WAAW,CAAC,KAAa;QACzB,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC7B,IAAI,CAAC,sBAAsB,CAAC,KAAK,GAAG,KAAK,CAAC;SAC7C;IACL,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,UAAU;YAClB,CAAC,CAAC,uBAAuB;YACzB,CAAC,CAAC,IAAI,CAAC,kBAAkB,CACnB,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,WAAW,CACnB,CAAC;IACZ,CAAC;IAED,IAAI,UAAU;QACV,MAAM,EAAC,KAAK,EAAC,GAAG,IAAI,CAAC;QAErB,OAAO,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC;IAC/E,CAAC;IAGD,OAAO;QACH,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,EAAE;YACpC,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;SAC1B;IACL,CAAC;IAED,iBAAiB,CAAC,MAAc;QAC5B,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;IACzC,CAAC;IAED,qCAAqC;IACrC;;;OAGG;IACH,aAAa;QACT,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW,EAAE;YACnC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;SACpB;IACL,CAAC;IAED,aAAa,CAAC,KAAa;QACvB,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;SAC3D;QAED,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YAChC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;SAC3B;QAED,IAAI,CAAC,KAAK;YACN,KAAK,CAAC,MAAM,KAAK,kBAAkB;gBAC/B,CAAC,CAAC,IAAI;gBACN,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC5D,CAAC;IAED,UAAU,CAAC,KAAa;QACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;IACtB,CAAC;IAED,aAAa,CAAC,KAAe;QACzB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,YAAY,CAAC,IAAa;QACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACrB,CAAC;IAED,SAAS,CAAC,OAAgB;QACtB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAEQ,gBAAgB;QACrB,KAAK,CAAC,gBAAgB,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;IACtB,CAAC;IAEQ,UAAU,CAAC,KAAoB;QACpC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACxB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC;IACvD,CAAC;IAEkB,wBAAwB,CACvC,QAAuB,EACvB,QAAuB;QAEvB,OAAO,eAAe,CAAC,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACvE,CAAC;IAGO,kBAAkB,CACtB,IAAiB,EACjB,SAAiB,EACjB,GAAW,EACX,GAAW;QAEX,OAAO,2BAA2B,CAAC;YAC/B,SAAS;YACT,IAAI,EAAE,6BAA6B,CAAC,IAAI,CAAC;YACzC,GAAG,EAAE,GAAG,CAAC,iBAAiB,EAAE;YAC5B,GAAG,EAAE,GAAG,CAAC,iBAAiB,EAAE;SAC/B,CAAC,CAAC;IACP,CAAC;;mHA1OQ,qBAAqB,kBAwClB,SAAS,yCAET,iBAAiB,aACjB,aAAa,aAEb,mBAAmB,6BAEnB,eAAe,aACf,kBAAkB,aAClB,cAAc,aAGd,0BAA0B,6BAE1B,sBAAsB,aACtB,kBAAkB;uGAvDrB,qBAAqB,yTAbnB;QACP,0BAA0B,CAAC,qBAAqB,CAAC;QACjD,YAAY,CAAC,qBAAqB,CAAC;QACnC,4BAA4B,CAAC,0BAA0B,CAAC;QACxD;YACI,OAAO,EAAE,sBAAsB;YAC/B,UAAU,EAAE,GAAG,EAAE,CACb,CAAC,MAAM,CAAC,aAAa,CAAC;gBAClB,MAAM,CAAC,mBAAmB,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;gBACtD,MAAM,CAAC,sBAAsB,EAAE,WAAW,CAAC,QAAQ,CAAC;SAC3D;KACJ,qEAMU,8BAA8B,uECtF7C,ypFAiFA;AD+NI;IADC,OAAO;+DAaP;4FA1OQ,qBAAqB;kBAlBjC,SAAS;mBAAC;oBACP,QAAQ,EAAE,gBAAgB;oBAC1B,WAAW,EAAE,4BAA4B;oBACzC,SAAS,EAAE,CAAC,yBAAyB,CAAC;oBACtC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE;wBACP,0BAA0B,uBAAuB;wBACjD,YAAY,uBAAuB;wBACnC,4BAA4B,CAAC,0BAA0B,CAAC;wBACxD;4BACI,OAAO,EAAE,sBAAsB;4BAC/B,UAAU,EAAE,GAAG,EAAE,CACb,CAAC,MAAM,CAAC,aAAa,CAAC;gCAClB,MAAM,CAAC,mBAAmB,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;gCACtD,MAAM,CAAC,sBAAsB,EAAE,WAAW,CAAC,QAAQ,CAAC;yBAC3D;qBACJ;iBACJ;;0BAuCQ,QAAQ;;0BACR,IAAI;;0BACJ,MAAM;2BAAC,SAAS;;0BAEhB,MAAM;2BAAC,iBAAiB;;0BACxB,MAAM;2BAAC,aAAa;;0BACpB,QAAQ;;0BACR,MAAM;2BAAC,mBAAmB;;0BAE1B,MAAM;2BAAC,eAAe;;0BACtB,MAAM;2BAAC,kBAAkB;;0BACzB,MAAM;2BAAC,cAAc;;0BAErB,QAAQ;;0BACR,MAAM;2BAAC,0BAA0B;;0BAEjC,MAAM;2BAAC,sBAAsB;;0BAC7B,MAAM;2BAAC,kBAAkB;4CAlDb,SAAS;sBADzB,SAAS;uBAAC,8BAA8B;gBAMzC,GAAG;sBADF,KAAK;gBAIN,GAAG;sBADF,KAAK;gBAIN,mBAAmB;sBADlB,KAAK;gBAIN,aAAa;sBADZ,KAAK;gBAIN,KAAK;sBADJ,KAAK;gBAIN,sBAAsB;sBADrB,KAAK;gBAsCF,IAAI;sBADP,WAAW;uBAAC,gBAAgB;gBAsF7B,OAAO;sBADN,YAAY;uBAAC,OAAO;gBA4Eb,kBAAkB","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    HostListener,\n    Inject,\n    inject,\n    InjectFlags,\n    Input,\n    Optional,\n    Self,\n    Type,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {MASKITO_DEFAULT_OPTIONS, MaskitoOptions} from '@maskito/core';\nimport {maskitoDateOptionsGenerator} from '@maskito/kit';\nimport {\n    AbstractTuiNullableControl,\n    AbstractTuiValueTransformer,\n    ALWAYS_FALSE_HANDLER,\n    changeDateSeparator,\n    DATE_FILLER_LENGTH,\n    TUI_DATE_FORMAT,\n    TUI_DATE_SEPARATOR,\n    TUI_IS_MOBILE,\n    TuiActiveZoneDirective,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiBooleanHandler,\n    TuiContextWithImplicit,\n    tuiDateClamp,\n    TuiDateMode,\n    TuiDay,\n    TuiFocusableElementAccessor,\n    TuiMonth,\n    tuiNullableSame,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_DEFAULT_MARKER_HANDLER,\n    TUI_DROPDOWN_COMPONENT,\n    TUI_TEXTFIELD_SIZE,\n    TuiMarkerHandler,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeS,\n    TuiTextfieldSizeDirective,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TuiNamedDay} from '@taiga-ui/kit/classes';\nimport {TUI_DATE_MODE_MASKITO_ADAPTER} from '@taiga-ui/kit/constants';\nimport {\n    TUI_DATE_TEXTS,\n    TUI_DATE_VALUE_TRANSFORMER,\n    TUI_INPUT_DATE_OPTIONS,\n    TUI_MOBILE_CALENDAR,\n    tuiDateStreamWithTransformer,\n    TuiInputDateOptions,\n} from '@taiga-ui/kit/tokens';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n@Component({\n    selector: 'tui-input-date',\n    templateUrl: './input-date.template.html',\n    styleUrls: ['./input-date.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputDateComponent),\n        tuiAsControl(TuiInputDateComponent),\n        tuiDateStreamWithTransformer(TUI_DATE_VALUE_TRANSFORMER),\n        {\n            provide: TUI_DROPDOWN_COMPONENT,\n            useFactory: () =>\n                (inject(TUI_IS_MOBILE) &&\n                    inject(TUI_MOBILE_CALENDAR, InjectFlags.Optional)) ||\n                inject(TUI_DROPDOWN_COMPONENT, InjectFlags.SkipSelf),\n        },\n    ],\n})\nexport class TuiInputDateComponent\n    extends AbstractTuiNullableControl<TuiDay>\n    implements TuiWithOptionalMinMax<TuiDay>, TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    private month: TuiMonth | null = null;\n\n    @Input()\n    min: TuiDay | null = this.options.min;\n\n    @Input()\n    max: TuiDay | null = this.options.max;\n\n    @Input()\n    disabledItemHandler: TuiBooleanHandler<TuiDay> = ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    markerHandler: TuiMarkerHandler = TUI_DEFAULT_MARKER_HANDLER;\n\n    @Input()\n    items: readonly TuiNamedDay[] = [];\n\n    @Input()\n    defaultActiveYearMonth = TuiMonth.currentLocal();\n\n    open = false;\n\n    readonly type!: TuiContextWithImplicit<TuiActiveZoneDirective>;\n\n    readonly filler$: Observable<string> = this.dateTexts$.pipe(\n        map(dateTexts =>\n            changeDateSeparator(dateTexts[this.dateFormat], this.dateSeparator),\n        ),\n    );\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(TUI_IS_MOBILE) readonly isMobile: boolean,\n        @Optional()\n        @Inject(TUI_MOBILE_CALENDAR)\n        private readonly mobileCalendar: Type<Record<string, any>> | null,\n        @Inject(TUI_DATE_FORMAT) readonly dateFormat: TuiDateMode,\n        @Inject(TUI_DATE_SEPARATOR) readonly dateSeparator: string,\n        @Inject(TUI_DATE_TEXTS)\n        readonly dateTexts$: Observable<Record<TuiDateMode, string>>,\n        @Optional()\n        @Inject(TUI_DATE_VALUE_TRANSFORMER)\n        override readonly valueTransformer: AbstractTuiValueTransformer<TuiDay | null> | null,\n        @Inject(TUI_INPUT_DATE_OPTIONS) private readonly options: TuiInputDateOptions,\n        @Inject(TUI_TEXTFIELD_SIZE)\n        private readonly textfieldSize: TuiTextfieldSizeDirective,\n    ) {\n        super(control, cdr, valueTransformer);\n    }\n\n    @HostBinding('attr.data-size')\n    get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    get computedMin(): TuiDay {\n        return this.min ?? this.options.min;\n    }\n\n    get computedMax(): TuiDay {\n        return this.max ?? this.options.max;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield?.nativeFocusableElement ?? null;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield?.focused;\n    }\n\n    /**\n     * @deprecated\n     */\n    get computedMobile(): boolean {\n        return this.isMobile && (!!this.mobileCalendar || this.nativePicker);\n    }\n\n    get nativePicker(): boolean {\n        return this.options.nativePicker;\n    }\n\n    get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    get computedValue(): string {\n        const {value, nativeValue, activeItem} = this;\n\n        if (activeItem) {\n            return String(activeItem);\n        }\n\n        return value ? value.toString(this.dateFormat, this.dateSeparator) : nativeValue;\n    }\n\n    get computedActiveYearMonth(): TuiMonth {\n        if (this.items[0] && this.value && this.value.daySame(this.items[0].day)) {\n            return this.items[0].displayDay;\n        }\n\n        return (\n            this.month ||\n            this.value ||\n            tuiDateClamp(this.defaultActiveYearMonth, this.computedMin, this.computedMax)\n        );\n    }\n\n    get nativeValue(): string {\n        return this.nativeFocusableElement?.value || '';\n    }\n\n    set nativeValue(value: string) {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.value = value;\n        }\n    }\n\n    get computedMask(): MaskitoOptions {\n        return this.activeItem\n            ? MASKITO_DEFAULT_OPTIONS\n            : this.computeMaskOptions(\n                  this.dateFormat,\n                  this.dateSeparator,\n                  this.computedMin,\n                  this.computedMax,\n              );\n    }\n\n    get activeItem(): TuiNamedDay | null {\n        const {value} = this;\n\n        return (value && this.items.find(item => item.day.daySame(value))) || null;\n    }\n\n    @HostListener('click')\n    onClick(): void {\n        if (!this.isMobile && this.interactive) {\n            this.open = !this.open;\n        }\n    }\n\n    getComputedFiller(filler: string): string {\n        return this.activeItem ? '' : filler;\n    }\n\n    // noinspection JSUnusedGlobalSymbols\n    /**\n     * TODO: Remove in 4.0\n     * @deprecated: use {@link onIconClick} instead\n     */\n    onMobileClick(): void {\n        this.onIconClick();\n    }\n\n    onIconClick(): void {\n        if (this.isMobile && this.interactive) {\n            this.open = true;\n        }\n    }\n\n    onValueChange(value: string): void {\n        if (this.control) {\n            this.control.updateValueAndValidity({emitEvent: false});\n        }\n\n        if (!value && !this.mobileCalendar) {\n            this.onOpenChange(true);\n        }\n\n        this.value =\n            value.length !== DATE_FILLER_LENGTH\n                ? null\n                : TuiDay.normalizeParse(value, this.dateFormat);\n    }\n\n    onDayClick(value: TuiDay): void {\n        this.value = value;\n        this.open = false;\n    }\n\n    onMonthChange(month: TuiMonth): void {\n        this.month = month;\n    }\n\n    onOpenChange(open: boolean): void {\n        this.open = open;\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.open = false;\n    }\n\n    override writeValue(value: TuiDay | null): void {\n        super.writeValue(value);\n        this.nativeValue = value ? this.computedValue : '';\n    }\n\n    protected override valueIdenticalComparator(\n        oldValue: TuiDay | null,\n        newValue: TuiDay | null,\n    ): boolean {\n        return tuiNullableSame(oldValue, newValue, (a, b) => a.daySame(b));\n    }\n\n    @tuiPure\n    private computeMaskOptions(\n        mode: TuiDateMode,\n        separator: string,\n        min: TuiDay,\n        max: TuiDay,\n    ): MaskitoOptions {\n        return maskitoDateOptionsGenerator({\n            separator,\n            mode: TUI_DATE_MODE_MASKITO_ADAPTER[mode],\n            min: min.toLocalNativeDate(),\n            max: max.toLocalNativeDate(),\n        });\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"interactive && !nativePicker\"\n    [content]=\"dropdown\"\n    [open]=\"open && interactive && !nativePicker\"\n    (openChange)=\"onOpenChange($event)\"\n>\n    <tui-primitive-textfield\n        *tuiLet=\"filler$ | async as filler\"\n        automation-id=\"tui-input-date-range__textfield\"\n        tuiValueAccessor\n        class=\"t-textfield\"\n        [disabled]=\"computedDisabled\"\n        [focusable]=\"computedFocusable\"\n        [invalid]=\"computedInvalid\"\n        [maskito]=\"computedMask\"\n        [nativeId]=\"nativeId\"\n        [pseudoFocus]=\"pseudoFocus\"\n        [pseudoHover]=\"pseudoHover\"\n        [readOnly]=\"readOnly\"\n        [tuiTextfieldFiller]=\"getComputedFiller(filler || '')\"\n        [tuiTextfieldIcon]=\"calendarIcon && iconContent\"\n        [value]=\"computedValue\"\n        (focusedChange)=\"onFocused($event)\"\n        (valueChange)=\"onValueChange($event)\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            ngProjectAs=\"input\"\n            select=\"input\"\n        ></ng-content>\n    </tui-primitive-textfield>\n\n    <ng-template #iconContent>\n        <tui-svg\n            *polymorpheusOutlet=\"calendarIcon as src; context: {$implicit: size}\"\n            appearance=\"icon\"\n            automation-id=\"tui-input-date-range__icon\"\n            tuiWrapper\n            [class.t-icon]=\"!computedDisabled\"\n            [src]=\"src\"\n            (click)=\"onIconClick()\"\n        ></tui-svg>\n        <input\n            *ngIf=\"isMobile && nativePicker\"\n            tuiDate\n            class=\"t-native-input\"\n        />\n    </ng-template>\n\n    <ng-template\n        #dropdown=\"polymorpheus\"\n        [polymorpheus]=\"type\"\n    >\n        <tui-calendar\n            automation-id=\"tui-input-date__calendar\"\n            tuiPreventDefault=\"mousedown\"\n            [disabledItemHandler]=\"disabledItemHandler\"\n            [markerHandler]=\"markerHandler\"\n            [max]=\"computedMax\"\n            [min]=\"computedMin\"\n            [month]=\"computedActiveYearMonth\"\n            [value]=\"value\"\n            (dayClick)=\"onDayClick($event)\"\n            (monthChange)=\"onMonthChange($event)\"\n        ></tui-calendar>\n        <div\n            *ngIf=\"items.length === 1\"\n            tuiPreventDefault=\"mousedown\"\n            class=\"t-button\"\n        >\n            <button\n                tuiLink\n                type=\"button\"\n                (click)=\"onDayClick(items[0].day)\"\n            >\n                {{ items[0] }}\n            </button>\n        </div>\n    </ng-template>\n</tui-hosted-dropdown>\n"]}
|
|
@@ -1,14 +1,13 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, Inject,
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, Inject, inject, InjectFlags, Input, Optional, Self, ViewChild, } from '@angular/core';
|
|
2
2
|
import { NgControl } from '@angular/forms';
|
|
3
3
|
import { maskitoDateOptionsGenerator } from '@maskito/kit';
|
|
4
4
|
import { AbstractTuiMultipleControl, ALWAYS_FALSE_HANDLER, changeDateSeparator, TUI_DATE_FORMAT, TUI_DATE_SEPARATOR, TUI_IS_MOBILE, tuiAsControl, tuiAsFocusableItemAccessor, tuiDateClamp, TuiDay, tuiIsString, TuiMonth, } from '@taiga-ui/cdk';
|
|
5
|
-
import { TUI_DEFAULT_MARKER_HANDLER,
|
|
5
|
+
import { TUI_DEFAULT_MARKER_HANDLER, TUI_DROPDOWN_COMPONENT, TUI_TEXTFIELD_SIZE, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
|
|
6
6
|
import { TuiStringifiableItem } from '@taiga-ui/kit/classes';
|
|
7
7
|
import { TuiInputTagComponent } from '@taiga-ui/kit/components/input-tag';
|
|
8
8
|
import { TUI_DATE_TEXTS, TUI_DATE_VALUE_TRANSFORMER, TUI_DONE_WORD, TUI_INPUT_DATE_OPTIONS, TUI_MOBILE_CALENDAR, tuiDateStreamWithTransformer, } from '@taiga-ui/kit/tokens';
|
|
9
9
|
import { tuiImmutableUpdateInputDateMulti } from '@taiga-ui/kit/utils';
|
|
10
|
-
import {
|
|
11
|
-
import { map, takeUntil } from 'rxjs/operators';
|
|
10
|
+
import { map } from 'rxjs/operators';
|
|
12
11
|
import * as i0 from "@angular/core";
|
|
13
12
|
import * as i1 from "@taiga-ui/core";
|
|
14
13
|
import * as i2 from "@taiga-ui/kit/components/input-tag";
|
|
@@ -19,12 +18,10 @@ import * as i6 from "@taiga-ui/cdk";
|
|
|
19
18
|
import * as i7 from "@angular/common";
|
|
20
19
|
import * as i8 from "rxjs";
|
|
21
20
|
export class TuiInputDateMultiComponent extends AbstractTuiMultipleControl {
|
|
22
|
-
constructor(control, cdr,
|
|
21
|
+
constructor(control, cdr, isMobile, mobileCalendar, dateFormat, dateSeparator, dateTexts$, valueTransformer, options, textfieldSize, doneWord$) {
|
|
23
22
|
var _a, _b;
|
|
24
23
|
super(control, cdr, valueTransformer);
|
|
25
|
-
this.injector = injector;
|
|
26
24
|
this.isMobile = isMobile;
|
|
27
|
-
this.dialogs = dialogs;
|
|
28
25
|
this.mobileCalendar = mobileCalendar;
|
|
29
26
|
this.dateFormat = dateFormat;
|
|
30
27
|
this.dateSeparator = dateSeparator;
|
|
@@ -66,7 +63,7 @@ export class TuiInputDateMultiComponent extends AbstractTuiMultipleControl {
|
|
|
66
63
|
this.valueMapper = value => value.map(item => new TuiStringifiableItem(item, item => String(item)));
|
|
67
64
|
}
|
|
68
65
|
onClick() {
|
|
69
|
-
if (!this.isMobile) {
|
|
66
|
+
if (!this.isMobile && this.interactive) {
|
|
70
67
|
this.open = !this.open;
|
|
71
68
|
}
|
|
72
69
|
}
|
|
@@ -103,28 +100,10 @@ export class TuiInputDateMultiComponent extends AbstractTuiMultipleControl {
|
|
|
103
100
|
this.value[this.value.length - 1] ||
|
|
104
101
|
tuiDateClamp(this.defaultActiveYearMonth, this.computedMin, this.computedMax));
|
|
105
102
|
}
|
|
106
|
-
get canOpen() {
|
|
107
|
-
return this.interactive && !this.computedMobile;
|
|
108
|
-
}
|
|
109
103
|
onIconClick() {
|
|
110
|
-
if (
|
|
111
|
-
|
|
104
|
+
if (this.isMobile && this.interactive) {
|
|
105
|
+
this.open = true;
|
|
112
106
|
}
|
|
113
|
-
this.dialogs
|
|
114
|
-
.open(new PolymorpheusComponent(this.mobileCalendar, this.injector), {
|
|
115
|
-
size: 'fullscreen',
|
|
116
|
-
closeable: false,
|
|
117
|
-
data: {
|
|
118
|
-
multi: true,
|
|
119
|
-
min: this.min,
|
|
120
|
-
max: this.max,
|
|
121
|
-
disabledItemHandler: this.disabledItemHandler,
|
|
122
|
-
},
|
|
123
|
-
})
|
|
124
|
-
.pipe(takeUntil(this.destroy$))
|
|
125
|
-
.subscribe(value => {
|
|
126
|
-
this.value = value;
|
|
127
|
-
});
|
|
128
107
|
}
|
|
129
108
|
onEnter(search) {
|
|
130
109
|
if (!this.tagValidator(search)) {
|
|
@@ -139,7 +118,7 @@ export class TuiInputDateMultiComponent extends AbstractTuiMultipleControl {
|
|
|
139
118
|
onValueChange(value) {
|
|
140
119
|
var _a;
|
|
141
120
|
(_a = this.control) === null || _a === void 0 ? void 0 : _a.updateValueAndValidity({ emitEvent: false });
|
|
142
|
-
if (!value.length) {
|
|
121
|
+
if (!value.length && !this.mobileCalendar) {
|
|
143
122
|
this.onOpenChange(true);
|
|
144
123
|
}
|
|
145
124
|
this.value = value.map(({ item }) => item);
|
|
@@ -164,12 +143,18 @@ export class TuiInputDateMultiComponent extends AbstractTuiMultipleControl {
|
|
|
164
143
|
this.open = false;
|
|
165
144
|
}
|
|
166
145
|
}
|
|
167
|
-
TuiInputDateMultiComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputDateMultiComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token:
|
|
146
|
+
TuiInputDateMultiComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputDateMultiComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_IS_MOBILE }, { token: TUI_MOBILE_CALENDAR, optional: true }, { token: TUI_DATE_FORMAT }, { token: TUI_DATE_SEPARATOR }, { token: TUI_DATE_TEXTS }, { token: TUI_DATE_VALUE_TRANSFORMER, optional: true }, { token: TUI_INPUT_DATE_OPTIONS }, { token: TUI_TEXTFIELD_SIZE }, { token: TUI_DONE_WORD }], target: i0.ɵɵFactoryTarget.Component });
|
|
168
147
|
TuiInputDateMultiComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiInputDateMultiComponent, selector: "tui-input-date[multiple]", inputs: { min: "min", max: "max", disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", defaultActiveYearMonth: "defaultActiveYearMonth", expandable: "expandable", inputHidden: "inputHidden", search: "search", placeholder: "placeholder", rows: "rows", tagValidator: "tagValidator" }, host: { listeners: { "click": "onClick()" }, properties: { "attr.data-size": "this.size" } }, providers: [
|
|
169
148
|
tuiAsFocusableItemAccessor(TuiInputDateMultiComponent),
|
|
170
149
|
tuiAsControl(TuiInputDateMultiComponent),
|
|
171
150
|
tuiDateStreamWithTransformer(TUI_DATE_VALUE_TRANSFORMER),
|
|
172
|
-
|
|
151
|
+
{
|
|
152
|
+
provide: TUI_DROPDOWN_COMPONENT,
|
|
153
|
+
useFactory: () => (inject(TUI_IS_MOBILE) &&
|
|
154
|
+
inject(TUI_MOBILE_CALENDAR, InjectFlags.Optional)) ||
|
|
155
|
+
inject(TUI_DROPDOWN_COMPONENT, InjectFlags.SkipSelf),
|
|
156
|
+
},
|
|
157
|
+
], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }, { propertyName: "inputTag", first: true, predicate: TuiInputTagComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"interactive\"\n [content]=\"dropdown\"\n [open]=\"open && interactive\"\n (openChange)=\"onOpenChange($event)\"\n>\n <tui-input-tag\n #inputTag\n class=\"t-input\"\n [disabled]=\"disabled\"\n [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerWrapper\"\n [editable]=\"false\"\n [expandable]=\"expandable\"\n [inputHidden]=\"inputHidden\"\n [maskito]=\"maskitoOptions\"\n [nativeId]=\"nativeId\"\n [ngModel]=\"value | tuiMapper: valueMapper\"\n [placeholder]=\"placeholder\"\n [pseudoFocus]=\"pseudoFocus\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoInvalid]=\"computedInvalid\"\n [readOnly]=\"readOnly\"\n [removable]=\"!nativeDropdownMode\"\n [rows]=\"rows\"\n [tagValidator]=\"tagValidator | tuiMapper: disabledItemHandlerWrapper\"\n [tuiTextfieldFiller]=\"(filler$ | async) || ''\"\n [tuiTextfieldIcon]=\"calendarIcon && iconContent\"\n (keydown.enter)=\"onEnter(inputTag.search || '')\"\n (ngModelChange)=\"onValueChange($event)\"\n >\n <ng-content></ng-content>\n <ng-content\n ngProjectAs=\"input\"\n select=\"input\"\n ></ng-content>\n </tui-input-tag>\n\n <ng-template #iconContent>\n <tui-svg\n *polymorpheusOutlet=\"calendarIcon as src; context: {$implicit: size}\"\n appearance=\"icon\"\n tuiWrapper\n [class.t-icon]=\"!computedDisabled\"\n [src]=\"src\"\n (click)=\"onIconClick()\"\n ></tui-svg>\n </ng-template>\n\n <ng-template #dropdown>\n <tui-calendar\n [disabledItemHandler]=\"disabledItemHandler\"\n [markerHandler]=\"markerHandler\"\n [max]=\"computedMax\"\n [min]=\"computedMin\"\n [month]=\"computedActiveYearMonth\"\n [value]=\"value\"\n (dayClick)=\"onDayClick($event)\"\n (monthChange)=\"onMonthChange($event)\"\n (mousedown.silent.prevent)=\"(0)\"\n ></tui-calendar>\n <div\n class=\"t-button\"\n (mousedown.silent.prevent)=\"(0)\"\n >\n <button\n tuiLink\n type=\"button\"\n (click)=\"done()\"\n >\n {{ doneWord$ | async }}\n </button>\n </div>\n </ng-template>\n</tui-hosted-dropdown>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}.t-hosted{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}.t-icon{pointer-events:auto}.t-button{display:flex;height:2.75rem;justify-content:center;box-shadow:inset 0 1px var(--tui-base-03)}.t-button button{flex:1;text-align:center}.t-native-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;pointer-events:auto;font-size:2rem}\n"], components: [{ type: i1.TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: ["content", "sided", "canOpen", "open"], outputs: ["openChange", "focusedChange"] }, { type: i2.TuiInputTagComponent, selector: "tui-input-tag", inputs: ["separator", "search", "editable", "tagValidator", "expandable", "rows", "inputHidden", "uniqueTags", "autoColor", "maxLength", "placeholder", "removable", "disabledItemHandler", "pseudoFocused"], outputs: ["searchChange"] }, { type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { type: i1.TuiCalendarComponent, selector: "tui-calendar", inputs: ["initialView", "month", "disabledItemHandler", "min", "max", "minViewedMonth", "maxViewedMonth", "hoveredItem", "showAdjacent", "markerHandler", "value"], outputs: ["dayClick", "monthChange", "hoveredItemChange"] }, { type: i1.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }], directives: [{ type: i3.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.TuiTextfieldFillerDirective, selector: "[tuiTextfieldFiller]", inputs: ["tuiTextfieldFiller"] }, { type: i1.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { type: i5.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i1.TuiWrapperDirective, selector: "[tuiWrapper]", inputs: ["disabled", "readOnly", "hover", "active", "focus", "invalid", "appearance"] }], pipes: { "tuiMapper": i6.TuiMapperPipe, "async": i7.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
173
158
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiInputDateMultiComponent, decorators: [{
|
|
174
159
|
type: Component,
|
|
175
160
|
args: [{
|
|
@@ -181,6 +166,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
181
166
|
tuiAsFocusableItemAccessor(TuiInputDateMultiComponent),
|
|
182
167
|
tuiAsControl(TuiInputDateMultiComponent),
|
|
183
168
|
tuiDateStreamWithTransformer(TUI_DATE_VALUE_TRANSFORMER),
|
|
169
|
+
{
|
|
170
|
+
provide: TUI_DROPDOWN_COMPONENT,
|
|
171
|
+
useFactory: () => (inject(TUI_IS_MOBILE) &&
|
|
172
|
+
inject(TUI_MOBILE_CALENDAR, InjectFlags.Optional)) ||
|
|
173
|
+
inject(TUI_DROPDOWN_COMPONENT, InjectFlags.SkipSelf),
|
|
174
|
+
},
|
|
184
175
|
],
|
|
185
176
|
}]
|
|
186
177
|
}], ctorParameters: function () { return [{ type: i4.NgControl, decorators: [{
|
|
@@ -193,15 +184,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
193
184
|
}] }, { type: i0.ChangeDetectorRef, decorators: [{
|
|
194
185
|
type: Inject,
|
|
195
186
|
args: [ChangeDetectorRef]
|
|
196
|
-
}] }, { type: i0.Injector, decorators: [{
|
|
197
|
-
type: Inject,
|
|
198
|
-
args: [Injector]
|
|
199
187
|
}] }, { type: undefined, decorators: [{
|
|
200
188
|
type: Inject,
|
|
201
189
|
args: [TUI_IS_MOBILE]
|
|
202
|
-
}] }, { type: i1.TuiDialogService, decorators: [{
|
|
203
|
-
type: Inject,
|
|
204
|
-
args: [TuiDialogService]
|
|
205
190
|
}] }, { type: i0.Type, decorators: [{
|
|
206
191
|
type: Optional
|
|
207
192
|
}, {
|
|
@@ -265,4 +250,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
265
250
|
type: HostBinding,
|
|
266
251
|
args: ['attr.data-size']
|
|
267
252
|
}] } });
|
|
268
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-multi.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date-multi/input-date-multi.component.ts","../../../../../projects/kit/components/input-date-multi/input-date-multi.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    HostListener,\n    Inject,\n    Injector,\n    Input,\n    Optional,\n    Self,\n    Type,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {MaskitoOptions} from '@maskito/core';\nimport {maskitoDateOptionsGenerator} from '@maskito/kit';\nimport {\n    AbstractTuiMultipleControl,\n    AbstractTuiValueTransformer,\n    ALWAYS_FALSE_HANDLER,\n    changeDateSeparator,\n    TUI_DATE_FORMAT,\n    TUI_DATE_SEPARATOR,\n    TUI_IS_MOBILE,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiBooleanHandler,\n    tuiDateClamp,\n    TuiDateMode,\n    TuiDay,\n    TuiFocusableElementAccessor,\n    tuiIsString,\n    TuiMapper,\n    TuiMonth,\n    TuiTypedMapper,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_DEFAULT_MARKER_HANDLER,\n    TUI_TEXTFIELD_SIZE,\n    TuiDialogService,\n    TuiMarkerHandler,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeS,\n    TuiTextfieldSizeDirective,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TuiStringifiableItem} from '@taiga-ui/kit/classes';\nimport {TuiInputTagComponent} from '@taiga-ui/kit/components/input-tag';\nimport {\n    TUI_DATE_TEXTS,\n    TUI_DATE_VALUE_TRANSFORMER,\n    TUI_DONE_WORD,\n    TUI_INPUT_DATE_OPTIONS,\n    TUI_MOBILE_CALENDAR,\n    tuiDateStreamWithTransformer,\n    TuiInputDateOptions,\n} from '@taiga-ui/kit/tokens';\nimport {tuiImmutableUpdateInputDateMulti} from '@taiga-ui/kit/utils';\nimport {PolymorpheusComponent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\n\n@Component({\n    selector: 'tui-input-date[multiple]',\n    templateUrl: './input-date-multi.template.html',\n    styleUrls: ['../input-date/input-date.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputDateMultiComponent),\n        tuiAsControl(TuiInputDateMultiComponent),\n        tuiDateStreamWithTransformer(TUI_DATE_VALUE_TRANSFORMER),\n    ],\n})\nexport class TuiInputDateMultiComponent\n    extends AbstractTuiMultipleControl<TuiDay>\n    implements TuiWithOptionalMinMax<TuiDay>, TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @ViewChild(TuiInputTagComponent)\n    private readonly inputTag?: TuiInputTagComponent;\n\n    private month: TuiMonth | null = null;\n\n    @Input()\n    min: TuiDay | null = this.options.min;\n\n    @Input()\n    max: TuiDay | null = this.options.max;\n\n    @Input()\n    disabledItemHandler: TuiBooleanHandler<TuiDay> = ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    markerHandler: TuiMarkerHandler = TUI_DEFAULT_MARKER_HANDLER;\n\n    @Input()\n    defaultActiveYearMonth = TuiMonth.currentLocal();\n\n    @Input()\n    expandable = false;\n\n    @Input()\n    inputHidden = false;\n\n    @Input()\n    search: string | null = '';\n\n    @Input()\n    placeholder = '';\n\n    @Input()\n    rows = Infinity;\n\n    maskitoOptions: MaskitoOptions = maskitoDateOptionsGenerator({\n        mode: 'dd/mm/yyyy',\n        separator: '.',\n        min: this.min?.toLocalNativeDate(),\n        max: this.max?.toLocalNativeDate(),\n    });\n\n    open = false;\n\n    readonly filler$: Observable<string> = this.dateTexts$.pipe(\n        map(dateTexts =>\n            changeDateSeparator(dateTexts[this.dateFormat], this.dateSeparator),\n        ),\n    );\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(Injector) private readonly injector: Injector,\n        @Inject(TUI_IS_MOBILE) readonly isMobile: boolean,\n        @Inject(TuiDialogService)\n        private readonly dialogs: TuiDialogService,\n        @Optional()\n        @Inject(TUI_MOBILE_CALENDAR)\n        private readonly mobileCalendar: Type<Record<string, any>> | null,\n        @Inject(TUI_DATE_FORMAT) readonly dateFormat: TuiDateMode,\n        @Inject(TUI_DATE_SEPARATOR) readonly dateSeparator: string,\n        @Inject(TUI_DATE_TEXTS)\n        readonly dateTexts$: Observable<Record<TuiDateMode, string>>,\n        @Optional()\n        @Inject(TUI_DATE_VALUE_TRANSFORMER)\n        override readonly valueTransformer: AbstractTuiValueTransformer<\n            readonly TuiDay[]\n        > | null,\n        @Inject(TUI_INPUT_DATE_OPTIONS) private readonly options: TuiInputDateOptions,\n        @Inject(TUI_TEXTFIELD_SIZE)\n        private readonly textfieldSize: TuiTextfieldSizeDirective,\n        @Inject(TUI_DONE_WORD) readonly doneWord$: Observable<string>,\n    ) {\n        super(control, cdr, valueTransformer);\n    }\n\n    @Input()\n    tagValidator: TuiBooleanHandler<string> = (tag: TuiDay | string) => {\n        const {year, month, day} = tuiIsString(tag)\n            ? TuiDay.parseRawDateString(tag)\n            : tag;\n        const date = new TuiDay(year, month, day);\n\n        return (\n            (TuiDay.isValidDay(year, month, day) &&\n                this.min?.dayBefore(date) &&\n                this.max?.dayAfter(date)) ??\n            false\n        );\n    };\n\n    @HostListener('click')\n    onClick(): void {\n        if (!this.isMobile) {\n            this.open = !this.open;\n        }\n    }\n\n    readonly disabledItemHandlerWrapper: TuiMapper<\n        TuiBooleanHandler<string> | TuiBooleanHandler<TuiDay>,\n        TuiBooleanHandler<TuiStringifiableItem<any> | string>\n    > = handler => stringifiable =>\n        tuiIsString(stringifiable) || handler(stringifiable.item);\n\n    readonly valueMapper: TuiTypedMapper<\n        [readonly TuiDay[]],\n        ReadonlyArray<TuiStringifiableItem<TuiDay>>\n    > = value => value.map(item => new TuiStringifiableItem(item, item => String(item)));\n\n    @HostBinding('attr.data-size')\n    get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    get nativeDropdownMode(): boolean {\n        return this.isMobile;\n    }\n\n    get computedMin(): TuiDay {\n        return this.min ?? this.options.min;\n    }\n\n    get computedMax(): TuiDay {\n        return this.max ?? this.options.max;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield?.nativeFocusableElement || null;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield?.focused;\n    }\n\n    get computedMobile(): boolean {\n        return this.isMobile && !!this.mobileCalendar;\n    }\n\n    get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    get computedActiveYearMonth(): TuiMonth {\n        return (\n            this.month ||\n            this.value[this.value.length - 1] ||\n            tuiDateClamp(this.defaultActiveYearMonth, this.computedMin, this.computedMax)\n        );\n    }\n\n    get canOpen(): boolean {\n        return this.interactive && !this.computedMobile;\n    }\n\n    onIconClick(): void {\n        if (!this.computedMobile || !this.mobileCalendar) {\n            return;\n        }\n\n        this.dialogs\n            .open<readonly TuiDay[]>(\n                new PolymorpheusComponent(this.mobileCalendar, this.injector),\n                {\n                    size: 'fullscreen',\n                    closeable: false,\n                    data: {\n                        multi: true,\n                        min: this.min,\n                        max: this.max,\n                        disabledItemHandler: this.disabledItemHandler,\n                    },\n                },\n            )\n            .pipe(takeUntil(this.destroy$))\n            .subscribe(value => {\n                this.value = value;\n            });\n    }\n\n    onEnter(search: string): void {\n        if (!this.tagValidator(search)) {\n            return;\n        }\n\n        this.value = tuiImmutableUpdateInputDateMulti(\n            this.value,\n            TuiDay.normalizeParse(search),\n        );\n\n        if (this.inputTag) {\n            this.inputTag.search = '';\n        }\n\n        this.done();\n    }\n\n    onValueChange(value: ReadonlyArray<TuiStringifiableItem<TuiDay>>): void {\n        this.control?.updateValueAndValidity({emitEvent: false});\n\n        if (!value.length) {\n            this.onOpenChange(true);\n        }\n\n        this.value = value.map(({item}) => item);\n    }\n\n    onDayClick(value: TuiDay): void {\n        this.value = tuiImmutableUpdateInputDateMulti(this.value, value);\n    }\n\n    done(): void {\n        this.open = false;\n    }\n\n    onMonthChange(month: TuiMonth): void {\n        this.month = month;\n    }\n\n    onOpenChange(open: boolean): void {\n        this.open = open;\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.open = false;\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"canOpen\"\n    [content]=\"dropdown\"\n    [open]=\"open && canOpen\"\n    (openChange)=\"onOpenChange($event)\"\n>\n    <tui-input-tag\n        #inputTag\n        class=\"t-input\"\n        [disabled]=\"disabled\"\n        [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerWrapper\"\n        [editable]=\"false\"\n        [expandable]=\"expandable\"\n        [inputHidden]=\"inputHidden\"\n        [maskito]=\"maskitoOptions\"\n        [nativeId]=\"nativeId\"\n        [ngModel]=\"value | tuiMapper: valueMapper\"\n        [placeholder]=\"placeholder\"\n        [pseudoFocus]=\"pseudoFocus\"\n        [pseudoHover]=\"pseudoHover\"\n        [pseudoInvalid]=\"computedInvalid\"\n        [readOnly]=\"readOnly\"\n        [removable]=\"!nativeDropdownMode\"\n        [rows]=\"rows\"\n        [tagValidator]=\"tagValidator | tuiMapper: disabledItemHandlerWrapper\"\n        [tuiTextfieldFiller]=\"(filler$ | async) || ''\"\n        [tuiTextfieldIcon]=\"calendarIcon && iconContent\"\n        (keydown.enter)=\"onEnter(inputTag.search || '')\"\n        (ngModelChange)=\"onValueChange($event)\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            ngProjectAs=\"input\"\n            select=\"input\"\n        ></ng-content>\n    </tui-input-tag>\n\n    <ng-template #iconContent>\n        <tui-svg\n            *polymorpheusOutlet=\"calendarIcon as src; context: {$implicit: size}\"\n            appearance=\"icon\"\n            tuiWrapper\n            [class.t-icon]=\"!computedDisabled\"\n            [src]=\"src\"\n            (click)=\"onIconClick()\"\n        ></tui-svg>\n    </ng-template>\n\n    <ng-template #dropdown>\n        <tui-calendar\n            [disabledItemHandler]=\"disabledItemHandler\"\n            [markerHandler]=\"markerHandler\"\n            [max]=\"computedMax\"\n            [min]=\"computedMin\"\n            [month]=\"computedActiveYearMonth\"\n            [value]=\"value\"\n            (dayClick)=\"onDayClick($event)\"\n            (monthChange)=\"onMonthChange($event)\"\n            (mousedown.silent.prevent)=\"(0)\"\n        ></tui-calendar>\n        <div\n            class=\"t-button\"\n            (mousedown.silent.prevent)=\"(0)\"\n        >\n            <button\n                tuiLink\n                type=\"button\"\n                (click)=\"done()\"\n            >\n                {{ doneWord$ | async }}\n            </button>\n        </div>\n    </ng-template>\n</tui-hosted-dropdown>\n"]}
|
|
253
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-multi.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date-multi/input-date-multi.component.ts","../../../../../projects/kit/components/input-date-multi/input-date-multi.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    HostListener,\n    Inject,\n    inject,\n    InjectFlags,\n    Input,\n    Optional,\n    Self,\n    Type,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {MaskitoOptions} from '@maskito/core';\nimport {maskitoDateOptionsGenerator} from '@maskito/kit';\nimport {\n    AbstractTuiMultipleControl,\n    AbstractTuiValueTransformer,\n    ALWAYS_FALSE_HANDLER,\n    changeDateSeparator,\n    TUI_DATE_FORMAT,\n    TUI_DATE_SEPARATOR,\n    TUI_IS_MOBILE,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiBooleanHandler,\n    tuiDateClamp,\n    TuiDateMode,\n    TuiDay,\n    TuiFocusableElementAccessor,\n    tuiIsString,\n    TuiMapper,\n    TuiMonth,\n    TuiTypedMapper,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_DEFAULT_MARKER_HANDLER,\n    TUI_DROPDOWN_COMPONENT,\n    TUI_TEXTFIELD_SIZE,\n    TuiMarkerHandler,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeS,\n    TuiTextfieldSizeDirective,\n    TuiWithOptionalMinMax,\n} from '@taiga-ui/core';\nimport {TuiStringifiableItem} from '@taiga-ui/kit/classes';\nimport {TuiInputTagComponent} from '@taiga-ui/kit/components/input-tag';\nimport {\n    TUI_DATE_TEXTS,\n    TUI_DATE_VALUE_TRANSFORMER,\n    TUI_DONE_WORD,\n    TUI_INPUT_DATE_OPTIONS,\n    TUI_MOBILE_CALENDAR,\n    tuiDateStreamWithTransformer,\n    TuiInputDateOptions,\n} from '@taiga-ui/kit/tokens';\nimport {tuiImmutableUpdateInputDateMulti} from '@taiga-ui/kit/utils';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n@Component({\n    selector: 'tui-input-date[multiple]',\n    templateUrl: './input-date-multi.template.html',\n    styleUrls: ['../input-date/input-date.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiInputDateMultiComponent),\n        tuiAsControl(TuiInputDateMultiComponent),\n        tuiDateStreamWithTransformer(TUI_DATE_VALUE_TRANSFORMER),\n        {\n            provide: TUI_DROPDOWN_COMPONENT,\n            useFactory: () =>\n                (inject(TUI_IS_MOBILE) &&\n                    inject(TUI_MOBILE_CALENDAR, InjectFlags.Optional)) ||\n                inject(TUI_DROPDOWN_COMPONENT, InjectFlags.SkipSelf),\n        },\n    ],\n})\nexport class TuiInputDateMultiComponent\n    extends AbstractTuiMultipleControl<TuiDay>\n    implements TuiWithOptionalMinMax<TuiDay>, TuiFocusableElementAccessor\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @ViewChild(TuiInputTagComponent)\n    private readonly inputTag?: TuiInputTagComponent;\n\n    private month: TuiMonth | null = null;\n\n    @Input()\n    min: TuiDay | null = this.options.min;\n\n    @Input()\n    max: TuiDay | null = this.options.max;\n\n    @Input()\n    disabledItemHandler: TuiBooleanHandler<TuiDay> = ALWAYS_FALSE_HANDLER;\n\n    @Input()\n    markerHandler: TuiMarkerHandler = TUI_DEFAULT_MARKER_HANDLER;\n\n    @Input()\n    defaultActiveYearMonth = TuiMonth.currentLocal();\n\n    @Input()\n    expandable = false;\n\n    @Input()\n    inputHidden = false;\n\n    @Input()\n    search: string | null = '';\n\n    @Input()\n    placeholder = '';\n\n    @Input()\n    rows = Infinity;\n\n    maskitoOptions: MaskitoOptions = maskitoDateOptionsGenerator({\n        mode: 'dd/mm/yyyy',\n        separator: '.',\n        min: this.min?.toLocalNativeDate(),\n        max: this.max?.toLocalNativeDate(),\n    });\n\n    open = false;\n\n    readonly filler$: Observable<string> = this.dateTexts$.pipe(\n        map(dateTexts =>\n            changeDateSeparator(dateTexts[this.dateFormat], this.dateSeparator),\n        ),\n    );\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(TUI_IS_MOBILE) readonly isMobile: boolean,\n        @Optional()\n        @Inject(TUI_MOBILE_CALENDAR)\n        private readonly mobileCalendar: Type<Record<string, any>> | null,\n        @Inject(TUI_DATE_FORMAT) readonly dateFormat: TuiDateMode,\n        @Inject(TUI_DATE_SEPARATOR) readonly dateSeparator: string,\n        @Inject(TUI_DATE_TEXTS)\n        readonly dateTexts$: Observable<Record<TuiDateMode, string>>,\n        @Optional()\n        @Inject(TUI_DATE_VALUE_TRANSFORMER)\n        override readonly valueTransformer: AbstractTuiValueTransformer<\n            readonly TuiDay[]\n        > | null,\n        @Inject(TUI_INPUT_DATE_OPTIONS) private readonly options: TuiInputDateOptions,\n        @Inject(TUI_TEXTFIELD_SIZE)\n        private readonly textfieldSize: TuiTextfieldSizeDirective,\n        @Inject(TUI_DONE_WORD) readonly doneWord$: Observable<string>,\n    ) {\n        super(control, cdr, valueTransformer);\n    }\n\n    @Input()\n    tagValidator: TuiBooleanHandler<string> = (tag: TuiDay | string) => {\n        const {year, month, day} = tuiIsString(tag)\n            ? TuiDay.parseRawDateString(tag)\n            : tag;\n        const date = new TuiDay(year, month, day);\n\n        return (\n            (TuiDay.isValidDay(year, month, day) &&\n                this.min?.dayBefore(date) &&\n                this.max?.dayAfter(date)) ??\n            false\n        );\n    };\n\n    @HostListener('click')\n    onClick(): void {\n        if (!this.isMobile && this.interactive) {\n            this.open = !this.open;\n        }\n    }\n\n    readonly disabledItemHandlerWrapper: TuiMapper<\n        TuiBooleanHandler<string> | TuiBooleanHandler<TuiDay>,\n        TuiBooleanHandler<TuiStringifiableItem<any> | string>\n    > = handler => stringifiable =>\n        tuiIsString(stringifiable) || handler(stringifiable.item);\n\n    readonly valueMapper: TuiTypedMapper<\n        [readonly TuiDay[]],\n        ReadonlyArray<TuiStringifiableItem<TuiDay>>\n    > = value => value.map(item => new TuiStringifiableItem(item, item => String(item)));\n\n    @HostBinding('attr.data-size')\n    get size(): TuiSizeL | TuiSizeS {\n        return this.textfieldSize.size;\n    }\n\n    get nativeDropdownMode(): boolean {\n        return this.isMobile;\n    }\n\n    get computedMin(): TuiDay {\n        return this.min ?? this.options.min;\n    }\n\n    get computedMax(): TuiDay {\n        return this.max ?? this.options.max;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield?.nativeFocusableElement || null;\n    }\n\n    get focused(): boolean {\n        return !!this.textfield?.focused;\n    }\n\n    get computedMobile(): boolean {\n        return this.isMobile && !!this.mobileCalendar;\n    }\n\n    get calendarIcon(): TuiInputDateOptions['icon'] {\n        return this.options.icon;\n    }\n\n    get computedActiveYearMonth(): TuiMonth {\n        return (\n            this.month ||\n            this.value[this.value.length - 1] ||\n            tuiDateClamp(this.defaultActiveYearMonth, this.computedMin, this.computedMax)\n        );\n    }\n\n    onIconClick(): void {\n        if (this.isMobile && this.interactive) {\n            this.open = true;\n        }\n    }\n\n    onEnter(search: string): void {\n        if (!this.tagValidator(search)) {\n            return;\n        }\n\n        this.value = tuiImmutableUpdateInputDateMulti(\n            this.value,\n            TuiDay.normalizeParse(search),\n        );\n\n        if (this.inputTag) {\n            this.inputTag.search = '';\n        }\n\n        this.done();\n    }\n\n    onValueChange(value: ReadonlyArray<TuiStringifiableItem<TuiDay>>): void {\n        this.control?.updateValueAndValidity({emitEvent: false});\n\n        if (!value.length && !this.mobileCalendar) {\n            this.onOpenChange(true);\n        }\n\n        this.value = value.map(({item}) => item);\n    }\n\n    onDayClick(value: TuiDay): void {\n        this.value = tuiImmutableUpdateInputDateMulti(this.value, value);\n    }\n\n    done(): void {\n        this.open = false;\n    }\n\n    onMonthChange(month: TuiMonth): void {\n        this.month = month;\n    }\n\n    onOpenChange(open: boolean): void {\n        this.open = open;\n    }\n\n    onFocused(focused: boolean): void {\n        this.updateFocused(focused);\n    }\n\n    override setDisabledState(): void {\n        super.setDisabledState();\n        this.open = false;\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"interactive\"\n    [content]=\"dropdown\"\n    [open]=\"open && interactive\"\n    (openChange)=\"onOpenChange($event)\"\n>\n    <tui-input-tag\n        #inputTag\n        class=\"t-input\"\n        [disabled]=\"disabled\"\n        [disabledItemHandler]=\"disabledItemHandler | tuiMapper: disabledItemHandlerWrapper\"\n        [editable]=\"false\"\n        [expandable]=\"expandable\"\n        [inputHidden]=\"inputHidden\"\n        [maskito]=\"maskitoOptions\"\n        [nativeId]=\"nativeId\"\n        [ngModel]=\"value | tuiMapper: valueMapper\"\n        [placeholder]=\"placeholder\"\n        [pseudoFocus]=\"pseudoFocus\"\n        [pseudoHover]=\"pseudoHover\"\n        [pseudoInvalid]=\"computedInvalid\"\n        [readOnly]=\"readOnly\"\n        [removable]=\"!nativeDropdownMode\"\n        [rows]=\"rows\"\n        [tagValidator]=\"tagValidator | tuiMapper: disabledItemHandlerWrapper\"\n        [tuiTextfieldFiller]=\"(filler$ | async) || ''\"\n        [tuiTextfieldIcon]=\"calendarIcon && iconContent\"\n        (keydown.enter)=\"onEnter(inputTag.search || '')\"\n        (ngModelChange)=\"onValueChange($event)\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            ngProjectAs=\"input\"\n            select=\"input\"\n        ></ng-content>\n    </tui-input-tag>\n\n    <ng-template #iconContent>\n        <tui-svg\n            *polymorpheusOutlet=\"calendarIcon as src; context: {$implicit: size}\"\n            appearance=\"icon\"\n            tuiWrapper\n            [class.t-icon]=\"!computedDisabled\"\n            [src]=\"src\"\n            (click)=\"onIconClick()\"\n        ></tui-svg>\n    </ng-template>\n\n    <ng-template #dropdown>\n        <tui-calendar\n            [disabledItemHandler]=\"disabledItemHandler\"\n            [markerHandler]=\"markerHandler\"\n            [max]=\"computedMax\"\n            [min]=\"computedMin\"\n            [month]=\"computedActiveYearMonth\"\n            [value]=\"value\"\n            (dayClick)=\"onDayClick($event)\"\n            (monthChange)=\"onMonthChange($event)\"\n            (mousedown.silent.prevent)=\"(0)\"\n        ></tui-calendar>\n        <div\n            class=\"t-button\"\n            (mousedown.silent.prevent)=\"(0)\"\n        >\n            <button\n                tuiLink\n                type=\"button\"\n                (click)=\"done()\"\n            >\n                {{ doneWord$ | async }}\n            </button>\n        </div>\n    </ng-template>\n</tui-hosted-dropdown>\n"]}
|