Files
bigcapital/packages/webapp/src/containers/FinancialStatements/CashFlowStatement/utils.tsx
2023-02-03 01:02:31 +02:00

60 lines
1.4 KiB
TypeScript

// @ts-nocheck
import React from 'react';
import moment from 'moment';
import { castArray } from 'lodash';
import { transformToForm } from '@/utils';
import { useAppQueryString } from '@/hooks';
/**
* Retrieves the default cashflow sheet query.
*/
export const getDefaultCashFlowSheetQuery = () => {
return {
fromDate: moment().startOf('year').format('YYYY-MM-DD'),
toDate: moment().endOf('year').format('YYYY-MM-DD'),
basis: 'cash',
displayColumnsType: 'total',
filterByOption: 'with-transactions',
branchesIds: [],
};
};
/**
* Parses the cashflow query from browser location.
*/
const parseCashflowQuery = (query) => {
const defaultQuery = getDefaultCashFlowSheetQuery();
const transformed = {
...defaultQuery,
...transformToForm(query, defaultQuery),
};
return {
...transformed,
// Ensures the branches ids is always array.
branchesIds: castArray(transformed.branchesIds),
};
};
/**
* Retrieves the cashflow statement query.
*/
export const useCashflowStatementQuery = () => {
// Retrieves location query.
const [locationQuery, setLocationQuery] = useAppQueryString();
// Merges the default filter query with location URL query.
const query = React.useMemo(
() => parseCashflowQuery(locationQuery),
[locationQuery],
);
return {
query,
locationQuery,
setLocationQuery,
};
};