@taiga-ui/kit 4.39.2 → 4.40.0-canary.cdfddf4
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/calendar-range/calendar-range.component.d.ts +4 -1
- package/components/combo-box/combo-box.directive.d.ts +13 -9
- package/components/data-list-wrapper/data-list-wrapper.component.d.ts +4 -1
- package/components/files/file/file.component.d.ts +1 -0
- package/components/files/file/file.options.d.ts +1 -1
- package/components/files/files.utils.d.ts +1 -1
- package/components/index.d.ts +1 -0
- package/components/input-date/index.d.ts +0 -1
- package/components/input-date/input-date.d.ts +1 -2
- package/components/input-date/input-date.directive.d.ts +14 -3
- package/components/input-date-range/index.d.ts +3 -0
- package/components/input-date-range/input-date-range.d.ts +3 -0
- package/components/input-date-range/input-date-range.directive.d.ts +20 -0
- package/components/input-date-range/input-date-range.options.d.ts +9 -0
- package/components/input-phone-international/input-phone-international.component.d.ts +1 -0
- package/esm2022/components/calendar-range/calendar-range.component.mjs +44 -27
- package/esm2022/components/combo-box/combo-box.directive.mjs +60 -37
- package/esm2022/components/data-list-wrapper/data-list-wrapper.component.mjs +16 -4
- package/esm2022/components/files/file/file.component.mjs +4 -3
- package/esm2022/components/files/file/file.options.mjs +1 -1
- package/esm2022/components/files/files.utils.mjs +3 -3
- package/esm2022/components/index.mjs +2 -1
- package/esm2022/components/input-date/index.mjs +1 -2
- package/esm2022/components/input-date/input-date.directive.mjs +49 -37
- package/esm2022/components/input-date/input-date.mjs +1 -3
- package/esm2022/components/input-date-range/index.mjs +4 -0
- package/esm2022/components/input-date-range/input-date-range.directive.mjs +75 -0
- package/esm2022/components/input-date-range/input-date-range.mjs +4 -0
- package/esm2022/components/input-date-range/input-date-range.options.mjs +10 -0
- package/esm2022/components/input-date-range/taiga-ui-kit-components-input-date-range.mjs +5 -0
- package/esm2022/components/input-month/input-month.directive.mjs +2 -3
- package/esm2022/components/input-month-range/input-month-range.directive.mjs +2 -3
- package/esm2022/components/input-number/input-number.directive.mjs +2 -4
- package/esm2022/components/input-phone-international/input-phone-international.component.mjs +2 -1
- package/esm2022/components/input-pin/input-pin.component.mjs +3 -3
- package/esm2022/components/input-slider/input-slider.directive.mjs +3 -2
- package/esm2022/components/segmented/segmented.component.mjs +2 -2
- package/esm2022/components/select/select.directive.mjs +2 -3
- package/fesm2022/taiga-ui-kit-components-calendar-range.mjs +43 -26
- package/fesm2022/taiga-ui-kit-components-calendar-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-combo-box.mjs +61 -38
- package/fesm2022/taiga-ui-kit-components-combo-box.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-data-list-wrapper.mjs +15 -3
- package/fesm2022/taiga-ui-kit-components-data-list-wrapper.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-files.mjs +5 -4
- package/fesm2022/taiga-ui-kit-components-files.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-date-range.mjs +89 -0
- package/fesm2022/taiga-ui-kit-components-input-date-range.mjs.map +1 -0
- package/fesm2022/taiga-ui-kit-components-input-date.mjs +50 -63
- package/fesm2022/taiga-ui-kit-components-input-date.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-month-range.mjs +1 -2
- package/fesm2022/taiga-ui-kit-components-input-month-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-month.mjs +1 -2
- package/fesm2022/taiga-ui-kit-components-input-month.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-number.mjs +1 -3
- package/fesm2022/taiga-ui-kit-components-input-number.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-phone-international.mjs +1 -0
- package/fesm2022/taiga-ui-kit-components-input-phone-international.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-pin.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-input-pin.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-slider.mjs +2 -1
- package/fesm2022/taiga-ui-kit-components-input-slider.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-segmented.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-segmented.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-select.mjs +1 -2
- package/fesm2022/taiga-ui-kit-components-select.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components.mjs +1 -0
- package/fesm2022/taiga-ui-kit-components.mjs.map +1 -1
- package/package.json +26 -20
- package/components/input-date/input-date.validator.d.ts +0 -10
- package/esm2022/components/input-date/input-date.validator.mjs +0 -31
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import { Directive, effect, inject, Input, untracked } from '@angular/core';
|
|
1
|
+
import { computed, Directive, effect, inject, Input, isSignal, signal, untracked, } from '@angular/core';
|
|
2
2
|
import { tuiAsControl, TuiControl } from '@taiga-ui/cdk/classes';
|
|
3
3
|
import { TUI_ALLOW_SIGNAL_WRITES, TUI_STRICT_MATCHER } from '@taiga-ui/cdk/constants';
|
|
4
4
|
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
5
|
-
import { tuiIsString } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
6
5
|
import { tuiAsOptionContent } from '@taiga-ui/core/components/data-list';
|
|
7
6
|
import { tuiAsTextfieldAccessor, tuiInjectAuxiliary, TuiTextfieldComponent, TuiTextfieldDirective, TuiWithTextfield, } from '@taiga-ui/core/components/textfield';
|
|
8
7
|
import { TuiDropdownDirective, tuiDropdownEnabled, tuiDropdownOpen, } from '@taiga-ui/core/directives/dropdown';
|
|
@@ -18,46 +17,71 @@ class TuiComboBox extends TuiControl {
|
|
|
18
17
|
this.host = inject(TuiTextfieldComponent);
|
|
19
18
|
this.textfield = inject(TuiTextfieldDirective);
|
|
20
19
|
this.open = tuiDropdownOpen();
|
|
20
|
+
this.dropdownEnabled = tuiDropdownEnabled(this.interactive);
|
|
21
21
|
this.dropdown = inject(TuiDropdownDirective);
|
|
22
22
|
this.itemsHandlers = inject(TUI_ITEMS_HANDLERS);
|
|
23
|
-
this.
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
23
|
+
this.matcher = signal(TUI_STRICT_MATCHER);
|
|
24
|
+
this.strict = signal(true);
|
|
25
|
+
this.datalist = tuiInjectAuxiliary((x) => x !== this && 'options' in x && isSignal(x.options));
|
|
26
|
+
this.options = computed(() => this.datalist()
|
|
27
|
+
?.options?.() // TODO(v5): remove optional call `?.()`
|
|
28
|
+
.filter((x) => !this.itemsHandlers.disabledItemHandler()(x)) ?? []);
|
|
29
|
+
this.nonStrictValueEffect = effect(() => {
|
|
30
|
+
if (!this.options().length && !this.strict()) {
|
|
31
|
+
this.onChange(this.textfield.value() || null);
|
|
32
|
+
}
|
|
33
|
+
}, TUI_ALLOW_SIGNAL_WRITES);
|
|
34
|
+
this.matchingEffect = effect(() => {
|
|
35
|
+
const options = this.options();
|
|
36
|
+
const matcher = this.matcher();
|
|
37
|
+
if (!options.length || !matcher) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
const textfieldValue = this.textfield.value();
|
|
41
|
+
const selectedOption = options.find((x) => matcher(x, textfieldValue, this.itemsHandlers.stringify())) ?? null;
|
|
42
|
+
const stringified = this.stringify(selectedOption);
|
|
43
|
+
const fallback = this.strict() || !textfieldValue ? null : textfieldValue;
|
|
44
|
+
this.onChange(selectedOption ?? fallback);
|
|
45
|
+
if (stringified && stringified !== textfieldValue) {
|
|
46
|
+
this.textfield.value.set(stringified);
|
|
34
47
|
}
|
|
35
48
|
}, TUI_ALLOW_SIGNAL_WRITES);
|
|
36
49
|
this.blurEffect = effect(() => {
|
|
37
|
-
const
|
|
38
|
-
if (!this.host.focused() &&
|
|
50
|
+
const incomplete = untracked(() => this.strict() && !this.value());
|
|
51
|
+
if (!this.host.focused() && incomplete) {
|
|
39
52
|
this.textfield.value.set('');
|
|
40
53
|
}
|
|
41
54
|
}, TUI_ALLOW_SIGNAL_WRITES);
|
|
42
|
-
|
|
43
|
-
|
|
55
|
+
}
|
|
56
|
+
// TODO(v5): use signal input
|
|
57
|
+
set strictSetter(x) {
|
|
58
|
+
this.strict.set(x);
|
|
59
|
+
}
|
|
60
|
+
// TODO(v5): use signal input
|
|
61
|
+
set matcherSetter(x) {
|
|
62
|
+
this.matcher.set(x);
|
|
44
63
|
}
|
|
45
64
|
setValue(value) {
|
|
65
|
+
const stringified = this.stringify(value);
|
|
66
|
+
if (stringified !== this.textfield.value()) {
|
|
67
|
+
this.textfield.value.set(stringified);
|
|
68
|
+
setTimeout((end = stringified.length) => this.el.setSelectionRange(end, end));
|
|
69
|
+
}
|
|
46
70
|
this.onChange(value);
|
|
47
71
|
if (!value) {
|
|
48
72
|
this.toggleDropdown(true);
|
|
49
|
-
this.textfield.value.set('');
|
|
50
73
|
}
|
|
51
74
|
}
|
|
75
|
+
writeValue(value) {
|
|
76
|
+
super.writeValue(value);
|
|
77
|
+
this.textfield.value.set(this.stringify(value));
|
|
78
|
+
}
|
|
52
79
|
toggleDropdown(open = !this.open()) {
|
|
53
80
|
if (this.dropdownEnabled() && this.dropdown.content) {
|
|
54
81
|
this.open.set(open);
|
|
55
82
|
}
|
|
56
83
|
}
|
|
57
|
-
onInput(
|
|
58
|
-
const match = this.match(value);
|
|
59
|
-
const fallback = this.strict || !value ? null : value;
|
|
60
|
-
this.onChange(match ?? fallback);
|
|
84
|
+
onInput() {
|
|
61
85
|
setTimeout(() => this.toggleDropdown(true));
|
|
62
86
|
}
|
|
63
87
|
keydownEnter(event) {
|
|
@@ -65,19 +89,17 @@ class TuiComboBox extends TuiControl {
|
|
|
65
89
|
return;
|
|
66
90
|
}
|
|
67
91
|
event.preventDefault();
|
|
68
|
-
|
|
69
|
-
|
|
92
|
+
const options = this.options();
|
|
93
|
+
if (options.length === 1 && options[0]) {
|
|
94
|
+
this.setValue(options[0]);
|
|
70
95
|
this.toggleDropdown(false);
|
|
71
96
|
}
|
|
72
97
|
}
|
|
73
|
-
|
|
74
|
-
return this.
|
|
75
|
-
}
|
|
76
|
-
match(value) {
|
|
77
|
-
return (this.options.find((item) => this.matcher?.(item, value, this.itemsHandlers.stringify())) ?? null);
|
|
98
|
+
stringify(value) {
|
|
99
|
+
return value ? this.itemsHandlers.stringify()(value) : '';
|
|
78
100
|
}
|
|
79
101
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiComboBox, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
80
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiComboBox, isStandalone: true, selector: "input[tuiComboBox]", inputs: {
|
|
102
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiComboBox, isStandalone: true, selector: "input[tuiComboBox]", inputs: { strictSetter: ["strict", "strictSetter"], matcherSetter: ["matcher", "matcherSetter"] }, host: { listeners: { "click": "toggleDropdown()", "input": "onInput()", "keydown.enter": "keydownEnter($event)" }, properties: { "disabled": "disabled()" } }, providers: [
|
|
81
103
|
tuiAsOptionContent(TuiSelectOption),
|
|
82
104
|
tuiAsTextfieldAccessor(TuiComboBox),
|
|
83
105
|
tuiAsControl(TuiComboBox),
|
|
@@ -99,15 +121,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
99
121
|
hostDirectives: [TuiWithTextfield],
|
|
100
122
|
host: {
|
|
101
123
|
'[disabled]': 'disabled()',
|
|
102
|
-
'(blur)': 'onTouched()',
|
|
103
124
|
'(click)': 'toggleDropdown()',
|
|
104
|
-
'(input)': 'onInput(
|
|
125
|
+
'(input)': 'onInput()',
|
|
105
126
|
'(keydown.enter)': 'keydownEnter($event)',
|
|
106
127
|
},
|
|
107
128
|
}]
|
|
108
|
-
}], propDecorators: {
|
|
109
|
-
type: Input
|
|
110
|
-
|
|
111
|
-
|
|
129
|
+
}], propDecorators: { strictSetter: [{
|
|
130
|
+
type: Input,
|
|
131
|
+
args: ['strict']
|
|
132
|
+
}], matcherSetter: [{
|
|
133
|
+
type: Input,
|
|
134
|
+
args: ['matcher']
|
|
112
135
|
}] } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combo-box.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/combo-box/combo-box.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAC,YAAY,EAAE,UAAU,EAAC,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAC,uBAAuB,EAAE,kBAAkB,EAAC,MAAM,yBAAyB,CAAC;AAEpF,OAAO,EAAC,gBAAgB,EAAC,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAC,WAAW,EAAC,MAAM,mCAAmC,CAAC;AAE9D,OAAO,EAAC,kBAAkB,EAAC,MAAM,qCAAqC,CAAC;AAEvE,OAAO,EACH,sBAAsB,EACtB,kBAAkB,EAClB,qBAAqB,EACrB,qBAAqB,EACrB,gBAAgB,GACnB,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EACH,oBAAoB,EACpB,kBAAkB,EAClB,eAAe,GAClB,MAAM,oCAAoC,CAAC;AAE5C,OAAO,EAAC,kBAAkB,EAAC,MAAM,0CAA0C,CAAC;AAC5E,OAAO,EAAC,cAAc,EAAC,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAC,eAAe,EAAC,MAAM,iCAAiC,CAAC;;;AAEhE,MAkBa,WACT,SAAQ,UAA6B;IAnBzC;;QAsBqB,OAAE,GAAG,gBAAgB,EAAoB,CAAC;QAC1C,SAAI,GAA6B,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAC/D,cAAS,GAA6B,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAEpE,SAAI,GAAG,eAAe,EAAE,CAAC;QACzB,aAAQ,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QACxC,kBAAa,GAAwB,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAChE,aAAQ,GAAG,kBAAkB,CAC1C,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,IAAI,CAAC,CAC3B,CAAC;QAEiB,oBAAe,GAAG,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAEvD,gBAAW,GAAG,MAAM,CAAC,GAAG,EAAE;YACzC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC;YACjC,MAAM,WAAW,GAAG,WAAW,CAAC,KAAK,CAAC;gBAClC,CAAC,CAAC,KAAK;gBACP,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,CAAC;YAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;YAEtC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,IAAI,CAAC,CAAC,CAAC;YAErD,IAAI,KAAK,EAAE;gBACP,UAAU,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,CACtC,IAAI,CAAC,EAAE,CAAC,iBAAiB,CAAC,GAAG,EAAE,GAAG,CAAC,CACtC,CAAC;aACL;QACL,CAAC,EAAE,uBAAuB,CAAC,CAAC;QAET,eAAU,GAAG,MAAM,CAAC,GAAG,EAAE;YACxC,MAAM,KAAK,GAAG,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;YAE5C,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,KAAK,EAAE;gBAC/C,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;aAChC;QACL,CAAC,EAAE,uBAAuB,CAAC,CAAC;QAGrB,WAAM,GAAG,IAAI,CAAC;QAGd,YAAO,GAA+B,kBAAkB,CAAC;KAiDnE;IA/CU,QAAQ,CAAC,KAAQ;QACpB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAErB,IAAI,CAAC,KAAK,EAAE;YACR,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAC1B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;SAChC;IACL,CAAC;IAES,cAAc,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE;QACxC,IAAI,IAAI,CAAC,eAAe,EAAE,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE;YACjD,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;SACvB;IACL,CAAC;IAES,OAAO,CAAC,KAAa;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAChC,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QAEtD,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,CAAC;QACjC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC;IAChD,CAAC;IAES,YAAY,CAAC,KAAoB;QACvC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE;YACd,OAAO;SACV;QAED,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;YAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAE,CAAC,CAAC;YAChC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;SAC9B;IACL,CAAC;IAED,IAAY,OAAO;QACf,OAAO,IAAI,CAAC,QAAQ,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;IAC/C,CAAC;IAEO,KAAK,CAAC,KAAa;QACvB,OAAO,CACH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CACvB,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC,CAC9D,IAAI,IAAI,CACZ,CAAC;IACN,CAAC;+GA7FQ,WAAW;mGAAX,WAAW,4TAfT;YACP,kBAAkB,CAAC,eAAe,CAAC;YACnC,sBAAsB,CAAC,WAAW,CAAC;YACnC,YAAY,CAAC,WAAW,CAAC;YACzB,cAAc,CAAC,WAAW,CAAC;SAC9B;;SAUQ,WAAW;4FAAX,WAAW;kBAlBvB,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,oBAAoB;oBAC9B,SAAS,EAAE;wBACP,kBAAkB,CAAC,eAAe,CAAC;wBACnC,sBAAsB,aAAa;wBACnC,YAAY,aAAa;wBACzB,cAAc,aAAa;qBAC9B;oBACD,cAAc,EAAE,CAAC,gBAAgB,CAAC;oBAClC,IAAI,EAAE;wBACF,YAAY,EAAE,YAAY;wBAC1B,QAAQ,EAAE,aAAa;wBACvB,SAAS,EAAE,kBAAkB;wBAC7B,SAAS,EAAE,8BAA8B;wBACzC,iBAAiB,EAAE,sBAAsB;qBAC5C;iBACJ;8BA2CU,MAAM;sBADZ,KAAK;gBAIC,OAAO;sBADb,KAAK","sourcesContent":["import {Directive, effect, inject, Input, untracked} from '@angular/core';\nimport {tuiAsControl, TuiControl} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES, TUI_STRICT_MATCHER} from '@taiga-ui/cdk/constants';\nimport type {TuiStringMatcher} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsString} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiDataListAccessor} from '@taiga-ui/core/components/data-list';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport type {TuiTextfieldAccessor} from '@taiga-ui/core/components/textfield';\nimport {\n    tuiAsTextfieldAccessor,\n    tuiInjectAuxiliary,\n    TuiTextfieldComponent,\n    TuiTextfieldDirective,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {\n    TuiDropdownDirective,\n    tuiDropdownEnabled,\n    tuiDropdownOpen,\n} 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 {tuiAsAuxiliary} from '@taiga-ui/core/tokens';\nimport {TuiSelectOption} from '@taiga-ui/kit/components/select';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiComboBox]',\n    providers: [\n        tuiAsOptionContent(TuiSelectOption),\n        tuiAsTextfieldAccessor(TuiComboBox),\n        tuiAsControl(TuiComboBox),\n        tuiAsAuxiliary(TuiComboBox),\n    ],\n    hostDirectives: [TuiWithTextfield],\n    host: {\n        '[disabled]': 'disabled()',\n        '(blur)': 'onTouched()',\n        '(click)': 'toggleDropdown()',\n        '(input)': 'onInput($event.target.value)',\n        '(keydown.enter)': 'keydownEnter($event)',\n    },\n})\nexport class TuiComboBox<T>\n    extends TuiControl<T | string | null>\n    implements TuiTextfieldAccessor<T>\n{\n    private readonly el = tuiInjectElement<HTMLInputElement>();\n    private readonly host: TuiTextfieldComponent<T> = inject(TuiTextfieldComponent);\n    private readonly textfield: TuiTextfieldDirective<T> = inject(TuiTextfieldDirective);\n\n    private readonly open = tuiDropdownOpen();\n    private readonly dropdown = inject(TuiDropdownDirective);\n    private readonly itemsHandlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n    private readonly datalist = tuiInjectAuxiliary<TuiDataListAccessor<T>>(\n        (x) => 'getOptions' in x,\n    );\n\n    protected readonly dropdownEnabled = tuiDropdownEnabled(this.interactive);\n\n    protected readonly valueEffect = effect(() => {\n        const value = this.value() ?? '';\n        const stringified = tuiIsString(value)\n            ? value\n            : this.itemsHandlers.stringify()(value);\n        const match = this.match(stringified);\n\n        this.textfield.value.update((x) => stringified || x);\n\n        if (match) {\n            setTimeout((end = this.el.value.length) =>\n                this.el.setSelectionRange(end, end),\n            );\n        }\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly blurEffect = effect(() => {\n        const value = untracked(() => this.value());\n\n        if (!this.host.focused() && this.strict && !value) {\n            this.textfield.value.set('');\n        }\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    @Input()\n    public strict = true;\n\n    @Input()\n    public matcher: TuiStringMatcher<T> | null = TUI_STRICT_MATCHER;\n\n    public setValue(value: T): void {\n        this.onChange(value);\n\n        if (!value) {\n            this.toggleDropdown(true);\n            this.textfield.value.set('');\n        }\n    }\n\n    protected toggleDropdown(open = !this.open()): void {\n        if (this.dropdownEnabled() && this.dropdown.content) {\n            this.open.set(open);\n        }\n    }\n\n    protected onInput(value: string): void {\n        const match = this.match(value);\n        const fallback = this.strict || !value ? null : value;\n\n        this.onChange(match ?? fallback);\n        setTimeout(() => this.toggleDropdown(true));\n    }\n\n    protected keydownEnter(event: KeyboardEvent): void {\n        if (!this.open()) {\n            return;\n        }\n\n        event.preventDefault();\n\n        if (this.options.length === 1) {\n            this.onChange(this.options[0]!);\n            this.toggleDropdown(false);\n        }\n    }\n\n    private get options(): readonly T[] {\n        return this.datalist()?.getOptions() || [];\n    }\n\n    private match(value: string): T | null {\n        return (\n            this.options.find((item) =>\n                this.matcher?.(item, value, this.itemsHandlers.stringify()),\n            ) ?? null\n        );\n    }\n}\n"]}
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combo-box.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/combo-box/combo-box.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    computed,\n    Directive,\n    effect,\n    inject,\n    Input,\n    isSignal,\n    signal,\n    untracked,\n} from '@angular/core';\nimport {tuiAsControl, TuiControl} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES, TUI_STRICT_MATCHER} from '@taiga-ui/cdk/constants';\nimport type {TuiStringMatcher} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport type {TuiDataListAccessor} from '@taiga-ui/core/components/data-list';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport type {TuiTextfieldAccessor} from '@taiga-ui/core/components/textfield';\nimport {\n    tuiAsTextfieldAccessor,\n    tuiInjectAuxiliary,\n    TuiTextfieldComponent,\n    TuiTextfieldDirective,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {\n    TuiDropdownDirective,\n    tuiDropdownEnabled,\n    tuiDropdownOpen,\n} 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 {tuiAsAuxiliary} from '@taiga-ui/core/tokens';\nimport {TuiSelectOption} from '@taiga-ui/kit/components/select';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiComboBox]',\n    providers: [\n        tuiAsOptionContent(TuiSelectOption),\n        tuiAsTextfieldAccessor(TuiComboBox),\n        tuiAsControl(TuiComboBox),\n        tuiAsAuxiliary(TuiComboBox),\n    ],\n    hostDirectives: [TuiWithTextfield],\n    host: {\n        '[disabled]': 'disabled()',\n        '(click)': 'toggleDropdown()',\n        '(input)': 'onInput()',\n        '(keydown.enter)': 'keydownEnter($event)',\n    },\n})\nexport class TuiComboBox<T>\n    extends TuiControl<T | string | null>\n    implements TuiTextfieldAccessor<T>\n{\n    private readonly el = tuiInjectElement<HTMLInputElement>();\n    private readonly host: TuiTextfieldComponent<T> = inject(TuiTextfieldComponent);\n    private readonly textfield: TuiTextfieldDirective<T> = inject(TuiTextfieldDirective);\n    private readonly open = tuiDropdownOpen();\n    private readonly dropdownEnabled = tuiDropdownEnabled(this.interactive);\n    private readonly dropdown = inject(TuiDropdownDirective);\n    private readonly itemsHandlers: TuiItemsHandlers<T | string> =\n        inject(TUI_ITEMS_HANDLERS);\n\n    private readonly matcher = signal<TuiStringMatcher<T> | null>(TUI_STRICT_MATCHER);\n    private readonly strict = signal(true);\n    private readonly datalist = tuiInjectAuxiliary<TuiDataListAccessor<T>>(\n        (x) => x !== this && 'options' in x && isSignal(x.options),\n    );\n\n    private readonly options = computed(\n        () =>\n            this.datalist()\n                ?.options?.() // TODO(v5): remove optional call `?.()`\n                .filter((x) => !this.itemsHandlers.disabledItemHandler()(x)) ?? [],\n    );\n\n    protected readonly nonStrictValueEffect = effect(() => {\n        if (!this.options().length && !this.strict()) {\n            this.onChange(this.textfield.value() || null);\n        }\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly matchingEffect = effect(() => {\n        const options = this.options();\n        const matcher = this.matcher();\n\n        if (!options.length || !matcher) {\n            return;\n        }\n\n        const textfieldValue = this.textfield.value();\n        const selectedOption =\n            options.find((x) =>\n                matcher(x, textfieldValue, this.itemsHandlers.stringify()),\n            ) ?? null;\n        const stringified = this.stringify(selectedOption);\n        const fallback = this.strict() || !textfieldValue ? null : textfieldValue;\n\n        this.onChange(selectedOption ?? fallback);\n\n        if (stringified && stringified !== textfieldValue) {\n            this.textfield.value.set(stringified);\n        }\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    protected readonly blurEffect = effect(() => {\n        const incomplete = untracked(() => this.strict() && !this.value());\n\n        if (!this.host.focused() && incomplete) {\n            this.textfield.value.set('');\n        }\n    }, TUI_ALLOW_SIGNAL_WRITES);\n\n    // TODO(v5): use signal input\n    @Input('strict')\n    public set strictSetter(x: boolean) {\n        this.strict.set(x);\n    }\n\n    // TODO(v5): use signal input\n    @Input('matcher')\n    public set matcherSetter(x: TuiStringMatcher<T> | null) {\n        this.matcher.set(x);\n    }\n\n    public setValue(value: T | null): void {\n        const stringified = this.stringify(value);\n\n        if (stringified !== this.textfield.value()) {\n            this.textfield.value.set(stringified);\n            setTimeout((end = stringified.length) => this.el.setSelectionRange(end, end));\n        }\n\n        this.onChange(value);\n\n        if (!value) {\n            this.toggleDropdown(true);\n        }\n    }\n\n    public override writeValue(value: T | string | null): void {\n        super.writeValue(value);\n        this.textfield.value.set(this.stringify(value));\n    }\n\n    protected toggleDropdown(open = !this.open()): void {\n        if (this.dropdownEnabled() && this.dropdown.content) {\n            this.open.set(open);\n        }\n    }\n\n    protected onInput(): void {\n        setTimeout(() => this.toggleDropdown(true));\n    }\n\n    protected keydownEnter(event: KeyboardEvent): void {\n        if (!this.open()) {\n            return;\n        }\n\n        event.preventDefault();\n\n        const options = this.options();\n\n        if (options.length === 1 && options[0]) {\n            this.setValue(options[0]);\n            this.toggleDropdown(false);\n        }\n    }\n\n    private stringify(value: T | string | null): string {\n        return value ? this.itemsHandlers.stringify()(value) : '';\n    }\n}\n"]}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { NgForOf, NgIf } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, inject, Input, isSignal, Output, ViewChildren, } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, computed, EventEmitter, forwardRef, inject, Input, isSignal, Output, signal, ViewChild, ViewChildren, } from '@angular/core';
|
|
3
3
|
import { EMPTY_QUERY } from '@taiga-ui/cdk/constants';
|
|
4
4
|
import { TuiElement } from '@taiga-ui/cdk/directives/element';
|
|
5
5
|
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
6
6
|
import { tuiIsNativeFocused } from '@taiga-ui/cdk/utils/focus';
|
|
7
7
|
import { tuiIsPresent } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
8
|
-
import { tuiAsDataListAccessor, TuiDataList, tuiInjectDataListSize, TuiOption, TuiOptionWithValue, } from '@taiga-ui/core/components/data-list';
|
|
8
|
+
import { tuiAsDataListAccessor, TuiDataList, TuiDataListComponent, tuiInjectDataListSize, TuiOption, TuiOptionWithValue, } from '@taiga-ui/core/components/data-list';
|
|
9
9
|
import { TuiLoader } from '@taiga-ui/core/components/loader';
|
|
10
10
|
import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives/items-handlers';
|
|
11
11
|
import { TUI_ITEMS_HANDLERS as TUI_ITEMS_HANDLERS_LEGACY } from '@taiga-ui/kit/tokens';
|
|
@@ -14,10 +14,13 @@ import * as i0 from "@angular/core";
|
|
|
14
14
|
import * as i1 from "@taiga-ui/core/components/data-list";
|
|
15
15
|
class TuiDataListWrapperComponent {
|
|
16
16
|
constructor() {
|
|
17
|
+
this.datalist = signal(null);
|
|
17
18
|
this.itemsHandlers = inject(TUI_ITEMS_HANDLERS);
|
|
18
19
|
// TODO(v5): delete
|
|
19
20
|
this.itemsHandlersLegacy = inject(TUI_ITEMS_HANDLERS_LEGACY);
|
|
21
|
+
// TODO(v5): delete
|
|
20
22
|
this.legacyOptionsQuery = EMPTY_QUERY;
|
|
23
|
+
// TODO(v5): delete
|
|
21
24
|
this.optionsQuery = EMPTY_QUERY;
|
|
22
25
|
this.newOptionMode = tuiInjectElement().hasAttribute('new');
|
|
23
26
|
this.items = [];
|
|
@@ -26,6 +29,7 @@ class TuiDataListWrapperComponent {
|
|
|
26
29
|
: this.itemsHandlersLegacy.disabledItemHandler;
|
|
27
30
|
this.size = tuiInjectDataListSize();
|
|
28
31
|
this.itemClick = new EventEmitter();
|
|
32
|
+
this.options = computed(() => this.datalist()?.options() ?? []);
|
|
29
33
|
this.itemContent = ({ $implicit }) => this.newOptionMode
|
|
30
34
|
? this.itemsHandlers.stringify()($implicit)
|
|
31
35
|
: this.itemsHandlersLegacy.stringify($implicit);
|
|
@@ -33,6 +37,7 @@ class TuiDataListWrapperComponent {
|
|
|
33
37
|
getContext($implicit, { nativeElement }) {
|
|
34
38
|
return { $implicit, active: tuiIsNativeFocused(nativeElement) };
|
|
35
39
|
}
|
|
40
|
+
// TODO(v5): delete
|
|
36
41
|
getOptions(includeDisabled = false) {
|
|
37
42
|
return [
|
|
38
43
|
...this.legacyOptionsQuery,
|
|
@@ -42,11 +47,15 @@ class TuiDataListWrapperComponent {
|
|
|
42
47
|
.map(({ value }) => (isSignal(value) ? value() : value))
|
|
43
48
|
.filter(tuiIsPresent);
|
|
44
49
|
}
|
|
50
|
+
// TODO(v5): use signal `viewChild`
|
|
51
|
+
set datalistSetter(x) {
|
|
52
|
+
this.datalist.set(x);
|
|
53
|
+
}
|
|
45
54
|
$cast(items) {
|
|
46
55
|
return items;
|
|
47
56
|
}
|
|
48
57
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDataListWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
49
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDataListWrapperComponent, isStandalone: true, selector: "tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]", inputs: { items: "items", disabledItemHandler: "disabledItemHandler", emptyContent: "emptyContent", size: "size", itemContent: "itemContent" }, outputs: { itemClick: "itemClick" }, providers: [tuiAsDataListAccessor(TuiDataListWrapperComponent)], viewQueries: [{ propertyName: "legacyOptionsQuery", predicate: i0.forwardRef(function () { return TuiOption; }), descendants: true }, { propertyName: "optionsQuery", predicate: i0.forwardRef(function () { return TuiOptionWithValue; }), descendants: true }], ngImport: i0, template: "<tui-data-list\n *ngIf=\"items; else loading\"\n [emptyContent]=\"emptyContent\"\n [size]=\"size\"\n>\n <ng-container *ngIf=\"newOptionMode; else legacyOptionFallback\">\n <button\n *ngFor=\"let item of $cast(items)\"\n #elementRef=\"elementRef\"\n new\n tuiElement\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n (click)=\"itemClick.emit(item)\"\n >\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n {{ text }}\n </ng-container>\n </button>\n </ng-container>\n\n <!-- TODO(v5): delete fallback -->\n <ng-template #legacyOptionFallback>\n <button\n *ngFor=\"let item of $cast(items)\"\n #elementRef=\"elementRef\"\n automation-id=\"tui-data-list-wrapper__option\"\n tuiElement\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n (click)=\"itemClick.emit(item)\"\n >\n <span class=\"t-content\">\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n {{ text }}\n </ng-container>\n </span>\n </button>\n </ng-template>\n</tui-data-list>\n<ng-template #loading>\n <tui-loader\n automation-id=\"tui-data-list-wrapper__loader\"\n class=\"t-loader\"\n />\n</ng-template>\n", styles: [":host{display:block}.t-content{flex:1;min-inline-size:0}.t-loader{margin:.75rem 0}\n"], dependencies: [{ kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: i1.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "component", type: i1.TuiOption, selector: "button[tuiOption]:not([new]), a[tuiOption]:not([new]), label[tuiOption]:not([new])", inputs: ["disabled", "value"] }, { kind: "directive", type: i1.TuiOptionNew, selector: "button[tuiOption][new], a[tuiOption][new], label[tuiOption][new]", inputs: ["disabled"] }, { kind: "directive", type: i1.TuiOptionWithValue, selector: "button[tuiOption][value][new], a[tuiOption][value][new], label[tuiOption][value][new]", inputs: ["disabled", "value"] }, { kind: "directive", type: TuiElement, selector: "[tuiElement]", exportAs: ["elementRef"] }, { kind: "component", type: TuiLoader, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
58
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDataListWrapperComponent, isStandalone: true, selector: "tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]", inputs: { items: "items", disabledItemHandler: "disabledItemHandler", emptyContent: "emptyContent", size: "size", itemContent: "itemContent" }, outputs: { itemClick: "itemClick" }, providers: [tuiAsDataListAccessor(TuiDataListWrapperComponent)], viewQueries: [{ propertyName: "datalistSetter", first: true, predicate: TuiDataListComponent, descendants: true }, { propertyName: "legacyOptionsQuery", predicate: i0.forwardRef(function () { return TuiOption; }), descendants: true }, { propertyName: "optionsQuery", predicate: i0.forwardRef(function () { return TuiOptionWithValue; }), descendants: true }], ngImport: i0, template: "<tui-data-list\n *ngIf=\"items; else loading\"\n [emptyContent]=\"emptyContent\"\n [size]=\"size\"\n>\n <ng-container *ngIf=\"newOptionMode; else legacyOptionFallback\">\n <button\n *ngFor=\"let item of $cast(items)\"\n #elementRef=\"elementRef\"\n new\n tuiElement\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n (click)=\"itemClick.emit(item)\"\n >\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n {{ text }}\n </ng-container>\n </button>\n </ng-container>\n\n <!-- TODO(v5): delete fallback -->\n <ng-template #legacyOptionFallback>\n <button\n *ngFor=\"let item of $cast(items)\"\n #elementRef=\"elementRef\"\n automation-id=\"tui-data-list-wrapper__option\"\n tuiElement\n tuiOption\n type=\"button\"\n [disabled]=\"disabledItemHandler(item)\"\n [value]=\"item\"\n (click)=\"itemClick.emit(item)\"\n >\n <span class=\"t-content\">\n <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n {{ text }}\n </ng-container>\n </span>\n </button>\n </ng-template>\n</tui-data-list>\n<ng-template #loading>\n <tui-loader\n automation-id=\"tui-data-list-wrapper__loader\"\n class=\"t-loader\"\n />\n</ng-template>\n", styles: [":host{display:block}.t-content{flex:1;min-inline-size:0}.t-loader{margin:.75rem 0}\n"], dependencies: [{ kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: i1.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "component", type: i1.TuiOption, selector: "button[tuiOption]:not([new]), a[tuiOption]:not([new]), label[tuiOption]:not([new])", inputs: ["disabled", "value"] }, { kind: "directive", type: i1.TuiOptionNew, selector: "button[tuiOption][new], a[tuiOption][new], label[tuiOption][new]", inputs: ["disabled"] }, { kind: "directive", type: i1.TuiOptionWithValue, selector: "button[tuiOption][value][new], a[tuiOption][value][new], label[tuiOption][value][new]", inputs: ["disabled", "value"] }, { kind: "directive", type: TuiElement, selector: "[tuiElement]", exportAs: ["elementRef"] }, { kind: "component", type: TuiLoader, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
50
59
|
}
|
|
51
60
|
export { TuiDataListWrapperComponent };
|
|
52
61
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDataListWrapperComponent, decorators: [{
|
|
@@ -70,5 +79,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
70
79
|
type: Output
|
|
71
80
|
}], itemContent: [{
|
|
72
81
|
type: Input
|
|
82
|
+
}], datalistSetter: [{
|
|
83
|
+
type: ViewChild,
|
|
84
|
+
args: [TuiDataListComponent]
|
|
73
85
|
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list-wrapper.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/data-list-wrapper/data-list-wrapper.component.ts","../../../../../projects/kit/components/data-list-wrapper/data-list-wrapper.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgForOf, NgIf} from '@angular/common';\nimport type {ElementRef, QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    forwardRef,\n    inject,\n    Input,\n    isSignal,\n    Output,\n    ViewChildren,\n} from '@angular/core';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiElement} from '@taiga-ui/cdk/directives/element';\nimport type {TuiBooleanHandler} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocused} from '@taiga-ui/cdk/utils/focus';\nimport {tuiIsPresent} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiDataListAccessor} from '@taiga-ui/core/components/data-list';\nimport {\n    tuiAsDataListAccessor,\n    TuiDataList,\n    tuiInjectDataListSize,\n    TuiOption,\n    TuiOptionWithValue,\n} from '@taiga-ui/core/components/data-list';\nimport {TuiLoader} from '@taiga-ui/core/components/loader';\nimport type {TuiItemsHandlers} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_ITEMS_HANDLERS} from '@taiga-ui/core/directives/items-handlers';\nimport type {TuiValueContentContext} from '@taiga-ui/core/types';\nimport type {TuiItemsHandlers as TuiItemsHandlersLegacy} from '@taiga-ui/kit/tokens';\nimport {TUI_ITEMS_HANDLERS as TUI_ITEMS_HANDLERS_LEGACY} from '@taiga-ui/kit/tokens';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\n@Component({\n    standalone: true,\n    selector:\n        'tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]', // TODO(v5): remove [new]\n    imports: [NgForOf, NgIf, PolymorpheusOutlet, TuiDataList, TuiElement, TuiLoader],\n    templateUrl: './data-list-wrapper.template.html',\n    styleUrls: ['./data-list-wrapper.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsDataListAccessor(TuiDataListWrapperComponent)],\n})\nexport class TuiDataListWrapperComponent<T, K = T> implements TuiDataListAccessor<T> {\n    private readonly itemsHandlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n    // TODO(v5): delete\n    private readonly itemsHandlersLegacy: TuiItemsHandlersLegacy<T> = inject(\n        TUI_ITEMS_HANDLERS_LEGACY,\n    );\n\n    @ViewChildren(forwardRef(() => TuiOption))\n    protected readonly legacyOptionsQuery: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    @ViewChildren(forwardRef(() => TuiOptionWithValue))\n    protected readonly optionsQuery: QueryList<TuiOptionWithValue<T>> = EMPTY_QUERY;\n\n    protected readonly newOptionMode = tuiInjectElement().hasAttribute('new');\n\n    @Input()\n    public items: readonly K[] | null = [];\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<T> = this.newOptionMode\n        ? this.itemsHandlers?.disabledItemHandler()\n        : this.itemsHandlersLegacy.disabledItemHandler;\n\n    @Input()\n    public emptyContent: PolymorpheusContent;\n\n    @Input()\n    public size = tuiInjectDataListSize();\n\n    @Output()\n    public readonly itemClick = new EventEmitter<T>();\n\n    @Input()\n    public itemContent: PolymorpheusContent<TuiValueContentContext<T>> = ({$implicit}) =>\n        this.newOptionMode\n            ? this.itemsHandlers.stringify()($implicit)\n            : this.itemsHandlersLegacy.stringify($implicit);\n\n    public getContext(\n        $implicit: T,\n        {nativeElement}: ElementRef<HTMLElement>,\n    ): TuiValueContentContext<T> {\n        return {$implicit, active: tuiIsNativeFocused(nativeElement)};\n    }\n\n    public getOptions(includeDisabled = false): readonly T[] {\n        return [\n            ...this.legacyOptionsQuery, // TODO(v5): delete\n            ...this.optionsQuery,\n        ]\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => (isSignal(value) ? value() : value))\n            .filter(tuiIsPresent);\n    }\n\n    protected $cast(items: readonly K[]): readonly T[] {\n        return items as unknown as readonly T[];\n    }\n}\n","<tui-data-list\n    *ngIf=\"items; else loading\"\n    [emptyContent]=\"emptyContent\"\n    [size]=\"size\"\n>\n    <ng-container *ngIf=\"newOptionMode; else legacyOptionFallback\">\n        <button\n            *ngFor=\"let item of $cast(items)\"\n            #elementRef=\"elementRef\"\n            new\n            tuiElement\n            tuiOption\n            type=\"button\"\n            [disabled]=\"disabledItemHandler(item)\"\n            [value]=\"item\"\n            (click)=\"itemClick.emit(item)\"\n        >\n            <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n                {{ text }}\n            </ng-container>\n        </button>\n    </ng-container>\n\n    <!-- TODO(v5): delete fallback -->\n    <ng-template #legacyOptionFallback>\n        <button\n            *ngFor=\"let item of $cast(items)\"\n            #elementRef=\"elementRef\"\n            automation-id=\"tui-data-list-wrapper__option\"\n            tuiElement\n            tuiOption\n            type=\"button\"\n            [disabled]=\"disabledItemHandler(item)\"\n            [value]=\"item\"\n            (click)=\"itemClick.emit(item)\"\n        >\n            <span class=\"t-content\">\n                <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n                    {{ text }}\n                </ng-container>\n            </span>\n        </button>\n    </ng-template>\n</tui-data-list>\n<ng-template #loading>\n    <tui-loader\n        automation-id=\"tui-data-list-wrapper__loader\"\n        class=\"t-loader\"\n    />\n</ng-template>\n"]}
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list-wrapper.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/data-list-wrapper/data-list-wrapper.component.ts","../../../../../projects/kit/components/data-list-wrapper/data-list-wrapper.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgForOf, NgIf} from '@angular/common';\nimport type {ElementRef, QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    EventEmitter,\n    forwardRef,\n    inject,\n    Input,\n    isSignal,\n    Output,\n    signal,\n    ViewChild,\n    ViewChildren,\n} from '@angular/core';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiElement} from '@taiga-ui/cdk/directives/element';\nimport type {TuiBooleanHandler} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocused} from '@taiga-ui/cdk/utils/focus';\nimport {tuiIsPresent} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiDataListAccessor} from '@taiga-ui/core/components/data-list';\nimport {\n    tuiAsDataListAccessor,\n    TuiDataList,\n    TuiDataListComponent,\n    tuiInjectDataListSize,\n    TuiOption,\n    TuiOptionWithValue,\n} from '@taiga-ui/core/components/data-list';\nimport {TuiLoader} from '@taiga-ui/core/components/loader';\nimport type {TuiItemsHandlers} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_ITEMS_HANDLERS} from '@taiga-ui/core/directives/items-handlers';\nimport type {TuiValueContentContext} from '@taiga-ui/core/types';\nimport type {TuiItemsHandlers as TuiItemsHandlersLegacy} from '@taiga-ui/kit/tokens';\nimport {TUI_ITEMS_HANDLERS as TUI_ITEMS_HANDLERS_LEGACY} from '@taiga-ui/kit/tokens';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\n@Component({\n    standalone: true,\n    selector:\n        'tui-data-list-wrapper:not([labels]), tui-data-list-wrapper:not([labels])[new]', // TODO(v5): remove [new]\n    imports: [NgForOf, NgIf, PolymorpheusOutlet, TuiDataList, TuiElement, TuiLoader],\n    templateUrl: './data-list-wrapper.template.html',\n    styleUrls: ['./data-list-wrapper.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsDataListAccessor(TuiDataListWrapperComponent)],\n})\nexport class TuiDataListWrapperComponent<T, K = T> implements TuiDataListAccessor<T> {\n    private readonly datalist = signal<TuiDataListComponent<T> | null>(null);\n    private readonly itemsHandlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n    // TODO(v5): delete\n    private readonly itemsHandlersLegacy: TuiItemsHandlersLegacy<T> = inject(\n        TUI_ITEMS_HANDLERS_LEGACY,\n    );\n\n    // TODO(v5): delete\n    @ViewChildren(forwardRef(() => TuiOption))\n    protected readonly legacyOptionsQuery: QueryList<TuiOption<T>> = EMPTY_QUERY;\n\n    // TODO(v5): delete\n    @ViewChildren(forwardRef(() => TuiOptionWithValue))\n    protected readonly optionsQuery: QueryList<TuiOptionWithValue<T>> = EMPTY_QUERY;\n\n    protected readonly newOptionMode = tuiInjectElement().hasAttribute('new');\n\n    @Input()\n    public items: readonly K[] | null = [];\n\n    @Input()\n    public disabledItemHandler: TuiBooleanHandler<T> = this.newOptionMode\n        ? this.itemsHandlers?.disabledItemHandler()\n        : this.itemsHandlersLegacy.disabledItemHandler;\n\n    @Input()\n    public emptyContent: PolymorpheusContent;\n\n    @Input()\n    public size = tuiInjectDataListSize();\n\n    @Output()\n    public readonly itemClick = new EventEmitter<T>();\n\n    public readonly options = computed(() => this.datalist()?.options() ?? []);\n\n    @Input()\n    public itemContent: PolymorpheusContent<TuiValueContentContext<T>> = ({$implicit}) =>\n        this.newOptionMode\n            ? this.itemsHandlers.stringify()($implicit)\n            : this.itemsHandlersLegacy.stringify($implicit);\n\n    public getContext(\n        $implicit: T,\n        {nativeElement}: ElementRef<HTMLElement>,\n    ): TuiValueContentContext<T> {\n        return {$implicit, active: tuiIsNativeFocused(nativeElement)};\n    }\n\n    // TODO(v5): delete\n    public getOptions(includeDisabled = false): readonly T[] {\n        return [\n            ...this.legacyOptionsQuery, // TODO(v5): delete\n            ...this.optionsQuery,\n        ]\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => (isSignal(value) ? value() : value))\n            .filter(tuiIsPresent);\n    }\n\n    // TODO(v5): use signal `viewChild`\n    @ViewChild(TuiDataListComponent)\n    protected set datalistSetter(x: TuiDataListComponent<T>) {\n        this.datalist.set(x);\n    }\n\n    protected $cast(items: readonly K[]): readonly T[] {\n        return items as unknown as readonly T[];\n    }\n}\n","<tui-data-list\n    *ngIf=\"items; else loading\"\n    [emptyContent]=\"emptyContent\"\n    [size]=\"size\"\n>\n    <ng-container *ngIf=\"newOptionMode; else legacyOptionFallback\">\n        <button\n            *ngFor=\"let item of $cast(items)\"\n            #elementRef=\"elementRef\"\n            new\n            tuiElement\n            tuiOption\n            type=\"button\"\n            [disabled]=\"disabledItemHandler(item)\"\n            [value]=\"item\"\n            (click)=\"itemClick.emit(item)\"\n        >\n            <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n                {{ text }}\n            </ng-container>\n        </button>\n    </ng-container>\n\n    <!-- TODO(v5): delete fallback -->\n    <ng-template #legacyOptionFallback>\n        <button\n            *ngFor=\"let item of $cast(items)\"\n            #elementRef=\"elementRef\"\n            automation-id=\"tui-data-list-wrapper__option\"\n            tuiElement\n            tuiOption\n            type=\"button\"\n            [disabled]=\"disabledItemHandler(item)\"\n            [value]=\"item\"\n            (click)=\"itemClick.emit(item)\"\n        >\n            <span class=\"t-content\">\n                <ng-container *polymorpheusOutlet=\"itemContent as text; context: getContext(item, elementRef)\">\n                    {{ text }}\n                </ng-container>\n            </span>\n        </button>\n    </ng-template>\n</tui-data-list>\n<ng-template #loading>\n    <tui-loader\n        automation-id=\"tui-data-list-wrapper__loader\"\n        class=\"t-loader\"\n    />\n</ng-template>\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output, } from '@angular/core';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, LOCALE_ID, Output, } from '@angular/core';
|
|
4
4
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
5
5
|
import { WA_WINDOW } from '@ng-web-apis/common';
|
|
6
6
|
import { tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
@@ -21,6 +21,7 @@ class TuiFile {
|
|
|
21
21
|
constructor() {
|
|
22
22
|
this.sanitizer = inject(DomSanitizer);
|
|
23
23
|
this.options = inject(TUI_FILE_OPTIONS);
|
|
24
|
+
this.locale = inject(LOCALE_ID);
|
|
24
25
|
this.units$ = inject(TUI_DIGITAL_INFORMATION_UNITS);
|
|
25
26
|
this.win = inject(WA_WINDOW);
|
|
26
27
|
this.icons = inject(TUI_COMMON_ICONS);
|
|
@@ -71,7 +72,7 @@ class TuiFile {
|
|
|
71
72
|
: of(this.file.content || '');
|
|
72
73
|
}
|
|
73
74
|
calculateFileSize$(file, units$) {
|
|
74
|
-
return units$.pipe(map((units) => this.options.formatSize(units, file.size)));
|
|
75
|
+
return units$.pipe(map((units) => this.options.formatSize(units, file.size, this.locale)));
|
|
75
76
|
}
|
|
76
77
|
createPreview(file) {
|
|
77
78
|
if (file.src) {
|
|
@@ -141,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
141
142
|
}], remove: [{
|
|
142
143
|
type: Output
|
|
143
144
|
}], calculateContent$: [], calculateFileSize$: [], createPreview: [], getName: [], getType: [] } });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.component.js","sourceRoot":"","sources":["../../../../../../projects/kit/components/files/file/file.component.ts","../../../../../../projects/kit/components/files/file/file.template.html"],"names":[],"mappings":"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","sourcesContent":["import {CommonModule} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport type {SafeValue} from '@angular/platform-browser';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport {WA_WINDOW} from '@ng-web-apis/common';\nimport type {TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport {TuiIcon} from '@taiga-ui/core/components/icon';\nimport {TuiLoader} from '@taiga-ui/core/components/loader';\nimport {\n    TuiAppearance,\n    tuiAppearanceOptionsProvider,\n} from '@taiga-ui/core/directives/appearance';\nimport {TuiHintOverflow} from '@taiga-ui/core/directives/hint';\nimport {TUI_COMMON_ICONS} from '@taiga-ui/core/tokens';\nimport type {TuiSizeL} from '@taiga-ui/core/types';\nimport type {TuiLanguage} from '@taiga-ui/i18n/types';\nimport {TUI_DIGITAL_INFORMATION_UNITS, TUI_FILE_TEXTS} from '@taiga-ui/kit/tokens';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet, PolymorpheusTemplate} from '@taiga-ui/polymorpheus';\nimport type {Observable} from 'rxjs';\nimport {map, of} from 'rxjs';\n\nimport type {TuiFileLike, TuiFileState} from '../files.types';\nimport {TUI_FILE_OPTIONS} from './file.options';\n\n@Component({\n    standalone: true,\n    selector: 'tui-file,a[tuiFile],button[tuiFile]',\n    imports: [\n        CommonModule,\n        PolymorpheusOutlet,\n        PolymorpheusTemplate,\n        TuiButton,\n        TuiHintOverflow,\n        TuiIcon,\n        TuiLoader,\n    ],\n    templateUrl: './file.template.html',\n    styleUrls: ['./file.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAppearanceOptionsProvider(TUI_FILE_OPTIONS)],\n    hostDirectives: [TuiAppearance],\n    host: {\n        '[attr.data-delete]': 'showDelete',\n    },\n})\nexport class TuiFile {\n    private readonly sanitizer = inject(DomSanitizer);\n    private readonly options = inject(TUI_FILE_OPTIONS);\n    private readonly units$ = inject(TUI_DIGITAL_INFORMATION_UNITS);\n    private readonly win = inject(WA_WINDOW) as Window & {File: typeof File};\n\n    protected readonly icons = inject(TUI_COMMON_ICONS);\n    protected readonly fileTexts$ = inject(TUI_FILE_TEXTS);\n\n    @Input()\n    public file: TuiFileLike = {name: ''};\n\n    @Input()\n    public state: TuiFileState = 'normal';\n\n    @Input()\n    public size: TuiSizeL = 'm';\n\n    @Input()\n    public showDelete: boolean | 'always' = true;\n\n    @Input()\n    public showSize = true;\n\n    @Input()\n    public leftContent: PolymorpheusContent;\n\n    @Output()\n    public readonly remove = new EventEmitter<void>();\n\n    protected get preview(): SafeValue {\n        return this.isBig ? this.createPreview(this.file) : '';\n    }\n\n    protected get isBig(): boolean {\n        return this.size === 'l';\n    }\n\n    protected get isLoading(): boolean {\n        return this.state === 'loading';\n    }\n\n    protected get isError(): boolean {\n        return this.state === 'error';\n    }\n\n    protected get isDeleted(): boolean {\n        return this.state === 'deleted';\n    }\n\n    protected get allowDelete(): boolean {\n        return this.showDelete && this.remove.observed;\n    }\n\n    protected get icon(): PolymorpheusContent<TuiContext<TuiSizeL>> {\n        return this.state === 'loading' ? '' : this.options.icons[this.state];\n    }\n\n    protected get name(): string {\n        return this.getName(this.file);\n    }\n\n    protected get type(): string {\n        return this.getType(this.file);\n    }\n\n    protected get content$(): Observable<PolymorpheusContent> {\n        return this.calculateContent$(this.state, this.file, this.fileTexts$);\n    }\n\n    protected get fileSize$(): Observable<string | null> {\n        return this.calculateFileSize$(this.file, this.units$);\n    }\n\n    @tuiPure\n    private calculateContent$(\n        state: TuiFileState,\n        file: TuiFileLike,\n        fileTexts$: Observable<Record<keyof TuiLanguage['fileTexts'], string>>,\n    ): Observable<PolymorpheusContent> {\n        return state === 'error' && !file.content\n            ? fileTexts$.pipe(map((texts) => texts.loadingError))\n            : of(this.file.content || '');\n    }\n\n    @tuiPure\n    private calculateFileSize$(\n        file: TuiFileLike,\n        units$: Observable<readonly [string, string, string]>,\n    ): Observable<string | null> {\n        return units$.pipe(map((units) => this.options.formatSize(units, file.size)));\n    }\n\n    @tuiPure\n    private createPreview(file: TuiFileLike): SafeValue {\n        if (file.src) {\n            return file.src;\n        }\n\n        if (\n            this.win.File &&\n            file instanceof this.win.File &&\n            file.type?.startsWith('image/')\n        ) {\n            return this.sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(file));\n        }\n\n        return '';\n    }\n\n    @tuiPure\n    private getName(file: TuiFileLike): string {\n        const dot = file.name.lastIndexOf('.');\n        // a dot at position 0 means a “hidden” file, not an extension\n\n        return dot > 0 ? file.name.slice(0, dot) : file.name;\n    }\n\n    @tuiPure\n    private getType(file: TuiFileLike): string {\n        const dot = file.name.lastIndexOf('.');\n        // only return an extension when there is one\n\n        return dot > 0 ? file.name.slice(dot) : '';\n    }\n}\n","<div\n    class=\"t-preview\"\n    [class.t-preview_big]=\"isBig\"\n>\n    <ng-container *polymorpheusOutlet=\"leftContent || defaultLeftContent as text\">\n        {{ text }}\n    </ng-container>\n</div>\n<div class=\"t-wrapper\">\n    <div class=\"t-text\">\n        <div\n            tuiHintOverflow\n            class=\"t-name\"\n        >\n            {{ name }}\n        </div>\n        <div class=\"t-type\">{{ type }}</div>\n        <div\n            *ngIf=\"showSize && (fileSize$ | async) as fileSize\"\n            class=\"t-size\"\n        >\n            {{ fileSize }}\n        </div>\n    </div>\n    <div\n        *ngIf=\"content$ | async as content\"\n        class=\"t-content\"\n    >\n        <ng-container *polymorpheusOutlet=\"content as text\">\n            {{ text }}\n        </ng-container>\n    </div>\n    <ng-content />\n</div>\n<ng-container *ngIf=\"allowDelete\">\n    <button\n        *ngIf=\"fileTexts$ | async as texts\"\n        appearance=\"icon\"\n        size=\"xs\"\n        tuiIconButton\n        type=\"button\"\n        class=\"t-remove\"\n        [iconStart]=\"icons.close\"\n        (click.prevent)=\"remove.emit()\"\n        (mousedown.prevent.zoneless)=\"(0)\"\n    >\n        {{ texts.remove }}\n    </button>\n</ng-container>\n\n<ng-template #defaultLeftContent>\n    <img\n        *ngIf=\"preview; else loader\"\n        alt=\"file preview\"\n        class=\"t-image\"\n        [src]=\"preview\"\n    />\n    <ng-template #loader>\n        <tui-loader\n            *ngIf=\"isLoading; else svg\"\n            class=\"t-loader\"\n            [inheritColor]=\"isBig\"\n        />\n    </ng-template>\n    <ng-template #svg>\n        <tui-icon\n            *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n            class=\"t-icon\"\n            [class.t-icon_blank]=\"isBig || isDeleted\"\n            [class.t-icon_error]=\"isError\"\n            [icon]=\"src.toString()\"\n        />\n    </ng-template>\n</ng-template>\n"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.component.js","sourceRoot":"","sources":["../../../../../../projects/kit/components/files/file/file.component.ts","../../../../../../projects/kit/components/files/file/file.template.html"],"names":[],"mappings":"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","sourcesContent":["import {CommonModule} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    LOCALE_ID,\n    Output,\n} from '@angular/core';\nimport type {SafeValue} from '@angular/platform-browser';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport {WA_WINDOW} from '@ng-web-apis/common';\nimport type {TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport {TuiIcon} from '@taiga-ui/core/components/icon';\nimport {TuiLoader} from '@taiga-ui/core/components/loader';\nimport {\n    TuiAppearance,\n    tuiAppearanceOptionsProvider,\n} from '@taiga-ui/core/directives/appearance';\nimport {TuiHintOverflow} from '@taiga-ui/core/directives/hint';\nimport {TUI_COMMON_ICONS} from '@taiga-ui/core/tokens';\nimport type {TuiSizeL} from '@taiga-ui/core/types';\nimport type {TuiLanguage} from '@taiga-ui/i18n/types';\nimport {TUI_DIGITAL_INFORMATION_UNITS, TUI_FILE_TEXTS} from '@taiga-ui/kit/tokens';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet, PolymorpheusTemplate} from '@taiga-ui/polymorpheus';\nimport type {Observable} from 'rxjs';\nimport {map, of} from 'rxjs';\n\nimport type {TuiFileLike, TuiFileState} from '../files.types';\nimport {TUI_FILE_OPTIONS} from './file.options';\n\n@Component({\n    standalone: true,\n    selector: 'tui-file,a[tuiFile],button[tuiFile]',\n    imports: [\n        CommonModule,\n        PolymorpheusOutlet,\n        PolymorpheusTemplate,\n        TuiButton,\n        TuiHintOverflow,\n        TuiIcon,\n        TuiLoader,\n    ],\n    templateUrl: './file.template.html',\n    styleUrls: ['./file.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAppearanceOptionsProvider(TUI_FILE_OPTIONS)],\n    hostDirectives: [TuiAppearance],\n    host: {\n        '[attr.data-delete]': 'showDelete',\n    },\n})\nexport class TuiFile {\n    private readonly sanitizer = inject(DomSanitizer);\n    private readonly options = inject(TUI_FILE_OPTIONS);\n    private readonly locale = inject(LOCALE_ID);\n    private readonly units$ = inject(TUI_DIGITAL_INFORMATION_UNITS);\n    private readonly win = inject(WA_WINDOW) as Window & {File: typeof File};\n\n    protected readonly icons = inject(TUI_COMMON_ICONS);\n    protected readonly fileTexts$ = inject(TUI_FILE_TEXTS);\n\n    @Input()\n    public file: TuiFileLike = {name: ''};\n\n    @Input()\n    public state: TuiFileState = 'normal';\n\n    @Input()\n    public size: TuiSizeL = 'm';\n\n    @Input()\n    public showDelete: boolean | 'always' = true;\n\n    @Input()\n    public showSize = true;\n\n    @Input()\n    public leftContent: PolymorpheusContent;\n\n    @Output()\n    public readonly remove = new EventEmitter<void>();\n\n    protected get preview(): SafeValue {\n        return this.isBig ? this.createPreview(this.file) : '';\n    }\n\n    protected get isBig(): boolean {\n        return this.size === 'l';\n    }\n\n    protected get isLoading(): boolean {\n        return this.state === 'loading';\n    }\n\n    protected get isError(): boolean {\n        return this.state === 'error';\n    }\n\n    protected get isDeleted(): boolean {\n        return this.state === 'deleted';\n    }\n\n    protected get allowDelete(): boolean {\n        return this.showDelete && this.remove.observed;\n    }\n\n    protected get icon(): PolymorpheusContent<TuiContext<TuiSizeL>> {\n        return this.state === 'loading' ? '' : this.options.icons[this.state];\n    }\n\n    protected get name(): string {\n        return this.getName(this.file);\n    }\n\n    protected get type(): string {\n        return this.getType(this.file);\n    }\n\n    protected get content$(): Observable<PolymorpheusContent> {\n        return this.calculateContent$(this.state, this.file, this.fileTexts$);\n    }\n\n    protected get fileSize$(): Observable<string | null> {\n        return this.calculateFileSize$(this.file, this.units$);\n    }\n\n    @tuiPure\n    private calculateContent$(\n        state: TuiFileState,\n        file: TuiFileLike,\n        fileTexts$: Observable<Record<keyof TuiLanguage['fileTexts'], string>>,\n    ): Observable<PolymorpheusContent> {\n        return state === 'error' && !file.content\n            ? fileTexts$.pipe(map((texts) => texts.loadingError))\n            : of(this.file.content || '');\n    }\n\n    @tuiPure\n    private calculateFileSize$(\n        file: TuiFileLike,\n        units$: Observable<readonly [string, string, string]>,\n    ): Observable<string | null> {\n        return units$.pipe(\n            map((units) => this.options.formatSize(units, file.size, this.locale)),\n        );\n    }\n\n    @tuiPure\n    private createPreview(file: TuiFileLike): SafeValue {\n        if (file.src) {\n            return file.src;\n        }\n\n        if (\n            this.win.File &&\n            file instanceof this.win.File &&\n            file.type?.startsWith('image/')\n        ) {\n            return this.sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(file));\n        }\n\n        return '';\n    }\n\n    @tuiPure\n    private getName(file: TuiFileLike): string {\n        const dot = file.name.lastIndexOf('.');\n        // a dot at position 0 means a “hidden” file, not an extension\n\n        return dot > 0 ? file.name.slice(0, dot) : file.name;\n    }\n\n    @tuiPure\n    private getType(file: TuiFileLike): string {\n        const dot = file.name.lastIndexOf('.');\n        // only return an extension when there is one\n\n        return dot > 0 ? file.name.slice(dot) : '';\n    }\n}\n","<div\n    class=\"t-preview\"\n    [class.t-preview_big]=\"isBig\"\n>\n    <ng-container *polymorpheusOutlet=\"leftContent || defaultLeftContent as text\">\n        {{ text }}\n    </ng-container>\n</div>\n<div class=\"t-wrapper\">\n    <div class=\"t-text\">\n        <div\n            tuiHintOverflow\n            class=\"t-name\"\n        >\n            {{ name }}\n        </div>\n        <div class=\"t-type\">{{ type }}</div>\n        <div\n            *ngIf=\"showSize && (fileSize$ | async) as fileSize\"\n            class=\"t-size\"\n        >\n            {{ fileSize }}\n        </div>\n    </div>\n    <div\n        *ngIf=\"content$ | async as content\"\n        class=\"t-content\"\n    >\n        <ng-container *polymorpheusOutlet=\"content as text\">\n            {{ text }}\n        </ng-container>\n    </div>\n    <ng-content />\n</div>\n<ng-container *ngIf=\"allowDelete\">\n    <button\n        *ngIf=\"fileTexts$ | async as texts\"\n        appearance=\"icon\"\n        size=\"xs\"\n        tuiIconButton\n        type=\"button\"\n        class=\"t-remove\"\n        [iconStart]=\"icons.close\"\n        (click.prevent)=\"remove.emit()\"\n        (mousedown.prevent.zoneless)=\"(0)\"\n    >\n        {{ texts.remove }}\n    </button>\n</ng-container>\n\n<ng-template #defaultLeftContent>\n    <img\n        *ngIf=\"preview; else loader\"\n        alt=\"file preview\"\n        class=\"t-image\"\n        [src]=\"preview\"\n    />\n    <ng-template #loader>\n        <tui-loader\n            *ngIf=\"isLoading; else svg\"\n            class=\"t-loader\"\n            [inheritColor]=\"isBig\"\n        />\n    </ng-template>\n    <ng-template #svg>\n        <tui-icon\n            *polymorpheusOutlet=\"icon as src; context: {$implicit: size}\"\n            class=\"t-icon\"\n            [class.t-icon_blank]=\"isBig || isDeleted\"\n            [class.t-icon_error]=\"isError\"\n            [icon]=\"src.toString()\"\n        />\n    </ng-template>\n</ng-template>\n"]}
|
|
@@ -13,4 +13,4 @@ export const TUI_FILE_DEFAULT_OPTIONS = {
|
|
|
13
13
|
* Default parameters for file component
|
|
14
14
|
*/
|
|
15
15
|
export const [TUI_FILE_OPTIONS, tuiFileOptionsProvider] = tuiCreateOptions(TUI_FILE_DEFAULT_OPTIONS);
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS5vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvZmlsZXMvZmlsZS9maWxlLm9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFNeEQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBYzdDLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFtQjtJQUNwRCxVQUFVLEVBQUUsU0FBUztJQUNyQixVQUFVLEVBQUUsYUFBYTtJQUN6QixLQUFLLEVBQUU7UUFDSCxNQUFNLEVBQUUsQ0FBQyxFQUFDLFNBQVMsRUFBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLFNBQVMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsbUJBQW1CLENBQUM7UUFDaEYsS0FBSyxFQUFFLG1CQUFtQjtRQUMxQixPQUFPLEVBQUUsWUFBWTtLQUN4QjtDQUNKLENBQUM7QUFFRjs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLEVBQUUsc0JBQXNCLENBQUMsR0FBRyxnQkFBZ0IsQ0FDdEUsd0JBQXdCLENBQzNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7VHVpQ29udGV4dH0gZnJvbSAnQHRhaWdhLXVpL2Nkay90eXBlcyc7XG5pbXBvcnQge3R1aUNyZWF0ZU9wdGlvbnN9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvZGknO1xuaW1wb3J0IHR5cGUge1R1aUFwcGVhcmFuY2VPcHRpb25zfSBmcm9tICdAdGFpZ2EtdWkvY29yZS9kaXJlY3RpdmVzL2FwcGVhcmFuY2UnO1xuaW1wb3J0IHR5cGUge1R1aVNpemVMfSBmcm9tICdAdGFpZ2EtdWkvY29yZS90eXBlcyc7XG5pbXBvcnQgdHlwZSB7UG9seW1vcnBoZXVzQ29udGVudH0gZnJvbSAnQHRhaWdhLXVpL3BvbHltb3JwaGV1cyc7XG5cbmltcG9ydCB0eXBlIHtUdWlGaWxlU3RhdGV9IGZyb20gJy4uL2ZpbGVzLnR5cGVzJztcbmltcG9ydCB7dHVpRm9ybWF0U2l6ZX0gZnJvbSAnLi4vZmlsZXMudXRpbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFR1aUZpbGVPcHRpb25zIGV4dGVuZHMgVHVpQXBwZWFyYW5jZU9wdGlvbnMge1xuICAgIHJlYWRvbmx5IGZvcm1hdFNpemU6IChcbiAgICAgICAgdW5pdHM6IHJlYWRvbmx5IFtzdHJpbmcsIHN0cmluZywgc3RyaW5nXSxcbiAgICAgICAgc2l6ZT86IG51bWJlcixcbiAgICAgICAgbG9jYWxlPzogc3RyaW5nLFxuICAgICkgPT4gc3RyaW5nIHwgbnVsbDtcbiAgICByZWFkb25seSBpY29uczogUmVjb3JkPFxuICAgICAgICBFeGNsdWRlPFR1aUZpbGVTdGF0ZSwgJ2xvYWRpbmcnPixcbiAgICAgICAgUG9seW1vcnBoZXVzQ29udGVudDxUdWlDb250ZXh0PFR1aVNpemVMPj5cbiAgICA+O1xufVxuXG5leHBvcnQgY29uc3QgVFVJX0ZJTEVfREVGQVVMVF9PUFRJT05TOiBUdWlGaWxlT3B0aW9ucyA9IHtcbiAgICBhcHBlYXJhbmNlOiAnb3V0bGluZScsXG4gICAgZm9ybWF0U2l6ZTogdHVpRm9ybWF0U2l6ZSxcbiAgICBpY29uczoge1xuICAgICAgICBub3JtYWw6ICh7JGltcGxpY2l0fSkgPT4gKCRpbXBsaWNpdCA9PT0gJ2wnID8gJ0B0dWkuZmlsZScgOiAnQHR1aS5jaXJjbGUtY2hlY2snKSxcbiAgICAgICAgZXJyb3I6ICdAdHVpLmNpcmNsZS1hbGVydCcsXG4gICAgICAgIGRlbGV0ZWQ6ICdAdHVpLnRyYXNoJyxcbiAgICB9LFxufTtcblxuLyoqXG4gKiBEZWZhdWx0IHBhcmFtZXRlcnMgZm9yIGZpbGUgY29tcG9uZW50XG4gKi9cbmV4cG9ydCBjb25zdCBbVFVJX0ZJTEVfT1BUSU9OUywgdHVpRmlsZU9wdGlvbnNQcm92aWRlcl0gPSB0dWlDcmVhdGVPcHRpb25zKFxuICAgIFRVSV9GSUxFX0RFRkFVTFRfT1BUSU9OUyxcbik7XG4iXX0=
|
|
@@ -15,7 +15,7 @@ export function tuiFilesAccepted(control) {
|
|
|
15
15
|
const format = control?.getError(TUI_FORMAT_ERROR)?.$implicit || [];
|
|
16
16
|
return files.filter((file) => !size.includes(file) && !format.includes(file));
|
|
17
17
|
}
|
|
18
|
-
export function tuiFormatSize(units, size) {
|
|
18
|
+
export function tuiFormatSize(units, size, locale) {
|
|
19
19
|
if (size === undefined) {
|
|
20
20
|
return null;
|
|
21
21
|
}
|
|
@@ -25,6 +25,6 @@ export function tuiFormatSize(units, size) {
|
|
|
25
25
|
if (size < BYTES_PER_MIB) {
|
|
26
26
|
return `${(size / BYTES_PER_KIB).toFixed(0)} ${units[1]}`;
|
|
27
27
|
}
|
|
28
|
-
return `${tuiRound(size / BYTES_PER_MIB, 2).toLocaleString(
|
|
28
|
+
return `${tuiRound(size / BYTES_PER_MIB, 2).toLocaleString(locale)} ${units[2]}`;
|
|
29
29
|
}
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZXMudXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9maWxlcy9maWxlcy51dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFFbEQsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBRWxELE9BQU8sRUFBQyxnQkFBZ0IsRUFBRSxjQUFjLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUVwRSxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUM7QUFDM0IsTUFBTSxhQUFhLEdBQUcsSUFBSSxHQUFHLGFBQWEsQ0FBQztBQUUzQyxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsT0FBZ0M7SUFDN0QsTUFBTSxNQUFNLEdBQVcsT0FBTyxFQUFFLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLFNBQVMsSUFBSSxFQUFFLENBQUM7SUFDNUUsTUFBTSxJQUFJLEdBQVcsT0FBTyxFQUFFLFFBQVEsQ0FBQyxjQUFjLENBQUMsRUFBRSxTQUFTLElBQUksRUFBRSxDQUFDO0lBRXhFLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLEdBQUcsQ0FBQyxDQUFDLEdBQUcsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3JELENBQUM7QUFFRCxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsT0FBZ0M7SUFDN0QsTUFBTSxLQUFLLEdBQUcsT0FBTyxFQUFFLEtBQUssSUFBSSxFQUFFLENBQUM7SUFDbkMsTUFBTSxLQUFLLEdBQVcsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3pDLE1BQU0sSUFBSSxHQUFXLE9BQU8sRUFBRSxRQUFRLENBQUMsY0FBYyxDQUFDLEVBQUUsU0FBUyxJQUFJLEVBQUUsQ0FBQztJQUN4RSxNQUFNLE1BQU0sR0FBVyxPQUFPLEVBQUUsUUFBUSxDQUFDLGdCQUFnQixDQUFDLEVBQUUsU0FBUyxJQUFJLEVBQUUsQ0FBQztJQUU1RSxPQUFPLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztBQUNsRixDQUFDO0FBRUQsTUFBTSxVQUFVLGFBQWEsQ0FDekIsS0FBd0MsRUFDeEMsSUFBYSxFQUNiLE1BQWU7SUFFZixJQUFJLElBQUksS0FBSyxTQUFTLEVBQUU7UUFDcEIsT0FBTyxJQUFJLENBQUM7S0FDZjtJQUVELElBQUksSUFBSSxHQUFHLGFBQWEsRUFBRTtRQUN0QixPQUFPLEdBQUcsSUFBSSxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO0tBQ2hDO0lBRUQsSUFBSSxJQUFJLEdBQUcsYUFBYSxFQUFFO1FBQ3RCLE9BQU8sR0FBRyxDQUFDLElBQUksR0FBRyxhQUFhLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7S0FDN0Q7SUFFRCxPQUFPLEdBQUcsUUFBUSxDQUFDLElBQUksR0FBRyxhQUFhLEVBQUUsQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO0FBQ3JGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge2NvZXJjZUFycmF5fSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nO1xuaW1wb3J0IHR5cGUge0Fic3RyYWN0Q29udHJvbH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHt0dWlSb3VuZH0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9tYXRoJztcblxuaW1wb3J0IHtUVUlfRk9STUFUX0VSUk9SLCBUVUlfU0laRV9FUlJPUn0gZnJvbSAnLi9maWxlcy52YWxpZGF0b3JzJztcblxuY29uc3QgQllURVNfUEVSX0tJQiA9IDEwMjQ7XG5jb25zdCBCWVRFU19QRVJfTUlCID0gMTAyNCAqIEJZVEVTX1BFUl9LSUI7XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlGaWxlc1JlamVjdGVkKGNvbnRyb2w/OiBBYnN0cmFjdENvbnRyb2wgfCBudWxsKTogRmlsZVtdIHtcbiAgICBjb25zdCBmb3JtYXQ6IEZpbGVbXSA9IGNvbnRyb2w/LmdldEVycm9yKFRVSV9GT1JNQVRfRVJST1IpPy4kaW1wbGljaXQgfHwgW107XG4gICAgY29uc3Qgc2l6ZTogRmlsZVtdID0gY29udHJvbD8uZ2V0RXJyb3IoVFVJX1NJWkVfRVJST1IpPy4kaW1wbGljaXQgfHwgW107XG5cbiAgICByZXR1cm4gQXJyYXkuZnJvbShuZXcgU2V0KFsuLi5mb3JtYXQsIC4uLnNpemVdKSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlGaWxlc0FjY2VwdGVkKGNvbnRyb2w/OiBBYnN0cmFjdENvbnRyb2wgfCBudWxsKTogRmlsZVtdIHtcbiAgICBjb25zdCB2YWx1ZSA9IGNvbnRyb2w/LnZhbHVlIHx8IFtdO1xuICAgIGNvbnN0IGZpbGVzOiBGaWxlW10gPSBjb2VyY2VBcnJheSh2YWx1ZSk7XG4gICAgY29uc3Qgc2l6ZTogRmlsZVtdID0gY29udHJvbD8uZ2V0RXJyb3IoVFVJX1NJWkVfRVJST1IpPy4kaW1wbGljaXQgfHwgW107XG4gICAgY29uc3QgZm9ybWF0OiBGaWxlW10gPSBjb250cm9sPy5nZXRFcnJvcihUVUlfRk9STUFUX0VSUk9SKT8uJGltcGxpY2l0IHx8IFtdO1xuXG4gICAgcmV0dXJuIGZpbGVzLmZpbHRlcigoZmlsZSkgPT4gIXNpemUuaW5jbHVkZXMoZmlsZSkgJiYgIWZvcm1hdC5pbmNsdWRlcyhmaWxlKSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlGb3JtYXRTaXplKFxuICAgIHVuaXRzOiByZWFkb25seSBbc3RyaW5nLCBzdHJpbmcsIHN0cmluZ10sXG4gICAgc2l6ZT86IG51bWJlcixcbiAgICBsb2NhbGU/OiBzdHJpbmcsXG4pOiBzdHJpbmcgfCBudWxsIHtcbiAgICBpZiAoc2l6ZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cblxuICAgIGlmIChzaXplIDwgQllURVNfUEVSX0tJQikge1xuICAgICAgICByZXR1cm4gYCR7c2l6ZX0gJHt1bml0c1swXX1gO1xuICAgIH1cblxuICAgIGlmIChzaXplIDwgQllURVNfUEVSX01JQikge1xuICAgICAgICByZXR1cm4gYCR7KHNpemUgLyBCWVRFU19QRVJfS0lCKS50b0ZpeGVkKDApfSAke3VuaXRzWzFdfWA7XG4gICAgfVxuXG4gICAgcmV0dXJuIGAke3R1aVJvdW5kKHNpemUgLyBCWVRFU19QRVJfTUlCLCAyKS50b0xvY2FsZVN0cmluZyhsb2NhbGUpfSAke3VuaXRzWzJdfWA7XG59XG4iXX0=
|
|
@@ -23,6 +23,7 @@ export * from '@taiga-ui/kit/components/files';
|
|
|
23
23
|
export * from '@taiga-ui/kit/components/filter';
|
|
24
24
|
export * from '@taiga-ui/kit/components/floating-container';
|
|
25
25
|
export * from '@taiga-ui/kit/components/input-date';
|
|
26
|
+
export * from '@taiga-ui/kit/components/input-date-range';
|
|
26
27
|
export * from '@taiga-ui/kit/components/input-inline';
|
|
27
28
|
export * from '@taiga-ui/kit/components/input-month';
|
|
28
29
|
export * from '@taiga-ui/kit/components/input-month-range';
|
|
@@ -58,4 +59,4 @@ export * from '@taiga-ui/kit/components/tabs';
|
|
|
58
59
|
export * from '@taiga-ui/kit/components/textarea';
|
|
59
60
|
export * from '@taiga-ui/kit/components/tiles';
|
|
60
61
|
export * from '@taiga-ui/kit/components/tree';
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLCtCQUErQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2FjY29yZGlvbic7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvYWN0aW9uLWJhcic7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvYXZhdGFyJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9iYWRnZSc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvYmFkZ2Utbm90aWZpY2F0aW9uJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9iYWRnZWQtY29udGVudCc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvYmxvY2snO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2JyZWFkY3J1bWJzJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9idXR0b24tbG9hZGluZyc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvY2FsZW5kYXItbW9udGgnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2NhbGVuZGFyLXJhbmdlJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9jYXJvdXNlbCc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvY2hlY2tib3gnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2NoaXAnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2NvbWJvLWJveCc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvY29tbWVudCc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvY29tcGFzcyc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvY29uZmlybSc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvZGF0YS1saXN0LXdyYXBwZXInO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2RyYXdlcic7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvZWxhc3RpYy1jb250YWluZXInO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2ZpbGVzJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9maWx0ZXInO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2Zsb2F0aW5nLWNvbnRhaW5lcic7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtZGF0ZSc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtZGF0ZS1yYW5nZSc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtaW5saW5lJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9pbnB1dC1tb250aCc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtbW9udGgtcmFuZ2UnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2lucHV0LW51bWJlcic7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtcGFzc3dvcmQnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2lucHV0LXBob25lLWludGVybmF0aW9uYWwnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2lucHV0LXBpbic7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtc2xpZGVyJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9pdGVtcy13aXRoLW1vcmUnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2xpa2UnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2xpbmUtY2xhbXAnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL21lc3NhZ2UnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3BhZ2VyJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9wYWdpbmF0aW9uJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9wZGYtdmlld2VyJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9waW4nO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3ByZXZpZXcnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3Byb2dyZXNzJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9wdWxzZSc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvcHVzaCc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvcmFkaW8nO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3JhZGlvLWxpc3QnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3JhbmdlJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9yYXRpbmcnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3JvdXRhYmxlLWRpYWxvZyc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvc2VnbWVudGVkJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9zZWxlY3QnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3NsaWRlcic7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvc3RhdHVzJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9zdGVwcGVyJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy9zd2l0Y2gnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3RhYnMnO1xuZXhwb3J0ICogZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL3RleHRhcmVhJztcbmV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9raXQvY29tcG9uZW50cy90aWxlcyc7XG5leHBvcnQgKiBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvdHJlZSc7XG4iXX0=
|
|
@@ -2,5 +2,4 @@ export * from './input-date';
|
|
|
2
2
|
export * from './input-date.component';
|
|
3
3
|
export * from './input-date.directive';
|
|
4
4
|
export * from './input-date.options';
|
|
5
|
-
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1kYXRlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2lucHV0LWRhdGUnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1kYXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LWRhdGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtZGF0ZS5vcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtZGF0ZS52YWxpZGF0b3InO1xuIl19
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1kYXRlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHNCQUFzQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1kYXRlJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtZGF0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1kYXRlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LWRhdGUub3B0aW9ucyc7XG4iXX0=
|