2022-06-02 12:05:00 +03:00

22 lines
630 B
TypeScript

import { observer } from 'mobx-react-lite';
import type { FC } from 'react';
import { useValue } from 'stores/calculation/values/hooks';
import type { Values } from 'stores/calculation/values/types';
import type { ElementsProps } from '../types/elements-props';
type BuilderProps = {
elementName: keyof ElementsProps;
valueName: Values;
};
export default function buildReadonly(
Component: FC<any>,
{ elementName, valueName }: BuilderProps
) {
return observer<ElementsProps[typeof elementName]>((props) => {
const [value] = useValue(valueName);
return <Component value={value} readOnly {...props} />;
});
}