Skip to content

Commit

Permalink
Merge pull request #49 from supriyaamisshra/bug-fix-async-stream-loading
Browse files Browse the repository at this point in the history
Fix #44 - Streams async load ordering
  • Loading branch information
codenamejason authored Mar 18, 2022
2 parents 70c6fe6 + 1c19af0 commit 88c82f6
Showing 1 changed file with 26 additions and 14 deletions.
40 changes: 26 additions & 14 deletions packages/react-app/src/views/Home.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -84,21 +84,33 @@ export default function Home({

const [sData, setData] = useState([]);

useEffect(async () => {
// parallely load all available streams data
Promise.all(
streams.map(async (stream) => {
const summary = await resolveStreamSummary(stream.stream, mainnetProvider);
return {...stream, 3: summary.cap, percent: summary.percent};
})
).then(results => {
setData(results);
useEffect(() => {
let shouldCancel = false;
const fetchStreams = async () => {
// parallely load all available streams data
Promise.all(
streams.map(async (stream) => {
const summary = await resolveStreamSummary(stream.stream, mainnetProvider);
return { ...stream, 3: summary.cap, percent: summary.percent };
})
).then(results => {
// process promised streams only when this effect call is not cancelled.
if (!shouldCancel) {
setData(results);

// Wait until list is almost fully loaded to render
if (results.length >= 20) {
setReady(true);
}
});
// Wait until list is almost fully loaded to render
if (results.length >= 18) {
setReady(true);
}
}
});
}

fetchStreams()
.catch(console.error);

// cleanup callback
return () => shouldCancel = true;
}, [streams]);

const createNewStream = async () => {
Expand Down

0 comments on commit 88c82f6

Please sign in to comment.