From e47f46a79cc1dd9fb270285f45a0148bf4ca17b9 Mon Sep 17 00:00:00 2001 From: Thomas Rittson <31796059+eliykat@users.noreply.github.com> Date: Thu, 11 Apr 2024 21:32:44 +1000 Subject: [PATCH] [AC-2436] Fix flashing unassigned items banner (#8689) * Fix flashing banner for users who shouldn't see it * Emit the right value the first time * simplify further * restore comment (cherry picked from commit b843aa6bd1d188b8c1ce450249df22f562721224) --- .../services/unassigned-items-banner.service.spec.ts | 8 +++----- .../src/services/unassigned-items-banner.service.ts | 10 +++++----- 2 files changed, 8 insertions(+), 10 deletions(-) diff --git a/libs/angular/src/services/unassigned-items-banner.service.spec.ts b/libs/angular/src/services/unassigned-items-banner.service.spec.ts index ac80f7d651a..9b2ffc1ef9c 100644 --- a/libs/angular/src/services/unassigned-items-banner.service.spec.ts +++ b/libs/angular/src/services/unassigned-items-banner.service.spec.ts @@ -1,5 +1,5 @@ import { MockProxy, mock } from "jest-mock-extended"; -import { firstValueFrom, skip } from "rxjs"; +import { firstValueFrom } from "rxjs"; import { FakeStateProvider, mockAccountServiceWith } from "@bitwarden/common/spec"; import { UserId } from "@bitwarden/common/types/guid"; @@ -44,10 +44,8 @@ describe("UnassignedItemsBanner", () => { showBanner.nextState(undefined); const sut = sutFactory(); - // skip first value so we get the recomputed value after the server call - expect(await firstValueFrom(sut.showBanner$.pipe(skip(1)))).toBe(true); - // Expect to have updated local state - expect(await firstValueFrom(showBanner.state$)).toBe(true); + + expect(await firstValueFrom(sut.showBanner$)).toBe(true); expect(apiService.getShowUnassignedCiphersBanner).toHaveBeenCalledTimes(1); }); }); diff --git a/libs/angular/src/services/unassigned-items-banner.service.ts b/libs/angular/src/services/unassigned-items-banner.service.ts index bc567aa44ea..faa766a18a8 100644 --- a/libs/angular/src/services/unassigned-items-banner.service.ts +++ b/libs/angular/src/services/unassigned-items-banner.service.ts @@ -1,5 +1,5 @@ import { Injectable } from "@angular/core"; -import { EMPTY, concatMap } from "rxjs"; +import { concatMap } from "rxjs"; import { StateProvider, @@ -24,15 +24,15 @@ export class UnassignedItemsBannerService { private _showBanner = this.stateProvider.getActive(SHOW_BANNER_KEY); showBanner$ = this._showBanner.state$.pipe( - concatMap(async (showBanner) => { + concatMap(async (showBannerState) => { // null indicates that the user has not seen or dismissed the banner yet - get the flag from server - if (showBanner == null) { + if (showBannerState == null) { const showBannerResponse = await this.apiService.getShowUnassignedCiphersBanner(); await this._showBanner.update(() => showBannerResponse); - return EMPTY; // complete the inner observable without emitting any value; the update on the previous line will trigger another run + return showBannerResponse; } - return showBanner; + return showBannerState; }), );