@taiga-ui/core 3.9.0 → 3.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taiga-ui-core-abstract.umd.js +1 -1
- package/bundles/taiga-ui-core-abstract.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-alert.umd.js +1 -1
- package/bundles/taiga-ui-core-components-alert.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-button.umd.js +1 -1
- package/bundles/taiga-ui-core-components-button.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-calendar.umd.js +1 -1
- package/bundles/taiga-ui-core-components-calendar.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-data-list.umd.js +39 -21
- package/bundles/taiga-ui-core-components-data-list.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-dialog.umd.js +2 -2
- package/bundles/taiga-ui-core-components-dialog.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-error.umd.js +1 -1
- package/bundles/taiga-ui-core-components-error.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-expand.umd.js +1 -1
- package/bundles/taiga-ui-core-components-expand.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-group.umd.js +1 -1
- package/bundles/taiga-ui-core-components-group.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js +35 -24
- package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-label.umd.js +1 -1
- package/bundles/taiga-ui-core-components-label.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-link.umd.js +1 -1
- package/bundles/taiga-ui-core-components-link.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-loader.umd.js +1 -1
- package/bundles/taiga-ui-core-components-loader.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-notification.umd.js +1 -1
- package/bundles/taiga-ui-core-components-notification.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-primitive-calendar.umd.js +2 -2
- package/bundles/taiga-ui-core-components-primitive-calendar.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-primitive-checkbox.umd.js +1 -1
- package/bundles/taiga-ui-core-components-primitive-checkbox.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-primitive-spin-button.umd.js +1 -1
- package/bundles/taiga-ui-core-components-primitive-spin-button.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-primitive-textfield.umd.js +3 -3
- package/bundles/taiga-ui-core-components-primitive-textfield.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-primitive-year-picker.umd.js +3 -2
- package/bundles/taiga-ui-core-components-primitive-year-picker.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-root.umd.js +2 -2
- package/bundles/taiga-ui-core-components-root.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-scroll-controls.umd.js +1 -1
- package/bundles/taiga-ui-core-components-scroll-controls.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-scrollbar.umd.js +1 -1
- package/bundles/taiga-ui-core-components-scrollbar.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-svg.umd.js +1 -1
- package/bundles/taiga-ui-core-components-svg.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-theme-night.umd.js +1 -1
- package/bundles/taiga-ui-core-components-theme-night.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-tooltip.umd.js +1 -1
- package/bundles/taiga-ui-core-components-tooltip.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-dropdown.umd.js +3 -3
- package/bundles/taiga-ui-core-directives-dropdown.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-hint.umd.js +2 -1
- package/bundles/taiga-ui-core-directives-hint.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-mode.umd.js +1 -1
- package/bundles/taiga-ui-core-directives-mode.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-scroll-into-view.umd.js +1 -1
- package/bundles/taiga-ui-core-directives-scroll-into-view.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js +1 -1
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js.map +1 -1
- package/bundles/taiga-ui-core-internal-primitive-year-month-pagination.umd.js +1 -1
- package/bundles/taiga-ui-core-internal-primitive-year-month-pagination.umd.js.map +1 -1
- package/bundles/taiga-ui-core-pipes-calendar-sheet.umd.js +1 -1
- package/bundles/taiga-ui-core-pipes-calendar-sheet.umd.js.map +1 -1
- package/bundles/taiga-ui-core-pipes-order-week-days.umd.js +1 -1
- package/bundles/taiga-ui-core-pipes-order-week-days.umd.js.map +1 -1
- package/bundles/taiga-ui-core-services.umd.js +1 -1
- package/bundles/taiga-ui-core-services.umd.js.map +1 -1
- package/bundles/taiga-ui-core-tokens.umd.js +1 -1
- package/bundles/taiga-ui-core-tokens.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-dom.umd.js +1 -0
- package/bundles/taiga-ui-core-utils-dom.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-format.umd.js +1 -1
- package/bundles/taiga-ui-core-utils-format.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-mask.umd.js +3 -2
- package/bundles/taiga-ui-core-utils-mask.umd.js.map +1 -1
- package/components/data-list/data-list.component.d.ts +6 -3
- package/components/data-list/option/option.component.d.ts +2 -1
- package/components/hosted-dropdown/hosted-dropdown.component.d.ts +9 -3
- package/components/svg/svg.component.d.ts +1 -1
- package/directives/hint/hint.directive.d.ts +2 -2
- package/esm2015/components/data-list/data-list.component.js +26 -8
- package/esm2015/components/data-list/option/option.component.js +4 -3
- package/esm2015/components/dialog/dialog.component.js +1 -1
- package/esm2015/components/hosted-dropdown/hosted-dropdown.component.js +18 -8
- package/esm2015/components/primitive-calendar/primitive-calendar.component.js +1 -1
- package/esm2015/components/primitive-textfield/primitive-textfield.component.js +1 -1
- package/esm2015/components/primitive-textfield/textfield/textfield.component.js +1 -1
- package/esm2015/components/primitive-year-picker/primitive-year-picker.component.js +3 -2
- package/esm2015/components/root/root.component.js +2 -2
- package/esm2015/components/svg/svg.component.js +1 -1
- package/esm2015/directives/dropdown/dropdown.component.js +3 -3
- package/esm2015/directives/hint/hint-position.directive.js +2 -1
- package/esm2015/directives/hint/hint.directive.js +1 -1
- package/esm2015/pipes/calendar-sheet/utils.js +2 -2
- package/esm2015/utils/dom/get-word-range.js +2 -1
- package/esm2015/utils/mask/create-number-mask.js +3 -2
- package/fesm2015/taiga-ui-core-components-data-list.js +27 -8
- package/fesm2015/taiga-ui-core-components-data-list.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-dialog.js +1 -1
- package/fesm2015/taiga-ui-core-components-hosted-dropdown.js +18 -8
- package/fesm2015/taiga-ui-core-components-hosted-dropdown.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-primitive-calendar.js +1 -1
- package/fesm2015/taiga-ui-core-components-primitive-textfield.js +2 -2
- package/fesm2015/taiga-ui-core-components-primitive-textfield.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-primitive-year-picker.js +2 -1
- package/fesm2015/taiga-ui-core-components-primitive-year-picker.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-root.js +1 -1
- package/fesm2015/taiga-ui-core-components-root.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-svg.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-dropdown.js +2 -2
- package/fesm2015/taiga-ui-core-directives-dropdown.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-hint.js +1 -0
- package/fesm2015/taiga-ui-core-directives-hint.js.map +1 -1
- package/fesm2015/taiga-ui-core-pipes-calendar-sheet.js +1 -1
- package/fesm2015/taiga-ui-core-pipes-calendar-sheet.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-dom.js +1 -0
- package/fesm2015/taiga-ui-core-utils-dom.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-mask.js +2 -1
- package/fesm2015/taiga-ui-core-utils-mask.js.map +1 -1
- package/package.json +4 -4
- package/styles/mixins/mixins.less +17 -0
- package/styles/mixins/picker.less +1 -1
- package/styles/mixins/picker.scss +1 -1
|
@@ -8,14 +8,14 @@ import { TuiHintOptions } from './hint-options.directive';
|
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export declare class TuiHintDirective<C> implements OnDestroy, OnChanges, TuiPortalItem<C>, TuiRectAccessor, TuiVehicle {
|
|
10
10
|
private readonly elementRef;
|
|
11
|
-
readonly component: PolymorpheusComponent<
|
|
11
|
+
readonly component: PolymorpheusComponent<Record<string, any>, Record<string, any>>;
|
|
12
12
|
private readonly hintService;
|
|
13
13
|
private readonly options;
|
|
14
14
|
readonly activeZone?: TuiActiveZoneDirective | null | undefined;
|
|
15
15
|
content: PolymorpheusContent<C>;
|
|
16
16
|
context?: C;
|
|
17
17
|
tuiHintAppearance: string | null;
|
|
18
|
-
constructor(elementRef: ElementRef<HTMLElement>, component: PolymorpheusComponent<
|
|
18
|
+
constructor(elementRef: ElementRef<HTMLElement>, component: PolymorpheusComponent<Record<string, any>, Record<string, any>>, hintService: TuiHintService, options: TuiHintOptions, activeZone?: TuiActiveZoneDirective | null | undefined);
|
|
19
19
|
get appearance(): string;
|
|
20
20
|
ngOnChanges(): void;
|
|
21
21
|
ngOnDestroy(): void;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, forwardRef, HostBinding, HostListener, Inject, Input, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, forwardRef, HostBinding, HostListener, Inject, Input, Optional, ViewEncapsulation, } from '@angular/core';
|
|
3
3
|
import { EMPTY_QUERY, tuiDefaultProp, tuiIsElement, tuiIsNativeFocusedIn, tuiIsPresent, tuiItemsQueryListObservable, tuiMoveFocus, tuiPure, tuiSetNativeMouseFocused, } from '@taiga-ui/cdk';
|
|
4
|
+
import { TuiTextfieldSizeDirective } from '@taiga-ui/core/directives';
|
|
4
5
|
import { TUI_NOTHING_FOUND_MESSAGE, tuiAsDataListAccessor } from '@taiga-ui/core/tokens';
|
|
5
6
|
import { map } from 'rxjs/operators';
|
|
6
7
|
// TODO: find the best way for prevent cycle
|
|
@@ -9,15 +10,19 @@ import { TuiOptionComponent } from './option/option.component';
|
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
import * as i1 from "@angular/common";
|
|
11
12
|
import * as i2 from "@tinkoff/ng-polymorpheus";
|
|
12
|
-
import * as i3 from "
|
|
13
|
+
import * as i3 from "@taiga-ui/core/directives";
|
|
14
|
+
import * as i4 from "rxjs";
|
|
13
15
|
// TODO: Consider aria-activedescendant for proper accessibility implementation
|
|
14
16
|
export class TuiDataListComponent {
|
|
15
|
-
constructor(elementRef, defaultEmptyContent$) {
|
|
17
|
+
constructor(controller, elementRef, defaultEmptyContent$) {
|
|
18
|
+
var _a;
|
|
19
|
+
this.controller = controller;
|
|
16
20
|
this.elementRef = elementRef;
|
|
17
21
|
this.defaultEmptyContent$ = defaultEmptyContent$;
|
|
18
22
|
this.options = EMPTY_QUERY;
|
|
19
23
|
this.role = `listbox`;
|
|
20
24
|
this.emptyContent = ``;
|
|
25
|
+
this.size = ((_a = this.controller) === null || _a === void 0 ? void 0 : _a.size) || `m`;
|
|
21
26
|
}
|
|
22
27
|
get empty$() {
|
|
23
28
|
return tuiItemsQueryListObservable(this.options).pipe(map(({ length }) => !length));
|
|
@@ -56,14 +61,17 @@ export class TuiDataListComponent {
|
|
|
56
61
|
return Array.from(this.elementRef.nativeElement.querySelectorAll(`[tuiOption]`));
|
|
57
62
|
}
|
|
58
63
|
}
|
|
59
|
-
TuiDataListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDataListComponent, deps: [{ token: ElementRef }, { token: TUI_NOTHING_FOUND_MESSAGE }], target: i0.ɵɵFactoryTarget.Component });
|
|
60
|
-
TuiDataListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDataListComponent, selector: "tui-data-list", inputs: { role: "role", emptyContent: "emptyContent" }, host: { listeners: { "focusin": "onFocusIn($event.relatedTarget,$event.currentTarget)", "mousedown.prevent": "noop()", "keydown.arrowDown.prevent": "onKeyDownArrow($event.target,1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target,-1)", "wheel.silent.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)" }, properties: { "attr.role": "this.role" } }, providers: [tuiAsDataListAccessor(TuiDataListComponent)], queries: [{ propertyName: "options", predicate: i0.forwardRef(function () { return TuiOptionComponent; }), descendants: true }], ngImport: i0, template: "<div\n tabindex=\"0\"\n class=\"t-trap\"\n (focusin)=\"onFocus($event, true)\"\n></div>\n<ng-content></ng-content>\n<div\n *ngIf=\"empty$ | async\"\n class=\"t-empty\"\n>\n <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n {{ text }}\n </ng-container>\n</div>\n<div\n tabindex=\"0\"\n class=\"t-trap\"\n (focusin)=\"onFocus($event, false)\"\n></div>\n", styles: ["tui-data-list{display:flex;font:var(--tui-font-text-m);flex-direction:column;padding
|
|
64
|
+
TuiDataListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDataListComponent, deps: [{ token: TuiTextfieldSizeDirective, optional: true }, { token: ElementRef }, { token: TUI_NOTHING_FOUND_MESSAGE }], target: i0.ɵɵFactoryTarget.Component });
|
|
65
|
+
TuiDataListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDataListComponent, selector: "tui-data-list", inputs: { role: "role", emptyContent: "emptyContent", size: "size" }, host: { listeners: { "focusin": "onFocusIn($event.relatedTarget,$event.currentTarget)", "mousedown.prevent": "noop()", "keydown.arrowDown.prevent": "onKeyDownArrow($event.target,1)", "keydown.arrowUp.prevent": "onKeyDownArrow($event.target,-1)", "wheel.silent.passive": "handleFocusLossIfNecessary()", "mouseleave": "handleFocusLossIfNecessary($event.target)" }, properties: { "attr.role": "this.role", "attr.data-list-size": "this.size" } }, providers: [tuiAsDataListAccessor(TuiDataListComponent)], queries: [{ propertyName: "options", predicate: i0.forwardRef(function () { return TuiOptionComponent; }), descendants: true }], ngImport: i0, template: "<div\n tabindex=\"0\"\n class=\"t-trap\"\n (focusin)=\"onFocus($event, true)\"\n></div>\n<ng-content></ng-content>\n<div\n *ngIf=\"empty$ | async\"\n class=\"t-empty\"\n>\n <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n {{ text }}\n </ng-container>\n</div>\n<div\n tabindex=\"0\"\n class=\"t-trap\"\n (focusin)=\"onFocus($event, false)\"\n></div>\n", styles: ["tui-data-list{--tui-padding: .25rem;display:flex;font:var(--tui-font-text-m);flex-direction:column;padding:var(--tui-padding);color:var(--tui-text-03)}tui-data-list:focus-within .t-trap{display:none}tui-data-list:focus-within [tuiOption]._with-dropdown:not(:focus){background-color:transparent}tui-data-list[data-list-size=l]{--tui-padding: .375rem}tui-data-list>.t-empty{margin:.75rem 1rem}tui-opt-group{position:relative;display:flex;font:var(--tui-font-text-xs);color:var(--tui-text-02);flex-direction:column;line-height:1rem}tui-data-list[data-list-size=l] tui-opt-group{font:var(--tui-font-text-s);line-height:1.25rem}tui-data-list[data-list-size=l] tui-opt-group:before{padding-left:.625rem;padding-right:.625rem}tui-data-list[data-list-size=l] tui-opt-group:after{left:.625rem;right:.625rem}tui-opt-group:empty:before,tui-opt-group:empty:after{display:none}tui-opt-group:before{content:attr(data-label);padding:var(--tui-padding) .5rem var(--tui-padding);white-space:normal;word-break:break-word}tui-opt-group:after{position:absolute;left:.5rem;right:.5rem;top:var(--tui-padding);height:1px;background:var(--tui-base-03)}tui-opt-group:not(:empty)~tui-opt-group:before{padding-top:calc(.75rem + var(--tui-padding))}tui-opt-group:not(:empty)~tui-opt-group[data-label=\"\"]:before{padding:var(--tui-padding) 0}tui-opt-group:not(:empty)~tui-opt-group:after{content:\"\"}tui-opt-group[data-label=\"\"]:before{padding:0 .5rem}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], pipes: { "async": i1.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
61
66
|
__decorate([
|
|
62
67
|
tuiDefaultProp()
|
|
63
68
|
], TuiDataListComponent.prototype, "role", void 0);
|
|
64
69
|
__decorate([
|
|
65
70
|
tuiDefaultProp()
|
|
66
71
|
], TuiDataListComponent.prototype, "emptyContent", void 0);
|
|
72
|
+
__decorate([
|
|
73
|
+
tuiDefaultProp()
|
|
74
|
+
], TuiDataListComponent.prototype, "size", void 0);
|
|
67
75
|
__decorate([
|
|
68
76
|
tuiPure
|
|
69
77
|
], TuiDataListComponent.prototype, "empty$", null);
|
|
@@ -77,10 +85,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
77
85
|
encapsulation: ViewEncapsulation.None,
|
|
78
86
|
providers: [tuiAsDataListAccessor(TuiDataListComponent)],
|
|
79
87
|
}]
|
|
80
|
-
}], ctorParameters: function () { return [{ type:
|
|
88
|
+
}], ctorParameters: function () { return [{ type: i3.TuiTextfieldSizeDirective, decorators: [{
|
|
89
|
+
type: Optional
|
|
90
|
+
}, {
|
|
91
|
+
type: Inject,
|
|
92
|
+
args: [TuiTextfieldSizeDirective]
|
|
93
|
+
}] }, { type: i0.ElementRef, decorators: [{
|
|
81
94
|
type: Inject,
|
|
82
95
|
args: [ElementRef]
|
|
83
|
-
}] }, { type:
|
|
96
|
+
}] }, { type: i4.Observable, decorators: [{
|
|
84
97
|
type: Inject,
|
|
85
98
|
args: [TUI_NOTHING_FOUND_MESSAGE]
|
|
86
99
|
}] }]; }, propDecorators: { options: [{
|
|
@@ -93,6 +106,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
93
106
|
args: [`attr.role`]
|
|
94
107
|
}], emptyContent: [{
|
|
95
108
|
type: Input
|
|
109
|
+
}], size: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}, {
|
|
112
|
+
type: HostBinding,
|
|
113
|
+
args: [`attr.data-list-size`]
|
|
96
114
|
}], empty$: [], onFocusIn: [{
|
|
97
115
|
type: HostListener,
|
|
98
116
|
args: [`focusin`, [`$event.relatedTarget`, `$event.currentTarget`]]
|
|
@@ -112,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
112
130
|
type: HostListener,
|
|
113
131
|
args: [`mouseleave`, [`$event.target`]]
|
|
114
132
|
}] } });
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/data-list/data-list.component.ts","../../../../../projects/core/components/data-list/data-list.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    QueryList,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    tuiDefaultProp,\n    tuiIsElement,\n    tuiIsNativeFocusedIn,\n    tuiIsPresent,\n    tuiItemsQueryListObservable,\n    tuiMoveFocus,\n    tuiPure,\n    tuiSetNativeMouseFocused,\n} from '@taiga-ui/cdk';\nimport {TuiDataListAccessor} from '@taiga-ui/core/interfaces';\nimport {TUI_NOTHING_FOUND_MESSAGE, tuiAsDataListAccessor} from '@taiga-ui/core/tokens';\nimport {TuiDataListRole} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiOptionComponent} from './option/option.component';\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    selector: `tui-data-list`,\n    templateUrl: `./data-list.template.html`,\n    styleUrls: [`./data-list.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [tuiAsDataListAccessor(TuiDataListComponent)],\n})\nexport class TuiDataListComponent<T> implements TuiDataListAccessor<T> {\n    @ContentChildren(forwardRef(() => TuiOptionComponent), {descendants: true})\n    private readonly options: QueryList<TuiOptionComponent<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n\n    @Input()\n    @HostBinding(`attr.role`)\n    @tuiDefaultProp()\n    role: TuiDataListRole = `listbox`;\n\n    @Input()\n    @tuiDefaultProp()\n    emptyContent: PolymorpheusContent = ``;\n\n    constructor(\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(TUI_NOTHING_FOUND_MESSAGE)\n        readonly defaultEmptyContent$: Observable<string>,\n    ) {}\n\n    @tuiPure\n    get empty$(): Observable<boolean> {\n        return tuiItemsQueryListObservable(this.options).pipe(map(({length}) => !length));\n    }\n\n    @HostListener(`focusin`, [`$event.relatedTarget`, `$event.currentTarget`])\n    onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    @HostListener(`mousedown.prevent`)\n    noop(): void {}\n\n    @HostListener(`keydown.arrowDown.prevent`, [`$event.target`, `1`])\n    @HostListener(`keydown.arrowUp.prevent`, [`$event.target`, `-1`])\n    onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    // TODO: Consider aria-activedescendant for proper accessibility implementation\n    @HostListener(`wheel.silent.passive`)\n    @HostListener(`mouseleave`, [`$event.target`])\n    handleFocusLossIfNecessary(element: Element = this.elementRef.nativeElement): void {\n        if (this.origin && tuiIsNativeFocusedIn(element)) {\n            tuiSetNativeMouseFocused(this.origin, true, true);\n        }\n    }\n\n    getOptions(includeDisabled: boolean = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    onFocus({target}: Event, top: boolean): void {\n        if (!tuiIsElement(target)) {\n            return;\n        }\n\n        const {elements} = this;\n\n        tuiMoveFocus(top ? -1 : elements.length, elements, top ? 1 : -1);\n        this.handleFocusLossIfNecessary(target);\n    }\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(this.elementRef.nativeElement.querySelectorAll(`[tuiOption]`));\n    }\n}\n","<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, true)\"\n></div>\n<ng-content></ng-content>\n<div\n    *ngIf=\"empty$ | async\"\n    class=\"t-empty\"\n>\n    <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n        {{ text }}\n    </ng-container>\n</div>\n<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, false)\"\n></div>\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-list.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/data-list/data-list.component.ts","../../../../../projects/core/components/data-list/data-list.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    ViewEncapsulation,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    tuiDefaultProp,\n    tuiIsElement,\n    tuiIsNativeFocusedIn,\n    tuiIsPresent,\n    tuiItemsQueryListObservable,\n    tuiMoveFocus,\n    tuiPure,\n    tuiSetNativeMouseFocused,\n} from '@taiga-ui/cdk';\nimport {TuiTextfieldSizeDirective} from '@taiga-ui/core/directives';\nimport {TuiDataListAccessor} from '@taiga-ui/core/interfaces';\nimport {TUI_NOTHING_FOUND_MESSAGE, tuiAsDataListAccessor} from '@taiga-ui/core/tokens';\nimport {TuiDataListRole} from '@taiga-ui/core/types';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiOptionComponent} from './option/option.component';\n\n// TODO: Consider aria-activedescendant for proper accessibility implementation\n@Component({\n    selector: `tui-data-list`,\n    templateUrl: `./data-list.template.html`,\n    styleUrls: [`./data-list.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [tuiAsDataListAccessor(TuiDataListComponent)],\n})\nexport class TuiDataListComponent<T> implements TuiDataListAccessor<T> {\n    @ContentChildren(forwardRef(() => TuiOptionComponent), {descendants: true})\n    private readonly options: QueryList<TuiOptionComponent<T>> = EMPTY_QUERY;\n\n    private origin?: HTMLElement;\n\n    @Input()\n    @HostBinding(`attr.role`)\n    @tuiDefaultProp()\n    role: TuiDataListRole = `listbox`;\n\n    @Input()\n    @tuiDefaultProp()\n    emptyContent: PolymorpheusContent = ``;\n\n    @Input()\n    @HostBinding(`attr.data-list-size`)\n    @tuiDefaultProp()\n    size = this.controller?.size || `m`;\n\n    constructor(\n        @Optional()\n        @Inject(TuiTextfieldSizeDirective)\n        private readonly controller: TuiTextfieldSizeDirective | null,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(TUI_NOTHING_FOUND_MESSAGE)\n        readonly defaultEmptyContent$: Observable<string>,\n    ) {}\n\n    @tuiPure\n    get empty$(): Observable<boolean> {\n        return tuiItemsQueryListObservable(this.options).pipe(map(({length}) => !length));\n    }\n\n    @HostListener(`focusin`, [`$event.relatedTarget`, `$event.currentTarget`])\n    onFocusIn(relatedTarget: HTMLElement, currentTarget: HTMLElement): void {\n        if (!currentTarget.contains(relatedTarget) && !this.origin) {\n            this.origin = relatedTarget;\n        }\n    }\n\n    @HostListener(`mousedown.prevent`)\n    noop(): void {}\n\n    @HostListener(`keydown.arrowDown.prevent`, [`$event.target`, `1`])\n    @HostListener(`keydown.arrowUp.prevent`, [`$event.target`, `-1`])\n    onKeyDownArrow(current: HTMLElement, step: number): void {\n        const {elements} = this;\n\n        tuiMoveFocus(elements.indexOf(current), elements, step);\n    }\n\n    // TODO: Consider aria-activedescendant for proper accessibility implementation\n    @HostListener(`wheel.silent.passive`)\n    @HostListener(`mouseleave`, [`$event.target`])\n    handleFocusLossIfNecessary(element: Element = this.elementRef.nativeElement): void {\n        if (this.origin && tuiIsNativeFocusedIn(element)) {\n            tuiSetNativeMouseFocused(this.origin, true, true);\n        }\n    }\n\n    getOptions(includeDisabled: boolean = false): readonly T[] {\n        return this.options\n            .filter(({disabled}) => includeDisabled || !disabled)\n            .map(({value}) => value)\n            .filter(tuiIsPresent);\n    }\n\n    onFocus({target}: Event, top: boolean): void {\n        if (!tuiIsElement(target)) {\n            return;\n        }\n\n        const {elements} = this;\n\n        tuiMoveFocus(top ? -1 : elements.length, elements, top ? 1 : -1);\n        this.handleFocusLossIfNecessary(target);\n    }\n\n    private get elements(): readonly HTMLElement[] {\n        return Array.from(this.elementRef.nativeElement.querySelectorAll(`[tuiOption]`));\n    }\n}\n","<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, true)\"\n></div>\n<ng-content></ng-content>\n<div\n    *ngIf=\"empty$ | async\"\n    class=\"t-empty\"\n>\n    <ng-container *polymorpheusOutlet=\"emptyContent || (defaultEmptyContent$ | async) as text\">\n        {{ text }}\n    </ng-container>\n</div>\n<div\n    tabindex=\"0\"\n    class=\"t-trap\"\n    (focusin)=\"onFocus($event, false)\"\n></div>\n"]}
|
|
@@ -24,7 +24,8 @@ export class TuiOptionComponent {
|
|
|
24
24
|
this.elementRef = elementRef;
|
|
25
25
|
this.host = host;
|
|
26
26
|
this.dropdown = dropdown;
|
|
27
|
-
|
|
27
|
+
/** @deprecated use size on {@link TuiDataListComponent} instead */
|
|
28
|
+
this.size = null;
|
|
28
29
|
this.role = `option`;
|
|
29
30
|
this.disabled = false;
|
|
30
31
|
}
|
|
@@ -46,7 +47,7 @@ export class TuiOptionComponent {
|
|
|
46
47
|
}
|
|
47
48
|
}
|
|
48
49
|
TuiOptionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiOptionComponent, deps: [{ token: TUI_OPTION_CONTENT, optional: true }, { token: forwardRef(() => TuiDataListComponent) }, { token: ElementRef }, { token: TUI_DATA_LIST_HOST, optional: true }, { token: TuiDropdownDirective, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
-
TuiOptionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiOptionComponent, selector: "button[tuiOption], a[tuiOption]", inputs: { size: "size", role: "role", disabled: "disabled", value: "value" }, host: { attributes: { "tabIndex": "-1", "type": "button" }, listeners: { "click": "onClick()", "mousemove.init": "onMouseMove($event)", "mousemove.silent": "onMouseMove($event)" }, properties: { "attr.disabled": "disabled || null", "attr.data-size": "this.size", "attr.role": "this.role", "class._with-dropdown": "this.active" } }, ngImport: i0, template: "<ng-container *polymorpheusOutlet=\"content || base as text; context: {$implicit: base}\">\n {{ text }}\n</ng-container>\n<ng-template #base>\n <ng-content></ng-content>\n <tui-svg\n *ngIf=\"dropdown\"\n src=\"tuiIconChevronRight\"\n class=\"t-arrow\"\n ></tui-svg>\n</ng-template>\n", styles: [":host{-webkit-appearance:none;-moz-appearance:none;appearance:none;
|
|
50
|
+
TuiOptionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiOptionComponent, selector: "button[tuiOption], a[tuiOption]", inputs: { size: "size", role: "role", disabled: "disabled", value: "value" }, host: { attributes: { "tabIndex": "-1", "type": "button" }, listeners: { "click": "onClick()", "mousemove.init": "onMouseMove($event)", "mousemove.silent": "onMouseMove($event)" }, properties: { "attr.disabled": "disabled || null", "attr.data-size": "this.size", "attr.role": "this.role", "class._with-dropdown": "this.active" } }, ngImport: i0, template: "<ng-container *polymorpheusOutlet=\"content || base as text; context: {$implicit: base}\">\n {{ text }}\n</ng-container>\n<ng-template #base>\n <ng-content></ng-content>\n <tui-svg\n *ngIf=\"dropdown\"\n src=\"tuiIconChevronRight\"\n class=\"t-arrow\"\n ></tui-svg>\n</ng-template>\n", styles: [":host{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:none;font-size:inherit;line-height:inherit;transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;align-items:center;justify-content:space-between;text-align:left;box-sizing:border-box;color:var(--tui-text-01);border-radius:var(--tui-radius-s);outline:none;text-decoration:none;cursor:pointer;background-clip:padding-box;font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem;margin:.125rem 0}:host:disabled{opacity:var(--tui-disabled-opacity);cursor:default}:host:focus,:host._with-dropdown{background-color:var(--tui-clear-disabled)}:host :host-context([data-list-size=\"s\"]),:host :host-context([data-list-size=\"xs\"]),:host[data-size=s][data-size=s],:host[data-size=xs][data-size=xs]{font:var(--tui-font-text-s);min-height:2rem;padding:.3125rem .5rem;margin:0}:host :host-context([data-list-size=\"m\"]),:host[data-size=m][data-size=m]{font:var(--tui-font-text-s);min-height:2.5rem;padding:.375rem .5rem;margin:.125rem 0}:host :host-context([data-list-size=\"l\"]),:host[data-size=l][data-size=l]{font:var(--tui-font-text-m);min-height:2.75rem;padding:.375rem .625rem;margin:.25rem 0}.t-arrow{margin:0 -.5rem 0 .75rem}\n"], components: [{ type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }], directives: [{ type: i2.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
50
51
|
__decorate([
|
|
51
52
|
tuiDefaultProp()
|
|
52
53
|
], TuiOptionComponent.prototype, "size", void 0);
|
|
@@ -122,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
122
123
|
type: HostListener,
|
|
123
124
|
args: [`mousemove.silent`, [`$event`]]
|
|
124
125
|
}] } });
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"option.component.js","sourceRoot":"","sources":["../../../../../../projects/core/components/data-list/option/option.component.ts","../../../../../../projects/core/components/data-list/option/option.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    Optional,\n    Self,\n    TemplateRef,\n} from '@angular/core';\nimport {\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiEventWith,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {TuiDropdownDirective} from '@taiga-ui/core/directives/dropdown';\nimport {TuiDataListHost} from '@taiga-ui/core/interfaces';\nimport {TUI_DATA_LIST_HOST, TUI_OPTION_CONTENT} from '@taiga-ui/core/tokens';\nimport {TuiOptionRole, TuiSizeL, TuiSizeXS} from '@taiga-ui/core/types';\nimport {shouldCall} from '@tinkoff/ng-event-plugins';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiDataListComponent} from '../data-list.component';\n\nfunction shouldFocus({currentTarget}: TuiEventWith<MouseEvent, HTMLElement>): boolean {\n    return !tuiIsNativeFocused(currentTarget);\n}\n\n// TODO: Consider all use cases for aria roles\n@Component({\n    selector: `button[tuiOption], a[tuiOption]`,\n    templateUrl: `./option.template.html`,\n    styleUrls: [`./option.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        tabIndex: `-1`,\n        type: `button`,\n        '[attr.disabled]': `disabled || null`,\n    },\n})\nexport class TuiOptionComponent<T = unknown> implements OnDestroy {\n    /** @deprecated use size on {@link TuiDataListComponent} instead */\n    @Input()\n    @HostBinding(`attr.data-size`)\n    @tuiDefaultProp()\n    size: TuiSizeXS | TuiSizeL | null = null;\n\n    @Input()\n    @HostBinding(`attr.role`)\n    @tuiDefaultProp()\n    role: TuiOptionRole = `option`;\n\n    @Input()\n    @tuiDefaultProp()\n    disabled = false;\n\n    @Input()\n    value?: T;\n\n    constructor(\n        @Optional()\n        @Inject(TUI_OPTION_CONTENT)\n        readonly content: PolymorpheusContent<\n            TuiContextWithImplicit<TemplateRef<Record<string, unknown>>>\n        > | null,\n        @Inject(forwardRef(() => TuiDataListComponent))\n        private readonly dataList: TuiDataListComponent<T>,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Optional()\n        @Inject(TUI_DATA_LIST_HOST)\n        private readonly host: TuiDataListHost<T> | null,\n        @Optional()\n        @Self()\n        @Inject(TuiDropdownDirective)\n        readonly dropdown: TuiDropdownDirective | null,\n    ) {}\n\n    @HostBinding(`class._with-dropdown`)\n    get active(): boolean {\n        return !!this.dropdown && !!this.dropdown.dropdownBoxRef;\n    }\n\n    @HostListener(`click`)\n    onClick(): void {\n        if (this.host && this.value !== undefined) {\n            this.host.handleOption(this.value);\n        }\n    }\n\n    // @bad TODO: Consider aria-activedescendant for proper accessibility implementation\n    @shouldCall(shouldFocus)\n    @HostListener(`mousemove.init`, [`$event`])\n    @HostListener(`mousemove.silent`, [`$event`])\n    onMouseMove({currentTarget}: TuiEventWith<MouseEvent, HTMLElement>): void {\n        currentTarget.focus({preventScroll: true});\n    }\n\n    // Preventing focus loss upon focused option removal\n    ngOnDestroy(): void {\n        this.dataList.handleFocusLossIfNecessary(this.elementRef.nativeElement);\n    }\n}\n","<ng-container *polymorpheusOutlet=\"content || base as text; context: {$implicit: base}\">\n    {{ text }}\n</ng-container>\n<ng-template #base>\n    <ng-content></ng-content>\n    <tui-svg\n        *ngIf=\"dropdown\"\n        src=\"tuiIconChevronRight\"\n        class=\"t-arrow\"\n    ></tui-svg>\n</ng-template>\n"]}
|
|
@@ -56,7 +56,7 @@ export class TuiDialogComponent {
|
|
|
56
56
|
}
|
|
57
57
|
}
|
|
58
58
|
TuiDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDialogComponent, deps: [{ token: TUI_ANIMATIONS_DURATION }, { token: TUI_IS_MOBILE }, { token: POLYMORPHEUS_CONTEXT }, { token: TUI_DIALOG_CLOSE_STREAM }, { token: TUI_CLOSE_WORD }], target: i0.ɵɵFactoryTarget.Component });
|
|
59
|
-
TuiDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDialogComponent, selector: "tui-dialog", host: { properties: { "attr.data-size": "this.size", "class._centered": "this.header", "@tuiSlideInTop": "this.slideInTop", "@tuiFadeIn": "this.slideInTop" } }, providers: TUI_DIALOG_PROVIDERS, ngImport: i0, template: "<header\n *ngIf=\"header\"\n class=\"t-header\"\n>\n <ng-container *polymorpheusOutlet=\"header as text; context: context\">\n {{ text }}\n </ng-container>\n</header>\n<div class=\"t-content\">\n <h2\n class=\"t-heading\"\n [id]=\"context.id\"\n [textContent]=\"context.label\"\n ></h2>\n <section>\n <!-- TODO: Polymorpheus fix type -->\n <ng-container *polymorpheusOutlet=\"$any(context.content) as text; context: context\">\n {{ text }}\n <div class=\"t-buttons\">\n <button\n tuiButton\n size=\"m\"\n (click)=\"context.$implicit.complete()\"\n >\n {{ $any(context.data)?.button || 'OK' }}\n </button>\n </div>\n </ng-container>\n </section>\n</div>\n<div\n *ngIf=\"context.closeable\"\n class=\"t-wrapper\"\n>\n <button\n tuiIconButton\n tuiPreventDefault=\"mousedown\"\n automation-id=\"tui-dialog__close\"\n size=\"s\"\n appearance=\"\"\n icon=\"tuiIconCloseLarge\"\n shape=\"rounded\"\n class=\"t-close\"\n [title]=\"closeWord$ | async\"\n (click)=\"close()\"\n ></button>\n</div>\n", styles: [":host{position:relative;display:flex;font:var(--tui-font-text-m);flex-direction:column;box-sizing:border-box;margin:auto;border-radius:1rem;border:2.5rem solid transparent}:host:after{position:absolute;top:0;left:0;width:100%;height:100%;box-shadow:0 1.125rem 1.875rem rgba(0,0,0,.48);content:\"\";border-radius:inherit;pointer-events:none}:host[data-size=auto]{width:auto}:host[data-size=s]{width:30rem}:host[data-size=s] .t-content{padding:1.5rem}:host[data-size=s] .t-heading{margin-bottom:.5rem;font:var(--tui-font-heading-5)}:host[data-size=m]{width:42.5rem}:host[data-size=m] .t-heading{margin-bottom:.75rem;font:var(--tui-font-heading-4)}:host[data-size=l]{width:55rem}:host[data-size=l] .t-heading{margin-bottom:1rem}:host[data-size=fullscreen],:host[data-size=page]{width:100%;min-height:100%;border-radius:0;border:none;background:var(--tui-elevation-01);box-shadow:0 4rem var(--tui-
|
|
59
|
+
TuiDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDialogComponent, selector: "tui-dialog", host: { properties: { "attr.data-size": "this.size", "class._centered": "this.header", "@tuiSlideInTop": "this.slideInTop", "@tuiFadeIn": "this.slideInTop" } }, providers: TUI_DIALOG_PROVIDERS, ngImport: i0, template: "<header\n *ngIf=\"header\"\n class=\"t-header\"\n>\n <ng-container *polymorpheusOutlet=\"header as text; context: context\">\n {{ text }}\n </ng-container>\n</header>\n<div class=\"t-content\">\n <h2\n class=\"t-heading\"\n [id]=\"context.id\"\n [textContent]=\"context.label\"\n ></h2>\n <section>\n <!-- TODO: Polymorpheus fix type -->\n <ng-container *polymorpheusOutlet=\"$any(context.content) as text; context: context\">\n {{ text }}\n <div class=\"t-buttons\">\n <button\n tuiButton\n size=\"m\"\n (click)=\"context.$implicit.complete()\"\n >\n {{ $any(context.data)?.button || 'OK' }}\n </button>\n </div>\n </ng-container>\n </section>\n</div>\n<div\n *ngIf=\"context.closeable\"\n class=\"t-wrapper\"\n>\n <button\n tuiIconButton\n tuiPreventDefault=\"mousedown\"\n automation-id=\"tui-dialog__close\"\n size=\"s\"\n appearance=\"\"\n icon=\"tuiIconCloseLarge\"\n shape=\"rounded\"\n class=\"t-close\"\n [title]=\"closeWord$ | async\"\n (click)=\"close()\"\n ></button>\n</div>\n", styles: [":host{position:relative;display:flex;font:var(--tui-font-text-m);flex-direction:column;box-sizing:border-box;margin:auto;border-radius:1rem;border:2.5rem solid transparent}:host:after{position:absolute;top:0;left:0;width:100%;height:100%;box-shadow:0 1.125rem 1.875rem rgba(0,0,0,.48);content:\"\";border-radius:inherit;pointer-events:none}:host[data-size=auto]{width:auto}:host[data-size=s]{width:30rem}:host[data-size=s] .t-content{padding:1.5rem}:host[data-size=s] .t-heading{margin-bottom:.5rem;font:var(--tui-font-heading-5)}:host[data-size=m]{width:42.5rem}:host[data-size=m] .t-heading{margin-bottom:.75rem;font:var(--tui-font-heading-4)}:host[data-size=l]{width:55rem}:host[data-size=l] .t-heading{margin-bottom:1rem}:host[data-size=fullscreen],:host[data-size=page]{width:100%;min-height:100%;border-radius:0;border:none;background:var(--tui-elevation-01);box-shadow:0 4rem var(--tui-elevation-01)}:host[data-size=fullscreen] .t-content,:host[data-size=page] .t-content{padding:3rem calc(50vw - (45rem / 2))}:host[data-size=fullscreen] .t-heading,:host[data-size=page] .t-heading{margin-bottom:1rem}:host[data-size=page] .t-content{padding:0}:host._centered{text-align:center}:host :host-context(tui-root._mobile)[data-size]{min-width:100%;width:100%;max-width:100%;border-radius:0;border:none;margin:auto 0 0}:host :host-context(tui-root._mobile)[data-size] .t-content{padding:1.5rem}:host :host-context(tui-root._mobile)[data-size] .t-heading{margin-bottom:.5rem;font:var(--tui-font-heading-5)}.t-heading{margin:0;word-wrap:break-word;font:var(--tui-font-heading-3)}.t-heading:empty{display:none}.t-header{display:flex;border-top-left-radius:inherit;border-top-right-radius:inherit;overflow:hidden}:host[data-size=fullscreen] :host-context(tui-root._mobile) .t-header{flex:1}.t-content{border-radius:inherit;padding:2rem;background:var(--tui-base-01)}.t-content:not(:first-child){border-top-left-radius:0;border-top-right-radius:0}.t-wrapper{position:-webkit-sticky;position:sticky;top:0;order:-1}.t-close{transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;position:fixed;top:1.5rem;right:1.5rem;color:var(--tui-base-01);background:rgba(104,104,104,.96)}.t-close:hover{background:rgba(159,159,159,.86)}:host:not([data-size=\"fullscreen\"]) .t-close{animation:tuiFadeIn var(--tui-duration)}:host:not([data-size=\"fullscreen\"]).ng-animating .t-close{display:none}:host-context(tui-root._mobile) .t-close{position:absolute;top:0;right:0;background:transparent;color:var(--tui-base-06)}:host-context(tui-root._mobile) .t-close:hover{color:var(--tui-base-07)}.t-buttons{margin-top:1.25rem;text-align:right}\n"], components: [{ type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i4.TuiPreventDefaultDirective, selector: "[tuiPreventDefault]" }], pipes: { "async": i2.AsyncPipe }, animations: [tuiSlideInTop, tuiFadeIn], changeDetection: i0.ChangeDetectionStrategy.Default });
|
|
60
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDialogComponent, decorators: [{
|
|
61
61
|
type: Component,
|
|
62
62
|
args: [{
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { ChangeDetectionStrategy, Component, ContentChild, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Input, Optional, Output, ViewChild, } from '@angular/core';
|
|
3
|
-
import { tuiAsFocusableItemAccessor, tuiDefaultProp, tuiGetClosestFocusable, tuiIsElement, tuiIsElementEditable, tuiIsHTMLElement, tuiIsNativeFocusedIn, tuiIsNativeKeyboardFocusable, } from '@taiga-ui/cdk';
|
|
3
|
+
import { TuiActiveZoneDirective, tuiAsFocusableItemAccessor, tuiDefaultProp, tuiGetClosestFocusable, tuiIsElement, tuiIsElementEditable, tuiIsHTMLElement, tuiIsNativeFocusedIn, tuiIsNativeKeyboardFocusable, } from '@taiga-ui/cdk';
|
|
4
4
|
import { TuiDropdownDirective, TuiDropdownHoverDirective, } from '@taiga-ui/core/directives/dropdown';
|
|
5
5
|
import { tuiIsEditingKey } from '@taiga-ui/core/utils/miscellaneous';
|
|
6
6
|
import { BehaviorSubject, combineLatest, EMPTY } from 'rxjs';
|
|
@@ -8,9 +8,9 @@ import { map, startWith } from 'rxjs/operators';
|
|
|
8
8
|
import { TuiHostedDropdownConnectorDirective } from './hosted-dropdown-connector.directive';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "@taiga-ui/cdk";
|
|
11
|
-
import * as i2 from "@
|
|
12
|
-
import * as i3 from "@
|
|
13
|
-
import * as i4 from "@
|
|
11
|
+
import * as i2 from "@angular/common";
|
|
12
|
+
import * as i3 from "@taiga-ui/core/directives/dropdown";
|
|
13
|
+
import * as i4 from "@tinkoff/ng-polymorpheus";
|
|
14
14
|
import * as i5 from "rxjs";
|
|
15
15
|
export class TuiHostedDropdownComponent {
|
|
16
16
|
constructor(hover$, elementRef) {
|
|
@@ -18,6 +18,7 @@ export class TuiHostedDropdownComponent {
|
|
|
18
18
|
this.elementRef = elementRef;
|
|
19
19
|
this.manual$ = new BehaviorSubject(false);
|
|
20
20
|
this.content = ``;
|
|
21
|
+
this.sided = false;
|
|
21
22
|
this.canOpen = true;
|
|
22
23
|
this.openChange = new EventEmitter();
|
|
23
24
|
this.focusedChange = new EventEmitter();
|
|
@@ -25,6 +26,7 @@ export class TuiHostedDropdownComponent {
|
|
|
25
26
|
this.manual$,
|
|
26
27
|
(this.hover$ || EMPTY).pipe(startWith(false)),
|
|
27
28
|
]).pipe(map(([manual, hover]) => manual || hover));
|
|
29
|
+
this.close = () => this.updateOpen(false);
|
|
28
30
|
}
|
|
29
31
|
set open(open) {
|
|
30
32
|
this.manual$.next(open);
|
|
@@ -159,10 +161,13 @@ export class TuiHostedDropdownComponent {
|
|
|
159
161
|
}
|
|
160
162
|
}
|
|
161
163
|
TuiHostedDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiHostedDropdownComponent, deps: [{ token: TuiDropdownHoverDirective, optional: true }, { token: ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
162
|
-
TuiHostedDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: { content: "content", canOpen: "canOpen", open: "open" }, outputs: { openChange: "openChange", focusedChange: "focusedChange" }, host: { listeners: { "focusin": "onFocusIn($event.target)", "click": "onClick($event.target)", "keydown.esc": "onKeyDownEsc($event)", "keydown.arrowDown": "onArrow($event,true)", "keydown.arrowUp": "onArrow($event,false)" }, properties: { "class._hosted_dropdown_focused": "this.focused" } }, providers: [tuiAsFocusableItemAccessor(TuiHostedDropdownComponent)], queries: [{ propertyName: "dropdownHost", first: true, predicate: TuiHostedDropdownConnectorDirective, descendants: true, read: ElementRef }], viewQueries: [{ propertyName: "wrapper", first: true, predicate: ["wrapper"], descendants: true, read: ElementRef }, { propertyName: "dropdownDirective", first: true, predicate: TuiDropdownDirective, descendants: true }], ngImport: i0, template: "<
|
|
164
|
+
TuiHostedDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: { content: "content", sided: "sided", canOpen: "canOpen", open: "open" }, outputs: { openChange: "openChange", focusedChange: "focusedChange" }, host: { listeners: { "focusin": "onFocusIn($event.target)", "click": "onClick($event.target)", "keydown.esc": "onKeyDownEsc($event)", "keydown.arrowDown": "onArrow($event,true)", "keydown.arrowUp": "onArrow($event,false)" }, properties: { "class._hosted_dropdown_focused": "this.focused" } }, providers: [tuiAsFocusableItemAccessor(TuiHostedDropdownComponent)], queries: [{ propertyName: "dropdownHost", first: true, predicate: TuiHostedDropdownConnectorDirective, descendants: true, read: ElementRef }], viewQueries: [{ propertyName: "wrapper", first: true, predicate: ["wrapper"], descendants: true, read: ElementRef }, { propertyName: "dropdownDirective", first: true, predicate: TuiDropdownDirective, descendants: true }, { propertyName: "activeZone", first: true, predicate: TuiActiveZoneDirective, descendants: true }], ngImport: i0, template: "<ng-container *tuiLet=\"!!(open$ | async) as isOpen\">\n <div\n *ngIf=\"sided; else default\"\n tuiDropdownSided\n class=\"t-wrapper\"\n [tuiDropdownHost]=\"host\"\n [tuiDropdown]=\"dropdown\"\n [tuiDropdownManual]=\"isOpen && canOpen\"\n [tuiObscuredEnabled]=\"isOpen\"\n (tuiObscured)=\"onHostObscured($event)\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n >\n <ng-container *ngTemplateOutlet=\"inner\"></ng-container>\n </div>\n <ng-template #default>\n <div\n class=\"t-wrapper\"\n [tuiDropdownHost]=\"host\"\n [tuiDropdown]=\"dropdown\"\n [tuiDropdownManual]=\"isOpen && canOpen\"\n [tuiObscuredEnabled]=\"isOpen\"\n (tuiObscured)=\"onHostObscured($event)\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n >\n <ng-container *ngTemplateOutlet=\"inner\"></ng-container>\n </div>\n </ng-template>\n</ng-container>\n\n<ng-template #inner>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template\n #dropdown=\"polymorpheus\"\n [polymorpheus]=\"context\"\n>\n <div\n #wrapper\n (keydown.esc)=\"onKeyDownEsc($event)\"\n (keydown)=\"onKeydown($event)\"\n >\n <ng-container\n *polymorpheusOutlet=\"\n content as text;\n context: {\n $implicit: activeZone,\n close: close\n }\n \"\n >\n {{ text }}\n </ng-container>\n </div>\n <!--This DIV is here to start backwards TreeWalker for focusing last focusable item on ArrowUp-->\n <div></div>\n</ng-template>\n", styles: [":host{display:inline-flex}.t-wrapper{border-radius:inherit;height:inherit;flex:1 1 auto;width:100%}\n"], directives: [{ type: i1.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.TuiDropdownPositionSidedDirective, selector: "[tuiDropdownSided]" }, { type: i3.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }, { type: i3.TuiDropdownDriverDirective, selector: "[tuiDropdown]" }, { type: i3.TuiDropdownHostDirective, selector: "[tuiDropdown][tuiDropdownHost]", inputs: ["tuiDropdownHost"] }, { type: i3.TuiDropdownManualDirective, selector: "[tuiDropdown][tuiDropdownManual]", inputs: ["tuiDropdownManual"] }, { type: i1.TuiObscuredDirective, selector: "[tuiObscured]", inputs: ["tuiObscuredEnabled"], outputs: ["tuiObscured"] }, { type: i1.TuiActiveZoneDirective, selector: "[tuiActiveZone]:not(ng-container), [tuiActiveZoneChange]:not(ng-container), [tuiActiveZoneParent]:not(ng-container)", inputs: ["tuiActiveZoneParent"], outputs: ["tuiActiveZoneChange"], exportAs: ["tuiActiveZone"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.TuiDropdownPositionDirective, selector: "[tuiDropdown]:not([tuiDropdownCustomPosition]):not([tuiDropdownSided])" }, { type: i4.PolymorpheusTemplate, selector: "ng-template[polymorpheus]", inputs: ["polymorpheus"], exportAs: ["polymorpheus"] }, { type: i4.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], pipes: { "async": i2.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
163
165
|
__decorate([
|
|
164
166
|
tuiDefaultProp()
|
|
165
167
|
], TuiHostedDropdownComponent.prototype, "content", void 0);
|
|
168
|
+
__decorate([
|
|
169
|
+
tuiDefaultProp()
|
|
170
|
+
], TuiHostedDropdownComponent.prototype, "sided", void 0);
|
|
166
171
|
__decorate([
|
|
167
172
|
tuiDefaultProp()
|
|
168
173
|
], TuiHostedDropdownComponent.prototype, "canOpen", void 0);
|
|
@@ -195,16 +200,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
195
200
|
}], dropdownDirective: [{
|
|
196
201
|
type: ViewChild,
|
|
197
202
|
args: [TuiDropdownDirective]
|
|
203
|
+
}], activeZone: [{
|
|
204
|
+
type: ViewChild,
|
|
205
|
+
args: [TuiActiveZoneDirective]
|
|
198
206
|
}], content: [{
|
|
199
207
|
type: Input
|
|
200
|
-
}],
|
|
208
|
+
}], sided: [{
|
|
201
209
|
type: Input
|
|
202
|
-
}],
|
|
210
|
+
}], canOpen: [{
|
|
203
211
|
type: Input
|
|
204
212
|
}], openChange: [{
|
|
205
213
|
type: Output
|
|
206
214
|
}], focusedChange: [{
|
|
207
215
|
type: Output
|
|
216
|
+
}], open: [{
|
|
217
|
+
type: Input
|
|
208
218
|
}], focused: [{
|
|
209
219
|
type: HostBinding,
|
|
210
220
|
args: [`class._hosted_dropdown_focused`]
|
|
@@ -224,4 +234,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
224
234
|
type: HostListener,
|
|
225
235
|
args: [`keydown.arrowUp`, [`$event`, `false`]]
|
|
226
236
|
}] } });
|
|
227
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hosted-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/hosted-dropdown/hosted-dropdown.component.ts","../../../../../projects/core/components/hosted-dropdown/hosted-dropdown.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport {\n    TuiActiveZoneDirective,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    tuiGetClosestFocusable,\n    tuiIsElement,\n    tuiIsElementEditable,\n    tuiIsHTMLElement,\n    tuiIsNativeFocusedIn,\n    tuiIsNativeKeyboardFocusable,\n    TuiNativeFocusableElement,\n} from '@taiga-ui/cdk';\nimport {\n    TuiDropdownDirective,\n    TuiDropdownHoverDirective,\n} from '@taiga-ui/core/directives/dropdown';\nimport {tuiIsEditingKey} from '@taiga-ui/core/utils/miscellaneous';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {BehaviorSubject, combineLatest, EMPTY, Observable} from 'rxjs';\nimport {map, startWith} from 'rxjs/operators';\n\nimport {TuiHostedDropdownConnectorDirective} from './hosted-dropdown-connector.directive';\n\n@Component({\n    selector: `tui-hosted-dropdown`,\n    templateUrl: `./hosted-dropdown.template.html`,\n    styleUrls: [`./hosted-dropdown.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsFocusableItemAccessor(TuiHostedDropdownComponent)],\n})\nexport class TuiHostedDropdownComponent implements TuiFocusableElementAccessor {\n    @ContentChild(TuiHostedDropdownConnectorDirective, {read: ElementRef})\n    private readonly dropdownHost?: ElementRef<HTMLElement>;\n\n    @ViewChild(`wrapper`, {read: ElementRef})\n    private readonly wrapper?: ElementRef<HTMLDivElement>;\n\n    @ViewChild(TuiDropdownDirective)\n    private readonly dropdownDirective?: TuiDropdownDirective;\n\n    private readonly manual$ = new BehaviorSubject(false);\n\n    @Input()\n    @tuiDefaultProp()\n    content: PolymorpheusContent<TuiContextWithImplicit<TuiActiveZoneDirective>> = ``;\n\n    @Input()\n    @tuiDefaultProp()\n    canOpen = true;\n\n    @Input()\n    @tuiDefaultProp()\n    set open(open: boolean) {\n        this.manual$.next(open);\n    }\n\n    @Output()\n    readonly openChange = new EventEmitter<boolean>();\n\n    @Output()\n    readonly focusedChange = new EventEmitter<boolean>();\n\n    readonly context!: TuiContextWithImplicit<TuiActiveZoneDirective>;\n\n    readonly open$ = combineLatest([\n        this.manual$,\n        (this.hover$ || EMPTY).pipe(startWith(false)),\n    ]).pipe(map(([manual, hover]) => manual || hover));\n\n    constructor(\n        @Optional()\n        @Inject(TuiDropdownHoverDirective)\n        private readonly hover$: Observable<boolean> | null,\n        @Inject(ElementRef) private readonly elementRef: ElementRef,\n    ) {}\n\n    get open(): boolean {\n        return this.manual$.value;\n    }\n\n    get host(): HTMLElement {\n        return this.dropdownHost?.nativeElement || this.elementRef.nativeElement;\n    }\n\n    get computedHost(): HTMLElement {\n        return (\n            this.dropdownHost?.nativeElement ||\n            this.nativeFocusableElement ||\n            this.elementRef.nativeElement\n        );\n    }\n\n    get dropdown(): HTMLElement | undefined {\n        return this.dropdownDirective?.dropdownBoxRef?.location.nativeElement;\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return tuiIsNativeKeyboardFocusable(this.host)\n            ? this.host\n            : tuiGetClosestFocusable({\n                  initial: this.host,\n                  root: this.elementRef.nativeElement,\n              });\n    }\n\n    @HostBinding(`class._hosted_dropdown_focused`)\n    get focused(): boolean {\n        return (\n            tuiIsNativeFocusedIn(this.host) ||\n            (this.open &&\n                !!this.wrapper &&\n                tuiIsNativeFocusedIn(this.wrapper.nativeElement))\n        );\n    }\n\n    @HostListener(`focusin`, [`$event.target`])\n    onFocusIn(target: HTMLElement): void {\n        if (!this.computedHost.contains(target)) {\n            this.updateOpen(false);\n        }\n    }\n\n    @HostListener(`click`, [`$event.target`])\n    onClick(target: HTMLElement): void {\n        if (!this.hostEditable && this.computedHost.contains(target)) {\n            this.updateOpen(!this.open);\n        }\n    }\n\n    @HostListener(`keydown.esc`, [`$event`])\n    onKeyDownEsc(event: Event): void {\n        if (!this.canOpen || !this.open) {\n            return;\n        }\n\n        event.stopPropagation();\n        this.closeDropdown();\n    }\n\n    @HostListener(`keydown.arrowDown`, [`$event`, `true`])\n    @HostListener(`keydown.arrowUp`, [`$event`, `false`])\n    onArrow(event: KeyboardEvent, down: boolean): void {\n        this.focusDropdown(event, down);\n    }\n\n    onKeydown({key, target, defaultPrevented}: KeyboardEvent): void {\n        if (\n            !defaultPrevented &&\n            tuiIsEditingKey(key) &&\n            this.hostEditable &&\n            tuiIsHTMLElement(target) &&\n            !tuiIsElementEditable(target)\n        ) {\n            this.focusHost();\n        }\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n\n        if (!active) {\n            this.updateOpen(false);\n        }\n    }\n\n    onHostObscured(obscured: boolean): void {\n        if (obscured) {\n            this.closeDropdown();\n        }\n    }\n\n    updateOpen(open: boolean): void {\n        if (open && !this.canOpen) {\n            return;\n        }\n\n        this.open = open;\n        this.openChange.emit(open);\n    }\n\n    private get hostEditable(): boolean {\n        return tuiIsElementEditable(this.computedHost);\n    }\n\n    private focusDropdown(event: KeyboardEvent, first: boolean): void {\n        const host = this.nativeFocusableElement;\n\n        if (\n            !host ||\n            !tuiIsHTMLElement(host) ||\n            !tuiIsElement(event.target) ||\n            !host.contains(event.target)\n        ) {\n            return;\n        }\n\n        if (\n            !this.wrapper ||\n            !this.open ||\n            !this.dropdown ||\n            !tuiIsHTMLElement(this.wrapper.nativeElement.nextElementSibling)\n        ) {\n            this.updateOpen(true);\n\n            if (!tuiIsElementEditable(host)) {\n                event.preventDefault();\n            }\n\n            return;\n        }\n\n        const initial = first\n            ? this.wrapper.nativeElement\n            : this.wrapper.nativeElement.nextElementSibling;\n        const focusable = tuiGetClosestFocusable({\n            initial,\n            root: this.wrapper.nativeElement,\n            previous: !first,\n        });\n\n        if (!focusable) {\n            return;\n        }\n\n        focusable.focus();\n        event.preventDefault();\n    }\n\n    private closeDropdown(): void {\n        if (this.focused) {\n            this.focusHost();\n        }\n\n        this.updateOpen(false);\n    }\n\n    private focusHost(): void {\n        const host = this.nativeFocusableElement;\n\n        if (host) {\n            host.focus({preventScroll: true});\n        }\n    }\n\n    private updateFocused(focused: boolean): void {\n        this.focusedChange.emit(focused);\n    }\n}\n","<div\n    *tuiLet=\"!!(open$ | async) as isOpen\"\n    #activeZone=\"tuiActiveZone\"\n    class=\"t-wrapper\"\n    [tuiDropdownHost]=\"host\"\n    [tuiDropdown]=\"dropdown\"\n    [tuiDropdownManual]=\"isOpen && canOpen\"\n    [tuiObscuredEnabled]=\"isOpen\"\n    (tuiObscured)=\"onHostObscured($event)\"\n    (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n    <ng-content></ng-content>\n    <ng-template\n        #dropdown=\"polymorpheus\"\n        [polymorpheus]=\"context\"\n    >\n        <div\n            #wrapper\n            (keydown.esc)=\"onKeyDownEsc($event)\"\n            (keydown)=\"onKeydown($event)\"\n        >\n            <ng-container *polymorpheusOutlet=\"content as text; context: {$implicit: activeZone}\">\n                {{ text }}\n            </ng-container>\n        </div>\n        <!--This DIV is here to start backwards TreeWalker for focusing last focusable item on ArrowUp-->\n        <div></div>\n    </ng-template>\n</div>\n"]}
|
|
237
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hosted-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/hosted-dropdown/hosted-dropdown.component.ts","../../../../../projects/core/components/hosted-dropdown/hosted-dropdown.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport {\n    TuiActiveZoneDirective,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    tuiGetClosestFocusable,\n    tuiIsElement,\n    tuiIsElementEditable,\n    tuiIsHTMLElement,\n    tuiIsNativeFocusedIn,\n    tuiIsNativeKeyboardFocusable,\n    TuiNativeFocusableElement,\n} from '@taiga-ui/cdk';\nimport {\n    TuiDropdownDirective,\n    TuiDropdownHoverDirective,\n} from '@taiga-ui/core/directives/dropdown';\nimport {tuiIsEditingKey} from '@taiga-ui/core/utils/miscellaneous';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {BehaviorSubject, combineLatest, EMPTY, Observable} from 'rxjs';\nimport {map, startWith} from 'rxjs/operators';\n\nimport {TuiHostedDropdownConnectorDirective} from './hosted-dropdown-connector.directive';\n\nexport interface TuiHostedDropdownContext\n    extends TuiContextWithImplicit<TuiActiveZoneDirective> {\n    close(): void;\n}\n\n@Component({\n    selector: `tui-hosted-dropdown`,\n    templateUrl: `./hosted-dropdown.template.html`,\n    styleUrls: [`./hosted-dropdown.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiAsFocusableItemAccessor(TuiHostedDropdownComponent)],\n})\nexport class TuiHostedDropdownComponent implements TuiFocusableElementAccessor {\n    @ContentChild(TuiHostedDropdownConnectorDirective, {read: ElementRef})\n    private readonly dropdownHost?: ElementRef<HTMLElement>;\n\n    @ViewChild(`wrapper`, {read: ElementRef})\n    private readonly wrapper?: ElementRef<HTMLDivElement>;\n\n    @ViewChild(TuiDropdownDirective)\n    private readonly dropdownDirective?: TuiDropdownDirective;\n\n    private readonly manual$ = new BehaviorSubject(false);\n\n    @ViewChild(TuiActiveZoneDirective)\n    readonly activeZone!: TuiActiveZoneDirective;\n\n    @Input()\n    @tuiDefaultProp()\n    content: PolymorpheusContent<TuiHostedDropdownContext> = ``;\n\n    @Input()\n    @tuiDefaultProp()\n    sided = false;\n\n    @Input()\n    @tuiDefaultProp()\n    canOpen = true;\n\n    @Output()\n    readonly openChange = new EventEmitter<boolean>();\n\n    @Output()\n    readonly focusedChange = new EventEmitter<boolean>();\n\n    readonly context!: TuiContextWithImplicit<TuiActiveZoneDirective>;\n\n    readonly open$ = combineLatest([\n        this.manual$,\n        (this.hover$ || EMPTY).pipe(startWith(false)),\n    ]).pipe(map(([manual, hover]) => manual || hover));\n\n    constructor(\n        @Optional()\n        @Inject(TuiDropdownHoverDirective)\n        private readonly hover$: Observable<boolean> | null,\n        @Inject(ElementRef) private readonly elementRef: ElementRef,\n    ) {}\n\n    @Input()\n    @tuiDefaultProp()\n    set open(open: boolean) {\n        this.manual$.next(open);\n    }\n\n    get open(): boolean {\n        return this.manual$.value;\n    }\n\n    get host(): HTMLElement {\n        return this.dropdownHost?.nativeElement || this.elementRef.nativeElement;\n    }\n\n    get computedHost(): HTMLElement {\n        return (\n            this.dropdownHost?.nativeElement ||\n            this.nativeFocusableElement ||\n            this.elementRef.nativeElement\n        );\n    }\n\n    get dropdown(): HTMLElement | undefined {\n        return this.dropdownDirective?.dropdownBoxRef?.location.nativeElement;\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return tuiIsNativeKeyboardFocusable(this.host)\n            ? this.host\n            : tuiGetClosestFocusable({\n                  initial: this.host,\n                  root: this.elementRef.nativeElement,\n              });\n    }\n\n    @HostBinding(`class._hosted_dropdown_focused`)\n    get focused(): boolean {\n        return (\n            tuiIsNativeFocusedIn(this.host) ||\n            (this.open &&\n                !!this.wrapper &&\n                tuiIsNativeFocusedIn(this.wrapper.nativeElement))\n        );\n    }\n\n    @HostListener(`focusin`, [`$event.target`])\n    onFocusIn(target: HTMLElement): void {\n        if (!this.computedHost.contains(target)) {\n            this.updateOpen(false);\n        }\n    }\n\n    @HostListener(`click`, [`$event.target`])\n    onClick(target: HTMLElement): void {\n        if (!this.hostEditable && this.computedHost.contains(target)) {\n            this.updateOpen(!this.open);\n        }\n    }\n\n    @HostListener(`keydown.esc`, [`$event`])\n    onKeyDownEsc(event: Event): void {\n        if (!this.canOpen || !this.open) {\n            return;\n        }\n\n        event.stopPropagation();\n        this.closeDropdown();\n    }\n\n    @HostListener(`keydown.arrowDown`, [`$event`, `true`])\n    @HostListener(`keydown.arrowUp`, [`$event`, `false`])\n    onArrow(event: KeyboardEvent, down: boolean): void {\n        this.focusDropdown(event, down);\n    }\n\n    onKeydown({key, target, defaultPrevented}: KeyboardEvent): void {\n        if (\n            !defaultPrevented &&\n            tuiIsEditingKey(key) &&\n            this.hostEditable &&\n            tuiIsHTMLElement(target) &&\n            !tuiIsElementEditable(target)\n        ) {\n            this.focusHost();\n        }\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n\n        if (!active) {\n            this.updateOpen(false);\n        }\n    }\n\n    onHostObscured(obscured: boolean): void {\n        if (obscured) {\n            this.closeDropdown();\n        }\n    }\n\n    updateOpen(open: boolean): void {\n        if (open && !this.canOpen) {\n            return;\n        }\n\n        this.open = open;\n        this.openChange.emit(open);\n    }\n\n    readonly close = (): void => this.updateOpen(false);\n\n    private get hostEditable(): boolean {\n        return tuiIsElementEditable(this.computedHost);\n    }\n\n    private focusDropdown(event: KeyboardEvent, first: boolean): void {\n        const host = this.nativeFocusableElement;\n\n        if (\n            !host ||\n            !tuiIsHTMLElement(host) ||\n            !tuiIsElement(event.target) ||\n            !host.contains(event.target)\n        ) {\n            return;\n        }\n\n        if (\n            !this.wrapper ||\n            !this.open ||\n            !this.dropdown ||\n            !tuiIsHTMLElement(this.wrapper.nativeElement.nextElementSibling)\n        ) {\n            this.updateOpen(true);\n\n            if (!tuiIsElementEditable(host)) {\n                event.preventDefault();\n            }\n\n            return;\n        }\n\n        const initial = first\n            ? this.wrapper.nativeElement\n            : this.wrapper.nativeElement.nextElementSibling;\n        const focusable = tuiGetClosestFocusable({\n            initial,\n            root: this.wrapper.nativeElement,\n            previous: !first,\n        });\n\n        if (!focusable) {\n            return;\n        }\n\n        focusable.focus();\n        event.preventDefault();\n    }\n\n    private closeDropdown(): void {\n        if (this.focused) {\n            this.focusHost();\n        }\n\n        this.updateOpen(false);\n    }\n\n    private focusHost(): void {\n        const host = this.nativeFocusableElement;\n\n        if (host) {\n            host.focus({preventScroll: true});\n        }\n    }\n\n    private updateFocused(focused: boolean): void {\n        this.focusedChange.emit(focused);\n    }\n}\n","<ng-container *tuiLet=\"!!(open$ | async) as isOpen\">\n    <div\n        *ngIf=\"sided; else default\"\n        tuiDropdownSided\n        class=\"t-wrapper\"\n        [tuiDropdownHost]=\"host\"\n        [tuiDropdown]=\"dropdown\"\n        [tuiDropdownManual]=\"isOpen && canOpen\"\n        [tuiObscuredEnabled]=\"isOpen\"\n        (tuiObscured)=\"onHostObscured($event)\"\n        (tuiActiveZoneChange)=\"onActiveZone($event)\"\n    >\n        <ng-container *ngTemplateOutlet=\"inner\"></ng-container>\n    </div>\n    <ng-template #default>\n        <div\n            class=\"t-wrapper\"\n            [tuiDropdownHost]=\"host\"\n            [tuiDropdown]=\"dropdown\"\n            [tuiDropdownManual]=\"isOpen && canOpen\"\n            [tuiObscuredEnabled]=\"isOpen\"\n            (tuiObscured)=\"onHostObscured($event)\"\n            (tuiActiveZoneChange)=\"onActiveZone($event)\"\n        >\n            <ng-container *ngTemplateOutlet=\"inner\"></ng-container>\n        </div>\n    </ng-template>\n</ng-container>\n\n<ng-template #inner>\n    <ng-content></ng-content>\n</ng-template>\n\n<ng-template\n    #dropdown=\"polymorpheus\"\n    [polymorpheus]=\"context\"\n>\n    <div\n        #wrapper\n        (keydown.esc)=\"onKeyDownEsc($event)\"\n        (keydown)=\"onKeydown($event)\"\n    >\n        <ng-container\n            *polymorpheusOutlet=\"\n                content as text;\n                context: {\n                    $implicit: activeZone,\n                    close: close\n                }\n            \"\n        >\n            {{ text }}\n        </ng-container>\n    </div>\n    <!--This DIV is here to start backwards TreeWalker for focusing last focusable item on ArrowUp-->\n    <div></div>\n</ng-template>\n"]}
|
|
@@ -114,7 +114,7 @@ export class TuiPrimitiveCalendarComponent {
|
|
|
114
114
|
}
|
|
115
115
|
}
|
|
116
116
|
TuiPrimitiveCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiPrimitiveCalendarComponent, deps: [{ token: TUI_SHORT_WEEK_DAYS }, { token: TUI_DAY_TYPE_HANDLER }], target: i0.ɵɵFactoryTarget.Component });
|
|
117
|
-
TuiPrimitiveCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiPrimitiveCalendarComponent, selector: "tui-primitive-calendar", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", value: "value", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent" }, outputs: { hoveredItemChange: "hoveredItemChange", dayClick: "dayClick" }, host: { properties: { "class._single": "this.isSingle" } }, ngImport: i0, template: "<div class=\"t-row t-row_weekday\">\n <div\n *ngFor=\"let day of unorderedWeekDays$ | tuiOrderWeekDays | async\"\n class=\"t-cell\"\n [textContent]=\"day\"\n ></div>\n</div>\n<div *tuiLet=\"month | tuiCalendarSheet: true as sheet\">\n <div\n *tuiRepeatTimes=\"let rowIndex of sheet.length\"\n automation-id=\"tui-primitive-calendar__row\"\n class=\"t-row\"\n >\n <ng-container *tuiRepeatTimes=\"let colIndex of sheet[rowIndex].length\">\n <ng-container *tuiLet=\"sheet[rowIndex][colIndex] as item\">\n <div\n *ngIf=\"!itemIsUnavailable(item) || showAdjacent\"\n automation-id=\"tui-primitive-calendar__cell\"\n class=\"t-cell\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [class.t-cell_interval]=\"itemIsInterval(item)\"\n [attr.data-range]=\"getItemRange(item)\"\n [attr.data-state]=\"getItemState(item)\"\n (tuiHoveredChange)=\"onItemHovered($event && item)\"\n (tuiPressedChange)=\"onItemPressed($event && item)\"\n (click)=\"onItemClick(item)\"\n >\n <div\n automation-id=\"tui-primitive-calendar__item\"\n class=\"t-item\"\n [attr.data-type]=\"item | tuiMapper: dayTypeHandler\"\n [class.t-item_unavailable]=\"itemIsUnavailable(item)\"\n >\n {{ item.day }}\n <div\n *ngIf=\"item | tuiMapper: toMarkers:itemIsToday(item):!!getItemRange(item) as markers\"\n class=\"t-dots\"\n >\n <div\n class=\"t-dot\"\n [style.backgroundColor]=\"markers[0]\"\n ></div>\n <div\n *ngIf=\"markers.length > 1\"\n class=\"t-dot\"\n [style.backgroundColor]=\"markers[1] || ''\"\n ></div>\n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n</div>\n", styles: [":host{display:block;font:var(--tui-font-text-m)}.t-row{position:relative;z-index:0;display:flex;justify-content:space-between;height:2.25rem}.t-item{position:relative;flex:1;line-height:2rem;border-radius:var(--tui-radius-m)}.t-item:before,.t-item:after{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;z-index:-1;border-radius:var(--tui-radius-m)}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;width:2.25rem;text-align:center;outline:none;cursor:pointer;background-clip:content-box;box-sizing:border-box;border:2px solid transparent}.t-cell:before{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;z-index:-1;border-radius:var(--tui-radius-m)}.t-cell_today:after{position:absolute;left:50%;transform:translate(-50%);content:\"\";bottom:.3125rem;height:.125rem;width:.75rem;border-radius:.375rem;background-color:var(--tui-text-
|
|
117
|
+
TuiPrimitiveCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiPrimitiveCalendarComponent, selector: "tui-primitive-calendar", inputs: { month: "month", disabledItemHandler: "disabledItemHandler", markerHandler: "markerHandler", value: "value", hoveredItem: "hoveredItem", showAdjacent: "showAdjacent" }, outputs: { hoveredItemChange: "hoveredItemChange", dayClick: "dayClick" }, host: { properties: { "class._single": "this.isSingle" } }, ngImport: i0, template: "<div class=\"t-row t-row_weekday\">\n <div\n *ngFor=\"let day of unorderedWeekDays$ | tuiOrderWeekDays | async\"\n class=\"t-cell\"\n [textContent]=\"day\"\n ></div>\n</div>\n<div *tuiLet=\"month | tuiCalendarSheet: true as sheet\">\n <div\n *tuiRepeatTimes=\"let rowIndex of sheet.length\"\n automation-id=\"tui-primitive-calendar__row\"\n class=\"t-row\"\n >\n <ng-container *tuiRepeatTimes=\"let colIndex of sheet[rowIndex].length\">\n <ng-container *tuiLet=\"sheet[rowIndex][colIndex] as item\">\n <div\n *ngIf=\"!itemIsUnavailable(item) || showAdjacent\"\n automation-id=\"tui-primitive-calendar__cell\"\n class=\"t-cell\"\n [class.t-cell_today]=\"itemIsToday(item)\"\n [class.t-cell_interval]=\"itemIsInterval(item)\"\n [attr.data-range]=\"getItemRange(item)\"\n [attr.data-state]=\"getItemState(item)\"\n (tuiHoveredChange)=\"onItemHovered($event && item)\"\n (tuiPressedChange)=\"onItemPressed($event && item)\"\n (click)=\"onItemClick(item)\"\n >\n <div\n automation-id=\"tui-primitive-calendar__item\"\n class=\"t-item\"\n [attr.data-type]=\"item | tuiMapper: dayTypeHandler\"\n [class.t-item_unavailable]=\"itemIsUnavailable(item)\"\n >\n {{ item.day }}\n <div\n *ngIf=\"item | tuiMapper: toMarkers:itemIsToday(item):!!getItemRange(item) as markers\"\n class=\"t-dots\"\n >\n <div\n class=\"t-dot\"\n [style.backgroundColor]=\"markers[0]\"\n ></div>\n <div\n *ngIf=\"markers.length > 1\"\n class=\"t-dot\"\n [style.backgroundColor]=\"markers[1] || ''\"\n ></div>\n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n</div>\n", styles: [":host{display:block;font:var(--tui-font-text-m)}.t-row{position:relative;z-index:0;display:flex;justify-content:space-between;height:2.25rem}.t-item{position:relative;flex:1;line-height:2rem;border-radius:var(--tui-radius-m)}.t-item:before,.t-item:after{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;z-index:-1;border-radius:var(--tui-radius-m)}.t-cell{position:relative;display:flex;align-items:center;justify-content:center;width:2.25rem;text-align:center;outline:none;cursor:pointer;background-clip:content-box;box-sizing:border-box;border:2px solid transparent}.t-cell:before{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;z-index:-1;border-radius:var(--tui-radius-m)}.t-cell_today:after{position:absolute;left:50%;transform:translate(-50%);content:\"\";bottom:.3125rem;height:.125rem;width:.75rem;border-radius:.375rem;background-color:var(--tui-text-01)}.t-cell_interval:before{background:var(--tui-base-02)}:host._single .t-cell_interval:before{background:var(--tui-secondary-hover)}.t-cell_interval:not(:last-child):before{right:-2.25rem}.t-cell_interval:last-child:first-child:before{right:0}.t-cell_interval:first-child>.t-item{border-top-left-radius:var(--tui-radius-m);border-bottom-left-radius:var(--tui-radius-m)}.t-cell_interval:last-child>.t-item{border-top-right-radius:var(--tui-radius-m);border-bottom-right-radius:var(--tui-radius-m)}.t-cell_interval>.t-item{border-radius:0}.t-cell[data-range]:after{background-color:var(--tui-primary-text)}.t-cell[data-range]>.t-item{color:var(--tui-primary-text)}.t-cell[data-range]>.t-item:before,.t-cell[data-range]>.t-item:after{background-color:var(--tui-primary)}.t-cell[data-range][data-state=hover]>.t-item:before,.t-cell[data-range][data-state=hover]>.t-item:after{background-color:var(--tui-primary-hover)}.t-cell[data-range][data-state=active]>.t-item:before,.t-cell[data-range][data-state=active]>.t-item:after{background-color:var(--tui-primary-active)}.t-cell[data-range=end]>.t-item:before{left:.25rem}.t-cell[data-range=end]>.t-item:after{left:-2rem;right:100%;transform:translate(1.4375rem) scaleY(.6) scaleX(.4) rotate(45deg)}.t-cell[data-range=start]>.t-item:before{right:.25rem}.t-cell[data-range=start]>.t-item:after{left:100%;right:-2rem;transform:translate(-1.4375rem) scaleY(.6) scaleX(.4) rotate(45deg)}.t-cell[data-state=disabled]{pointer-events:none}.t-cell[data-state=disabled]>.t-item{opacity:.36}.t-cell[data-state=hover]:hover:not([data-range])>.t-item{background-color:var(--tui-secondary-hover)}.t-cell[data-state=active]:hover:not([data-range])>.t-item{background-color:var(--tui-secondary-active)}:host{width:15.75rem}.t-row{justify-content:flex-start}.t-row:first-child{justify-content:flex-end}.t-row_weekday{font:var(--tui-font-text-s);color:var(--tui-text-02);pointer-events:none}.t-item{display:flex;flex-direction:column}.t-item_unavailable{opacity:var(--tui-disabled-opacity)}.t-dots{display:flex;justify-content:center;margin-top:-.5rem;padding-bottom:.25rem}.t-dot{display:inline-block;width:.25rem;height:.25rem;border-radius:100%;margin:0 .0625rem}\n"], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { type: i2.TuiRepeatTimesDirective, selector: "[tuiRepeatTimes][tuiRepeatTimesOf]", inputs: ["tuiRepeatTimesOf"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.TuiHoveredDirective, selector: "[tuiHoveredChange]", outputs: ["tuiHoveredChange"] }, { type: i2.TuiPressedDirective, selector: "[tuiPressedChange]", outputs: ["tuiPressedChange"] }], pipes: { "async": i1.AsyncPipe, "tuiOrderWeekDays": i3.TuiOrderWeekDaysPipe, "tuiCalendarSheet": i3.TuiCalendarSheetPipe, "tuiMapper": i2.TuiMapperPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
118
118
|
__decorate([
|
|
119
119
|
tuiDefaultProp()
|
|
120
120
|
], TuiPrimitiveCalendarComponent.prototype, "month", void 0);
|