@randy.tarampi/jsx
Version:
Some common JSX components for www.randytarampi.ca
73 lines (68 loc) • 5.28 kB
JavaScript
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
import { createBlacklistFilter, createFilter, createWhitelistFilter } from "@actra-development-oss/redux-persist-transform-filter-immutable";
import { logger } from "@randy.tarampi/browser-logger";
import { Bear, Character, DeadBear, DisBear, DoubtBear, Emoji, HelloBear, LennyBear, Organization, Person, Photo, Place, Post, PostalAddress, Profile, ShrugBear, SizedPhoto } from "@randy.tarampi/js";
import { offlineStateLens, persist, persistAutoRehydrate as _persistAutoRehydrate } from "@randy.tarampi/redux-offline-immutable-config";
import { offline } from "@redux-offline/redux-offline";
import defaultReduxOfflineConfig from "@redux-offline/redux-offline/lib/defaults";
import { connectRouter, routerMiddleware } from "connected-react-router/immutable";
import Immutable, { Map } from "immutable";
import { applyMiddleware, createStore } from "redux";
import thunk from "redux-thunk";
import { composeWithDevTools } from "redux-devtools-extension";
import { combineReducers } from "redux-immutable";
import { errorMiddleware, metricsMiddleware, ravenMiddleware, routerMiddleware as meRouterMiddleware, uiMiddleware } from "../middleware";
export var reduxOfflineImmutableTransformRecords = [Bear, DeadBear, DisBear, DoubtBear, HelloBear, LennyBear, ShrugBear, Emoji, Character, Organization, Person, Photo, Place, Post, PostalAddress, Profile, SizedPhoto];
var errorStateBlacklistFilter = createBlacklistFilter("error", ["error", "errorMessage", "errorCode", "errorTimeoutHandler"]);
export var reduxOfflineConfig = _objectSpread(_objectSpread({}, defaultReduxOfflineConfig), {}, {
persist,
persistAutoRehydrate: () => _persistAutoRehydrate({
log: false
}),
persistOptions: {
records: reduxOfflineImmutableTransformRecords,
transforms: [errorStateBlacklistFilter]
},
persistCallback: () => logger.warn("Rehydrated state, but did anything else dispatch before this? 🤔"),
offlineStateLens,
returnPromises: true
});
export var createImmutableBlacklistFilter = createBlacklistFilter;
export var createImmutableFilter = createFilter;
export var createImmutableWhitelistFilter = createWhitelistFilter;
export var buildReduxOfflineConfig = function buildReduxOfflineConfig() {
var overrides = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var otherTransforms = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
var transforms = overrides.persistOptions && overrides.persistOptions.transforms && [...overrides.persistOptions.transforms] || [];
transforms.push(errorStateBlacklistFilter);
transforms.push.apply(transforms, otherTransforms);
return _objectSpread(_objectSpread(_objectSpread({}, reduxOfflineConfig), overrides), {}, {
persistOptions: _objectSpread(_objectSpread(_objectSpread({}, reduxOfflineConfig.persistOptions), overrides && overrides.persistOptions), {}, {
transforms
})
});
};
export var configureOfflineStore = function configureOfflineStore() {
var initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : Map();
var history = arguments.length > 1 ? arguments[1] : undefined;
var reducers = arguments.length > 2 ? arguments[2] : undefined;
var middleware = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : [];
var offlineConfig = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : buildReduxOfflineConfig();
var combinedMiddleware = [thunk, metricsMiddleware, routerMiddleware(history), meRouterMiddleware, uiMiddleware, errorMiddleware, ...middleware];
if (typeof window !== "undefined" && window.SENTRY_DSN && window.LOGGER && window.LOGGER.streams.sentry) {
combinedMiddleware.unshift(ravenMiddleware());
}
var reduxDevToolsOptions = {
serialize: {
immutable: Immutable,
refs: offlineConfig && offlineConfig.persistOptions && offlineConfig.persistOptions.records
}
};
var store = createStore(combineReducers(_objectSpread({
router: connectRouter(history)
}, reducers)), initialState, composeWithDevTools(reduxDevToolsOptions)(applyMiddleware(...combinedMiddleware), offline(offlineConfig)));
return store;
};
export default configureOfflineStore;