import type { Elements } from '../config/map/values'; import { useStoreValue } from './hooks'; import { useStatus } from '@/stores/calculation/statuses/hooks'; import { useValidation } from '@/stores/calculation/validation/hooks'; import type { Values } from '@/stores/calculation/values/types'; import { observer } from 'mobx-react-lite'; import type { ChangeEvent, ComponentType } from 'react'; import { Form } from 'ui/elements'; type BuilderProps = { elementName: Elements; valueName: Values; }; export function buildValue( Component: ComponentType, { elementName, valueName }: BuilderProps ) { return observer((props: T) => { const [value, setValue] = useStoreValue(valueName); const status = useStatus(elementName); const { validateStatus, help } = useValidation(elementName); return ( ) => { setValue(e.target.value); }} disabled={status === 'Disabled'} value={value} {...props} /> ); }); } export function buildNumberValue( Component: ComponentType, { elementName, valueName }: BuilderProps ) { return observer((props: T) => { const [value, setValue] = useStoreValue(valueName); const status = useStatus(elementName); const { validateStatus, help } = useValidation(elementName); return ( { setValue(inputValue || 0); }} disabled={status === 'Disabled'} value={value} {...props} /> ); }); }