mirror of
https://github.com/supabase/supabase.git
synced 2026-07-05 02:24:20 +08:00
* 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>
90 lines
2.8 KiB
TypeScript
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
|