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.
80 lines
2.1 KiB
80 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
|
|
|