24 lines
1,002 B
TypeScript
24 lines
1,002 B
TypeScript
import type { ComponentProps, ComponentType, FunctionComponent } from 'react';
|
|
import { useState } from 'react';
|
|
import { Dialog, DialogProps, DialogWrapperContext, WrapperProps } from '@/components/elements/dialog';
|
|
|
|
function asDialog(
|
|
initialProps?: WrapperProps,
|
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
|
): <P extends {}>(C: ComponentType<P>) => FunctionComponent<P & DialogProps> {
|
|
return function (Component) {
|
|
return function ({ open, onClose, ...rest }) {
|
|
const [props, setProps] = useState<WrapperProps>(initialProps || {});
|
|
|
|
return (
|
|
<DialogWrapperContext.Provider value={{ props, setProps, close: onClose }}>
|
|
<Dialog {...props} open={open} onClose={onClose}>
|
|
<Component {...(rest as unknown as ComponentProps<typeof Component>)} />
|
|
</Dialog>
|
|
</DialogWrapperContext.Provider>
|
|
);
|
|
};
|
|
};
|
|
}
|
|
|
|
export default asDialog;
|