You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

51 lines
1.2 KiB

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
}