import {useMutation} from '@tanstack/react-query'; import {apiClient, queryClient} from '../../../http/query-client'; import {BackendResponse} from '../../../http/backend-response/backend-response'; import {toast} from '../../../ui/toast/toast'; import {Role} from '../../../auth/role'; import {useTrans} from '../../../i18n/use-trans'; import {message} from '../../../i18n/message'; import {DatatableDataQueryKey} from '../../../datatable/requests/paginated-resources'; import {onFormQueryError} from '../../../errors/on-form-query-error'; import {UseFormReturn} from 'react-hook-form'; interface Response extends BackendResponse { role: Role; } export interface CreateRolePayload extends Partial {} const Endpoint = 'roles'; export function useCreateRole(form: UseFormReturn) { const {trans} = useTrans(); return useMutation({ mutationFn: (payload: CreateRolePayload) => createRole(payload), onSuccess: () => { toast(trans(message('Created new role'))); queryClient.invalidateQueries({queryKey: DatatableDataQueryKey('roles')}); }, onError: r => onFormQueryError(r, form), }); } function createRole({id, ...payload}: CreateRolePayload): Promise { return apiClient.post(Endpoint, payload).then(r => r.data); }