diff --git a/app/common/constants/appEnums.js b/app/common/constants/appEnums.js new file mode 100644 index 00000000000..e68bafec08d --- /dev/null +++ b/app/common/constants/appEnums.js @@ -0,0 +1,11 @@ +/* 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 tabs = { + MAX_ALLOWED_NEW_SESSIONS: 9 +} + +module.exports = { + tabs +} diff --git a/app/extensions/brave/img/tabs/new_session.svg b/app/extensions/brave/img/tabs/new_session.svg new file mode 100644 index 00000000000..bf4f691fffc --- /dev/null +++ b/app/extensions/brave/img/tabs/new_session.svg @@ -0,0 +1,17 @@ + + + diff --git a/app/renderer/components/styles/global.js b/app/renderer/components/styles/global.js index 11368431acf..11b3ae28e89 100644 --- a/app/renderer/components/styles/global.js +++ b/app/renderer/components/styles/global.js @@ -9,7 +9,7 @@ const globalStyles = { largeMedium: '83px', medium: '66px', mediumSmall: '53px', - small: '42px', + small: '46px', extraSmall: '33px', smallest: '19px' } @@ -166,7 +166,6 @@ const globalStyles = { closeTab: 'fa fa-times-circle', defaultIcon: 'fa fa-file-o', loading: 'fa fa-spinner fa-spin', - newSession: 'fa fa-user', private: 'fa fa-eye', refresh: 'fa fa-refresh', remove: 'fa fa-times', diff --git a/app/renderer/components/tabContent.js b/app/renderer/components/tabContent.js index df7ed0755d2..09e6e802438 100644 --- a/app/renderer/components/tabContent.js +++ b/app/renderer/components/tabContent.js @@ -8,6 +8,9 @@ const {StyleSheet, css} = require('aphrodite/no-important') const globalStyles = require('./styles/global') const {isWindows} = require('../../common/lib/platformUtil') const {getTextColorForBackground} = require('../../../js/lib/color') +const {tabs} = require('../../common/constants/appEnums') + +const newSessionSvg = require('../../extensions/brave/img/tabs/new_session.svg') /** * Boilerplate component for all tab icons @@ -17,13 +20,15 @@ class TabIcon extends ImmutableComponent { const tabIconStyle = { // Currently it's not possible to concatenate Aphrodite generated classes // and pre-built classes using default Aphrodite API, so we keep with inline-style - fontSize: 'inherit', + fontSize: this.props.symbolContent ? '8px' : 'inherit', display: 'flex', alignSelf: 'center', width: globalStyles.spacing.iconSize, height: globalStyles.spacing.iconSize, alignItems: 'center', - justifyContent: 'center' + justifyContent: this.props.symbolContent ? 'flex-end' : 'center', + fontWeight: this.props.symbolContent ? 'bold' : 'normal', + color: this.props.symbolContent ? globalStyles.color.black100 : 'inherit' } return
+ style={tabIconStyle}>{this.props.symbolContent} : null } @@ -128,10 +133,39 @@ class NewSessionIcon extends ImmutableComponent { return sizes.includes(this.props.tabProps.get('breakpoint')) } + get partitionNumber () { + return this.props.tabProps.get('partitionNumber') + } + + get partitionIndicator () { + // For now due to UI limitations set session up to 9 visually + return this.partitionNumber > tabs.MAX_ALLOWED_NEW_SESSIONS + ? tabs.MAX_ALLOWED_NEW_SESSIONS + : this.partitionNumber + } + + get iconColor () { + const themeColor = this.props.tabProps.get('themeColor') || this.props.tabProps.get('computedThemeColor') + return this.props.paintTabs && themeColor + ? getTextColorForBackground(themeColor) + : globalStyles.color.black100 + } + render () { - return this.props.tabProps.get('partitionNumber') && !this.props.tabProps.get('hoverState') && !this.narrowView - ?