import React, { useMemo } from 'react'; import { Empty } from '@douyinfe/semi-ui'; import CardTable from '../../common/ui/CardTable.js'; import { IllustrationNoResult, IllustrationNoResultDark } from '@douyinfe/semi-illustrations'; import { getChannelsColumns } from './ChannelsColumnDefs.js'; const ChannelsTable = (channelsData) => { const { channels, loading, searching, activePage, pageSize, channelCount, enableBatchDelete, compactMode, visibleColumns, setSelectedChannels, handlePageChange, handlePageSizeChange, handleRow, t, COLUMN_KEYS, // Column functions and data updateChannelBalance, manageChannel, manageTag, submitTagEdit, testChannel, setCurrentTestChannel, setShowModelTestModal, setEditingChannel, setShowEdit, setShowEditTag, setEditingTag, copySelectedChannel, refresh, } = channelsData; // Get all columns const allColumns = useMemo(() => { return getChannelsColumns({ t, COLUMN_KEYS, updateChannelBalance, manageChannel, manageTag, submitTagEdit, testChannel, setCurrentTestChannel, setShowModelTestModal, setEditingChannel, setShowEdit, setShowEditTag, setEditingTag, copySelectedChannel, refresh, activePage, channels, }); }, [ t, COLUMN_KEYS, updateChannelBalance, manageChannel, manageTag, submitTagEdit, testChannel, setCurrentTestChannel, setShowModelTestModal, setEditingChannel, setShowEdit, setShowEditTag, setEditingTag, copySelectedChannel, refresh, activePage, channels, ]); // 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 ( { setSelectedChannels(selectedRows); }, } : null } empty={ } darkModeImage={} description={t('搜索无结果')} style={{ padding: 30 }} /> } className="rounded-xl overflow-hidden" size="middle" loading={loading || searching} /> ); }; export default ChannelsTable;