From b4874d8a46461fc5c2d593f5ff3ecb491b8e74cc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Th=C3=A9o=20Poizat?= Date: Mon, 18 Dec 2023 09:53:45 +0100 Subject: [PATCH 1/3] refactor: Create a getAvailableAppHighlightAlerts function and move it in another file --- .../AppHighlightAlertWrapper.jsx | 19 +++------------- src/components/AppHighlightAlert/helpers.js | 22 +++++++++++++++++++ 2 files changed, 25 insertions(+), 16 deletions(-) create mode 100644 src/components/AppHighlightAlert/helpers.js diff --git a/src/components/AppHighlightAlert/AppHighlightAlertWrapper.jsx b/src/components/AppHighlightAlert/AppHighlightAlertWrapper.jsx index 84e976fdb4..f8cd21e4ca 100644 --- a/src/components/AppHighlightAlert/AppHighlightAlertWrapper.jsx +++ b/src/components/AppHighlightAlert/AppHighlightAlertWrapper.jsx @@ -1,7 +1,6 @@ import React, { useEffect, useState } from 'react' -import { getBackupAppHighlightAlert } from 'components/AppHighlightAlert/BackupAppHighlightAlert' -import { getGeolocationTrackingAppHighlightAlert } from 'components/AppHighlightAlert/GeolocationTrackingAppHighlightAlert' +import { getAvailableAppHighlightAlerts } from 'components/AppHighlightAlert/helpers' import { useClient } from 'cozy-client' const AppHighlightAlertWrapper = ({ apps }) => { @@ -10,21 +9,9 @@ const AppHighlightAlertWrapper = ({ apps }) => { useEffect(() => { const getAppHighlightAlerts = async () => { - const appHighlightAlerts = [ - getBackupAppHighlightAlert(), - await getGeolocationTrackingAppHighlightAlert(client) - ] - - const availableAppHighlightAlerts = appHighlightAlerts.filter( - status => status.available - ) - - const selectedIndex = availableAppHighlightAlerts.findIndex( - status => status.displayable + const availableAppHighlightAlerts = await getAvailableAppHighlightAlerts( + client ) - if (selectedIndex !== -1) { - availableAppHighlightAlerts[selectedIndex].displayed = true - } setAppHighlightAlerts(availableAppHighlightAlerts) } diff --git a/src/components/AppHighlightAlert/helpers.js b/src/components/AppHighlightAlert/helpers.js new file mode 100644 index 0000000000..42af47214b --- /dev/null +++ b/src/components/AppHighlightAlert/helpers.js @@ -0,0 +1,22 @@ +import { getBackupAppHighlightAlert } from 'components/AppHighlightAlert/BackupAppHighlightAlert' +import { getGeolocationTrackingAppHighlightAlert } from 'components/AppHighlightAlert/GeolocationTrackingAppHighlightAlert' + +export const getAvailableAppHighlightAlerts = async client => { + const appHighlightAlerts = [ + getBackupAppHighlightAlert(), + await getGeolocationTrackingAppHighlightAlert(client) + ] + + const availableAppHighlightAlerts = appHighlightAlerts.filter( + status => status.available + ) + + const selectedIndex = availableAppHighlightAlerts.findIndex( + status => status.displayable + ) + if (selectedIndex !== -1) { + availableAppHighlightAlerts[selectedIndex].displayed = true + } + + return availableAppHighlightAlerts +} From 04fe43e9dd39cadf47e61d8b6c17dae6b5bdbe4e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Th=C3=A9o=20Poizat?= Date: Mon, 18 Dec 2023 10:41:30 +0100 Subject: [PATCH 2/3] test: Add unit tests to getAvailableAppHighlightAlerts --- .../AppHighlightAlert/helpers.spec.js | 106 ++++++++++++++++++ 1 file changed, 106 insertions(+) create mode 100644 src/components/AppHighlightAlert/helpers.spec.js diff --git a/src/components/AppHighlightAlert/helpers.spec.js b/src/components/AppHighlightAlert/helpers.spec.js new file mode 100644 index 0000000000..0bfdb7d0af --- /dev/null +++ b/src/components/AppHighlightAlert/helpers.spec.js @@ -0,0 +1,106 @@ +import { getAvailableAppHighlightAlerts } from 'components/AppHighlightAlert/helpers' +import { getBackupAppHighlightAlert } from 'components/AppHighlightAlert/BackupAppHighlightAlert' +import { getGeolocationTrackingAppHighlightAlert } from 'components/AppHighlightAlert/GeolocationTrackingAppHighlightAlert' + +jest.mock('components/AppHighlightAlert/BackupAppHighlightAlert') +jest.mock('components/AppHighlightAlert/GeolocationTrackingAppHighlightAlert') + +describe('getAvailableAppHighlightAlerts', () => { + it('should set the only displayable alert as displayed if only one displayable alert found', async () => { + getBackupAppHighlightAlert.mockReturnValue({ + name: 'BackupAppHighlightAlert', + available: false, + displayable: false + }) + getGeolocationTrackingAppHighlightAlert.mockReturnValue({ + name: 'GeolocationTrackingAppHighlightAlert', + available: true, + displayable: true + }) + + const availableAppHighlightAlerts = await getAvailableAppHighlightAlerts() + + expect(availableAppHighlightAlerts).toEqual([ + { + name: 'GeolocationTrackingAppHighlightAlert', + available: true, + displayable: true, + displayed: true + } + ]) + }) + + it('should set the first displayable alert as displayed if multiple displayable alerts found', async () => { + getBackupAppHighlightAlert.mockReturnValue({ + name: 'BackupAppHighlightAlert', + available: true, + displayable: true + }) + getGeolocationTrackingAppHighlightAlert.mockReturnValue({ + name: 'GeolocationTrackingAppHighlightAlert', + available: true, + displayable: true + }) + + const availableAppHighlightAlerts = await getAvailableAppHighlightAlerts() + + expect(availableAppHighlightAlerts).toEqual([ + { + name: 'BackupAppHighlightAlert', + available: true, + displayable: true, + displayed: true + }, + { + name: 'GeolocationTrackingAppHighlightAlert', + available: true, + displayable: true + } + ]) + }) + + it('should not return not available alerts', async () => { + getBackupAppHighlightAlert.mockReturnValue({ + name: 'BackupAppHighlightAlert', + available: false, + displayable: false + }) + getGeolocationTrackingAppHighlightAlert.mockReturnValue({ + name: 'GeolocationTrackingAppHighlightAlert', + available: false, + displayable: false + }) + + const availableAppHighlightAlerts = await getAvailableAppHighlightAlerts() + + expect(availableAppHighlightAlerts).toEqual([]) + }) + + it('should do nothing with not displayable alerts', async () => { + getBackupAppHighlightAlert.mockReturnValue({ + name: 'BackupAppHighlightAlert', + available: true, + displayable: false + }) + getGeolocationTrackingAppHighlightAlert.mockReturnValue({ + name: 'GeolocationTrackingAppHighlightAlert', + available: true, + displayable: false + }) + + const availableAppHighlightAlerts = await getAvailableAppHighlightAlerts() + + expect(availableAppHighlightAlerts).toEqual([ + { + name: 'BackupAppHighlightAlert', + available: true, + displayable: false + }, + { + name: 'GeolocationTrackingAppHighlightAlert', + available: true, + displayable: false + } + ]) + }) +}) From 309c30dfce5540de1d6877f3c43abf93658f8e4e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Th=C3=A9o=20Poizat?= Date: Mon, 18 Dec 2023 15:00:38 +0100 Subject: [PATCH 3/3] fix: Do not increment app highlight counter if app not installed --- .../AppHighlightAlert/AppHighlightAlertWrapper.jsx | 9 ++++++--- .../AppHighlightAlert/BackupAppHighlightAlert.jsx | 7 ++++--- .../GeolocationTrackingAppHighlightAlert.jsx | 10 +++++++--- src/components/AppHighlightAlert/helpers.js | 6 +++--- 4 files changed, 20 insertions(+), 12 deletions(-) diff --git a/src/components/AppHighlightAlert/AppHighlightAlertWrapper.jsx b/src/components/AppHighlightAlert/AppHighlightAlertWrapper.jsx index f8cd21e4ca..bb7e2e0768 100644 --- a/src/components/AppHighlightAlert/AppHighlightAlertWrapper.jsx +++ b/src/components/AppHighlightAlert/AppHighlightAlertWrapper.jsx @@ -10,14 +10,17 @@ const AppHighlightAlertWrapper = ({ apps }) => { useEffect(() => { const getAppHighlightAlerts = async () => { const availableAppHighlightAlerts = await getAvailableAppHighlightAlerts( - client + client, + apps ) setAppHighlightAlerts(availableAppHighlightAlerts) } - getAppHighlightAlerts() - }, [client]) + if (apps && appHighlightAlerts.length === 0) { + getAppHighlightAlerts() + } + }, [client, apps, appHighlightAlerts.length]) useEffect(() => { appHighlightAlerts.forEach(component => { diff --git a/src/components/AppHighlightAlert/BackupAppHighlightAlert.jsx b/src/components/AppHighlightAlert/BackupAppHighlightAlert.jsx index e30c22d7e5..b451ecdfb0 100644 --- a/src/components/AppHighlightAlert/BackupAppHighlightAlert.jsx +++ b/src/components/AppHighlightAlert/BackupAppHighlightAlert.jsx @@ -11,8 +11,9 @@ const APP_START_COUNT_KEY = 'BackupAppHighlightAlert__appStartCount' const MAX_COUNT_VALUE = 2 const DISABLED_COUNT_VALUE = -1 -const isAvailable = () => { +const isAvailable = installedApps => { return ( + installedApps.find(app => app.slug === 'photos') && isFlagshipApp() && flag('flagship.backup.enabled') && flag('flagship.backup.homeHighlightEnabled') @@ -26,11 +27,11 @@ const isDisplayable = () => { return appStartCount >= MAX_COUNT_VALUE - 1 } -export const getBackupAppHighlightAlert = () => { +export const getBackupAppHighlightAlert = installedApps => { return { name: 'BackupAppHighlightAlert', Component: BackupAppHighlightAlert, - available: isAvailable(), + available: isAvailable(installedApps), displayable: isDisplayable(), onNotDisplayed: onNotDisplayed, onDisplayed: onDisplayed diff --git a/src/components/AppHighlightAlert/GeolocationTrackingAppHighlightAlert.jsx b/src/components/AppHighlightAlert/GeolocationTrackingAppHighlightAlert.jsx index 2d9e6d93a1..9a312c6ea7 100644 --- a/src/components/AppHighlightAlert/GeolocationTrackingAppHighlightAlert.jsx +++ b/src/components/AppHighlightAlert/GeolocationTrackingAppHighlightAlert.jsx @@ -20,10 +20,11 @@ const hasNoTimeseriesGeojson = async client => { return timeseries.length === 0 } -const isAvailable = async client => { +const isAvailable = async (client, installedApps) => { const bikegoalSettings = flag('coachco2.bikegoal.settings') return ( + installedApps.find(app => app.slug === 'coachco2') && flag('home.push.coachco2.opencount') && flag('home.push.coachco2.opencount') >= 0 && (!bikegoalSettings || @@ -41,11 +42,14 @@ const isDisplayable = () => { return appStartCount >= flag('home.push.coachco2.opencount') - 1 } -export const getGeolocationTrackingAppHighlightAlert = async client => { +export const getGeolocationTrackingAppHighlightAlert = async ( + client, + installedApps +) => { return { name: 'GeolocationTrackingAppHighlightAlert', Component: GeolocationTrackingAppHighlightAlert, - available: await isAvailable(client), + available: await isAvailable(client, installedApps), displayable: isDisplayable(), onNotDisplayed: onNotDisplayed, onDisplayed: onDisplayed diff --git a/src/components/AppHighlightAlert/helpers.js b/src/components/AppHighlightAlert/helpers.js index 42af47214b..23d0b01c75 100644 --- a/src/components/AppHighlightAlert/helpers.js +++ b/src/components/AppHighlightAlert/helpers.js @@ -1,10 +1,10 @@ import { getBackupAppHighlightAlert } from 'components/AppHighlightAlert/BackupAppHighlightAlert' import { getGeolocationTrackingAppHighlightAlert } from 'components/AppHighlightAlert/GeolocationTrackingAppHighlightAlert' -export const getAvailableAppHighlightAlerts = async client => { +export const getAvailableAppHighlightAlerts = async (client, installedApps) => { const appHighlightAlerts = [ - getBackupAppHighlightAlert(), - await getGeolocationTrackingAppHighlightAlert(client) + getBackupAppHighlightAlert(installedApps), + await getGeolocationTrackingAppHighlightAlert(client, installedApps) ] const availableAppHighlightAlerts = appHighlightAlerts.filter(