2022-05-18 21:54:29 +03:00

17 lines
661 B
TypeScript

import { observer } from 'mobx-react-lite';
import { useStatus } from 'stores/calculation/statuses/hooks';
import { useComputedValue } from 'stores/calculation/values/hooks';
import { getComputedValueName } from '../config/map-computed';
import type { BuilderProps } from './types';
export default function buildComputedValue({ elementName, Component, ...props }: BuilderProps) {
const computedValueName = getComputedValueName(elementName);
return observer(() => {
const computedValue = useComputedValue(computedValueName);
const status = useStatus(elementName);
return <Component value={computedValue} status={status} {...props} />;
});
}