From b0e9790382a6bebf0f27d861c5b35fe76f7dae59 Mon Sep 17 00:00:00 2001 From: Lukas Martinelli Date: Sat, 31 Dec 2016 14:56:26 +0100 Subject: [PATCH] Support updating of ArrayInput #39 --- src/components/inputs/ArrayInput.jsx | 31 +++++++++++++++++++++++----- 1 file changed, 26 insertions(+), 5 deletions(-) diff --git a/src/components/inputs/ArrayInput.jsx b/src/components/inputs/ArrayInput.jsx index 1bf665f..f8e2700 100644 --- a/src/components/inputs/ArrayInput.jsx +++ b/src/components/inputs/ArrayInput.jsx @@ -1,7 +1,7 @@ import React from 'react' import input from '../../config/input.js' import StringInput from './StringInput' -import NumberInput from './StringInput' +import NumberInput from './NumberInput' import { margins } from '../../config/scales.js' @@ -15,17 +15,38 @@ class ArrayInput extends React.Component { onChange: React.PropTypes.func, } + changeValue(idx, newValue) { + console.log(idx, newValue) + const values = this.values.slice(0) + values[idx] = newValue + this.props.onChange(values) + } + + get values() { + return this.props.value || this.props.default || [] + } + render() { - const values = this.props.value || this.props.default || [] const commonStyle = { width: '49%', marginRight: '1%', } - const inputs = values.map((v, i) => { + const inputs = this.values.map((v, i) => { if(this.props.type === 'number') { - return + return + } else { + return } - return }) return