diff --git a/src/components/ContentHighlights/ContentHighlights.jsx b/src/components/ContentHighlights/ContentHighlights.jsx index 9dcd792768..fea59f6fd2 100644 --- a/src/components/ContentHighlights/ContentHighlights.jsx +++ b/src/components/ContentHighlights/ContentHighlights.jsx @@ -16,13 +16,14 @@ import ContentHighlightsContextProvider from './ContentHighlightsContext'; import ContentHighlightToast from './ContentHighlightToast'; import { EnterpriseAppContext } from '../EnterpriseApp/EnterpriseAppContextProvider'; import { withLocation } from '../../hoc'; +import { GROUP_TYPE_BUDGET } from '../PeopleManagement/constants'; const ContentHighlights = ({ location, enterpriseGroupsV1 }) => { const navigate = useNavigate(); const { state: locationState } = location; const [toasts, setToasts] = useState([]); const isEdxStaff = getAuthenticatedUser().administrator; - const [isSubGroup, setIsSubGroup] = useState(false); + const [hasBudgetGroup, setHasBudgetGroup] = useState(false); const { enterpriseCuration: { enterpriseCuration } } = useContext(EnterpriseAppContext); const intl = useIntl(); @@ -31,8 +32,8 @@ const ContentHighlights = ({ location, enterpriseGroupsV1 }) => { try { const response = await LmsApiService.fetchEnterpriseGroups(); response.data.results.forEach((group) => { - if (group.applies_to_all_contexts === false) { - setIsSubGroup(true); + if (group.group_type === GROUP_TYPE_BUDGET) { + setHasBudgetGroup(true); } }); } catch (error) { @@ -102,7 +103,7 @@ const ContentHighlights = ({ location, enterpriseGroupsV1 }) => { description: 'Hero title for the highlights page.', })} /> - {isSubGroup && ( + {hasBudgetGroup && ( ', () => { }); it('Displays the alert if custom groups is enabled and user is staff', () => { LmsApiService.fetchEnterpriseGroups.mockImplementation(() => Promise.resolve({ - data: { results: [{ applies_to_all_contexts: true }] }, + data: { results: [{ group_type: GROUP_TYPE_BUDGET }] }, })); renderWithRouter(); }); diff --git a/src/components/PeopleManagement/constants.js b/src/components/PeopleManagement/constants.js index c8c2b3a241..c253692b5b 100644 --- a/src/components/PeopleManagement/constants.js +++ b/src/components/PeopleManagement/constants.js @@ -1,2 +1,4 @@ -const MAX_LENGTH_GROUP_NAME = 60; -export default MAX_LENGTH_GROUP_NAME; +export const MAX_LENGTH_GROUP_NAME = 60; + +export const GROUP_TYPE_BUDGET = 'budget'; +export const GROUP_TYPE_FLEX = 'flex'; diff --git a/src/components/Sidebar/index.jsx b/src/components/Sidebar/index.jsx index 110f1ffb34..bb5f0891f3 100644 --- a/src/components/Sidebar/index.jsx +++ b/src/components/Sidebar/index.jsx @@ -22,6 +22,7 @@ import { useOnMount } from '../../hooks'; import { EnterpriseSubsidiesContext } from '../EnterpriseSubsidiesContext'; import { EnterpriseAppContext } from '../EnterpriseApp/EnterpriseAppContextProvider'; import LmsApiService from '../../data/services/LmsApiService'; +import { GROUP_TYPE_BUDGET } from '../PeopleManagement/constants'; const Sidebar = ({ baseUrl, @@ -48,8 +49,8 @@ const Sidebar = ({ const { canManageLearnerCredit } = useContext(EnterpriseSubsidiesContext); const { FEATURE_CONTENT_HIGHLIGHTS } = getConfig(); const isEdxStaff = getAuthenticatedUser().administrator; - const [isSubGroup, setIsSubGroup] = useState(false); - const hideHighlightsForGroups = enterpriseGroupsV1 && isSubGroup && !isEdxStaff; + const [hasBudgetGroup, setHasBudgetGroup] = useState(false); + const hideHighlightsForGroups = enterpriseGroupsV1 && hasBudgetGroup && !isEdxStaff; const intl = useIntl(); const getSidebarWidth = useCallback(() => { @@ -89,8 +90,8 @@ const Sidebar = ({ // we only want to hide the feature if a customer has a group this does not // apply to all contexts/include all users response.data.results.forEach((group) => { - if (group.applies_to_all_contexts === false) { - setIsSubGroup(true); + if (group.group_type === GROUP_TYPE_BUDGET) { + setHasBudgetGroup(true); } }); } catch (error) { diff --git a/src/containers/Sidebar/Sidebar.test.jsx b/src/containers/Sidebar/Sidebar.test.jsx index 35b9550ae0..080d608164 100644 --- a/src/containers/Sidebar/Sidebar.test.jsx +++ b/src/containers/Sidebar/Sidebar.test.jsx @@ -444,9 +444,9 @@ describe('', () => { }); it.each([ - { appliesToAllContexts: true }, - { appliesToAllContexts: false }, - ])('hides highlights when we have groups with a subset of all learners (%s)', async ({ appliesToAllContexts }) => { + { groupType: 'budget' }, + { groupType: 'flex' }, + ])('hides highlights when we have budget groups (%s)', async ({ groupType }) => { getAuthenticatedUser.mockReturnValue({ administrator: false, }); @@ -460,12 +460,12 @@ describe('', () => { }, }); LmsApiService.fetchEnterpriseGroups.mockImplementation(() => Promise.resolve({ - data: { results: [{ applies_to_all_contexts: appliesToAllContexts }] }, + data: { results: [{ group_type: groupType }] }, })); render(); const highlightsLink = screen.queryByRole('link', { name: 'Highlights' }); await waitFor(() => { - if (appliesToAllContexts) { + if (groupType === 'flex') { expect(highlightsLink).toBeInTheDocument(); } else { expect(highlightsLink).not.toBeInTheDocument();