Skip to content

Commit

Permalink
Converts ContextMenu into redux component
Browse files Browse the repository at this point in the history
Resolves brave#9482

Auditors: @bsclifton @bridiver

Test Plan:
  • Loading branch information
NejcZdovc committed Jun 16, 2017
1 parent 4464958 commit 899926e
Show file tree
Hide file tree
Showing 2 changed files with 61 additions and 29 deletions.
85 changes: 60 additions & 25 deletions app/renderer/components/common/contextMenu.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ const Immutable = require('immutable')

// Components
const ImmutableComponent = require('../immutableComponent')
const ReduxComponent = require('../reduxComponent')

// Actions
const windowActions = require('../../../../js/actions/windowActions')
Expand All @@ -16,6 +17,7 @@ const keyCodes = require('../../../common/constants/keyCodes')

// Utils
const cx = require('../../../../js/lib/classSet')
const frameStateUtil = require('../../../../js/state/frameStateUtil')
const {formatAccelerator, wrappingClamp} = require('../../../common/lib/formatUtil')
const {separatorMenuItem} = require('../../../common/commonMenu')

Expand Down Expand Up @@ -267,18 +269,20 @@ class ContextMenuSingle extends ImmutableComponent {
/**
* Represents a context menu including all submenus
*/
class ContextMenu extends ImmutableComponent {
constructor () {
super()
class ContextMenu extends React.Component {
constructor (props) {
super(props)
this.onKeyDown = this.onKeyDown.bind(this)
this.onClick = this.onClick.bind(this)
this.onAuxClick = this.onAuxClick.bind(this)
}

componentDidMount () {
window.addEventListener('keydown', this.onKeyDown)
window.addEventListener('keyup', this.onKeyUp)

if (this.node) {
this.node.addEventListener('auxclick', this.onAuxClick.bind(this))
this.node.addEventListener('auxclick', this.onAuxClick)
}
}

Expand Down Expand Up @@ -452,41 +456,72 @@ class ContextMenu extends ImmutableComponent {
return (this.props.selectedIndex === null) ? false : this.props.selectedIndex.length > 1
}

mergeProps (state, ownProps) {
const currentWindow = state.get('currentWindow')
const activeFrame = frameStateUtil.getActiveFrame(currentWindow) || Immutable.Map()
const selectedIndex = currentWindow.getIn(['ui', 'contextMenu', 'selectedIndex'], null)
const contextMenuDetail = currentWindow.get('contextMenuDetail', Immutable.Map())

const props = {}
props.lastZoomPercentage = activeFrame.get('lastZoomPercentage')
props.contextMenuDetail = contextMenuDetail // TODO (nejc) only primitives
props.selectedIndex = typeof selectedIndex === 'object' &&
Array.isArray(selectedIndex) &&
selectedIndex.length > 0
? selectedIndex
: null
props.selectedIndexNorm = selectedIndex === null
? [0]
: props.selectedIndex
props.selectedIndexChild = props.selectedIndex
? this.props.selectedIndex[0]
: null
props.left = contextMenuDetail.get('left')
props.right = contextMenuDetail.get('right')
props.top = contextMenuDetail.get('top')
props.bottom = contextMenuDetail.get('bottom')
props.width = contextMenuDetail.get('width')
props.maxHeight = contextMenuDetail.get('maxHeight')
props.template = contextMenuDetail.get('template')

return props
}

render () {
const selectedIndex = (this.props.selectedIndex === null) ? [0] : this.props.selectedIndex
const styles = {}
if (this.props.contextMenuDetail.get('left') !== undefined) {
styles.left = this.props.contextMenuDetail.get('left')
if (this.props.left !== undefined) {
styles.left = this.props.left
}
if (this.props.contextMenuDetail.get('right') !== undefined) {
styles.right = this.props.contextMenuDetail.get('right')
if (this.props.right !== undefined) {
styles.right = this.props.right
}
if (this.props.contextMenuDetail.get('top') !== undefined) {
styles.marginTop = this.props.contextMenuDetail.get('top')
if (this.props.top !== undefined) {
styles.marginTop = this.props.top
}
if (this.props.contextMenuDetail.get('bottom') !== undefined) {
styles.bottom = this.props.contextMenuDetail.get('bottom')
if (this.props.bottom !== undefined) {
styles.bottom = this.props.bottom
}
if (this.props.contextMenuDetail.get('width') !== undefined) {
styles.width = this.props.contextMenuDetail.get('width')
if (this.props.width !== undefined) {
styles.width = this.props.width
}
if (this.props.contextMenuDetail.get('maxHeight')) {
styles.maxHeight = this.props.contextMenuDetail.get('maxHeight')
if (this.props.maxHeight) {
styles.maxHeight = this.props.maxHeight
}

return <div
ref={(node) => { this.node = node }}
className={cx({
contextMenu: true,
reverseExpand: this.props.contextMenuDetail.get('right') !== undefined,
contextMenuScrollable: this.props.contextMenuDetail.get('maxHeight') !== undefined
reverseExpand: this.props.right !== undefined,
contextMenuScrollable: this.props.maxHeight !== undefined
})}
onClick={this.onClick.bind(this)}
onClick={this.onClick}
style={styles}>
<ContextMenuSingle contextMenuDetail={this.props.contextMenuDetail}
submenuIndex={0}
lastZoomPercentage={this.props.lastZoomPercentage}
template={this.props.contextMenuDetail.get('template')}
selectedIndex={this.props.selectedIndex ? this.props.selectedIndex[0] : null} />
template={this.props.template}
selectedIndex={this.props.selectedIndexChild} />
{
this.openedSubmenuDetails.map((openedSubmenuDetail, i) =>
<ContextMenuSingle contextMenuDetail={this.props.contextMenuDetail}
Expand All @@ -495,12 +530,12 @@ class ContextMenu extends ImmutableComponent {
template={openedSubmenuDetail.get('template')}
y={openedSubmenuDetail.get('y')}
selectedIndex={
selectedIndex && (i + 1) < selectedIndex.length
? selectedIndex[i + 1]
this.props.selectedIndexNorm && (i + 1) < this.props.selectedIndexNorm.length
? this.props.selectedIndexNorm[i + 1]
: null} />)
}
</div>
}
}

module.exports = ContextMenu
module.exports = ReduxComponent.connect(ContextMenu)
5 changes: 1 addition & 4 deletions app/renderer/components/main/main.js
Original file line number Diff line number Diff line change
Expand Up @@ -696,10 +696,7 @@ class Main extends ImmutableComponent {
onClick={this.onClickWindow}>
{
contextMenuDetail
? <ContextMenu
lastZoomPercentage={activeFrame && activeFrame.get('lastZoomPercentage')}
contextMenuDetail={contextMenuDetail}
selectedIndex={customTitlebar.contextMenuSelectedIndex} />
? <ContextMenu />
: null
}
{
Expand Down

0 comments on commit 899926e

Please sign in to comment.