import type { CSSProperties, ReactNode } from 'react'; import { useLoader } from '../context/LoaderContext.js'; import { useCheckToolsVisibility } from '../hooks/useCheckToolsVisibility.js'; const styles: Record<'container' | 'text', CSSProperties> = { container: { display: 'flex', alignItems: 'center', justifyContent: 'center', backgroundColor: ' rgba(255, 255, 255, 0.25)', flexDirection: 'column', userSelect: 'none', width: '100%', height: '100%', outline: '10px dashed rgba(0, 0, 0, 0.3)', outlineOffset: '-10px', paddingLeft: '20px', paddingRight: '20px', }, text: { padding: '15px 30px', backgroundColor: 'rgba(0, 0, 0, 0.5)', borderRadius: '39px', color: 'white', fontSize: 'x-large', fontWeight: 'bold', }, }; interface NoDataProps { isEmpty?: boolean; canOpenLoader?: boolean; emptyText?: ReactNode; style?: CSSProperties; } function NoData({ isEmpty = true, emptyText = 'Drag and drop here a JCAMP-DX, Bruker folder, Jeol jdf or NMRium file', canOpenLoader = true, style, }: NoDataProps) { const openLoader = useLoader(); const isToolEnabled = useCheckToolsVisibility(); if (!isEmpty) { return null; } return (
{isToolEnabled('import') ? emptyText : 'Importation feature has been disabled'}
); } export default NoData;