UNPKG

react-redux-fetch

Version:

A declarative and customizable way to fetch data for React components and manage that data in the Redux state

74 lines (52 loc) 2.75 kB
'use strict'; exports.__esModule = true; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _seamlessImmutable = require('seamless-immutable'); var _seamlessImmutable2 = _interopRequireDefault(_seamlessImmutable); var _map = require('lodash/map'); var _map2 = _interopRequireDefault(_map); var _actionTypes = require('../constants/actionTypes'); var _request = require('../constants/request'); var _fetchRequest = require('../utils/fetchRequest'); var _fetchRequest2 = _interopRequireDefault(_fetchRequest); var _fetchFulfill = require('../utils/fetchFulfill'); var _fetchFulfill2 = _interopRequireDefault(_fetchFulfill); var _fetchReject = require('../utils/fetchReject'); var _fetchReject2 = _interopRequireDefault(_fetchReject); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var INITIAL_STATE = _extends({}, _request.INIT, { value: null, request: { meta: null } }); var getReducer = function getReducer() { var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : (0, _seamlessImmutable2.default)(INITIAL_STATE); var action = arguments[1]; switch (action.type) { case _actionTypes.FETCH.for('get').REQUEST: return (0, _fetchRequest2.default)(state, action); case _actionTypes.FETCH.for('get').FULFILL: if (action.request.meta && action.request.meta.addToList && state.value) { var _ret = function () { var idName = action.request.meta.addToList.idName; var id = action.request.meta.addToList.id; var newValue = state.value ? (0, _map2.default)(state.value, function (item) { if (item[idName] === id) { return action.value; } return item; }) : [action.value]; return { v: (0, _fetchFulfill2.default)(state, Object.assign({}, action, { value: newValue })) }; }(); if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v; } return (0, _fetchFulfill2.default)(state, action); case _actionTypes.FETCH.for('get').REJECT: return (0, _fetchReject2.default)(state, action); default: return state; } }; exports.default = getReducer;