import styled from '@emotion/styled'; import {trackAnalyticsEvent} from 'sentry/utils/analytics'; import replaceRouterParams from 'sentry/utils/replaceRouterParams'; import SettingsNavItem from 'sentry/views/settings/components/settingsNavItem'; import {NavigationGroupProps} from 'sentry/views/settings/types'; const SettingsNavigationGroup = (props: NavigationGroupProps) => { const {organization, project, name, items} = props; const navLinks = items.map(({path, title, index, show, badge, id, recordAnalytics}) => { if (typeof show === 'function' && !show(props)) { return null; } if (typeof show !== 'undefined' && !show) { return null; } const badgeResult = typeof badge === 'function' ? badge(props) : null; const to = replaceRouterParams(path, { ...(organization ? {orgId: organization.slug} : {}), ...(project ? {projectId: project.slug} : {}), }); const handleClick = () => { // only call the analytics event if the URL is changing if (recordAnalytics && to !== window.location.pathname) { trackAnalyticsEvent({ organization_id: organization ? organization.id : null, project_id: project && project.id, eventName: 'Sidebar Item Clicked', eventKey: 'sidebar.item_clicked', sidebar_item_id: id, dest: path, }); } }; return ( ); }); if (!navLinks.some(link => link !== null)) { return null; } return ( {name} {navLinks} ); }; const NavSection = styled('div')` margin-bottom: 20px; `; const SettingsHeading = styled('div')` color: ${p => p.theme.subText}; font-size: 12px; font-weight: 600; text-transform: uppercase; margin-bottom: 20px; `; export default SettingsNavigationGroup;