Daniel Ternyak db1a7ca2c3
Allow network selection via query parameter (#1496)
* initial non-working design

* continue implementation

* don't export shared type

* delay before requesting currentBlock

* setup one-time node change intent

* working implementation without node pulse

* dispatch action instead of call to enable node pulse

* Remove copy changes

* add test case for delay in handleNodeChangeIntent saga

* don't redundantly change networks

* Cleanup code and add tests (#1504)
2018-04-12 18:17:46 -05:00

46 lines
1.0 KiB
TypeScript

import { getParam } from 'utils/helpers';
import queryString from 'query-string';
import React from 'react';
import { withRouter, RouteComponentProps } from 'react-router-dom';
const parse = (location: RouteComponentProps<any>['location']): Query => {
const searchStr = location.search;
const query = queryString.parse(searchStr);
return query;
};
interface IQueryResults {
[key: string]: string | null;
}
export type Param =
| 'to'
| 'data'
| 'readOnly'
| 'tokenSymbol'
| 'value'
| 'gaslimit'
| 'limit'
| 'network';
interface Props extends RouteComponentProps<{}> {
params: Param[];
withQuery(query: IQueryResults): React.ReactElement<any> | null;
}
interface Query {
[key: string]: string;
}
export const Query = withRouter<Props>(
class extends React.Component<Props, {}> {
public render() {
const { withQuery, params, location } = this.props;
const query = parse(location);
const res = params.reduce((obj, param) => ({ ...obj, [param]: getParam(query, param) }), {});
return withQuery(res);
}
}
);