mirror of
https://github.com/langgenius/dify.git
synced 2024-11-16 03:32:23 +08:00
fix member auth
This commit is contained in:
parent
70c2ec8ed5
commit
7431dab7b0
|
@ -34,7 +34,7 @@ const MembersPage = () => {
|
||||||
}
|
}
|
||||||
const { locale } = useContext(I18n)
|
const { locale } = useContext(I18n)
|
||||||
|
|
||||||
const { userProfile, currentWorkspace, isCurrentWorkspaceManager } = useAppContext()
|
const { userProfile, currentWorkspace, isCurrentWorkspaceOwner, isCurrentWorkspaceManager } = useAppContext()
|
||||||
const { data, mutate } = useSWR({ url: '/workspaces/current/members' }, fetchMembers)
|
const { data, mutate } = useSWR({ url: '/workspaces/current/members' }, fetchMembers)
|
||||||
const [inviteModalVisible, setInviteModalVisible] = useState(false)
|
const [inviteModalVisible, setInviteModalVisible] = useState(false)
|
||||||
const [invitationResults, setInvitationResults] = useState<InvitationResult[]>([])
|
const [invitationResults, setInvitationResults] = useState<InvitationResult[]>([])
|
||||||
|
@ -109,8 +109,8 @@ const MembersPage = () => {
|
||||||
<div className='shrink-0 flex items-center w-[104px] py-2 text-[13px] text-gray-700'>{dayjs(Number((account.last_active_at || account.created_at)) * 1000).locale(locale === 'zh-Hans' ? 'zh-cn' : 'en').fromNow()}</div>
|
<div className='shrink-0 flex items-center w-[104px] py-2 text-[13px] text-gray-700'>{dayjs(Number((account.last_active_at || account.created_at)) * 1000).locale(locale === 'zh-Hans' ? 'zh-cn' : 'en').fromNow()}</div>
|
||||||
<div className='shrink-0 w-[96px] flex items-center'>
|
<div className='shrink-0 w-[96px] flex items-center'>
|
||||||
{
|
{
|
||||||
(owner && account.role !== 'owner')
|
((isCurrentWorkspaceOwner && account.role !== 'owner') || (isCurrentWorkspaceManager && !['owner', 'admin'].includes(account.role)))
|
||||||
? <Operation member={account} onOperate={mutate} />
|
? <Operation member={account} operatorRole={currentWorkspace.role} onOperate={mutate} />
|
||||||
: <div className='px-3 text-[13px] text-gray-700'>{RoleMap[account.role] || RoleMap.normal}</div>
|
: <div className='px-3 text-[13px] text-gray-700'>{RoleMap[account.role] || RoleMap.normal}</div>
|
||||||
}
|
}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -26,11 +26,13 @@ const itemDescClassName = `
|
||||||
|
|
||||||
type IOperationProps = {
|
type IOperationProps = {
|
||||||
member: Member
|
member: Member
|
||||||
|
operatorRole: string
|
||||||
onOperate: () => void
|
onOperate: () => void
|
||||||
}
|
}
|
||||||
|
|
||||||
const Operation = ({
|
const Operation = ({
|
||||||
member,
|
member,
|
||||||
|
operatorRole,
|
||||||
onOperate,
|
onOperate,
|
||||||
}: IOperationProps) => {
|
}: IOperationProps) => {
|
||||||
const { t } = useTranslation()
|
const { t } = useTranslation()
|
||||||
|
@ -43,11 +45,20 @@ const Operation = ({
|
||||||
dataset_operator: t('common.members.datasetOperator'),
|
dataset_operator: t('common.members.datasetOperator'),
|
||||||
}
|
}
|
||||||
const roleList = useMemo(() => {
|
const roleList = useMemo(() => {
|
||||||
|
if (operatorRole === 'owner') {
|
||||||
return [
|
return [
|
||||||
...['admin', 'editor', 'normal'],
|
...['admin', 'editor', 'normal'],
|
||||||
...(datasetOperatorEnabled ? ['dataset_operator'] : []),
|
...(datasetOperatorEnabled ? ['dataset_operator'] : []),
|
||||||
]
|
]
|
||||||
}, [datasetOperatorEnabled])
|
}
|
||||||
|
if (operatorRole === 'admin') {
|
||||||
|
return [
|
||||||
|
...['editor', 'normal'],
|
||||||
|
...(datasetOperatorEnabled ? ['dataset_operator'] : []),
|
||||||
|
]
|
||||||
|
}
|
||||||
|
return []
|
||||||
|
}, [operatorRole, datasetOperatorEnabled])
|
||||||
const { notify } = useContext(ToastContext)
|
const { notify } = useContext(ToastContext)
|
||||||
const toHump = (name: string) => name.replace(/_(\w)/g, (all, letter) => letter.toUpperCase())
|
const toHump = (name: string) => name.replace(/_(\w)/g, (all, letter) => letter.toUpperCase())
|
||||||
const handleDeleteMemberOrCancelInvitation = async () => {
|
const handleDeleteMemberOrCancelInvitation = async () => {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user