@taiga-ui/kit 4.45.0 → 4.46.0-canary.3415f27
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/components/badged-content/badged-content.component.d.ts +5 -1
- package/components/combo-box/combo-box.directive.d.ts +0 -1
- package/components/index.d.ts +2 -0
- package/components/input-chip/input-chip.component.d.ts +1 -0
- package/components/input-chip/input-chip.directive.d.ts +5 -3
- package/components/input-date/date-filler.d.ts +2 -0
- package/components/input-date/index.d.ts +1 -0
- package/components/input-date/input-date.directive.d.ts +14 -10
- package/components/input-date-multi/index.d.ts +2 -0
- package/components/input-date-multi/input-date-multi.d.ts +4 -0
- package/components/input-date-multi/input-date-multi.directive.d.ts +30 -0
- package/components/input-date-range/input-date-range.directive.d.ts +1 -1
- package/components/input-date-time/index.d.ts +4 -0
- package/components/input-date-time/input-date-time.component.d.ts +13 -0
- package/components/input-date-time/input-date-time.d.ts +4 -0
- package/components/input-date-time/input-date-time.directive.d.ts +37 -0
- package/components/input-date-time/input-date-time.options.d.ts +18 -0
- package/components/input-time/input-time.component.d.ts +12 -3
- package/components/preview/preview.component.d.ts +2 -1
- package/esm2022/components/avatar/avatar.component.mjs +3 -3
- package/esm2022/components/badged-content/badged-content.component.mjs +14 -3
- package/esm2022/components/button-loading/button-loading.component.mjs +2 -1
- package/esm2022/components/combo-box/combo-box.directive.mjs +4 -10
- package/esm2022/components/index.mjs +3 -1
- package/esm2022/components/input-chip/input-chip.component.mjs +5 -3
- package/esm2022/components/input-chip/input-chip.directive.mjs +3 -3
- package/esm2022/components/input-date/date-filler.mjs +20 -0
- package/esm2022/components/input-date/index.mjs +2 -1
- package/esm2022/components/input-date/input-date.directive.mjs +32 -32
- package/esm2022/components/input-date-multi/index.mjs +3 -0
- package/esm2022/components/input-date-multi/input-date-multi.directive.mjs +129 -0
- package/esm2022/components/input-date-multi/input-date-multi.mjs +9 -0
- package/esm2022/components/input-date-multi/taiga-ui-kit-components-input-date-multi.mjs +5 -0
- package/esm2022/components/input-date-range/input-date-range.directive.mjs +5 -5
- package/esm2022/components/input-date-time/index.mjs +5 -0
- package/esm2022/components/input-date-time/input-date-time.component.mjs +34 -0
- package/esm2022/components/input-date-time/input-date-time.directive.mjs +174 -0
- package/esm2022/components/input-date-time/input-date-time.mjs +9 -0
- package/esm2022/components/input-date-time/input-date-time.options.mjs +20 -0
- package/esm2022/components/input-date-time/taiga-ui-kit-components-input-date-time.mjs +5 -0
- package/esm2022/components/input-time/input-time.component.mjs +44 -26
- package/esm2022/components/input-time/input-time.directive.mjs +7 -2
- package/esm2022/components/pager/pager.component.mjs +3 -3
- package/esm2022/components/preview/dialog/preview-dialog.component.mjs +3 -3
- package/esm2022/components/preview/preview.component.mjs +8 -6
- package/esm2022/components/status/status.directive.mjs +2 -2
- package/esm2022/components/textarea/textarea.component.mjs +3 -2
- package/esm2022/directives/lazy-loading/lazy-loading.directive.mjs +2 -1
- package/fesm2022/taiga-ui-kit-components-avatar.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-avatar.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-badged-content.mjs +13 -2
- package/fesm2022/taiga-ui-kit-components-badged-content.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-button-loading.mjs +1 -0
- package/fesm2022/taiga-ui-kit-components-button-loading.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-combo-box.mjs +3 -9
- package/fesm2022/taiga-ui-kit-components-combo-box.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-chip.mjs +7 -5
- package/fesm2022/taiga-ui-kit-components-input-chip.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-date-multi.mjs +141 -0
- package/fesm2022/taiga-ui-kit-components-input-date-multi.mjs.map +1 -0
- package/fesm2022/taiga-ui-kit-components-input-date-range.mjs +4 -4
- package/fesm2022/taiga-ui-kit-components-input-date-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-date-time.mjs +230 -0
- package/fesm2022/taiga-ui-kit-components-input-date-time.mjs.map +1 -0
- package/fesm2022/taiga-ui-kit-components-input-date.mjs +52 -37
- package/fesm2022/taiga-ui-kit-components-input-date.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-time.mjs +48 -26
- package/fesm2022/taiga-ui-kit-components-input-time.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-pager.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-pager.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-preview-dialog.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-preview-dialog.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-preview.mjs +9 -7
- package/fesm2022/taiga-ui-kit-components-preview.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-status.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-status.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-textarea.mjs +2 -1
- package/fesm2022/taiga-ui-kit-components-textarea.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components.mjs +2 -0
- package/fesm2022/taiga-ui-kit-components.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-directives-lazy-loading.mjs +1 -0
- package/fesm2022/taiga-ui-kit-directives-lazy-loading.mjs.map +1 -1
- package/package.json +26 -14
- package/styles/components/status.less +1 -4
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './input-date-multi';
|
|
2
|
+
export * from './input-date-multi.directive';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1kYXRlLW11bHRpL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vaW5wdXQtZGF0ZS1tdWx0aSc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LWRhdGUtbXVsdGkuZGlyZWN0aXZlJztcbiJdfQ==
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { computed, Directive, effect, inject, Input, signal } from '@angular/core';
|
|
2
|
+
import { toSignal } from '@angular/core/rxjs-interop';
|
|
3
|
+
import { MaskitoDirective } from '@maskito/angular';
|
|
4
|
+
import { maskitoDateOptionsGenerator } from '@maskito/kit';
|
|
5
|
+
import { tuiAsControl } from '@taiga-ui/cdk/classes';
|
|
6
|
+
import { TUI_ALLOW_SIGNAL_WRITES } from '@taiga-ui/cdk/constants';
|
|
7
|
+
import { DATE_FILLER_LENGTH, TuiDay, TuiMonth } from '@taiga-ui/cdk/date-time';
|
|
8
|
+
import { TuiNativeValidator } from '@taiga-ui/cdk/directives/native-validator';
|
|
9
|
+
import { tuiFallbackValueProvider } from '@taiga-ui/cdk/tokens';
|
|
10
|
+
import { TuiCalendar } from '@taiga-ui/core/components/calendar';
|
|
11
|
+
import { tuiAsTextfieldAccessor, tuiInjectAuxiliary, TuiTextfieldBase, tuiTextfieldIconBinding, } from '@taiga-ui/core/components/textfield';
|
|
12
|
+
import { TuiDropdownAuto } from '@taiga-ui/core/directives/dropdown';
|
|
13
|
+
import { TUI_DATE_FORMAT, TUI_DEFAULT_DATE_FORMAT } from '@taiga-ui/core/tokens';
|
|
14
|
+
import { TuiInputChipDirective } from '@taiga-ui/kit/components/input-chip';
|
|
15
|
+
import { TUI_DATE_ADAPTER, TUI_INPUT_DATE_OPTIONS_NEW, } from '@taiga-ui/kit/components/input-date';
|
|
16
|
+
import { tuiMaskito } from '@taiga-ui/kit/utils';
|
|
17
|
+
import * as i0 from "@angular/core";
|
|
18
|
+
import * as i1 from "@taiga-ui/cdk/directives/native-validator";
|
|
19
|
+
import * as i2 from "@taiga-ui/core/directives/dropdown";
|
|
20
|
+
import * as i3 from "@maskito/angular";
|
|
21
|
+
import * as i4 from "@taiga-ui/core/components/textfield";
|
|
22
|
+
class TuiInputDateMultiDirective extends TuiInputChipDirective {
|
|
23
|
+
constructor() {
|
|
24
|
+
super(...arguments);
|
|
25
|
+
this.dateOptions = inject(TUI_INPUT_DATE_OPTIONS_NEW);
|
|
26
|
+
this.icon = tuiTextfieldIconBinding(TUI_INPUT_DATE_OPTIONS_NEW);
|
|
27
|
+
this.stringify = this.handlers.stringify.set((item) => item.toString(this.format().mode, this.format().separator));
|
|
28
|
+
this.mask = tuiMaskito(computed(() => maskitoDateOptionsGenerator({
|
|
29
|
+
separator: this.format().separator,
|
|
30
|
+
mode: TUI_DATE_ADAPTER[this.format().mode],
|
|
31
|
+
min: this.min().toLocalNativeDate(),
|
|
32
|
+
max: this.max().toLocalNativeDate(),
|
|
33
|
+
})));
|
|
34
|
+
this.format = toSignal(inject(TUI_DATE_FORMAT), {
|
|
35
|
+
initialValue: TUI_DEFAULT_DATE_FORMAT,
|
|
36
|
+
});
|
|
37
|
+
this.calendarIn = effect(() => {
|
|
38
|
+
if (this.calendar()) {
|
|
39
|
+
this.processCalendar(this.calendar());
|
|
40
|
+
}
|
|
41
|
+
}, TUI_ALLOW_SIGNAL_WRITES);
|
|
42
|
+
this.calendarOut = effect((onCleanup) => {
|
|
43
|
+
const subscription = this.calendar()?.dayClick.subscribe((day) => {
|
|
44
|
+
this.updateValue(day);
|
|
45
|
+
});
|
|
46
|
+
onCleanup(() => subscription?.unsubscribe());
|
|
47
|
+
});
|
|
48
|
+
this.min = signal(this.dateOptions.min);
|
|
49
|
+
this.max = signal(this.dateOptions.max);
|
|
50
|
+
this.calendar = tuiInjectAuxiliary((x) => x instanceof TuiCalendar);
|
|
51
|
+
}
|
|
52
|
+
set minSetter(min) {
|
|
53
|
+
this.min.set(min || this.dateOptions.min);
|
|
54
|
+
}
|
|
55
|
+
set maxSetter(max) {
|
|
56
|
+
this.max.set(max || this.dateOptions.max);
|
|
57
|
+
}
|
|
58
|
+
clear() {
|
|
59
|
+
this.onChange([]);
|
|
60
|
+
this.open.set(this.interactive());
|
|
61
|
+
}
|
|
62
|
+
processCalendar(calendar) {
|
|
63
|
+
calendar.value = this.value();
|
|
64
|
+
calendar.min = this.min();
|
|
65
|
+
calendar.max = this.max();
|
|
66
|
+
calendar.month =
|
|
67
|
+
this.value()?.[this.value().length - 1] ?? TuiMonth.currentLocal();
|
|
68
|
+
}
|
|
69
|
+
onClick() {
|
|
70
|
+
this.open.update((open) => !open);
|
|
71
|
+
}
|
|
72
|
+
onValueChange(value) {
|
|
73
|
+
const newValue = value.length === DATE_FILLER_LENGTH
|
|
74
|
+
? TuiDay.normalizeParse(value, this.format().mode)
|
|
75
|
+
: null;
|
|
76
|
+
if (newValue && !this.handlers.disabledItemHandler()(newValue)) {
|
|
77
|
+
this.updateValue(newValue);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
onEnter() {
|
|
81
|
+
this.onValueChange(this.textfield.value().trim());
|
|
82
|
+
this.scrollTo();
|
|
83
|
+
}
|
|
84
|
+
updateValue(day) {
|
|
85
|
+
const exist = this.value().find((x) => x.daySame(day));
|
|
86
|
+
const newValue = exist
|
|
87
|
+
? this.value().filter((x) => !x.daySame(day))
|
|
88
|
+
: this.value().concat(day);
|
|
89
|
+
this.setValue(newValue);
|
|
90
|
+
}
|
|
91
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateMultiDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
92
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputDateMultiDirective, isStandalone: true, selector: "input[tuiInputDateMulti]", inputs: { minSetter: ["min", "minSetter"], maxSetter: ["max", "maxSetter"] }, host: { listeners: { "keydown.enter.prevent": "0" } }, providers: [
|
|
93
|
+
tuiAsControl(TuiInputDateMultiDirective),
|
|
94
|
+
tuiFallbackValueProvider([]),
|
|
95
|
+
tuiAsTextfieldAccessor(TuiInputDateMultiDirective),
|
|
96
|
+
], usesInheritance: true, hostDirectives: [{ directive: i1.TuiNativeValidator }, { directive: i2.TuiDropdownAuto }, { directive: i3.MaskitoDirective }, { directive: i4.TuiTextfieldBase, inputs: ["invalid", "invalid", "focused", "focused", "readOnly", "readOnly", "state", "state"] }], ngImport: i0 }); }
|
|
97
|
+
}
|
|
98
|
+
export { TuiInputDateMultiDirective };
|
|
99
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateMultiDirective, decorators: [{
|
|
100
|
+
type: Directive,
|
|
101
|
+
args: [{
|
|
102
|
+
standalone: true,
|
|
103
|
+
selector: 'input[tuiInputDateMulti]',
|
|
104
|
+
providers: [
|
|
105
|
+
tuiAsControl(TuiInputDateMultiDirective),
|
|
106
|
+
tuiFallbackValueProvider([]),
|
|
107
|
+
tuiAsTextfieldAccessor(TuiInputDateMultiDirective),
|
|
108
|
+
],
|
|
109
|
+
hostDirectives: [
|
|
110
|
+
TuiNativeValidator,
|
|
111
|
+
TuiDropdownAuto,
|
|
112
|
+
MaskitoDirective,
|
|
113
|
+
{
|
|
114
|
+
directive: TuiTextfieldBase,
|
|
115
|
+
inputs: ['invalid', 'focused', 'readOnly', 'state'],
|
|
116
|
+
},
|
|
117
|
+
],
|
|
118
|
+
host: {
|
|
119
|
+
'(keydown.enter.prevent)': '0',
|
|
120
|
+
},
|
|
121
|
+
}]
|
|
122
|
+
}], propDecorators: { minSetter: [{
|
|
123
|
+
type: Input,
|
|
124
|
+
args: ['min']
|
|
125
|
+
}], maxSetter: [{
|
|
126
|
+
type: Input,
|
|
127
|
+
args: ['max']
|
|
128
|
+
}] } });
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-multi.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date-multi/input-date-multi.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAC,MAAM,eAAe,CAAC;AACjF,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AACpD,OAAO,EAAC,gBAAgB,EAAC,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAC,2BAA2B,EAAC,MAAM,cAAc,CAAC;AACzD,OAAO,EAAC,YAAY,EAAC,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAC,uBAAuB,EAAC,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAC,kBAAkB,EAAE,MAAM,EAAE,QAAQ,EAAC,MAAM,yBAAyB,CAAC;AAC7E,OAAO,EAAC,kBAAkB,EAAC,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAC,wBAAwB,EAAC,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EAAC,WAAW,EAAC,MAAM,oCAAoC,CAAC;AAC/D,OAAO,EACH,sBAAsB,EACtB,kBAAkB,EAClB,gBAAgB,EAChB,uBAAuB,GAC1B,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAC,eAAe,EAAC,MAAM,oCAAoC,CAAC;AACnE,OAAO,EAAC,eAAe,EAAE,uBAAuB,EAAC,MAAM,uBAAuB,CAAC;AAC/E,OAAO,EAAC,qBAAqB,EAAC,MAAM,qCAAqC,CAAC;AAC1E,OAAO,EACH,gBAAgB,EAChB,0BAA0B,GAC7B,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAC,UAAU,EAAC,MAAM,qBAAqB,CAAC;;;;;;AAE/C,MAqBa,0BAA2B,SAAQ,qBAA6B;IArB7E;;QAsBqB,gBAAW,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;QAE/C,SAAI,GAAG,uBAAuB,CAAC,0BAA0B,CAAC,CAAC;QAC3D,cAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAChE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC,CAC7D,CAAC;QAEiB,SAAI,GAAG,UAAU,CAChC,QAAQ,CAAC,GAAG,EAAE,CACV,2BAA2B,CAAC;YACxB,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS;YAClC,IAAI,EAAE,gBAAgB,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC;YAC1C,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,EAAE;YACnC,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,EAAE;SACtC,CAAC,CACL,CACJ,CAAC;QAEiB,WAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,eAAe,CAAC,EAAE;YAC1D,YAAY,EAAE,uBAAuB;SACxC,CAAC,CAAC;QAEgB,eAAU,GAAG,MAAM,CAAC,GAAG,EAAE;YACxC,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE;gBACjB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAG,CAAC,CAAC;aAC1C;QACL,CAAC,EAAE,uBAAuB,CAAC,CAAC;QAET,gBAAW,GAAG,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE;YAClD,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,EAAE,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;gBAC7D,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;YAC1B,CAAC,CAAC,CAAC;YAEH,SAAS,CAAC,GAAG,EAAE,CAAC,YAAY,EAAE,WAAW,EAAE,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QAEa,QAAG,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QACnC,QAAG,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAEnC,aAAQ,GAAG,kBAAkB,CACzC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,YAAY,WAAW,CAClC,CAAC;KAqDL;IAnDG,IACW,SAAS,CAAC,GAAkB;QACnC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IAC9C,CAAC;IAED,IACW,SAAS,CAAC,GAAkB;QACnC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IAC9C,CAAC;IAES,KAAK;QACX,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAClB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IACtC,CAAC;IAES,eAAe,CAAC,QAAqB;QAC3C,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QAC9B,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC1B,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC1B,QAAQ,CAAC,KAAK;YACV,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,QAAQ,CAAC,YAAY,EAAE,CAAC;IAC3E,CAAC;IAES,OAAO;QACb,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAES,aAAa,CAAC,KAAa;QACjC,MAAM,QAAQ,GACV,KAAK,CAAC,MAAM,KAAK,kBAAkB;YAC/B,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC;YAClD,CAAC,CAAC,IAAI,CAAC;QAEf,IAAI,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC,EAAE;YAC5D,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;SAC9B;IACL,CAAC;IAEkB,OAAO;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QAClD,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAEO,WAAW,CAAC,GAAW;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;QACvD,MAAM,QAAQ,GAAG,KAAK;YAClB,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAC7C,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAE/B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC5B,CAAC;+GA9FQ,0BAA0B;mGAA1B,0BAA0B,4MAlBxB;YACP,YAAY,CAAC,0BAA0B,CAAC;YACxC,wBAAwB,CAAC,EAAE,CAAC;YAC5B,sBAAsB,CAAC,0BAA0B,CAAC;SACrD;;SAcQ,0BAA0B;4FAA1B,0BAA0B;kBArBtC,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,0BAA0B;oBACpC,SAAS,EAAE;wBACP,YAAY,4BAA4B;wBACxC,wBAAwB,CAAC,EAAE,CAAC;wBAC5B,sBAAsB,4BAA4B;qBACrD;oBACD,cAAc,EAAE;wBACZ,kBAAkB;wBAClB,eAAe;wBACf,gBAAgB;wBAChB;4BACI,SAAS,EAAE,gBAAgB;4BAC3B,MAAM,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,CAAC;yBACtD;qBACJ;oBACD,IAAI,EAAE;wBACF,yBAAyB,EAAE,GAAG;qBACjC;iBACJ;8BA8Cc,SAAS;sBADnB,KAAK;uBAAC,KAAK;gBAMD,SAAS;sBADnB,KAAK;uBAAC,KAAK","sourcesContent":["import {computed, Directive, effect, inject, Input, signal} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {maskitoDateOptionsGenerator} from '@maskito/kit';\nimport {tuiAsControl} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport {DATE_FILLER_LENGTH, TuiDay, TuiMonth} from '@taiga-ui/cdk/date-time';\nimport {TuiNativeValidator} from '@taiga-ui/cdk/directives/native-validator';\nimport {tuiFallbackValueProvider} from '@taiga-ui/cdk/tokens';\nimport {TuiCalendar} from '@taiga-ui/core/components/calendar';\nimport {\n    tuiAsTextfieldAccessor,\n    tuiInjectAuxiliary,\n    TuiTextfieldBase,\n    tuiTextfieldIconBinding,\n} from '@taiga-ui/core/components/textfield';\nimport {TuiDropdownAuto} from '@taiga-ui/core/directives/dropdown';\nimport {TUI_DATE_FORMAT, TUI_DEFAULT_DATE_FORMAT} from '@taiga-ui/core/tokens';\nimport {TuiInputChipDirective} from '@taiga-ui/kit/components/input-chip';\nimport {\n    TUI_DATE_ADAPTER,\n    TUI_INPUT_DATE_OPTIONS_NEW,\n} from '@taiga-ui/kit/components/input-date';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputDateMulti]',\n    providers: [\n        tuiAsControl(TuiInputDateMultiDirective),\n        tuiFallbackValueProvider([]),\n        tuiAsTextfieldAccessor(TuiInputDateMultiDirective),\n    ],\n    hostDirectives: [\n        TuiNativeValidator,\n        TuiDropdownAuto,\n        MaskitoDirective,\n        {\n            directive: TuiTextfieldBase,\n            inputs: ['invalid', 'focused', 'readOnly', 'state'],\n        },\n    ],\n    host: {\n        '(keydown.enter.prevent)': '0',\n    },\n})\nexport class TuiInputDateMultiDirective extends TuiInputChipDirective<TuiDay> {\n    private readonly dateOptions = inject(TUI_INPUT_DATE_OPTIONS_NEW);\n\n    protected readonly icon = tuiTextfieldIconBinding(TUI_INPUT_DATE_OPTIONS_NEW);\n    protected readonly stringify = this.handlers.stringify.set((item) =>\n        item.toString(this.format().mode, this.format().separator),\n    );\n\n    protected readonly mask = tuiMaskito(\n        computed(() =>\n            maskitoDateOptionsGenerator({\n                separator: this.format().separator,\n                mode: TUI_DATE_ADAPTER[this.format().mode],\n                min: this.min().toLocalNativeDate(),\n                max: this.max().toLocalNativeDate(),\n            }),\n        ),\n    );\n\n    protected readonly format = toSignal(inject(TUI_DATE_FORMAT), {\n        initialValue: TUI_DEFAULT_DATE_FORMAT,\n    });\n\n    protected readonly calendarIn = effect(() => {\n        if (this.calendar()) {\n            this.processCalendar(this.calendar()!);\n        }\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly calendarOut = effect((onCleanup) => {\n        const subscription = this.calendar()?.dayClick.subscribe((day) => {\n            this.updateValue(day);\n        });\n\n        onCleanup(() => subscription?.unsubscribe());\n    });\n\n    public readonly min = signal(this.dateOptions.min);\n    public readonly max = signal(this.dateOptions.max);\n\n    public readonly calendar = tuiInjectAuxiliary<TuiCalendar>(\n        (x) => x instanceof TuiCalendar,\n    );\n\n    @Input('min')\n    public set minSetter(min: TuiDay | null) {\n        this.min.set(min || this.dateOptions.min);\n    }\n\n    @Input('max')\n    public set maxSetter(max: TuiDay | null) {\n        this.max.set(max || this.dateOptions.max);\n    }\n\n    protected clear(): void {\n        this.onChange([]);\n        this.open.set(this.interactive());\n    }\n\n    protected processCalendar(calendar: TuiCalendar): void {\n        calendar.value = this.value();\n        calendar.min = this.min();\n        calendar.max = this.max();\n        calendar.month =\n            this.value()?.[this.value().length - 1] ?? TuiMonth.currentLocal();\n    }\n\n    protected onClick(): void {\n        this.open.update((open) => !open);\n    }\n\n    protected onValueChange(value: string): void {\n        const newValue =\n            value.length === DATE_FILLER_LENGTH\n                ? TuiDay.normalizeParse(value, this.format().mode)\n                : null;\n\n        if (newValue && !this.handlers.disabledItemHandler()(newValue)) {\n            this.updateValue(newValue);\n        }\n    }\n\n    protected override onEnter(): void {\n        this.onValueChange(this.textfield.value().trim());\n        this.scrollTo();\n    }\n\n    private updateValue(day: TuiDay): void {\n        const exist = this.value().find((x) => x.daySame(day));\n        const newValue = exist\n            ? this.value().filter((x) => !x.daySame(day))\n            : this.value().concat(day);\n\n        this.setValue(newValue);\n    }\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TuiCalendar } from '@taiga-ui/core/components/calendar';
|
|
2
|
+
import { TuiInputChipComponent } from '@taiga-ui/kit/components/input-chip';
|
|
3
|
+
import { TuiInputDateMultiDirective } from './input-date-multi.directive';
|
|
4
|
+
export const TuiInputDateMulti = [
|
|
5
|
+
TuiInputDateMultiDirective,
|
|
6
|
+
TuiCalendar,
|
|
7
|
+
TuiInputChipComponent,
|
|
8
|
+
];
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS1tdWx0aS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2lucHV0LWRhdGUtbXVsdGkvaW5wdXQtZGF0ZS1tdWx0aS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDL0QsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFFMUUsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFFeEUsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUc7SUFDN0IsMEJBQTBCO0lBQzFCLFdBQVc7SUFDWCxxQkFBcUI7Q0FDZixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUdWlDYWxlbmRhcn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9jYWxlbmRhcic7XG5pbXBvcnQge1R1aUlucHV0Q2hpcENvbXBvbmVudH0gZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2lucHV0LWNoaXAnO1xuXG5pbXBvcnQge1R1aUlucHV0RGF0ZU11bHRpRGlyZWN0aXZlfSBmcm9tICcuL2lucHV0LWRhdGUtbXVsdGkuZGlyZWN0aXZlJztcblxuZXhwb3J0IGNvbnN0IFR1aUlucHV0RGF0ZU11bHRpID0gW1xuICAgIFR1aUlucHV0RGF0ZU11bHRpRGlyZWN0aXZlLFxuICAgIFR1aUNhbGVuZGFyLFxuICAgIFR1aUlucHV0Q2hpcENvbXBvbmVudCxcbl0gYXMgY29uc3Q7XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWkta2l0LWNvbXBvbmVudHMtaW5wdXQtZGF0ZS1tdWx0aS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2lucHV0LWRhdGUtbXVsdGkvdGFpZ2EtdWkta2l0LWNvbXBvbmVudHMtaW5wdXQtZGF0ZS1tdWx0aS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -3,11 +3,11 @@ import { MaskitoDirective } from '@maskito/angular';
|
|
|
3
3
|
import { maskitoDateRangeOptionsGenerator } from '@maskito/kit';
|
|
4
4
|
import { tuiAsControl, tuiValueTransformerFrom } from '@taiga-ui/cdk/classes';
|
|
5
5
|
import { DATE_RANGE_FILLER_LENGTH, RANGE_SEPARATOR_CHAR, TuiDayRange, } from '@taiga-ui/cdk/date-time';
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
6
|
+
import { tuiProvide } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
7
|
+
import { TuiWithTextfield } from '@taiga-ui/core/components/textfield';
|
|
8
8
|
import { TuiDropdownAuto } from '@taiga-ui/core/directives/dropdown';
|
|
9
9
|
import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives/items-handlers';
|
|
10
|
-
import { TUI_DATE_ADAPTER, TUI_INPUT_DATE_OPTIONS_NEW, TuiInputDateBase, } from '@taiga-ui/kit/components/input-date';
|
|
10
|
+
import { TUI_DATE_ADAPTER, TUI_INPUT_DATE_OPTIONS_NEW, TuiInputDateBase, tuiWithDateFiller, } from '@taiga-ui/kit/components/input-date';
|
|
11
11
|
import { tuiMaskito } from '@taiga-ui/kit/utils';
|
|
12
12
|
import { TUI_INPUT_DATE_RANGE_OPTIONS } from './input-date-range.options';
|
|
13
13
|
import * as i0 from "@angular/core";
|
|
@@ -18,7 +18,7 @@ class TuiInputDateRangeDirective extends TuiInputDateBase {
|
|
|
18
18
|
constructor() {
|
|
19
19
|
super(...arguments);
|
|
20
20
|
this.identity = inject(TUI_ITEMS_HANDLERS).identityMatcher.set((a, b) => a.daySame(b));
|
|
21
|
-
this.
|
|
21
|
+
this.filler = tuiWithDateFiller((filler) => `${filler}${RANGE_SEPARATOR_CHAR}${filler}`);
|
|
22
22
|
this.mask = tuiMaskito(computed(() => maskitoDateRangeOptionsGenerator({
|
|
23
23
|
dateSeparator: this.format().separator,
|
|
24
24
|
mode: TUI_DATE_ADAPTER[this.format().mode],
|
|
@@ -76,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
76
76
|
type: Input,
|
|
77
77
|
args: ['maxLength']
|
|
78
78
|
}] } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-range.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date-range/input-date-range.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {computed, Directive, inject, Input, signal} from '@angular/core';\nimport {MaskitoDirective} from '@maskito/angular';\nimport {maskitoDateRangeOptionsGenerator} from '@maskito/kit';\nimport {tuiAsControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport type {TuiDayLike} from '@taiga-ui/cdk/date-time';\nimport {\n    DATE_RANGE_FILLER_LENGTH,\n    RANGE_SEPARATOR_CHAR,\n    TuiDayRange,\n} from '@taiga-ui/cdk/date-time';\nimport {tuiProvide} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiWithTextfield} from '@taiga-ui/core/components/textfield';\nimport {TuiDropdownAuto} from '@taiga-ui/core/directives/dropdown';\nimport type {TuiItemsHandlers} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_ITEMS_HANDLERS} from '@taiga-ui/core/directives/items-handlers';\nimport type {TuiCalendarRange} from '@taiga-ui/kit/components/calendar-range';\nimport {\n    TUI_DATE_ADAPTER,\n    TUI_INPUT_DATE_OPTIONS_NEW,\n    TuiInputDateBase,\n    tuiWithDateFiller,\n} from '@taiga-ui/kit/components/input-date';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_DATE_RANGE_OPTIONS} from './input-date-range.options';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputDateRange]',\n    providers: [\n        // TODO: Add SelectOption after data-list in calendar-range is refactored\n        tuiAsControl(TuiInputDateRangeDirective),\n        tuiValueTransformerFrom(TUI_INPUT_DATE_RANGE_OPTIONS),\n        tuiProvide(TUI_INPUT_DATE_OPTIONS_NEW, TUI_INPUT_DATE_RANGE_OPTIONS),\n    ],\n    hostDirectives: [TuiWithTextfield, TuiDropdownAuto, MaskitoDirective],\n})\nexport class TuiInputDateRangeDirective extends TuiInputDateBase<TuiDayRange> {\n    protected readonly identity = inject<TuiItemsHandlers<TuiDayRange>>(\n        TUI_ITEMS_HANDLERS,\n    ).identityMatcher.set((a, b) => a.daySame(b));\n\n    protected override readonly filler = tuiWithDateFiller(\n        (filler) => `${filler}${RANGE_SEPARATOR_CHAR}${filler}`,\n    );\n\n    protected readonly mask = tuiMaskito(\n        computed(() =>\n            maskitoDateRangeOptionsGenerator({\n                dateSeparator: this.format().separator,\n                mode: TUI_DATE_ADAPTER[this.format().mode],\n                min: this.min().toLocalNativeDate(),\n                max: this.max().toLocalNativeDate(),\n                minLength: this.minLength() || {},\n                maxLength: this.maxLength() || {},\n            }),\n        ),\n    );\n\n    public readonly minLength = signal<TuiDayLike | null>(null);\n    public readonly maxLength = signal<TuiDayLike | null>(null);\n\n    @Input('minLength')\n    public set minLengthSetter(minLength: TuiDayLike | null) {\n        this.minLength.set(minLength);\n    }\n\n    @Input('maxLength')\n    public set maxLengthSetter(maxLength: TuiDayLike | null) {\n        this.maxLength.set(maxLength);\n    }\n\n    protected override processCalendar(calendar: TuiCalendarRange): void {\n        super.processCalendar(calendar);\n\n        calendar.minLength = this.minLength();\n        calendar.maxLength = this.maxLength();\n    }\n\n    protected override onValueChange(value: string): void {\n        this.control?.control?.updateValueAndValidity({emitEvent: false});\n        this.onChange(\n            value.length === DATE_RANGE_FILLER_LENGTH\n                ? TuiDayRange.normalizeParse(value, this.format().mode)\n                : null,\n        );\n    }\n}\n"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './input-date-time';
|
|
2
|
+
export * from './input-date-time.component';
|
|
3
|
+
export * from './input-date-time.directive';
|
|
4
|
+
export * from './input-date-time.options';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1kYXRlLXRpbWUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vaW5wdXQtZGF0ZS10aW1lJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtZGF0ZS10aW1lLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LWRhdGUtdGltZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1kYXRlLXRpbWUub3B0aW9ucyc7XG4iXX0=
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { NgIf } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, inject, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { TuiDay, TuiTime } from '@taiga-ui/cdk/date-time';
|
|
4
|
+
import { TuiTextfieldContent } from '@taiga-ui/core/components/textfield';
|
|
5
|
+
import { TuiNativeTimePicker } from '@taiga-ui/kit/components/input-time';
|
|
6
|
+
import { TuiInputDateTimeDirective } from './input-date-time.directive';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
class TuiInputDateTimeComponent extends TuiNativeTimePicker {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
this.host = inject(TuiInputDateTimeDirective);
|
|
12
|
+
this.step = computed(() => this.getStep(this.host.timeMode()));
|
|
13
|
+
this.value = computed(() => this.toISOString(this.host.value()));
|
|
14
|
+
this.min = computed(() => this.toISOString([this.host.min(), this.host.minTime()]));
|
|
15
|
+
this.max = computed(() => this.toISOString([this.host.max(), this.host.maxTime()]));
|
|
16
|
+
}
|
|
17
|
+
onInput(value) {
|
|
18
|
+
if (!value) {
|
|
19
|
+
return this.host.setValue(null);
|
|
20
|
+
}
|
|
21
|
+
const date = new Date(value);
|
|
22
|
+
const day = TuiDay.fromLocalNativeDate(date);
|
|
23
|
+
const time = TuiTime.fromLocalNativeDate(date);
|
|
24
|
+
this.host.setValue([day, time]);
|
|
25
|
+
}
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateTimeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
27
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputDateTimeComponent, isStandalone: true, selector: "input[tuiInputDateTime][type=\"datetime-local\"]", host: { attributes: { "ngSkipHydration": "true" } }, usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"host.native\">\n <input\n *tuiTextfieldContent\n type=\"datetime-local\"\n [attr.list]=\"list\"\n [max]=\"max()\"\n [min]=\"min()\"\n [step]=\"step()\"\n [value]=\"value()\"\n (click.stop.zoneless)=\"(0)\"\n (input)=\"onInput($any($event.target).value)\"\n (pointerdown.stop.zoneless)=\"(0)\"\n />\n</ng-container>\n", styles: ["tui-textfield input[tuiInputDateTime]~.t-content input[type=datetime-local]{position:absolute;top:0;left:auto;right:0;bottom:0;inline-size:2.5rem;padding:0;opacity:0}tui-textfield input[tuiInputDateTime]~.t-content input[type=datetime-local]::-webkit-calendar-picker-indicator{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TuiTextfieldContent, selector: "ng-template[tuiTextfieldContent]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
28
|
+
}
|
|
29
|
+
export { TuiInputDateTimeComponent };
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateTimeComponent, decorators: [{
|
|
31
|
+
type: Component,
|
|
32
|
+
args: [{ standalone: true, selector: 'input[tuiInputDateTime][type="datetime-local"]', imports: [NgIf, TuiTextfieldContent], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: { ngSkipHydration: 'true' }, template: "<ng-container *ngIf=\"host.native\">\n <input\n *tuiTextfieldContent\n type=\"datetime-local\"\n [attr.list]=\"list\"\n [max]=\"max()\"\n [min]=\"min()\"\n [step]=\"step()\"\n [value]=\"value()\"\n (click.stop.zoneless)=\"(0)\"\n (input)=\"onInput($any($event.target).value)\"\n (pointerdown.stop.zoneless)=\"(0)\"\n />\n</ng-container>\n", styles: ["tui-textfield input[tuiInputDateTime]~.t-content input[type=datetime-local]{position:absolute;top:0;left:auto;right:0;bottom:0;inline-size:2.5rem;padding:0;opacity:0}tui-textfield input[tuiInputDateTime]~.t-content input[type=datetime-local]::-webkit-calendar-picker-indicator{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}\n"] }]
|
|
33
|
+
}] });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS10aW1lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2lucHV0LWRhdGUtdGltZS9pbnB1dC1kYXRlLXRpbWUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvaW5wdXQtZGF0ZS10aW1lL2lucHV0LWRhdGUtdGltZS50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUNyQyxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxRQUFRLEVBQ1IsTUFBTSxFQUNOLGlCQUFpQixHQUNwQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsTUFBTSxFQUFFLE9BQU8sRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3hELE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQ3hFLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBRXhFLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLDZCQUE2QixDQUFDOztBQUV0RSxNQVVhLHlCQUEwQixTQUFRLG1CQUFtQjtJQVZsRTs7UUFXdUIsU0FBSSxHQUFHLE1BQU0sQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO1FBQ3pDLFNBQUksR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUMxRCxVQUFLLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFckUsUUFBRyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FDMUIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDLENBQzNELENBQUM7UUFFUSxRQUFHLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUMxQixJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FDM0QsQ0FBQztLQWFMO0lBWGEsT0FBTyxDQUFDLEtBQWE7UUFDM0IsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNSLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDbkM7UUFFRCxNQUFNLElBQUksR0FBRyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QixNQUFNLEdBQUcsR0FBRyxNQUFNLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDN0MsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDO1FBRS9DLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDcEMsQ0FBQzsrR0F2QlEseUJBQXlCO21HQUF6Qix5QkFBeUIsd0xDeEJ0QyxnYUFjQSxpWkRHYyxJQUFJLDZGQUFFLG1CQUFtQjs7U0FPMUIseUJBQXlCOzRGQUF6Qix5QkFBeUI7a0JBVnJDLFNBQVM7aUNBQ00sSUFBSSxZQUNOLGdEQUFnRCxXQUNqRCxDQUFDLElBQUksRUFBRSxtQkFBbUIsQ0FBQyxpQkFHckIsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSxRQUN6QyxFQUFDLGVBQWUsRUFBRSxNQUFNLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nSWZ9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENvbXBvbmVudCxcbiAgICBjb21wdXRlZCxcbiAgICBpbmplY3QsXG4gICAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlEYXksIFR1aVRpbWV9IGZyb20gJ0B0YWlnYS11aS9jZGsvZGF0ZS10aW1lJztcbmltcG9ydCB7VHVpVGV4dGZpZWxkQ29udGVudH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy90ZXh0ZmllbGQnO1xuaW1wb3J0IHtUdWlOYXRpdmVUaW1lUGlja2VyfSBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtdGltZSc7XG5cbmltcG9ydCB7VHVpSW5wdXREYXRlVGltZURpcmVjdGl2ZX0gZnJvbSAnLi9pbnB1dC1kYXRlLXRpbWUuZGlyZWN0aXZlJztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2lucHV0W3R1aUlucHV0RGF0ZVRpbWVdW3R5cGU9XCJkYXRldGltZS1sb2NhbFwiXScsXG4gICAgaW1wb3J0czogW05nSWYsIFR1aVRleHRmaWVsZENvbnRlbnRdLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9pbnB1dC1kYXRlLXRpbWUudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vaW5wdXQtZGF0ZS10aW1lLnN0eWxlLmxlc3MnXSxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGhvc3Q6IHtuZ1NraXBIeWRyYXRpb246ICd0cnVlJ30sXG59KVxuZXhwb3J0IGNsYXNzIFR1aUlucHV0RGF0ZVRpbWVDb21wb25lbnQgZXh0ZW5kcyBUdWlOYXRpdmVUaW1lUGlja2VyIHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaG9zdCA9IGluamVjdChUdWlJbnB1dERhdGVUaW1lRGlyZWN0aXZlKTtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgc3RlcCA9IGNvbXB1dGVkKCgpID0+IHRoaXMuZ2V0U3RlcCh0aGlzLmhvc3QudGltZU1vZGUoKSkpO1xuICAgIHByb3RlY3RlZCByZWFkb25seSB2YWx1ZSA9IGNvbXB1dGVkKCgpID0+IHRoaXMudG9JU09TdHJpbmcodGhpcy5ob3N0LnZhbHVlKCkpKTtcblxuICAgIHByb3RlY3RlZCBtaW4gPSBjb21wdXRlZCgoKSA9PlxuICAgICAgICB0aGlzLnRvSVNPU3RyaW5nKFt0aGlzLmhvc3QubWluKCksIHRoaXMuaG9zdC5taW5UaW1lKCldKSxcbiAgICApO1xuXG4gICAgcHJvdGVjdGVkIG1heCA9IGNvbXB1dGVkKCgpID0+XG4gICAgICAgIHRoaXMudG9JU09TdHJpbmcoW3RoaXMuaG9zdC5tYXgoKSwgdGhpcy5ob3N0Lm1heFRpbWUoKV0pLFxuICAgICk7XG5cbiAgICBwcm90ZWN0ZWQgb25JbnB1dCh2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgICAgIGlmICghdmFsdWUpIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmhvc3Quc2V0VmFsdWUobnVsbCk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBkYXRlID0gbmV3IERhdGUodmFsdWUpO1xuICAgICAgICBjb25zdCBkYXkgPSBUdWlEYXkuZnJvbUxvY2FsTmF0aXZlRGF0ZShkYXRlKTtcbiAgICAgICAgY29uc3QgdGltZSA9IFR1aVRpbWUuZnJvbUxvY2FsTmF0aXZlRGF0ZShkYXRlKTtcblxuICAgICAgICB0aGlzLmhvc3Quc2V0VmFsdWUoW2RheSwgdGltZV0pO1xuICAgIH1cbn1cbiIsIjxuZy1jb250YWluZXIgKm5nSWY9XCJob3N0Lm5hdGl2ZVwiPlxuICAgIDxpbnB1dFxuICAgICAgICAqdHVpVGV4dGZpZWxkQ29udGVudFxuICAgICAgICB0eXBlPVwiZGF0ZXRpbWUtbG9jYWxcIlxuICAgICAgICBbYXR0ci5saXN0XT1cImxpc3RcIlxuICAgICAgICBbbWF4XT1cIm1heCgpXCJcbiAgICAgICAgW21pbl09XCJtaW4oKVwiXG4gICAgICAgIFtzdGVwXT1cInN0ZXAoKVwiXG4gICAgICAgIFt2YWx1ZV09XCJ2YWx1ZSgpXCJcbiAgICAgICAgKGNsaWNrLnN0b3Auem9uZWxlc3MpPVwiKDApXCJcbiAgICAgICAgKGlucHV0KT1cIm9uSW5wdXQoJGFueSgkZXZlbnQudGFyZ2V0KS52YWx1ZSlcIlxuICAgICAgICAocG9pbnRlcmRvd24uc3RvcC56b25lbGVzcyk9XCIoMClcIlxuICAgIC8+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
import { computed, Directive, effect, inject, Input, signal } from '@angular/core';
|
|
2
|
+
import { toSignal } from '@angular/core/rxjs-interop';
|
|
3
|
+
import { MaskitoDirective } from '@maskito/angular';
|
|
4
|
+
import { maskitoDateTimeOptionsGenerator, maskitoSelectionChangeHandler, } from '@maskito/kit';
|
|
5
|
+
import { tuiAsControl, tuiValueTransformerFrom } from '@taiga-ui/cdk/classes';
|
|
6
|
+
import { DATE_FILLER_LENGTH, MILLISECONDS_IN_DAY, TuiDay, TuiTime, } from '@taiga-ui/cdk/date-time';
|
|
7
|
+
import { tuiClamp, tuiSum } from '@taiga-ui/cdk/utils/math';
|
|
8
|
+
import { tuiDirectiveBinding } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
9
|
+
import { tuiAsOptionContent } from '@taiga-ui/core/components/data-list';
|
|
10
|
+
import { tuiAsTextfieldAccessor, TuiWithTextfield, } from '@taiga-ui/core/components/textfield';
|
|
11
|
+
import { TuiDropdownAuto } from '@taiga-ui/core/directives/dropdown';
|
|
12
|
+
import { TuiItemsHandlersValidator } from '@taiga-ui/core/directives/items-handlers';
|
|
13
|
+
import { TUI_DATE_ADAPTER, TuiInputDateBase, tuiWithDateFiller, } from '@taiga-ui/kit/components/input-date';
|
|
14
|
+
import { TuiSelectOption } from '@taiga-ui/kit/components/select';
|
|
15
|
+
import { TUI_TIME_TEXTS } from '@taiga-ui/kit/tokens';
|
|
16
|
+
import { tuiMaskito } from '@taiga-ui/kit/utils';
|
|
17
|
+
import { noop } from 'rxjs';
|
|
18
|
+
import { TUI_INPUT_DATE_TIME_OPTIONS } from './input-date-time.options';
|
|
19
|
+
import * as i0 from "@angular/core";
|
|
20
|
+
import * as i1 from "@maskito/angular";
|
|
21
|
+
import * as i2 from "@taiga-ui/core/directives/dropdown";
|
|
22
|
+
import * as i3 from "@taiga-ui/core/directives/items-handlers";
|
|
23
|
+
import * as i4 from "@taiga-ui/core/components/textfield";
|
|
24
|
+
const MIN_TIME = new TuiTime(0, 0);
|
|
25
|
+
const MAX_TIME = TuiTime.fromAbsoluteMilliseconds(MILLISECONDS_IN_DAY - 1);
|
|
26
|
+
class TuiInputDateTimeDirective extends TuiInputDateBase {
|
|
27
|
+
constructor() {
|
|
28
|
+
super(...arguments);
|
|
29
|
+
this.timeFillers = toSignal(inject(TUI_TIME_TEXTS));
|
|
30
|
+
this.options = inject(TUI_INPUT_DATE_TIME_OPTIONS);
|
|
31
|
+
this.filler = tuiWithDateFiller((date) => {
|
|
32
|
+
const time = this.timeFillers()?.[this.timeMode()] ?? '';
|
|
33
|
+
return `${date}${this.options.dateTimeSeparator}${time}`;
|
|
34
|
+
});
|
|
35
|
+
this.valueEffect = effect(noop);
|
|
36
|
+
this.identity = this.handlers.identityMatcher.set((a, b) => tuiSum(...a.map(Number)) === tuiSum(...b.map(Number)));
|
|
37
|
+
this.disabledItemHandler = tuiDirectiveBinding(TuiItemsHandlersValidator, 'disabledItemHandler', (value) => Boolean(value && this.handlers.disabledItemHandler()(value)));
|
|
38
|
+
this.mask = tuiMaskito(computed(() => this.computeMask({
|
|
39
|
+
dateMode: TUI_DATE_ADAPTER[this.format().mode],
|
|
40
|
+
timeMode: this.timeMode(),
|
|
41
|
+
min: this.toNativeDate([this.min(), this.minTime()]),
|
|
42
|
+
max: this.toNativeDate([this.max(), this.maxTime()]),
|
|
43
|
+
dateSeparator: this.format().separator,
|
|
44
|
+
dateTimeSeparator: this.options.dateTimeSeparator,
|
|
45
|
+
})));
|
|
46
|
+
this.timeMode = signal(this.options.timeMode);
|
|
47
|
+
this.minTime = signal(MIN_TIME);
|
|
48
|
+
this.maxTime = signal(MAX_TIME);
|
|
49
|
+
}
|
|
50
|
+
// TODO(v5): use signal inputs
|
|
51
|
+
set timeModeSetter(x) {
|
|
52
|
+
this.timeMode.set(x);
|
|
53
|
+
}
|
|
54
|
+
set minSetter(min) {
|
|
55
|
+
const [date, time] = Array.isArray(min) ? min : [min, null];
|
|
56
|
+
this.min.set(date || this.options.min);
|
|
57
|
+
this.minTime.set(time ?? MIN_TIME);
|
|
58
|
+
}
|
|
59
|
+
set maxSetter(max) {
|
|
60
|
+
const [date, time] = Array.isArray(max) ? max : [max, null];
|
|
61
|
+
this.max.set(date || this.options.max);
|
|
62
|
+
this.maxTime.set(time ?? MAX_TIME);
|
|
63
|
+
}
|
|
64
|
+
setValue(value) {
|
|
65
|
+
this.onChange(value);
|
|
66
|
+
this.textfield.value.set(this.stringify(value));
|
|
67
|
+
}
|
|
68
|
+
setDate(newDate) {
|
|
69
|
+
const [date, time] = this.clampTime([newDate, this.value()?.[1] ?? null]);
|
|
70
|
+
this.setValue([date, time]);
|
|
71
|
+
this.open.set(false);
|
|
72
|
+
setTimeout((caretIndex = DATE_FILLER_LENGTH + this.options.dateTimeSeparator.length) => this.el.setSelectionRange(caretIndex, caretIndex));
|
|
73
|
+
}
|
|
74
|
+
writeValue(value) {
|
|
75
|
+
super.writeValue(value);
|
|
76
|
+
this.textfield.value.set(this.stringify(this.value()));
|
|
77
|
+
}
|
|
78
|
+
processCalendar(calendar) {
|
|
79
|
+
super.processCalendar(calendar);
|
|
80
|
+
calendar.disabledItemHandler = (day) => this.handlers.disabledItemHandler()([day, null]);
|
|
81
|
+
}
|
|
82
|
+
onValueChange(value) {
|
|
83
|
+
this.textfield.value.set(value);
|
|
84
|
+
this.control?.control?.updateValueAndValidity({ emitEvent: false });
|
|
85
|
+
const [date = '', time = ''] = value.split(this.options.dateTimeSeparator);
|
|
86
|
+
const parsedDate = date.length >= DATE_FILLER_LENGTH
|
|
87
|
+
? TuiDay.normalizeParse(date, this.format().mode)
|
|
88
|
+
: null;
|
|
89
|
+
const parsedTime = time.length === this.timeMode().length ? TuiTime.fromString(time) : null;
|
|
90
|
+
if (!parsedDate || (time && !parsedTime)) {
|
|
91
|
+
return this.onChange(null);
|
|
92
|
+
}
|
|
93
|
+
const [prevDate, prevTime = null] = this.value() ?? [];
|
|
94
|
+
if (!prevDate?.daySame(parsedDate) || Number(parsedTime) !== Number(prevTime)) {
|
|
95
|
+
this.onChange([parsedDate, parsedTime]);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
stringify(value) {
|
|
99
|
+
const [date, time] = value ?? [];
|
|
100
|
+
const dateString = date?.toString(this.format().mode, this.format().separator) ?? '';
|
|
101
|
+
const timeString = time?.toString(this.timeMode());
|
|
102
|
+
return timeString
|
|
103
|
+
? `${dateString}${this.options.dateTimeSeparator}${timeString}`
|
|
104
|
+
: dateString;
|
|
105
|
+
}
|
|
106
|
+
clampTime([date, time]) {
|
|
107
|
+
const min = date.daySame(this.min())
|
|
108
|
+
? this.minTime().toAbsoluteMilliseconds()
|
|
109
|
+
: -Infinity;
|
|
110
|
+
const max = date.daySame(this.max())
|
|
111
|
+
? this.maxTime().toAbsoluteMilliseconds()
|
|
112
|
+
: Infinity;
|
|
113
|
+
return [
|
|
114
|
+
date,
|
|
115
|
+
time &&
|
|
116
|
+
TuiTime.fromAbsoluteMilliseconds(tuiClamp(time.toAbsoluteMilliseconds(), min, max)),
|
|
117
|
+
];
|
|
118
|
+
}
|
|
119
|
+
computeMask(params) {
|
|
120
|
+
const options = maskitoDateTimeOptionsGenerator(params);
|
|
121
|
+
const { timeMode, dateMode, dateTimeSeparator } = params;
|
|
122
|
+
const inputModeSwitchPlugin = maskitoSelectionChangeHandler((element) => {
|
|
123
|
+
element.inputMode =
|
|
124
|
+
element.selectionStart >=
|
|
125
|
+
dateMode.length + dateTimeSeparator.length + timeMode.indexOf(' AA')
|
|
126
|
+
? 'text'
|
|
127
|
+
: 'numeric';
|
|
128
|
+
});
|
|
129
|
+
return {
|
|
130
|
+
...options,
|
|
131
|
+
plugins: options.plugins.concat(timeMode.includes('AA') ? inputModeSwitchPlugin : []),
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
toNativeDate([{ year, month, day }, { hours, minutes, seconds, ms }]) {
|
|
135
|
+
return new Date(year, month, day, hours, minutes, seconds, ms);
|
|
136
|
+
}
|
|
137
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateTimeDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
138
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputDateTimeDirective, isStandalone: true, selector: "input[tuiInputDateTime]", inputs: { timeModeSetter: ["timeMode", "timeModeSetter"], minSetter: ["min", "minSetter"], maxSetter: ["max", "maxSetter"] }, providers: [
|
|
139
|
+
tuiAsOptionContent(TuiSelectOption),
|
|
140
|
+
tuiAsControl(TuiInputDateTimeDirective),
|
|
141
|
+
tuiAsTextfieldAccessor(TuiInputDateTimeDirective),
|
|
142
|
+
tuiValueTransformerFrom(TUI_INPUT_DATE_TIME_OPTIONS),
|
|
143
|
+
], usesInheritance: true, hostDirectives: [{ directive: i1.MaskitoDirective }, { directive: i2.TuiDropdownAuto }, { directive: i3.TuiItemsHandlersValidator }, { directive: i4.TuiWithTextfield }], ngImport: i0 }); }
|
|
144
|
+
}
|
|
145
|
+
export { TuiInputDateTimeDirective };
|
|
146
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateTimeDirective, decorators: [{
|
|
147
|
+
type: Directive,
|
|
148
|
+
args: [{
|
|
149
|
+
standalone: true,
|
|
150
|
+
selector: 'input[tuiInputDateTime]',
|
|
151
|
+
providers: [
|
|
152
|
+
tuiAsOptionContent(TuiSelectOption),
|
|
153
|
+
tuiAsControl(TuiInputDateTimeDirective),
|
|
154
|
+
tuiAsTextfieldAccessor(TuiInputDateTimeDirective),
|
|
155
|
+
tuiValueTransformerFrom(TUI_INPUT_DATE_TIME_OPTIONS),
|
|
156
|
+
],
|
|
157
|
+
hostDirectives: [
|
|
158
|
+
MaskitoDirective,
|
|
159
|
+
TuiDropdownAuto,
|
|
160
|
+
TuiItemsHandlersValidator,
|
|
161
|
+
TuiWithTextfield,
|
|
162
|
+
],
|
|
163
|
+
}]
|
|
164
|
+
}], propDecorators: { timeModeSetter: [{
|
|
165
|
+
type: Input,
|
|
166
|
+
args: ['timeMode']
|
|
167
|
+
}], minSetter: [{
|
|
168
|
+
type: Input,
|
|
169
|
+
args: ['min']
|
|
170
|
+
}], maxSetter: [{
|
|
171
|
+
type: Input,
|
|
172
|
+
args: ['max']
|
|
173
|
+
}] } });
|
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date-time.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date-time/input-date-time.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {computed, Directive, effect, inject, Input, signal} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {MaskitoDirective} from '@maskito/angular';\nimport type {MaskitoOptions} from '@maskito/core';\nimport type {MaskitoDateTimeParams, MaskitoTimeMode} from '@maskito/kit';\nimport {\n    maskitoDateTimeOptionsGenerator,\n    maskitoSelectionChangeHandler,\n} from '@maskito/kit';\nimport {tuiAsControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {\n    DATE_FILLER_LENGTH,\n    MILLISECONDS_IN_DAY,\n    TuiDay,\n    TuiTime,\n} from '@taiga-ui/cdk/date-time';\nimport {tuiClamp, tuiSum} from '@taiga-ui/cdk/utils/math';\nimport {tuiDirectiveBinding} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiCalendar} from '@taiga-ui/core/components/calendar';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport type {TuiTextfieldAccessor} from '@taiga-ui/core/components/textfield';\nimport {\n    tuiAsTextfieldAccessor,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {TuiDropdownAuto} from '@taiga-ui/core/directives/dropdown';\nimport {TuiItemsHandlersValidator} from '@taiga-ui/core/directives/items-handlers';\nimport {\n    TUI_DATE_ADAPTER,\n    TuiInputDateBase,\n    tuiWithDateFiller,\n} from '@taiga-ui/kit/components/input-date';\nimport {TuiSelectOption} from '@taiga-ui/kit/components/select';\nimport {TUI_TIME_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\nimport {noop} from 'rxjs';\n\nimport {TUI_INPUT_DATE_TIME_OPTIONS} from './input-date-time.options';\n\nconst MIN_TIME = new TuiTime(0, 0);\nconst MAX_TIME = TuiTime.fromAbsoluteMilliseconds(MILLISECONDS_IN_DAY - 1);\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputDateTime]',\n    providers: [\n        tuiAsOptionContent(TuiSelectOption),\n        tuiAsControl(TuiInputDateTimeDirective),\n        tuiAsTextfieldAccessor(TuiInputDateTimeDirective),\n        tuiValueTransformerFrom(TUI_INPUT_DATE_TIME_OPTIONS),\n    ],\n    hostDirectives: [\n        MaskitoDirective,\n        TuiDropdownAuto,\n        TuiItemsHandlersValidator,\n        TuiWithTextfield,\n    ],\n})\nexport class TuiInputDateTimeDirective\n    extends TuiInputDateBase<readonly [TuiDay, TuiTime | null]>\n    implements TuiTextfieldAccessor<readonly [TuiDay, TuiTime | null]>\n{\n    private readonly timeFillers = toSignal(inject(TUI_TIME_TEXTS));\n\n    protected override readonly options = inject(TUI_INPUT_DATE_TIME_OPTIONS);\n\n    protected override readonly filler = tuiWithDateFiller((date) => {\n        const time = this.timeFillers()?.[this.timeMode()] ?? '';\n\n        return `${date}${this.options.dateTimeSeparator}${time}`;\n    });\n\n    protected override valueEffect = effect(noop);\n\n    protected readonly identity = this.handlers.identityMatcher.set(\n        (a, b) => tuiSum(...a.map(Number)) === tuiSum(...b.map(Number)),\n    );\n\n    protected readonly disabledItemHandler = tuiDirectiveBinding(\n        TuiItemsHandlersValidator,\n        'disabledItemHandler',\n        (value: readonly [TuiDay, TuiTime | null] | null) =>\n            Boolean(value && this.handlers.disabledItemHandler()(value)),\n    );\n\n    protected readonly mask = tuiMaskito(\n        computed(() =>\n            this.computeMask({\n                dateMode: TUI_DATE_ADAPTER[this.format().mode],\n                timeMode: this.timeMode(),\n                min: this.toNativeDate([this.min(), this.minTime()]),\n                max: this.toNativeDate([this.max(), this.maxTime()]),\n                dateSeparator: this.format().separator,\n                dateTimeSeparator: this.options.dateTimeSeparator,\n            }),\n        ),\n    );\n\n    public readonly timeMode = signal(this.options.timeMode);\n    public readonly minTime = signal(MIN_TIME);\n    public readonly maxTime = signal(MAX_TIME);\n\n    // TODO(v5): use signal inputs\n    @Input('timeMode')\n    public set timeModeSetter(x: MaskitoTimeMode) {\n        this.timeMode.set(x);\n    }\n\n    @Input('min')\n    public override set minSetter(\n        min: TuiDay | readonly [TuiDay, TuiTime | null] | null,\n    ) {\n        const [date, time] = Array.isArray(min) ? min : [min, null];\n\n        this.min.set(date || this.options.min);\n        this.minTime.set(time ?? MIN_TIME);\n    }\n\n    @Input('max')\n    public override set maxSetter(\n        max: TuiDay | readonly [TuiDay, TuiTime | null] | null,\n    ) {\n        const [date, time] = Array.isArray(max) ? max : [max, null];\n\n        this.max.set(date || this.options.max);\n        this.maxTime.set(time ?? MAX_TIME);\n    }\n\n    public setValue(value: readonly [TuiDay, TuiTime | null] | null): void {\n        this.onChange(value);\n        this.textfield.value.set(this.stringify(value));\n    }\n\n    public override setDate(newDate: TuiDay): void {\n        const [date, time] = this.clampTime([newDate, this.value()?.[1] ?? null]);\n\n        this.setValue([date, time]);\n        this.open.set(false);\n        setTimeout(\n            (caretIndex = DATE_FILLER_LENGTH + this.options.dateTimeSeparator.length) =>\n                this.el.setSelectionRange(caretIndex, caretIndex),\n        );\n    }\n\n    public override writeValue(value: [TuiDay, TuiTime | null] | null): void {\n        super.writeValue(value);\n        this.textfield.value.set(this.stringify(this.value()));\n    }\n\n    protected override processCalendar(calendar: TuiCalendar): void {\n        super.processCalendar(calendar);\n        calendar.disabledItemHandler = (day: TuiDay) =>\n            this.handlers.disabledItemHandler()([day, null]);\n    }\n\n    protected override onValueChange(value: string): void {\n        this.textfield.value.set(value);\n        this.control?.control?.updateValueAndValidity({emitEvent: false});\n\n        const [date = '', time = ''] = value.split(this.options.dateTimeSeparator);\n        const parsedDate =\n            date.length >= DATE_FILLER_LENGTH\n                ? TuiDay.normalizeParse(date, this.format().mode)\n                : null;\n        const parsedTime =\n            time.length === this.timeMode().length ? TuiTime.fromString(time) : null;\n\n        if (!parsedDate || (time && !parsedTime)) {\n            return this.onChange(null);\n        }\n\n        const [prevDate, prevTime = null] = this.value() ?? [];\n\n        if (!prevDate?.daySame(parsedDate) || Number(parsedTime) !== Number(prevTime)) {\n            this.onChange([parsedDate, parsedTime]);\n        }\n    }\n\n    protected override stringify(\n        value: readonly [TuiDay, TuiTime | null] | null,\n    ): string {\n        const [date, time] = value ?? [];\n\n        const dateString =\n            date?.toString(this.format().mode, this.format().separator) ?? '';\n        const timeString = time?.toString(this.timeMode());\n\n        return timeString\n            ? `${dateString}${this.options.dateTimeSeparator}${timeString}`\n            : dateString;\n    }\n\n    private clampTime([date, time]: [TuiDay, TuiTime | null]): [TuiDay, TuiTime | null] {\n        const min = date.daySame(this.min())\n            ? this.minTime().toAbsoluteMilliseconds()\n            : -Infinity;\n        const max = date.daySame(this.max())\n            ? this.maxTime().toAbsoluteMilliseconds()\n            : Infinity;\n\n        return [\n            date,\n            time &&\n                TuiTime.fromAbsoluteMilliseconds(\n                    tuiClamp(time.toAbsoluteMilliseconds(), min, max),\n                ),\n        ];\n    }\n\n    private computeMask(\n        params: Omit<Required<MaskitoDateTimeParams>, 'timeStep'>,\n    ): MaskitoOptions {\n        const options = maskitoDateTimeOptionsGenerator(params);\n        const {timeMode, dateMode, dateTimeSeparator} = params;\n        const inputModeSwitchPlugin = maskitoSelectionChangeHandler((element) => {\n            element.inputMode =\n                element.selectionStart! >=\n                dateMode.length + dateTimeSeparator.length + timeMode.indexOf(' AA')\n                    ? 'text'\n                    : 'numeric';\n        });\n\n        return {\n            ...options,\n            plugins: options.plugins.concat(\n                timeMode.includes('AA') ? inputModeSwitchPlugin : [],\n            ),\n        };\n    }\n\n    private toNativeDate([{year, month, day}, {hours, minutes, seconds, ms}]: readonly [\n        TuiDay,\n        TuiTime,\n    ]): Date {\n        return new Date(year, month, day, hours, minutes, seconds, ms);\n    }\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { TuiCalendar } from '@taiga-ui/core/components/calendar';
|
|
2
|
+
import { TuiInputDateTimeComponent } from './input-date-time.component';
|
|
3
|
+
import { TuiInputDateTimeDirective } from './input-date-time.directive';
|
|
4
|
+
export const TuiInputDateTime = [
|
|
5
|
+
TuiInputDateTimeDirective,
|
|
6
|
+
TuiInputDateTimeComponent,
|
|
7
|
+
TuiCalendar,
|
|
8
|
+
];
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS10aW1lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvaW5wdXQtZGF0ZS10aW1lL2lucHV0LWRhdGUtdGltZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFFL0QsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDdEUsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFFdEUsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUc7SUFDNUIseUJBQXlCO0lBQ3pCLHlCQUF5QjtJQUN6QixXQUFXO0NBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7VHVpQ2FsZW5kYXJ9IGZyb20gJ0B0YWlnYS11aS9jb3JlL2NvbXBvbmVudHMvY2FsZW5kYXInO1xuXG5pbXBvcnQge1R1aUlucHV0RGF0ZVRpbWVDb21wb25lbnR9IGZyb20gJy4vaW5wdXQtZGF0ZS10aW1lLmNvbXBvbmVudCc7XG5pbXBvcnQge1R1aUlucHV0RGF0ZVRpbWVEaXJlY3RpdmV9IGZyb20gJy4vaW5wdXQtZGF0ZS10aW1lLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCBjb25zdCBUdWlJbnB1dERhdGVUaW1lID0gW1xuICAgIFR1aUlucHV0RGF0ZVRpbWVEaXJlY3RpdmUsXG4gICAgVHVpSW5wdXREYXRlVGltZUNvbXBvbmVudCxcbiAgICBUdWlDYWxlbmRhcixcbl0gYXMgY29uc3Q7XG4iXX0=
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { inject, InjectionToken } from '@angular/core';
|
|
2
|
+
import { TUI_IDENTITY_VALUE_TRANSFORMER } from '@taiga-ui/cdk/classes';
|
|
3
|
+
import { tuiProvideOptions } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
4
|
+
import { TUI_INPUT_DATE_DEFAULT_OPTIONS_NEW, TUI_INPUT_DATE_OPTIONS_NEW, } from '@taiga-ui/kit/components/input-date';
|
|
5
|
+
export const TUI_INPUT_DATE_TIME_DEFAULT_OPTIONS = {
|
|
6
|
+
valueTransformer: TUI_IDENTITY_VALUE_TRANSFORMER,
|
|
7
|
+
timeMode: 'HH:MM',
|
|
8
|
+
dateTimeSeparator: ', ',
|
|
9
|
+
};
|
|
10
|
+
export const TUI_INPUT_DATE_TIME_OPTIONS = new InjectionToken(ngDevMode ? 'TUI_INPUT_DATE_TIME_OPTIONS' : '', {
|
|
11
|
+
factory: () => ({
|
|
12
|
+
...inject(TUI_INPUT_DATE_OPTIONS_NEW),
|
|
13
|
+
...TUI_INPUT_DATE_TIME_DEFAULT_OPTIONS,
|
|
14
|
+
}),
|
|
15
|
+
});
|
|
16
|
+
export const tuiInputDateTimeOptionsProvider = (options) => tuiProvideOptions(TUI_INPUT_DATE_TIME_OPTIONS, options, {
|
|
17
|
+
...TUI_INPUT_DATE_DEFAULT_OPTIONS_NEW,
|
|
18
|
+
...TUI_INPUT_DATE_TIME_DEFAULT_OPTIONS,
|
|
19
|
+
});
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS10aW1lLm9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1kYXRlLXRpbWUvaW5wdXQtZGF0ZS10aW1lLm9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFDLE1BQU0sRUFBRSxjQUFjLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFHckQsT0FBTyxFQUFDLDhCQUE4QixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFFckUsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFFcEUsT0FBTyxFQUNILGtDQUFrQyxFQUNsQywwQkFBMEIsR0FDN0IsTUFBTSxxQ0FBcUMsQ0FBQztBQVM3QyxNQUFNLENBQUMsTUFBTSxtQ0FBbUMsR0FBRztJQUMvQyxnQkFBZ0IsRUFBRSw4QkFBOEI7SUFDaEQsUUFBUSxFQUFFLE9BQU87SUFDakIsaUJBQWlCLEVBQUUsSUFBSTtDQUNqQixDQUFDO0FBRVgsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsSUFBSSxjQUFjLENBQ3pELFNBQVMsQ0FBQyxDQUFDLENBQUMsNkJBQTZCLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFDOUM7SUFDSSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQztRQUNaLEdBQUcsTUFBTSxDQUFDLDBCQUEwQixDQUFDO1FBQ3JDLEdBQUcsbUNBQW1DO0tBQ3pDLENBQUM7Q0FDTCxDQUNKLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSwrQkFBK0IsR0FBRyxDQUMzQyxPQUF5QyxFQUMxQixFQUFFLENBQ2pCLGlCQUFpQixDQUFDLDJCQUEyQixFQUFFLE9BQU8sRUFBRTtJQUNwRCxHQUFHLGtDQUFrQztJQUNyQyxHQUFHLG1DQUFtQztDQUN6QyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7RmFjdG9yeVByb3ZpZGVyfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7aW5qZWN0LCBJbmplY3Rpb25Ub2tlbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7TWFza2l0b1RpbWVNb2RlfSBmcm9tICdAbWFza2l0by9raXQnO1xuaW1wb3J0IHR5cGUge1R1aVZhbHVlVHJhbnNmb3JtZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsvY2xhc3Nlcyc7XG5pbXBvcnQge1RVSV9JREVOVElUWV9WQUxVRV9UUkFOU0ZPUk1FUn0gZnJvbSAnQHRhaWdhLXVpL2Nkay9jbGFzc2VzJztcbmltcG9ydCB0eXBlIHtUdWlEYXksIFR1aVRpbWV9IGZyb20gJ0B0YWlnYS11aS9jZGsvZGF0ZS10aW1lJztcbmltcG9ydCB7dHVpUHJvdmlkZU9wdGlvbnN9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5pbXBvcnQgdHlwZSB7VHVpSW5wdXREYXRlT3B0aW9uc05ld30gZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2lucHV0LWRhdGUnO1xuaW1wb3J0IHtcbiAgICBUVUlfSU5QVVRfREFURV9ERUZBVUxUX09QVElPTlNfTkVXLFxuICAgIFRVSV9JTlBVVF9EQVRFX09QVElPTlNfTkVXLFxufSBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtZGF0ZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHVpSW5wdXREYXRlVGltZU9wdGlvbnNcbiAgICBleHRlbmRzIE9taXQ8VHVpSW5wdXREYXRlT3B0aW9uc05ldywgJ3ZhbHVlVHJhbnNmb3JtZXInPiB7XG4gICAgcmVhZG9ubHkgdGltZU1vZGU6IE1hc2tpdG9UaW1lTW9kZTtcbiAgICByZWFkb25seSBkYXRlVGltZVNlcGFyYXRvcjogc3RyaW5nO1xuICAgIHJlYWRvbmx5IHZhbHVlVHJhbnNmb3JtZXI6IFR1aVZhbHVlVHJhbnNmb3JtZXI8W1R1aURheSwgVHVpVGltZSB8IG51bGxdIHwgbnVsbCwgYW55Pjtcbn1cblxuZXhwb3J0IGNvbnN0IFRVSV9JTlBVVF9EQVRFX1RJTUVfREVGQVVMVF9PUFRJT05TID0ge1xuICAgIHZhbHVlVHJhbnNmb3JtZXI6IFRVSV9JREVOVElUWV9WQUxVRV9UUkFOU0ZPUk1FUixcbiAgICB0aW1lTW9kZTogJ0hIOk1NJyxcbiAgICBkYXRlVGltZVNlcGFyYXRvcjogJywgJyxcbn0gYXMgY29uc3Q7XG5cbmV4cG9ydCBjb25zdCBUVUlfSU5QVVRfREFURV9USU1FX09QVElPTlMgPSBuZXcgSW5qZWN0aW9uVG9rZW48VHVpSW5wdXREYXRlVGltZU9wdGlvbnM+KFxuICAgIG5nRGV2TW9kZSA/ICdUVUlfSU5QVVRfREFURV9USU1FX09QVElPTlMnIDogJycsXG4gICAge1xuICAgICAgICBmYWN0b3J5OiAoKSA9PiAoe1xuICAgICAgICAgICAgLi4uaW5qZWN0KFRVSV9JTlBVVF9EQVRFX09QVElPTlNfTkVXKSxcbiAgICAgICAgICAgIC4uLlRVSV9JTlBVVF9EQVRFX1RJTUVfREVGQVVMVF9PUFRJT05TLFxuICAgICAgICB9KSxcbiAgICB9LFxuKTtcblxuZXhwb3J0IGNvbnN0IHR1aUlucHV0RGF0ZVRpbWVPcHRpb25zUHJvdmlkZXIgPSAoXG4gICAgb3B0aW9uczogUGFydGlhbDxUdWlJbnB1dERhdGVUaW1lT3B0aW9ucz4sXG4pOiBGYWN0b3J5UHJvdmlkZXIgPT5cbiAgICB0dWlQcm92aWRlT3B0aW9ucyhUVUlfSU5QVVRfREFURV9USU1FX09QVElPTlMsIG9wdGlvbnMsIHtcbiAgICAgICAgLi4uVFVJX0lOUFVUX0RBVEVfREVGQVVMVF9PUFRJT05TX05FVyxcbiAgICAgICAgLi4uVFVJX0lOUFVUX0RBVEVfVElNRV9ERUZBVUxUX09QVElPTlMsXG4gICAgfSk7XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWkta2l0LWNvbXBvbmVudHMtaW5wdXQtZGF0ZS10aW1lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvaW5wdXQtZGF0ZS10aW1lL3RhaWdhLXVpLWtpdC1jb21wb25lbnRzLWlucHV0LWRhdGUtdGltZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|