ruvector/studio/components/interfaces/Auth/Users/AddUserDropdown.tsx
rUv 814f595995 feat(studio): Add complete RuVector Studio application
Major additions:
- Complete Next.js studio application with 1600+ components
- Docker support (Dockerfile.combined, docker-compose.yml)
- GCP deployment documentation and benchmarks
- SQL benchmark scripts for performance testing
- Sentry integration for monitoring
- Comprehensive test suite and mocks

Studio features:
- Dashboard and admin interfaces
- Data visualization components
- Authentication and user management
- API integration with RuVector backend
- Static data and public assets

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-06 23:04:48 +00:00

78 lines
2.8 KiB
TypeScript

import { PermissionAction } from '@supabase/shared-types/out/constants'
import { ChevronDown, Mail, UserPlus } from 'lucide-react'
import { parseAsBoolean, useQueryState } from 'nuqs'
import { DropdownMenuItemTooltip } from 'components/ui/DropdownMenuItemTooltip'
import { useAsyncCheckPermissions } from 'hooks/misc/useCheckPermissions'
import { useIsFeatureEnabled } from 'hooks/misc/useIsFeatureEnabled'
import { Button, DropdownMenu, DropdownMenuContent, DropdownMenuTrigger } from 'ui'
import CreateUserModal from './CreateUserModal'
import InviteUserModal from './InviteUserModal'
export const AddUserDropdown = () => {
const showSendInvitation = useIsFeatureEnabled('authentication:show_send_invitation')
const { can: canInviteUsers } = useAsyncCheckPermissions(
PermissionAction.AUTH_EXECUTE,
'invite_user'
)
const { can: canCreateUsers } = useAsyncCheckPermissions(
PermissionAction.AUTH_EXECUTE,
'create_user'
)
const [inviteVisible, setInviteVisible] = useQueryState(
'invite',
parseAsBoolean.withDefault(false).withOptions({ history: 'push', clearOnDefault: true })
)
const [createVisible, setCreateVisible] = useQueryState(
'new',
parseAsBoolean.withDefault(false).withOptions({ history: 'push', clearOnDefault: true })
)
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">
{showSendInvitation && (
<DropdownMenuItemTooltip
className="gap-x-2"
disabled={!canInviteUsers}
onClick={() => {
if (canInviteUsers) setInviteVisible(true)
}}
tooltip={{
content: { side: 'left', text: 'You need additional permissions to invite users' },
}}
>
<Mail size={14} />
<p>Send invitation</p>
</DropdownMenuItemTooltip>
)}
<DropdownMenuItemTooltip
className="space-x-2 !pointer-events-auto"
disabled={!canCreateUsers}
onClick={() => {
if (canCreateUsers) setCreateVisible(true)
}}
tooltip={{
content: { side: 'left', text: 'You need additional permissions to create users' },
}}
>
<UserPlus size={14} />
<p>Create new user</p>
</DropdownMenuItemTooltip>
</DropdownMenuContent>
</DropdownMenu>
<InviteUserModal visible={inviteVisible} setVisible={setInviteVisible} />
<CreateUserModal visible={createVisible} setVisible={setCreateVisible} />
</>
)
}