import { TChangeLanguage, TChangeNodeRequestedOneTime, TAddCustomNode, TRemoveCustomNode, TAddCustomNetwork, AddCustomNodeAction, changeLanguage, changeNodeRequestedOneTime, addCustomNode, removeCustomNode, addCustomNetwork } from 'actions/config'; import logo from 'assets/images/logo-mycrypto.svg'; import { OldDropDown } from 'components/ui'; import React, { Component } from 'react'; import classnames from 'classnames'; import { Link } from 'react-router-dom'; import { TSetGasPriceField, setGasPriceField } from 'actions/transaction'; import { ANNOUNCEMENT_MESSAGE, ANNOUNCEMENT_TYPE, languages } from 'config'; import Navigation from './components/Navigation'; import OnlineStatus from './components/OnlineStatus'; import NetworkDropdown from './components/NetworkDropdown'; import CustomNodeModal from 'components/CustomNodeModal'; import { getKeyByValue } from 'utils/helpers'; import { AppState } from 'reducers'; import { getOffline, isNodeChanging, getLanguageSelection, getNetworkConfig, isStaticNodeId } from 'selectors/config'; import { NetworkConfig } from 'types/network'; import { connect, MapStateToProps } from 'react-redux'; import './index.scss'; interface OwnProps { networkParam: string | null; } interface DispatchProps { changeLanguage: TChangeLanguage; changeNodeRequestedOneTime: TChangeNodeRequestedOneTime; setGasPriceField: TSetGasPriceField; addCustomNode: TAddCustomNode; removeCustomNode: TRemoveCustomNode; addCustomNetwork: TAddCustomNetwork; } interface StateProps { shouldSetNodeFromQS: boolean; network: NetworkConfig; languageSelection: AppState['config']['meta']['languageSelection']; isChangingNode: AppState['config']['nodes']['selectedNode']['pending']; isOffline: AppState['config']['meta']['offline']; } const mapStateToProps: MapStateToProps = ( state, { networkParam } ): StateProps => ({ shouldSetNodeFromQS: !!(networkParam && isStaticNodeId(state, networkParam)), isOffline: getOffline(state), isChangingNode: isNodeChanging(state), languageSelection: getLanguageSelection(state), network: getNetworkConfig(state) }); const mapDispatchToProps: DispatchProps = { setGasPriceField, changeLanguage, changeNodeRequestedOneTime, addCustomNode, removeCustomNode, addCustomNetwork }; interface State { isAddingCustomNode: boolean; } type Props = OwnProps & StateProps & DispatchProps; class Header extends Component { public state = { isAddingCustomNode: false }; public componentDidMount() { this.attemptSetNodeFromQueryParameter(); } public render() { const { languageSelection, isChangingNode, isOffline, network } = this.props; const { isAddingCustomNode } = this.state; const selectedLanguage = languageSelection; const LanguageDropDown = OldDropDown as new () => OldDropDown; return (
{ANNOUNCEMENT_MESSAGE && (
{ANNOUNCEMENT_MESSAGE}
)}
MyCrypto logo
); } public changeLanguage = (value: string) => { const key = getKeyByValue(languages, value); if (key) { this.props.changeLanguage(key); } }; private openCustomNodeModal = () => { this.setState({ isAddingCustomNode: true }); }; private closeCustomNodeModal = () => { this.setState({ isAddingCustomNode: false }); }; private addCustomNode = (payload: AddCustomNodeAction['payload']) => { this.setState({ isAddingCustomNode: false }); this.props.addCustomNode(payload); }; private attemptSetNodeFromQueryParameter() { const { shouldSetNodeFromQS, networkParam } = this.props; if (shouldSetNodeFromQS) { this.props.changeNodeRequestedOneTime(networkParam!); } } } export default connect(mapStateToProps, mapDispatchToProps)(Header);