Added fetchPopularLinks action in links redux

• Added:
- fetchPopularLinks action in links redux
This commit is contained in:
mgabdev 2020-11-06 23:30:12 -06:00
parent fc7cbbb457
commit 15d9714252
2 changed files with 61 additions and 5 deletions

@ -4,9 +4,17 @@ export const LINK_FETCH_REQUEST = 'LINK_FETCH_REQUEST'
export const LINK_FETCH_SUCCESS = 'LINK_FETCH_SUCCESS'
export const LINK_FETCH_FAIL = 'LINK_FETCH_FAIL'
export const POPULAR_LINKS_FETCH_REQUEST = 'POPULAR_LINKS_FETCH_REQUEST'
export const POPULAR_LINKS_FETCH_SUCCESS = 'POPULAR_LINKS_FETCH_SUCCESS'
export const POPULAR_LINKS_FETCH_FAIL = 'POPULAR_LINKS_FETCH_FAIL'
export const IMPORT_LINK_CARDS = 'IMPORT_LINK_CARDS'
export const fetchLinkCard = (cardId) => (dispatch, getState) => {
//If card exists, don't refetch
const card = getState().getIn(['links', 'items', `${cardId}`])
if (!!card) return
dispatch(fetchLinkCardRequest(cardId))
api(getState).get(`/api/v1/links/${cardId}`).then(({ data }) => {
@ -34,4 +42,30 @@ export const fetchLinkCardFail = (error, cardId) => ({
export const importLinkCards = (cards) => ({
type: IMPORT_LINK_CARDS,
cards,
})
})
export const fetchPopularLinks = () => (dispatch, getState) => {
const isFetched = getState().getIn(['links', 'popular', 'isFetched'], false)
if (isFetched) return
dispatch(fetchPopularLinksRequest())
api(getState).get(`/api/v1/popular_links?type=links`).then(({ data }) => {
dispatch(fetchPopularLinksSuccess(data))
})
.catch((err) => dispatch(fetchPopularLinksFail(err)))
}
export const fetchPopularLinksRequest = () => ({
type: POPULAR_LINKS_FETCH_REQUEST,
})
export const fetchPopularLinksSuccess = (cards) => ({
type: POPULAR_LINKS_FETCH_SUCCESS,
cards,
})
export const fetchPopularLinksFail = (error) => ({
type: POPULAR_LINKS_FETCH_FAIL,
error,
})

@ -8,13 +8,20 @@ import {
LINK_FETCH_SUCCESS,
LINK_FETCH_FAIL,
IMPORT_LINK_CARDS,
POPULAR_LINKS_FETCH_REQUEST,
POPULAR_LINKS_FETCH_SUCCESS,
POPULAR_LINKS_FETCH_FAIL,
} from '../actions/links'
const initialState = ImmutableMap({
isFetched: false,
isError: false,
isLoading: false,
items: ImmutableMap(),
popular: ImmutableMap({
isLoading: false,
isFetched: false,
items: ImmutableList(),
}),
})
export default function links(state = initialState, action) {
@ -26,20 +33,35 @@ export default function links(state = initialState, action) {
mutable.setIn(['items', `${action.card.id}`], fromJS(action.card))
mutable.set('isLoading', false)
mutable.set('isFetched', false)
mutable.set('isError', false)
})
case IMPORT_LINK_CARDS:
return state.withMutations((mutable) => {
action.cards.forEach((card) => mutable.setIn(['items', `${card.id}`], fromJS(card)))
mutable.set('isLoading', false)
mutable.set('isFetched', false)
mutable.set('isError', false)
})
case LINK_FETCH_FAIL:
return state.withMutations((mutable) => {
mutable.set('isLoading', false)
mutable.set('isFetched', false)
mutable.set('isError', true)
})
case POPULAR_LINKS_FETCH_REQUEST:
return state.setIn(['popular', 'isLoading'], true)
case POPULAR_LINKS_FETCH_SUCCESS:
return state.withMutations((mutable) => {
let popularIds = []
action.cards.forEach((card) => {
mutable.setIn(['items', `${card.id}`], fromJS(card))
popularIds.push(`${card.id}`)
})
mutable.setIn(['popular', 'items'], fromJS(popularIds))
mutable.setIn(['popular', 'isFetched'], true)
})
case POPULAR_LINKS_FETCH_FAIL:
return state.withMutations((mutable) => {
mutable.setIn(['popular', 'isLoading'], false)
mutable.setIn(['popular', 'isFetched'], true)
mutable.setIn(['popular', 'items'], ImmutableList())
})
default:
return state