123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- import {browserHistory, RouteComponentProps} from 'react-router';
- import styled from '@emotion/styled';
- import IdBadge from 'sentry/components/idBadge';
- import {Organization} from 'sentry/types';
- import recreateRoute from 'sentry/utils/recreateRoute';
- import shouldUseLegacyRoute from 'sentry/utils/shouldUseLegacyRoute';
- import withLatestContext from 'sentry/utils/withLatestContext';
- import BreadcrumbDropdown from 'sentry/views/settings/components/settingsBreadcrumb/breadcrumbDropdown';
- import findFirstRouteWithoutRouteParam from 'sentry/views/settings/components/settingsBreadcrumb/findFirstRouteWithoutRouteParam';
- import MenuItem from 'sentry/views/settings/components/settingsBreadcrumb/menuItem';
- import {CrumbLink} from '.';
- type Props = RouteComponentProps<{projectId?: string}, {}> & {
- organization: Organization;
- organizations: Organization[];
- };
- const OrganizationCrumb = ({
- organization,
- organizations,
- params,
- routes,
- route,
- ...props
- }: Props) => {
- const handleSelect = (item: {value: Organization}) => {
- // If we are currently in a project context, and we're attempting to switch organizations,
- // then we need to default to index route (e.g. `route`)
- //
- // Otherwise, find the last route without a router param
- // e.g. if you are on API details, we want the API listing
- // This fails if our route tree is not nested
- const hasProjectParam = !!params.projectId;
- let destination = hasProjectParam
- ? route
- : findFirstRouteWithoutRouteParam(routes.slice(routes.indexOf(route)));
- // It's possible there is no route without route params (e.g. organization settings index),
- // in which case, we can use the org settings index route (e.g. `route`)
- if (!hasProjectParam && typeof destination === 'undefined') {
- destination = route;
- }
- if (destination === undefined) {
- return;
- }
- const org = item.value;
- const path = recreateRoute(destination, {
- routes,
- params: {...params, orgId: org.slug},
- });
- if (shouldUseLegacyRoute(org)) {
- browserHistory.push(path);
- } else {
- const {organizationUrl} = org.links;
- window.location.assign(`${organizationUrl}${path}`);
- }
- };
- if (!organization) {
- return null;
- }
- const hasMenu = organizations.length > 1;
- const orgSettings = `/settings/${organization.slug}/`;
- return (
- <BreadcrumbDropdown
- name={
- <CrumbLink to={orgSettings}>
- <BadgeWrapper>
- <IdBadge avatarSize={18} organization={organization} />
- </BadgeWrapper>
- </CrumbLink>
- }
- onSelect={handleSelect}
- hasMenu={hasMenu}
- route={route}
- items={organizations.map((org, index) => ({
- index,
- value: org,
- label: (
- <MenuItem>
- <IdBadge organization={org} />
- </MenuItem>
- ),
- }))}
- {...props}
- />
- );
- };
- const BadgeWrapper = styled('div')`
- display: flex;
- align-items: center;
- `;
- export {OrganizationCrumb};
- export default withLatestContext(OrganizationCrumb);
|