1
0
Files
bigcapital/packages/webapp/src/containers/FinancialStatements/CashFlowStatement/CashFlowStatementTable.tsx
T
2026-03-01 04:08:26 +02:00

96 lines
2.3 KiB
TypeScript

// @ts-nocheck
import React, { useMemo } from 'react';
import intl from 'react-intl-universal';
import styled from 'styled-components';
import { TableStyle } from '@/constants';
import { DataTable, FinancialSheet } from '@/components';
import { defaultExpanderReducer, tableRowTypesToClassnames } from '@/utils';
import { useCashFlowStatementColumns } from './components';
import { useCashFlowStatementContext } from './CashFlowStatementProvider';
/**
* Cash flow statement table.
*/
export default function CashFlowStatementTable({
// #ownProps
companyName,
}) {
const {
cashFlowStatement: { tableRows, meta },
query,
} = useCashFlowStatementContext();
const columns = useCashFlowStatementColumns();
const expandedRows = useMemo(
() => defaultExpanderReducer(tableRows, 4),
[tableRows],
);
return (
<FinancialSheet
companyName={companyName}
sheetType={intl.get('statement_of_cash_flow')}
dateText={meta?.formatted_date_range ?? meta?.formatted_as_date}
basis={query.basis}
>
<CashflowStatementDataTable
columns={columns}
data={tableRows}
rowClassNames={tableRowTypesToClassnames}
noInitialFetch={true}
expandable={true}
expanded={expandedRows}
expandToggleColumn={1}
sticky={true}
expandColumnSpace={0.8}
styleName={TableStyle.Constrant}
/>
</FinancialSheet>
);
}
const CashflowStatementDataTable = styled(DataTable)`
.table {
.tbody {
.tr:not(.no-results) {
.td {
border-bottom-width: 0;
padding-top: 0.32rem;
padding-bottom: 0.32rem;
}
&.row_type--ACCOUNTS {
.td {
border-top-width: 1px;
border-top-style: solid;
}
}
&.row-id--CASH_END_PERIOD {
.td {
border-bottom-width: 3px;
border-bottom-style: double;
}
}
&.row_type--TOTAL {
font-weight: 500;
&:not(:first-child) .td {
border-top-width: 1px;
border-top-style: solid;
}
}
}
.tr.is-expanded {
.td.total,
.td.date-period {
.cell-inner {
display: none;
}
}
}
}
}
`;