mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-18 22:00:31 +00:00
50 lines
1.3 KiB
TypeScript
50 lines
1.3 KiB
TypeScript
import React from 'react';
|
|
import { FastField } from 'formik';
|
|
import classNames from 'classnames';
|
|
import { CLASSES } from '@/constants/classes';
|
|
import {
|
|
entriesFieldShouldUpdate,
|
|
defaultEntry,
|
|
MIN_LINES_NUMBER,
|
|
} from './utils';
|
|
import { useMakeJournalFormContext } from './MakeJournalProvider';
|
|
import MakeJournalEntriesTable from './MakeJournalEntriesTable';
|
|
|
|
/**
|
|
* Make journal entries field.
|
|
*/
|
|
export default function MakeJournalEntriesField() {
|
|
const { accounts, contacts, branches, projects } =
|
|
useMakeJournalFormContext();
|
|
|
|
return (
|
|
<div className={classNames(CLASSES.PAGE_FORM_BODY)}>
|
|
<FastField
|
|
name={'entries'}
|
|
contacts={contacts}
|
|
accounts={accounts}
|
|
branches={branches}
|
|
projects={projects}
|
|
shouldUpdate={entriesFieldShouldUpdate}
|
|
>
|
|
{({
|
|
form: { values, setFieldValue },
|
|
field: { value },
|
|
meta: { error, touched },
|
|
}) => (
|
|
<MakeJournalEntriesTable
|
|
onChange={(entries) => {
|
|
setFieldValue('entries', entries);
|
|
}}
|
|
entries={value}
|
|
defaultEntry={defaultEntry}
|
|
initialLinesNumber={MIN_LINES_NUMBER}
|
|
error={error}
|
|
currencyCode={values.currency_code}
|
|
/>
|
|
)}
|
|
</FastField>
|
|
</div>
|
|
);
|
|
}
|