Last active
August 24, 2019 22:30
-
-
Save ryan2clw/0a7556c9ed4c6a3d2180c6e5643aa956 to your computer and use it in GitHub Desktop.
Card action and reducer
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import { actionTypes } from './actionTypes'; | |
import { action as act } from 'typesafe-actions' | |
import { getCards } from '../webservices/bingoService'; | |
import { Reducer, AnyAction } from 'redux' | |
import { Dispatch } from 'react'; | |
import { danger, clear } from './messages'; | |
/* Card Interface */ | |
export interface ICardArray { | |
readonly [key: number]: ICard, | |
readonly cards: ICard[], | |
} | |
export interface IRow { | |
readonly b_val: string, | |
readonly i_val: string, | |
readonly n_val: string, | |
readonly g_val: string, | |
readonly o_val: string, | |
} | |
export interface ICard { | |
readonly id: number, | |
readonly [key: number]: IRow, | |
readonly rows: IRow[], | |
} | |
/* Card Actions */ | |
const fetchRequest = (cardCount: number, meta: string) => act(actionTypes.CARD_REQUEST, cardCount, meta) | |
const fetchSuccess = (data: ICardArray) => act(actionTypes.CARD_SUCCESS, data) | |
const fetchFailure = (error: string) => act(actionTypes.CARD_FAILURE, error) | |
export const requestNumbers = async (cardCount = 1, dispatch: Dispatch<AnyAction>) => { | |
dispatch(fetchRequest(cardCount, "Requesting cards")) | |
getCards(cardCount) | |
.then( | |
(payload) => { | |
return dispatch(fetchSuccess(payload)); | |
}, | |
(error) => { | |
dispatch(fetchFailure(error.toString())); // for debugging with redux-logger | |
dispatch(danger(error.toString())); // sends error to the UI | |
setTimeout(() => { | |
dispatch(clear()); // clear error after 10 seconds from UI | |
}, 10000); | |
}, | |
); | |
} | |
/* Reducers map actions to state, set the default here */ | |
const initialState = { | |
cards: [], | |
} | |
/* Card Reducer */ | |
export const cardReducer: Reducer<ICardArray> = (state = initialState, action) => { | |
switch (action.type) { | |
case actionTypes.CARD_REQUEST: | |
return { | |
...state, | |
}; | |
case actionTypes.CARD_SUCCESS: | |
return { | |
...state, | |
cards: action.payload, | |
}; | |
case actionTypes.CARD_FAILURE: | |
return { | |
cards: [], | |
error: action.error, | |
}; | |
default: | |
return state; | |
} | |
}; |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment