mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-03 00:15:11 +03:00
Wired user invite actions on adminX
refs https://github.com/TryGhost/Team/issues/3351 - wires resend and revoke actions for a user invite in staff settings
This commit is contained in:
parent
c88a073a5c
commit
c243b48629
@ -5,14 +5,16 @@ import List from '../../../admin-x-ds/global/List';
|
||||
import ListItem from '../../../admin-x-ds/global/ListItem';
|
||||
import NiceModal from '@ebay/nice-modal-react';
|
||||
import NoValueLabel from '../../../admin-x-ds/global/NoValueLabel';
|
||||
import React from 'react';
|
||||
import React, {useContext, useState} from 'react';
|
||||
import SettingGroup from '../../../admin-x-ds/settings/SettingGroup';
|
||||
import TabView from '../../../admin-x-ds/global/TabView';
|
||||
import UserDetailModal from './modals/UserDetailModal';
|
||||
import useStaffUsers from '../../../hooks/useStaffUsers';
|
||||
import {ServicesContext} from '../../providers/ServiceProvider';
|
||||
import {User} from '../../../types/api';
|
||||
import {UserInvite} from '../../../utils/api';
|
||||
import {generateAvatarColor, getInitials} from '../../../utils/helpers';
|
||||
import {showToast} from '../../../admin-x-ds/global/Toast';
|
||||
|
||||
interface OwnerProps {
|
||||
user: User;
|
||||
@ -81,6 +83,57 @@ const UsersList: React.FC<UsersListProps> = ({users, updateUser}) => {
|
||||
);
|
||||
};
|
||||
|
||||
const UserInviteActions: React.FC<{invite: UserInvite}> = ({invite}) => {
|
||||
const {api} = useContext(ServicesContext);
|
||||
const [revokeState, setRevokeState] = useState<'progress'|''>('');
|
||||
const [resendState, setResendState] = useState<'progress'|''>('');
|
||||
let revokeActionLabel = 'Revoke';
|
||||
if (revokeState === 'progress') {
|
||||
revokeActionLabel = 'Revoking...';
|
||||
}
|
||||
let resendActionLabel = 'Resend';
|
||||
if (resendState === 'progress') {
|
||||
resendActionLabel = 'Resending...';
|
||||
}
|
||||
return (
|
||||
<div className='flex gap-2'>
|
||||
<Button
|
||||
color='red'
|
||||
label={revokeActionLabel}
|
||||
link={true}
|
||||
onClick={async () => {
|
||||
setRevokeState('progress');
|
||||
await api.invites.delete(invite.id);
|
||||
setRevokeState('');
|
||||
showToast({
|
||||
message: `Invitation revoked(${invite.email})`,
|
||||
type: 'success'
|
||||
});
|
||||
}}
|
||||
/>
|
||||
<Button
|
||||
className='ml-2'
|
||||
color='green'
|
||||
label={resendActionLabel}
|
||||
link={true}
|
||||
onClick={async () => {
|
||||
setResendState('progress');
|
||||
await api.invites.delete(invite.id);
|
||||
await api.invites.add({
|
||||
email: invite.email,
|
||||
roleId: invite.role_id
|
||||
});
|
||||
setResendState('');
|
||||
showToast({
|
||||
message: `Invitation resent!(${invite.email})`,
|
||||
type: 'success'
|
||||
});
|
||||
}}
|
||||
/>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
const InvitesUserList: React.FC<InviteListProps> = ({users}) => {
|
||||
if (!users || !users.length) {
|
||||
return (
|
||||
@ -90,24 +143,13 @@ const InvitesUserList: React.FC<InviteListProps> = ({users}) => {
|
||||
);
|
||||
}
|
||||
|
||||
const actions = (
|
||||
<div className='flex gap-2'>
|
||||
<Button color='red' label='Revoke' link={true} onClick={() => {
|
||||
// Revoke invite
|
||||
}}/>
|
||||
<Button className='ml-2' color='green' label='Resend' link={true} onClick={() => {
|
||||
// Resend invite
|
||||
}}/>
|
||||
</div>
|
||||
);
|
||||
|
||||
return (
|
||||
<List>
|
||||
{users.map((user) => {
|
||||
return (
|
||||
<ListItem
|
||||
key={user.id}
|
||||
action={actions}
|
||||
action={<UserInviteActions invite={user} />}
|
||||
avatar={(<Avatar bgColor={generateAvatarColor((user.email))} image={''} label={''} labelColor='white' />)}
|
||||
detail={user.role}
|
||||
hideActions={true}
|
||||
|
@ -118,6 +118,7 @@ interface API {
|
||||
status?: string;
|
||||
token?: string;
|
||||
}) => Promise<InvitesResponseType>;
|
||||
delete: (inviteId: string) => Promise<void>;
|
||||
}
|
||||
}
|
||||
|
||||
@ -292,6 +293,12 @@ function setupGhostApi({ghostVersion}: GhostApiOptions): API {
|
||||
});
|
||||
const data: InvitesResponseType = await response.json();
|
||||
return data;
|
||||
},
|
||||
delete: async (inviteId: string) => {
|
||||
await fetcher(`/invites/${inviteId}/`, {
|
||||
method: 'DELETE'
|
||||
});
|
||||
return;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user