import React, { useCallback } from 'react'
import {
BooleanInput,
Create,
email,
FormDataConsumer,
PasswordInput,
required,
SimpleForm,
TextInput,
useMutation,
useNotify,
useRedirect,
useTranslate,
} from 'react-admin'
import { Typography } from '@material-ui/core'
import { Title } from '../common'
import { LibrarySelectionField } from './LibrarySelectionField.jsx'
const UserCreate = (props) => {
const translate = useTranslate()
const [mutate] = useMutation()
const notify = useNotify()
const redirect = useRedirect()
const resourceName = translate('resources.user.name', { smart_count: 1 })
const title = translate('ra.page.create', {
name: `${resourceName}`,
})
const save = useCallback(
async (values) => {
try {
await mutate(
{
type: 'create',
resource: 'user',
payload: { data: values },
},
{ returnPromise: true },
)
notify('resources.user.notifications.created', 'info', {
smart_count: 1,
})
redirect('/user')
} catch (error) {
if (error.body.errors) {
return error.body.errors
}
}
},
[mutate, notify, redirect],
)
// Custom validation function
const validateUserForm = (values) => {
const errors = {}
// Library selection is optional for non-admin users since they will be auto-assigned to default libraries
// No validation required for library selection
return errors
}
return (
} {...props}>
{/* Conditional Library Selection */}
{({ formData }) => (
<>
{!formData.isAdmin && }
{formData.isAdmin && (
{translate('resources.user.message.adminAutoLibraries')}
)}
>
)}
)
}
export default UserCreate