diff --git a/.github/workflows/after-close-pr.yml b/.github/workflows/after-close-pr.yml index 15d468781eac..d6ad0d31c157 100644 --- a/.github/workflows/after-close-pr.yml +++ b/.github/workflows/after-close-pr.yml @@ -28,7 +28,7 @@ jobs: steps: - uses: actions/checkout@v4.2.2 - name: Drop e2e report site - uses: w9jds/firebase-action@v13.28.0 + uses: w9jds/firebase-action@v13.29.0 continue-on-error: true with: args: hosting:channel:delete ${{ env.channel }}-e2e --site taiga-previews-demo-e2e-report -f @@ -36,7 +36,7 @@ jobs: GCP_SA_KEY: ${{ secrets.FIREBASE_TAIGA_PREVIEWS_SA }} PROJECT_ID: taiga-previews - name: Drop preview demo site - uses: w9jds/firebase-action@v13.28.0 + uses: w9jds/firebase-action@v13.29.0 continue-on-error: true with: args: hosting:channel:delete ${{ env.channel }}-demo --site taiga-previews-demo -f diff --git a/projects/addon-table/components/table-pagination/table-pagination.component.ts b/projects/addon-table/components/table-pagination/table-pagination.component.ts index c407eb2fbfdc..bf7239d0314b 100644 --- a/projects/addon-table/components/table-pagination/table-pagination.component.ts +++ b/projects/addon-table/components/table-pagination/table-pagination.component.ts @@ -90,7 +90,7 @@ export class TuiTablePagination { } protected get start(): number { - return this.page * this.size; + return Math.min(this.page * this.size, Math.max(this.total - this.size, 0)); } protected get end(): number { diff --git a/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts b/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts index ded45fa8ffd5..1c1c4a98dc16 100644 --- a/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts +++ b/projects/core/directives/dropdown/dropdown-open-legacy.directive.ts @@ -1,5 +1,5 @@ import {Directive, Input, Output} from '@angular/core'; -import {BehaviorSubject} from 'rxjs'; +import {distinctUntilChanged, Subject} from 'rxjs'; /** * @deprecated TODO: remove in v.5 when legacy controls are dropped @@ -10,11 +10,18 @@ import {BehaviorSubject} from 'rxjs'; '[tuiDropdownOpen]:not([tuiDropdown]),[tuiDropdownOpenChange]:not([tuiDropdown])', }) export class TuiDropdownOpenLegacy { + private readonly openStateSub = new Subject(); + @Output() - public readonly tuiDropdownOpenChange = new BehaviorSubject(false); + public readonly tuiDropdownOpenChange = + this.openStateSub.pipe(distinctUntilChanged()); @Input() public set tuiDropdownOpen(open: boolean) { - this.tuiDropdownOpenChange.next(open); + this.emitOpenChange(open); + } + + public emitOpenChange(open: boolean): void { + this.openStateSub.next(open); } } diff --git a/projects/demo/src/modules/components/table-pagination/index.html b/projects/demo/src/modules/components/table-pagination/index.html index 746614bc7c0d..576d6d9ec005 100644 --- a/projects/demo/src/modules/components/table-pagination/index.html +++ b/projects/demo/src/modules/components/table-pagination/index.html @@ -59,6 +59,7 @@ documentationPropertyName="total" documentationPropertyType="number" [(documentationPropertyValue)]="total" + (documentationPropertyValueChange)="totalChange($event)" > Total amount of items/lines in the table. diff --git a/projects/demo/src/modules/components/table-pagination/index.ts b/projects/demo/src/modules/components/table-pagination/index.ts index 358bcae20497..c614458f0181 100644 --- a/projects/demo/src/modules/components/table-pagination/index.ts +++ b/projects/demo/src/modules/components/table-pagination/index.ts @@ -27,4 +27,9 @@ export default class Page { this.page = page; this.size = size; } + + protected totalChange(total: number): void { + this.total = total; + this.size = Math.min(this.size, Math.max(total, 1)); + } } diff --git a/projects/demo/src/modules/directives/swipe/examples/2/index.ts b/projects/demo/src/modules/directives/swipe/examples/2/index.ts index a333ebfae1f1..4011f863b622 100644 --- a/projects/demo/src/modules/directives/swipe/examples/2/index.ts +++ b/projects/demo/src/modules/directives/swipe/examples/2/index.ts @@ -2,13 +2,14 @@ import {AsyncPipe} from '@angular/common'; import {Component} from '@angular/core'; import {changeDetection} from '@demo/emulate/change-detection'; import {encapsulation} from '@demo/emulate/encapsulation'; +import {TuiSidebar} from '@taiga-ui/addon-mobile'; import type {TuiSwipeEvent} from '@taiga-ui/cdk'; import {TuiSwipe} from '@taiga-ui/cdk'; import {Subject} from 'rxjs'; @Component({ standalone: true, - imports: [AsyncPipe, TuiSwipe], + imports: [AsyncPipe, TuiSidebar, TuiSwipe], templateUrl: './index.html', styleUrls: ['./index.less'], encapsulation, diff --git a/projects/legacy/directives/legacy-dropdown-open-monitor/legacy-dropdown-open-monitor.ts b/projects/legacy/directives/legacy-dropdown-open-monitor/legacy-dropdown-open-monitor.ts index 9fd6cb8fcf88..e0d027a48492 100644 --- a/projects/legacy/directives/legacy-dropdown-open-monitor/legacy-dropdown-open-monitor.ts +++ b/projects/legacy/directives/legacy-dropdown-open-monitor/legacy-dropdown-open-monitor.ts @@ -34,6 +34,6 @@ export class TuiLegacyDropdownOpenMonitorDirective implements AfterViewInit { this.host.driver .pipe(distinctUntilChanged(), takeUntilDestroyed(this.destroyRef)) - .subscribe((open) => this.external?.tuiDropdownOpenChange.next(open)); + .subscribe((open) => this.external?.emitOpenChange(open)); } }