HookModal.tsx 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. import React, { PropsWithChildren } from 'react';
  2. import ConfirmModal from '../ConfirmModal';
  3. import { ConfirmProps } from '../confirm';
  4. interface HookModalProps {
  5. afterClose: (...args: any[]) => void;
  6. config: ConfirmProps
  7. }
  8. export interface HookModalRef {
  9. destroy: () => void;
  10. update: (newConfig: ConfirmProps) => void
  11. }
  12. const HookModal = ({ afterClose, config, ...props }: PropsWithChildren<HookModalProps>, ref: React.Ref<any>) => {
  13. const [innerConfig, setInnerConfig] = React.useState(config);
  14. React.useImperativeHandle(ref, () => ({
  15. destroy: () => {
  16. setInnerConfig(originConfig => ({
  17. ...originConfig,
  18. visible: false,
  19. }));
  20. },
  21. update: newConfig => {
  22. setInnerConfig(originConfig => ({
  23. ...originConfig,
  24. ...newConfig,
  25. }));
  26. },
  27. }));
  28. const mergeAfterClose = () => {
  29. config?.afterClose?.();
  30. afterClose();
  31. };
  32. return (
  33. <ConfirmModal
  34. {...innerConfig}
  35. afterClose={mergeAfterClose}
  36. // visible={!visible ? visible : undefined}
  37. />
  38. );
  39. };
  40. export default React.forwardRef<HookModalRef, HookModalProps>(HookModal);