import {Fragment} from 'react';
import styled from '@emotion/styled';
import startCase from 'lodash/startCase';
import {Button} from 'sentry/components/button';
import EmptyMessage from 'sentry/components/emptyMessage';
import {TeamBadge} from 'sentry/components/idBadge/teamBadge';
import Link from 'sentry/components/links/link';
import LoadingIndicator from 'sentry/components/loadingIndicator';
import Panel from 'sentry/components/panels/panel';
import PanelBody from 'sentry/components/panels/panelBody';
import PanelHeader from 'sentry/components/panels/panelHeader';
import PanelItem from 'sentry/components/panels/panelItem';
import TeamRoleSelect from 'sentry/components/teamRoleSelect';
import {TeamRoleColumnLabel} from 'sentry/components/teamRoleUtils';
import {IconSubtract} from 'sentry/icons';
import {t} from 'sentry/locale';
import {space} from 'sentry/styles/space';
import type {Member, Organization, Team} from 'sentry/types';
import {getEffectiveOrgRole} from 'sentry/utils/orgRole';
import {useTeams} from 'sentry/utils/useTeams';
import {RoleOverwritePanelAlert} from 'sentry/views/settings/organizationTeams/roleOverwriteWarning';
import {getButtonHelpText} from 'sentry/views/settings/organizationTeams/utils';
import type {TeamSelectProps} from './utils';
import {DropdownAddTeam} from './utils';
type Props = TeamSelectProps & {
/**
* Member that this component is acting upon
*/
member: Member;
/**
* Used when showing Teams for a Member
*/
onChangeTeamRole: (teamSlug: string, teamRole: string) => void;
/**
* Used when showing Teams for a Member
*/
selectedOrgRole: Member['orgRole'];
/**
* Used when showing Teams for a Member
*/
selectedTeamRoles: Member['teamRoles'];
};
function TeamSelect({
disabled,
loadingTeams,
member,
selectedOrgRole,
selectedTeamRoles,
organization,
onAddTeam,
onRemoveTeam,
onCreateTeam,
onChangeTeamRole,
}: Props) {
const {teams, onSearch, fetching: isLoadingTeams} = useTeams();
const {orgRoleList, teamRoleList} = organization;
const selectedTeamSlugs = new Set(selectedTeamRoles.map(tm => tm.teamSlug));
const selectedTeams = teams.filter(tm => selectedTeamSlugs.has(tm.slug));
// Determine if adding a team changes the minimum team-role
// Get org-roles from team membership, if any
const groupOrgRoles = selectedTeams
.filter(team => team.orgRole)
.map(team => team.orgRole as string);
if (selectedOrgRole) {
groupOrgRoles.push(selectedOrgRole);
}
// Sort them and to get the highest priority role
// Highest priority role may change minimum team role
const effectiveOrgRole = getEffectiveOrgRole(groupOrgRoles, orgRoleList);
const renderBody = () => {
if (selectedTeams.length === 0) {
return {t('No Teams assigned')};
}
return (
{effectiveOrgRole && (
)}
{selectedTeams.map(team => (
onRemoveTeam(slug)}
/>
))}
);
};
return (