Skip to content

Commit

Permalink
fix(legacy): Input fix [(tuiDropdownOpen)]
Browse files Browse the repository at this point in the history
fix(legacy): `MultiSelect` fix `filterByInput` pipe
fix(kit): `TabsWithMore` fix clicks in dropdown
  • Loading branch information
waterplea committed Sep 26, 2024
1 parent 329a782 commit 992d8ba
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 10 deletions.
6 changes: 3 additions & 3 deletions projects/kit/components/tabs/tab.directive.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,11 @@ import {Directive, inject} from '@angular/core';
import {takeUntilDestroyed} from '@angular/core/rxjs-interop';
import {RouterLinkActive} from '@angular/router';
import {MutationObserverService} from '@ng-web-apis/mutation-observer';
import {tuiTypedFromEvent} from '@taiga-ui/cdk/observables';
import {tuiTypedFromEvent, tuiZonefreeScheduler} from '@taiga-ui/cdk/observables';
import {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';
import {tuiIsNativeFocused} from '@taiga-ui/cdk/utils/focus';
import {TuiWithIcons} from '@taiga-ui/core/directives/icons';
import {EMPTY, filter, merge} from 'rxjs';
import {debounceTime, EMPTY, filter, merge} from 'rxjs';

export const TUI_TAB_ACTIVATE = 'tui-tab-activate';

Expand All @@ -34,7 +34,7 @@ export class TuiTab implements OnDestroy {
this.rla?.isActiveChange.pipe(filter(Boolean)) || EMPTY,
this.el.matches('button') ? tuiTypedFromEvent(this.el, 'click') : EMPTY,
)
.pipe(takeUntilDestroyed())
.pipe(debounceTime(0, tuiZonefreeScheduler()), takeUntilDestroyed())
.subscribe(() =>
this.el.dispatchEvent(new CustomEvent(TUI_TAB_ACTIVATE, {bubbles: true})),
);
Expand Down
15 changes: 9 additions & 6 deletions projects/kit/pipes/filter-by-input/filter-by-input.pipe.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import type {PipeTransform} from '@angular/core';
import {inject, Pipe} from '@angular/core';
import {TUI_DEFAULT_MATCHER} from '@taiga-ui/cdk/constants';
import type {TuiStringHandler, TuiStringMatcher} from '@taiga-ui/cdk/types';
import {tuiIsPresent, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';
import {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';
import {TUI_DATA_LIST_HOST} from '@taiga-ui/core/components/data-list';
import {TuiTextfieldComponent} from '@taiga-ui/core/components/textfield';
import {tuiIsFlat} from '@taiga-ui/kit/utils';
Expand Down Expand Up @@ -57,7 +57,7 @@ export class TuiFilterByInputPipe implements PipeTransform {
): readonly T[] {
const match = this.getMatch(items, stringify, query);

return tuiIsPresent(match)
return match != null
? items
: items.filter((item) => matcher(item, query, stringify));
}
Expand All @@ -68,11 +68,9 @@ export class TuiFilterByInputPipe implements PipeTransform {
stringify: TuiStringHandler<T>,
query: string,
): ReadonlyArray<readonly T[]> {
const match = items.find((item) =>
tuiIsPresent(this.getMatch(item, stringify, query)),
);
const match = items.find((item) => this.getMatch(item, stringify, query) != null);

return tuiIsPresent(match)
return match != null
? items
: items.map((inner) => this.filterFlat(inner, matcher, stringify, query));
}
Expand All @@ -82,6 +80,11 @@ export class TuiFilterByInputPipe implements PipeTransform {
stringify: TuiStringHandler<T>,
query: string,
): T | undefined {
// TODO: Refactor when tui-textfield[multi] is ready
if ((this.host as any).tagValidator) {
return undefined;
}

return items.find(
(item) => stringify(item).toLocaleLowerCase() === query.toLocaleLowerCase(),
);
Expand Down
8 changes: 7 additions & 1 deletion projects/legacy/components/input/input.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,12 +5,18 @@ import {
TuiPrimitiveTextfieldModule,
TuiTextfieldComponent,
} from '@taiga-ui/legacy/components/primitive-textfield';
import {TuiLegacyDropdownOpenMonitorDirective} from '@taiga-ui/legacy/directives';

import {TuiInputComponent} from './input.component';
import {TuiInputDirective} from './input.directive';

@NgModule({
imports: [CommonModule, TuiPrimitiveTextfieldModule, ...TuiDropdown],
imports: [
CommonModule,
TuiPrimitiveTextfieldModule,
...TuiDropdown,
TuiLegacyDropdownOpenMonitorDirective,
],
declarations: [TuiInputComponent, TuiInputDirective],
exports: [
TuiInputComponent,
Expand Down

0 comments on commit 992d8ba

Please sign in to comment.