Files
bigcapital/client/src/hooks/query/items.js
a.bouhuolia 6e10ed0721 refactoring: inventory adjustments list.
refactoring: items categories list.
2021-02-09 13:56:37 +02:00

132 lines
2.9 KiB
JavaScript

import { useMutation, useQuery, useQueryClient } from 'react-query';
import { defaultTo } from 'lodash';
import ApiService from 'services/ApiService';
import { transformPagination, transformResponse } from 'utils';
const defaultPagination = {
pageSize: 12,
page: 0,
pagesCount: 0,
};
/**
* Creates a new item.
*/
export function useCreateItem(props) {
const queryClient = useQueryClient();
return useMutation((values) => ApiService.post('items', values), {
onSuccess: () => {
queryClient.invalidateQueries('ITEMS');
queryClient.invalidateQueries('ITEMS_CATEGORIES');
},
...props,
});
}
/**
* Edits the given item.
*/
export function useEditItem(props) {
const queryClient = useQueryClient();
return useMutation(([id, values]) => ApiService.post(`items/${id}`, values), {
onSuccess: () => {
queryClient.invalidateQueries('ITEMS');
queryClient.invalidateQueries('ITEM');
queryClient.invalidateQueries('ITEMS_CATEGORIES');
},
...props,
});
}
/**
* Deletes the given item.
*/
export function useDeleteItem(props) {
const queryClient = useQueryClient();
return useMutation((id) => ApiService.delete(`items/${id}`), {
onSuccess: () => {
queryClient.invalidateQueries('ITEMS');
queryClient.invalidateQueries('ITEM');
queryClient.invalidateQueries('ITEMS_CATEGORIES');
},
...props,
});
}
// Transformes items response.
const transformItemsResponse = (response) => {
return {
items: response.data.items,
pagination: transformPagination(
transformResponse(response.data.pagination)
),
filterMeta: transformResponse(response.data.filter_meta),
};
};
/**
* Retrieves items list.
*/
export function useItems(query, props) {
const result = useQuery(
['ITEMS', query],
() =>
ApiService.get(`items`, { params: query }).then(transformItemsResponse),
props,
);
return {
...result,
data: defaultTo(result.data, {
items: [],
pagination: defaultPagination,
filterMeta: {},
}),
};
}
/**
* Retrieve details of the given item.
* @param {number} id - Item id.
*/
export function useItem(id, props) {
return useQuery(
['ITEM', id],
() => ApiService.get(`items/${id}`).then((response) => response.data.item),
props,
);
}
/**
* Activate the given item.
*/
export function useActivateItem(props) {
const queryClient = useQueryClient();
return useMutation((id) => ApiService.post(`items/${id}/activate`), {
onSuccess: () => {
queryClient.invalidateQueries('ITEMS');
queryClient.invalidateQueries('ITEM');
},
...props,
});
}
/**
* Inactivate the given item.
*/
export function useInactivateItem(props) {
const queryClient = useQueryClient();
return useMutation((id) => ApiService.post(`items/${id}/inactivate`), {
onSuccess: () => {
queryClient.invalidateQueries('ITEMS');
queryClient.invalidateQueries('ITEM');
},
...props,
});
}