diff options
| -rw-r--r-- | .eslintrc.json | 1 | ||||
| -rw-r--r-- | src/containers/WaybillForm.tsx | 7 | ||||
| -rw-r--r-- | src/hooks/useOptions.ts | 12 | 
3 files changed, 13 insertions, 7 deletions
| diff --git a/.eslintrc.json b/.eslintrc.json index 8fbc76e..b780736 100644 --- a/.eslintrc.json +++ b/.eslintrc.json @@ -16,6 +16,7 @@      "arrow-parens": [2, "as-needed"],      "import/extensions": ["error", { "ts": "never", "tsx": "never" }],      "arrow-body-style": 0, +    "curly": 0,      "no-underscore-dangle": 0,      "no-cond-assign": 0,      "no-nested-ternary": 0, diff --git a/src/containers/WaybillForm.tsx b/src/containers/WaybillForm.tsx index 2167d17..1297a0f 100644 --- a/src/containers/WaybillForm.tsx +++ b/src/containers/WaybillForm.tsx @@ -7,13 +7,16 @@ import Select from '../components/Select';  import Paper from '../components/Paper';  import useOptions from '../hooks/useOptions'; +  const WaybillForm: React.FC<FormikProps> = ({ setFieldValue, values }) => {    const [recordsNumber, setRecordsNumber] = useState<number>(values.records.length);    const handleAddRecord = () => setRecordsNumber(v => v + 1); -  const contractorOptions = useOptions('contractors', 'contractorId', values, setFieldValue); -  const productOptions = useOptions('products', 'productId', values, setFieldValue); +  const productInitFields = _.times(recordsNumber).map(index => `records.${index}.productId`); + +  const contractorOptions = useOptions('contractors', ['contractorId'], values, setFieldValue); +  const productOptions = useOptions('products', productInitFields, values, setFieldValue);    return (      <Form id="form"> diff --git a/src/hooks/useOptions.ts b/src/hooks/useOptions.ts index de8fc95..2a5aee6 100644 --- a/src/hooks/useOptions.ts +++ b/src/hooks/useOptions.ts @@ -1,4 +1,5 @@  import { useEffect } from 'react'; +import _ from 'lodash';  import { Option } from '../components/Select';  import hooks from './useAPIClient'; @@ -6,7 +7,7 @@ import hooks from './useAPIClient';  // setting the default value in formik  const useOptions = (    service: string, -  field: string, +  fields: string[],    values: Record<string, any>,    setFieldValue: (any) => void,    mapper = item => ({ key: item._id, label: item.name }), @@ -16,10 +17,11 @@ const useOptions = (    const options = items?.map(mapper);    useEffect(() => { -    if (items?.length && !values[field]) { -      setFieldValue(field, items[0]._id); -    } -  }, [items, setFieldValue]); +    // Initialize all empty fields +    if (items?.length) fields.forEach(field => { +      if (!_.get(values, field)) setFieldValue(field, items[0]._id); +    }); +  }, [items, values, setFieldValue]);    return options;  }; | 
