mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-20 14:50:32 +00:00
refactor(CashflowSheet): refactor the body sheet.
This commit is contained in:
@@ -6,10 +6,9 @@ import { FinancialStatement } from 'components';
|
|||||||
import DashboardPageContent from 'components/Dashboard/DashboardPageContent';
|
import DashboardPageContent from 'components/Dashboard/DashboardPageContent';
|
||||||
|
|
||||||
import CashFlowStatementHeader from './CashFlowStatementHeader';
|
import CashFlowStatementHeader from './CashFlowStatementHeader';
|
||||||
import CashFlowStatementTable from './CashFlowStatementTable';
|
|
||||||
import CashFlowStatementActionsBar from './CashFlowStatementActionsBar';
|
import CashFlowStatementActionsBar from './CashFlowStatementActionsBar';
|
||||||
|
import { CashFlowStatementBody } from './CashFlowStatementBody';
|
||||||
|
|
||||||
import withCurrentOrganization from '../../Organization/withCurrentOrganization';
|
|
||||||
import withCashFlowStatementActions from './withCashFlowStatementActions';
|
import withCashFlowStatementActions from './withCashFlowStatementActions';
|
||||||
import { CashFlowStatementProvider } from './CashFlowStatementProvider';
|
import { CashFlowStatementProvider } from './CashFlowStatementProvider';
|
||||||
import {
|
import {
|
||||||
@@ -23,8 +22,6 @@ import { compose } from 'utils';
|
|||||||
* Cash flow statement.
|
* Cash flow statement.
|
||||||
*/
|
*/
|
||||||
function CashFlowStatement({
|
function CashFlowStatement({
|
||||||
// #withPreferences
|
|
||||||
organizationName,
|
|
||||||
//#withCashStatementActions
|
//#withCashStatementActions
|
||||||
toggleCashFlowStatementFilterDrawer,
|
toggleCashFlowStatementFilterDrawer,
|
||||||
}) {
|
}) {
|
||||||
@@ -77,18 +74,11 @@ function CashFlowStatement({
|
|||||||
pageFilter={filter}
|
pageFilter={filter}
|
||||||
onSubmitFilter={handleFilterSubmit}
|
onSubmitFilter={handleFilterSubmit}
|
||||||
/>
|
/>
|
||||||
<div class="financial-statement__body">
|
<CashFlowStatementBody />
|
||||||
<CashFlowStatementTable companyName={organizationName} />
|
|
||||||
</div>
|
|
||||||
</FinancialStatement>
|
</FinancialStatement>
|
||||||
</DashboardPageContent>
|
</DashboardPageContent>
|
||||||
</CashFlowStatementProvider>
|
</CashFlowStatementProvider>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export default compose(
|
export default compose(withCashFlowStatementActions)(CashFlowStatement);
|
||||||
withCurrentOrganization(({ organization }) => ({
|
|
||||||
organizationName: organization.name,
|
|
||||||
})),
|
|
||||||
withCashFlowStatementActions,
|
|
||||||
)(CashFlowStatement);
|
|
||||||
|
|||||||
@@ -0,0 +1,36 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import * as R from 'ramda';
|
||||||
|
|
||||||
|
import CashFlowStatementTable from './CashFlowStatementTable';
|
||||||
|
import { FinancialReportBody } from '../FinancialReportPage';
|
||||||
|
import { FinancialSheetSkeleton } from 'components/FinancialSheet';
|
||||||
|
|
||||||
|
import { useCashFlowStatementContext } from './CashFlowStatementProvider';
|
||||||
|
import withCurrentOrganization from '../../Organization/withCurrentOrganization';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cashflow stement body.
|
||||||
|
* @returns {React.JSX}
|
||||||
|
*/
|
||||||
|
function CashFlowStatementBodyJSX({
|
||||||
|
// #withPreferences
|
||||||
|
organizationName,
|
||||||
|
}) {
|
||||||
|
const { isCashFlowLoading } = useCashFlowStatementContext();
|
||||||
|
|
||||||
|
return (
|
||||||
|
<FinancialReportBody>
|
||||||
|
{isCashFlowLoading ? (
|
||||||
|
<FinancialSheetSkeleton />
|
||||||
|
) : (
|
||||||
|
<CashFlowStatementTable companyName={organizationName} />
|
||||||
|
)}
|
||||||
|
</FinancialReportBody>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
export const CashFlowStatementBody = R.compose(
|
||||||
|
withCurrentOrganization(({ organization }) => ({
|
||||||
|
organizationName: organization.name,
|
||||||
|
})),
|
||||||
|
)(CashFlowStatementBodyJSX);
|
||||||
@@ -1,12 +1,14 @@
|
|||||||
import React, { useMemo } from 'react';
|
import React, { useMemo } from 'react';
|
||||||
import intl from 'react-intl-universal';
|
import intl from 'react-intl-universal';
|
||||||
|
import styled from 'styled-components';
|
||||||
|
|
||||||
import { DataTable, FinancialSheet } from 'components';
|
import { DataTable, FinancialSheet } from 'components';
|
||||||
|
|
||||||
import { useCashFlowStatementColumns } from './components';
|
import { useCashFlowStatementColumns } from './components';
|
||||||
import { useCashFlowStatementContext } from './CashFlowStatementProvider';
|
import { useCashFlowStatementContext } from './CashFlowStatementProvider';
|
||||||
|
|
||||||
import { defaultExpanderReducer } from 'utils';
|
import { TableStyle } from 'common';
|
||||||
|
import { defaultExpanderReducer, tableRowTypesToClassnames } from 'utils';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Cash flow statement table.
|
* Cash flow statement table.
|
||||||
@@ -27,14 +29,6 @@ export default function CashFlowStatementTable({
|
|||||||
() => defaultExpanderReducer(tableRows, 4),
|
() => defaultExpanderReducer(tableRows, 4),
|
||||||
[tableRows],
|
[tableRows],
|
||||||
);
|
);
|
||||||
|
|
||||||
const rowClassNames = (row) => {
|
|
||||||
return [
|
|
||||||
`row-type--${row.original.row_types}`,
|
|
||||||
`row-type--${row.original.id}`,
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<FinancialSheet
|
<FinancialSheet
|
||||||
name="cash-flow-statement"
|
name="cash-flow-statement"
|
||||||
@@ -45,17 +39,55 @@ export default function CashFlowStatementTable({
|
|||||||
toDate={query.to_date}
|
toDate={query.to_date}
|
||||||
basis={query.basis}
|
basis={query.basis}
|
||||||
>
|
>
|
||||||
<DataTable
|
<CashflowStatementDataTable
|
||||||
className="bigcapital-datatable--financial-report"
|
|
||||||
columns={columns}
|
columns={columns}
|
||||||
data={tableRows}
|
data={tableRows}
|
||||||
rowClassNames={rowClassNames}
|
rowClassNames={tableRowTypesToClassnames}
|
||||||
noInitialFetch={true}
|
noInitialFetch={true}
|
||||||
expandable={true}
|
expandable={true}
|
||||||
expanded={expandedRows}
|
expanded={expandedRows}
|
||||||
expandToggleColumn={1}
|
expandToggleColumn={1}
|
||||||
expandColumnSpace={0.8}
|
expandColumnSpace={0.8}
|
||||||
|
styleName={TableStyle.Constrant}
|
||||||
/>
|
/>
|
||||||
</FinancialSheet>
|
</FinancialSheet>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const CashflowStatementDataTable = styled(DataTable)`
|
||||||
|
.table {
|
||||||
|
.tbody {
|
||||||
|
.tr:not(.no-results) {
|
||||||
|
.td {
|
||||||
|
border-bottom: 0;
|
||||||
|
padding-top: 0.32rem;
|
||||||
|
padding-bottom: 0.32rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
// &.row-type--AGGREGATE,
|
||||||
|
&.row_type--ACCOUNTS {
|
||||||
|
border-top: 1px solid #bbb;
|
||||||
|
}
|
||||||
|
&.row-id--CASH_END_PERIOD {
|
||||||
|
border-bottom: 3px double #333;
|
||||||
|
}
|
||||||
|
&.row_type--TOTAL {
|
||||||
|
font-weight: 500;
|
||||||
|
|
||||||
|
&:not(:first-child) .td {
|
||||||
|
border-top: 1px solid #bbb;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.tr.is-expanded {
|
||||||
|
.td.total,
|
||||||
|
.td.date-period {
|
||||||
|
.cell-inner {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|||||||
@@ -1,12 +1,13 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { Button } from '@blueprintjs/core';
|
import { Button } from '@blueprintjs/core';
|
||||||
|
|
||||||
import { Icon, If } from 'components';
|
import { Icon, If } from 'components';
|
||||||
import { FormattedMessage as T } from 'components';
|
import { FormattedMessage as T } from 'components';
|
||||||
|
|
||||||
import { dynamicColumns } from './utils';
|
|
||||||
import { useCashFlowStatementContext } from './CashFlowStatementProvider';
|
|
||||||
import FinancialLoadingBar from '../FinancialLoadingBar';
|
import FinancialLoadingBar from '../FinancialLoadingBar';
|
||||||
|
|
||||||
|
import { dynamicColumns } from './dynamicColumns';
|
||||||
|
import { useCashFlowStatementContext } from './CashFlowStatementProvider';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieve cash flow statement columns.
|
* Retrieve cash flow statement columns.
|
||||||
*/
|
*/
|
||||||
@@ -49,7 +50,6 @@ export function CashFlowStatementAlerts() {
|
|||||||
if (isCashFlowLoading) {
|
if (isCashFlowLoading) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<If condition={cashFlowStatement.meta.is_cost_compute_running}>
|
<If condition={cashFlowStatement.meta.is_cost_compute_running}>
|
||||||
<div className="alert-compute-running">
|
<div className="alert-compute-running">
|
||||||
|
|||||||
@@ -0,0 +1,78 @@
|
|||||||
|
import * as R from 'ramda';
|
||||||
|
import intl from 'react-intl-universal';
|
||||||
|
|
||||||
|
import { Align } from 'common';
|
||||||
|
import { CellTextSpan } from 'components/Datatable/Cells';
|
||||||
|
import { getColumnWidth } from 'utils';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Account name column mapper.
|
||||||
|
*/
|
||||||
|
const accountNameMapper = (column) => ({
|
||||||
|
id: column.key,
|
||||||
|
key: column.key,
|
||||||
|
Header: intl.get('account_name'),
|
||||||
|
accessor: 'cells[0].value',
|
||||||
|
className: 'account_name',
|
||||||
|
textOverview: true,
|
||||||
|
width: 400,
|
||||||
|
disableSortBy: true,
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Date range columns mapper.
|
||||||
|
*/
|
||||||
|
const dateRangeMapper = (data, index, column) => ({
|
||||||
|
id: column.key,
|
||||||
|
Header: column.label,
|
||||||
|
key: column.key,
|
||||||
|
accessor: `cells[${index}].value`,
|
||||||
|
width: getColumnWidth(data, `cells.${index}.value`, {
|
||||||
|
magicSpacing: 10,
|
||||||
|
minWidth: 100,
|
||||||
|
}),
|
||||||
|
className: `date-period ${column.key}`,
|
||||||
|
disableSortBy: true,
|
||||||
|
textOverview: true,
|
||||||
|
align: Align.Right,
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Total column mapper.
|
||||||
|
*/
|
||||||
|
const totalMapper = (data, index, column) => ({
|
||||||
|
key: 'total',
|
||||||
|
Header: intl.get('total'),
|
||||||
|
accessor: `cells[${index}].value`,
|
||||||
|
className: 'total',
|
||||||
|
textOverview: true,
|
||||||
|
Cell: CellTextSpan,
|
||||||
|
width: getColumnWidth(data, `cells[${index}].value`, {
|
||||||
|
magicSpacing: 10,
|
||||||
|
minWidth: 100,
|
||||||
|
}),
|
||||||
|
disableSortBy: true,
|
||||||
|
align: Align.Right,
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Detarmines the given string starts with `date-range` string.
|
||||||
|
*/
|
||||||
|
const isMatchesDateRange = (r) => R.match(/^date-range/g, r).length > 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Cash flow dynamic columns.
|
||||||
|
*/
|
||||||
|
export const dynamicColumns = (columns, data) => {
|
||||||
|
const mapper = (column, index) => {
|
||||||
|
return R.compose(
|
||||||
|
R.when(
|
||||||
|
R.pathSatisfies(isMatchesDateRange, ['key']),
|
||||||
|
R.curry(dateRangeMapper)(data, index),
|
||||||
|
),
|
||||||
|
R.when(R.pathEq(['key'], 'name'), accountNameMapper),
|
||||||
|
R.when(R.pathEq(['key'], 'total'), R.curry(totalMapper)(data, index)),
|
||||||
|
)(column);
|
||||||
|
};
|
||||||
|
return columns.map(mapper);
|
||||||
|
};
|
||||||
@@ -1,74 +0,0 @@
|
|||||||
import * as R from 'ramda';
|
|
||||||
import { CellTextSpan } from 'components/Datatable/Cells';
|
|
||||||
import { getColumnWidth } from 'utils';
|
|
||||||
import intl from 'react-intl-universal';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Account name column mapper.
|
|
||||||
*/
|
|
||||||
const accountNameMapper = (column) => ({
|
|
||||||
id: column.key,
|
|
||||||
key: column.key,
|
|
||||||
Header: intl.get('account_name'),
|
|
||||||
accessor: 'cells[0].value',
|
|
||||||
className: 'account_name',
|
|
||||||
textOverview: true,
|
|
||||||
width: 400,
|
|
||||||
disableSortBy: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Date range columns mapper.
|
|
||||||
*/
|
|
||||||
const dateRangeMapper = (data, index, column) => ({
|
|
||||||
id: column.key,
|
|
||||||
Header: column.label,
|
|
||||||
key: column.key,
|
|
||||||
accessor: `cells[${index}].value`,
|
|
||||||
width: getColumnWidth(data, `cells.${index}.value`, {
|
|
||||||
magicSpacing: 10,
|
|
||||||
minWidth: 100,
|
|
||||||
}),
|
|
||||||
className: `date-period ${column.key}`,
|
|
||||||
disableSortBy: true,
|
|
||||||
textOverview: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Total column mapper.
|
|
||||||
*/
|
|
||||||
const totalMapper = (data, index, column) => ({
|
|
||||||
key: 'total',
|
|
||||||
Header: intl.get('total'),
|
|
||||||
accessor: `cells[${index}].value`,
|
|
||||||
className: 'total',
|
|
||||||
textOverview: true,
|
|
||||||
Cell: CellTextSpan,
|
|
||||||
width: getColumnWidth(data, `cells[${index}].value`, {
|
|
||||||
magicSpacing: 10,
|
|
||||||
minWidth: 100,
|
|
||||||
}),
|
|
||||||
disableSortBy: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Detarmines the given string starts with `date-range` string.
|
|
||||||
*/
|
|
||||||
const isMatchesDateRange = (r) => R.match(/^date-range/g, r).length > 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Cash flow dynamic columns.
|
|
||||||
*/
|
|
||||||
export const dynamicColumns = (columns, data) => {
|
|
||||||
const mapper = (column, index) => {
|
|
||||||
return R.compose(
|
|
||||||
R.when(
|
|
||||||
R.pathSatisfies(isMatchesDateRange, ['key']),
|
|
||||||
R.curry(dateRangeMapper)(data, index),
|
|
||||||
),
|
|
||||||
R.when(R.pathEq(['key'], 'name'), accountNameMapper),
|
|
||||||
R.when(R.pathEq(['key'], 'total'), R.curry(totalMapper)(data, index)),
|
|
||||||
)(column);
|
|
||||||
};
|
|
||||||
return columns.map(mapper);
|
|
||||||
};
|
|
||||||
|
|||||||
@@ -1,46 +1,7 @@
|
|||||||
.financial-sheet {
|
.financial-sheet {
|
||||||
&--cash-flow-statement {
|
&--cash-flow-statement {
|
||||||
.financial-sheet__table {
|
.financial-sheet__table {
|
||||||
.thead,
|
|
||||||
.tbody {
|
|
||||||
.tr .td.account_name ~ .td,
|
|
||||||
.tr .th.account_name ~ .th {
|
|
||||||
text-align: right;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
.tbody {
|
|
||||||
.tr:not(.no-results) {
|
|
||||||
// &.row-type--AGGREGATE,
|
|
||||||
&.row-type--ACCOUNTS {
|
|
||||||
border-top: 1px solid #bbb;
|
|
||||||
}
|
|
||||||
&.row-type--CASH_END_PERIOD {
|
|
||||||
border-bottom: 3px double #333;
|
|
||||||
}
|
|
||||||
.td {
|
|
||||||
border-bottom: 0;
|
|
||||||
padding-top: 0.4rem;
|
|
||||||
padding-bottom: 0.4rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
&.row-type--TOTAL {
|
|
||||||
font-weight: 500;
|
|
||||||
|
|
||||||
&:not(:first-child) .td {
|
|
||||||
border-top: 1px solid #bbb;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.tr.is-expanded {
|
|
||||||
.td.total,
|
|
||||||
.td.date-period {
|
|
||||||
.cell-inner {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user