From fc7d8174c38f419f2dc8c5ffabd4d0943e284819 Mon Sep 17 00:00:00 2001 From: Sergey Petushkov Date: Wed, 28 Aug 2024 13:04:14 +0200 Subject: [PATCH] chore(connections): make sure that getThemeOf method gets updated when colors change (#6162) --- .../hooks/use-tab-connection-theme.spec.ts | 25 +++++++++++++++++++ .../src/hooks/use-tab-connection-theme.ts | 15 +++++------ .../src/stores/store-context.tsx | 14 +++++++++++ 3 files changed, 45 insertions(+), 9 deletions(-) diff --git a/packages/compass-connections/src/hooks/use-tab-connection-theme.spec.ts b/packages/compass-connections/src/hooks/use-tab-connection-theme.spec.ts index 5b0682ef54b..29d8d002046 100644 --- a/packages/compass-connections/src/hooks/use-tab-connection-theme.spec.ts +++ b/packages/compass-connections/src/hooks/use-tab-connection-theme.spec.ts @@ -89,4 +89,29 @@ describe('useTabConnectionTheme', function () { ).to.equal(undefined); }); }); + + it('tracks updates of connection color state and returns a new method when they are changed', async function () { + const { result, connectionsStore } = renderHookWithConnections( + useTabConnectionTheme, + { + preferences: { enableMultipleConnectionSystem: true }, + connections: [CONNECTION_INFO], + } + ); + + const getThemeOf = result.current.getThemeOf; + + await connectionsStore.actions.saveEditedConnection({ + ...CONNECTION_INFO, + favorite: { + ...CONNECTION_INFO.favorite, + color: 'color1', + }, + }); + + expect(result.current.getThemeOf).to.not.eq(getThemeOf); + expect(result.current.getThemeOf(CONNECTION_INFO.id)).to.not.eq( + getThemeOf(CONNECTION_INFO.id) + ); + }); }); diff --git a/packages/compass-connections/src/hooks/use-tab-connection-theme.ts b/packages/compass-connections/src/hooks/use-tab-connection-theme.ts index 643cf950ab2..dbfed847ba6 100644 --- a/packages/compass-connections/src/hooks/use-tab-connection-theme.ts +++ b/packages/compass-connections/src/hooks/use-tab-connection-theme.ts @@ -1,10 +1,10 @@ import { type ConnectionInfo } from '@mongodb-js/connection-info'; import { useConnectionColor } from '@mongodb-js/connection-form'; -import { useConnectionRepository } from './use-connection-repository'; import { useDarkMode, type TabTheme } from '@mongodb-js/compass-components'; import { palette } from '@mongodb-js/compass-components'; import { useCallback } from 'react'; import { usePreference } from 'compass-preferences-model/provider'; +import { useConnectionsColorList } from '../stores/store-context'; type ThemeProvider = { getThemeOf( @@ -16,20 +16,17 @@ type ThemeProvider = { export function useTabConnectionTheme(): ThemeProvider { const { connectionColorToHex, connectionColorToHexActive } = useConnectionColor(); - const { getConnectionInfoById } = useConnectionRepository(); + const connectionColorsList = useConnectionsColorList(); const darkTheme = useDarkMode(); const isMultipleConnectionsEnabled = usePreference( 'enableMultipleConnectionSystem' ); - // TODO: this method is not reactive and works only by accident, refactor the - // hook to explicitly track changes to color in connections, otherwise the - // value of the theme might be stale when we remove `useConnectionRepository` - // hook completely const getThemeOf = useCallback( (connectionId: ConnectionInfo['id']) => { - const connectionInfo = getConnectionInfoById(connectionId); - const color = connectionInfo?.favorite?.color; + const color = connectionColorsList.find((connection) => { + return connection.id === connectionId; + })?.color; const bgColor = connectionColorToHex(color); const activeBgColor = connectionColorToHexActive(color); @@ -70,7 +67,7 @@ export function useTabConnectionTheme(): ThemeProvider { }, [ palette, - getConnectionInfoById, + connectionColorsList, connectionColorToHex, connectionColorToHexActive, darkTheme, diff --git a/packages/compass-connections/src/stores/store-context.tsx b/packages/compass-connections/src/stores/store-context.tsx index ff9b6fa581c..adce1a0a941 100644 --- a/packages/compass-connections/src/stores/store-context.tsx +++ b/packages/compass-connections/src/stores/store-context.tsx @@ -335,3 +335,17 @@ export function useConnectionsState() { noopCheck: 'never', }); } + +export function useConnectionsColorList(): { + id: ConnectionId; + color: string | undefined; +}[] { + return useSelector((state) => { + return Object.values(state.connections.byId).map((connection) => { + return { + id: connection.info.id, + color: connection.info.favorite?.color, + }; + }); + }, isEqual); +}