import ShlinkApiClient from '../../api/ShlinkApiClient'; import ServersService from '../../servers/services/ServersService'; export const LIST_SHORT_URLS_START = 'shlink/shortUrlsList/LIST_SHORT_URLS_START'; export const LIST_SHORT_URLS_ERROR = 'shlink/shortUrlsList/LIST_SHORT_URLS_ERROR'; export const LIST_SHORT_URLS = 'shlink/shortUrlsList/LIST_SHORT_URLS'; export const UPDATE_SHORT_URLS_LIST = LIST_SHORT_URLS; const initialState = { shortUrls: [], loading: true, }; export default function reducer(state = initialState, action) { switch (action.type) { case LIST_SHORT_URLS_START: return { ...state, loading: true, error: false }; case LIST_SHORT_URLS: return { loading: false, error: false, shortUrls: action.shortUrls }; case LIST_SHORT_URLS_ERROR: return { loading: false, error: true, shortUrls: [] }; default: return state; } } export const listShortUrls = (serverId, params = {}) => { // FIXME There should be a way to not need this, however, the active server is set when any route is loaded, in an // FIXME outer component's componentDidMount, which makes it be invoked after this action const selectedServer = ServersService.findServerById(serverId); ShlinkApiClient.setConfig(selectedServer); return updateShortUrlsList(params); }; export const updateShortUrlsList = (params = {}) => async dispatch => { dispatch({ type: LIST_SHORT_URLS_START }); try { const shortUrls = await ShlinkApiClient.listShortUrls(params); dispatch({ type: LIST_SHORT_URLS, shortUrls, params }); } catch (e) { dispatch({ type: LIST_SHORT_URLS_ERROR, params }); } };