feat(webapp): wip tax rates management

This commit is contained in:
Ahmed Bouhuolia
2023-09-14 23:35:54 +02:00
parent b98b73ad98
commit 8a64198433
34 changed files with 1205 additions and 14 deletions

View File

@@ -1,6 +1,8 @@
// @ts-nocheck
import { useMutation, useQueryClient } from 'react-query';
import { useRequestQuery } from '../useQueryRequest';
import QUERY_TYPES from './types';
import useApiRequest from '../useRequest';
/**
* Retrieves tax rates.
@@ -20,3 +22,75 @@ export function useTaxRates(props) {
},
);
}
/**
* Retrieves tax rate.
* @param {number} taxRateId - Tax rate id.
*/
export function useTaxRate(taxRateId: string, props) {
return useRequestQuery(
[QUERY_TYPES.TAX_RATES, taxRateId],
{
method: 'get',
url: `tax-rates/${taxRateId}}`,
},
{
select: (res) => res.data.data,
...props,
},
);
}
/**
* Edit the given tax rate.
*/
export function useEditTaxRate(props) {
const queryClient = useQueryClient();
const apiRequest = useApiRequest();
return useMutation(
([id, values]) => apiRequest.post(`tax-rates/${id}`, values),
{
onSuccess: (res, id) => {
// Invalidate specific item.
queryClient.invalidateQueries([QUERY_TYPES.TAX_RATES, id]);
queryClient.invalidateQueries([QUERY_TYPES.TAX_RATES]);
},
...props,
},
);
}
/**
* Creates a new tax rate.
*/
export function useCreateTaxRate(props) {
const queryClient = useQueryClient();
const apiRequest = useApiRequest();
return useMutation(([values]) => apiRequest.post('tax-rates', values), {
onSuccess: (res, id) => {
// Invalidate specific item.
queryClient.invalidateQueries([QUERY_TYPES.TAX_RATES, id]);
queryClient.invalidateQueries([QUERY_TYPES.TAX_RATES]);
},
...props,
});
}
/**
* Deletes a new tax rate.
*/
export function useDeleteTaxRate(props) {
const queryClient = useQueryClient();
const apiRequest = useApiRequest();
return useMutation(([id]) => apiRequest.delete(`tax-rates/${id}`), {
onSuccess: (res, id) => {
// Invalidate specific item.
queryClient.invalidateQueries([QUERY_TYPES.TAX_RATES, id]);
queryClient.invalidateQueries([QUERY_TYPES.TAX_RATES]);
},
...props,
});
}