import Alert from 'elements/Alert'; import Table from 'elements/Table'; import { computed } from 'mobx'; import { observer } from 'mobx-react-lite'; import { useStore } from 'stores/hooks'; import styled from 'styled-components'; import { Box, Flex } from 'UIKit/grid'; import { min } from 'UIKit/mq'; import { columns } from './config'; const Grid = styled(Flex)` flex-direction: column; `; const TableWrapper = styled.div` td > * { margin: 0; } `; const TablesGroupGrid = styled(Box)` display: flex; flex-direction: column; gap: 10px; ${min('tablet')} { display: grid; grid-template-columns: repeat(5, 1fr); } `; const Validation = observer(() => { const store = useStore(); const { payments } = store.$tables; const messages = payments.validation.getMessages(); if (messages?.length) { return ; } return null; }); const SPLIT_NUMBER = 12; function TablePart({ num }) { const store = useStore(); const { payments } = store.$tables; const values = payments.values.slice(num * SPLIT_NUMBER, num * SPLIT_NUMBER + SPLIT_NUMBER); const dataSource = values.map((value, index) => ({ key: index + num * SPLIT_NUMBER, num: index + num * SPLIT_NUMBER, paymentRelation: value, })); return ( ); } const TablesGroup = observer(() => { const store = useStore(); const { payments } = store.$tables; const valuesLength = computed(() => payments.values.length).get(); const tablesNumber = Math.ceil(valuesLength / SPLIT_NUMBER); const tables = []; for (let i = 0; i < tablesNumber; i += 1) { tables.push(); } return {tables}; }); export default function TablePayments() { return ( ); }