From 8f052ccae15f0472292b53297054e27abc69c7ae Mon Sep 17 00:00:00 2001 From: NejcZdovc Date: Tue, 13 Jun 2017 09:07:49 +0200 Subject: [PATCH] Converts SiteInfo into redux component Resolves #9412 Auditors: @bsclifton @bridiver Test Plan: --- app/renderer/components/main/main.js | 6 +- app/renderer/components/main/siteInfo.js | 380 ++++++++++++----------- test/lib/selectors.js | 3 +- test/navbar-components/siteInfoTest.js | 56 ++++ 4 files changed, 256 insertions(+), 189 deletions(-) create mode 100644 test/navbar-components/siteInfoTest.js diff --git a/app/renderer/components/main/main.js b/app/renderer/components/main/main.js index 350c4accb90..e94a7b2ae0d 100644 --- a/app/renderer/components/main/main.js +++ b/app/renderer/components/main/main.js @@ -67,6 +67,7 @@ const cx = require('../../../../js/lib/classSet') const eventUtil = require('../../../../js/lib/eventUtil') const siteSettings = require('../../../../js/state/siteSettings') const debounce = require('../../../../js/lib/debounce') +const {isSourceAboutUrl} = require('../../../../js/lib/appUrlUtil') const {getCurrentWindowId, isMaximized, isFocused, isFullScreen} = require('../../currentWindow') const {isDarwin, isWindows} = require('../../../common/lib/platformUtil') @@ -687,7 +688,7 @@ class Main extends ImmutableComponent { const btbMode = getSetting(settings.BOOKMARKS_TOOLBAR_MODE) const showFavicon = (btbMode === bookmarksToolbarMode.TEXT_AND_FAVICONS || btbMode === bookmarksToolbarMode.FAVICONS_ONLY) const showOnlyFavicon = btbMode === bookmarksToolbarMode.FAVICONS_ONLY - const siteInfoIsVisible = this.props.windowState.getIn(['ui', 'siteInfo', 'isVisible']) + const siteInfoIsVisible = this.props.windowState.getIn(['ui', 'siteInfo', 'isVisible']) && !isSourceAboutUrl(activeFrame.get('location')) const braveryPanelIsVisible = shieldState.braveShieldsEnabled(activeFrame) && this.props.windowState.get('braveryPanelDetail') const clearBrowsingDataPanelIsVisible = this.props.windowState.getIn(['ui', 'isClearBrowsingDataPanelVisible']) @@ -737,8 +738,7 @@ class Main extends ImmutableComponent { { siteInfoIsVisible - ? + ? : null } { diff --git a/app/renderer/components/main/siteInfo.js b/app/renderer/components/main/siteInfo.js index 545d4367bc6..ae16ba4de62 100644 --- a/app/renderer/components/main/siteInfo.js +++ b/app/renderer/components/main/siteInfo.js @@ -3,235 +3,250 @@ * You can obtain one at http://mozilla.org/MPL/2.0/. */ const React = require('react') -const PropTypes = require('prop-types') +const Immutable = require('immutable') const {StyleSheet, css} = require('aphrodite/no-important') // Components -const ImmutableComponent = require('../immutableComponent') +const ReduxComponent = require('../reduxComponent') const Dialog = require('../common/dialog') const Button = require('../common/button') // Actions const appActions = require('../../../../js/actions/appActions') const webviewActions = require('../../../../js/actions/webviewActions') +const windowActions = require('../../../../js/actions/windowActions') + +// State +const tabState = require('../../../common/state/tabState') // Utils const cx = require('../../../../js/lib/classSet') const {isPotentialPhishingUrl} = require('../../../../js/lib/urlutil') -const {isSourceAboutUrl} = require('../../../../js/lib/appUrlUtil') const siteUtil = require('../../../../js/state/siteUtil') const platformUtil = require('../../../common/lib/platformUtil') +const frameStateUtil = require('../../../../js/state/frameStateUtil') // Styles const globalStyles = require('../styles/global') const commonStyles = require('../styles/commonStyles') -class SiteInfo extends ImmutableComponent { - constructor () { - super() +class SiteInfo extends React.Component { + constructor (props) { + super(props) this.onAllowRunInsecureContent = this.onAllowRunInsecureContent.bind(this) this.onDenyRunInsecureContent = this.onDenyRunInsecureContent.bind(this) this.onViewCertificate = this.onViewCertificate.bind(this) } + onAllowRunInsecureContent () { - appActions.changeSiteSetting(siteUtil.getOrigin(this.location), - 'runInsecureContent', true, this.isPrivate) - appActions.loadURLRequested(this.props.frameProps.get('tabId'), this.location) - this.props.onHide() + appActions.changeSiteSetting(siteUtil.getOrigin(this.props.location), + 'runInsecureContent', true, this.props.isPrivate) + appActions.loadURLRequested(this.props.activeTabId, this.props.location) + this.onHide() } + onDenyRunInsecureContent () { - appActions.removeSiteSetting(siteUtil.getOrigin(this.location), - 'runInsecureContent', this.isPrivate) - appActions.loadURLRequested(this.props.frameProps.get('tabId'), this.location) - this.props.onHide() + appActions.removeSiteSetting(siteUtil.getOrigin(this.props.location), + 'runInsecureContent', this.props.isPrivate) + appActions.loadURLRequested(this.props.activeTabId, this.props.location) + this.onHide() } + onViewCertificate () { - this.props.onHide() + this.onHide() webviewActions.showCertificate() } - get isExtendedValidation () { - return this.props.frameProps.getIn(['security', 'isExtendedValidation']) - } - get isSecure () { - return this.props.frameProps.getIn(['security', 'isSecure']) - } - get isPrivate () { - return this.props.frameProps.getIn(['isPrivate']) - } - get runInsecureContent () { - return this.props.frameProps.getIn(['security', 'runInsecureContent']) - } - get isBlockedRunInsecureContent () { - return this.props.frameProps.getIn(['security', 'blockedRunInsecureContent']) - } - get partitionNumber () { - return this.props.frameProps.getIn(['partitionNumber']) - } - get location () { - return this.props.frameProps.getIn(['location']) - } - get maybePhishingLocation () { - return isPotentialPhishingUrl(this.props.frameProps.getIn(['location'])) - } - render () { - if (isSourceAboutUrl(this.location)) { - return null - } - // Figure out the partition info display - let l10nArgs = { - partitionNumber: this.partitionNumber - } + onHide () { + windowActions.setSiteInfoVisible(false) + } - let secureIcon - if (this.isSecure === true && !this.runInsecureContent) { + get secureIcon () { + if (this.props.isFullySecured) { // fully secure - secureIcon = -
- - -
- } else if (this.isSecure === 1 && !this.runInsecureContent) { + return
+ + +
+ } else if (this.props.isMixedContent) { // passive mixed content loaded - secureIcon = -
- - -
+ return
+ + +
} else { // insecure - secureIcon = -
- - -
+ return
+ + +
} + } - let partitionInfo - if (this.partitionNumber) { - partitionInfo = -
- - -
+ get partitionInfo () { + if (this.props.partitionNumber) { + // Figure out the partition info display + let l10nArgs = { + partitionNumber: this.props.partitionNumber + } + + return
+ + +
} - let connectionInfo = null - let viewCertificateButton = null + return null + } + get viewCertificateButton () { + // TODO(Anthony): Hide it until muon support linux + if (!platformUtil.isLinux()) { + return
+
+ } + + return null + } + + get connectionInfo () { const certErrl10nArgs = { - site: this.location + site: this.props.location } - // TODO(Anthony): Hide it until muon support linux - if (!platformUtil.isLinux()) { - viewCertificateButton = + if (this.props.maybePhishingLocation) { + return
+
+
+ } else if (this.props.isBlockedRunInsecureContent) { + return
+
-
- } - - if (this.maybePhishingLocation) { - connectionInfo = -
-
-
- } else if (this.isBlockedRunInsecureContent) { - connectionInfo = -
-
-
-
- {viewCertificateButton} -
- } else if (this.runInsecureContent) { - connectionInfo = -
-
-
-
- {viewCertificateButton} -
- } else if (this.isSecure === true) { - connectionInfo = -
-
- {viewCertificateButton} -
- } else if (this.isSecure === 1) { - connectionInfo = -
-
- {viewCertificateButton} -
- } else if (this.isSecure === 2) { - connectionInfo = -
-
- {viewCertificateButton} + {this.viewCertificateButton} +
+ } else if (this.props.runInsecureContent) { + return
+
+
+
+ {this.viewCertificateButton} +
+ } else if (this.props.secureConnection) { + return
+
+ {this.viewCertificateButton} +
+ } else if (this.props.partiallySecureConnection) { + return
+
+ {this.viewCertificateButton} +
+ } else if (this.props.certErrorConnection) { + return
+
+ {this.viewCertificateButton} +
} else { - connectionInfo = -
-
-
+ return
+
+
} + } - return + mergeProps (state, ownProps) { + const currentWindow = state.get('currentWindow') + const activeFrame = frameStateUtil.getActiveFrame(currentWindow) || Immutable.Map() + const isSecure = activeFrame.getIn(['security', 'isSecure']) + const runInsecureContent = activeFrame.getIn(['security', 'runInsecureContent']) + + const props = {} + // used in renderer + props.isFullySecured = isSecure === true && !runInsecureContent + props.isMixedContent = isSecure === 1 && !runInsecureContent + props.isExtendedValidation = activeFrame.getIn(['security', 'isExtendedValidation']) + props.partitionNumber = activeFrame.get('partitionNumber') + props.location = activeFrame.get('location') + props.maybePhishingLocation = isPotentialPhishingUrl(props.location) + props.isBlockedRunInsecureContent = activeFrame.getIn(['security', 'blockedRunInsecureContent']) + props.runInsecureContent = activeFrame.getIn(['security', 'runInsecureContent']) + props.secureConnection = isSecure === true + props.partiallySecureConnection = isSecure === 1 + props.certErrorConnection = isSecure === 2 + + // used in other function + props.isPrivate = activeFrame.get('isPrivate') + props.activeTabId = activeFrame.get('tabId', tabState.TAB_ID_NONE) + + return props + } + + render () { + return
e.stopPropagation()} className={cx({ [css(commonStyles.flyoutDialog)]: true, @@ -239,23 +254,20 @@ class SiteInfo extends ImmutableComponent { [css(styles.siteInfo__wrapper__large)]: (this.isBlockedRunInsecureContent || this.runInsecureContent) })}> { - secureIcon + this.secureIcon } { - partitionInfo + this.partitionInfo } { - connectionInfo + this.connectionInfo }
} } -SiteInfo.propTypes = { - frameProps: PropTypes.object, - onHide: PropTypes.func -} +module.exports = ReduxComponent.connect(SiteInfo) const styles = StyleSheet.create({ flexJustifyEnd: { @@ -302,5 +314,3 @@ const styles = StyleSheet.create({ maxWidth: '500px' } }) - -module.exports = SiteInfo diff --git a/test/lib/selectors.js b/test/lib/selectors.js index a17d4347c8b..ef8979f6c2e 100644 --- a/test/lib/selectors.js +++ b/test/lib/selectors.js @@ -127,5 +127,6 @@ module.exports = { downloadDeleteConfirm: '[data-test-id="confirmDeleteButton"]', downloadRemoveFromList: '[data-test-id="downloadRemoveFromList"]', - siteInfoDialog: '[data-test-id="siteInfoDialog"]' + siteInfoDialog: '[data-test-id="siteInfoDialog"]', + viewCertificateButton: '[data-test-id="viewCertificate"]' } diff --git a/test/navbar-components/siteInfoTest.js b/test/navbar-components/siteInfoTest.js new file mode 100644 index 00000000000..21c7565bf7c --- /dev/null +++ b/test/navbar-components/siteInfoTest.js @@ -0,0 +1,56 @@ +/* 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/. */ + +/* global describe, it, beforeEach */ + +const Brave = require('../lib/brave') +const {urlInput, urlbarIcon, siteInfoDialog, viewCertificateButton} = require('../lib/selectors') + +describe('siteInfo component tests', function () { + function * setup (client) { + yield client + .waitForUrl(Brave.newTabUrl) + .waitForBrowserWindow() + .waitForVisible(urlInput) + } + + describe('view certificate button', function () { + const page1 = 'https://brave.github.io/brave-tests/' + const isLinux = process.platform === 'linux' + + Brave.beforeEach(this) + beforeEach(function * () { + yield setup(this.app.client) + }) + + it('hide it if on linux', function * () { + if (!isLinux) { + this.skip() + return + } + + yield this.app.client + .tabByIndex(0) + .loadUrl(page1) + .windowByUrl(Brave.browserWindowUrl) + .click(urlbarIcon) + .waitForElementCount(siteInfoDialog, 1) + .waitForElementCount(viewCertificateButton, 0) + }) + + it('show it if on other then linux', function * () { + if (isLinux) { + this.skip() + return + } + yield this.app.client + .tabByIndex(0) + .loadUrl(page1) + .windowByUrl(Brave.browserWindowUrl) + .click(urlbarIcon) + .waitForElementCount(siteInfoDialog, 1) + .waitForElementCount(viewCertificateButton, 1) + }) + }) +})