import * as React from 'react';
import classNames from 'classnames';
import FlashMessageRender from '@/components/FlashMessageRender';
import SpinnerOverlay from '@/components/elements/SpinnerOverlay';

type Props = Readonly<React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement> & {
    title?: string;
    borderColor?: string;
    showFlashes?: string | boolean;
    showLoadingOverlay?: boolean;
}>;

const ContentBox = ({ title, borderColor, showFlashes, showLoadingOverlay, children, ...props }: Props) => (
    <div {...props}>
        {title && <h2 className={'text-neutral-300 mb-4 px-4'}>{title}</h2>}
        {showFlashes &&
        <FlashMessageRender
            byKey={typeof showFlashes === 'string' ? showFlashes : undefined}
            className={'mb-4'}
        />
        }
        <div className={classNames('bg-neutral-700 p-4 rounded shadow-lg relative', borderColor, {
            'border-t-4': !!borderColor,
        })}>
            <SpinnerOverlay visible={showLoadingOverlay || false}/>
            {children}
        </div>
    </div>
);

export default ContentBox;