From fcfab79bed90cc2b2b5ed8235a30e2afb697a12e Mon Sep 17 00:00:00 2001 From: Alejandro Celaya Date: Sun, 17 Mar 2019 09:38:37 +0100 Subject: [PATCH] Refactored shortUrlDetail reducer to take advantage of redux-actions --- src/visits/reducers/shortUrlDetail.js | 33 +++++++-------------------- 1 file changed, 8 insertions(+), 25 deletions(-) diff --git a/src/visits/reducers/shortUrlDetail.js b/src/visits/reducers/shortUrlDetail.js index 385c8071..cd06db65 100644 --- a/src/visits/reducers/shortUrlDetail.js +++ b/src/visits/reducers/shortUrlDetail.js @@ -1,11 +1,12 @@ +import { handleActions } from 'redux-actions'; import PropTypes from 'prop-types'; import { shortUrlType } from '../../short-urls/reducers/shortUrlsList'; -/* eslint-disable padding-line-between-statements, newline-after-var */ +/* eslint-disable padding-line-between-statements */ export const GET_SHORT_URL_DETAIL_START = 'shlink/shortUrlDetail/GET_SHORT_URL_DETAIL_START'; export const GET_SHORT_URL_DETAIL_ERROR = 'shlink/shortUrlDetail/GET_SHORT_URL_DETAIL_ERROR'; export const GET_SHORT_URL_DETAIL = 'shlink/shortUrlDetail/GET_SHORT_URL_DETAIL'; -/* eslint-enable padding-line-between-statements, newline-after-var */ +/* eslint-enable padding-line-between-statements */ export const shortUrlDetailType = PropTypes.shape({ shortUrl: shortUrlType, @@ -19,29 +20,11 @@ const initialState = { error: false, }; -export default function reducer(state = initialState, action) { - switch (action.type) { - case GET_SHORT_URL_DETAIL_START: - return { - ...state, - loading: true, - }; - case GET_SHORT_URL_DETAIL_ERROR: - return { - ...state, - loading: false, - error: true, - }; - case GET_SHORT_URL_DETAIL: - return { - shortUrl: action.shortUrl, - loading: false, - error: false, - }; - default: - return state; - } -} +export default handleActions({ + [GET_SHORT_URL_DETAIL_START]: (state) => ({ ...state, loading: true }), + [GET_SHORT_URL_DETAIL_ERROR]: (state) => ({ ...state, loading: false, error: true }), + [GET_SHORT_URL_DETAIL]: (state, { shortUrl }) => ({ shortUrl, loading: false, error: false }), +}, initialState); export const getShortUrlDetail = (buildShlinkApiClient) => (shortCode) => async (dispatch, getState) => { dispatch({ type: GET_SHORT_URL_DETAIL_START });