Files
bigcapital/client/src/hooks/query/paymentReceives.js
2021-02-20 15:33:20 +02:00

164 lines
3.8 KiB
JavaScript

import { useMutation, useQuery, useQueryClient } from 'react-query';
import { defaultTo } from 'lodash';
import useApiRequest from '../useRequest';
import { transformPagination, saveInvoke } from 'utils';
/**
* Retrieve accounts list.
*/
export function usePaymentReceives(query, props) {
const apiRequest = useApiRequest();
const states = useQuery(
['PAYMENT_RECEIVES', query],
() => apiRequest.get('sales/payment_receives', { params: query }),
{
select: (res) => ({
paymentReceives: res.data.payment_receives,
pagination: transformPagination(res.data.pagination),
filterMeta: res.data.filter_meta,
}),
...props,
},
);
return {
...states,
data: defaultTo(states.data, {
paymentReceives: [],
pagination: {
page: 1,
pageSize: 12,
total: 0,
},
filterMeta: {},
}),
}
}
/**
* Creates payment receive.
*/
export function useCreatePaymentReceive(props) {
const client = useQueryClient();
const apiRequest = useApiRequest();
return useMutation(
(values) => apiRequest.post('sales/payment_receives', values),
{
onSuccess: (data, values) => {
client.invalidateQueries('PAYMENT_RECEIVES');
client.invalidateQueries('SALE_INVOICE_DUE');
client.invalidateQueries('SALE_INVOICES');
client.invalidateQueries('SALE_INVOICE');
saveInvoke(props?.onSuccess, data);
},
...props,
},
);
}
/**
* Edits payment receive.
*/
export function useEditPaymentReceive(props) {
const client = useQueryClient();
const apiRequest = useApiRequest();
return useMutation(
([id, values]) => apiRequest.post(`sales/payment_receives/${id}`, values),
{
onSuccess: (data) => {
client.invalidateQueries('PAYMENT_RECEIVES');
client.invalidateQueries('SALE_INVOICE_DUE');
client.invalidateQueries('SALE_INVOICES');
client.invalidateQueries('SALE_INVOICE');
saveInvoke(props?.onSuccess, data);
},
...props,
},
);
}
/**
* Deletes payment receive.
*/
export function useDeletePaymentReceive(props) {
const client = useQueryClient();
const apiRequest = useApiRequest();
return useMutation(
(id) => apiRequest.delete(`sales/payment_receives/${id}`),
{
onSuccess: (data, [id]) => {
client.invalidateQueries('PAYMENT_RECEIVES');
client.invalidateQueries('SALE_INVOICE_DUE');
client.invalidateQueries('SALE_INVOICES');
client.invalidateQueries('SALE_INVOICE');
saveInvoke(props?.onSuccess, data);
},
...props,
},
);
}
/**
* Retrieve specific payment receive.
* @param {number} id - Payment receive.
*/
export function usePaymentReceive(id, props) {
const apiRequest = useApiRequest();
const states = useQuery(
['PAYMENT_RECEIVE', id],
() => apiRequest.get(`sales/payment_receives/${id}`),
{
select: (res) => ({
paymentReceive: res.data.payment_receive,
receivableEntries: res.data.receivable_entries,
}),
...props
},
);
return {
...states,
data: defaultTo(states.data, {
paymentReceive: {},
receivableInvoices: {},
paymentInvoices: {}
}),
}
}
/**
* Retrieve information of payment receive in edit page.
* @param {number} id - Payment receive id.
*/
export function usePaymentReceiveEditPage(id, props) {
const apiRequest = useApiRequest();
const states = useQuery(
['PAYMENT_RECEIVE_EDIT_PAGE', id],
() => apiRequest.get(`sales/payment_receives/${id}/edit-page`),
{
select: (res) => ({
paymentReceive: res.data.payment_receive,
entries: res.data.entries,
}),
...props,
},
);
return {
...states,
data: defaultTo(states.data, {
paymentReceive: {},
entries: [],
})
}
}