Fix the loading bar with the new Redux actions (#28422)
This commit is contained in:
parent
7cfc078198
commit
8b1eeb2f90
3 changed files with 54 additions and 30 deletions
|
@ -21,7 +21,7 @@ function actionWithSkipLoadingTrue<Args extends object>(args: Args) {
|
||||||
}
|
}
|
||||||
|
|
||||||
export const followAccountSuccess = createAction(
|
export const followAccountSuccess = createAction(
|
||||||
'accounts/followAccountSuccess',
|
'accounts/followAccount/SUCCESS',
|
||||||
actionWithSkipLoadingTrue<{
|
actionWithSkipLoadingTrue<{
|
||||||
relationship: ApiRelationshipJSON;
|
relationship: ApiRelationshipJSON;
|
||||||
alreadyFollowing: boolean;
|
alreadyFollowing: boolean;
|
||||||
|
@ -29,7 +29,7 @@ export const followAccountSuccess = createAction(
|
||||||
);
|
);
|
||||||
|
|
||||||
export const unfollowAccountSuccess = createAction(
|
export const unfollowAccountSuccess = createAction(
|
||||||
'accounts/unfollowAccountSuccess',
|
'accounts/unfollowAccount/SUCCESS',
|
||||||
actionWithSkipLoadingTrue<{
|
actionWithSkipLoadingTrue<{
|
||||||
relationship: ApiRelationshipJSON;
|
relationship: ApiRelationshipJSON;
|
||||||
statuses: unknown;
|
statuses: unknown;
|
||||||
|
@ -38,60 +38,60 @@ export const unfollowAccountSuccess = createAction(
|
||||||
);
|
);
|
||||||
|
|
||||||
export const authorizeFollowRequestSuccess = createAction<{ id: string }>(
|
export const authorizeFollowRequestSuccess = createAction<{ id: string }>(
|
||||||
'accounts/followRequestAuthorizeSuccess',
|
'accounts/followRequestAuthorize/SUCCESS',
|
||||||
);
|
);
|
||||||
|
|
||||||
export const rejectFollowRequestSuccess = createAction<{ id: string }>(
|
export const rejectFollowRequestSuccess = createAction<{ id: string }>(
|
||||||
'accounts/followRequestRejectSuccess',
|
'accounts/followRequestReject/SUCCESS',
|
||||||
);
|
);
|
||||||
|
|
||||||
export const followAccountRequest = createAction(
|
export const followAccountRequest = createAction(
|
||||||
'accounts/followRequest',
|
'accounts/follow/REQUEST',
|
||||||
actionWithSkipLoadingTrue<{ id: string; locked: boolean }>,
|
actionWithSkipLoadingTrue<{ id: string; locked: boolean }>,
|
||||||
);
|
);
|
||||||
|
|
||||||
export const followAccountFail = createAction(
|
export const followAccountFail = createAction(
|
||||||
'accounts/followFail',
|
'accounts/follow/FAIL',
|
||||||
actionWithSkipLoadingTrue<{ id: string; error: string; locked: boolean }>,
|
actionWithSkipLoadingTrue<{ id: string; error: string; locked: boolean }>,
|
||||||
);
|
);
|
||||||
|
|
||||||
export const unfollowAccountRequest = createAction(
|
export const unfollowAccountRequest = createAction(
|
||||||
'accounts/unfollowRequest',
|
'accounts/unfollow/REQUEST',
|
||||||
actionWithSkipLoadingTrue<{ id: string }>,
|
actionWithSkipLoadingTrue<{ id: string }>,
|
||||||
);
|
);
|
||||||
|
|
||||||
export const unfollowAccountFail = createAction(
|
export const unfollowAccountFail = createAction(
|
||||||
'accounts/unfollowFail',
|
'accounts/unfollow/FAIL',
|
||||||
actionWithSkipLoadingTrue<{ id: string; error: string }>,
|
actionWithSkipLoadingTrue<{ id: string; error: string }>,
|
||||||
);
|
);
|
||||||
|
|
||||||
export const blockAccountSuccess = createAction<{
|
export const blockAccountSuccess = createAction<{
|
||||||
relationship: ApiRelationshipJSON;
|
relationship: ApiRelationshipJSON;
|
||||||
statuses: unknown;
|
statuses: unknown;
|
||||||
}>('accounts/blockSuccess');
|
}>('accounts/block/SUCCESS');
|
||||||
|
|
||||||
export const unblockAccountSuccess = createAction<{
|
export const unblockAccountSuccess = createAction<{
|
||||||
relationship: ApiRelationshipJSON;
|
relationship: ApiRelationshipJSON;
|
||||||
}>('accounts/unblockSuccess');
|
}>('accounts/unblock/SUCCESS');
|
||||||
|
|
||||||
export const muteAccountSuccess = createAction<{
|
export const muteAccountSuccess = createAction<{
|
||||||
relationship: ApiRelationshipJSON;
|
relationship: ApiRelationshipJSON;
|
||||||
statuses: unknown;
|
statuses: unknown;
|
||||||
}>('accounts/muteSuccess');
|
}>('accounts/mute/SUCCESS');
|
||||||
|
|
||||||
export const unmuteAccountSuccess = createAction<{
|
export const unmuteAccountSuccess = createAction<{
|
||||||
relationship: ApiRelationshipJSON;
|
relationship: ApiRelationshipJSON;
|
||||||
}>('accounts/unmuteSuccess');
|
}>('accounts/unmute/SUCCESS');
|
||||||
|
|
||||||
export const pinAccountSuccess = createAction<{
|
export const pinAccountSuccess = createAction<{
|
||||||
relationship: ApiRelationshipJSON;
|
relationship: ApiRelationshipJSON;
|
||||||
}>('accounts/pinSuccess');
|
}>('accounts/pin/SUCCESS');
|
||||||
|
|
||||||
export const unpinAccountSuccess = createAction<{
|
export const unpinAccountSuccess = createAction<{
|
||||||
relationship: ApiRelationshipJSON;
|
relationship: ApiRelationshipJSON;
|
||||||
}>('accounts/unpinSuccess');
|
}>('accounts/unpin/SUCCESS');
|
||||||
|
|
||||||
export const fetchRelationshipsSuccess = createAction(
|
export const fetchRelationshipsSuccess = createAction(
|
||||||
'relationships/fetchSuccess',
|
'relationships/fetch/SUCCESS',
|
||||||
actionWithSkipLoadingTrue<{ relationships: ApiRelationshipJSON[] }>,
|
actionWithSkipLoadingTrue<{ relationships: ApiRelationshipJSON[] }>,
|
||||||
);
|
);
|
||||||
|
|
|
@ -5,9 +5,9 @@ import type { Account } from 'mastodon/models/account';
|
||||||
export const blockDomainSuccess = createAction<{
|
export const blockDomainSuccess = createAction<{
|
||||||
domain: string;
|
domain: string;
|
||||||
accounts: Account[];
|
accounts: Account[];
|
||||||
}>('domain_blocks/blockSuccess');
|
}>('domain_blocks/block/SUCCESS');
|
||||||
|
|
||||||
export const unblockDomainSuccess = createAction<{
|
export const unblockDomainSuccess = createAction<{
|
||||||
domain: string;
|
domain: string;
|
||||||
accounts: Account[];
|
accounts: Account[];
|
||||||
}>('domain_blocks/unblockSuccess');
|
}>('domain_blocks/unblock/SUCCESS');
|
||||||
|
|
|
@ -1,3 +1,9 @@
|
||||||
|
import {
|
||||||
|
isAsyncThunkAction,
|
||||||
|
isPending as isThunkActionPending,
|
||||||
|
isFulfilled as isThunkActionFulfilled,
|
||||||
|
isRejected as isThunkActionRejected,
|
||||||
|
} from '@reduxjs/toolkit';
|
||||||
import { showLoading, hideLoading } from 'react-redux-loading-bar';
|
import { showLoading, hideLoading } from 'react-redux-loading-bar';
|
||||||
import type { AnyAction, Middleware } from 'redux';
|
import type { AnyAction, Middleware } from 'redux';
|
||||||
|
|
||||||
|
@ -21,25 +27,43 @@ export const loadingBarMiddleware = (
|
||||||
return ({ dispatch }) =>
|
return ({ dispatch }) =>
|
||||||
(next) =>
|
(next) =>
|
||||||
(action: AnyAction) => {
|
(action: AnyAction) => {
|
||||||
if (action.type && !action.skipLoading) {
|
let isPending = false;
|
||||||
|
let isFulfilled = false;
|
||||||
|
let isRejected = false;
|
||||||
|
|
||||||
|
if (
|
||||||
|
isAsyncThunkAction(action)
|
||||||
|
// TODO: once we get the first use-case for it, add a check for skipLoading
|
||||||
|
) {
|
||||||
|
if (isThunkActionPending(action)) isPending = true;
|
||||||
|
else if (isThunkActionFulfilled(action)) isFulfilled = true;
|
||||||
|
else if (isThunkActionRejected(action)) isRejected = true;
|
||||||
|
} else if (
|
||||||
|
action.type &&
|
||||||
|
!action.skipLoading &&
|
||||||
|
typeof action.type === 'string'
|
||||||
|
) {
|
||||||
const [PENDING, FULFILLED, REJECTED] = promiseTypeSuffixes;
|
const [PENDING, FULFILLED, REJECTED] = promiseTypeSuffixes;
|
||||||
|
|
||||||
const isPending = new RegExp(`${PENDING}$`, 'g');
|
const isPendingRegexp = new RegExp(`${PENDING}$`, 'g');
|
||||||
const isFulfilled = new RegExp(`${FULFILLED}$`, 'g');
|
const isFulfilledRegexp = new RegExp(`${FULFILLED}$`, 'g');
|
||||||
const isRejected = new RegExp(`${REJECTED}$`, 'g');
|
const isRejectedRegexp = new RegExp(`${REJECTED}$`, 'g');
|
||||||
|
|
||||||
if (typeof action.type === 'string') {
|
if (action.type.match(isPendingRegexp)) {
|
||||||
if (action.type.match(isPending)) {
|
isPending = true;
|
||||||
dispatch(showLoading());
|
} else if (action.type.match(isFulfilledRegexp)) {
|
||||||
} else if (
|
isFulfilled = true;
|
||||||
action.type.match(isFulfilled) ??
|
} else if (action.type.match(isRejectedRegexp)) {
|
||||||
action.type.match(isRejected)
|
isRejected = true;
|
||||||
) {
|
|
||||||
dispatch(hideLoading());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (isPending) {
|
||||||
|
dispatch(showLoading());
|
||||||
|
} else if (isFulfilled || isRejected) {
|
||||||
|
dispatch(hideLoading());
|
||||||
|
}
|
||||||
|
|
||||||
return next(action);
|
return next(action);
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue