import React, { useMemo } from 'react'; import { Table, Empty } from '@douyinfe/semi-ui'; import { IllustrationNoResult, IllustrationNoResultDark, } from '@douyinfe/semi-illustrations'; import { getMjLogsColumns } from './MjLogsColumnDefs.js'; const MjLogsTable = (mjLogsData) => { const { logs, loading, activePage, pageSize, logCount, compactMode, visibleColumns, handlePageChange, handlePageSizeChange, copyText, openContentModal, openImageModal, isAdminUser, t, COLUMN_KEYS, } = mjLogsData; // Get all columns const allColumns = useMemo(() => { return getMjLogsColumns({ t, COLUMN_KEYS, copyText, openContentModal, openImageModal, isAdminUser, }); }, [ t, COLUMN_KEYS, copyText, openContentModal, openImageModal, isAdminUser, ]); // Filter columns based on visibility settings const getVisibleColumns = () => { return allColumns.filter((column) => visibleColumns[column.key]); }; const visibleColumnsList = useMemo(() => { return getVisibleColumns(); }, [visibleColumns, allColumns]); const tableColumns = useMemo(() => { return compactMode ? visibleColumnsList.map(({ fixed, ...rest }) => rest) : visibleColumnsList; }, [compactMode, visibleColumnsList]); return (