// Copyright 2024, Command Line Inc. // SPDX-License-Identifier: Apache-2.0 import { Button } from "@/app/element/button"; import clsx from "clsx"; import { forwardRef } from "react"; import ReactDOM from "react-dom"; import "./modal.less"; interface ModalProps { children?: React.ReactNode; description?: string; okLabel?: string; cancelLabel?: string; className?: string; onClickBackdrop?: () => void; onOk?: () => void; onCancel?: () => void; onClose?: () => void; } const Modal = forwardRef( ( { children, className, description, cancelLabel, okLabel, onCancel, onOk, onClose, onClickBackdrop, }: ModalProps, ref ) => { const renderBackdrop = (onClick) =>
; const renderFooter = () => { return onOk || onCancel; }; const renderModal = () => (
{renderBackdrop(onClickBackdrop)}
{children}
{renderFooter() && ( )}
); return ReactDOM.createPortal(renderModal(), document.getElementById("main")); } ); interface ModalContentProps { children: React.ReactNode; } function ModalContent({ children }: ModalContentProps) { return
{children}
; } interface ModalFooterProps { okLabel?: string; cancelLabel?: string; onOk?: () => void; onCancel?: () => void; } const ModalFooter = ({ onCancel, onOk, cancelLabel = "Cancel", okLabel = "Ok" }: ModalFooterProps) => { return ( ); }; interface FlexiModalProps { children?: React.ReactNode; className?: string; onClickBackdrop?: () => void; } interface FlexiModalComponent extends React.ForwardRefExoticComponent> { Content: typeof ModalContent; Footer: typeof ModalFooter; } const FlexiModal = forwardRef( ({ children, className, onClickBackdrop }: FlexiModalProps, ref) => { const renderBackdrop = (onClick: () => void) =>
; const renderModal = () => (
{renderBackdrop(onClickBackdrop)}
{children}
); return ReactDOM.createPortal(renderModal(), document.getElementById("main")!); } ); (FlexiModal as FlexiModalComponent).Content = ModalContent; (FlexiModal as FlexiModalComponent).Footer = ModalFooter; export { FlexiModal, Modal };