@taiga-ui/kit 4.42.0-canary.551f28f → 4.42.0-canary.a1d4758
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/index.d.ts +0 -1
- package/components/input-chip/input-chip.component.d.ts +2 -2
- package/components/input-chip/input-chip.directive.d.ts +0 -2
- package/components/input-date/input-date.directive.d.ts +1 -2
- package/components/input-date-range/input-date-range.directive.d.ts +0 -1
- package/components/select/select-option/select-option.component.d.ts +4 -2
- package/directives/button-select/button-select.directive.d.ts +2 -3
- package/esm2022/components/badge/badge.directive.mjs +2 -2
- package/esm2022/components/calendar-month/calendar-month.component.mjs +3 -3
- package/esm2022/components/combo-box/combo-box.directive.mjs +5 -2
- package/esm2022/components/files/input-files/input-files.directive.mjs +2 -3
- package/esm2022/components/index.mjs +1 -2
- package/esm2022/components/input-chip/input-chip.component.mjs +13 -15
- package/esm2022/components/input-chip/input-chip.directive.mjs +9 -20
- package/esm2022/components/input-date/input-date.directive.mjs +3 -11
- package/esm2022/components/input-date-range/input-date-range.directive.mjs +2 -6
- package/esm2022/components/input-inline/input-inline.component.mjs +1 -1
- package/esm2022/components/select/select-option/select-option.component.mjs +18 -10
- package/esm2022/components/select/select.directive.mjs +4 -1
- package/esm2022/components/tabs/tabs.directive.mjs +2 -2
- package/esm2022/directives/button-select/button-select.directive.mjs +7 -15
- package/esm2022/pipes/index.mjs +1 -2
- package/esm2022/tokens/items-handlers.mjs +4 -4
- package/esm2022/utils/index.mjs +1 -2
- package/fesm2022/taiga-ui-kit-components-badge.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-badge.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-calendar-month.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-calendar-month.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-combo-box.mjs +4 -1
- package/fesm2022/taiga-ui-kit-components-combo-box.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-files.mjs +1 -2
- package/fesm2022/taiga-ui-kit-components-files.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-chip.mjs +95 -109
- package/fesm2022/taiga-ui-kit-components-input-chip.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-date-range.mjs +0 -4
- package/fesm2022/taiga-ui-kit-components-input-date-range.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-date.mjs +2 -10
- package/fesm2022/taiga-ui-kit-components-input-date.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-input-inline.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-select.mjs +20 -11
- package/fesm2022/taiga-ui-kit-components-select.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components-tabs.mjs +2 -2
- package/fesm2022/taiga-ui-kit-components-tabs.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-components.mjs +0 -1
- package/fesm2022/taiga-ui-kit-components.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-directives-button-select.mjs +6 -14
- package/fesm2022/taiga-ui-kit-directives-button-select.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-pipes.mjs +0 -1
- package/fesm2022/taiga-ui-kit-pipes.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-tokens.mjs +3 -3
- package/fesm2022/taiga-ui-kit-tokens.mjs.map +1 -1
- package/fesm2022/taiga-ui-kit-utils.mjs +1 -12
- package/fesm2022/taiga-ui-kit-utils.mjs.map +1 -1
- package/package.json +19 -31
- package/pipes/index.d.ts +0 -1
- package/styles/components/badge.less +13 -1
- package/tokens/items-handlers.d.ts +4 -4
- package/utils/index.d.ts +0 -1
- package/components/input-time/index.d.ts +0 -4
- package/components/input-time/input-time.component.d.ts +0 -14
- package/components/input-time/input-time.d.ts +0 -3
- package/components/input-time/input-time.directive.d.ts +0 -31
- package/components/input-time/input-time.options.d.ts +0 -11
- package/esm2022/components/input-time/index.mjs +0 -5
- package/esm2022/components/input-time/input-time.component.mjs +0 -49
- package/esm2022/components/input-time/input-time.directive.mjs +0 -123
- package/esm2022/components/input-time/input-time.mjs +0 -4
- package/esm2022/components/input-time/input-time.options.mjs +0 -9
- package/esm2022/components/input-time/taiga-ui-kit-components-input-time.mjs +0 -5
- package/esm2022/pipes/hide-selected/hide-selected.pipe.mjs +0 -46
- package/esm2022/pipes/hide-selected/index.mjs +0 -2
- package/esm2022/pipes/hide-selected/taiga-ui-kit-pipes-hide-selected.mjs +0 -5
- package/esm2022/utils/inject-value.mjs +0 -11
- package/fesm2022/taiga-ui-kit-components-input-time.mjs +0 -180
- package/fesm2022/taiga-ui-kit-components-input-time.mjs.map +0 -1
- package/fesm2022/taiga-ui-kit-pipes-hide-selected.mjs +0 -52
- package/fesm2022/taiga-ui-kit-pipes-hide-selected.mjs.map +0 -1
- package/pipes/hide-selected/hide-selected.pipe.d.ts +0 -12
- package/pipes/hide-selected/index.d.ts +0 -1
- package/utils/inject-value.d.ts +0 -2
|
@@ -2,16 +2,16 @@ import { NgIf } from '@angular/common';
|
|
|
2
2
|
import { ChangeDetectionStrategy, Component, computed, ElementRef, inject, Input, signal, ViewChild, } from '@angular/core';
|
|
3
3
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
4
|
import { TUI_IS_MOBILE } from '@taiga-ui/cdk/tokens';
|
|
5
|
-
import { tuiDirectiveBinding
|
|
5
|
+
import { tuiDirectiveBinding } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
6
6
|
import { TuiButton } from '@taiga-ui/core/components/button';
|
|
7
|
-
import { TUI_TEXTFIELD_OPTIONS,
|
|
7
|
+
import { TUI_TEXTFIELD_OPTIONS, tuiInjectAuxiliary, } from '@taiga-ui/core/components/textfield';
|
|
8
8
|
import { TuiAppearance } from '@taiga-ui/core/directives/appearance';
|
|
9
9
|
import { TuiHintDirective, TuiHintOverflow } from '@taiga-ui/core/directives/hint';
|
|
10
10
|
import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives/items-handlers';
|
|
11
11
|
import { TuiChip } from '@taiga-ui/kit/components/chip';
|
|
12
12
|
import { TuiFade } from '@taiga-ui/kit/directives/fade';
|
|
13
|
-
import { tuiInjectValue } from '@taiga-ui/kit/utils';
|
|
14
13
|
import { injectContext } from '@taiga-ui/polymorpheus';
|
|
14
|
+
import { TuiInputChipDirective } from './input-chip.directive';
|
|
15
15
|
import * as i0 from "@angular/core";
|
|
16
16
|
import * as i1 from "@taiga-ui/kit/components/chip";
|
|
17
17
|
import * as i2 from "@angular/forms";
|
|
@@ -19,13 +19,13 @@ class TuiInputChipComponent {
|
|
|
19
19
|
constructor() {
|
|
20
20
|
this.options = inject(TUI_TEXTFIELD_OPTIONS);
|
|
21
21
|
this.context = injectContext();
|
|
22
|
-
this.value =
|
|
22
|
+
this.value = computed(() => this.directive()?.value() ?? []);
|
|
23
23
|
this.mobile = inject(TUI_IS_MOBILE);
|
|
24
24
|
this.internal = signal(this.context.$implicit.item);
|
|
25
25
|
this.editing = signal(false);
|
|
26
26
|
this.hint = inject(TuiHintDirective, { self: true, optional: true });
|
|
27
27
|
this.handlers = inject(TUI_ITEMS_HANDLERS);
|
|
28
|
-
this.
|
|
28
|
+
this.directive = tuiInjectAuxiliary((x) => x instanceof TuiInputChipDirective);
|
|
29
29
|
this.disabled = tuiDirectiveBinding(TuiAppearance, 'tuiAppearanceState', computed(() => this.handlers.disabledItemHandler()(this.context.$implicit.item)
|
|
30
30
|
? 'disabled'
|
|
31
31
|
: null));
|
|
@@ -36,9 +36,9 @@ class TuiInputChipComponent {
|
|
|
36
36
|
return this.context.$implicit.index;
|
|
37
37
|
}
|
|
38
38
|
delete() {
|
|
39
|
-
this.
|
|
39
|
+
this.directive()?.onChange(this.value().filter((_, i) => i !== this.index));
|
|
40
40
|
if (!this.mobile) {
|
|
41
|
-
this.
|
|
41
|
+
this.directive()?.el.focus({ preventScroll: true });
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
44
|
save() {
|
|
@@ -49,25 +49,23 @@ class TuiInputChipComponent {
|
|
|
49
49
|
return;
|
|
50
50
|
}
|
|
51
51
|
const value = this.value().map((item, index) => index === this.index ? this.internal() : item);
|
|
52
|
-
this.
|
|
52
|
+
this.directive()?.onChange(value);
|
|
53
53
|
this.editing.set(false);
|
|
54
|
-
this.
|
|
54
|
+
this.directive()?.el.focus({ preventScroll: true });
|
|
55
55
|
}
|
|
56
56
|
cancel() {
|
|
57
57
|
this.editing.set(false);
|
|
58
58
|
this.internal.set(this.context.$implicit.item);
|
|
59
59
|
}
|
|
60
60
|
edit() {
|
|
61
|
-
if (!this.editable ||
|
|
62
|
-
!this.textfield.cva?.interactive() ||
|
|
63
|
-
!tuiIsString(this.internal())) {
|
|
61
|
+
if (!this.editable || !this.directive()?.interactive()) {
|
|
64
62
|
return;
|
|
65
63
|
}
|
|
66
64
|
this.editing.set(true);
|
|
67
65
|
setTimeout(() => this.input?.nativeElement.focus());
|
|
68
66
|
}
|
|
69
67
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputChipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
70
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputChipComponent, isStandalone: true, selector: "tui-input-chip", inputs: { editable: "editable" }, host: { attributes: { "tuiChip": "" }, listeners: { "click": "editing() && $event.stopPropagation()", "keydown.backspace.prevent": "delete()", "keydown.enter.prevent": "edit()", "dblclick": "edit()" }, properties: { "class._edit": "editing()", "attr.tabIndex": "disabled() ? null : -1" }, classAttribute: "tui-interactive" }, viewQueries: [{ propertyName: "input", first: true, predicate: TuiChip, descendants: true, read: ElementRef }], hostDirectives: [{ directive: i1.TuiChip }], ngImport: i0, template: "<input\n appearance=\"\"\n enterkeyhint=\"enter\"\n tuiChip\n class=\"t-input\"\n [disabled]=\"!editing()\"\n [ngModel]=\"internal()\"\n (blur)=\"cancel()\"\n (keydown.enter)=\"save()\"\n (keydown.esc)=\"cancel()\"\n (keydown.stop)=\"(0)\"\n (ngModelChange)=\"internal.set($event)\"\n/>\n<div\n tuiFade\n tuiFadeOffset=\"0.5rem\"\n class=\"t-text\"\n [tuiHintOverflow]=\"hint?.content() ? null : handlers.stringify()(internal())\"\n (mousedown.prevent.zoneless)=\"(0)\"\n>\n {{
|
|
68
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputChipComponent, isStandalone: true, selector: "tui-input-chip", inputs: { editable: "editable" }, host: { attributes: { "tuiChip": "" }, listeners: { "click": "editing() && $event.stopPropagation()", "keydown.backspace.prevent": "delete()", "keydown.enter.prevent": "edit()", "dblclick": "edit()" }, properties: { "class._edit": "editing()", "attr.tabIndex": "disabled() ? null : -1" }, classAttribute: "tui-interactive" }, viewQueries: [{ propertyName: "input", first: true, predicate: TuiChip, descendants: true, read: ElementRef }], hostDirectives: [{ directive: i1.TuiChip }], ngImport: i0, template: "<input\n appearance=\"\"\n enterkeyhint=\"enter\"\n tuiChip\n class=\"t-input\"\n [disabled]=\"!editing()\"\n [ngModel]=\"internal()\"\n (blur)=\"cancel()\"\n (keydown.enter)=\"save()\"\n (keydown.esc)=\"cancel()\"\n (keydown.stop)=\"(0)\"\n (ngModelChange)=\"internal.set($event)\"\n/>\n<div\n tuiFade\n tuiFadeOffset=\"0.5rem\"\n class=\"t-text\"\n [tuiHintOverflow]=\"hint?.content() ? null : handlers.stringify()(internal())\"\n (mousedown.prevent.zoneless)=\"(0)\"\n>\n {{ internal() }}\n</div>\n<button\n *ngIf=\"directive()?.interactive() && !editing() && !disabled()\"\n iconStart=\"@tui.x\"\n tabIndex=\"-1\"\n tuiIconButton\n type=\"button\"\n (click.stop)=\"delete()\"\n (pointerdown.prevent.stop.zoneless)=\"(0)\"\n>\n Remove\n</button>\n", styles: [":host{cursor:pointer}:host[data-state=disabled]{pointer-events:none}:host .t-input{padding:0;text-indent:.375rem;transition:none;color:var(--tui-text-primary);cursor:text;outline:none}:host .t-input:disabled{visibility:hidden}:host._edit{background:transparent}:host._edit .t-text{pointer-events:none;visibility:hidden}:host._edit:before{color:transparent;transition:none}:host-context(tui-textfield[data-size=\"s\"]){left:-.375rem;margin:.0625rem .125rem .0625rem 0}:host-context(tui-textfield[data-size=\"m\"]){left:-.125rem;margin:.125rem .25rem .125rem 0}:host-context(tui-textfield[data-size=\"l\"]){left:-.25rem;margin:.125rem .25rem .125rem 0}:host-context(tui-textfield[data-size=\"l\"]) .t-input{text-indent:.625rem}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "directive", type: TuiChip, selector: "tui-chip,[tuiChip]", inputs: ["size"] }, { kind: "directive", type: TuiFade, selector: "[tuiFade]", inputs: ["tuiFadeHeight", "tuiFadeSize", "tuiFadeOffset", "tuiFade"] }, { kind: "directive", type: TuiHintOverflow, selector: "[tuiHintOverflow]", inputs: ["tuiHintOverflow"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
71
69
|
}
|
|
72
70
|
export { TuiInputChipComponent };
|
|
73
71
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputChipComponent, decorators: [{
|
|
@@ -89,11 +87,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
89
87
|
'(keydown.backspace.prevent)': 'delete()',
|
|
90
88
|
'(keydown.enter.prevent)': 'edit()',
|
|
91
89
|
'(dblclick)': 'edit()',
|
|
92
|
-
}, template: "<input\n appearance=\"\"\n enterkeyhint=\"enter\"\n tuiChip\n class=\"t-input\"\n [disabled]=\"!editing()\"\n [ngModel]=\"internal()\"\n (blur)=\"cancel()\"\n (keydown.enter)=\"save()\"\n (keydown.esc)=\"cancel()\"\n (keydown.stop)=\"(0)\"\n (ngModelChange)=\"internal.set($event)\"\n/>\n<div\n tuiFade\n tuiFadeOffset=\"0.5rem\"\n class=\"t-text\"\n [tuiHintOverflow]=\"hint?.content() ? null : handlers.stringify()(internal())\"\n (mousedown.prevent.zoneless)=\"(0)\"\n>\n {{
|
|
90
|
+
}, template: "<input\n appearance=\"\"\n enterkeyhint=\"enter\"\n tuiChip\n class=\"t-input\"\n [disabled]=\"!editing()\"\n [ngModel]=\"internal()\"\n (blur)=\"cancel()\"\n (keydown.enter)=\"save()\"\n (keydown.esc)=\"cancel()\"\n (keydown.stop)=\"(0)\"\n (ngModelChange)=\"internal.set($event)\"\n/>\n<div\n tuiFade\n tuiFadeOffset=\"0.5rem\"\n class=\"t-text\"\n [tuiHintOverflow]=\"hint?.content() ? null : handlers.stringify()(internal())\"\n (mousedown.prevent.zoneless)=\"(0)\"\n>\n {{ internal() }}\n</div>\n<button\n *ngIf=\"directive()?.interactive() && !editing() && !disabled()\"\n iconStart=\"@tui.x\"\n tabIndex=\"-1\"\n tuiIconButton\n type=\"button\"\n (click.stop)=\"delete()\"\n (pointerdown.prevent.stop.zoneless)=\"(0)\"\n>\n Remove\n</button>\n", styles: [":host{cursor:pointer}:host[data-state=disabled]{pointer-events:none}:host .t-input{padding:0;text-indent:.375rem;transition:none;color:var(--tui-text-primary);cursor:text;outline:none}:host .t-input:disabled{visibility:hidden}:host._edit{background:transparent}:host._edit .t-text{pointer-events:none;visibility:hidden}:host._edit:before{color:transparent;transition:none}:host-context(tui-textfield[data-size=\"s\"]){left:-.375rem;margin:.0625rem .125rem .0625rem 0}:host-context(tui-textfield[data-size=\"m\"]){left:-.125rem;margin:.125rem .25rem .125rem 0}:host-context(tui-textfield[data-size=\"l\"]){left:-.25rem;margin:.125rem .25rem .125rem 0}:host-context(tui-textfield[data-size=\"l\"]) .t-input{text-indent:.625rem}\n"] }]
|
|
93
91
|
}], propDecorators: { input: [{
|
|
94
92
|
type: ViewChild,
|
|
95
93
|
args: [TuiChip, { read: ElementRef }]
|
|
96
94
|
}], editable: [{
|
|
97
95
|
type: Input
|
|
98
96
|
}] } });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-chip.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-chip/input-chip.component.ts","../../../../../projects/kit/components/input-chip/input-chip.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    ElementRef,\n    inject,\n    Input,\n    signal,\n    ViewChild,\n} from '@angular/core';\nimport {FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport type {TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiDirectiveBinding, tuiIsString} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport type {TuiTextfieldItem} from '@taiga-ui/core/components/textfield';\nimport {\n    TUI_TEXTFIELD_OPTIONS,\n    TuiTextfieldComponent,\n} from '@taiga-ui/core/components/textfield';\nimport {TuiAppearance} from '@taiga-ui/core/directives/appearance';\nimport {TuiHintDirective, TuiHintOverflow} from '@taiga-ui/core/directives/hint';\nimport type {TuiItemsHandlers} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_ITEMS_HANDLERS} from '@taiga-ui/core/directives/items-handlers';\nimport {TuiChip} from '@taiga-ui/kit/components/chip';\nimport {TuiFade} from '@taiga-ui/kit/directives/fade';\nimport {tuiInjectValue} from '@taiga-ui/kit/utils';\nimport {injectContext} from '@taiga-ui/polymorpheus';\n\n@Component({\n    standalone: true,\n    selector: 'tui-input-chip',\n    imports: [\n        FormsModule,\n        NgIf,\n        ReactiveFormsModule,\n        TuiButton,\n        TuiChip,\n        TuiFade,\n        TuiHintOverflow,\n    ],\n    templateUrl: './input-chip.template.html',\n    styleUrls: ['./input-chip.styles.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    hostDirectives: [TuiChip],\n    host: {\n        tuiChip: '',\n        class: 'tui-interactive',\n        '[class._edit]': 'editing()',\n        '[attr.tabIndex]': 'disabled() ? null : -1',\n        '(click)': 'editing() && $event.stopPropagation()',\n        '(keydown.backspace.prevent)': 'delete()',\n        '(keydown.enter.prevent)': 'edit()',\n        '(dblclick)': 'edit()',\n    },\n})\nexport class TuiInputChipComponent<T> {\n    @ViewChild(TuiChip, {read: ElementRef})\n    private readonly input?: ElementRef<HTMLInputElement>;\n\n    private readonly options = inject(TUI_TEXTFIELD_OPTIONS);\n    private readonly context = injectContext<TuiContext<TuiTextfieldItem<T>>>();\n    private readonly value = tuiInjectValue<readonly T[]>();\n\n    protected readonly mobile = inject(TUI_IS_MOBILE);\n    protected readonly internal = signal(this.context.$implicit.item);\n    protected readonly editing = signal(false);\n    protected readonly hint = inject(TuiHintDirective, {self: true, optional: true});\n    protected readonly handlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n    protected readonly textfield = inject(TuiTextfieldComponent);\n\n    protected readonly disabled = tuiDirectiveBinding(\n        TuiAppearance,\n        'tuiAppearanceState',\n        computed(() =>\n            this.handlers.disabledItemHandler()(this.context.$implicit.item)\n                ? 'disabled'\n                : null,\n        ),\n    );\n\n    protected readonly size = tuiDirectiveBinding(\n        TuiChip,\n        'size',\n        computed(() => (this.options.size() === 'l' ? 's' : 'xs')),\n    );\n\n    @Input()\n    public editable = true;\n\n    protected get index(): number {\n        return this.context.$implicit.index;\n    }\n\n    protected delete(): void {\n        this.textfield.cva?.onChange(this.value().filter((_, i) => i !== this.index));\n\n        if (!this.mobile) {\n            this.textfield.input?.nativeElement.focus({preventScroll: true});\n        }\n    }\n\n    protected save(): void {\n        if (!this.internal()) {\n            this.delete();\n        } else if (this.handlers.disabledItemHandler()(this.internal())) {\n            return;\n        }\n\n        const value = this.value().map((item, index) =>\n            index === this.index ? this.internal() : item,\n        );\n\n        this.textfield.cva?.onChange(value);\n        this.editing.set(false);\n        this.textfield.input?.nativeElement.focus({preventScroll: true});\n    }\n\n    protected cancel(): void {\n        this.editing.set(false);\n        this.internal.set(this.context.$implicit.item);\n    }\n\n    protected edit(): void {\n        if (\n            !this.editable ||\n            !this.textfield.cva?.interactive() ||\n            !tuiIsString(this.internal())\n        ) {\n            return;\n        }\n\n        this.editing.set(true);\n        setTimeout(() => this.input?.nativeElement.focus());\n    }\n}\n","<input\n    appearance=\"\"\n    enterkeyhint=\"enter\"\n    tuiChip\n    class=\"t-input\"\n    [disabled]=\"!editing()\"\n    [ngModel]=\"internal()\"\n    (blur)=\"cancel()\"\n    (keydown.enter)=\"save()\"\n    (keydown.esc)=\"cancel()\"\n    (keydown.stop)=\"(0)\"\n    (ngModelChange)=\"internal.set($event)\"\n/>\n<div\n    tuiFade\n    tuiFadeOffset=\"0.5rem\"\n    class=\"t-text\"\n    [tuiHintOverflow]=\"hint?.content() ? null : handlers.stringify()(internal())\"\n    (mousedown.prevent.zoneless)=\"(0)\"\n>\n    {{ handlers.stringify()(internal()) }}\n</div>\n<button\n    *ngIf=\"textfield.cva?.interactive() && !editing() && !disabled()\"\n    iconStart=\"@tui.x\"\n    tabIndex=\"-1\"\n    tuiIconButton\n    type=\"button\"\n    (click.stop)=\"delete()\"\n    (pointerdown.prevent.stop.zoneless)=\"(0)\"\n>\n    Remove\n</button>\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-chip.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-chip/input-chip.component.ts","../../../../../projects/kit/components/input-chip/input-chip.template.html"],"names":[],"mappings":"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","sourcesContent":["import {NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    ElementRef,\n    inject,\n    Input,\n    signal,\n    ViewChild,\n} from '@angular/core';\nimport {FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport type {TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiDirectiveBinding} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport type {TuiTextfieldItem} from '@taiga-ui/core/components/textfield';\nimport {\n    TUI_TEXTFIELD_OPTIONS,\n    tuiInjectAuxiliary,\n} from '@taiga-ui/core/components/textfield';\nimport {TuiAppearance} from '@taiga-ui/core/directives/appearance';\nimport {TuiHintDirective, TuiHintOverflow} from '@taiga-ui/core/directives/hint';\nimport type {TuiItemsHandlers} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_ITEMS_HANDLERS} from '@taiga-ui/core/directives/items-handlers';\nimport {TuiChip} from '@taiga-ui/kit/components/chip';\nimport {TuiFade} from '@taiga-ui/kit/directives/fade';\nimport {injectContext} from '@taiga-ui/polymorpheus';\n\nimport {TuiInputChipDirective} from './input-chip.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-input-chip',\n    imports: [\n        FormsModule,\n        NgIf,\n        ReactiveFormsModule,\n        TuiButton,\n        TuiChip,\n        TuiFade,\n        TuiHintOverflow,\n    ],\n    templateUrl: './input-chip.template.html',\n    styleUrls: ['./input-chip.styles.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    hostDirectives: [TuiChip],\n    host: {\n        tuiChip: '',\n        class: 'tui-interactive',\n        '[class._edit]': 'editing()',\n        '[attr.tabIndex]': 'disabled() ? null : -1',\n        '(click)': 'editing() && $event.stopPropagation()',\n        '(keydown.backspace.prevent)': 'delete()',\n        '(keydown.enter.prevent)': 'edit()',\n        '(dblclick)': 'edit()',\n    },\n})\nexport class TuiInputChipComponent<T> {\n    @ViewChild(TuiChip, {read: ElementRef})\n    private readonly input?: ElementRef<HTMLInputElement>;\n\n    private readonly options = inject(TUI_TEXTFIELD_OPTIONS);\n    private readonly context = injectContext<TuiContext<TuiTextfieldItem<T>>>();\n    private readonly value = computed(() => this.directive()?.value() ?? []);\n\n    protected readonly mobile = inject(TUI_IS_MOBILE);\n    protected readonly internal = signal(this.context.$implicit.item);\n    protected readonly editing = signal(false);\n    protected readonly hint = inject(TuiHintDirective, {self: true, optional: true});\n    protected readonly handlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n\n    protected readonly directive = tuiInjectAuxiliary<TuiInputChipDirective<T>>(\n        (x) => x instanceof TuiInputChipDirective,\n    );\n\n    protected readonly disabled = tuiDirectiveBinding(\n        TuiAppearance,\n        'tuiAppearanceState',\n        computed(() =>\n            this.handlers.disabledItemHandler()(this.context.$implicit.item)\n                ? 'disabled'\n                : null,\n        ),\n    );\n\n    protected readonly size = tuiDirectiveBinding(\n        TuiChip,\n        'size',\n        computed(() => (this.options.size() === 'l' ? 's' : 'xs')),\n    );\n\n    @Input()\n    public editable = true;\n\n    protected get index(): number {\n        return this.context.$implicit.index;\n    }\n\n    protected delete(): void {\n        this.directive()?.onChange(this.value().filter((_, i) => i !== this.index));\n\n        if (!this.mobile) {\n            this.directive()?.el.focus({preventScroll: true});\n        }\n    }\n\n    protected save(): void {\n        if (!this.internal()) {\n            this.delete();\n        } else if (this.handlers.disabledItemHandler()(this.internal())) {\n            return;\n        }\n\n        const value = this.value().map((item, index) =>\n            index === this.index ? this.internal() : item,\n        );\n\n        this.directive()?.onChange(value);\n        this.editing.set(false);\n        this.directive()?.el.focus({preventScroll: true});\n    }\n\n    protected cancel(): void {\n        this.editing.set(false);\n        this.internal.set(this.context.$implicit.item);\n    }\n\n    protected edit(): void {\n        if (!this.editable || !this.directive()?.interactive()) {\n            return;\n        }\n\n        this.editing.set(true);\n        setTimeout(() => this.input?.nativeElement.focus());\n    }\n}\n","<input\n    appearance=\"\"\n    enterkeyhint=\"enter\"\n    tuiChip\n    class=\"t-input\"\n    [disabled]=\"!editing()\"\n    [ngModel]=\"internal()\"\n    (blur)=\"cancel()\"\n    (keydown.enter)=\"save()\"\n    (keydown.esc)=\"cancel()\"\n    (keydown.stop)=\"(0)\"\n    (ngModelChange)=\"internal.set($event)\"\n/>\n<div\n    tuiFade\n    tuiFadeOffset=\"0.5rem\"\n    class=\"t-text\"\n    [tuiHintOverflow]=\"hint?.content() ? null : handlers.stringify()(internal())\"\n    (mousedown.prevent.zoneless)=\"(0)\"\n>\n    {{ internal() }}\n</div>\n<button\n    *ngIf=\"directive()?.interactive() && !editing() && !disabled()\"\n    iconStart=\"@tui.x\"\n    tabIndex=\"-1\"\n    tuiIconButton\n    type=\"button\"\n    (click.stop)=\"delete()\"\n    (pointerdown.prevent.stop.zoneless)=\"(0)\"\n>\n    Remove\n</button>\n"]}
|
|
@@ -1,14 +1,12 @@
|
|
|
1
1
|
import { Directive, inject, Input } from '@angular/core';
|
|
2
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
2
|
import { tuiAsControl, TuiControl } from '@taiga-ui/cdk/classes';
|
|
4
|
-
import { TuiActiveZone } from '@taiga-ui/cdk/directives/active-zone';
|
|
5
3
|
import { TuiNativeValidator } from '@taiga-ui/cdk/directives/native-validator';
|
|
6
4
|
import { TUI_IS_MOBILE, tuiFallbackValueProvider } from '@taiga-ui/cdk/tokens';
|
|
7
5
|
import { tuiGetClipboardDataText, tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
8
6
|
import { tuiAsTextfieldAccessor, TuiTextfieldBase, TuiTextfieldMultiComponent, } from '@taiga-ui/core/components/textfield';
|
|
9
|
-
import {
|
|
7
|
+
import { tuiDropdownOpen } from '@taiga-ui/core/directives/dropdown';
|
|
10
8
|
import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives/items-handlers';
|
|
11
|
-
import {
|
|
9
|
+
import { tuiAsAuxiliary } from '@taiga-ui/core/tokens';
|
|
12
10
|
import { TUI_INPUT_CHIP_OPTIONS } from './input-chip.options';
|
|
13
11
|
import * as i0 from "@angular/core";
|
|
14
12
|
import * as i1 from "@taiga-ui/cdk/directives/native-validator";
|
|
@@ -21,13 +19,6 @@ class TuiInputChipDirective extends TuiControl {
|
|
|
21
19
|
this.mobile = inject(TUI_IS_MOBILE);
|
|
22
20
|
this.textfield = inject(TuiTextfieldMultiComponent);
|
|
23
21
|
this.open = tuiDropdownOpen();
|
|
24
|
-
this.dropdown = inject(TuiDropdownDirective);
|
|
25
|
-
this.sub = inject(TuiActiveZone)
|
|
26
|
-
.tuiActiveZoneChange.pipe(filter((active) => !active), takeUntilDestroyed())
|
|
27
|
-
.subscribe(() => {
|
|
28
|
-
this.onEnter();
|
|
29
|
-
this.textfield.value.set('');
|
|
30
|
-
});
|
|
31
22
|
this.separator = this.options.separator;
|
|
32
23
|
this.unique = this.options.unique;
|
|
33
24
|
this.el = tuiInjectElement();
|
|
@@ -47,7 +38,7 @@ class TuiInputChipDirective extends TuiControl {
|
|
|
47
38
|
this.scrollTo();
|
|
48
39
|
}
|
|
49
40
|
onInput() {
|
|
50
|
-
this.open.set(
|
|
41
|
+
this.open.set(true);
|
|
51
42
|
if (this.separator && this.textfield.value().match(this.separator)) {
|
|
52
43
|
this.onEnter();
|
|
53
44
|
}
|
|
@@ -72,24 +63,20 @@ class TuiInputChipDirective extends TuiControl {
|
|
|
72
63
|
}
|
|
73
64
|
}
|
|
74
65
|
scrollTo() {
|
|
75
|
-
let sign = 1;
|
|
76
|
-
try {
|
|
77
|
-
sign = this.textfield.el.matches(':dir(rtl)') ? -1 : 1;
|
|
78
|
-
}
|
|
79
|
-
catch { }
|
|
80
66
|
// Allow change detection to run and add new tag to DOM
|
|
81
67
|
setTimeout(() => {
|
|
82
68
|
this.textfield.el.scrollTo({
|
|
83
|
-
left: sign * Number.MAX_SAFE_INTEGER,
|
|
84
69
|
top: Number.MAX_SAFE_INTEGER,
|
|
70
|
+
left: Number.MAX_SAFE_INTEGER,
|
|
85
71
|
});
|
|
86
72
|
});
|
|
87
73
|
}
|
|
88
74
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputChipDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
89
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputChipDirective, isStandalone: true, selector: "input[tuiInputChip]", inputs: { separator: "separator", unique: "unique" }, host: { attributes: { "enterkeyhint": "enter" }, listeners: { "keydown.enter.prevent": "onEnter()", "keydown.zoneless": "onBackspace($event.key)", "input": "onInput()", "paste.prevent": "onPaste($event)", "drop.prevent": "onPaste($event)" }, properties: { "disabled": "disabled()" } }, providers: [
|
|
75
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputChipDirective, isStandalone: true, selector: "input[tuiInputChip]", inputs: { separator: "separator", unique: "unique" }, host: { attributes: { "enterkeyhint": "enter" }, listeners: { "blur": "onEnter();", "keydown.enter.prevent": "onEnter()", "keydown.zoneless": "onBackspace($event.key)", "input": "onInput()", "paste.prevent": "onPaste($event)", "drop.prevent": "onPaste($event)" }, properties: { "disabled": "disabled()" } }, providers: [
|
|
90
76
|
tuiAsControl(TuiInputChipDirective),
|
|
91
77
|
tuiFallbackValueProvider([]),
|
|
92
78
|
tuiAsTextfieldAccessor(TuiInputChipDirective),
|
|
79
|
+
tuiAsAuxiliary(TuiInputChipDirective),
|
|
93
80
|
], usesInheritance: true, hostDirectives: [{ directive: i1.TuiNativeValidator }, { directive: i2.TuiTextfieldBase, inputs: ["invalid", "invalid", "focused", "focused", "readOnly", "readOnly", "state", "state"] }], ngImport: i0 }); }
|
|
94
81
|
}
|
|
95
82
|
export { TuiInputChipDirective };
|
|
@@ -102,6 +89,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
102
89
|
tuiAsControl(TuiInputChipDirective),
|
|
103
90
|
tuiFallbackValueProvider([]),
|
|
104
91
|
tuiAsTextfieldAccessor(TuiInputChipDirective),
|
|
92
|
+
tuiAsAuxiliary(TuiInputChipDirective),
|
|
105
93
|
],
|
|
106
94
|
hostDirectives: [
|
|
107
95
|
TuiNativeValidator,
|
|
@@ -113,6 +101,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
113
101
|
host: {
|
|
114
102
|
enterkeyhint: 'enter',
|
|
115
103
|
'[disabled]': 'disabled()',
|
|
104
|
+
'(blur)': 'onEnter();',
|
|
116
105
|
'(keydown.enter.prevent)': 'onEnter()',
|
|
117
106
|
'(keydown.zoneless)': 'onBackspace($event.key)',
|
|
118
107
|
'(input)': 'onInput()',
|
|
@@ -125,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
125
114
|
}], unique: [{
|
|
126
115
|
type: Input
|
|
127
116
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-chip.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-chip/input-chip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, inject, Input} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {tuiAsControl, TuiControl} from '@taiga-ui/cdk/classes';\nimport {TuiActiveZone} from '@taiga-ui/cdk/directives/active-zone';\nimport {TuiNativeValidator} from '@taiga-ui/cdk/directives/native-validator';\nimport {TUI_IS_MOBILE, tuiFallbackValueProvider} from '@taiga-ui/cdk/tokens';\nimport {tuiGetClipboardDataText, tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport type {TuiTextfieldAccessor} from '@taiga-ui/core/components/textfield';\nimport {\n    tuiAsTextfieldAccessor,\n    TuiTextfieldBase,\n    TuiTextfieldMultiComponent,\n} from '@taiga-ui/core/components/textfield';\nimport {TuiDropdownDirective, tuiDropdownOpen} 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 {filter} from 'rxjs';\n\nimport {TUI_INPUT_CHIP_OPTIONS} from './input-chip.options';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputChip]',\n    providers: [\n        tuiAsControl(TuiInputChipDirective),\n        tuiFallbackValueProvider([]),\n        tuiAsTextfieldAccessor(TuiInputChipDirective),\n    ],\n    hostDirectives: [\n        TuiNativeValidator,\n        {\n            directive: TuiTextfieldBase,\n            inputs: ['invalid', 'focused', 'readOnly', 'state'],\n        },\n    ],\n    host: {\n        enterkeyhint: 'enter',\n        '[disabled]': 'disabled()',\n        '(keydown.enter.prevent)': 'onEnter()',\n        '(keydown.zoneless)': 'onBackspace($event.key)',\n        '(input)': 'onInput()',\n        '(paste.prevent)': 'onPaste($event)',\n        '(drop.prevent)': 'onPaste($event)',\n    },\n})\nexport class TuiInputChipDirective<T>\n    extends TuiControl<T[]>\n    implements TuiTextfieldAccessor<T[]>\n{\n    private readonly handlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n    private readonly options = inject(TUI_INPUT_CHIP_OPTIONS);\n    private readonly mobile = inject(TUI_IS_MOBILE);\n    private readonly textfield = inject(TuiTextfieldMultiComponent);\n    private readonly open = tuiDropdownOpen();\n    private readonly dropdown = inject(TuiDropdownDirective);\n\n    protected readonly sub = inject(TuiActiveZone)\n        .tuiActiveZoneChange.pipe(\n            filter((active) => !active),\n            takeUntilDestroyed(),\n        )\n        .subscribe(() => {\n            this.onEnter();\n            this.textfield.value.set('');\n        });\n\n    @Input()\n    public separator = this.options.separator;\n\n    @Input()\n    public unique = this.options.unique;\n\n    public readonly el = tuiInjectElement<HTMLInputElement>();\n\n    public setValue(value: T[]): void {\n        this.textfield.value.set('');\n        this.onChange(\n            this.unique ? Array.from(new Set(value.reverse())).reverse() : value,\n        );\n    }\n\n    protected onEnter(): void {\n        const value = this.textfield.value().trim();\n        const items: any[] = this.separator ? value.split(this.separator) : [value];\n        const valid = items.filter(\n            (item) => item && !this.handlers.disabledItemHandler()(item),\n        );\n\n        if (!value || !valid.length) {\n            return;\n        }\n\n        this.setValue([...this.value(), ...valid]);\n        this.scrollTo();\n    }\n\n    protected onInput(): void {\n        this.open.set(!!this.dropdown.content);\n\n        if (this.separator && this.textfield.value().match(this.separator)) {\n            this.onEnter();\n        } else {\n            this.scrollTo();\n        }\n    }\n\n    protected onPaste(event: ClipboardEvent | DragEvent): void {\n        const value =\n            'dataTransfer' in event\n                ? event.dataTransfer?.getData('text/plain') || ''\n                : tuiGetClipboardDataText(event);\n\n        this.textfield.value.set(value);\n        this.onEnter();\n    }\n\n    protected onBackspace(key: string): void {\n        // (keydown.backspace) doesn't emit event on empty input in ios safari\n        if (\n            key === 'Backspace' &&\n            !this.textfield.value() &&\n            this.interactive() &&\n            (this.mobile || !this.textfield.item)\n        ) {\n            this.onChange(this.value().slice(0, -1));\n        }\n    }\n\n    protected scrollTo(): void {\n        let sign = 1;\n\n        try {\n            sign = this.textfield.el.matches(':dir(rtl)') ? -1 : 1;\n        } catch {}\n\n        // Allow change detection to run and add new tag to DOM\n        setTimeout(() => {\n            this.textfield.el.scrollTo({\n                left: sign * Number.MAX_SAFE_INTEGER,\n                top: Number.MAX_SAFE_INTEGER,\n            });\n        });\n    }\n}\n"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-chip.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-chip/input-chip.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAC,MAAM,eAAe,CAAC;AACvD,OAAO,EAAC,YAAY,EAAE,UAAU,EAAC,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAC,kBAAkB,EAAC,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAC,aAAa,EAAE,wBAAwB,EAAC,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAC,uBAAuB,EAAE,gBAAgB,EAAC,MAAM,yBAAyB,CAAC;AAElF,OAAO,EACH,sBAAsB,EACtB,gBAAgB,EAChB,0BAA0B,GAC7B,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAC,eAAe,EAAC,MAAM,oCAAoC,CAAC;AAEnE,OAAO,EAAC,kBAAkB,EAAC,MAAM,0CAA0C,CAAC;AAC5E,OAAO,EAAC,cAAc,EAAC,MAAM,uBAAuB,CAAC;AAErD,OAAO,EAAC,sBAAsB,EAAC,MAAM,sBAAsB,CAAC;;;;AAE5D,MA2Ba,qBACT,SAAQ,UAAe;IA5B3B;;QA+BqB,aAAQ,GAAwB,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAC3D,YAAO,GAAG,MAAM,CAAC,sBAAsB,CAAC,CAAC;QACzC,WAAM,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QAC/B,cAAS,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;QAC/C,SAAI,GAAG,eAAe,EAAE,CAAC;QAGnC,cAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;QAGnC,WAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;QAEpB,OAAE,GAAG,gBAAgB,EAAoB,CAAC;KAiE7D;IA/DU,QAAQ,CAAC,KAAU;QACtB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC7B,IAAI,CAAC,QAAQ,CACT,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,KAAK,CACvE,CAAC;IACN,CAAC;IAES,OAAO;QACb,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC;QAC5C,MAAM,KAAK,GAAU,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAC5E,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CACtB,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,mBAAmB,EAAE,CAAC,IAAI,CAAC,CAC/D,CAAC;QAEF,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YACzB,OAAO;SACV;QAED,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAES,OAAO;QACb,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAEpB,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;YAChE,IAAI,CAAC,OAAO,EAAE,CAAC;SAClB;aAAM;YACH,IAAI,CAAC,QAAQ,EAAE,CAAC;SACnB;IACL,CAAC;IAES,OAAO,CAAC,KAAiC;QAC/C,MAAM,KAAK,GACP,cAAc,IAAI,KAAK;YACnB,CAAC,CAAC,KAAK,CAAC,YAAY,EAAE,OAAO,CAAC,YAAY,CAAC,IAAI,EAAE;YACjD,CAAC,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QAEzC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAChC,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IAES,WAAW,CAAC,GAAW;QAC7B,sEAAsE;QACtE,IACI,GAAG,KAAK,WAAW;YACnB,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;YACvB,IAAI,CAAC,WAAW,EAAE;YAClB,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EACvC;YACE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;SAC5C;IACL,CAAC;IAES,QAAQ;QACd,uDAAuD;QACvD,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,QAAQ,CAAC;gBACvB,GAAG,EAAE,MAAM,CAAC,gBAAgB;gBAC5B,IAAI,EAAE,MAAM,CAAC,gBAAgB;aAChC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;+GAhFQ,qBAAqB;mGAArB,qBAAqB,4aAxBnB;YACP,YAAY,CAAC,qBAAqB,CAAC;YACnC,wBAAwB,CAAC,EAAE,CAAC;YAC5B,sBAAsB,CAAC,qBAAqB,CAAC;YAC7C,cAAc,CAAC,qBAAqB,CAAC;SACxC;;SAmBQ,qBAAqB;4FAArB,qBAAqB;kBA3BjC,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,qBAAqB;oBAC/B,SAAS,EAAE;wBACP,YAAY,uBAAuB;wBACnC,wBAAwB,CAAC,EAAE,CAAC;wBAC5B,sBAAsB,uBAAuB;wBAC7C,cAAc,uBAAuB;qBACxC;oBACD,cAAc,EAAE;wBACZ,kBAAkB;wBAClB;4BACI,SAAS,EAAE,gBAAgB;4BAC3B,MAAM,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO,CAAC;yBACtD;qBACJ;oBACD,IAAI,EAAE;wBACF,YAAY,EAAE,OAAO;wBACrB,YAAY,EAAE,YAAY;wBAC1B,QAAQ,EAAE,YAAY;wBACtB,yBAAyB,EAAE,WAAW;wBACtC,oBAAoB,EAAE,yBAAyB;wBAC/C,SAAS,EAAE,WAAW;wBACtB,iBAAiB,EAAE,iBAAiB;wBACpC,gBAAgB,EAAE,iBAAiB;qBACtC;iBACJ;8BAYU,SAAS;sBADf,KAAK;gBAIC,MAAM;sBADZ,KAAK","sourcesContent":["import {Directive, inject, Input} from '@angular/core';\nimport {tuiAsControl, TuiControl} from '@taiga-ui/cdk/classes';\nimport {TuiNativeValidator} from '@taiga-ui/cdk/directives/native-validator';\nimport {TUI_IS_MOBILE, tuiFallbackValueProvider} from '@taiga-ui/cdk/tokens';\nimport {tuiGetClipboardDataText, tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport type {TuiTextfieldAccessor} from '@taiga-ui/core/components/textfield';\nimport {\n    tuiAsTextfieldAccessor,\n    TuiTextfieldBase,\n    TuiTextfieldMultiComponent,\n} from '@taiga-ui/core/components/textfield';\nimport {tuiDropdownOpen} 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';\n\nimport {TUI_INPUT_CHIP_OPTIONS} from './input-chip.options';\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputChip]',\n    providers: [\n        tuiAsControl(TuiInputChipDirective),\n        tuiFallbackValueProvider([]),\n        tuiAsTextfieldAccessor(TuiInputChipDirective),\n        tuiAsAuxiliary(TuiInputChipDirective),\n    ],\n    hostDirectives: [\n        TuiNativeValidator,\n        {\n            directive: TuiTextfieldBase,\n            inputs: ['invalid', 'focused', 'readOnly', 'state'],\n        },\n    ],\n    host: {\n        enterkeyhint: 'enter',\n        '[disabled]': 'disabled()',\n        '(blur)': 'onEnter();',\n        '(keydown.enter.prevent)': 'onEnter()',\n        '(keydown.zoneless)': 'onBackspace($event.key)',\n        '(input)': 'onInput()',\n        '(paste.prevent)': 'onPaste($event)',\n        '(drop.prevent)': 'onPaste($event)',\n    },\n})\nexport class TuiInputChipDirective<T>\n    extends TuiControl<T[]>\n    implements TuiTextfieldAccessor<T[]>\n{\n    private readonly handlers: TuiItemsHandlers<T> = inject(TUI_ITEMS_HANDLERS);\n    private readonly options = inject(TUI_INPUT_CHIP_OPTIONS);\n    private readonly mobile = inject(TUI_IS_MOBILE);\n    private readonly textfield = inject(TuiTextfieldMultiComponent);\n    private readonly open = tuiDropdownOpen();\n\n    @Input()\n    public separator = this.options.separator;\n\n    @Input()\n    public unique = this.options.unique;\n\n    public readonly el = tuiInjectElement<HTMLInputElement>();\n\n    public setValue(value: T[]): void {\n        this.textfield.value.set('');\n        this.onChange(\n            this.unique ? Array.from(new Set(value.reverse())).reverse() : value,\n        );\n    }\n\n    protected onEnter(): void {\n        const value = this.textfield.value().trim();\n        const items: any[] = this.separator ? value.split(this.separator) : [value];\n        const valid = items.filter(\n            (item) => item && !this.handlers.disabledItemHandler()(item),\n        );\n\n        if (!value || !valid.length) {\n            return;\n        }\n\n        this.setValue([...this.value(), ...valid]);\n        this.scrollTo();\n    }\n\n    protected onInput(): void {\n        this.open.set(true);\n\n        if (this.separator && this.textfield.value().match(this.separator)) {\n            this.onEnter();\n        } else {\n            this.scrollTo();\n        }\n    }\n\n    protected onPaste(event: ClipboardEvent | DragEvent): void {\n        const value =\n            'dataTransfer' in event\n                ? event.dataTransfer?.getData('text/plain') || ''\n                : tuiGetClipboardDataText(event);\n\n        this.textfield.value.set(value);\n        this.onEnter();\n    }\n\n    protected onBackspace(key: string): void {\n        // (keydown.backspace) doesn't emit event on empty input in ios safari\n        if (\n            key === 'Backspace' &&\n            !this.textfield.value() &&\n            this.interactive() &&\n            (this.mobile || !this.textfield.item)\n        ) {\n            this.onChange(this.value().slice(0, -1));\n        }\n    }\n\n    protected scrollTo(): void {\n        // Allow change detection to run and add new tag to DOM\n        setTimeout(() => {\n            this.textfield.el.scrollTo({\n                top: Number.MAX_SAFE_INTEGER,\n                left: Number.MAX_SAFE_INTEGER,\n            });\n        });\n    }\n}\n"]}
|
|
@@ -9,13 +9,11 @@ import { TUI_IS_MOBILE } from '@taiga-ui/cdk/tokens';
|
|
|
9
9
|
import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
|
|
10
10
|
import { changeDateSeparator, tuiDirectiveBinding, } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
11
11
|
import { TuiCalendar } from '@taiga-ui/core/components/calendar';
|
|
12
|
-
import { tuiAsOptionContent } from '@taiga-ui/core/components/data-list';
|
|
13
12
|
import { tuiInjectAuxiliary, TuiTextfieldComponent, TuiTextfieldDirective, tuiTextfieldIconBinding, TuiWithTextfield, } from '@taiga-ui/core/components/textfield';
|
|
14
13
|
import { TuiDropdownAuto, tuiDropdownEnabled, tuiDropdownOpen, } from '@taiga-ui/core/directives/dropdown';
|
|
15
|
-
import {
|
|
14
|
+
import { TuiItemsHandlersDirective, TuiItemsHandlersValidator, } from '@taiga-ui/core/directives/items-handlers';
|
|
16
15
|
import { TUI_DATE_FORMAT, TUI_DEFAULT_DATE_FORMAT } from '@taiga-ui/core/tokens';
|
|
17
16
|
import { TuiCalendarRange } from '@taiga-ui/kit/components/calendar-range';
|
|
18
|
-
import { TuiSelectOption } from '@taiga-ui/kit/components/select';
|
|
19
17
|
import { TUI_DATE_TEXTS } from '@taiga-ui/kit/tokens';
|
|
20
18
|
import { tuiMaskito } from '@taiga-ui/kit/utils';
|
|
21
19
|
import { TUI_INPUT_DATE_OPTIONS_NEW } from './input-date.options';
|
|
@@ -33,6 +31,7 @@ class TuiInputDateBase extends TuiControl {
|
|
|
33
31
|
constructor() {
|
|
34
32
|
super(...arguments);
|
|
35
33
|
this.el = tuiInjectElement();
|
|
34
|
+
this.mobile = inject(TUI_IS_MOBILE);
|
|
36
35
|
this.options = inject(TUI_INPUT_DATE_OPTIONS_NEW);
|
|
37
36
|
this.handlers = inject(TuiItemsHandlersDirective);
|
|
38
37
|
this.textfield = inject(TuiTextfieldDirective);
|
|
@@ -43,7 +42,6 @@ class TuiInputDateBase extends TuiControl {
|
|
|
43
42
|
const texts = this.texts() || '';
|
|
44
43
|
return texts && changeDateSeparator(texts[mode], separator);
|
|
45
44
|
}), {});
|
|
46
|
-
this.mobile = inject(TUI_IS_MOBILE);
|
|
47
45
|
this.open = tuiDropdownOpen();
|
|
48
46
|
this.icon = tuiTextfieldIconBinding(TUI_INPUT_DATE_OPTIONS_NEW);
|
|
49
47
|
this.dropdownEnabled = tuiDropdownEnabled(computed(() => !this.native && this.interactive()));
|
|
@@ -118,10 +116,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
118
116
|
args: ['max']
|
|
119
117
|
}] } });
|
|
120
118
|
class TuiInputDateDirective extends TuiInputDateBase {
|
|
121
|
-
constructor() {
|
|
122
|
-
super(...arguments);
|
|
123
|
-
this.identity = inject(TUI_ITEMS_HANDLERS).identityMatcher.set((a, b) => a.daySame(b));
|
|
124
|
-
}
|
|
125
119
|
onValueChange(value) {
|
|
126
120
|
this.control?.control?.updateValueAndValidity({ emitEvent: false });
|
|
127
121
|
this.onChange(value.length === DATE_FILLER_LENGTH
|
|
@@ -130,7 +124,6 @@ class TuiInputDateDirective extends TuiInputDateBase {
|
|
|
130
124
|
}
|
|
131
125
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
132
126
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputDateDirective, isStandalone: true, selector: "input[tuiInputDate]", providers: [
|
|
133
|
-
tuiAsOptionContent(TuiSelectOption),
|
|
134
127
|
tuiAsControl(TuiInputDateDirective),
|
|
135
128
|
tuiValueTransformerFrom(TUI_INPUT_DATE_OPTIONS_NEW),
|
|
136
129
|
], usesInheritance: true, hostDirectives: [{ directive: i1.TuiWithTextfield }, { directive: i2.TuiDropdownAuto }, { directive: i3.TuiItemsHandlersValidator }, { directive: i4.MaskitoDirective }], ngImport: i0 }); }
|
|
@@ -142,7 +135,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
142
135
|
standalone: true,
|
|
143
136
|
selector: 'input[tuiInputDate]',
|
|
144
137
|
providers: [
|
|
145
|
-
tuiAsOptionContent(TuiSelectOption),
|
|
146
138
|
tuiAsControl(TuiInputDateDirective),
|
|
147
139
|
tuiValueTransformerFrom(TUI_INPUT_DATE_OPTIONS_NEW),
|
|
148
140
|
],
|
|
@@ -154,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
154
146
|
],
|
|
155
147
|
}]
|
|
156
148
|
}] });
|
|
157
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date/input-date.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 {MaskitoDateMode} from '@maskito/kit';\nimport {maskitoDateOptionsGenerator} from '@maskito/kit';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport type {TuiDateMode, TuiDayRange} from '@taiga-ui/cdk/date-time';\nimport {DATE_FILLER_LENGTH, TuiDay} from '@taiga-ui/cdk/date-time';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {\n    changeDateSeparator,\n    tuiDirectiveBinding,\n} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiCalendar} from '@taiga-ui/core/components/calendar';\nimport {tuiAsOptionContent} from '@taiga-ui/core/components/data-list';\nimport {\n    tuiInjectAuxiliary,\n    TuiTextfieldComponent,\n    TuiTextfieldDirective,\n    tuiTextfieldIconBinding,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {\n    TuiDropdownAuto,\n    tuiDropdownEnabled,\n    tuiDropdownOpen,\n} from '@taiga-ui/core/directives/dropdown';\nimport type {TuiItemsHandlers} from '@taiga-ui/core/directives/items-handlers';\nimport {\n    TUI_ITEMS_HANDLERS,\n    TuiItemsHandlersDirective,\n    TuiItemsHandlersValidator,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_DATE_FORMAT, TUI_DEFAULT_DATE_FORMAT} from '@taiga-ui/core/tokens';\nimport {TuiCalendarRange} from '@taiga-ui/kit/components/calendar-range';\nimport {TuiSelectOption} from '@taiga-ui/kit/components/select';\nimport {TUI_DATE_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_DATE_OPTIONS_NEW} from './input-date.options';\n\nexport const TUI_DATE_ADAPTER: Record<TuiDateMode, MaskitoDateMode> = {\n    DMY: 'dd/mm/yyyy',\n    MDY: 'mm/dd/yyyy',\n    YMD: 'yyyy/mm/dd',\n};\n\n@Directive({\n    standalone: true,\n    host: {\n        '[attr.inputmode]': 'mobile && open() ? \"none\" : \"numeric\"',\n        '[disabled]': 'disabled()',\n        '(input)': 'onValueChange($event.target.value)',\n        '(click.capture.stop)': 'onClick()',\n    },\n})\nexport abstract class TuiInputDateBase<\n    T extends TuiDay | TuiDayRange,\n> extends TuiControl<T | null> {\n    private readonly el = tuiInjectElement<HTMLInputElement>();\n    private readonly options = inject(TUI_INPUT_DATE_OPTIONS_NEW);\n    private readonly handlers = inject(TuiItemsHandlersDirective);\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly texts = toSignal(inject(TUI_DATE_TEXTS));\n    private readonly calendar = tuiInjectAuxiliary<TuiCalendar | TuiCalendarRange>(\n        (x) => x instanceof TuiCalendar || x instanceof TuiCalendarRange,\n    );\n\n    protected readonly filler = tuiDirectiveBinding(\n        TuiTextfieldComponent,\n        'fillerSetter',\n        computed(() => {\n            const {mode, separator} = this.format();\n            const texts = this.texts() || '';\n\n            return texts && changeDateSeparator(texts[mode], separator);\n        }),\n        {},\n    );\n\n    protected readonly mobile = inject(TUI_IS_MOBILE);\n    protected readonly open = tuiDropdownOpen();\n    protected readonly icon = tuiTextfieldIconBinding(TUI_INPUT_DATE_OPTIONS_NEW);\n    protected readonly dropdownEnabled = tuiDropdownEnabled(\n        computed(() => !this.native && this.interactive()),\n    );\n\n    protected readonly format = toSignal(inject(TUI_DATE_FORMAT), {\n        initialValue: TUI_DEFAULT_DATE_FORMAT,\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 valueEffect = effect(() => {\n        const value =\n            this.value()?.toString(this.format().mode, this.format().separator) ??\n            (this.filler().length === this.el.value.length ? '' : this.el.value);\n\n        this.textfield.value.set(value);\n    }, TUI_ALLOW_SIGNAL_WRITES);\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()?.valueChange.subscribe((value: any) => {\n            this.onChange(value);\n            this.open.set(false);\n            this.el.blur();\n        });\n\n        onCleanup(() => subscription?.unsubscribe());\n    });\n\n    public readonly native = this.el.type === 'date' && this.mobile;\n    public readonly min = signal(this.options.min);\n    public readonly max = signal(this.options.max);\n\n    protected abstract onValueChange(value: string): void;\n\n    @Input('min')\n    public set minSetter(min: TuiDay | null) {\n        this.min.set(min || this.options.min);\n    }\n\n    @Input('max')\n    public set maxSetter(max: TuiDay | null) {\n        this.max.set(max || this.options.max);\n    }\n\n    protected processCalendar(calendar: TuiCalendar | TuiCalendarRange): void {\n        calendar.value = this.value();\n        calendar.disabledItemHandler = this.handlers.disabledItemHandler();\n        calendar.min = this.min();\n        calendar.max = this.max();\n    }\n\n    protected onClick(): void {\n        if (!this.mobile) {\n            this.open.update((open) => !open);\n        }\n    }\n}\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputDate]',\n    providers: [\n        tuiAsOptionContent(TuiSelectOption),\n        tuiAsControl(TuiInputDateDirective),\n        tuiValueTransformerFrom(TUI_INPUT_DATE_OPTIONS_NEW),\n    ],\n    hostDirectives: [\n        TuiWithTextfield,\n        TuiDropdownAuto,\n        TuiItemsHandlersValidator,\n        MaskitoDirective,\n    ],\n})\nexport class TuiInputDateDirective extends TuiInputDateBase<TuiDay> {\n    protected readonly identity = inject<TuiItemsHandlers<TuiDay>>(\n        TUI_ITEMS_HANDLERS,\n    ).identityMatcher.set((a, b) => a.daySame(b));\n\n    protected override onValueChange(value: string): void {\n        this.control?.control?.updateValueAndValidity({emitEvent: false});\n        this.onChange(\n            value.length === DATE_FILLER_LENGTH\n                ? TuiDay.normalizeParse(value, this.format().mode)\n                : null,\n        );\n    }\n}\n"]}
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/input-date/input-date.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;AAElD,OAAO,EAAC,2BAA2B,EAAC,MAAM,cAAc,CAAC;AACzD,OAAO,EAAC,YAAY,EAAE,UAAU,EAAE,uBAAuB,EAAC,MAAM,uBAAuB,CAAC;AACxF,OAAO,EAAC,uBAAuB,EAAC,MAAM,yBAAyB,CAAC;AAEhE,OAAO,EAAC,kBAAkB,EAAE,MAAM,EAAC,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,gBAAgB,EAAC,MAAM,yBAAyB,CAAC;AACzD,OAAO,EACH,mBAAmB,EACnB,mBAAmB,GACtB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAC,WAAW,EAAC,MAAM,oCAAoC,CAAC;AAC/D,OAAO,EACH,kBAAkB,EAClB,qBAAqB,EACrB,qBAAqB,EACrB,uBAAuB,EACvB,gBAAgB,GACnB,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EACH,eAAe,EACf,kBAAkB,EAClB,eAAe,GAClB,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EACH,yBAAyB,EACzB,yBAAyB,GAC5B,MAAM,0CAA0C,CAAC;AAClD,OAAO,EAAC,eAAe,EAAE,uBAAuB,EAAC,MAAM,uBAAuB,CAAC;AAC/E,OAAO,EAAC,gBAAgB,EAAC,MAAM,yCAAyC,CAAC;AACzE,OAAO,EAAC,cAAc,EAAC,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAC,UAAU,EAAC,MAAM,qBAAqB,CAAC;AAE/C,OAAO,EAAC,0BAA0B,EAAC,MAAM,sBAAsB,CAAC;;;;;;AAEhE,MAAM,CAAC,MAAM,gBAAgB,GAAyC;IAClE,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,YAAY;IACjB,GAAG,EAAE,YAAY;CACpB,CAAC;AAEF,MASsB,gBAEpB,SAAQ,UAAoB;IAX9B;;QAYqB,OAAE,GAAG,gBAAgB,EAAoB,CAAC;QAC1C,WAAM,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QAC/B,YAAO,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;QAC7C,aAAQ,GAAG,MAAM,CAAC,yBAAyB,CAAC,CAAC;QAC7C,cAAS,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAC1C,UAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;QACzC,aAAQ,GAAG,kBAAkB,CAC1C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,YAAY,WAAW,IAAI,CAAC,YAAY,gBAAgB,CACnE,CAAC;QAEiB,WAAM,GAAG,mBAAmB,CAC3C,qBAAqB,EACrB,cAAc,EACd,QAAQ,CAAC,GAAG,EAAE;YACV,MAAM,EAAC,IAAI,EAAE,SAAS,EAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YACxC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC;YAEjC,OAAO,KAAK,IAAI,mBAAmB,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,CAAC;QAChE,CAAC,CAAC,EACF,EAAE,CACL,CAAC;QAEiB,SAAI,GAAG,eAAe,EAAE,CAAC;QACzB,SAAI,GAAG,uBAAuB,CAAC,0BAA0B,CAAC,CAAC;QAC3D,oBAAe,GAAG,kBAAkB,CACnD,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,CACrD,CAAC;QAEiB,WAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,eAAe,CAAC,EAAE;YAC1D,YAAY,EAAE,uBAAuB;SACxC,CAAC,CAAC;QAEgB,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,gBAAW,GAAG,MAAM,CAAC,GAAG,EAAE;YACzC,MAAM,KAAK,GACP,IAAI,CAAC,KAAK,EAAE,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,SAAS,CAAC;gBACnE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,KAAK,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;YAEzE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC,EAAE,uBAAuB,CAAC,CAAC;QAET,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,WAAW,CAAC,SAAS,CAAC,CAAC,KAAU,EAAE,EAAE;gBACvE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;gBACrB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBACrB,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC;YACnB,CAAC,CAAC,CAAC;YAEH,SAAS,CAAC,GAAG,EAAE,CAAC,YAAY,EAAE,WAAW,EAAE,CAAC,CAAC;QACjD,CAAC,CAAC,CAAC;QAEa,WAAM,GAAG,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC;QAChD,QAAG,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAC/B,QAAG,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;KA0BlD;IAtBG,IACW,SAAS,CAAC,GAAkB;QACnC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC1C,CAAC;IAED,IACW,SAAS,CAAC,GAAkB;QACnC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC1C,CAAC;IAES,eAAe,CAAC,QAAwC;QAC9D,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QAC9B,QAAQ,CAAC,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,EAAE,CAAC;QACnE,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC1B,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAC9B,CAAC;IAES,OAAO;QACb,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACd,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;SACrC;IACL,CAAC;+GAjGiB,gBAAgB;mGAAhB,gBAAgB;;SAAhB,gBAAgB;4FAAhB,gBAAgB;kBATrC,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,IAAI,EAAE;wBACF,kBAAkB,EAAE,uCAAuC;wBAC3D,YAAY,EAAE,YAAY;wBAC1B,SAAS,EAAE,oCAAoC;wBAC/C,sBAAsB,EAAE,WAAW;qBACtC;iBACJ;8BA8Ec,SAAS;sBADnB,KAAK;uBAAC,KAAK;gBAMD,SAAS;sBADnB,KAAK;uBAAC,KAAK;;AAmBhB,MAca,qBAAsB,SAAQ,gBAAwB;IAC5C,aAAa,CAAC,KAAa;QAC1C,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,sBAAsB,CAAC,EAAC,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;QAClE,IAAI,CAAC,QAAQ,CACT,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,CACb,CAAC;IACN,CAAC;+GARQ,qBAAqB;mGAArB,qBAAqB,kEAXnB;YACP,YAAY,CAAC,qBAAqB,CAAC;YACnC,uBAAuB,CAAC,0BAA0B,CAAC;SACtD;;SAQQ,qBAAqB;4FAArB,qBAAqB;kBAdjC,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,qBAAqB;oBAC/B,SAAS,EAAE;wBACP,YAAY,uBAAuB;wBACnC,uBAAuB,CAAC,0BAA0B,CAAC;qBACtD;oBACD,cAAc,EAAE;wBACZ,gBAAgB;wBAChB,eAAe;wBACf,yBAAyB;wBACzB,gBAAgB;qBACnB;iBACJ","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 {MaskitoDateMode} from '@maskito/kit';\nimport {maskitoDateOptionsGenerator} from '@maskito/kit';\nimport {tuiAsControl, TuiControl, tuiValueTransformerFrom} from '@taiga-ui/cdk/classes';\nimport {TUI_ALLOW_SIGNAL_WRITES} from '@taiga-ui/cdk/constants';\nimport type {TuiDateMode, TuiDayRange} from '@taiga-ui/cdk/date-time';\nimport {DATE_FILLER_LENGTH, TuiDay} from '@taiga-ui/cdk/date-time';\nimport {TUI_IS_MOBILE} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {\n    changeDateSeparator,\n    tuiDirectiveBinding,\n} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiCalendar} from '@taiga-ui/core/components/calendar';\nimport {\n    tuiInjectAuxiliary,\n    TuiTextfieldComponent,\n    TuiTextfieldDirective,\n    tuiTextfieldIconBinding,\n    TuiWithTextfield,\n} from '@taiga-ui/core/components/textfield';\nimport {\n    TuiDropdownAuto,\n    tuiDropdownEnabled,\n    tuiDropdownOpen,\n} from '@taiga-ui/core/directives/dropdown';\nimport {\n    TuiItemsHandlersDirective,\n    TuiItemsHandlersValidator,\n} from '@taiga-ui/core/directives/items-handlers';\nimport {TUI_DATE_FORMAT, TUI_DEFAULT_DATE_FORMAT} from '@taiga-ui/core/tokens';\nimport {TuiCalendarRange} from '@taiga-ui/kit/components/calendar-range';\nimport {TUI_DATE_TEXTS} from '@taiga-ui/kit/tokens';\nimport {tuiMaskito} from '@taiga-ui/kit/utils';\n\nimport {TUI_INPUT_DATE_OPTIONS_NEW} from './input-date.options';\n\nexport const TUI_DATE_ADAPTER: Record<TuiDateMode, MaskitoDateMode> = {\n    DMY: 'dd/mm/yyyy',\n    MDY: 'mm/dd/yyyy',\n    YMD: 'yyyy/mm/dd',\n};\n\n@Directive({\n    standalone: true,\n    host: {\n        '[attr.inputmode]': 'mobile && open() ? \"none\" : \"numeric\"',\n        '[disabled]': 'disabled()',\n        '(input)': 'onValueChange($event.target.value)',\n        '(click.capture.stop)': 'onClick()',\n    },\n})\nexport abstract class TuiInputDateBase<\n    T extends TuiDay | TuiDayRange,\n> extends TuiControl<T | null> {\n    private readonly el = tuiInjectElement<HTMLInputElement>();\n    private readonly mobile = inject(TUI_IS_MOBILE);\n    private readonly options = inject(TUI_INPUT_DATE_OPTIONS_NEW);\n    private readonly handlers = inject(TuiItemsHandlersDirective);\n    private readonly textfield = inject(TuiTextfieldDirective);\n    private readonly texts = toSignal(inject(TUI_DATE_TEXTS));\n    private readonly calendar = tuiInjectAuxiliary<TuiCalendar | TuiCalendarRange>(\n        (x) => x instanceof TuiCalendar || x instanceof TuiCalendarRange,\n    );\n\n    protected readonly filler = tuiDirectiveBinding(\n        TuiTextfieldComponent,\n        'fillerSetter',\n        computed(() => {\n            const {mode, separator} = this.format();\n            const texts = this.texts() || '';\n\n            return texts && changeDateSeparator(texts[mode], separator);\n        }),\n        {},\n    );\n\n    protected readonly open = tuiDropdownOpen();\n    protected readonly icon = tuiTextfieldIconBinding(TUI_INPUT_DATE_OPTIONS_NEW);\n    protected readonly dropdownEnabled = tuiDropdownEnabled(\n        computed(() => !this.native && this.interactive()),\n    );\n\n    protected readonly format = toSignal(inject(TUI_DATE_FORMAT), {\n        initialValue: TUI_DEFAULT_DATE_FORMAT,\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 valueEffect = effect(() => {\n        const value =\n            this.value()?.toString(this.format().mode, this.format().separator) ??\n            (this.filler().length === this.el.value.length ? '' : this.el.value);\n\n        this.textfield.value.set(value);\n    }, TUI_ALLOW_SIGNAL_WRITES);\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()?.valueChange.subscribe((value: any) => {\n            this.onChange(value);\n            this.open.set(false);\n            this.el.blur();\n        });\n\n        onCleanup(() => subscription?.unsubscribe());\n    });\n\n    public readonly native = this.el.type === 'date' && this.mobile;\n    public readonly min = signal(this.options.min);\n    public readonly max = signal(this.options.max);\n\n    protected abstract onValueChange(value: string): void;\n\n    @Input('min')\n    public set minSetter(min: TuiDay | null) {\n        this.min.set(min || this.options.min);\n    }\n\n    @Input('max')\n    public set maxSetter(max: TuiDay | null) {\n        this.max.set(max || this.options.max);\n    }\n\n    protected processCalendar(calendar: TuiCalendar | TuiCalendarRange): void {\n        calendar.value = this.value();\n        calendar.disabledItemHandler = this.handlers.disabledItemHandler();\n        calendar.min = this.min();\n        calendar.max = this.max();\n    }\n\n    protected onClick(): void {\n        if (!this.mobile) {\n            this.open.update((open) => !open);\n        }\n    }\n}\n\n@Directive({\n    standalone: true,\n    selector: 'input[tuiInputDate]',\n    providers: [\n        tuiAsControl(TuiInputDateDirective),\n        tuiValueTransformerFrom(TUI_INPUT_DATE_OPTIONS_NEW),\n    ],\n    hostDirectives: [\n        TuiWithTextfield,\n        TuiDropdownAuto,\n        TuiItemsHandlersValidator,\n        MaskitoDirective,\n    ],\n})\nexport class TuiInputDateDirective extends TuiInputDateBase<TuiDay> {\n    protected override onValueChange(value: string): void {\n        this.control?.control?.updateValueAndValidity({emitEvent: false});\n        this.onChange(\n            value.length === DATE_FILLER_LENGTH\n                ? TuiDay.normalizeParse(value, this.format().mode)\n                : null,\n        );\n    }\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { computed, Directive,
|
|
1
|
+
import { computed, Directive, Input, signal } from '@angular/core';
|
|
2
2
|
import { MaskitoDirective } from '@maskito/angular';
|
|
3
3
|
import { maskitoDateRangeOptionsGenerator } from '@maskito/kit';
|
|
4
4
|
import { tuiAsControl, tuiValueTransformerFrom } from '@taiga-ui/cdk/classes';
|
|
@@ -6,7 +6,6 @@ import { DATE_RANGE_FILLER_LENGTH, RANGE_SEPARATOR_CHAR, TuiDayRange, } from '@t
|
|
|
6
6
|
import { tuiDirectiveBinding, tuiProvide } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
7
7
|
import { TuiTextfieldComponent, TuiWithTextfield, } from '@taiga-ui/core/components/textfield';
|
|
8
8
|
import { TuiDropdownAuto } from '@taiga-ui/core/directives/dropdown';
|
|
9
|
-
import { TUI_ITEMS_HANDLERS } from '@taiga-ui/core/directives/items-handlers';
|
|
10
9
|
import { TUI_DATE_ADAPTER, TUI_INPUT_DATE_OPTIONS_NEW, TuiInputDateBase, } from '@taiga-ui/kit/components/input-date';
|
|
11
10
|
import { tuiMaskito } from '@taiga-ui/kit/utils';
|
|
12
11
|
import { TUI_INPUT_DATE_RANGE_OPTIONS } from './input-date-range.options';
|
|
@@ -17,7 +16,6 @@ import * as i3 from "@maskito/angular";
|
|
|
17
16
|
class TuiInputDateRangeDirective extends TuiInputDateBase {
|
|
18
17
|
constructor() {
|
|
19
18
|
super(...arguments);
|
|
20
|
-
this.identity = inject(TUI_ITEMS_HANDLERS).identityMatcher.set((a, b) => a.daySame(b));
|
|
21
19
|
this.rangeFiller = tuiDirectiveBinding(TuiTextfieldComponent, 'fillerSetter', computed((filler = this.filler()) => `${filler}${RANGE_SEPARATOR_CHAR}${filler}`), {});
|
|
22
20
|
this.mask = tuiMaskito(computed(() => maskitoDateRangeOptionsGenerator({
|
|
23
21
|
dateSeparator: this.format().separator,
|
|
@@ -49,7 +47,6 @@ class TuiInputDateRangeDirective extends TuiInputDateBase {
|
|
|
49
47
|
}
|
|
50
48
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiInputDateRangeDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
51
49
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiInputDateRangeDirective, isStandalone: true, selector: "input[tuiInputDateRange]", inputs: { minLengthSetter: ["minLength", "minLengthSetter"], maxLengthSetter: ["maxLength", "maxLengthSetter"] }, providers: [
|
|
52
|
-
// TODO: Add SelectOption after data-list in calendar-range is refactored
|
|
53
50
|
tuiAsControl(TuiInputDateRangeDirective),
|
|
54
51
|
tuiValueTransformerFrom(TUI_INPUT_DATE_RANGE_OPTIONS),
|
|
55
52
|
tuiProvide(TUI_INPUT_DATE_OPTIONS_NEW, TUI_INPUT_DATE_RANGE_OPTIONS),
|
|
@@ -62,7 +59,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
62
59
|
standalone: true,
|
|
63
60
|
selector: 'input[tuiInputDateRange]',
|
|
64
61
|
providers: [
|
|
65
|
-
// TODO: Add SelectOption after data-list in calendar-range is refactored
|
|
66
62
|
tuiAsControl(TuiInputDateRangeDirective),
|
|
67
63
|
tuiValueTransformerFrom(TUI_INPUT_DATE_RANGE_OPTIONS),
|
|
68
64
|
tuiProvide(TUI_INPUT_DATE_OPTIONS_NEW, TUI_INPUT_DATE_RANGE_OPTIONS),
|
|
@@ -76,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
76
72
|
type: Input,
|
|
77
73
|
args: ['maxLength']
|
|
78
74
|
}] } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS1yYW5nZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pbnB1dC1kYXRlLXJhbmdlL2lucHV0LWRhdGUtcmFuZ2UuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakUsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDbEQsT0FBTyxFQUFDLGdDQUFnQyxFQUFDLE1BQU0sY0FBYyxDQUFDO0FBQzlELE9BQU8sRUFBQyxZQUFZLEVBQUUsdUJBQXVCLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQUU1RSxPQUFPLEVBQ0gsd0JBQXdCLEVBQ3hCLG9CQUFvQixFQUNwQixXQUFXLEdBQ2QsTUFBTSx5QkFBeUIsQ0FBQztBQUNqQyxPQUFPLEVBQUMsbUJBQW1CLEVBQUUsVUFBVSxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbEYsT0FBTyxFQUNILHFCQUFxQixFQUNyQixnQkFBZ0IsR0FDbkIsTUFBTSxxQ0FBcUMsQ0FBQztBQUM3QyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFFbkUsT0FBTyxFQUNILGdCQUFnQixFQUNoQiwwQkFBMEIsRUFDMUIsZ0JBQWdCLEdBQ25CLE1BQU0scUNBQXFDLENBQUM7QUFDN0MsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBRS9DLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLDRCQUE0QixDQUFDOzs7OztBQUV4RSxNQVVhLDBCQUEyQixTQUFRLGdCQUE2QjtJQVY3RTs7UUFXdUIsZ0JBQVcsR0FBRyxtQkFBbUIsQ0FDaEQscUJBQXFCLEVBQ3JCLGNBQWMsRUFDZCxRQUFRLENBQUMsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxHQUFHLE1BQU0sR0FBRyxvQkFBb0IsR0FBRyxNQUFNLEVBQUUsQ0FBQyxFQUNqRixFQUFFLENBQ0wsQ0FBQztRQUUwQixTQUFJLEdBQUcsVUFBVSxDQUN6QyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQ1YsZ0NBQWdDLENBQUM7WUFDN0IsYUFBYSxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxTQUFTO1lBQ3RDLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDO1lBQzFDLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsaUJBQWlCLEVBQUU7WUFDbkMsR0FBRyxFQUFFLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxpQkFBaUIsRUFBRTtZQUNuQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLEVBQUU7WUFDakMsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxFQUFFO1NBQ3BDLENBQUMsQ0FDTCxDQUNKLENBQUM7UUFFYyxjQUFTLEdBQUcsTUFBTSxDQUFvQixJQUFJLENBQUMsQ0FBQztRQUM1QyxjQUFTLEdBQUcsTUFBTSxDQUFvQixJQUFJLENBQUMsQ0FBQztLQTJCL0Q7SUF6QkcsSUFDVyxlQUFlLENBQUMsU0FBNEI7UUFDbkQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVELElBQ1csZUFBZSxDQUFDLFNBQTRCO1FBQ25ELElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFa0IsZUFBZSxDQUFDLFFBQTBCO1FBQ3pELEtBQUssQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFaEMsUUFBUSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDdEMsUUFBUSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDMUMsQ0FBQztJQUVrQixhQUFhLENBQUMsS0FBYTtRQUMxQyxJQUFJLENBQUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxzQkFBc0IsQ0FBQyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQUMsQ0FBQyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxRQUFRLENBQ1QsS0FBSyxDQUFDLE1BQU0sS0FBSyx3QkFBd0I7WUFDckMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxjQUFjLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUM7WUFDdkQsQ0FBQyxDQUFDLElBQUksQ0FDYixDQUFDO0lBQ04sQ0FBQzsrR0FoRFEsMEJBQTBCO21HQUExQiwwQkFBMEIseUxBUHhCO1lBQ1AsWUFBWSxDQUFDLDBCQUEwQixDQUFDO1lBQ3hDLHVCQUF1QixDQUFDLDRCQUE0QixDQUFDO1lBQ3JELFVBQVUsQ0FBQywwQkFBMEIsRUFBRSw0QkFBNEIsQ0FBQztTQUN2RTs7U0FHUSwwQkFBMEI7NEZBQTFCLDBCQUEwQjtrQkFWdEMsU0FBUzttQkFBQztvQkFDUCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLDBCQUEwQjtvQkFDcEMsU0FBUyxFQUFFO3dCQUNQLFlBQVksNEJBQTRCO3dCQUN4Qyx1QkFBdUIsQ0FBQyw0QkFBNEIsQ0FBQzt3QkFDckQsVUFBVSxDQUFDLDBCQUEwQixFQUFFLDRCQUE0QixDQUFDO3FCQUN2RTtvQkFDRCxjQUFjLEVBQUUsQ0FBQyxnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLENBQUM7aUJBQ3hFOzhCQTBCYyxlQUFlO3NCQUR6QixLQUFLO3VCQUFDLFdBQVc7Z0JBTVAsZUFBZTtzQkFEekIsS0FBSzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtjb21wdXRlZCwgRGlyZWN0aXZlLCBJbnB1dCwgc2lnbmFsfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TWFza2l0b0RpcmVjdGl2ZX0gZnJvbSAnQG1hc2tpdG8vYW5ndWxhcic7XG5pbXBvcnQge21hc2tpdG9EYXRlUmFuZ2VPcHRpb25zR2VuZXJhdG9yfSBmcm9tICdAbWFza2l0by9raXQnO1xuaW1wb3J0IHt0dWlBc0NvbnRyb2wsIHR1aVZhbHVlVHJhbnNmb3JtZXJGcm9tfSBmcm9tICdAdGFpZ2EtdWkvY2RrL2NsYXNzZXMnO1xuaW1wb3J0IHR5cGUge1R1aURheUxpa2V9IGZyb20gJ0B0YWlnYS11aS9jZGsvZGF0ZS10aW1lJztcbmltcG9ydCB7XG4gICAgREFURV9SQU5HRV9GSUxMRVJfTEVOR1RILFxuICAgIFJBTkdFX1NFUEFSQVRPUl9DSEFSLFxuICAgIFR1aURheVJhbmdlLFxufSBmcm9tICdAdGFpZ2EtdWkvY2RrL2RhdGUtdGltZSc7XG5pbXBvcnQge3R1aURpcmVjdGl2ZUJpbmRpbmcsIHR1aVByb3ZpZGV9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5pbXBvcnQge1xuICAgIFR1aVRleHRmaWVsZENvbXBvbmVudCxcbiAgICBUdWlXaXRoVGV4dGZpZWxkLFxufSBmcm9tICdAdGFpZ2EtdWkvY29yZS9jb21wb25lbnRzL3RleHRmaWVsZCc7XG5pbXBvcnQge1R1aURyb3Bkb3duQXV0b30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvZGlyZWN0aXZlcy9kcm9wZG93bic7XG5pbXBvcnQgdHlwZSB7VHVpQ2FsZW5kYXJSYW5nZX0gZnJvbSAnQHRhaWdhLXVpL2tpdC9jb21wb25lbnRzL2NhbGVuZGFyLXJhbmdlJztcbmltcG9ydCB7XG4gICAgVFVJX0RBVEVfQURBUFRFUixcbiAgICBUVUlfSU5QVVRfREFURV9PUFRJT05TX05FVyxcbiAgICBUdWlJbnB1dERhdGVCYXNlLFxufSBmcm9tICdAdGFpZ2EtdWkva2l0L2NvbXBvbmVudHMvaW5wdXQtZGF0ZSc7XG5pbXBvcnQge3R1aU1hc2tpdG99IGZyb20gJ0B0YWlnYS11aS9raXQvdXRpbHMnO1xuXG5pbXBvcnQge1RVSV9JTlBVVF9EQVRFX1JBTkdFX09QVElPTlN9IGZyb20gJy4vaW5wdXQtZGF0ZS1yYW5nZS5vcHRpb25zJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2lucHV0W3R1aUlucHV0RGF0ZVJhbmdlXScsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHR1aUFzQ29udHJvbChUdWlJbnB1dERhdGVSYW5nZURpcmVjdGl2ZSksXG4gICAgICAgIHR1aVZhbHVlVHJhbnNmb3JtZXJGcm9tKFRVSV9JTlBVVF9EQVRFX1JBTkdFX09QVElPTlMpLFxuICAgICAgICB0dWlQcm92aWRlKFRVSV9JTlBVVF9EQVRFX09QVElPTlNfTkVXLCBUVUlfSU5QVVRfREFURV9SQU5HRV9PUFRJT05TKSxcbiAgICBdLFxuICAgIGhvc3REaXJlY3RpdmVzOiBbVHVpV2l0aFRleHRmaWVsZCwgVHVpRHJvcGRvd25BdXRvLCBNYXNraXRvRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpSW5wdXREYXRlUmFuZ2VEaXJlY3RpdmUgZXh0ZW5kcyBUdWlJbnB1dERhdGVCYXNlPFR1aURheVJhbmdlPiB7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHJhbmdlRmlsbGVyID0gdHVpRGlyZWN0aXZlQmluZGluZyhcbiAgICAgICAgVHVpVGV4dGZpZWxkQ29tcG9uZW50LFxuICAgICAgICAnZmlsbGVyU2V0dGVyJyxcbiAgICAgICAgY29tcHV0ZWQoKGZpbGxlciA9IHRoaXMuZmlsbGVyKCkpID0+IGAke2ZpbGxlcn0ke1JBTkdFX1NFUEFSQVRPUl9DSEFSfSR7ZmlsbGVyfWApLFxuICAgICAgICB7fSxcbiAgICApO1xuXG4gICAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlYWRvbmx5IG1hc2sgPSB0dWlNYXNraXRvKFxuICAgICAgICBjb21wdXRlZCgoKSA9PlxuICAgICAgICAgICAgbWFza2l0b0RhdGVSYW5nZU9wdGlvbnNHZW5lcmF0b3Ioe1xuICAgICAgICAgICAgICAgIGRhdGVTZXBhcmF0b3I6IHRoaXMuZm9ybWF0KCkuc2VwYXJhdG9yLFxuICAgICAgICAgICAgICAgIG1vZGU6IFRVSV9EQVRFX0FEQVBURVJbdGhpcy5mb3JtYXQoKS5tb2RlXSxcbiAgICAgICAgICAgICAgICBtaW46IHRoaXMubWluKCkudG9Mb2NhbE5hdGl2ZURhdGUoKSxcbiAgICAgICAgICAgICAgICBtYXg6IHRoaXMubWF4KCkudG9Mb2NhbE5hdGl2ZURhdGUoKSxcbiAgICAgICAgICAgICAgICBtaW5MZW5ndGg6IHRoaXMubWluTGVuZ3RoKCkgfHwge30sXG4gICAgICAgICAgICAgICAgbWF4TGVuZ3RoOiB0aGlzLm1heExlbmd0aCgpIHx8IHt9LFxuICAgICAgICAgICAgfSksXG4gICAgICAgICksXG4gICAgKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBtaW5MZW5ndGggPSBzaWduYWw8VHVpRGF5TGlrZSB8IG51bGw+KG51bGwpO1xuICAgIHB1YmxpYyByZWFkb25seSBtYXhMZW5ndGggPSBzaWduYWw8VHVpRGF5TGlrZSB8IG51bGw+KG51bGwpO1xuXG4gICAgQElucHV0KCdtaW5MZW5ndGgnKVxuICAgIHB1YmxpYyBzZXQgbWluTGVuZ3RoU2V0dGVyKG1pbkxlbmd0aDogVHVpRGF5TGlrZSB8IG51bGwpIHtcbiAgICAgICAgdGhpcy5taW5MZW5ndGguc2V0KG1pbkxlbmd0aCk7XG4gICAgfVxuXG4gICAgQElucHV0KCdtYXhMZW5ndGgnKVxuICAgIHB1YmxpYyBzZXQgbWF4TGVuZ3RoU2V0dGVyKG1heExlbmd0aDogVHVpRGF5TGlrZSB8IG51bGwpIHtcbiAgICAgICAgdGhpcy5tYXhMZW5ndGguc2V0KG1heExlbmd0aCk7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIG92ZXJyaWRlIHByb2Nlc3NDYWxlbmRhcihjYWxlbmRhcjogVHVpQ2FsZW5kYXJSYW5nZSk6IHZvaWQge1xuICAgICAgICBzdXBlci5wcm9jZXNzQ2FsZW5kYXIoY2FsZW5kYXIpO1xuXG4gICAgICAgIGNhbGVuZGFyLm1pbkxlbmd0aCA9IHRoaXMubWluTGVuZ3RoKCk7XG4gICAgICAgIGNhbGVuZGFyLm1heExlbmd0aCA9IHRoaXMubWF4TGVuZ3RoKCk7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIG92ZXJyaWRlIG9uVmFsdWVDaGFuZ2UodmFsdWU6IHN0cmluZyk6IHZvaWQge1xuICAgICAgICB0aGlzLmNvbnRyb2w/LmNvbnRyb2w/LnVwZGF0ZVZhbHVlQW5kVmFsaWRpdHkoe2VtaXRFdmVudDogZmFsc2V9KTtcbiAgICAgICAgdGhpcy5vbkNoYW5nZShcbiAgICAgICAgICAgIHZhbHVlLmxlbmd0aCA9PT0gREFURV9SQU5HRV9GSUxMRVJfTEVOR1RIXG4gICAgICAgICAgICAgICAgPyBUdWlEYXlSYW5nZS5ub3JtYWxpemVQYXJzZSh2YWx1ZSwgdGhpcy5mb3JtYXQoKS5tb2RlKVxuICAgICAgICAgICAgICAgIDogbnVsbCxcbiAgICAgICAgKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -20,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
20
20
|
type: ContentChild,
|
|
21
21
|
args: [NgControl]
|
|
22
22
|
}] } });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtaW5saW5lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL2lucHV0LWlubGluZS9pbnB1dC1pbmxpbmUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvaW5wdXQtaW5saW5lL2lucHV0LWlubGluZS50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsSUFBSSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDaEQsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLGlCQUFpQixHQUNwQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsU0FBUyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDekMsT0FBTyxFQUFDLE1BQU0sRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3BELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUMsS0FBSyxFQUFDLE1BQU0sTUFBTSxDQUFDOztBQUUzQixNQVNhLGNBQWM7SUFUM0I7UUFhdUIsV0FBTSxHQUFHLEtBQUssQ0FBQyxHQUFHLEVBQUUsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQVEsQ0FBQyxDQUFDLENBQUM7S0FDM0U7K0dBTFksY0FBYzttR0FBZCxjQUFjLGlIQUNULFNBQVMsZ0RDdEIzQiwyV0FlQSx5bkJEQWMsU0FBUyw4Q0FBRSxJQUFJLDZGQUFFLE1BQU07O1NBTXhCLGNBQWM7NEZBQWQsY0FBYztrQkFUMUIsU0FBUztpQ0FDTSxJQUFJLFlBQ04sa0JBQWtCLFdBQ25CLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxNQUFNLENBQUMsaUJBR25CLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU07OEJBSTlCLE9BQU87c0JBRHZCLFlBQVk7dUJBQUMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXN5bmNQaXBlLCBOZ0lmfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnQsXG4gICAgQ29udGVudENoaWxkLFxuICAgIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TmdDb250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge1R1aUxldH0gZnJvbSAnQHRhaWdhLXVpL2Nkay9kaXJlY3RpdmVzL2xldCc7XG5pbXBvcnQge3R1aUNvbnRyb2xWYWx1ZX0gZnJvbSAnQHRhaWdhLXVpL2Nkay9vYnNlcnZhYmxlcyc7XG5pbXBvcnQge2RlZmVyfSBmcm9tICdyeGpzJztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ3R1aS1pbnB1dC1pbmxpbmUnLFxuICAgIGltcG9ydHM6IFtBc3luY1BpcGUsIE5nSWYsIFR1aUxldF0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL2lucHV0LWlubGluZS50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9pbnB1dC1pbmxpbmUuc3R5bGUubGVzcyddLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFR1aUlucHV0SW5saW5lIHtcbiAgICBAQ29udGVudENoaWxkKE5nQ29udHJvbClcbiAgICBwcml2YXRlIHJlYWRvbmx5IGNvbnRyb2w/OiBOZ0NvbnRyb2w7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgdmFsdWUkID0gZGVmZXIoKCkgPT4gdHVpQ29udHJvbFZhbHVlKHRoaXMuY29udHJvbCEpKTtcbn1cbiIsIjxuZy1jb250YWluZXIgKnR1aUxldD1cInZhbHVlJCB8IGFzeW5jIGFzIHZhbHVlXCI+XG4gICAgPHNwYW5cbiAgICAgICAgY2xhc3M9XCJ0LWJlZm9yZVwiXG4gICAgICAgIFt0ZXh0Q29udGVudF09XCJ2YWx1ZVwiXG4gICAgPjwvc3Bhbj5cblxuICAgIDxzcGFuXG4gICAgICAgICpuZ0lmPVwiIXZhbHVlXCJcbiAgICAgICAgYXV0b21hdGlvbi1pZD1cInR1aS1pbnB1dC1pbmxpbmVfX3BsYWNlaG9sZGVyXCJcbiAgICAgICAgY2xhc3M9XCJ0LXBsYWNlaG9sZGVyXCJcbiAgICA+XG4gICAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgPC9zcGFuPlxuPC9uZy1jb250YWluZXI+XG48bmctY29udGVudCBzZWxlY3Q9XCJpbnB1dFwiIC8+XG4iXX0=
|