mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-20 23:00:34 +00:00
feat(warehousetransfer): add api.
This commit is contained in:
@@ -4,11 +4,11 @@ import { DATATYPES_LENGTH } from 'common/dataTypes';
|
|||||||
|
|
||||||
const Schema = Yup.object().shape({
|
const Schema = Yup.object().shape({
|
||||||
date: Yup.date().required().label(intl.get('date')),
|
date: Yup.date().required().label(intl.get('date')),
|
||||||
transfer_number: Yup.string()
|
transaction_number: Yup.string()
|
||||||
.max(DATATYPES_LENGTH.STRING)
|
.max(DATATYPES_LENGTH.STRING)
|
||||||
.label(intl.get('transfer_number')),
|
.label(intl.get('transaction_number')),
|
||||||
from_warehouse: Yup.number().required().label(intl.get('from_warehouse')),
|
from_warehouse_id: Yup.number().required().label(intl.get('from_warehouse')),
|
||||||
to_warehouse: Yup.number().required().label(intl.get('from_warehouse')),
|
to_warehouse_id: Yup.number().required().label(intl.get('from_warehouse')),
|
||||||
reason: Yup.string()
|
reason: Yup.string()
|
||||||
.trim()
|
.trim()
|
||||||
.min(1)
|
.min(1)
|
||||||
@@ -17,8 +17,9 @@ const Schema = Yup.object().shape({
|
|||||||
entries: Yup.array().of(
|
entries: Yup.array().of(
|
||||||
Yup.object().shape({
|
Yup.object().shape({
|
||||||
item_id: Yup.number().nullable(),
|
item_id: Yup.number().nullable(),
|
||||||
source_warehouse: Yup.number().nullable(),
|
// source_warehouse: Yup.number().nullable(),
|
||||||
destination_warehouse: Yup.number().nullable(),
|
// destination_warehouse: Yup.number().nullable(),
|
||||||
|
description: Yup.string().nullable().max(DATATYPES_LENGTH.TEXT),
|
||||||
quantity: Yup.number().nullable().max(DATATYPES_LENGTH.INT_10),
|
quantity: Yup.number().nullable().max(DATATYPES_LENGTH.INT_10),
|
||||||
}),
|
}),
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ function WarehouseTransferFormHeaderFields({
|
|||||||
warehouseTransferNextNumber,
|
warehouseTransferNextNumber,
|
||||||
warehouseTransferNumberPrefix,
|
warehouseTransferNumberPrefix,
|
||||||
}) {
|
}) {
|
||||||
const { accounts } = useWarehouseTransferFormContext();
|
const { warehouses } = useWarehouseTransferFormContext();
|
||||||
|
|
||||||
// Handle warehouse transfer number changing.
|
// Handle warehouse transfer number changing.
|
||||||
const handleTransferNumberChange = () => {
|
const handleTransferNumberChange = () => {
|
||||||
@@ -92,11 +92,11 @@ function WarehouseTransferFormHeaderFields({
|
|||||||
)}
|
)}
|
||||||
</FastField>
|
</FastField>
|
||||||
{/* ----------- Transfer number ----------- */}
|
{/* ----------- Transfer number ----------- */}
|
||||||
<Field name={'transfer_number'}>
|
<Field name={'transaction_number'}>
|
||||||
{({ form, field, meta: { error, touched } }) => (
|
{({ form, field, meta: { error, touched } }) => (
|
||||||
<FormGroup
|
<FormGroup
|
||||||
label={<T id={'warehouse_transfer.label.transfer_no'} />}
|
label={<T id={'warehouse_transfer.label.transfer_no'} />}
|
||||||
labelInfo={<FieldRequiredHint />}
|
// labelInfo={<FieldRequiredHint />}
|
||||||
inline={true}
|
inline={true}
|
||||||
className={classNames('form-group--transfer-no', CLASSES.FILL)}
|
className={classNames('form-group--transfer-no', CLASSES.FILL)}
|
||||||
intent={inputIntent({ error, touched })}
|
intent={inputIntent({ error, touched })}
|
||||||
@@ -131,7 +131,7 @@ function WarehouseTransferFormHeaderFields({
|
|||||||
)}
|
)}
|
||||||
</Field>
|
</Field>
|
||||||
{/* ----------- Form Warehouse ----------- */}
|
{/* ----------- Form Warehouse ----------- */}
|
||||||
<FastField name={'form_warehouse'} accounts={accounts}>
|
<FastField name={'from_warehouse_id'} accounts={warehouses}>
|
||||||
{({ form, field: { value }, meta: { error, touched } }) => (
|
{({ form, field: { value }, meta: { error, touched } }) => (
|
||||||
<FormGroup
|
<FormGroup
|
||||||
label={<T id={'warehouse_transfer.label.form_warehouse'} />}
|
label={<T id={'warehouse_transfer.label.form_warehouse'} />}
|
||||||
@@ -142,12 +142,12 @@ function WarehouseTransferFormHeaderFields({
|
|||||||
inline={true}
|
inline={true}
|
||||||
labelInfo={<FieldRequiredHint />}
|
labelInfo={<FieldRequiredHint />}
|
||||||
intent={inputIntent({ error, touched })}
|
intent={inputIntent({ error, touched })}
|
||||||
helperText={<ErrorMessage name={'form_warehouse'} />}
|
helperText={<ErrorMessage name={'from_warehouse_id'} />}
|
||||||
>
|
>
|
||||||
<AccountsSelectList
|
<AccountsSelectList
|
||||||
accounts={accounts}
|
accounts={warehouses}
|
||||||
onAccountSelected={(account) => {
|
onAccountSelected={(account) => {
|
||||||
form.setFieldValue('form_warehouse', account.id);
|
form.setFieldValue('from_warehouse_id', account.id);
|
||||||
}}
|
}}
|
||||||
defaultSelectText={'Select Warehouse Transfer'}
|
defaultSelectText={'Select Warehouse Transfer'}
|
||||||
selectedAccountId={value}
|
selectedAccountId={value}
|
||||||
@@ -158,7 +158,7 @@ function WarehouseTransferFormHeaderFields({
|
|||||||
)}
|
)}
|
||||||
</FastField>
|
</FastField>
|
||||||
{/* ----------- To Warehouse ----------- */}
|
{/* ----------- To Warehouse ----------- */}
|
||||||
<FastField name={'to_warehouse'} accounts={accounts}>
|
<FastField name={'to_warehouse_id'} accounts={warehouses}>
|
||||||
{({ form, field: { value }, meta: { error, touched } }) => (
|
{({ form, field: { value }, meta: { error, touched } }) => (
|
||||||
<FormGroup
|
<FormGroup
|
||||||
label={<T id={'warehouse_transfer.label.to_warehouse'} />}
|
label={<T id={'warehouse_transfer.label.to_warehouse'} />}
|
||||||
@@ -169,12 +169,12 @@ function WarehouseTransferFormHeaderFields({
|
|||||||
inline={true}
|
inline={true}
|
||||||
labelInfo={<FieldRequiredHint />}
|
labelInfo={<FieldRequiredHint />}
|
||||||
intent={inputIntent({ error, touched })}
|
intent={inputIntent({ error, touched })}
|
||||||
helperText={<ErrorMessage name={'to_warehouse'} />}
|
helperText={<ErrorMessage name={'to_warehouse_id'} />}
|
||||||
>
|
>
|
||||||
<AccountsSelectList
|
<AccountsSelectList
|
||||||
accounts={accounts}
|
accounts={warehouses}
|
||||||
onAccountSelected={(account) => {
|
onAccountSelected={(account) => {
|
||||||
form.setFieldValue('to_warehouse', account.id);
|
form.setFieldValue('to_warehouse_id', account.id);
|
||||||
}}
|
}}
|
||||||
defaultSelectText={'Select Warehouse Transfer'}
|
defaultSelectText={'Select Warehouse Transfer'}
|
||||||
selectedAccountId={value}
|
selectedAccountId={value}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import DashboardInsider from 'components/Dashboard/DashboardInsider';
|
import DashboardInsider from 'components/Dashboard/DashboardInsider';
|
||||||
import { useItems, useAccounts } from 'hooks/query';
|
import { useItems, useWarehouses } from 'hooks/query';
|
||||||
import { ITEMS_FILTER_ROLES_QUERY } from './utils.js';
|
import { ITEMS_FILTER_ROLES_QUERY } from './utils.js';
|
||||||
|
|
||||||
const WarehouseFormContext = React.createContext();
|
const WarehouseFormContext = React.createContext();
|
||||||
@@ -19,17 +19,23 @@ function WarehouseTransferFormProvider({ warehouseTransferId, ...props }) {
|
|||||||
stringified_filter_roles: ITEMS_FILTER_ROLES_QUERY,
|
stringified_filter_roles: ITEMS_FILTER_ROLES_QUERY,
|
||||||
});
|
});
|
||||||
|
|
||||||
// Fetch accounts list.
|
// Fetch warehouses list.
|
||||||
const { data: accounts, isLoading: isAccountsLoading } = useAccounts();
|
const {
|
||||||
|
data: warehouses,
|
||||||
|
isFetching: isWarehouesFetching,
|
||||||
|
isLoading: isWarehouesLoading,
|
||||||
|
} = useWarehouses();
|
||||||
|
|
||||||
// Provider payload.
|
// Provider payload.
|
||||||
const provider = {
|
const provider = {
|
||||||
items,
|
items,
|
||||||
accounts,
|
warehouses,
|
||||||
|
isItemsFetching,
|
||||||
|
isWarehouesFetching,
|
||||||
};
|
};
|
||||||
return (
|
return (
|
||||||
<DashboardInsider
|
<DashboardInsider
|
||||||
loading={isItemsLoading || isAccountsLoading}
|
loading={isItemsLoading || isWarehouesLoading}
|
||||||
name={'warehouseTransfer-form'}
|
name={'warehouseTransfer-form'}
|
||||||
>
|
>
|
||||||
<WarehouseFormContext.Provider value={provider} {...props} />
|
<WarehouseFormContext.Provider value={provider} {...props} />
|
||||||
|
|||||||
@@ -18,28 +18,15 @@ export const MIN_LINES_NUMBER = 4;
|
|||||||
|
|
||||||
export const defaultWarehouseTransfer = {
|
export const defaultWarehouseTransfer = {
|
||||||
date: moment(new Date()).format('YYYY-MM-DD'),
|
date: moment(new Date()).format('YYYY-MM-DD'),
|
||||||
transfer_number: '',
|
transaction_number: '',
|
||||||
from_warehouse: '',
|
from_warehouse_id: '',
|
||||||
to_warehouse: '',
|
to_warehouse_id: '',
|
||||||
reason: '',
|
reason: '',
|
||||||
entries: [...repeatValue(defaultWareTransferEntry, MIN_LINES_NUMBER)],
|
entries: [...repeatValue(defaultWareTransferEntry, MIN_LINES_NUMBER)],
|
||||||
};
|
};
|
||||||
|
|
||||||
export const ITEMS_FILTER_ROLES_QUERY = JSON.stringify([
|
export const ITEMS_FILTER_ROLES_QUERY = JSON.stringify([
|
||||||
{
|
{ fieldKey: 'type', comparator: 'is', value: 'inventory', index: 1 },
|
||||||
index: 1,
|
|
||||||
fieldKey: 'sellable',
|
|
||||||
value: true,
|
|
||||||
condition: '&&',
|
|
||||||
comparator: 'equals',
|
|
||||||
},
|
|
||||||
{
|
|
||||||
index: 2,
|
|
||||||
fieldKey: 'active',
|
|
||||||
value: true,
|
|
||||||
condition: '&&',
|
|
||||||
comparator: 'equals',
|
|
||||||
},
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -50,6 +37,6 @@ export const useObserveTransferNoSettings = (prefix, nextNumber) => {
|
|||||||
|
|
||||||
React.useEffect(() => {
|
React.useEffect(() => {
|
||||||
const transferNo = transactionNumber(prefix, nextNumber);
|
const transferNo = transactionNumber(prefix, nextNumber);
|
||||||
setFieldValue('transfer_no', transferNo);
|
setFieldValue('transaction_number', transferNo);
|
||||||
}, [setFieldValue, prefix, nextNumber]);
|
}, [setFieldValue, prefix, nextNumber]);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -8,6 +8,10 @@ const commonInvalidateQueries = (queryClient) => {
|
|||||||
// Invalidate warehouses.
|
// Invalidate warehouses.
|
||||||
queryClient.invalidateQueries(t.WAREHOUSES);
|
queryClient.invalidateQueries(t.WAREHOUSES);
|
||||||
queryClient.invalidateQueries(t.WAREHOUSE);
|
queryClient.invalidateQueries(t.WAREHOUSE);
|
||||||
|
|
||||||
|
// Invalidate warehouses transfers.
|
||||||
|
queryClient.invalidateQueries(t.WAREHOUSE_TRANSFERS);
|
||||||
|
queryClient.invalidateQueries(t.WAREHOUSE_TRANSFER);
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -97,3 +101,94 @@ export function useWarehouse(id, props, requestProps) {
|
|||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new warehouse transfer.
|
||||||
|
*/
|
||||||
|
export function useCreateWarehouseTransfer(props) {
|
||||||
|
const queryClient = useQueryClient();
|
||||||
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
|
return useMutation(
|
||||||
|
(values) => apiRequest.post('warehouses/transfers', values),
|
||||||
|
{
|
||||||
|
onSuccess: (res, values) => {
|
||||||
|
// Common invalidate queries.
|
||||||
|
commonInvalidateQueries(queryClient);
|
||||||
|
},
|
||||||
|
...props,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Edits the given warehouse transfer.
|
||||||
|
*/
|
||||||
|
export function useEditWarehouseTransfer(props) {
|
||||||
|
const queryClient = useQueryClient();
|
||||||
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
|
return useMutation(
|
||||||
|
([id, values]) => apiRequest.post(`warehouses/transfers${id}`, values),
|
||||||
|
{
|
||||||
|
onSuccess: (res, [id, values]) => {
|
||||||
|
// Invalidate specific sale invoice.
|
||||||
|
queryClient.invalidateQueries([t.WAREHOUSE_TRANSFER, id]);
|
||||||
|
|
||||||
|
// Common invalidate queries.
|
||||||
|
commonInvalidateQueries(queryClient);
|
||||||
|
},
|
||||||
|
...props,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Deletes the given warehouse Transfer.
|
||||||
|
*/
|
||||||
|
export function useDeleteWarehouseTransfer(props) {
|
||||||
|
const queryClient = useQueryClient();
|
||||||
|
const apiRequest = useApiRequest();
|
||||||
|
|
||||||
|
return useMutation((id) => apiRequest.delete(`warehouses/transfers/${id}`), {
|
||||||
|
onSuccess: (res, id) => {
|
||||||
|
// Invalidate specific warehoue.
|
||||||
|
queryClient.invalidateQueries([t.WAREHOUSE_TRANSFER, id]);
|
||||||
|
|
||||||
|
// Common invalidate queries.
|
||||||
|
commonInvalidateQueries(queryClient);
|
||||||
|
},
|
||||||
|
...props,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve Warehoues list.
|
||||||
|
*/
|
||||||
|
export function useWarehousesTransfers(query, props) {
|
||||||
|
return useRequestQuery(
|
||||||
|
[t.WAREHOUSE_TRANSFERS, query],
|
||||||
|
{ method: 'get', url: 'warehouses/transfers', params: query },
|
||||||
|
{
|
||||||
|
select: (res) => res.data,
|
||||||
|
defaultData: [],
|
||||||
|
...props,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Retrieve the warehouse transfer details.
|
||||||
|
* @param {number}
|
||||||
|
*/
|
||||||
|
export function useWarehouseTransfer(id, props, requestProps) {
|
||||||
|
return useRequestQuery(
|
||||||
|
[t.WAREHOUSE_TRANSFER, id],
|
||||||
|
{ method: 'get', url: `warehouses/transfers/${id}`, ...requestProps },
|
||||||
|
{
|
||||||
|
select: (res) => res.data,
|
||||||
|
defaultData: {},
|
||||||
|
...props,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user