diff --git a/src/components/SourcesTableModal/SourcesView/Topics/Table/index.tsx b/src/components/SourcesTableModal/SourcesView/Topics/Table/index.tsx index 6e797046e..2e09c4ea4 100644 --- a/src/components/SourcesTableModal/SourcesView/Topics/Table/index.tsx +++ b/src/components/SourcesTableModal/SourcesView/Topics/Table/index.tsx @@ -30,13 +30,14 @@ interface CheckboxIconProps { export const Table: React.FC = ({ setShowMuteUnmute, showMuted, + loading, onTopicEdit, onChangeFilter, checkedStates, setCheckedStates, }) => { const { close } = useModal('sourcesTable') - const [loading, setLoading] = useState(false) + const [muteLoading, setMuteLoading] = useState(false) const [anchorEl, setAnchorEl] = React.useState(null) const [selectedRefId, setSelectedRefId] = React.useState('') @@ -74,7 +75,7 @@ export const Table: React.FC = ({ const id = open ? 'simple-popover' : undefined const handleSelectedMuteUnmute = async () => { - setLoading(true) + setMuteLoading(true) try { const promises = Object.keys(checkedStates).map(async (checkedId) => { @@ -105,153 +106,153 @@ export const Table: React.FC = ({ setCheckedStates({}) - setLoading(false) + setMuteLoading(false) } catch (error) { console.error('Error:', error) - setLoading(false) + setMuteLoading(false) } } - return !data ? ( + return !loading && !data ? ( There is not any results for selected filters ) : ( <> - {!Object.keys(data).length ? ( + {data && !Object.keys(data).length ? ( There is not any results for selected filters ) : ( - - {loading ? ( - - ) : ( - <> - - {checkedCount > 0 ? ( - - - - setCheckedStates({})}> - - - - - - - {checkedCount} - selected - - - - - {showMuted ? ( - <> - Unmute ALL - - ) : ( - <> - Mute ALL - - )} - - - handlePopoverAction('mergeTopic')}> - Merge - - - + + + {checkedCount > 0 ? ( + + + + setCheckedStates({})}> + + + + + + + {checkedCount} + selected + - - - ) : ( - - + + + {showMuted ? ( + <> + Unmute ALL + + ) : ( + <> + Mute ALL + + )} + - - handleChange(ALPHABETICALLY)}> - Name - - - Type - - handleChange(EDGE_COUNT)}> - Count - - - Edge list - - handleChange(DATE)}> - Date - - - - - - - {showMuted && } - - Muted - - - - - - )} - - {data && ( - - {ids?.map((i: string) => ( - isChecked).length > 1} - onClick={handleClick} - onSearch={handleSearch} - setCheckedStates={setCheckedStates} - topic={data[i]} - /> - ))} - - )} - - {selectedRefId ? ( - - {showMuted ? ( - handlePopoverAction('unMute')}> - {' '} - Unmute - - ) : ( - handlePopoverAction('mute')}> - {' '} - Mute - - )} - handlePopoverAction('editTopic')}> - Rename - - - handlePopoverAction('mergeTopic')}> - Merge - - handlePopoverAction('addEdge')}> - Add edge - - - ) : null} - - )} + handlePopoverAction('mergeTopic')}> + Merge + + + + + + + ) : ( + + + + + handleChange(ALPHABETICALLY)}> + Name + + + Type + + handleChange(EDGE_COUNT)}> + Count + + + Edge list + + handleChange(DATE)}> + Date + + + + + + + {showMuted && } + + Muted + + + + + + )} + + {(loading || muteLoading) && !data && ( + + + + )} + + {data && ( + + {ids?.map((i: string) => ( + isChecked).length > 1} + onClick={handleClick} + onSearch={handleSearch} + setCheckedStates={setCheckedStates} + topic={data[i]} + /> + ))} + + )} + + {selectedRefId ? ( + + {showMuted ? ( + handlePopoverAction('unMute')}> + {' '} + Unmute + + ) : ( + handlePopoverAction('mute')}> + {' '} + Mute + + )} + handlePopoverAction('editTopic')}> + Rename + + + handlePopoverAction('mergeTopic')}> + Merge + + handlePopoverAction('addEdge')}> + Add edge + + + ) : null} )} @@ -368,3 +369,14 @@ const TableInnerWrapper = styled(Flex)` width: 100%; position: relative; ` + +const ClipLoaderWrapper = styled.div` + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); + z-index: 10; + display: flex; + align-items: center; + justify-content: center; +` diff --git a/src/components/SourcesTableModal/SourcesView/Topics/index.tsx b/src/components/SourcesTableModal/SourcesView/Topics/index.tsx index 530edcd5d..be34b9eed 100644 --- a/src/components/SourcesTableModal/SourcesView/Topics/index.tsx +++ b/src/components/SourcesTableModal/SourcesView/Topics/index.tsx @@ -146,26 +146,21 @@ export const TopicSources = () => { - {loading && !data ? ( - - ) : ( - <> - setFilters({ is_muted: !filters.is_muted })} - showMuted={filters.is_muted} - /> - {total > ids.length ? ( - - ) : null} - - )} +
setFilters({ is_muted: !filters.is_muted })} + showMuted={filters.is_muted} + /> + {total > ids.length ? ( + + ) : null} diff --git a/src/components/SourcesTableModal/SourcesView/types.ts b/src/components/SourcesTableModal/SourcesView/types.ts index 11c10fca4..8977299ba 100644 --- a/src/components/SourcesTableModal/SourcesView/types.ts +++ b/src/components/SourcesTableModal/SourcesView/types.ts @@ -7,6 +7,7 @@ export type Props = { export type TopicTableProps = { showMuted?: boolean + loading: boolean onTopicEdit: (id: string, action: string) => void onChangeFilter: (val: string) => void setShowMuteUnmute: () => void