import { useEffect, useCallback } from 'react';
import { useDispatch, useSelector } from 'react-redux';
import { getContractMethodData as getContractMethodDataAction } from '../store/actions';

import { getKnownMethodData } from '../selectors/selectors';

/**
 * Access known method data and attempt to resolve unknown method data
 *
 * encapsulates an effect that will fetch methodData when the component mounts,
 * and subsequently anytime the provided data attribute changes. Note that
 * the getContractMethodData action handles over-fetching prevention, first checking
 * if the data is in the store and returning it directly. While using this hook
 * in multiple places in a tree for the same data will create extra event ticks and
 * hit the action more frequently, it should only ever result in a single store update
 * @param {string} data - the transaction data to find method data for
 * @return {Object} contract method data
 */
export function useMethodData(data) {
  const dispatch = useDispatch();
  const knownMethodData = useSelector((state) =>
    getKnownMethodData(state, data),
  );
  const getContractMethodData = useCallback(
    (methodData) => dispatch(getContractMethodDataAction(methodData)),
    [dispatch],
  );

  useEffect(() => {
    if (data) {
      getContractMethodData(data);
    }
  }, [getContractMethodData, data]);
  return knownMethodData;
}