Merge branch 'instance-fetch-fix' into 'develop'
Catch instance/fetch error, only set instance_fetch_failed on 404 See merge request soapbox-pub/soapbox-fe!1296
This commit is contained in:
commit
9fc79c942e
2 changed files with 13 additions and 6 deletions
|
@ -39,12 +39,16 @@ const needsNodeinfo = (instance: Record<string, any>): boolean => {
|
|||
|
||||
export const fetchInstance = createAsyncThunk<void, void, { state: RootState }>(
|
||||
'instance/fetch',
|
||||
async(_arg, { dispatch, getState }) => {
|
||||
const { data: instance } = await api(getState).get('/api/v1/instance');
|
||||
if (needsNodeinfo(instance)) {
|
||||
dispatch(fetchNodeinfo());
|
||||
async(_arg, { dispatch, getState, rejectWithValue }) => {
|
||||
try {
|
||||
const { data: instance } = await api(getState).get('/api/v1/instance');
|
||||
if (needsNodeinfo(instance)) {
|
||||
dispatch(fetchNodeinfo());
|
||||
}
|
||||
return instance;
|
||||
} catch(e) {
|
||||
return rejectWithValue(e);
|
||||
}
|
||||
return instance;
|
||||
},
|
||||
);
|
||||
|
||||
|
|
|
@ -13,7 +13,10 @@ const ReducerRecord = ImmutableRecord({
|
|||
export default function meta(state = ReducerRecord(), action: AnyAction) {
|
||||
switch(action.type) {
|
||||
case fetchInstance.rejected.type:
|
||||
return state.set('instance_fetch_failed', true);
|
||||
if (action.payload.response?.status === 404) {
|
||||
return state.set('instance_fetch_failed', true);
|
||||
}
|
||||
return state;
|
||||
default:
|
||||
return state;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue