2023-02-02 00:36:53 +00:00
|
|
|
import { Box } from '@mui/material';
|
2023-02-17 05:36:39 +00:00
|
|
|
import { ReactElement, ReactNode, useMemo } from 'react';
|
2023-02-01 02:31:24 +00:00
|
|
|
|
|
|
|
const TabContent = <T,>({
|
|
|
|
changingTabId,
|
|
|
|
children,
|
2023-02-17 05:36:39 +00:00
|
|
|
retain = false,
|
2023-02-01 02:31:24 +00:00
|
|
|
tabId,
|
|
|
|
}: TabContentProps<T>): ReactElement => {
|
|
|
|
const isTabIdMatch = useMemo(
|
|
|
|
() => changingTabId === tabId,
|
|
|
|
[changingTabId, tabId],
|
|
|
|
);
|
2023-02-17 05:36:39 +00:00
|
|
|
const result = useMemo<ReactNode>(
|
|
|
|
() =>
|
|
|
|
retain ? (
|
|
|
|
<Box sx={{ display: isTabIdMatch ? 'initial' : 'none' }}>
|
|
|
|
{children}
|
|
|
|
</Box>
|
|
|
|
) : (
|
|
|
|
isTabIdMatch && children
|
|
|
|
),
|
|
|
|
[children, isTabIdMatch, retain],
|
2023-02-02 00:36:53 +00:00
|
|
|
);
|
2023-02-01 02:31:24 +00:00
|
|
|
|
2023-02-17 05:36:39 +00:00
|
|
|
return <>{result}</>;
|
2023-02-01 02:31:24 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
export default TabContent;
|