21 lines
773 B
TypeScript
21 lines
773 B
TypeScript
import { observer } from 'mobx-react-lite';
|
|
import { useStatus } from 'stores/calculation/statuses/hooks';
|
|
import { useValidation } from 'stores/calculation/validation/hooks';
|
|
import { useSetValue } from 'stores/calculation/values/hooks';
|
|
import { getValueName } from '../config/map-values';
|
|
import type { BuilderProps } from './types';
|
|
|
|
export default function buildValue({ elementName, Component, ...props }: BuilderProps) {
|
|
const valueName = getValueName(elementName);
|
|
|
|
return observer(() => {
|
|
const setValue = useSetValue(valueName);
|
|
const status = useStatus(elementName);
|
|
const { isValid, help } = useValidation(elementName);
|
|
|
|
return (
|
|
<Component setValue={setValue} status={status} isValid={isValid} help={help} {...props} />
|
|
);
|
|
});
|
|
}
|