File manager - Edit - /var/www/payraty/helpdesk/common/resources/client/admin/translations/create-localization.ts
Back
import {useMutation, useQueryClient} from '@tanstack/react-query'; import {UseFormReturn} from 'react-hook-form'; import {toast} from '../../ui/toast/toast'; import {BackendResponse} from '../../http/backend-response/backend-response'; import {apiClient} from '../../http/query-client'; import {message} from '../../i18n/message'; import {DatatableDataQueryKey} from '../../datatable/requests/paginated-resources'; import {onFormQueryError} from '../../errors/on-form-query-error'; import {Localization} from '../../i18n/localization'; interface Response extends BackendResponse { localization: Localization; } export interface CreateLocalizationPayload { name: string; language: string; } function createLocalization( payload: CreateLocalizationPayload, ): Promise<Response> { return apiClient.post(`localizations`, payload).then(r => r.data); } export function useCreateLocalization( form: UseFormReturn<CreateLocalizationPayload>, ) { const queryClient = useQueryClient(); return useMutation({ mutationFn: (props: CreateLocalizationPayload) => createLocalization(props), onSuccess: () => { toast(message('Localization created')); queryClient.invalidateQueries({ queryKey: DatatableDataQueryKey('localizations'), }); }, onError: r => onFormQueryError(r, form), }); }
| ver. 1.4 |
Github
|
.
| PHP 8.3.30 | Generation time: 0 |
proxy
|
phpinfo
|
Settings