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.

73 lines
1.7 KiB

import { createSelector } from 'reselect'
import { callApi } from '../api'
// ------------------------------------
// Constants
// ------------------------------------
export const SET_CHANNEL = 'SET_CHANNEL'
export const GET_CHANNELS = 'GET_CHANNELS'
export const RECEIVE_CHANNELS = 'RECEIVE_CHANNELS'
// ------------------------------------
// Actions
// ------------------------------------
export function setChannel(channel) {
return {
type: SET_CHANNEL,
channel
}
}
export function getChannels() {
return {
type: GET_CHANNELS
}
}
export function receiveChannels({ channels }) {
return {
type: RECEIVE_CHANNELS,
channels
}
}
export const fetchChannels = () => async (dispatch) => {
dispatch(getChannels())
const channels = await callApi('channels')
dispatch(receiveChannels(channels.data))
}
// ------------------------------------
// Action Handlers
// ------------------------------------
const ACTION_HANDLERS = {
[SET_CHANNEL]: (state, { channel }) => ({ ...state, channel }),
[GET_CHANNELS]: (state) => ({ ...state, channelsLoading: true }),
[RECEIVE_CHANNELS]: (state, { channels }) => ({ ...state, channelsLoading: false, channels })
}
const channelsSelectors = {}
const channelSelector = state => state.channels.channel
channelsSelectors.channelModalOpen = createSelector(
channelSelector,
channel => channel ? true : false
)
export { channelsSelectors }
// ------------------------------------
// Reducer
// ------------------------------------
const initialState = {
channelsLoading: false,
channels: [],
channel: null
}
export default function channelsReducer(state = initialState, action) {
const handler = ACTION_HANDLERS[action.type]
return handler ? handler(state, action) : state
}