|
|
|
import { callApi } from '../api'
|
|
|
|
// ------------------------------------
|
|
|
|
// Constants
|
|
|
|
// ------------------------------------
|
|
|
|
export const GET_INFO = 'GET_INFO'
|
|
|
|
export const RECEIVE_INFO = 'RECEIVE_INFO'
|
|
|
|
|
|
|
|
// ------------------------------------
|
|
|
|
// Actions
|
|
|
|
// ------------------------------------
|
|
|
|
export function getInfo() {
|
|
|
|
return {
|
|
|
|
type: GET_INFO
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function receiveInfo(data) {
|
|
|
|
return {
|
|
|
|
type: RECEIVE_INFO,
|
|
|
|
data
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export const fetchInfo = () => async (dispatch) => {
|
|
|
|
dispatch(getInfo())
|
|
|
|
const info = await callApi('info')
|
|
|
|
dispatch(receiveInfo(info.data))
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------------------------
|
|
|
|
// Action Handlers
|
|
|
|
// ------------------------------------
|
|
|
|
const ACTION_HANDLERS = {
|
|
|
|
[GET_INFO]: state => ({ ...state, infoLoading: true }),
|
|
|
|
[RECEIVE_INFO]: (state, { data }) => ({ ...state, infoLoading: false, data })
|
|
|
|
}
|
|
|
|
|
|
|
|
// ------------------------------------
|
|
|
|
// Reducer
|
|
|
|
// ------------------------------------
|
|
|
|
const initialState = {
|
|
|
|
infoLoading: false,
|
|
|
|
data: {}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default function infoReducer(state = initialState, action) {
|
|
|
|
const handler = ACTION_HANDLERS[action.type]
|
|
|
|
|
|
|
|
return handler ? handler(state, action) : state
|
|
|
|
}
|