mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-15 20:30:33 +00:00
76 lines
1.9 KiB
TypeScript
76 lines
1.9 KiB
TypeScript
// @ts-nocheck
|
|
import React from 'react';
|
|
import moment from 'moment';
|
|
import { castArray } from 'lodash';
|
|
import * as Yup from 'yup';
|
|
import intl from 'react-intl-universal';
|
|
|
|
import { useAppQueryString } from '@/hooks';
|
|
import { transformToForm } from '@/utils';
|
|
|
|
/**
|
|
* Retrieves inventory item details default query.
|
|
*/
|
|
export const getInventoryItemDetailsDefaultQuery = () => ({
|
|
fromDate: moment().startOf('year').format('YYYY-MM-DD'),
|
|
toDate: moment().endOf('year').format('YYYY-MM-DD'),
|
|
itemsIds: [],
|
|
warehousesIds: [],
|
|
branchesIds: [],
|
|
});
|
|
|
|
/**
|
|
* Retrieves inventory item details query schema.
|
|
* @returns {Yup}
|
|
*/
|
|
export const getInventoryItemDetailsQuerySchema = () => {
|
|
return Yup.object().shape({
|
|
fromDate: Yup.date().required().label(intl.get('fromDate')),
|
|
toDate: Yup.date()
|
|
.min(Yup.ref('fromDate'))
|
|
.required()
|
|
.label(intl.get('toDate')),
|
|
});
|
|
};
|
|
|
|
/**
|
|
* Parses inventory item details browser location query.
|
|
*/
|
|
const parseInventoryItemDetailsQuery = (locationQuery) => {
|
|
const defaultQuery = getInventoryItemDetailsDefaultQuery();
|
|
|
|
const transformed = {
|
|
...defaultQuery,
|
|
...transformToForm(locationQuery, defaultQuery),
|
|
};
|
|
|
|
return {
|
|
...transformed,
|
|
|
|
// Ensure the branches, warehouses and items ids is always array.
|
|
itemsIds: castArray(transformed.itemsIds),
|
|
branchesIds: castArray(transformed.branchesIds),
|
|
warehousesIds: castArray(transformed.warehousesIds),
|
|
};
|
|
};
|
|
|
|
/**
|
|
* State setter/getter of inventory valuation browser location query.
|
|
*/
|
|
export const useInventoryValuationQuery = () => {
|
|
// Retrieves location query.
|
|
const [locationQuery, setLocationQuery] = useAppQueryString();
|
|
|
|
// Merges the default filter query with location URL query.
|
|
const query = React.useMemo(
|
|
() => parseInventoryItemDetailsQuery(locationQuery),
|
|
[locationQuery],
|
|
);
|
|
|
|
return {
|
|
query,
|
|
locationQuery,
|
|
setLocationQuery,
|
|
};
|
|
};
|