import * as SETTINGS from 'constants/settings'; import { connect } from 'react-redux'; import { selectTotalBalance, selectBalance } from 'redux/selectors/wallet'; import { formatCredits } from 'util/format-credits'; import { selectGetSyncErrorMessage } from 'redux/selectors/sync'; import { selectUserVerifiedEmail, selectUserEmail, selectEmailToVerify, selectUser } from 'redux/selectors/user'; import { doClearEmailEntry, doClearPasswordEntry } from 'redux/actions/user'; import { doSetClientSetting } from 'redux/actions/settings'; import { doSignOut, doOpenModal } from 'redux/actions/app'; import { selectClientSetting, selectLanguage } from 'redux/selectors/settings'; import { selectHasNavigated, selectActiveChannelClaim, selectActiveChannelStakedLevel } from 'redux/selectors/app'; import Header from './view'; const select = (state) => ({ language: selectLanguage(state), balance: selectBalance(state), roundedSpendableBalance: formatCredits(selectBalance(state), 2, true), roundedBalance: formatCredits(selectTotalBalance(state), 2, true), currentTheme: selectClientSetting(state, SETTINGS.THEME), automaticDarkModeEnabled: selectClientSetting(state, SETTINGS.AUTOMATIC_DARK_MODE_ENABLED), hideBalance: selectClientSetting(state, SETTINGS.HIDE_BALANCE), authenticated: selectUserVerifiedEmail(state), email: selectUserEmail(state), syncError: selectGetSyncErrorMessage(state), emailToVerify: selectEmailToVerify(state), hasNavigated: selectHasNavigated(state), user: selectUser(state), activeChannelClaim: selectActiveChannelClaim(state), activeChannelStakedLevel: selectActiveChannelStakedLevel(state), }); const perform = (dispatch) => ({ setClientSetting: (key, value, push) => dispatch(doSetClientSetting(key, value, push)), signOut: () => dispatch(doSignOut()), doOpenModal: (modal, props) => dispatch(doOpenModal(modal, props)), clearEmailEntry: () => dispatch(doClearEmailEntry()), clearPasswordEntry: () => dispatch(doClearPasswordEntry()), }); export default connect(select, perform)(Header);