Merge branch 'oakes/import-relationships' into 'develop'

Import relationships and fix familiar followers dialog

See merge request soapbox-pub/soapbox!2574
This commit is contained in:
Alex Gleason 2023-06-27 18:54:45 +00:00
commit 9eff8d1e9c
3 changed files with 12 additions and 1 deletions

View file

@ -1,3 +1,5 @@
import { importEntities } from 'soapbox/entity-store/actions';
import { Entities } from 'soapbox/entity-store/entities';
import { isLoggedIn } from 'soapbox/utils/auth'; import { isLoggedIn } from 'soapbox/utils/auth';
import { getFeatures, parseVersion, PLEROMA } from 'soapbox/utils/features'; import { getFeatures, parseVersion, PLEROMA } from 'soapbox/utils/features';
@ -607,7 +609,10 @@ const fetchRelationships = (accountIds: string[]) =>
return api(getState) return api(getState)
.get(`/api/v1/accounts/relationships?${newAccountIds.map(id => `id[]=${id}`).join('&')}`) .get(`/api/v1/accounts/relationships?${newAccountIds.map(id => `id[]=${id}`).join('&')}`)
.then(response => dispatch(fetchRelationshipsSuccess(response.data))) .then(response => {
dispatch(importEntities(response.data, Entities.RELATIONSHIPS));
dispatch(fetchRelationshipsSuccess(response.data));
})
.catch(error => dispatch(fetchRelationshipsFail(error))); .catch(error => dispatch(fetchRelationshipsFail(error)));
}; };

View file

@ -2,8 +2,11 @@ import { AppDispatch, RootState } from 'soapbox/store';
import api from '../api'; import api from '../api';
import { fetchRelationships } from './accounts';
import { importFetchedAccounts } from './importer'; import { importFetchedAccounts } from './importer';
import type { APIEntity } from 'soapbox/types/entities';
export const FAMILIAR_FOLLOWERS_FETCH_REQUEST = 'FAMILIAR_FOLLOWERS_FETCH_REQUEST'; export const FAMILIAR_FOLLOWERS_FETCH_REQUEST = 'FAMILIAR_FOLLOWERS_FETCH_REQUEST';
export const FAMILIAR_FOLLOWERS_FETCH_SUCCESS = 'FAMILIAR_FOLLOWERS_FETCH_SUCCESS'; export const FAMILIAR_FOLLOWERS_FETCH_SUCCESS = 'FAMILIAR_FOLLOWERS_FETCH_SUCCESS';
export const FAMILIAR_FOLLOWERS_FETCH_FAIL = 'FAMILIAR_FOLLOWERS_FETCH_FAIL'; export const FAMILIAR_FOLLOWERS_FETCH_FAIL = 'FAMILIAR_FOLLOWERS_FETCH_FAIL';
@ -19,6 +22,7 @@ export const fetchAccountFamiliarFollowers = (accountId: string) => (dispatch: A
const accounts = data.find(({ id }: { id: string }) => id === accountId).accounts; const accounts = data.find(({ id }: { id: string }) => id === accountId).accounts;
dispatch(importFetchedAccounts(accounts)); dispatch(importFetchedAccounts(accounts));
dispatch(fetchRelationships(accounts.map((item: APIEntity) => item.id)));
dispatch({ dispatch({
type: FAMILIAR_FOLLOWERS_FETCH_SUCCESS, type: FAMILIAR_FOLLOWERS_FETCH_SUCCESS,
id: accountId, id: accountId,

View file

@ -35,6 +35,8 @@ const FamiliarFollowersModal = ({ accountId, onClose }: IFamiliarFollowersModal)
scrollKey='familiar_followers' scrollKey='familiar_followers'
emptyMessage={emptyMessage} emptyMessage={emptyMessage}
itemClassName='pb-3' itemClassName='pb-3'
style={{ height: '80vh' }}
useWindowScroll={false}
> >
{familiarFollowerIds.map(id => {familiarFollowerIds.map(id =>
<AccountContainer key={id} id={id} />, <AccountContainer key={id} id={id} />,