import React, { useMemo } from 'react'; import { Table, Empty } from '@douyinfe/semi-ui'; import { IllustrationNoResult, IllustrationNoResultDark, } from '@douyinfe/semi-illustrations'; import { getTaskLogsColumns } from './TaskLogsColumnDefs.js'; const TaskLogsTable = (taskLogsData) => { const { logs, loading, activePage, pageSize, logCount, compactMode, visibleColumns, handlePageChange, handlePageSizeChange, copyText, openContentModal, isAdminUser, t, COLUMN_KEYS, } = taskLogsData; // Get all columns const allColumns = useMemo(() => { return getTaskLogsColumns({ t, COLUMN_KEYS, copyText, openContentModal, isAdminUser, }); }, [ t, COLUMN_KEYS, copyText, openContentModal, 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 (