mastodon/app/assets/javascripts/components/reducers/search.jsx

71 lines
1.6 KiB
React
Raw Normal View History

2016-11-13 13:04:18 +01:00
import {
SEARCH_CHANGE,
SEARCH_SUGGESTIONS_READY,
SEARCH_RESET
} from '../actions/search';
import Immutable from 'immutable';
const initialState = Immutable.Map({
value: '',
loaded_value: '',
suggestions: []
});
2017-03-22 04:09:09 +01:00
const normalizeSuggestions = (state, value, accounts, hashtags, statuses) => {
let newSuggestions = [];
if (accounts.length > 0) {
newSuggestions.push({
2016-11-18 15:36:16 +01:00
title: 'account',
2016-11-13 13:04:18 +01:00
items: accounts.map(item => ({
type: 'account',
id: item.id,
value: item.acct
}))
2017-03-22 04:09:09 +01:00
});
}
if (value.indexOf('@') === -1 && value.indexOf(' ') === -1 || hashtags.length > 0) {
let hashtagItems = hashtags.map(item => ({
type: 'hashtag',
id: item,
value: `#${item}`
}));
if (value.indexOf('@') === -1 && value.indexOf(' ') === -1 && hashtags.indexOf(value) === -1) {
hashtagItems.unshift({
type: 'hashtag',
id: value,
value: `#${value}`
});
2016-11-13 13:04:18 +01:00
}
newSuggestions.push({
2016-11-18 15:36:16 +01:00
title: 'hashtag',
2017-03-22 04:09:09 +01:00
items: hashtagItems
2016-11-13 13:04:18 +01:00
});
}
return state.withMutations(map => {
map.set('suggestions', newSuggestions);
map.set('loaded_value', value);
});
};
export default function search(state = initialState, action) {
switch(action.type) {
2017-03-22 04:09:09 +01:00
case SEARCH_CHANGE:
return state.set('value', action.value);
case SEARCH_SUGGESTIONS_READY:
return normalizeSuggestions(state, action.value, action.accounts, action.hashtags, action.statuses);
case SEARCH_RESET:
return state.withMutations(map => {
map.set('suggestions', []);
map.set('value', '');
map.set('loaded_value', '');
});
default:
return state;
2016-11-13 13:04:18 +01:00
}
};