You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

81 lines
2.1 KiB

import React from 'react'
import PropTypes from 'prop-types'
import Menu from './Menu'
import Fiat from './Fiat'
import Locale from './Locale'
import styles from './Settings.scss'
class Settings extends React.Component {
constructor(props) {
super(props)
this.setWrapperRef = this.setWrapperRef.bind(this)
this.handleClickOutside = this.handleClickOutside.bind(this)
this.renderSettings = this.renderSettings.bind(this)
}
componentDidMount() {
document.addEventListener('mousedown', this.handleClickOutside)
}
componentWillUnmount() {
document.removeEventListener('mousedown', this.handleClickOutside)
}
// Set the wrapper ref
setWrapperRef(node) {
this.wrapperRef = node
}
// Alert if clicked on outside of element
handleClickOutside(event) {
const { toggleSettings, settings } = this.props
if (this.wrapperRef && !this.wrapperRef.contains(event.target) && settings.settingsOpen) {
// Do not toggle the settings if they user clicked on their alias
// as that will cause us to double toggle and re-open it
if (
typeof event.target.className === 'string' &&
event.target.className.includes('aliasText')
) {
return
}
// The user clicked outside of the settings box and not on the
// alias so we should toggle the settings
toggleSettings()
}
}
renderSettings() {
const { settings, fiatProps, localeProps, setActiveSubMenu } = this.props
switch (settings.activeSubMenu) {
case 'fiat':
return <Fiat {...fiatProps} />
case 'locale':
return <Locale {...localeProps} />
default:
return <Menu setActiveSubMenu={setActiveSubMenu} />
}
}
render() {
return (
<div className={styles.container} ref={this.setWrapperRef}>
{this.renderSettings()}
</div>
)
}
}
Settings.propTypes = {
settings: PropTypes.object.isRequired,
setActiveSubMenu: PropTypes.func.isRequired,
toggleSettings: PropTypes.func.isRequired,
fiatProps: PropTypes.object.isRequired,
localeProps: PropTypes.object.isRequired
}
export default Settings