mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-16 12:50:38 +00:00
110 lines
2.6 KiB
JavaScript
110 lines
2.6 KiB
JavaScript
import { useMutation, useQueryClient } from 'react-query';
|
|
import { useRequestQuery } from '../useQueryRequest';
|
|
import useApiRequest from '../useRequest';
|
|
import t from './types';
|
|
|
|
const commonInvalidateQueries = (queryClient) => {
|
|
// Invalidate items categories.
|
|
queryClient.invalidateQueries(t.ITEMS_CATEGORIES);
|
|
|
|
// Invalidate items.
|
|
queryClient.invalidateQueries(t.ITEMS);
|
|
};
|
|
|
|
/**
|
|
* Creates a new item category.
|
|
*/
|
|
export function useCreateItemCategory(props) {
|
|
const queryClient = useQueryClient();
|
|
const apiRequest = useApiRequest();
|
|
|
|
return useMutation((values) => apiRequest.post('item_categories', values), {
|
|
onSuccess: () => {
|
|
// Common invalidate queries.
|
|
commonInvalidateQueries(queryClient);
|
|
},
|
|
...props,
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Edits the item category.
|
|
*/
|
|
export function useEditItemCategory(props) {
|
|
const queryClient = useQueryClient();
|
|
const apiRequest = useApiRequest();
|
|
|
|
return useMutation(
|
|
([id, values]) => apiRequest.post(`item_categories/${id}`, values),
|
|
{
|
|
onSuccess: (res, [id, values]) => {
|
|
// Invalidate specific item category.
|
|
queryClient.invalidateQueries([t.ITEM_CATEGORY, id]);
|
|
|
|
// Common invalidate queries.
|
|
commonInvalidateQueries(queryClient);
|
|
},
|
|
...props,
|
|
},
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Deletes the given item category.
|
|
*/
|
|
export function useDeleteItemCategory(props) {
|
|
const queryClient = useQueryClient();
|
|
const apiRequest = useApiRequest();
|
|
|
|
return useMutation((id) => apiRequest.delete(`item_categories/${id}`), {
|
|
onSuccess: (res, id) => {
|
|
// Invalidate specific item category.
|
|
queryClient.invalidateQueries([t.ITEM_CATEGORY, id]);
|
|
|
|
// Common invalidate queries.
|
|
commonInvalidateQueries(queryClient);
|
|
},
|
|
...props,
|
|
});
|
|
}
|
|
|
|
|
|
const transformCategories = (res) => ({
|
|
itemsCategories: res.data.item_categories,
|
|
pagination: res.data.pagination,
|
|
});
|
|
|
|
/**
|
|
* Retrieve the items categories.
|
|
*/
|
|
export function useItemsCategories(query, props) {
|
|
return useRequestQuery(
|
|
[t.ITEMS_CATEGORIES, query],
|
|
{ method: 'get', url: `item_categories`, params: query },
|
|
{
|
|
select: transformCategories,
|
|
defaultData: {
|
|
itemsCategories: [],
|
|
pagination: {}
|
|
},
|
|
...props,
|
|
},
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Retrieve the item category details.
|
|
* @param {number} id - Item category.
|
|
*/
|
|
export function useItemCategory(id, props) {
|
|
return useRequestQuery(
|
|
[t.ITEM_CATEGORY, id],
|
|
{ method: 'get', url: `item_categories/${id}` },
|
|
{
|
|
select: (res) => res.data.category,
|
|
defaultData: {},
|
|
...props,
|
|
},
|
|
);
|
|
}
|