Better handling of failures
Some mastodon instances are getting hit hard
This commit is contained in:
parent
951c93a070
commit
2031e88d87
3 changed files with 149 additions and 104 deletions
|
@ -276,7 +276,19 @@ function Home({ hidden }) {
|
||||||
</ul>
|
</ul>
|
||||||
)}
|
)}
|
||||||
{uiState === 'error' && (
|
{uiState === 'error' && (
|
||||||
<p class="ui-state">Error loading statuses</p>
|
<p class="ui-state">
|
||||||
|
Unable to load statuses
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
onClick={() => {
|
||||||
|
loadStatuses(true);
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
Try again
|
||||||
|
</button>
|
||||||
|
</p>
|
||||||
)}
|
)}
|
||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
|
|
|
@ -402,7 +402,14 @@ function Notifications() {
|
||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
{uiState === 'error' && (
|
{uiState === 'error' && (
|
||||||
<p class="ui-state">Error loading notifications</p>
|
<p class="ui-state">
|
||||||
|
Unable to load notifications
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
<button type="button" onClick={() => loadNotifications(true)}>
|
||||||
|
Try again
|
||||||
|
</button>
|
||||||
|
</p>
|
||||||
)}
|
)}
|
||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
|
|
|
@ -103,7 +103,6 @@ function StatusPage({ id }) {
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.error(e);
|
console.error(e);
|
||||||
setUIState('error');
|
setUIState('error');
|
||||||
alert('Error fetching status');
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -345,6 +344,7 @@ function StatusPage({ id }) {
|
||||||
</Link>
|
</Link>
|
||||||
</div>
|
</div>
|
||||||
</header>
|
</header>
|
||||||
|
{!!statuses.length && heroStatus ? (
|
||||||
<ul
|
<ul
|
||||||
class={`timeline flat contextual grow ${
|
class={`timeline flat contextual grow ${
|
||||||
uiState === 'loading' ? 'loading' : ''
|
uiState === 'loading' ? 'loading' : ''
|
||||||
|
@ -453,6 +453,32 @@ function StatusPage({ id }) {
|
||||||
</li>
|
</li>
|
||||||
)}
|
)}
|
||||||
</ul>
|
</ul>
|
||||||
|
) : (
|
||||||
|
<>
|
||||||
|
{uiState === 'loading' && (
|
||||||
|
<ul class="timeline flat contextual grow loading">
|
||||||
|
<li>
|
||||||
|
<Status skeleton size="l" />
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
)}
|
||||||
|
{uiState === 'error' && (
|
||||||
|
<p class="ui-state">
|
||||||
|
Unable to load status
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
onClick={() => {
|
||||||
|
states.reloadStatusPage++;
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
Try again
|
||||||
|
</button>
|
||||||
|
</p>
|
||||||
|
)}
|
||||||
|
</>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
Loading…
Add table
Reference in a new issue