From 19a47ecde87f7cdfe07d86569cd1f919ffef7e3f Mon Sep 17 00:00:00 2001 From: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue, 17 Nov 2020 15:55:30 -0800 Subject: [PATCH] split HOC in two: one inside AppStateHOC, one out `ScratchDesktopOuterComponent` is now responsible for `showTelemetryModal` which only works if it comes from outside the `AppStateHOC` since it's used in the `AppStateHOC` constructor. The outer component also handles a few static props, like `isScratchDesktop`. `ScratchDesktopInnerComponent` handles everything else, most notably anything that interacts with the state established by `AppStateHOC`. --- src/renderer/app.jsx | 42 ++++++++++++++++++++++++++++-------------- 1 file changed, 28 insertions(+), 14 deletions(-) diff --git a/src/renderer/app.jsx b/src/renderer/app.jsx index 1fe1a37..4d9760d 100644 --- a/src/renderer/app.jsx +++ b/src/renderer/app.jsx @@ -7,7 +7,7 @@ import ReactDOM from 'react-dom'; import {connect} from 'react-redux'; import {compose} from 'redux'; import GUI from 'scratch-gui/src/index'; -import VM from 'scratch-vm'; +import GUIComponent from 'scratch-gui/src/components/gui/gui.jsx'; import AppStateHOC from 'scratch-gui/src/lib/app-state-hoc.jsx'; import { @@ -43,8 +43,26 @@ document.body.appendChild(appTarget); GUI.setAppElement(appTarget); -const ScratchDesktopHOC = function (WrappedComponent) { - class ScratchDesktopComponent extends React.Component { +const ScratchDesktopOuterHOC = function (WrappedComponent) { + const ScratchDesktopOuterComponent = function (props) { + const shouldShowTelemetryModal = (typeof ipcRenderer.sendSync('getTelemetryDidOptIn') !== 'boolean'); + + return (); + }; + + return ScratchDesktopOuterComponent; +}; + +const ScratchDesktopInnerHOC = function (WrappedComponent) { + class ScratchDesktopInnerComponent extends React.Component { constructor (props) { super(props); bindAll(this, [ @@ -116,15 +134,9 @@ const ScratchDesktopHOC = function (WrappedComponent) { this.setState({projectTitle: newTitle}); } render () { - const shouldShowTelemetryModal = (typeof ipcRenderer.sendSync('getTelemetryDidOptIn') !== 'boolean'); - - const childProps = omit(this.props, Object.keys(ScratchDesktopComponent.propTypes)); + const childProps = omit(this.props, Object.keys(ScratchDesktopInnerComponent.propTypes)); return ( { const loadingState = state.scratchGui.projectState.loadingState; @@ -177,15 +190,16 @@ const ScratchDesktopHOC = function (WrappedComponent) { onRequestNewProject: () => dispatch(requestNewProject(false)) }); - return connect(mapStateToProps, mapDispatchToProps)(ScratchDesktopComponent); + return connect(mapStateToProps, mapDispatchToProps)(ScratchDesktopInnerComponent); }; // note that redux's 'compose' function is just being used as a general utility to make // the hierarchy of HOC constructor calls clearer here; it has nothing to do with redux's // ability to compose reducers. const WrappedGui = compose( + ScratchDesktopOuterHOC, AppStateHOC, - ScratchDesktopHOC + ScratchDesktopInnerHOC )(GUI); ReactDOM.render(, appTarget);