Skip to content
This repository has been archived by the owner on Dec 11, 2019. It is now read-only.

Commit

Permalink
add tor tab indicator
Browse files Browse the repository at this point in the history
fix #14175
  • Loading branch information
diracdeltas committed Jun 22, 2018
1 parent 48554fc commit 6defed2
Show file tree
Hide file tree
Showing 3 changed files with 115 additions and 0 deletions.
1 change: 1 addition & 0 deletions app/extensions/brave/img/tabs/tor.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
112 changes: 112 additions & 0 deletions app/renderer/components/tabs/content/torIcon.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,112 @@
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/. */

const React = require('react')
const ReactDOM = require('react-dom')
const {StyleSheet} = require('aphrodite/no-important')

// Components
const ReduxComponent = require('../../reduxComponent')
const TabIcon = require('./tabIcon')

// State helpers
const frameStateUtil = require('../../../../../js/state/frameStateUtil')
const tabState = require('../../../../common/state/tabState')
const privateState = require('../../../../common/state/tabContentState/privateState')

// Styles
const globalStyles = require('../../styles/global')
const {theme} = require('../../styles/theme')
const {opacityIncreaseElementKeyframes} = require('../../styles/animations')

const torSvg = require('../../../../extensions/brave/img/tabs/tor.svg')

class TorIcon extends React.Component {
constructor (props) {
super(props)
this.setRef = this.setRef.bind(this)
}

mergeProps (state, ownProps) {
const currentWindow = state.get('currentWindow')
const tabId = ownProps.tabId
const frameKey = frameStateUtil.getFrameKeyByTabId(currentWindow, tabId)
const frame = frameStateUtil.getFrameByKey(currentWindow, frameKey)

const props = {}
props.isPinned = tabState.isTabPinned(state, tabId)
props.isActive = frameStateUtil.isFrameKeyActive(currentWindow, frameKey)
props.showTorIcon = frameStateUtil.isTor(frame) &&
privateState.showPrivateIcon(currentWindow, frameKey)
props.tabId = tabId

return props
}

componentDidMount (props) {
this.transitionInIfRequired()
}

componentDidUpdate (prevProps) {
this.transitionInIfRequired(prevProps)
}

transitionInIfRequired (prevProps) {
const shouldTransitionIn = (
// need to have the element created already
this.element &&
// should show the icon
this.props.showTorIcon &&
// state has changed
(!prevProps || !prevProps.showTorIcon)
)
if (shouldTransitionIn) {
this.element.animate(opacityIncreaseElementKeyframes, {
duration: 120,
easing: 'ease-out'
})
}
}

setRef (ref) {
this.element = ReactDOM.findDOMNode(ref)
}

render () {
if (this.props.isPinned || !this.props.showTorIcon) {
return null
}

return <TabIcon
data-test-id='torIcon'
className={[
styles.icon_private,
this.props.isActive && styles.icon_private_active
]}
ref={this.setRef}
/>
}
}

const styles = StyleSheet.create({
icon_private: {
WebkitMaskRepeat: 'no-repeat',
WebkitMaskPosition: 'center',
WebkitMaskImage: `url(${torSvg})`,
WebkitMaskSize: globalStyles.spacing.sessionIconSize,
marginRight: globalStyles.spacing.defaultTabMargin,

// Override default properties
backgroundSize: 0,
height: globalStyles.spacing.sessionIconSize,
width: globalStyles.spacing.sessionIconSize,
backgroundColor: theme.tab.icon.private.background.notActive
},

icon_private_active: {
backgroundColor: theme.tab.icon.private.background.active
}
})

module.exports = ReduxComponent.connect(TorIcon)
2 changes: 2 additions & 0 deletions app/renderer/components/tabs/tab.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ const Favicon = require('./content/favIcon')
const AudioTabIcon = require('./content/audioTabIcon')
const NewSessionIcon = require('./content/newSessionIcon')
const PrivateIcon = require('./content/privateIcon')
const TorIcon = require('./content/torIcon')
const TabTitle = require('./content/tabTitle')
const CloseTabIcon = require('./content/closeTabIcon')
const {NotificationBarCaret} = require('../main/notificationBar')
Expand Down Expand Up @@ -467,6 +468,7 @@ class Tab extends React.Component {
<TabTitle tabId={this.props.tabId} />
</div>
<PrivateIcon tabId={this.props.tabId} />
<TorIcon tabId={this.props.tabId} />
<NewSessionIcon tabId={this.props.tabId} />
<CloseTabIcon tabId={this.props.tabId} onClick={this.onTabClosedWithMouse} />
</div>
Expand Down

0 comments on commit 6defed2

Please sign in to comment.