@taiga-ui/core 3.9.0 → 3.11.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.
Files changed (132) hide show
  1. package/bundles/taiga-ui-core-abstract.umd.js +1 -1
  2. package/bundles/taiga-ui-core-abstract.umd.js.map +1 -1
  3. package/bundles/taiga-ui-core-components-alert.umd.js +1 -1
  4. package/bundles/taiga-ui-core-components-alert.umd.js.map +1 -1
  5. package/bundles/taiga-ui-core-components-button.umd.js +1 -1
  6. package/bundles/taiga-ui-core-components-button.umd.js.map +1 -1
  7. package/bundles/taiga-ui-core-components-calendar.umd.js +1 -1
  8. package/bundles/taiga-ui-core-components-calendar.umd.js.map +1 -1
  9. package/bundles/taiga-ui-core-components-data-list.umd.js +39 -21
  10. package/bundles/taiga-ui-core-components-data-list.umd.js.map +1 -1
  11. package/bundles/taiga-ui-core-components-dialog.umd.js +2 -2
  12. package/bundles/taiga-ui-core-components-dialog.umd.js.map +1 -1
  13. package/bundles/taiga-ui-core-components-error.umd.js +1 -1
  14. package/bundles/taiga-ui-core-components-error.umd.js.map +1 -1
  15. package/bundles/taiga-ui-core-components-expand.umd.js +1 -1
  16. package/bundles/taiga-ui-core-components-expand.umd.js.map +1 -1
  17. package/bundles/taiga-ui-core-components-group.umd.js +1 -1
  18. package/bundles/taiga-ui-core-components-group.umd.js.map +1 -1
  19. package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js +15 -4
  20. package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js.map +1 -1
  21. package/bundles/taiga-ui-core-components-label.umd.js +1 -1
  22. package/bundles/taiga-ui-core-components-label.umd.js.map +1 -1
  23. package/bundles/taiga-ui-core-components-link.umd.js +1 -1
  24. package/bundles/taiga-ui-core-components-link.umd.js.map +1 -1
  25. package/bundles/taiga-ui-core-components-loader.umd.js +1 -1
  26. package/bundles/taiga-ui-core-components-loader.umd.js.map +1 -1
  27. package/bundles/taiga-ui-core-components-notification.umd.js +1 -1
  28. package/bundles/taiga-ui-core-components-notification.umd.js.map +1 -1
  29. package/bundles/taiga-ui-core-components-primitive-calendar.umd.js +2 -2
  30. package/bundles/taiga-ui-core-components-primitive-calendar.umd.js.map +1 -1
  31. package/bundles/taiga-ui-core-components-primitive-checkbox.umd.js +1 -1
  32. package/bundles/taiga-ui-core-components-primitive-checkbox.umd.js.map +1 -1
  33. package/bundles/taiga-ui-core-components-primitive-spin-button.umd.js +1 -1
  34. package/bundles/taiga-ui-core-components-primitive-spin-button.umd.js.map +1 -1
  35. package/bundles/taiga-ui-core-components-primitive-textfield.umd.js +3 -3
  36. package/bundles/taiga-ui-core-components-primitive-textfield.umd.js.map +1 -1
  37. package/bundles/taiga-ui-core-components-primitive-year-picker.umd.js +3 -2
  38. package/bundles/taiga-ui-core-components-primitive-year-picker.umd.js.map +1 -1
  39. package/bundles/taiga-ui-core-components-root.umd.js +2 -2
  40. package/bundles/taiga-ui-core-components-root.umd.js.map +1 -1
  41. package/bundles/taiga-ui-core-components-scroll-controls.umd.js +1 -1
  42. package/bundles/taiga-ui-core-components-scroll-controls.umd.js.map +1 -1
  43. package/bundles/taiga-ui-core-components-scrollbar.umd.js +1 -1
  44. package/bundles/taiga-ui-core-components-scrollbar.umd.js.map +1 -1
  45. package/bundles/taiga-ui-core-components-svg.umd.js +1 -1
  46. package/bundles/taiga-ui-core-components-svg.umd.js.map +1 -1
  47. package/bundles/taiga-ui-core-components-theme-night.umd.js +1 -1
  48. package/bundles/taiga-ui-core-components-theme-night.umd.js.map +1 -1
  49. package/bundles/taiga-ui-core-components-tooltip.umd.js +1 -1
  50. package/bundles/taiga-ui-core-components-tooltip.umd.js.map +1 -1
  51. package/bundles/taiga-ui-core-directives-dropdown.umd.js +32 -17
  52. package/bundles/taiga-ui-core-directives-dropdown.umd.js.map +1 -1
  53. package/bundles/taiga-ui-core-directives-hint.umd.js +2 -1
  54. package/bundles/taiga-ui-core-directives-hint.umd.js.map +1 -1
  55. package/bundles/taiga-ui-core-directives-mode.umd.js +1 -1
  56. package/bundles/taiga-ui-core-directives-mode.umd.js.map +1 -1
  57. package/bundles/taiga-ui-core-directives-scroll-into-view.umd.js +1 -1
  58. package/bundles/taiga-ui-core-directives-scroll-into-view.umd.js.map +1 -1
  59. package/bundles/taiga-ui-core-directives-textfield-controller.umd.js +1 -1
  60. package/bundles/taiga-ui-core-directives-textfield-controller.umd.js.map +1 -1
  61. package/bundles/taiga-ui-core-internal-primitive-year-month-pagination.umd.js +2 -2
  62. package/bundles/taiga-ui-core-internal-primitive-year-month-pagination.umd.js.map +1 -1
  63. package/bundles/taiga-ui-core-pipes-calendar-sheet.umd.js +1 -1
  64. package/bundles/taiga-ui-core-pipes-calendar-sheet.umd.js.map +1 -1
  65. package/bundles/taiga-ui-core-pipes-order-week-days.umd.js +1 -1
  66. package/bundles/taiga-ui-core-pipes-order-week-days.umd.js.map +1 -1
  67. package/bundles/taiga-ui-core-services.umd.js +1 -1
  68. package/bundles/taiga-ui-core-services.umd.js.map +1 -1
  69. package/bundles/taiga-ui-core-tokens.umd.js +1 -1
  70. package/bundles/taiga-ui-core-tokens.umd.js.map +1 -1
  71. package/bundles/taiga-ui-core-utils-dom.umd.js +1 -0
  72. package/bundles/taiga-ui-core-utils-dom.umd.js.map +1 -1
  73. package/bundles/taiga-ui-core-utils-format.umd.js +1 -1
  74. package/bundles/taiga-ui-core-utils-format.umd.js.map +1 -1
  75. package/bundles/taiga-ui-core-utils-mask.umd.js +3 -2
  76. package/bundles/taiga-ui-core-utils-mask.umd.js.map +1 -1
  77. package/components/data-list/data-list.component.d.ts +6 -3
  78. package/components/data-list/option/option.component.d.ts +2 -1
  79. package/components/hosted-dropdown/hosted-dropdown.component.d.ts +9 -3
  80. package/components/svg/svg.component.d.ts +1 -1
  81. package/directives/dropdown/dropdown-position-sided.directive.d.ts +5 -3
  82. package/directives/dropdown/dropdown-position.directive.d.ts +1 -1
  83. package/directives/hint/hint.directive.d.ts +2 -2
  84. package/esm2015/components/data-list/data-list.component.js +26 -8
  85. package/esm2015/components/data-list/option/option.component.js +4 -3
  86. package/esm2015/components/dialog/dialog.component.js +1 -1
  87. package/esm2015/components/hosted-dropdown/hosted-dropdown.component.js +15 -5
  88. package/esm2015/components/primitive-calendar/primitive-calendar.component.js +2 -2
  89. package/esm2015/components/primitive-textfield/primitive-textfield.component.js +1 -1
  90. package/esm2015/components/primitive-textfield/textfield/textfield.component.js +1 -1
  91. package/esm2015/components/primitive-year-picker/primitive-year-picker.component.js +3 -2
  92. package/esm2015/components/root/root.component.js +2 -2
  93. package/esm2015/components/svg/svg.component.js +1 -1
  94. package/esm2015/directives/dropdown/dropdown-position-sided.directive.js +26 -8
  95. package/esm2015/directives/dropdown/dropdown-position.directive.js +5 -6
  96. package/esm2015/directives/dropdown/dropdown.component.js +3 -3
  97. package/esm2015/directives/hint/hint-position.directive.js +2 -1
  98. package/esm2015/directives/hint/hint.directive.js +1 -1
  99. package/esm2015/internal/primitive-year-month-pagination/primitive-year-month-pagination.component.js +2 -2
  100. package/esm2015/pipes/calendar-sheet/utils.js +2 -2
  101. package/esm2015/utils/dom/get-word-range.js +2 -1
  102. package/esm2015/utils/mask/create-number-mask.js +3 -2
  103. package/fesm2015/taiga-ui-core-components-data-list.js +27 -8
  104. package/fesm2015/taiga-ui-core-components-data-list.js.map +1 -1
  105. package/fesm2015/taiga-ui-core-components-dialog.js +1 -1
  106. package/fesm2015/taiga-ui-core-components-hosted-dropdown.js +14 -4
  107. package/fesm2015/taiga-ui-core-components-hosted-dropdown.js.map +1 -1
  108. package/fesm2015/taiga-ui-core-components-primitive-calendar.js +1 -1
  109. package/fesm2015/taiga-ui-core-components-primitive-calendar.js.map +1 -1
  110. package/fesm2015/taiga-ui-core-components-primitive-textfield.js +2 -2
  111. package/fesm2015/taiga-ui-core-components-primitive-textfield.js.map +1 -1
  112. package/fesm2015/taiga-ui-core-components-primitive-year-picker.js +2 -1
  113. package/fesm2015/taiga-ui-core-components-primitive-year-picker.js.map +1 -1
  114. package/fesm2015/taiga-ui-core-components-root.js +1 -1
  115. package/fesm2015/taiga-ui-core-components-root.js.map +1 -1
  116. package/fesm2015/taiga-ui-core-components-svg.js.map +1 -1
  117. package/fesm2015/taiga-ui-core-directives-dropdown.js +29 -13
  118. package/fesm2015/taiga-ui-core-directives-dropdown.js.map +1 -1
  119. package/fesm2015/taiga-ui-core-directives-hint.js +1 -0
  120. package/fesm2015/taiga-ui-core-directives-hint.js.map +1 -1
  121. package/fesm2015/taiga-ui-core-internal-primitive-year-month-pagination.js +1 -1
  122. package/fesm2015/taiga-ui-core-internal-primitive-year-month-pagination.js.map +1 -1
  123. package/fesm2015/taiga-ui-core-pipes-calendar-sheet.js +1 -1
  124. package/fesm2015/taiga-ui-core-pipes-calendar-sheet.js.map +1 -1
  125. package/fesm2015/taiga-ui-core-utils-dom.js +1 -0
  126. package/fesm2015/taiga-ui-core-utils-dom.js.map +1 -1
  127. package/fesm2015/taiga-ui-core-utils-mask.js +2 -1
  128. package/fesm2015/taiga-ui-core-utils-mask.js.map +1 -1
  129. package/package.json +4 -4
  130. package/styles/mixins/mixins.less +17 -0
  131. package/styles/mixins/picker.less +1 -1
  132. package/styles/mixins/picker.scss +1 -1
@@ -6,9 +6,11 @@ export declare class TuiDropdownPositionSidedDirective implements TuiPositionAcc
6
6
  private readonly options;
7
7
  private readonly windowRef;
8
8
  private readonly accessor;
9
+ private readonly vertical;
9
10
  private previous;
10
- constructor(options: TuiDropdownOptions, windowRef: Window, accessor: TuiRectAccessor);
11
- getPosition({ height, width }: ClientRect): TuiPoint;
11
+ tuiDropdownSided: boolean | string;
12
+ constructor(options: TuiDropdownOptions, windowRef: Window, accessor: TuiRectAccessor, vertical: TuiPositionAccessor);
13
+ getPosition(rect: ClientRect): TuiPoint;
12
14
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownPositionSidedDirective, never>;
13
- static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownPositionSidedDirective, "[tuiDropdownSided]", never, {}, {}, never>;
15
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TuiDropdownPositionSidedDirective, "[tuiDropdownSided]", never, { "tuiDropdownSided": "tuiDropdownSided"; }, {}, never>;
14
16
  }
@@ -6,7 +6,7 @@ export declare class TuiDropdownPositionDirective implements TuiPositionAccessor
6
6
  private readonly options;
7
7
  private readonly windowRef;
8
8
  private readonly accessor;
9
- private previous;
9
+ private previous?;
10
10
  constructor(options: TuiDropdownOptions, windowRef: Window, accessor: TuiRectAccessor);
11
11
  getPosition({ width, height }: ClientRect): TuiPoint;
12
12
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiDropdownPositionDirective, never>;
@@ -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<object, object>;
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<object, object>, hintService: TuiHintService, options: TuiHintOptions, activeZone?: TuiActiveZoneDirective | null | undefined);
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 "rxjs";
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:.375rem 0;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>.t-empty{margin:.75rem 1rem}tui-opt-group{position:relative;display:flex;font:var(--tui-font-text-s);color:var(--tui-text-02);flex-direction:column;line-height:1rem}tui-opt-group:empty:before,tui-opt-group:empty:after{display:none}tui-opt-group:before{content:attr(data-label);padding:.375rem 1rem .75rem;line-height:1rem;white-space:normal}tui-opt-group:not(:empty)~tui-opt-group:before{padding:.875rem 1rem .75rem}tui-opt-group:not(:empty)~tui-opt-group[data-label=\"\"]:before{padding:.5rem 0 0}tui-opt-group:not(:empty)~tui-opt-group:after{content:\"\";position:absolute;left:1rem;right:1rem;top:.25rem;height:1px;background:var(--tui-base-03)}tui-opt-group[data-label=\"\"]:before{padding:0 1rem}\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 });
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: i0.ElementRef, decorators: [{
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: i3.Observable, decorators: [{
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":";AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,UAAU,EACV,UAAU,EACV,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EACL,QAAQ,EAER,iBAAiB,GACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,WAAW,EACX,cAAc,EACd,YAAY,EACZ,oBAAoB,EACpB,YAAY,EACZ,2BAA2B,EAC3B,YAAY,EACZ,OAAO,EACP,wBAAwB,GAC3B,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,yBAAyB,EAAC,MAAM,2BAA2B,CAAC;AAEpE,OAAO,EAAC,yBAAyB,EAAE,qBAAqB,EAAC,MAAM,uBAAuB,CAAC;AAIvF,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAEnC,4CAA4C;AAC5C,2CAA2C;AAC3C,OAAO,EAAC,kBAAkB,EAAC,MAAM,2BAA2B,CAAC;;;;;;AAE7D,+EAA+E;AAS/E,MAAM,OAAO,oBAAoB;IAoB7B,YAGqB,UAA4C,EACxB,UAAmC,EAE/D,oBAAwC;;QAHhC,eAAU,GAAV,UAAU,CAAkC;QACxB,eAAU,GAAV,UAAU,CAAyB;QAE/D,yBAAoB,GAApB,oBAAoB,CAAoB;QAxBpC,YAAO,GAAqC,WAAW,CAAC;QAOzE,SAAI,GAAoB,SAAS,CAAC;QAIlC,iBAAY,GAAwB,EAAE,CAAC;QAKvC,SAAI,GAAG,CAAA,MAAA,IAAI,CAAC,UAAU,0CAAE,IAAI,KAAI,GAAG,CAAC;IASjC,CAAC;IAGJ,IAAI,MAAM;QACN,OAAO,2BAA2B,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAC,MAAM,EAAC,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IACtF,CAAC;IAGD,SAAS,CAAC,aAA0B,EAAE,aAA0B;QAC5D,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACxD,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC;SAC/B;IACL,CAAC;IAGD,IAAI,KAAU,CAAC;IAIf,cAAc,CAAC,OAAoB,EAAE,IAAY;QAC7C,MAAM,EAAC,QAAQ,EAAC,GAAG,IAAI,CAAC;QAExB,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED,+EAA+E;IAG/E,0BAA0B,CAAC,UAAmB,IAAI,CAAC,UAAU,CAAC,aAAa;QACvE,IAAI,IAAI,CAAC,MAAM,IAAI,oBAAoB,CAAC,OAAO,CAAC,EAAE;YAC9C,wBAAwB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;SACrD;IACL,CAAC;IAED,UAAU,CAAC,kBAA2B,KAAK;QACvC,OAAO,IAAI,CAAC,OAAO;aACd,MAAM,CAAC,CAAC,EAAC,QAAQ,EAAC,EAAE,EAAE,CAAC,eAAe,IAAI,CAAC,QAAQ,CAAC;aACpD,GAAG,CAAC,CAAC,EAAC,KAAK,EAAC,EAAE,EAAE,CAAC,KAAK,CAAC;aACvB,MAAM,CAAC,YAAY,CAAC,CAAC;IAC9B,CAAC;IAED,OAAO,CAAC,EAAC,MAAM,EAAQ,EAAE,GAAY;QACjC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;YACvB,OAAO;SACV;QAED,MAAM,EAAC,QAAQ,EAAC,GAAG,IAAI,CAAC;QAExB,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACjE,IAAI,CAAC,0BAA0B,CAAC,MAAM,CAAC,CAAC;IAC5C,CAAC;IAED,IAAY,QAAQ;QAChB,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,CAAC;IACrF,CAAC;;kHAjFQ,oBAAoB,kBAsBjB,yBAAyB,6BAEzB,UAAU,aACV,yBAAyB;sGAzB5B,oBAAoB,yiBAFlB,CAAC,qBAAqB,CAAC,oBAAoB,CAAC,CAAC,qFAGtB,kBAAkB,oDC/CxD,obAmBA;ADoCI;IADC,cAAc,EAAE;kDACiB;AAIlC;IADC,cAAc,EAAE;0DACsB;AAKvC;IADC,cAAc,EAAE;kDACmB;AAYpC;IADC,OAAO;kDAGP;4FAhCQ,oBAAoB;kBARhC,SAAS;mBAAC;oBACP,QAAQ,EAAE,eAAe;oBACzB,WAAW,EAAE,2BAA2B;oBACxC,SAAS,EAAE,CAAC,wBAAwB,CAAC;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,SAAS,EAAE,CAAC,qBAAqB,sBAAsB,CAAC;iBAC3D;;0BAsBQ,QAAQ;;0BACR,MAAM;2BAAC,yBAAyB;;0BAEhC,MAAM;2BAAC,UAAU;;0BACjB,MAAM;2BAAC,yBAAyB;4CAvBpB,OAAO;sBADvB,eAAe;uBAAC,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC,EAAE,EAAC,WAAW,EAAE,IAAI,EAAC;gBAQ1E,IAAI;sBAHH,KAAK;;sBACL,WAAW;uBAAC,WAAW;gBAMxB,YAAY;sBAFX,KAAK;gBAON,IAAI;sBAHH,KAAK;;sBACL,WAAW;uBAAC,qBAAqB;gBAc9B,MAAM,MAKV,SAAS;sBADR,YAAY;uBAAC,SAAS,EAAE,CAAC,sBAAsB,EAAE,sBAAsB,CAAC;gBAQzE,IAAI;sBADH,YAAY;uBAAC,mBAAmB;gBAKjC,cAAc;sBAFb,YAAY;uBAAC,2BAA2B,EAAE,CAAC,eAAe,EAAE,GAAG,CAAC;;sBAChE,YAAY;uBAAC,yBAAyB,EAAE,CAAC,eAAe,EAAE,IAAI,CAAC;gBAUhE,0BAA0B;sBAFzB,YAAY;uBAAC,sBAAsB;;sBACnC,YAAY;uBAAC,YAAY,EAAE,CAAC,eAAe,CAAC","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
- this.size = `m`;
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;padding:0;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;font:var(--tui-font-text-m);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}:host:disabled{opacity:var(--tui-disabled-opacity);cursor:default}:host:focus,:host._with-dropdown{background-color:var(--tui-clear-disabled)}:host[data-size=xs]{font:var(--tui-font-text-s);min-height:2rem;padding:.3125rem .375rem;margin:.0625rem .375rem}:host[data-size=s]{min-height:2rem;padding:.3125rem .375rem;margin:.0625rem .375rem}:host[data-size=m]{min-height:2.75rem;padding:.375rem .5rem;margin:.125rem .5rem}:host[data-size=l]{min-height:3.5rem;padding:.375rem .5rem;margin:.125rem .5rem}.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
+ 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,{"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    @Input()\n    @HostBinding(`attr.data-size`)\n    @tuiDefaultProp()\n    size: TuiSizeXS | TuiSizeL = `m`;\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"]}
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":";AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,UAAU,EACV,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,QAAQ,EACR,IAAI,GAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EAEH,cAAc,EAEd,kBAAkB,GACrB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,oBAAoB,EAAC,MAAM,oCAAoC,CAAC;AAExE,OAAO,EAAC,kBAAkB,EAAE,kBAAkB,EAAC,MAAM,uBAAuB,CAAC;AAE7E,OAAO,EAAC,UAAU,EAAC,MAAM,2BAA2B,CAAC;AAGrD,4CAA4C;AAC5C,2CAA2C;AAC3C,OAAO,EAAC,oBAAoB,EAAC,MAAM,wBAAwB,CAAC;;;;;;;AAE5D,SAAS,WAAW,CAAC,EAAC,aAAa,EAAwC;IACvE,OAAO,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC;AAC9C,CAAC;AAED,8CAA8C;AAY9C,MAAM,OAAO,kBAAkB;IAmB3B,YAGa,OAED,EAES,QAAiC,EACb,UAAmC,EAGvD,IAA+B,EAIvC,QAAqC;QAZrC,YAAO,GAAP,OAAO,CAER;QAES,aAAQ,GAAR,QAAQ,CAAyB;QACb,eAAU,GAAV,UAAU,CAAyB;QAGvD,SAAI,GAAJ,IAAI,CAA2B;QAIvC,aAAQ,GAAR,QAAQ,CAA6B;QAjClD,mEAAmE;QAInE,SAAI,GAAgC,IAAI,CAAC;QAKzC,SAAI,GAAkB,QAAQ,CAAC;QAI/B,aAAQ,GAAG,KAAK,CAAC;IAqBd,CAAC;IAEJ,IACI,MAAM;QACN,OAAO,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC;IAC7D,CAAC;IAGD,OAAO;QACH,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE;YACvC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACtC;IACL,CAAC;IAED,oFAAoF;IAIpF,WAAW,CAAC,EAAC,aAAa,EAAwC;QAC9D,aAAa,CAAC,KAAK,CAAC,EAAC,aAAa,EAAE,IAAI,EAAC,CAAC,CAAC;IAC/C,CAAC;IAED,oDAAoD;IACpD,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,0BAA0B,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAC5E,CAAC;;gHA5DQ,kBAAkB,kBAqBf,kBAAkB,6BAIlB,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC,aAEtC,UAAU,aAEV,kBAAkB,6BAIlB,oBAAoB;oGAjCvB,kBAAkB,ieC/C/B,8TAWA;ADyCI;IADC,cAAc,EAAE;gDACwB;AAKzC;IADC,cAAc,EAAE;gDACc;AAI/B;IADC,cAAc,EAAE;oDACA;AAuCjB;IAHC,UAAU,CAAC,WAAW,CAAC;qDAKvB;4FAvDQ,kBAAkB;kBAX9B,SAAS;mBAAC;oBACP,QAAQ,EAAE,iCAAiC;oBAC3C,WAAW,EAAE,wBAAwB;oBACrC,SAAS,EAAE,CAAC,qBAAqB,CAAC;oBAClC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,IAAI,EAAE;wBACF,QAAQ,EAAE,IAAI;wBACd,IAAI,EAAE,QAAQ;wBACd,iBAAiB,EAAE,kBAAkB;qBACxC;iBACJ;;0BAqBQ,QAAQ;;0BACR,MAAM;2BAAC,kBAAkB;;0BAIzB,MAAM;2BAAC,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;;0BAE7C,MAAM;2BAAC,UAAU;;0BACjB,QAAQ;;0BACR,MAAM;2BAAC,kBAAkB;;0BAEzB,QAAQ;;0BACR,IAAI;;0BACJ,MAAM;2BAAC,oBAAoB;4CA5BhC,IAAI;sBAHH,KAAK;;sBACL,WAAW;uBAAC,gBAAgB;gBAO7B,IAAI;sBAHH,KAAK;;sBACL,WAAW;uBAAC,WAAW;gBAMxB,QAAQ;sBAFP,KAAK;gBAKN,KAAK;sBADJ,KAAK;gBAsBF,MAAM;sBADT,WAAW;uBAAC,sBAAsB;gBAMnC,OAAO;sBADN,YAAY;uBAAC,OAAO;gBAWrB,WAAW;sBAFV,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;;sBACzC,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC","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-base-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:2rem 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 });
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';
@@ -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: "<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", 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.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }, { type: i2.TuiDropdownDriverDirective, selector: "[tuiDropdown]" }, { type: i2.TuiDropdownPositionDirective, selector: "[tuiDropdown]:not([tuiDropdownCustomPosition]):not([tuiDropdownSided])" }, { type: i2.TuiDropdownHostDirective, selector: "[tuiDropdown][tuiDropdownHost]", inputs: ["tuiDropdownHost"] }, { type: i2.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: i3.PolymorpheusTemplate, selector: "ng-template[polymorpheus]", inputs: ["polymorpheus"], exportAs: ["polymorpheus"] }, { type: i3.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], pipes: { "async": i4.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
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: "<div\n *tuiLet=\"!!(open$ | async) as isOpen\"\n #activeZone=\"tuiActiveZone\"\n class=\"t-wrapper\"\n [tuiDropdownSided]=\"sided\"\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\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</div>\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.TuiDropdownPositionSidedDirective, selector: "[tuiDropdownSided]", inputs: ["tuiDropdownSided"] }, { type: i2.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }, { type: i2.TuiDropdownDriverDirective, selector: "[tuiDropdown]" }, { type: i2.TuiDropdownHostDirective, selector: "[tuiDropdown][tuiDropdownHost]", inputs: ["tuiDropdownHost"] }, { type: i2.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: i3.PolymorpheusTemplate, selector: "ng-template[polymorpheus]", inputs: ["polymorpheus"], exportAs: ["polymorpheus"] }, { type: i3.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], pipes: { "async": i4.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
- }], canOpen: [{
208
+ }], sided: [{
201
209
  type: Input
202
- }], open: [{
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","<div\n    *tuiLet=\"!!(open$ | async) as isOpen\"\n    #activeZone=\"tuiActiveZone\"\n    class=\"t-wrapper\"\n    [tuiDropdownSided]=\"sided\"\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\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</div>\n"]}