Files
supabase/apps/studio/components/interfaces/Auth/Users/AddUserDropdown.tsx
Joshen Lim a897cc27f0 Part 1 of swapping useCheckPermissions with useAsyncCheckProjectPermissions (#37751)
* Part 1 of swapping useCheckPermissions with useAsyncCheckProjectPermissions

* Update apps/studio/hooks/misc/useCheckPermissions.ts

Co-authored-by: Drake Costa <drake@saeris.io>

* Address feedback

---------

Co-authored-by: Drake Costa <drake@saeris.io>
2025-08-11 11:53:15 +07:00

90 lines
2.8 KiB
TypeScript

import { PermissionAction } from '@supabase/shared-types/out/constants'
import { ChevronDown, Mail, UserPlus } from 'lucide-react'
import { useState } from 'react'
import { useAsyncCheckProjectPermissions } from 'hooks/misc/useCheckPermissions'
import {
Button,
DropdownMenu,
DropdownMenuContent,
DropdownMenuItem,
DropdownMenuTrigger,
Tooltip,
TooltipContent,
TooltipTrigger,
} from 'ui'
import CreateUserModal from './CreateUserModal'
import InviteUserModal from './InviteUserModal'
const AddUserDropdown = () => {
const { can: canInviteUsers } = useAsyncCheckProjectPermissions(
PermissionAction.AUTH_EXECUTE,
'invite_user'
)
const { can: canCreateUsers } = useAsyncCheckProjectPermissions(
PermissionAction.AUTH_EXECUTE,
'create_user'
)
const [inviteVisible, setInviteVisible] = useState(false)
const [createVisible, setCreateVisible] = useState(false)
return (
<>
<DropdownMenu>
<DropdownMenuTrigger asChild>
<Button type="primary" iconRight={<ChevronDown size={14} strokeWidth={1.5} />}>
Add user
</Button>
</DropdownMenuTrigger>
<DropdownMenuContent side="bottom" align="end" className="w-40">
<Tooltip>
<TooltipTrigger asChild>
<DropdownMenuItem
className="space-x-2 !pointer-events-auto"
disabled={!canInviteUsers}
onClick={() => {
if (canInviteUsers) setInviteVisible(true)
}}
>
<Mail size={14} />
<p>Send invitation</p>
</DropdownMenuItem>
</TooltipTrigger>
{!canInviteUsers && (
<TooltipContent side="left">
You need additional permissions to invite users
</TooltipContent>
)}
</Tooltip>
<Tooltip>
<TooltipTrigger asChild>
<DropdownMenuItem
className="space-x-2 !pointer-events-auto"
disabled={!canCreateUsers}
onClick={() => {
if (canCreateUsers) setCreateVisible(true)
}}
>
<UserPlus size={14} />
<p>Create new user</p>
</DropdownMenuItem>
</TooltipTrigger>
{!canCreateUsers && (
<TooltipContent side="left">
You need additional permissions to create users
</TooltipContent>
)}
</Tooltip>
</DropdownMenuContent>
</DropdownMenu>
<InviteUserModal visible={inviteVisible} setVisible={setInviteVisible} />
<CreateUserModal visible={createVisible} setVisible={setCreateVisible} />
</>
)
}
export default AddUserDropdown