31 lines
1.3 KiB
JavaScript
31 lines
1.3 KiB
JavaScript
import { connect } from 'react-redux';
|
|
import { doClearEmailEntry, doClearPasswordEntry } from 'redux/actions/user';
|
|
import { doSignOut, doOpenModal } from 'redux/actions/app';
|
|
import { selectClientSetting } from 'redux/selectors/settings';
|
|
import { selectGetSyncErrorMessage } from 'redux/selectors/sync';
|
|
import { selectHasNavigated } from 'redux/selectors/app';
|
|
import { selectTotalBalance, selectBalance } from 'redux/selectors/wallet';
|
|
import { selectUserVerifiedEmail, selectEmailToVerify, selectUser } from 'redux/selectors/user';
|
|
import * as MODALS from 'constants/modal_types';
|
|
import * as SETTINGS from 'constants/settings';
|
|
import Header from './view';
|
|
|
|
const select = (state) => ({
|
|
authenticated: selectUserVerifiedEmail(state),
|
|
balance: selectBalance(state),
|
|
emailToVerify: selectEmailToVerify(state),
|
|
hasNavigated: selectHasNavigated(state),
|
|
hideBalance: selectClientSetting(state, SETTINGS.HIDE_BALANCE),
|
|
totalBalance: selectTotalBalance(state),
|
|
syncError: selectGetSyncErrorMessage(state),
|
|
user: selectUser(state),
|
|
});
|
|
|
|
const perform = (dispatch) => ({
|
|
clearEmailEntry: () => dispatch(doClearEmailEntry()),
|
|
clearPasswordEntry: () => dispatch(doClearPasswordEntry()),
|
|
signOut: () => dispatch(doSignOut()),
|
|
openChangelog: (modalProps) => dispatch(doOpenModal(MODALS.CONFIRM, modalProps)),
|
|
});
|
|
|
|
export default connect(select, perform)(Header);
|