/* Copyright (C) 2025 QuantumNous This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . For commercial licensing, please contact support@quantumnous.com */ import React, { useMemo } from 'react'; import { Empty } from '@douyinfe/semi-ui'; import CardTable from '../../common/ui/CardTable'; import { IllustrationNoResult, IllustrationNoResultDark, } from '@douyinfe/semi-illustrations'; import { getChannelsColumns } from './ChannelsColumnDefs'; 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, // Multi-key management setShowMultiKeyManageModal, setCurrentMultiKeyChannel, } = 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, setShowMultiKeyManageModal, setCurrentMultiKeyChannel, }); }, [ t, COLUMN_KEYS, updateChannelBalance, manageChannel, manageTag, submitTagEdit, testChannel, setCurrentTestChannel, setShowModelTestModal, setEditingChannel, setShowEdit, setShowEditTag, setEditingTag, copySelectedChannel, refresh, activePage, channels, setShowMultiKeyManageModal, setCurrentMultiKeyChannel, ]); // 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;