From 79098e3a5ff853dcb81879a7b3b8dfdab8b69535 Mon Sep 17 00:00:00 2001 From: andsandv Date: Wed, 22 Oct 2014 14:05:36 +0200 Subject: [PATCH] #13 Post enable change to server and update state --- unleash-server/public/js/unleash.js | 50 ++++++++++++++++++++++------- 1 file changed, 39 insertions(+), 11 deletions(-) diff --git a/unleash-server/public/js/unleash.js b/unleash-server/public/js/unleash.js index 1c607a7e05..dd99726ce6 100644 --- a/unleash-server/public/js/unleash.js +++ b/unleash-server/public/js/unleash.js @@ -22,15 +22,39 @@ var FeatureList = React.createClass({ }, componentDidMount: function () { - reqwest("/features").then(this.setFeatures); + reqwest('/features').then(this.setFeatures); + }, + + setFeatures: function (data) { + this.setState({features: data.features}); + }, + + updateFeature: function (feature) { + var newFeatures = this.state.features; + newFeatures.forEach(function(f){ + if(f.name === feature.name) { + f = feature; + } + }); + + reqwest({ + url: 'features/' + feature.name, + method: 'post', + type: 'json', + data: feature + }).then(function() { + this.setState({features: newFeatures}); + }.bind(this), function() { + alert("update failed"); + }.bind(this)); }, render: function () { var featureNodes = this.state.features.map(function (feature) { return ( - + ); - }); + }.bind(this)); return (
@@ -41,19 +65,23 @@ var FeatureList = React.createClass({
); - }, - - setFeatures: function (data) { - this.setState({features: data.features}); } }); var Feature = React.createClass({ // TODO: validate props? - - handleStatusChange: function (event) { +/* + handleStatusChange: function (feature, event) { + console.log(feature); console.log(event); }, +*/ + handleEnableChange: function(event) { + var feature = this.props.feature; + + feature.enabled = event.target.checked; + this.props.updateFeature(feature); + }, render: function () { return ( @@ -80,9 +108,9 @@ var Feature = React.createClass({ {this.props.feature.status}