2022-06-15 13:11:36 -07:00
|
|
|
import { isLoggedIn } from 'soapbox/utils/auth';
|
|
|
|
|
2024-08-04 07:09:52 -07:00
|
|
|
import { getClient } from '../api';
|
2022-06-15 13:11:36 -07:00
|
|
|
|
|
|
|
import { fetchRelationships } from './accounts';
|
|
|
|
import { importFetchedAccounts } from './importer';
|
2022-07-01 13:09:07 -07:00
|
|
|
import { insertSuggestionsIntoTimeline } from './timelines';
|
2022-06-15 13:11:36 -07:00
|
|
|
|
|
|
|
import type { AppDispatch, RootState } from 'soapbox/store';
|
|
|
|
|
|
|
|
const SUGGESTIONS_FETCH_REQUEST = 'SUGGESTIONS_FETCH_REQUEST';
|
|
|
|
const SUGGESTIONS_FETCH_SUCCESS = 'SUGGESTIONS_FETCH_SUCCESS';
|
|
|
|
const SUGGESTIONS_FETCH_FAIL = 'SUGGESTIONS_FETCH_FAIL';
|
|
|
|
|
|
|
|
const SUGGESTIONS_DISMISS = 'SUGGESTIONS_DISMISS';
|
|
|
|
|
2024-08-04 07:09:52 -07:00
|
|
|
const fetchSuggestions = (limit = 50) =>
|
2022-06-15 13:11:36 -07:00
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
const state = getState();
|
2024-08-04 07:09:52 -07:00
|
|
|
const client = getClient(state);
|
2022-06-15 13:11:36 -07:00
|
|
|
const me = state.me;
|
|
|
|
|
2022-07-01 13:09:07 -07:00
|
|
|
if (!me) return null;
|
2022-06-15 13:11:36 -07:00
|
|
|
|
2024-08-04 07:09:52 -07:00
|
|
|
if (client.features.suggestions) {
|
|
|
|
dispatch({ type: SUGGESTIONS_FETCH_REQUEST, skipLoading: true });
|
|
|
|
|
|
|
|
return getClient(getState).accounts.getSuggestions(limit).then((suggestions) => {
|
|
|
|
const accounts = suggestions.map(({ account }) => account);
|
|
|
|
|
|
|
|
dispatch(importFetchedAccounts(accounts));
|
|
|
|
dispatch({ type: SUGGESTIONS_FETCH_SUCCESS, suggestions, skipLoading: true });
|
|
|
|
|
|
|
|
dispatch(fetchRelationships(accounts.map(({ id }) => id)));
|
|
|
|
return suggestions;
|
|
|
|
}).catch(error => {
|
|
|
|
dispatch({ type: SUGGESTIONS_FETCH_FAIL, error, skipLoading: true, skipAlert: true });
|
|
|
|
throw error;
|
|
|
|
});
|
2022-06-15 13:11:36 -07:00
|
|
|
} else {
|
|
|
|
// Do nothing
|
2022-07-01 13:09:07 -07:00
|
|
|
return null;
|
2022-06-15 13:11:36 -07:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-07-01 13:09:07 -07:00
|
|
|
const fetchSuggestionsForTimeline = () => (dispatch: AppDispatch, _getState: () => RootState) => {
|
2024-08-04 07:09:52 -07:00
|
|
|
dispatch(fetchSuggestions(20))?.then(() => dispatch(insertSuggestionsIntoTimeline()));
|
2022-07-01 13:09:07 -07:00
|
|
|
};
|
|
|
|
|
2022-06-15 13:11:36 -07:00
|
|
|
const dismissSuggestion = (accountId: string) =>
|
|
|
|
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
|
|
if (!isLoggedIn(getState)) return;
|
|
|
|
|
|
|
|
dispatch({
|
|
|
|
type: SUGGESTIONS_DISMISS,
|
|
|
|
id: accountId,
|
|
|
|
});
|
|
|
|
|
2024-08-04 07:09:52 -07:00
|
|
|
return getClient(getState).accounts.dismissSuggestions(accountId);
|
2022-06-15 13:11:36 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
export {
|
|
|
|
SUGGESTIONS_FETCH_REQUEST,
|
|
|
|
SUGGESTIONS_FETCH_SUCCESS,
|
|
|
|
SUGGESTIONS_FETCH_FAIL,
|
|
|
|
SUGGESTIONS_DISMISS,
|
|
|
|
fetchSuggestions,
|
2022-07-01 13:09:07 -07:00
|
|
|
fetchSuggestionsForTimeline,
|
2022-06-15 13:11:36 -07:00
|
|
|
dismissSuggestion,
|
|
|
|
};
|