123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215 |
- import { fromJS } from 'immutable';
- import { searchHistory } from 'mastodon/settings';
- import api from '../api';
- import { fetchRelationships } from './accounts';
- import { importFetchedAccounts, importFetchedStatuses } from './importer';
- export const SEARCH_CHANGE = 'SEARCH_CHANGE';
- export const SEARCH_CLEAR = 'SEARCH_CLEAR';
- export const SEARCH_SHOW = 'SEARCH_SHOW';
- export const SEARCH_FETCH_REQUEST = 'SEARCH_FETCH_REQUEST';
- export const SEARCH_FETCH_SUCCESS = 'SEARCH_FETCH_SUCCESS';
- export const SEARCH_FETCH_FAIL = 'SEARCH_FETCH_FAIL';
- export const SEARCH_EXPAND_REQUEST = 'SEARCH_EXPAND_REQUEST';
- export const SEARCH_EXPAND_SUCCESS = 'SEARCH_EXPAND_SUCCESS';
- export const SEARCH_EXPAND_FAIL = 'SEARCH_EXPAND_FAIL';
- export const SEARCH_HISTORY_UPDATE = 'SEARCH_HISTORY_UPDATE';
- export function changeSearch(value) {
- return {
- type: SEARCH_CHANGE,
- value,
- };
- }
- export function clearSearch() {
- return {
- type: SEARCH_CLEAR,
- };
- }
- export function submitSearch(type) {
- return (dispatch, getState) => {
- const value = getState().getIn(['search', 'value']);
- const signedIn = !!getState().getIn(['meta', 'me']);
- if (value.length === 0) {
- dispatch(fetchSearchSuccess({ accounts: [], statuses: [], hashtags: [] }, '', type));
- return;
- }
- dispatch(fetchSearchRequest(type));
- api(getState).get('/api/v2/search', {
- params: {
- q: value,
- resolve: signedIn,
- limit: 11,
- type,
- },
- }).then(response => {
- if (response.data.accounts) {
- dispatch(importFetchedAccounts(response.data.accounts));
- }
- if (response.data.statuses) {
- dispatch(importFetchedStatuses(response.data.statuses));
- }
- dispatch(fetchSearchSuccess(response.data, value, type));
- dispatch(fetchRelationships(response.data.accounts.map(item => item.id)));
- }).catch(error => {
- dispatch(fetchSearchFail(error));
- });
- };
- }
- export function fetchSearchRequest(searchType) {
- return {
- type: SEARCH_FETCH_REQUEST,
- searchType,
- };
- }
- export function fetchSearchSuccess(results, searchTerm, searchType) {
- return {
- type: SEARCH_FETCH_SUCCESS,
- results,
- searchType,
- searchTerm,
- };
- }
- export function fetchSearchFail(error) {
- return {
- type: SEARCH_FETCH_FAIL,
- error,
- };
- }
- export const expandSearch = type => (dispatch, getState) => {
- const value = getState().getIn(['search', 'value']);
- const offset = getState().getIn(['search', 'results', type]).size - 1;
- dispatch(expandSearchRequest(type));
- api(getState).get('/api/v2/search', {
- params: {
- q: value,
- type,
- offset,
- limit: 11,
- },
- }).then(({ data }) => {
- if (data.accounts) {
- dispatch(importFetchedAccounts(data.accounts));
- }
- if (data.statuses) {
- dispatch(importFetchedStatuses(data.statuses));
- }
- dispatch(expandSearchSuccess(data, value, type));
- dispatch(fetchRelationships(data.accounts.map(item => item.id)));
- }).catch(error => {
- dispatch(expandSearchFail(error));
- });
- };
- export const expandSearchRequest = (searchType) => ({
- type: SEARCH_EXPAND_REQUEST,
- searchType,
- });
- export const expandSearchSuccess = (results, searchTerm, searchType) => ({
- type: SEARCH_EXPAND_SUCCESS,
- results,
- searchTerm,
- searchType,
- });
- export const expandSearchFail = error => ({
- type: SEARCH_EXPAND_FAIL,
- error,
- });
- export const showSearch = () => ({
- type: SEARCH_SHOW,
- });
- export const openURL = (value, history, onFailure) => (dispatch, getState) => {
- const signedIn = !!getState().getIn(['meta', 'me']);
- if (!signedIn) {
- if (onFailure) {
- onFailure();
- }
- return;
- }
- dispatch(fetchSearchRequest());
- api(getState).get('/api/v2/search', { params: { q: value, resolve: true } }).then(response => {
- if (response.data.accounts?.length > 0) {
- dispatch(importFetchedAccounts(response.data.accounts));
- history.push(`/@${response.data.accounts[0].acct}`);
- } else if (response.data.statuses?.length > 0) {
- dispatch(importFetchedStatuses(response.data.statuses));
- history.push(`/@${response.data.statuses[0].account.acct}/${response.data.statuses[0].id}`);
- } else if (onFailure) {
- onFailure();
- }
- dispatch(fetchSearchSuccess(response.data, value));
- }).catch(err => {
- dispatch(fetchSearchFail(err));
- if (onFailure) {
- onFailure();
- }
- });
- };
- export const clickSearchResult = (q, type) => (dispatch, getState) => {
- const previous = getState().getIn(['search', 'recent']);
- if (previous.some(x => x.get('q') === q && x.get('type') === type)) {
- return;
- }
- const me = getState().getIn(['meta', 'me']);
- const current = previous.add(fromJS({ type, q })).takeLast(4);
- searchHistory.set(me, current.toJS());
- dispatch(updateSearchHistory(current));
- };
- export const forgetSearchResult = q => (dispatch, getState) => {
- const previous = getState().getIn(['search', 'recent']);
- const me = getState().getIn(['meta', 'me']);
- const current = previous.filterNot(result => result.get('q') === q);
- searchHistory.set(me, current.toJS());
- dispatch(updateSearchHistory(current));
- };
- export const updateSearchHistory = recent => ({
- type: SEARCH_HISTORY_UPDATE,
- recent,
- });
- export const hydrateSearch = () => (dispatch, getState) => {
- const me = getState().getIn(['meta', 'me']);
- const history = searchHistory.get(me);
- if (history !== null) {
- dispatch(updateSearchHistory(history));
- }
- };
|