Files
bigcapital/client/src/containers/Sales/Receipts/ReceiptsLanding/ReceiptViewTabs.js
2021-08-04 16:55:50 +02:00

53 lines
1.3 KiB
JavaScript

import React from 'react';
import { Alignment, Navbar, NavbarGroup } from '@blueprintjs/core';
import { DashboardViewsTabs } from 'components';
import withReceiptActions from './withReceiptsActions';
import withReceipts from './withReceipts';
import { compose, transfromViewsToTabs } from 'utils';
import { useReceiptsListContext } from './ReceiptsListProvider';
/**
* Receipts views tabs.
*/
function ReceiptViewTabs({
// #withReceiptActions
setReceiptsTableState,
// #withReceipts
receiptsCurrentView,
}) {
// Receipts list context.
const { receiptsViews } = useReceiptsListContext();
const tabs = transfromViewsToTabs(receiptsViews);
// Handles the active tab chaning.
const handleTabsChange = (viewSlug) => {
setReceiptsTableState({
viewSlug: viewSlug || null,
});
};
return (
<Navbar className={'navbar--dashboard-views'}>
<NavbarGroup align={Alignment.LEFT}>
<DashboardViewsTabs
currentViewSlug={receiptsCurrentView}
tabs={tabs}
resourceName={'receipts'}
onChange={handleTabsChange}
/>
</NavbarGroup>
</Navbar>
);
}
export default compose(
withReceiptActions,
withReceipts(({ receiptTableState }) => ({
receiptsCurrentView: receiptTableState.viewSlug,
})),
)(ReceiptViewTabs);