feat(home): add loading state string for feed

This commit is contained in:
plebeius.eth
2023-10-30 12:20:21 +01:00
parent 619ef97ef3
commit a3777dfd7b
2 changed files with 97 additions and 1 deletions

View File

@@ -5,6 +5,7 @@ import { useFeed } from '@plebbit/plebbit-react-hooks';
import useDefaultSubplebbits from '../../../hooks/use-default-subplebbits';
import styles from './home.module.css';
import Post from '../../post';
import useFeedStateString from '../../../hooks/use-feed-state-string';
const lastVirtuosoStates: { [key: string]: StateSnapshot } = {};
@@ -14,7 +15,7 @@ const Home: FC = () => {
const subplebbitAddresses = useDefaultSubplebbits();
const sortType = useParams<{ sortType: string }>().sortType || 'hot';
const { feed, hasMore, loadMore } = useFeed({ subplebbitAddresses, sortType });
const loadingStateString = 'loading...';
const loadingStateString = useFeedStateString(subplebbitAddresses) || 'loading...'
useEffect(() => {
document.title = `seedit`;

View File

@@ -0,0 +1,95 @@
import { useMemo } from 'react';
import useStateString from './use-state-string';
import { useSubplebbit, useSubplebbitsStates } from '@plebbit/plebbit-react-hooks';
const clientHosts: { [key: string]: string } = {};
const getClientHost = (clientUrl: string): string => {
if (!clientHosts[clientUrl]) {
try {
clientHosts[clientUrl] = new URL(clientUrl).hostname || clientUrl;
} catch (e) {
clientHosts[clientUrl] = clientUrl;
}
}
return clientHosts[clientUrl];
};
const useFeedStateString = (subplebbitAddresses?: string[]): string | undefined => {
const subplebbitAddress = subplebbitAddresses?.length === 1 ? subplebbitAddresses[0] : undefined;
const subplebbit = useSubplebbit({ subplebbitAddress });
const singleSubplebbitFeedStateString = useStateString(subplebbit);
const { states } = useSubplebbitsStates({ subplebbitAddresses });
const multipleSubplebbitsFeedStateString = useMemo(() => {
if (subplebbitAddress) {
return
}
// e.g. infura.io: 2 resolving-address, cloudflare-ipfs.com/ipfs.io: 2 fetching-ipns 1 fetching-ipfs
let stateString = ''
if (states['resolving-address']) {
const {subplebbitAddresses, clientUrls} = states['resolving-address']
if (subplebbitAddresses.length && clientUrls.length) {
stateString += `${clientUrls.map(getClientHost).join('/')}: ${subplebbitAddresses.length} resolving-address`
}
}
// find all page client and sub addresses
const pagesStatesClientHosts = new Set()
const pagesStatesSubplebbitAddresses = new Set()
for (const state in states) {
if (state.match('page')) {
states[state].clientUrls.forEach((clientUrl) => pagesStatesClientHosts.add(getClientHost(clientUrl)))
states[state].subplebbitAddresses.forEach((subplebbitAddress) => pagesStatesSubplebbitAddresses.add(subplebbitAddress))
}
}
if (states['fetching-ipns'] || states['fetching-ipfs'] || pagesStatesSubplebbitAddresses.size) {
// separate 2 different states using ' '
if (stateString) {
stateString += ' '
}
// find all client urls
const clientHosts = new Set([...pagesStatesClientHosts])
states['fetching-ipns']?.clientUrls.forEach((clientUrl) => clientHosts.add(getClientHost(clientUrl)))
states['fetching-ipfs']?.clientUrls.forEach((clientUrl) => clientHosts.add(getClientHost(clientUrl)))
if (clientHosts.size) {
stateString += `${[...clientHosts].join('/')}: `
if (states['fetching-ipns']) {
stateString += `${states['fetching-ipns'].subplebbitAddresses.length} fetching-ipns`
}
if (states['fetching-ipfs']) {
if (states['fetching-ipns']) {
stateString += ' '
}
stateString += `${states['fetching-ipfs'].subplebbitAddresses.length} fetching-ipfs`
}
if (pagesStatesSubplebbitAddresses.size) {
if (states['fetching-ipns'] || states['fetching-ipfs']) {
stateString += ' '
}
stateString += `${pagesStatesSubplebbitAddresses.size} fetching-page`
}
}
}
if (stateString) {
stateString += '...'
}
// if string is empty, return undefined instead
return stateString === '' ? undefined : stateString
}, [states, subplebbitAddress])
if (singleSubplebbitFeedStateString) {
return singleSubplebbitFeedStateString
}
return multipleSubplebbitsFeedStateString
}
export default useFeedStateString