mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-18 05:40:31 +00:00
feat(warehouse): add credit & edit & delete warehouse.
This commit is contained in:
@@ -33,3 +33,4 @@ export * from './roles';
|
||||
export * from './creditNote';
|
||||
export * from './vendorCredit';
|
||||
export * from './transactionsLocking';
|
||||
export * from './warehouses'
|
||||
|
||||
@@ -191,6 +191,11 @@ const TARNSACTIONS_LOCKING = {
|
||||
TRANSACTIONS_LOCKING: 'TRANSACTIONS_LOCKING',
|
||||
};
|
||||
|
||||
const WAREHOUSES = {
|
||||
WAREHOUSE: 'WAREHOUSE',
|
||||
WAREHOUSES: 'WAREHOUSES',
|
||||
};
|
||||
|
||||
export default {
|
||||
...ACCOUNTS,
|
||||
...BILLS,
|
||||
@@ -218,4 +223,5 @@ export default {
|
||||
...CREDIT_NOTES,
|
||||
...VENDOR_CREDIT_NOTES,
|
||||
...TARNSACTIONS_LOCKING,
|
||||
...WAREHOUSES
|
||||
};
|
||||
|
||||
99
src/hooks/query/warehouses.js
Normal file
99
src/hooks/query/warehouses.js
Normal file
@@ -0,0 +1,99 @@
|
||||
import { useQueryClient, useMutation } from 'react-query';
|
||||
import { useRequestQuery } from '../useQueryRequest';
|
||||
import useApiRequest from '../useRequest';
|
||||
import t from './types';
|
||||
|
||||
// Common invalidate queries.
|
||||
const commonInvalidateQueries = (queryClient) => {
|
||||
// Invalidate warehouses.
|
||||
queryClient.invalidateQueries(t.WAREHOUSES);
|
||||
queryClient.invalidateQueries(t.WAREHOUSE);
|
||||
};
|
||||
|
||||
/**
|
||||
* Create a new warehouse.
|
||||
*/
|
||||
export function useCreateWarehouse(props) {
|
||||
const queryClient = useQueryClient();
|
||||
const apiRequest = useApiRequest();
|
||||
|
||||
return useMutation((values) => apiRequest.post('warehouses', values), {
|
||||
onSuccess: (res, values) => {
|
||||
// Common invalidate queries.
|
||||
commonInvalidateQueries(queryClient);
|
||||
},
|
||||
...props,
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Edits the given warehouse.
|
||||
*/
|
||||
export function useEditWarehouse(props) {
|
||||
const queryClient = useQueryClient();
|
||||
const apiRequest = useApiRequest();
|
||||
|
||||
return useMutation(
|
||||
([id, values]) => apiRequest.post(`warehouses/${id}`, values),
|
||||
{
|
||||
onSuccess: (res, [id, values]) => {
|
||||
// Invalidate specific sale invoice.
|
||||
queryClient.invalidateQueries([t.WAREHOUSE, id]);
|
||||
|
||||
// Common invalidate queries.
|
||||
commonInvalidateQueries(queryClient);
|
||||
},
|
||||
...props,
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Deletes the given warehouse.
|
||||
*/
|
||||
export function useDeleteWarehouse(props) {
|
||||
const queryClient = useQueryClient();
|
||||
const apiRequest = useApiRequest();
|
||||
|
||||
return useMutation((id) => apiRequest.delete(`warehouses/${id}`), {
|
||||
onSuccess: (res, id) => {
|
||||
// Invalidate specific warehoue.
|
||||
queryClient.invalidateQueries([t.WAREHOUSE, id]);
|
||||
|
||||
// Common invalidate queries.
|
||||
commonInvalidateQueries(queryClient);
|
||||
},
|
||||
...props,
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve Warehoues list.
|
||||
*/
|
||||
export function useWarehouses(query, props) {
|
||||
return useRequestQuery(
|
||||
[t.WAREHOUSES, query],
|
||||
{ method: 'get', url: 'warehouses', params: query },
|
||||
{
|
||||
select: (res) => res.data.warehouses,
|
||||
defaultData: [],
|
||||
...props,
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve the warehouse details.
|
||||
* @param {number}
|
||||
*/
|
||||
export function useWarehouse(id, props, requestProps) {
|
||||
return useRequestQuery(
|
||||
[t.WAREHOUSE, id],
|
||||
{ method: 'get', url: `warehouses/${id}`, ...requestProps },
|
||||
{
|
||||
select: (res) => res.data.warehouse,
|
||||
defaultData: {},
|
||||
...props,
|
||||
},
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user