diff --git a/app/soapbox/actions/favourites.js b/app/soapbox/actions/favourites.js
index 44c40cd81..dfc1ee9ba 100644
--- a/app/soapbox/actions/favourites.js
+++ b/app/soapbox/actions/favourites.js
@@ -10,6 +10,14 @@ export const FAVOURITED_STATUSES_EXPAND_REQUEST = 'FAVOURITED_STATUSES_EXPAND_RE
export const FAVOURITED_STATUSES_EXPAND_SUCCESS = 'FAVOURITED_STATUSES_EXPAND_SUCCESS';
export const FAVOURITED_STATUSES_EXPAND_FAIL = 'FAVOURITED_STATUSES_EXPAND_FAIL';
+export const ACCOUNT_FAVOURITED_STATUSES_FETCH_REQUEST = 'ACCOUNT_FAVOURITED_STATUSES_FETCH_REQUEST';
+export const ACCOUNT_FAVOURITED_STATUSES_FETCH_SUCCESS = 'ACCOUNT_FAVOURITED_STATUSES_FETCH_SUCCESS';
+export const ACCOUNT_FAVOURITED_STATUSES_FETCH_FAIL = 'ACCOUNT_FAVOURITED_STATUSES_FETCH_FAIL';
+
+export const ACCOUNT_FAVOURITED_STATUSES_EXPAND_REQUEST = 'ACCOUNT_FAVOURITED_STATUSES_EXPAND_REQUEST';
+export const ACCOUNT_FAVOURITED_STATUSES_EXPAND_SUCCESS = 'ACCOUNT_FAVOURITED_STATUSES_EXPAND_SUCCESS';
+export const ACCOUNT_FAVOURITED_STATUSES_EXPAND_FAIL = 'ACCOUNT_FAVOURITED_STATUSES_EXPAND_FAIL';
+
export function fetchFavouritedStatuses() {
return (dispatch, getState) => {
if (!isLoggedIn(getState)) return;
@@ -96,3 +104,96 @@ export function expandFavouritedStatusesFail(error) {
error,
};
}
+
+export function fetchAccountFavouritedStatuses(accountId) {
+ return (dispatch, getState) => {
+ if (!isLoggedIn(getState)) return;
+
+ if (getState().getIn(['status_lists', `favourites:${accountId}`, 'isLoading'])) {
+ return;
+ }
+
+ dispatch(fetchAccountFavouritedStatusesRequest(accountId));
+
+ api(getState).get(`/api/v1/pleroma/accounts/${accountId}/favourites`).then(response => {
+ const next = getLinks(response).refs.find(link => link.rel === 'next');
+ dispatch(importFetchedStatuses(response.data));
+ dispatch(fetchAccountFavouritedStatusesSuccess(accountId, response.data, next ? next.uri : null));
+ }).catch(error => {
+ dispatch(fetchAccountFavouritedStatusesFail(accountId, error));
+ });
+ };
+}
+
+export function fetchAccountFavouritedStatusesRequest(accountId) {
+ return {
+ type: ACCOUNT_FAVOURITED_STATUSES_FETCH_REQUEST,
+ accountId,
+ skipLoading: true,
+ };
+}
+
+export function fetchAccountFavouritedStatusesSuccess(accountId, statuses, next) {
+ return {
+ type: ACCOUNT_FAVOURITED_STATUSES_FETCH_SUCCESS,
+ accountId,
+ statuses,
+ next,
+ skipLoading: true,
+ };
+}
+
+export function fetchAccountFavouritedStatusesFail(accountId, error) {
+ return {
+ type: ACCOUNT_FAVOURITED_STATUSES_FETCH_FAIL,
+ accountId,
+ error,
+ skipLoading: true,
+ };
+}
+
+export function expandAccountFavouritedStatuses(accountId) {
+ return (dispatch, getState) => {
+ if (!isLoggedIn(getState)) return;
+
+ const url = getState().getIn(['status_lists', `favourites:${accountId}`, 'next'], null);
+
+ if (url === null || getState().getIn(['status_lists', `favourites:${accountId}`, 'isLoading'])) {
+ return;
+ }
+
+ dispatch(expandAccountFavouritedStatusesRequest(accountId));
+
+ api(getState).get(url).then(response => {
+ const next = getLinks(response).refs.find(link => link.rel === 'next');
+ dispatch(importFetchedStatuses(response.data));
+ dispatch(expandAccountFavouritedStatusesSuccess(accountId, response.data, next ? next.uri : null));
+ }).catch(error => {
+ dispatch(expandAccountFavouritedStatusesFail(accountId, error));
+ });
+ };
+}
+
+export function expandAccountFavouritedStatusesRequest(accountId) {
+ return {
+ type: ACCOUNT_FAVOURITED_STATUSES_EXPAND_REQUEST,
+ accountId,
+ };
+}
+
+export function expandAccountFavouritedStatusesSuccess(accountId, statuses, next) {
+ return {
+ type: ACCOUNT_FAVOURITED_STATUSES_EXPAND_SUCCESS,
+ accountId,
+ statuses,
+ next,
+ };
+}
+
+export function expandAccountFavouritedStatusesFail(accountId, error) {
+ return {
+ type: ACCOUNT_FAVOURITED_STATUSES_EXPAND_FAIL,
+ accountId,
+ error,
+ };
+}
diff --git a/app/soapbox/features/account/components/header.js b/app/soapbox/features/account/components/header.js
index e477306e1..426486d80 100644
--- a/app/soapbox/features/account/components/header.js
+++ b/app/soapbox/features/account/components/header.js
@@ -356,24 +356,20 @@ class Header extends ImmutablePureComponent {
}
- {
- ownAccount &&
-
-
- { /* : TODO : shortNumberFormat(account.get('favourite_count')) */ }
- •
-
-
-
- { /* : TODO : shortNumberFormat(account.get('pinned_count')) */ }
- •
-
-
-
+ {(ownAccount || !account.getIn(['pleroma', 'hide_favorites'], true)) &&
+ { /* : TODO : shortNumberFormat(account.get('favourite_count')) */ }
+ •
+
+ }
+
+ {ownAccount &&
+
+ { /* : TODO : shortNumberFormat(account.get('pinned_count')) */ }
+ •
+
+
}
diff --git a/app/soapbox/features/favourited_statuses/index.js b/app/soapbox/features/favourited_statuses/index.js
index 527afd2de..be87190fa 100644
--- a/app/soapbox/features/favourited_statuses/index.js
+++ b/app/soapbox/features/favourited_statuses/index.js
@@ -2,23 +2,55 @@ import React from 'react';
import { connect } from 'react-redux';
import PropTypes from 'prop-types';
import ImmutablePropTypes from 'react-immutable-proptypes';
-import { fetchFavouritedStatuses, expandFavouritedStatuses } from '../../actions/favourites';
+import { fetchFavouritedStatuses, expandFavouritedStatuses, fetchAccountFavouritedStatuses, expandAccountFavouritedStatuses } from '../../actions/favourites';
import Column from '../ui/components/column';
import StatusList from '../../components/status_list';
import { injectIntl, FormattedMessage } from 'react-intl';
import ImmutablePureComponent from 'react-immutable-pure-component';
import { debounce } from 'lodash';
import MissingIndicator from 'soapbox/components/missing_indicator';
+import { fetchAccount, fetchAccountByUsername } from '../../actions/accounts';
+import LoadingIndicator from '../../components/loading_indicator';
const mapStateToProps = (state, { params }) => {
const username = params.username || '';
const me = state.get('me');
const meUsername = state.getIn(['accounts', me, 'username'], '');
+
+ const isMyAccount = (username.toLowerCase() === meUsername.toLowerCase());
+
+ if (isMyAccount) {
+ return {
+ isMyAccount,
+ statusIds: state.getIn(['status_lists', 'favourites', 'items']),
+ isLoading: state.getIn(['status_lists', 'favourites', 'isLoading'], true),
+ hasMore: !!state.getIn(['status_lists', 'favourites', 'next']),
+ };
+ }
+
+ const accounts = state.getIn(['accounts']);
+ const accountFetchError = (state.getIn(['accounts', -1, 'username'], '').toLowerCase() === username.toLowerCase());
+
+ let accountId = -1;
+ if (accountFetchError) {
+ accountId = null;
+ } else {
+ const account = accounts.find(acct => username.toLowerCase() === acct.getIn(['acct'], '').toLowerCase());
+ accountId = account ? account.getIn(['id'], null) : -1;
+ }
+
+ const isBlocked = state.getIn(['relationships', accountId, 'blocked_by'], false);
+ const unavailable = (me === accountId) ? false : isBlocked;
+
return {
- isMyAccount: (username.toLowerCase() === meUsername.toLowerCase()),
- statusIds: state.getIn(['status_lists', 'favourites', 'items']),
- isLoading: state.getIn(['status_lists', 'favourites', 'isLoading'], true),
- hasMore: !!state.getIn(['status_lists', 'favourites', 'next']),
+ isMyAccount,
+ accountId,
+ unavailable,
+ username,
+ isAccount: !!state.getIn(['accounts', accountId]),
+ statusIds: state.getIn(['status_lists', `favourites:${accountId}`, 'items'], []),
+ isLoading: state.getIn(['status_lists', `favourites:${accountId}`, 'isLoading'], true),
+ hasMore: !!state.getIn(['status_lists', `favourites:${accountId}`, 'next']),
};
};
@@ -36,17 +68,43 @@ class Favourites extends ImmutablePureComponent {
};
componentDidMount() {
- this.props.dispatch(fetchFavouritedStatuses());
+ const { accountId, isMyAccount, username } = this.props;
+
+ if (isMyAccount)
+ this.props.dispatch(fetchFavouritedStatuses());
+ else {
+ if (accountId && accountId !== -1) {
+ this.props.dispatch(fetchAccount(accountId));
+ this.props.dispatch(fetchAccountFavouritedStatuses(accountId));
+ } else {
+ this.props.dispatch(fetchAccountByUsername(username));
+ }
+ }
+ }
+
+ componentDidUpdate(prevProps) {
+ const { accountId, isMyAccount } = this.props;
+
+ if (!isMyAccount && accountId && accountId !== -1 && (accountId !== prevProps.accountId && accountId)) {
+ this.props.dispatch(fetchAccount(accountId));
+ this.props.dispatch(fetchAccountFavouritedStatuses(accountId));
+ }
}
handleLoadMore = debounce(() => {
- this.props.dispatch(expandFavouritedStatuses());
+ const { accountId, isMyAccount } = this.props;
+
+ if (isMyAccount) {
+ this.props.dispatch(expandFavouritedStatuses());
+ } else {
+ this.props.dispatch(expandAccountFavouritedStatuses(accountId));
+ }
}, 300, { leading: true })
render() {
- const { statusIds, hasMore, isLoading, isMyAccount } = this.props;
+ const { statusIds, isLoading, hasMore, isMyAccount, isAccount, accountId, unavailable } = this.props;
- if (!isMyAccount) {
+ if (!isMyAccount && !isAccount && accountId !== -1) {
return (
@@ -54,7 +112,27 @@ class Favourites extends ImmutablePureComponent {
);
}
- const emptyMessage = ;
+ if (accountId === -1) {
+ return (
+
+
+
+ );
+ }
+
+ if (unavailable) {
+ return (
+
+
+
+
+
+ );
+ }
+
+ const emptyMessage = isMyAccount
+ ?
+ : ;
return (
diff --git a/app/soapbox/locales/pl.json b/app/soapbox/locales/pl.json
index 5ae873e7d..997828ce5 100644
--- a/app/soapbox/locales/pl.json
+++ b/app/soapbox/locales/pl.json
@@ -312,6 +312,7 @@
"emoji_button.search_results": "Wyniki wyszukiwania",
"emoji_button.symbols": "Symbole",
"emoji_button.travel": "Podróże i miejsca",
+ "empty_column.account_favourited_statuses": "Ten użytkownik nie polubił jeszcze żadnego wpisu.",
"empty_column.account_timeline": "Brak wpisów tutaj!",
"empty_column.account_unavailable": "Profil niedostępny",
"empty_column.aliases": "Nie utworzyłeś(-aś) jeszcze żadnego aliasu konta.",
@@ -321,7 +322,7 @@
"empty_column.community": "Lokalna oś czasu jest pusta. Napisz coś publicznie, aby zagaić!",
"empty_column.direct": "Nie masz żadnych wiadomości bezpośrednich. Kiedy dostaniesz lub wyślesz jakąś, pojawi się ona tutaj.",
"empty_column.domain_blocks": "Brak ukrytych domen.",
- "empty_column.favourited_statuses": "Nie dodałeś(-aś) żadnego wpisu do ulubionych. Kiedy to zrobisz, pojawi się on tutaj.",
+ "empty_column.favourited_statuses": "Nie polubiłeś(-aś) żadnego wpisu. Kiedy to zrobisz, pojawi się on tutaj.",
"empty_column.favourites": "Nikt nie dodał tego wpisu do ulubionych. Gdy ktoś to zrobi, pojawi się tutaj.",
"empty_column.filters": "Nie wyciszyłeś(-aś) jeszcze żadnego słowa.",
"empty_column.follow_requests": "Nie masz żadnych próśb o możliwość śledzenia. Kiedy ktoś utworzy ją, pojawi się tutaj.",
diff --git a/app/soapbox/reducers/status_lists.js b/app/soapbox/reducers/status_lists.js
index 7ac8184ac..1953e636c 100644
--- a/app/soapbox/reducers/status_lists.js
+++ b/app/soapbox/reducers/status_lists.js
@@ -5,6 +5,12 @@ import {
FAVOURITED_STATUSES_EXPAND_REQUEST,
FAVOURITED_STATUSES_EXPAND_SUCCESS,
FAVOURITED_STATUSES_EXPAND_FAIL,
+ ACCOUNT_FAVOURITED_STATUSES_FETCH_REQUEST,
+ ACCOUNT_FAVOURITED_STATUSES_FETCH_SUCCESS,
+ ACCOUNT_FAVOURITED_STATUSES_FETCH_FAIL,
+ ACCOUNT_FAVOURITED_STATUSES_EXPAND_REQUEST,
+ ACCOUNT_FAVOURITED_STATUSES_EXPAND_SUCCESS,
+ ACCOUNT_FAVOURITED_STATUSES_EXPAND_FAIL,
} from '../actions/favourites';
import {
BOOKMARKED_STATUSES_FETCH_REQUEST,
@@ -101,6 +107,16 @@ export default function statusLists(state = initialState, action) {
return normalizeList(state, 'favourites', action.statuses, action.next);
case FAVOURITED_STATUSES_EXPAND_SUCCESS:
return appendToList(state, 'favourites', action.statuses, action.next);
+ case ACCOUNT_FAVOURITED_STATUSES_FETCH_REQUEST:
+ case ACCOUNT_FAVOURITED_STATUSES_EXPAND_REQUEST:
+ return setLoading(state, `favourites:${action.accountId}`, true);
+ case ACCOUNT_FAVOURITED_STATUSES_FETCH_FAIL:
+ case ACCOUNT_FAVOURITED_STATUSES_EXPAND_FAIL:
+ return setLoading(state, `favourites:${action.accountId}`, false);
+ case ACCOUNT_FAVOURITED_STATUSES_FETCH_SUCCESS:
+ return normalizeList(state, `favourites:${action.accountId}`, action.statuses, action.next);
+ case ACCOUNT_FAVOURITED_STATUSES_EXPAND_SUCCESS:
+ return appendToList(state, `favourites:${action.accountId}`, action.statuses, action.next);
case BOOKMARKED_STATUSES_FETCH_REQUEST:
case BOOKMARKED_STATUSES_EXPAND_REQUEST:
return setLoading(state, 'bookmarks', true);