Files
Readarr/frontend/src/Components/Page/Header/ArtistSearchInputConnector.js
T
2020-05-09 22:24:45 +01:00

67 lines
1.7 KiB
JavaScript

import { connect } from 'react-redux';
import { push } from 'connected-react-router';
import { createSelector } from 'reselect';
import createAllArtistSelector from 'Store/Selectors/createAllArtistSelector';
import createDeepEqualSelector from 'Store/Selectors/createDeepEqualSelector';
import createTagsSelector from 'Store/Selectors/createTagsSelector';
import ArtistSearchInput from './ArtistSearchInput';
function createCleanArtistSelector() {
return createSelector(
createAllArtistSelector(),
createTagsSelector(),
(allArtists, allTags) => {
return allArtists.map((artist) => {
const {
artistName,
sortName,
images,
titleSlug,
tags = []
} = artist;
return {
artistName,
sortName,
titleSlug,
images,
tags: tags.reduce((acc, id) => {
const matchingTag = allTags.find((tag) => tag.id === id);
if (matchingTag) {
acc.push(matchingTag);
}
return acc;
}, [])
};
});
}
);
}
function createMapStateToProps() {
return createDeepEqualSelector(
createCleanArtistSelector(),
(artists) => {
return {
artists
};
}
);
}
function createMapDispatchToProps(dispatch, props) {
return {
onGoToArtist(titleSlug) {
dispatch(push(`${window.Readarr.urlBase}/author/${titleSlug}`));
},
onGoToAddNewArtist(query) {
dispatch(push(`${window.Readarr.urlBase}/add/search?term=${encodeURIComponent(query)}`));
}
};
}
export default connect(createMapStateToProps, createMapDispatchToProps)(ArtistSearchInput);