Files
bigcapital/packages/webapp/src/containers/Drawers/EstimateDetailDrawer/EstimateDetailHeader.tsx
2024-12-04 12:00:22 +02:00

100 lines
2.7 KiB
TypeScript

// @ts-nocheck
import React from 'react';
import intl from 'react-intl-universal';
import styled from 'styled-components';
import { defaultTo } from 'lodash';
import {
CommercialDocHeader,
CommercialDocTopHeader,
FormatDate,
T,
DetailsMenu,
DetailItem,
Row,
Col,
CustomerDrawerLink,
ExchangeRateDetailItem,
} from '@/components';
import { useEstimateDetailDrawerContext } from './EstimateDetailDrawerProvider';
import { EstimateDetailsStatus } from './components';
/**
* Estimate read-only details drawer header.
*/
export default function EstimateDetailHeader() {
const { estimate } = useEstimateDetailDrawerContext();
return (
<CommercialDocHeader>
<CommercialDocTopHeader>
<DetailsMenu>
<AmountEstimateDetail label={intl.get('amount')}>
<span class="big-number">{estimate.total_formatted}</span>
</AmountEstimateDetail>
<EstimateStatusDetail>
<EstimateDetailsStatus estimate={estimate} />
</EstimateStatusDetail>
</DetailsMenu>
</CommercialDocTopHeader>
<Row>
<Col xs={6}>
<DetailsMenu direction={'horizantal'} minLabelSize={'180px'}>
<DetailItem
label={intl.get('estimate.details.estimate_number')}
children={defaultTo(estimate.estimate_number, '-')}
/>
<DetailItem label={intl.get('customer_name')}>
<CustomerDrawerLink customerId={estimate.customer_id}>
{estimate.customer?.display_name}
</CustomerDrawerLink>
</DetailItem>
<DetailItem
label={intl.get('estimate_date')}
children={estimate.formatted_estimate_date}
/>
<DetailItem
label={intl.get('expiration_date')}
children={estimate.formatted_expiration_date}
/>
<ExchangeRateDetailItem
exchangeRate={estimate?.exchange_rate}
toCurrency={estimate?.currency_code}
/>
</DetailsMenu>
</Col>
<Col xs={6}>
<DetailsMenu
textAlign={'right'}
direction={'horizantal'}
minLabelSize={'180px'}
>
<DetailItem
label={intl.get('reference')}
children={defaultTo(estimate.reference, '-')}
/>
<DetailItem
label={<T id={'estimate.details.created_at'} />}
children={estimate.formatted_created_at}
/>
</DetailsMenu>
</Col>
</Row>
</CommercialDocHeader>
);
}
const EstimateStatusDetail = styled(DetailItem)`
width: 50%;
text-align: right;
`;
const AmountEstimateDetail = styled(DetailItem)`
width: 50%;
`;