From 429ad676cd9e61a9a224d845f1fa3f3ab324acef Mon Sep 17 00:00:00 2001 From: NejcZdovc Date: Thu, 15 Jun 2017 16:51:17 +0200 Subject: [PATCH] Converts ReleaseNotes into redux component Resolves #9448 Auditors: @bsclifton @bridiver Test Plan: --- app/renderer/components/main/main.js | 9 +---- app/renderer/components/main/releaseNotes.js | 40 ++++++++++++++++---- 2 files changed, 33 insertions(+), 16 deletions(-) diff --git a/app/renderer/components/main/main.js b/app/renderer/components/main/main.js index 4efa0d87da0..91e2f31079d 100644 --- a/app/renderer/components/main/main.js +++ b/app/renderer/components/main/main.js @@ -80,7 +80,6 @@ class Main extends ImmutableComponent { this.onHideClearBrowsingDataPanel = this.onHideClearBrowsingDataPanel.bind(this) this.onHideAutofillAddressPanel = this.onHideAutofillAddressPanel.bind(this) this.onHideAutofillCreditCardPanel = this.onHideAutofillCreditCardPanel.bind(this) - this.onHideReleaseNotes = this.onHideReleaseNotes.bind(this) this.onTabContextMenu = this.onTabContextMenu.bind(this) this.checkForTitleMode = debounce(this.checkForTitleMode.bind(this), 20) this.resetAltMenuProcessing() @@ -544,10 +543,6 @@ class Main extends ImmutableComponent { windowActions.setAutofillCreditCardDetail() } - onHideReleaseNotes () { - windowActions.setReleaseNotesVisible(false) - } - onMouseDown (e) { // TODO(bsclifton): update this to use eventUtil.eventElHasAncestorWithClasses let node = e.target @@ -744,9 +739,7 @@ class Main extends ImmutableComponent { } { releaseNotesIsVisible - ? + ? : null } { diff --git a/app/renderer/components/main/releaseNotes.js b/app/renderer/components/main/releaseNotes.js index b0a0bc5c29f..8257d42a10c 100644 --- a/app/renderer/components/main/releaseNotes.js +++ b/app/renderer/components/main/releaseNotes.js @@ -4,33 +4,59 @@ const React = require('react') const {StyleSheet, css} = require('aphrodite') +const Immutable = require('immutable') // Components -const ImmutableComponent = require('../immutableComponent') +const ReduxComponent = require('../reduxComponent') const Dialog = require('../common/dialog') +// Actions +const windowActions = require('../../../../js/actions/windowActions') + // Styles const commonStyles = require('../styles/commonStyles') -class ReleaseNotes extends ImmutableComponent { +class ReleaseNotes extends React.Component { + constructor (props) { + super(props) + this.onClick = this.onClick.bind(this) + } + onClick (e) { e.stopPropagation() } + + onHide () { + windowActions.setReleaseNotesVisible(false) + } + + mergeProps (state, ownProps) { + const metadata = state.getIn(['updates', 'metadata'], Immutable.Map()) + + const props = {} + props.name = metadata.get('name') + props.notes = metadata.get('notes') + + return props + } + render () { const className = css( commonStyles.flyoutDialog, styles.releaseNotes ) - return -
-

{this.props.metadata.get('name')}

-
{this.props.metadata.get('notes')}
+ return +
+

{this.props.name}

+
{this.props.notes}
} } +module.exports = ReduxComponent.connect(ReleaseNotes) + const styles = StyleSheet.create({ releaseNotes: { width: 'auto', @@ -42,5 +68,3 @@ const styles = StyleSheet.create({ marginBottom: '10px' } }) - -module.exports = ReleaseNotes