2020-07-27 16:04:12 -04:00
|
|
|
// @flow
|
|
|
|
import * as ACTIONS from 'constants/action_types';
|
|
|
|
import { handleActions } from 'util/redux-utils';
|
2021-03-26 16:33:30 +08:00
|
|
|
import { SEARCH_OPTIONS, SEARCH_PAGE_SIZE } from 'constants/search';
|
|
|
|
import { createNormalizedSearchKey } from 'util/search';
|
2021-07-22 16:04:46 -04:00
|
|
|
import { LIGHTHOUSE_DEFAULT_TYPES } from 'config';
|
|
|
|
const defaultSearchTypes = LIGHTHOUSE_DEFAULT_TYPES && LIGHTHOUSE_DEFAULT_TYPES.split(',');
|
2020-07-27 16:04:12 -04:00
|
|
|
|
2020-12-03 12:29:47 -05:00
|
|
|
const defaultState: SearchState = {
|
|
|
|
// $FlowFixMe
|
2020-07-27 16:04:12 -04:00
|
|
|
options: {
|
2021-03-26 16:33:30 +08:00
|
|
|
[SEARCH_OPTIONS.RESULT_COUNT]: SEARCH_PAGE_SIZE,
|
2020-07-27 16:04:12 -04:00
|
|
|
[SEARCH_OPTIONS.CLAIM_TYPE]: SEARCH_OPTIONS.INCLUDE_FILES_AND_CHANNELS,
|
2021-07-22 16:04:46 -04:00
|
|
|
[SEARCH_OPTIONS.MEDIA_AUDIO]: defaultSearchTypes.includes(SEARCH_OPTIONS.MEDIA_AUDIO),
|
|
|
|
[SEARCH_OPTIONS.MEDIA_VIDEO]: defaultSearchTypes.includes(SEARCH_OPTIONS.MEDIA_VIDEO),
|
|
|
|
[SEARCH_OPTIONS.MEDIA_TEXT]: defaultSearchTypes.includes(SEARCH_OPTIONS.MEDIA_TEXT),
|
|
|
|
[SEARCH_OPTIONS.MEDIA_IMAGE]: defaultSearchTypes.includes(SEARCH_OPTIONS.MEDIA_IMAGE),
|
|
|
|
[SEARCH_OPTIONS.MEDIA_APPLICATION]: defaultSearchTypes.includes(SEARCH_OPTIONS.MEDIA_APPLICATION),
|
2020-07-27 16:04:12 -04:00
|
|
|
},
|
2021-08-17 10:03:25 -04:00
|
|
|
resultsByQuery: {},
|
2021-03-26 16:33:30 +08:00
|
|
|
hasReachedMaxResultsLength: {},
|
2020-12-03 12:29:47 -05:00
|
|
|
searching: false,
|
2022-01-24 11:07:09 -05:00
|
|
|
results: [],
|
|
|
|
mentionQuery: '',
|
2020-07-27 16:04:12 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
export default handleActions(
|
|
|
|
{
|
|
|
|
[ACTIONS.SEARCH_START]: (state: SearchState): SearchState => ({
|
|
|
|
...state,
|
|
|
|
searching: true,
|
|
|
|
}),
|
|
|
|
[ACTIONS.SEARCH_SUCCESS]: (state: SearchState, action: SearchSuccess): SearchState => {
|
2021-08-17 10:03:25 -04:00
|
|
|
const { query, uris, from, size, recsys } = action.data;
|
2021-03-26 16:33:30 +08:00
|
|
|
const normalizedQuery = createNormalizedSearchKey(query);
|
2021-08-17 10:03:25 -04:00
|
|
|
const urisForQuery = state.resultsByQuery[normalizedQuery] && state.resultsByQuery[normalizedQuery]['uris'];
|
2021-03-26 16:33:30 +08:00
|
|
|
|
|
|
|
let newUris = uris;
|
2021-08-17 10:03:25 -04:00
|
|
|
if (from !== 0 && urisForQuery) {
|
|
|
|
newUris = Array.from(new Set(urisForQuery.concat(uris)));
|
2021-03-26 16:33:30 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// The returned number of urls is less than the page size, so we're on the last page
|
|
|
|
const noMoreResults = size && uris.length < size;
|
2020-07-27 16:04:12 -04:00
|
|
|
|
2021-08-17 10:03:25 -04:00
|
|
|
const results = { uris: newUris, recsys };
|
2020-07-27 16:04:12 -04:00
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
searching: false,
|
2021-08-17 10:03:25 -04:00
|
|
|
resultsByQuery: Object.assign({}, state.resultsByQuery, { [normalizedQuery]: results }),
|
2021-03-26 16:33:30 +08:00
|
|
|
hasReachedMaxResultsLength: Object.assign({}, state.hasReachedMaxResultsLength, {
|
|
|
|
[normalizedQuery]: noMoreResults,
|
|
|
|
}),
|
2020-07-27 16:04:12 -04:00
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
[ACTIONS.SEARCH_FAIL]: (state: SearchState): SearchState => ({
|
|
|
|
...state,
|
|
|
|
searching: false,
|
|
|
|
}),
|
|
|
|
|
|
|
|
[ACTIONS.UPDATE_SEARCH_OPTIONS]: (state: SearchState, action: UpdateSearchOptions): SearchState => {
|
|
|
|
const { options: oldOptions } = state;
|
|
|
|
const newOptions = action.data;
|
|
|
|
const options = { ...oldOptions, ...newOptions };
|
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
options,
|
|
|
|
};
|
|
|
|
},
|
2022-01-24 11:07:09 -05:00
|
|
|
|
|
|
|
[ACTIONS.SET_MENTION_SEARCH_RESULTS]: (state: SearchState, action: SearchSuccess): SearchState => ({
|
|
|
|
...state,
|
|
|
|
results: action.data.uris,
|
|
|
|
mentionQuery: action.data.query,
|
|
|
|
}),
|
2020-07-27 16:04:12 -04:00
|
|
|
},
|
|
|
|
defaultState
|
|
|
|
);
|