import { SaveIcon } from '@heroicons/react/outline'; import axios from 'axios'; import { Form, Formik } from 'formik'; import { useRouter } from 'next/router'; import React from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { useToasts } from 'react-toast-notifications'; import useSWR from 'swr'; import { useUser } from '../../../../hooks/useUser'; import globalMessages from '../../../../i18n/globalMessages'; import Error from '../../../../pages/_error'; import Alert from '../../../Common/Alert'; import Button from '../../../Common/Button'; import LoadingSpinner from '../../../Common/LoadingSpinner'; import PageTitle from '../../../Common/PageTitle'; import PermissionEdit from '../../../PermissionEdit'; const messages = defineMessages({ toastSettingsSuccess: 'Permissions saved successfully!', toastSettingsFailure: 'Something went wrong while saving settings.', permissions: 'Permissions', unauthorizedDescription: 'You cannot modify your own permissions.', }); const UserPermissions: React.FC = () => { const intl = useIntl(); const { addToast } = useToasts(); const router = useRouter(); const { user: currentUser } = useUser(); const { user, revalidate: revalidateUser } = useUser({ id: Number(router.query.userId), }); const { data, error, mutate: revalidate, } = useSWR<{ permissions?: number }>( user ? `/api/v1/user/${user?.id}/settings/permissions` : null ); if (!data && !error) { return ; } if (!data) { return ; } if (currentUser?.id !== 1 && currentUser?.id === user?.id) { return ( <>

{intl.formatMessage(messages.permissions)}

); } return ( <>

{intl.formatMessage(messages.permissions)}

{ try { await axios.post(`/api/v1/user/${user?.id}/settings/permissions`, { permissions: values.currentPermissions ?? 0, }); addToast(intl.formatMessage(messages.toastSettingsSuccess), { autoDismiss: true, appearance: 'success', }); } catch (e) { addToast(intl.formatMessage(messages.toastSettingsFailure), { autoDismiss: true, appearance: 'error', }); } finally { revalidate(); revalidateUser(); } }} > {({ isSubmitting, setFieldValue, values }) => { return (
setFieldValue('currentPermissions', newPermission) } />
); }}
); }; export default UserPermissions;