shlink-web-client/src/short-urls/reducers/shortUrlsList.js

72 lines
2.2 KiB
JavaScript
Raw Normal View History

2018-12-21 12:58:51 +03:00
import { assoc, assocPath, propEq, reject } from 'ramda';
import PropTypes from 'prop-types';
import { SHORT_URL_TAGS_EDITED } from './shortUrlTags';
2018-09-16 11:47:17 +03:00
import { SHORT_URL_DELETED } from './shortUrlDeletion';
2018-06-15 22:49:25 +03:00
/* eslint-disable padding-line-between-statements, newline-after-var */
2018-12-21 12:58:51 +03:00
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';
/* eslint-enable padding-line-between-statements, newline-after-var */
export const shortUrlType = PropTypes.shape({
tags: PropTypes.arrayOf(PropTypes.string),
shortCode: PropTypes.string,
originalUrl: PropTypes.string,
});
const initialState = {
2018-08-05 09:13:12 +03:00
shortUrls: {},
loading: true,
2018-12-21 12:58:51 +03:00
error: false,
};
export default function reducer(state = initialState, action) {
2018-06-15 22:49:25 +03:00
switch (action.type) {
case LIST_SHORT_URLS_START:
return { ...state, loading: true, error: false };
2018-06-15 22:49:25 +03:00
case LIST_SHORT_URLS:
return {
loading: false,
error: false,
shortUrls: action.shortUrls,
};
case LIST_SHORT_URLS_ERROR:
return {
loading: false,
error: true,
2018-12-21 12:58:51 +03:00
shortUrls: {},
};
case SHORT_URL_TAGS_EDITED:
const { data } = state.shortUrls;
return assocPath([ 'shortUrls', 'data' ], data.map((shortUrl) =>
shortUrl.shortCode === action.shortCode
? assoc('tags', action.tags, shortUrl)
: shortUrl), state);
2018-09-16 11:47:17 +03:00
case SHORT_URL_DELETED:
return assocPath(
[ 'shortUrls', 'data' ],
2018-12-21 12:58:51 +03:00
reject(propEq('shortCode', action.shortCode), state.shortUrls.data),
2018-09-16 11:47:17 +03:00
state,
);
2018-06-15 22:49:25 +03:00
default:
return state;
}
}
export const listShortUrls = (buildShlinkApiClient) => (params = {}) => async (dispatch, getState) => {
dispatch({ type: LIST_SHORT_URLS_START });
const { selectedServer = {} } = getState();
2018-12-21 12:58:51 +03:00
const { listShortUrls } = buildShlinkApiClient(selectedServer);
try {
2018-12-21 12:58:51 +03:00
const shortUrls = await listShortUrls(params);
dispatch({ type: LIST_SHORT_URLS, shortUrls, params });
} catch (e) {
dispatch({ type: LIST_SHORT_URLS_ERROR, params });
}
};