From aa808be68271648a728cdd69704c0cffeaf9a1cd Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Mon, 4 Apr 2022 14:44:31 -0500 Subject: [PATCH] Display a thread loading state --- app/soapbox/features/status/index.tsx | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/app/soapbox/features/status/index.tsx b/app/soapbox/features/status/index.tsx index 06d0e27ca4..04971be0e0 100644 --- a/app/soapbox/features/status/index.tsx +++ b/app/soapbox/features/status/index.tsx @@ -20,6 +20,7 @@ import { getSoapboxConfig } from 'soapbox/actions/soapbox'; import PullToRefresh from 'soapbox/components/pull-to-refresh'; import SubNavigation from 'soapbox/components/sub_navigation'; import { Column } from 'soapbox/components/ui'; +import PlaceholderStatus from 'soapbox/features/placeholder/components/placeholder_status'; import PendingStatus from 'soapbox/features/ui/components/pending_status'; import { blockAccount } from '../../actions/accounts'; @@ -60,6 +61,7 @@ import ActionBar from './components/action-bar'; import DetailedStatus from './components/detailed_status'; import ThreadStatus from './components/thread_status'; +import type { AxiosError } from 'axios'; import type { History } from 'history'; import type { AnyAction } from 'redux'; import type { ThunkDispatch } from 'redux-thunk'; @@ -185,6 +187,8 @@ interface IStatusState { showMedia: boolean, loadedStatusId?: string, emojiSelectorFocused: boolean, + isLoaded: boolean, + error?: AxiosError, } class Status extends ImmutablePureComponent { @@ -194,6 +198,8 @@ class Status extends ImmutablePureComponent { showMedia: defaultMediaVisibility(this.props.status, this.props.displayMedia), loadedStatusId: undefined, emojiSelectorFocused: false, + isLoaded: Boolean(this.props.status), + error: undefined, }; node: HTMLDivElement | null = null; @@ -208,7 +214,11 @@ class Status extends ImmutablePureComponent { } componentDidMount() { - this.fetchData(); + this.fetchData().then(() => { + this.setState({ isLoaded: true }); + }).catch(error => { + this.setState({ error, isLoaded: true }); + }); attachFullscreenListener(this.onFullScreenChange); } @@ -635,10 +645,15 @@ class Status extends ImmutablePureComponent { let ancestors, descendants; const { status, ancestorsIds, descendantsIds, intl } = this.props; - if (status === null) { + if (!status && this.state.isLoaded) { + // TODO: handle errors other than 404 with `this.state.error?.response?.status` return ( ); + } else if (!status) { + return ( + + ); } if (ancestorsIds && ancestorsIds.size > 0) {