From e96d4eb76604f6dcfd96594778ee1b87109d9259 Mon Sep 17 00:00:00 2001
From: Vladimir Potekhin <46284632+vladimirpotekhin@users.noreply.github.com>
Date: Wed, 25 Dec 2024 09:02:38 +0300
Subject: [PATCH] fix(legacy): `TuiMultiSelect` fix arrow (#10050)
---
.../legacy/components/arrow/arrow.component.ts | 16 ++++++++++------
.../legacy/components/arrow/arrow.template.html | 1 -
.../components/input-tag/input-tag.component.ts | 17 +++++++++++------
3 files changed, 21 insertions(+), 13 deletions(-)
diff --git a/projects/legacy/components/arrow/arrow.component.ts b/projects/legacy/components/arrow/arrow.component.ts
index 198d217b54b0..a56222e45a07 100644
--- a/projects/legacy/components/arrow/arrow.component.ts
+++ b/projects/legacy/components/arrow/arrow.component.ts
@@ -1,5 +1,6 @@
import {AsyncPipe, NgIf} from '@angular/common';
-import {ChangeDetectionStrategy, Component, inject} from '@angular/core';
+import {ChangeDetectionStrategy, Component, computed, inject} from '@angular/core';
+import {toSignal} from '@angular/core/rxjs-interop';
import {TuiIcon} from '@taiga-ui/core/components/icon';
import {TuiDropdownOpen} from '@taiga-ui/core/directives/dropdown';
import {tuiSizeBigger} from '@taiga-ui/core/utils/miscellaneous';
@@ -11,6 +12,7 @@ import {
PolymorpheusOutlet,
PolymorpheusTemplate,
} from '@taiga-ui/polymorpheus';
+import {of} from 'rxjs';
import {TUI_ARROW_OPTIONS} from './arrow.options';
@@ -25,7 +27,7 @@ import {TUI_ARROW_OPTIONS} from './arrow.options';
styleUrls: ['./arrow.style.less'],
changeDetection: ChangeDetectionStrategy.OnPush,
host: {
- '[class._rotated]': 'rotated',
+ '[class._rotated]': 'rotated()',
'[class._small]': 'small',
},
})
@@ -33,11 +35,13 @@ export class TuiArrowComponent {
private readonly control: any = inject(AbstractTuiControl, {optional: true});
private readonly textfieldSize = inject(TUI_TEXTFIELD_SIZE);
private readonly options = inject(TUI_ARROW_OPTIONS);
- protected readonly directive = inject(TuiDropdownOpen, {optional: true});
+ protected readonly dropdownOpen = toSignal(
+ inject(TuiDropdownOpen, {optional: true})?.tuiDropdownOpenChange || of(false),
+ );
- protected get rotated(): boolean {
- return this.directive?.tuiDropdownOpen || !!this.control.pseudoOpen || false;
- }
+ protected readonly rotated = computed(
+ () => this.dropdownOpen() || this.control.pseudoOpen?.(),
+ );
protected get small(): boolean {
return !tuiSizeBigger(this.textfieldSize.size);
diff --git a/projects/legacy/components/arrow/arrow.template.html b/projects/legacy/components/arrow/arrow.template.html
index 560a57f74c8a..8a291f72f5fd 100644
--- a/projects/legacy/components/arrow/arrow.template.html
+++ b/projects/legacy/components/arrow/arrow.template.html
@@ -2,4 +2,3 @@
*polymorpheusOutlet="arrowIcon as src"
[icon]="src"
/>
-
diff --git a/projects/legacy/components/input-tag/input-tag.component.ts b/projects/legacy/components/input-tag/input-tag.component.ts
index 94e37c4abdca..a6007c0cf133 100644
--- a/projects/legacy/components/input-tag/input-tag.component.ts
+++ b/projects/legacy/components/input-tag/input-tag.component.ts
@@ -8,6 +8,7 @@ import {
inject,
Input,
Output,
+ signal,
TemplateRef,
ViewChild,
ViewChildren,
@@ -159,12 +160,6 @@ export class TuiInputTagComponent
@Input()
public removable = true;
- /**
- * @deprecated hack
- */
- @Input()
- public pseudoOpen = false;
-
@Input()
public disabledItemHandler: TuiBooleanHandler | string> =
TUI_FALSE_HANDLER;
@@ -172,6 +167,8 @@ export class TuiInputTagComponent
@Output()
public readonly searchChange = new EventEmitter();
+ public pseudoOpen = signal(false);
+
@Input('pseudoFocused')
public set pseudoFocusedSetter(value: boolean | null) {
if (!value && !this.focused) {
@@ -181,6 +178,14 @@ export class TuiInputTagComponent
this.pseudoFocus = value;
}
+ /**
+ * @deprecated hack
+ */
+ @Input('pseudoOpen')
+ public set setPseudoOpen(value: boolean) {
+ this.pseudoOpen.set(value);
+ }
+
public get labelOutside(): boolean {
const {size, labelOutside} = this.controller;