import { TEAM_MEMBER_ROLE_HIERARCHY } from '@documenso/lib/constants/teams'; import { TEAM_MEMBER_ROLE_MAP } from '@documenso/lib/constants/teams-translations'; import { trpc } from '@documenso/trpc/react'; import { Button } from '@documenso/ui/primitives/button'; import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, DialogTrigger, } from '@documenso/ui/primitives/dialog'; import { Form, FormControl, FormDescription, FormField, FormItem, FormLabel, FormMessage, } from '@documenso/ui/primitives/form/form'; import { Input } from '@documenso/ui/primitives/input'; import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from '@documenso/ui/primitives/select'; import { useToast } from '@documenso/ui/primitives/use-toast'; import { zodResolver } from '@hookform/resolvers/zod'; import { Trans, useLingui } from '@lingui/react/macro'; import { TeamMemberRole } from '@prisma/client'; import type * as DialogPrimitive from '@radix-ui/react-dialog'; import { useEffect, useState } from 'react'; import { useForm } from 'react-hook-form'; import { match } from 'ts-pattern'; import { z } from 'zod'; import { type OrganisationGroupOption, OrganisationGroupsMultiSelectCombobox, } from '~/components/general/organisation-groups-multiselect-combobox'; import { useCurrentTeam } from '~/providers/team'; export type TeamGroupCreateDialogProps = Omit; const ZAddTeamMembersFormSchema = z.object({ groups: z.array( z.object({ organisationGroupId: z.string(), teamRole: z.nativeEnum(TeamMemberRole), }), ), }); type TAddTeamMembersFormSchema = z.infer; export const TeamGroupCreateDialog = ({ ...props }: TeamGroupCreateDialogProps) => { const [open, setOpen] = useState(false); const [step, setStep] = useState<'SELECT' | 'ROLES'>('SELECT'); const [selectedGroups, setSelectedGroups] = useState([]); const { t } = useLingui(); const { toast } = useToast(); const team = useCurrentTeam(); const form = useForm({ resolver: zodResolver(ZAddTeamMembersFormSchema), defaultValues: { groups: [], }, }); const { mutateAsync: createTeamGroups } = trpc.team.group.createMany.useMutation(); const onFormSubmit = async ({ groups }: TAddTeamMembersFormSchema) => { try { await createTeamGroups({ teamId: team.id, groups, }); toast({ title: t`Success`, description: t`Team members have been added.`, duration: 5000, }); setOpen(false); } catch { toast({ title: t`An unknown error occurred`, description: t`We encountered an unknown error while attempting to add team members. Please try again later.`, variant: 'destructive', }); } }; useEffect(() => { if (!open) { form.reset(); setStep('SELECT'); setSelectedGroups([]); } }, [open, form]); return ( e.stopPropagation()} asChild> {match(step) .with('SELECT', () => ( Add groups Select groups of members to add to the team. )) .with('ROLES', () => ( Add group roles Configure the team roles for each group )) .exhaustive()}
{step === 'SELECT' && ( <> ( Groups { setSelectedGroups(groups); field.onChange( groups.map((group) => ({ organisationGroupId: group.id, teamRole: field.value.find((value) => value.organisationGroupId === group.id)?.teamRole || TeamMemberRole.MEMBER, })), ); }} className="w-full bg-background" dataTestId="team-groups-picker" /> Select groups to add to this team )} /> )} {step === 'ROLES' && ( <>
{form.getValues('groups').map((group, index) => (
{index === 0 && ( Group )} id === group.organisationGroupId)?.name || t`Untitled Group` } />
( {index === 0 && ( Team Role )} )} />
))}
)}
); };