diff --git a/app/soapbox/actions/interactions.ts b/app/soapbox/actions/interactions.ts index 70fd93317..1a90a259f 100644 --- a/app/soapbox/actions/interactions.ts +++ b/app/soapbox/actions/interactions.ts @@ -5,6 +5,7 @@ import { isLoggedIn } from 'soapbox/utils/auth'; import api from '../api'; +import { fetchRelationships } from './accounts'; import { importFetchedAccounts, importFetchedStatus } from './importer'; import type { AxiosError } from 'axios'; @@ -292,6 +293,7 @@ const fetchReblogs = (id: string) => api(getState).get(`/api/v1/statuses/${id}/reblogged_by`).then(response => { dispatch(importFetchedAccounts(response.data)); + dispatch(fetchRelationships(response.data.map((item: APIEntity) => item.id))); dispatch(fetchReblogsSuccess(id, response.data)); }).catch(error => { dispatch(fetchReblogsFail(id, error)); @@ -323,6 +325,7 @@ const fetchFavourites = (id: string) => api(getState).get(`/api/v1/statuses/${id}/favourited_by`).then(response => { dispatch(importFetchedAccounts(response.data)); + dispatch(fetchRelationships(response.data.map((item: APIEntity) => item.id))); dispatch(fetchFavouritesSuccess(id, response.data)); }).catch(error => { dispatch(fetchFavouritesFail(id, error)); diff --git a/app/soapbox/components/profile-hover-card.tsx b/app/soapbox/components/profile-hover-card.tsx index 11de952f2..e2574c755 100644 --- a/app/soapbox/components/profile-hover-card.tsx +++ b/app/soapbox/components/profile-hover-card.tsx @@ -97,7 +97,7 @@ export const ProfileHoverCard: React.FC = ({ visible = true } return (
= ({ status }): JSX. return ( {getReposts()} - + {features.emojiReacts ? getEmojiReacts() : getFavourites()} ); diff --git a/app/soapbox/features/ui/components/favourites_modal.tsx b/app/soapbox/features/ui/components/modals/favourites-modal.tsx similarity index 67% rename from app/soapbox/features/ui/components/favourites_modal.tsx rename to app/soapbox/features/ui/components/modals/favourites-modal.tsx index 60bc9123f..d414a3c09 100644 --- a/app/soapbox/features/ui/components/favourites_modal.tsx +++ b/app/soapbox/features/ui/components/modals/favourites-modal.tsx @@ -2,8 +2,7 @@ import React, { useEffect } from 'react'; import { FormattedMessage } from 'react-intl'; import { fetchFavourites } from 'soapbox/actions/interactions'; -import ScrollableList from 'soapbox/components/scrollable_list'; -import { Modal, Spinner } from 'soapbox/components/ui'; +import { Modal, Spinner, Stack } from 'soapbox/components/ui'; import AccountContainer from 'soapbox/containers/account_container'; import { useAppDispatch, useAppSelector } from 'soapbox/hooks'; @@ -34,18 +33,16 @@ const FavouritesModal: React.FC = ({ onClose, statusId }) => { if (!accountIds) { body = ; } else { - const emptyMessage = ; - body = ( - - {accountIds.map((id) => - , + + {accountIds.size > 0 ? ( + accountIds.map((id) => + , + ) + ) : ( + )} - + ); } diff --git a/app/soapbox/features/ui/util/async-components.ts b/app/soapbox/features/ui/util/async-components.ts index 8836b9a09..e73efd243 100644 --- a/app/soapbox/features/ui/util/async-components.ts +++ b/app/soapbox/features/ui/util/async-components.ts @@ -203,7 +203,7 @@ export function ReblogsModal() { } export function FavouritesModal() { - return import(/* webpackChunkName: "features/ui" */'../components/favourites_modal'); + return import(/* webpackChunkName: "features/ui" */'../components/modals/favourites-modal'); } export function ReactionsModal() { diff --git a/app/soapbox/locales/defaultMessages.json b/app/soapbox/locales/defaultMessages.json index 674824f45..2dd513e59 100644 --- a/app/soapbox/locales/defaultMessages.json +++ b/app/soapbox/locales/defaultMessages.json @@ -6035,7 +6035,7 @@ "id": "column.favourites" } ], - "path": "app/soapbox/features/ui/components/favourites_modal.json" + "path": "app/soapbox/features/ui/components/modals/favourites-modal.json" }, { "descriptors": [