AugurProject/augur-ui

View on GitHub
src/modules/app/hocs/rewrite-url-params/index.jsx

Summary

Maintainability
A
1 hr
Test Coverage
import React from "react";
import PropTypes from "prop-types";
import parseQuery from "src/modules/routes/helpers/parse-query";
import * as keys from "src/modules/app/constants/endpoint-url-params";

import { createPath } from "history";

import { camelCase, compose, isEmpty, mapKeys, omit, pick } from "lodash/fp";
import makeQuery from "src/modules/routes/helpers/make-query";

const valuesToGet = Object.values(keys);
const grabParams = pick(valuesToGet);

const grabAndCamelCaseWindowParams = compose(
  mapKeys(camelCase),
  grabParams,
  parseQuery
);

export const RewriteUrlParams = windowRef => BaseCmp => {
  const WrapperCmp = props => {
    const { location } = props;
    const searchValues = parseQuery(location.search);

    const paramsToMove = grabParams(searchValues);
    if (!isEmpty(paramsToMove)) {
      const remainingSearchValues = omit(valuesToGet, searchValues);
      const path = createPath({
        ...location,
        search: makeQuery(remainingSearchValues)
      });

      windowRef.location.href = createPath({
        pathname: windowRef.location.origin,
        search: makeQuery(paramsToMove),
        hash: path
      });
    }

    // Discover params added to window location and pass to wrapped component.
    const windowParams = grabAndCamelCaseWindowParams(
      windowRef.location.search
    );

    return <BaseCmp {...props} {...windowParams} />;
  };

  WrapperCmp.propTypes = {
    location: PropTypes.object.isRequired,
    history: PropTypes.shape({
      push: PropTypes.func.isRequired,
      replace: PropTypes.func.isRequired,
      createHref: PropTypes.func.isRequired
    }).isRequired
  };

  return WrapperCmp;
};