AugurProject/augur-ui

View on GitHub
src/modules/events/actions/wrap-log-handler.js

Summary

Maintainability
B
4 hrs
Test Coverage
import { find } from "lodash";
import { defaultLogHandler } from "modules/events/actions/default-log-handler";

export const wrapLogHandler = (logHandler = defaultLogHandler) => (
  dispatch,
  getState
) => (err, log) => {
  if (err) return console.error((log || {}).eventName, err, log);
  if (log) {
    // console.info(`${new Date().toISOString()} LOG ${log.removed ? 'REMOVED' : 'ADDED'} ${log.eventName} ${JSON.stringify(log)}`)
    const universeId = getState().universe.id;
    const isInCurrentUniverse = find(
      Object.values(log),
      value => universeId === value
    );
    if (Array.isArray(log)) {
      if (isInCurrentUniverse) dispatch(logHandler(log));
      log.forEach(log => {
        if (
          find(Object.values(log), value => universeId === value) ||
          (log.contractName === "Cash" && log.eventName === "Approval")
        )
          dispatch(logHandler(log));
      });
    } else {
      const isInCurrentUniverse = find(
        Object.values(log),
        value => universeId === value
      );
      if (
        isInCurrentUniverse ||
        (log.contractName === "Cash" && log.eventName === "Approval")
      )
        dispatch(logHandler(log));
    }
  }
};