2018-06-15 22:49:25 +03:00
|
|
|
import ShlinkApiClient from '../../api/ShlinkApiClient';
|
2018-07-28 10:56:08 +03:00
|
|
|
import ServersService from '../../servers/services/ServersService';
|
2018-06-15 22:49:25 +03:00
|
|
|
|
2018-07-15 11:39:05 +03:00
|
|
|
export const LIST_SHORT_URLS_START = 'shlink/shortUrlsList/LIST_SHORT_URLS_START';
|
2018-07-24 20:17:01 +03:00
|
|
|
export const LIST_SHORT_URLS_ERROR = 'shlink/shortUrlsList/LIST_SHORT_URLS_ERROR';
|
2018-07-15 11:28:39 +03:00
|
|
|
export const LIST_SHORT_URLS = 'shlink/shortUrlsList/LIST_SHORT_URLS';
|
2018-07-24 20:17:01 +03:00
|
|
|
export const UPDATE_SHORT_URLS_LIST = LIST_SHORT_URLS;
|
2018-07-15 11:28:39 +03:00
|
|
|
|
2018-07-15 11:39:05 +03:00
|
|
|
const initialState = {
|
|
|
|
shortUrls: [],
|
|
|
|
loading: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
export default function reducer(state = initialState, action) {
|
2018-06-15 22:49:25 +03:00
|
|
|
switch (action.type) {
|
2018-07-15 11:39:05 +03:00
|
|
|
case LIST_SHORT_URLS_START:
|
2018-07-24 20:17:01 +03:00
|
|
|
return { ...state, loading: true, error: false };
|
2018-06-15 22:49:25 +03:00
|
|
|
case LIST_SHORT_URLS:
|
2018-07-15 11:39:05 +03:00
|
|
|
return {
|
|
|
|
loading: false,
|
2018-07-24 20:17:01 +03:00
|
|
|
error: false,
|
2018-07-15 11:39:05 +03:00
|
|
|
shortUrls: action.shortUrls
|
|
|
|
};
|
2018-07-24 20:17:01 +03:00
|
|
|
case LIST_SHORT_URLS_ERROR:
|
|
|
|
return {
|
|
|
|
loading: false,
|
|
|
|
error: true,
|
|
|
|
shortUrls: []
|
|
|
|
};
|
2018-06-15 22:49:25 +03:00
|
|
|
default:
|
|
|
|
return state;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-06-16 12:24:42 +03:00
|
|
|
export const listShortUrls = (serverId, params = {}) => {
|
2018-07-24 20:17:01 +03:00
|
|
|
// 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);
|
2018-06-15 22:49:25 +03:00
|
|
|
|
2018-07-24 20:17:01 +03:00
|
|
|
return updateShortUrlsList(params);
|
2018-06-15 22:49:25 +03:00
|
|
|
};
|
2018-06-17 18:12:16 +03:00
|
|
|
|
|
|
|
export const updateShortUrlsList = (params = {}) => {
|
|
|
|
return async dispatch => {
|
2018-07-15 11:39:05 +03:00
|
|
|
dispatch({ type: LIST_SHORT_URLS_START });
|
2018-07-15 11:28:39 +03:00
|
|
|
|
2018-07-24 20:17:01 +03:00
|
|
|
try {
|
|
|
|
const shortUrls = await ShlinkApiClient.listShortUrls(params);
|
|
|
|
dispatch({ type: LIST_SHORT_URLS, shortUrls, params });
|
|
|
|
} catch (e) {
|
|
|
|
dispatch({ type: LIST_SHORT_URLS_ERROR, params });
|
|
|
|
}
|
2018-06-17 18:12:16 +03:00
|
|
|
};
|
|
|
|
};
|