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);