UNPKG

@randy.tarampi/jsx

Version:

Some common JSX components for www.randytarampi.ca

73 lines (68 loc) 5.28 kB
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;