feat(warehousetransfer): add api.

This commit is contained in:
elforjani13
2022-02-02 00:46:02 +02:00
committed by a.bouhuolia
parent de2a71433b
commit 9089e3d120
5 changed files with 129 additions and 40 deletions

View File

@@ -4,11 +4,11 @@ import { DATATYPES_LENGTH } from 'common/dataTypes';
const Schema = Yup.object().shape({
date: Yup.date().required().label(intl.get('date')),
transfer_number: Yup.string()
transaction_number: Yup.string()
.max(DATATYPES_LENGTH.STRING)
.label(intl.get('transfer_number')),
from_warehouse: Yup.number().required().label(intl.get('from_warehouse')),
to_warehouse: Yup.number().required().label(intl.get('from_warehouse')),
.label(intl.get('transaction_number')),
from_warehouse_id: Yup.number().required().label(intl.get('from_warehouse')),
to_warehouse_id: Yup.number().required().label(intl.get('from_warehouse')),
reason: Yup.string()
.trim()
.min(1)
@@ -17,8 +17,9 @@ const Schema = Yup.object().shape({
entries: Yup.array().of(
Yup.object().shape({
item_id: Yup.number().nullable(),
source_warehouse: Yup.number().nullable(),
destination_warehouse: Yup.number().nullable(),
// source_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),
}),
),

View File

@@ -37,7 +37,7 @@ function WarehouseTransferFormHeaderFields({
warehouseTransferNextNumber,
warehouseTransferNumberPrefix,
}) {
const { accounts } = useWarehouseTransferFormContext();
const { warehouses } = useWarehouseTransferFormContext();
// Handle warehouse transfer number changing.
const handleTransferNumberChange = () => {
@@ -92,11 +92,11 @@ function WarehouseTransferFormHeaderFields({
)}
</FastField>
{/* ----------- Transfer number ----------- */}
<Field name={'transfer_number'}>
<Field name={'transaction_number'}>
{({ form, field, meta: { error, touched } }) => (
<FormGroup
label={<T id={'warehouse_transfer.label.transfer_no'} />}
labelInfo={<FieldRequiredHint />}
// labelInfo={<FieldRequiredHint />}
inline={true}
className={classNames('form-group--transfer-no', CLASSES.FILL)}
intent={inputIntent({ error, touched })}
@@ -131,7 +131,7 @@ function WarehouseTransferFormHeaderFields({
)}
</Field>
{/* ----------- Form Warehouse ----------- */}
<FastField name={'form_warehouse'} accounts={accounts}>
<FastField name={'from_warehouse_id'} accounts={warehouses}>
{({ form, field: { value }, meta: { error, touched } }) => (
<FormGroup
label={<T id={'warehouse_transfer.label.form_warehouse'} />}
@@ -142,12 +142,12 @@ function WarehouseTransferFormHeaderFields({
inline={true}
labelInfo={<FieldRequiredHint />}
intent={inputIntent({ error, touched })}
helperText={<ErrorMessage name={'form_warehouse'} />}
helperText={<ErrorMessage name={'from_warehouse_id'} />}
>
<AccountsSelectList
accounts={accounts}
accounts={warehouses}
onAccountSelected={(account) => {
form.setFieldValue('form_warehouse', account.id);
form.setFieldValue('from_warehouse_id', account.id);
}}
defaultSelectText={'Select Warehouse Transfer'}
selectedAccountId={value}
@@ -158,7 +158,7 @@ function WarehouseTransferFormHeaderFields({
)}
</FastField>
{/* ----------- To Warehouse ----------- */}
<FastField name={'to_warehouse'} accounts={accounts}>
<FastField name={'to_warehouse_id'} accounts={warehouses}>
{({ form, field: { value }, meta: { error, touched } }) => (
<FormGroup
label={<T id={'warehouse_transfer.label.to_warehouse'} />}
@@ -169,12 +169,12 @@ function WarehouseTransferFormHeaderFields({
inline={true}
labelInfo={<FieldRequiredHint />}
intent={inputIntent({ error, touched })}
helperText={<ErrorMessage name={'to_warehouse'} />}
helperText={<ErrorMessage name={'to_warehouse_id'} />}
>
<AccountsSelectList
accounts={accounts}
accounts={warehouses}
onAccountSelected={(account) => {
form.setFieldValue('to_warehouse', account.id);
form.setFieldValue('to_warehouse_id', account.id);
}}
defaultSelectText={'Select Warehouse Transfer'}
selectedAccountId={value}

View File

@@ -1,6 +1,6 @@
import React from 'react';
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';
const WarehouseFormContext = React.createContext();
@@ -19,17 +19,23 @@ function WarehouseTransferFormProvider({ warehouseTransferId, ...props }) {
stringified_filter_roles: ITEMS_FILTER_ROLES_QUERY,
});
// Fetch accounts list.
const { data: accounts, isLoading: isAccountsLoading } = useAccounts();
// Fetch warehouses list.
const {
data: warehouses,
isFetching: isWarehouesFetching,
isLoading: isWarehouesLoading,
} = useWarehouses();
// Provider payload.
const provider = {
items,
accounts,
warehouses,
isItemsFetching,
isWarehouesFetching,
};
return (
<DashboardInsider
loading={isItemsLoading || isAccountsLoading}
loading={isItemsLoading || isWarehouesLoading}
name={'warehouseTransfer-form'}
>
<WarehouseFormContext.Provider value={provider} {...props} />

View File

@@ -18,28 +18,15 @@ export const MIN_LINES_NUMBER = 4;
export const defaultWarehouseTransfer = {
date: moment(new Date()).format('YYYY-MM-DD'),
transfer_number: '',
from_warehouse: '',
to_warehouse: '',
transaction_number: '',
from_warehouse_id: '',
to_warehouse_id: '',
reason: '',
entries: [...repeatValue(defaultWareTransferEntry, MIN_LINES_NUMBER)],
};
export const ITEMS_FILTER_ROLES_QUERY = JSON.stringify([
{
index: 1,
fieldKey: 'sellable',
value: true,
condition: '&&',
comparator: 'equals',
},
{
index: 2,
fieldKey: 'active',
value: true,
condition: '&&',
comparator: 'equals',
},
{ fieldKey: 'type', comparator: 'is', value: 'inventory', index: 1 },
]);
/**
@@ -50,6 +37,6 @@ export const useObserveTransferNoSettings = (prefix, nextNumber) => {
React.useEffect(() => {
const transferNo = transactionNumber(prefix, nextNumber);
setFieldValue('transfer_no', transferNo);
setFieldValue('transaction_number', transferNo);
}, [setFieldValue, prefix, nextNumber]);
};

View File

@@ -8,6 +8,10 @@ const commonInvalidateQueries = (queryClient) => {
// Invalidate warehouses.
queryClient.invalidateQueries(t.WAREHOUSES);
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,
},
);
}