From 5964c374bc11c846c2f154507f75ff6e3390662b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ivar=20Conradi=20=C3=98sthus?= Date: Fri, 27 Mar 2015 22:19:56 +0100 Subject: [PATCH] Application states should be loaded as high up as possible --- public/js/UnleashApp.jsx | 46 ++++++++++++++++++- .../feature/ArchiveFeatureComponent-test.js | 9 +--- .../feature/ArchiveFeatureComponent.jsx | 22 +-------- .../feature/FeatureTogglesComponent.jsx | 21 ++------- .../strategy/StrategiesComponent.jsx | 18 +------- 5 files changed, 53 insertions(+), 63 deletions(-) diff --git a/public/js/UnleashApp.jsx b/public/js/UnleashApp.jsx index b407773a5c..724bcbdd2f 100644 --- a/public/js/UnleashApp.jsx +++ b/public/js/UnleashApp.jsx @@ -3,6 +3,9 @@ var Router = require('react-router'); var Menu = require('./components/Menu'); var ErrorMessages = require('./components/ErrorMessages'); var initalizer = require('./stores/initalizer'); +var FeatureToggleStore = require('./stores/FeatureToggleStore'); +var StrategyStore = require('./stores/StrategyStore'); +var ArchiveStore = require('./stores/ArchivedToggleStore'); var Link = Router.Link; var RouteHandler = Router.RouteHandler; @@ -11,6 +14,43 @@ var UnleashApp = React.createClass({ router: React.PropTypes.func }, + getInitialState: function() { + return { + features: FeatureToggleStore.getFeatureToggles(), + strategies: StrategyStore.getStrategies(), + archivedFeatures: ArchiveStore.getArchivedToggles() + }; + }, + + onFeatureToggleChange: function() { + this.setState({ + features: FeatureToggleStore.getFeatureToggles() + }); + }, + + onStrategiesChange: function() { + this.setState({ + strategies: StrategyStore.getStrategies() + }); + }, + + onArchiveChange: function() { + this.setState({ + archivedFeatures: ArchiveStore.getArchivedToggles() + }); + }, + + componentDidMount: function() { + this.unsubscribeFS = FeatureToggleStore.listen(this.onFeatureToggleChange); + this.unsubscribeSS = StrategyStore.listen(this.onStrategiesChange); + this.unsubscribeAS = ArchiveStore.listen(this.onArchiveChange); + }, + componentWillUnmount: function() { + this.unsubscribeFS(); + this.unsubscribeSS(); + this.unsubscribeAS(); + }, + componentWillMount: function() { initalizer(30); }, @@ -38,7 +78,11 @@ var UnleashApp = React.createClass({
- +
diff --git a/public/js/__tests__/components/feature/ArchiveFeatureComponent-test.js b/public/js/__tests__/components/feature/ArchiveFeatureComponent-test.js index a219abd55c..7a874aec6d 100644 --- a/public/js/__tests__/components/feature/ArchiveFeatureComponent-test.js +++ b/public/js/__tests__/components/feature/ArchiveFeatureComponent-test.js @@ -16,13 +16,8 @@ describe("FeatureForm", function () { { name: "featureY" } ]; - Server.getArchivedFeatures.mockImplementation(function(cb) { - cb(null, archivedToggles); - }); - - FeatureToggleStore.initStore(archivedToggles); - - Component = TestUtils.renderIntoDocument(); + Component = TestUtils.renderIntoDocument( + ); }); afterEach(function() { diff --git a/public/js/components/feature/ArchiveFeatureComponent.jsx b/public/js/components/feature/ArchiveFeatureComponent.jsx index 3730d0d0cb..6d0304e44b 100644 --- a/public/js/components/feature/ArchiveFeatureComponent.jsx +++ b/public/js/components/feature/ArchiveFeatureComponent.jsx @@ -1,27 +1,7 @@ var React = require("react"); var FeatureActions = require('../../stores/FeatureToggleActions'); -var FeatureToggleStore = require('../../stores/ArchivedToggleStore'); var ArchiveFeatureComponent = React.createClass({ - getInitialState: function() { - return { - archivedFeatures: FeatureToggleStore.getArchivedToggles() - }; - }, - - onStoreChange: function() { - this.setState({ - archivedFeatures: FeatureToggleStore.getArchivedToggles() - }); - }, - - componentDidMount: function() { - this.unsubscribe = FeatureToggleStore.listen(this.onStoreChange); - }, - - componentWillUnmount: function() { - this.unsubscribe(); - }, onRevive: function(item) { FeatureActions.revive.triggerPromise(item); @@ -39,7 +19,7 @@ var ArchiveFeatureComponent = React.createClass({ - {this.state.archivedFeatures.map(this.renderArchivedItem)} + {this.props.archivedFeatures.map(this.renderArchivedItem)} diff --git a/public/js/components/feature/FeatureTogglesComponent.jsx b/public/js/components/feature/FeatureTogglesComponent.jsx index 683d362d3a..37661e1130 100644 --- a/public/js/components/feature/FeatureTogglesComponent.jsx +++ b/public/js/components/feature/FeatureTogglesComponent.jsx @@ -3,29 +3,14 @@ var FeatureList = require('./FeatureList'); var FeatureForm = require('./FeatureForm'); var FeatureActions = require('../../stores/FeatureToggleActions'); var ErrorActions = require('../../stores/ErrorActions'); -var FeatureToggleStore = require('../../stores/FeatureToggleStore'); -var StrategyStore = require('../../stores/StrategyStore'); var FeatureTogglesComponent = React.createClass({ getInitialState: function() { return { - features: FeatureToggleStore.getFeatureToggles(), createView: false }; }, - onFeatureToggleChange: function() { - this.setState({ - features: FeatureToggleStore.getFeatureToggles() - }); - }, - componentDidMount: function() { - this.unsubscribe = FeatureToggleStore.listen(this.onFeatureToggleChange); - }, - componentWillUnmount: function() { - this.unsubscribe(); - }, - updateFeature: function (feature) { FeatureActions.update.triggerPromise(feature); }, @@ -55,13 +40,13 @@ var FeatureTogglesComponent = React.createClass({ {this.state.createView ? this.renderCreateView() : this.renderCreateButton()} + strategies={this.props.strategies} /> ); }, @@ -70,7 +55,7 @@ var FeatureTogglesComponent = React.createClass({ return ; + strategies={this.props.strategies} />; }, renderCreateButton: function() { diff --git a/public/js/components/strategy/StrategiesComponent.jsx b/public/js/components/strategy/StrategiesComponent.jsx index e913f6c03b..79fecd29f3 100644 --- a/public/js/components/strategy/StrategiesComponent.jsx +++ b/public/js/components/strategy/StrategiesComponent.jsx @@ -1,29 +1,15 @@ var React = require('react'); var StrategyList = require('./StrategyList'); var StrategyForm = require('./StrategyForm'); -var StrategyStore = require('../../stores/StrategyStore'); var StrategyActions = require('../../stores/StrategyActions'); var StrategiesComponent = React.createClass({ getInitialState: function() { return { - createView: false, - strategies: StrategyStore.getStrategies() + createView: false }; }, - onStoreChange: function() { - this.setState({ - strategies: StrategyStore.getStrategies() - }); - }, - componentDidMount: function() { - this.unsubscribe = StrategyStore.listen(this.onStoreChange); - }, - componentWillUnmount: function() { - this.unsubscribe(); - }, - onNewStrategy: function() { this.setState({createView: true}); }, @@ -48,7 +34,7 @@ var StrategiesComponent = React.createClass({ this.renderCreateView() : this.renderCreateButton()}
);