12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- import type {RouteComponentProps} from 'react-router';
- import debounce from 'lodash/debounce';
- import IdBadge from 'sentry/components/idBadge';
- import {DEFAULT_DEBOUNCE_DURATION} from 'sentry/constants';
- import {browserHistory} from 'sentry/utils/browserHistory';
- import recreateRoute from 'sentry/utils/recreateRoute';
- import {useParams} from 'sentry/utils/useParams';
- import {useTeams} from 'sentry/utils/useTeams';
- import BreadcrumbDropdown from 'sentry/views/settings/components/settingsBreadcrumb/breadcrumbDropdown';
- import MenuItem from 'sentry/views/settings/components/settingsBreadcrumb/menuItem';
- import {CrumbLink} from '.';
- type Props = RouteComponentProps<{teamId: string}, {}>;
- function TeamCrumb({routes, route, ...props}: Props) {
- const {teams, onSearch, fetching} = useTeams();
- const params = useParams();
- const team = teams.find(({slug}) => slug === params.teamId);
- const hasMenu = teams.length > 1;
- const handleSearchChange = (e: React.ChangeEvent<HTMLInputElement>) => {
- onSearch(e.target.value);
- };
- const debouncedHandleSearch = debounce(handleSearchChange, DEFAULT_DEBOUNCE_DURATION);
- if (!team) {
- return null;
- }
- const teamUrl = `/settings/${params.orgId}/teams/${team.slug}/`;
- return (
- <BreadcrumbDropdown
- name={
- <CrumbLink to={teamUrl}>
- <IdBadge avatarSize={18} team={team} />
- </CrumbLink>
- }
- onSelect={item => {
- browserHistory.push(
- recreateRoute('', {
- routes,
- params: {...params, teamId: item.value},
- })
- );
- }}
- hasMenu={hasMenu}
- route={route}
- items={teams.map((teamItem, index) => ({
- index,
- value: teamItem.slug,
- label: (
- <MenuItem>
- <IdBadge team={teamItem} />
- </MenuItem>
- ),
- }))}
- onChange={debouncedHandleSearch}
- busyItemsStillVisible={fetching}
- {...props}
- />
- );
- }
- export default TeamCrumb;
|