2016-06-18 21:53:18 +02:00
|
|
|
'use strict';
|
|
|
|
const React = require('react');
|
|
|
|
const TextInput = require('../form/TextInput');
|
2014-11-02 22:39:52 +01:00
|
|
|
|
2016-06-18 21:53:18 +02:00
|
|
|
const StrategyForm = React.createClass({
|
2014-11-02 22:39:52 +01:00
|
|
|
|
2016-07-02 11:54:50 +02:00
|
|
|
getDefaultProps () {
|
2014-11-02 22:39:52 +01:00
|
|
|
return {
|
2016-06-18 21:55:46 +02:00
|
|
|
maxParams: 4,
|
2014-11-02 22:39:52 +01:00
|
|
|
};
|
|
|
|
},
|
|
|
|
|
2016-07-02 11:54:50 +02:00
|
|
|
getInitialState () {
|
2014-11-02 22:39:52 +01:00
|
|
|
return {
|
2016-06-18 21:55:46 +02:00
|
|
|
parameters: [],
|
2014-11-02 22:39:52 +01:00
|
|
|
};
|
|
|
|
},
|
|
|
|
|
2016-07-02 11:54:50 +02:00
|
|
|
onSubmit (event) {
|
2014-11-02 22:39:52 +01:00
|
|
|
event.preventDefault();
|
|
|
|
|
2016-06-18 21:53:18 +02:00
|
|
|
const strategy = {};
|
2014-11-03 21:27:47 +01:00
|
|
|
strategy.name = this.refs.name.getValue();
|
|
|
|
strategy.description = this.refs.description.getValue();
|
2014-11-02 22:39:52 +01:00
|
|
|
strategy.parametersTemplate = {};
|
|
|
|
|
2016-06-18 21:53:18 +02:00
|
|
|
this.state.parameters.forEach(parameter => {
|
2016-06-18 22:23:19 +02:00
|
|
|
const name = this.refs[parameter.name].getDOMNode().value.trim();
|
2016-06-18 21:55:46 +02:00
|
|
|
if (name) {
|
|
|
|
strategy.parametersTemplate[name] = 'string';
|
2014-11-02 22:39:52 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2014-11-03 21:37:40 +01:00
|
|
|
this.props.onSave(strategy);
|
2014-11-02 22:39:52 +01:00
|
|
|
},
|
|
|
|
|
2016-07-02 11:54:50 +02:00
|
|
|
onCancel (event) {
|
2014-11-25 13:54:25 +01:00
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
this.props.onCancelNewStrategy();
|
|
|
|
},
|
|
|
|
|
2016-07-02 11:54:50 +02:00
|
|
|
onAddParam (event) {
|
2014-11-02 22:39:52 +01:00
|
|
|
event.preventDefault();
|
2016-06-18 21:53:18 +02:00
|
|
|
const id = this.state.parameters.length + 1;
|
2016-06-18 21:55:46 +02:00
|
|
|
const params = this.state.parameters.concat([{ id, name: `param_${id}`, label: `Parameter ${id}` }]);
|
|
|
|
this.setState({ parameters: params });
|
2014-11-02 22:39:52 +01:00
|
|
|
},
|
|
|
|
|
2016-07-02 11:54:50 +02:00
|
|
|
onRemoveParam (event) {
|
2014-11-02 22:39:52 +01:00
|
|
|
event.preventDefault();
|
2016-06-18 21:53:18 +02:00
|
|
|
const params = this.state.parameters.slice(0, -1);
|
2014-11-02 22:39:52 +01:00
|
|
|
|
2016-06-18 21:55:46 +02:00
|
|
|
this.setState({ parameters: params });
|
2014-11-02 22:39:52 +01:00
|
|
|
},
|
|
|
|
|
2016-07-02 11:54:50 +02:00
|
|
|
render () {
|
2014-11-02 22:39:52 +01:00
|
|
|
return (
|
2014-11-29 11:43:41 +01:00
|
|
|
<div className="line r-pam bg-lilac-xlt">
|
2014-11-02 22:39:52 +01:00
|
|
|
<div className="unit r-size1of2">
|
|
|
|
<form onSubmit={this.onSubmit}>
|
|
|
|
<fieldset>
|
|
|
|
<legend>Create strategy</legend>
|
2014-11-03 21:27:47 +01:00
|
|
|
|
|
|
|
<TextInput
|
|
|
|
id="name"
|
|
|
|
name="name"
|
|
|
|
label="Name"
|
|
|
|
ref="name"
|
|
|
|
placeholder="Strategy name" />
|
|
|
|
|
|
|
|
<TextInput
|
|
|
|
id="description"
|
|
|
|
name="description"
|
|
|
|
label="Description"
|
|
|
|
ref="description"
|
2014-11-25 13:54:25 +01:00
|
|
|
placeholder="Please write a short description" />
|
2014-11-02 22:39:52 +01:00
|
|
|
|
|
|
|
{this.renderParameters()}
|
|
|
|
{this.renderRemoveLink()}
|
|
|
|
|
|
|
|
<div className="actions">
|
|
|
|
<input type="submit" value="Save" className="primary mrs" />
|
2014-11-25 13:54:25 +01:00
|
|
|
<button onClick={this.onCancel} className="mrs">Cancel</button>
|
2014-11-02 22:39:52 +01:00
|
|
|
{this.renderAddLink()}
|
|
|
|
</div>
|
|
|
|
</fieldset>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
},
|
|
|
|
|
2016-07-02 11:54:50 +02:00
|
|
|
renderParameters () {
|
2016-06-18 21:53:18 +02:00
|
|
|
return this.state.parameters.map(param => <div className="formelement" key={param.name}>
|
|
|
|
<label className="t4">{param.label}</label>
|
|
|
|
<div className="input">
|
|
|
|
<div className="line">
|
|
|
|
|
|
|
|
<div className="unit size2of3">
|
|
|
|
<input
|
|
|
|
type="text"
|
|
|
|
name={param.name}
|
|
|
|
ref={param.name}
|
|
|
|
placeholder="Parameter name"
|
|
|
|
/>
|
|
|
|
</div>
|
2014-11-02 22:39:52 +01:00
|
|
|
|
2016-06-18 21:53:18 +02:00
|
|
|
<div className="unit size1of3">
|
|
|
|
<select defaultValue="string">
|
|
|
|
<option value="string">string</option>
|
|
|
|
</select>
|
2014-11-02 22:39:52 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
2016-06-18 21:53:18 +02:00
|
|
|
</div>
|
|
|
|
</div>);
|
2014-11-02 22:39:52 +01:00
|
|
|
},
|
|
|
|
|
2016-07-02 11:54:50 +02:00
|
|
|
renderAddLink () {
|
2016-06-18 21:55:46 +02:00
|
|
|
if (this.state.parameters.length < this.props.maxParams) {
|
2014-11-03 21:37:40 +01:00
|
|
|
return <a href="#add" onClick={this.onAddParam}>+ Add required parameter</a>;
|
2014-11-02 22:39:52 +01:00
|
|
|
}
|
|
|
|
},
|
2016-07-02 11:54:50 +02:00
|
|
|
renderRemoveLink () {
|
2016-06-18 21:55:46 +02:00
|
|
|
if (this.state.parameters.length > 0) {
|
2014-11-02 22:39:52 +01:00
|
|
|
return (
|
|
|
|
<div className="formelement mtn">
|
2015-03-23 18:47:23 +01:00
|
|
|
<a href="#add"
|
|
|
|
className="negative"
|
|
|
|
onClick={this.onRemoveParam}>
|
|
|
|
- Remove parameter
|
|
|
|
</a>
|
2014-11-02 22:39:52 +01:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2016-06-18 21:55:46 +02:00
|
|
|
},
|
2014-11-02 22:39:52 +01:00
|
|
|
});
|
|
|
|
|
2015-03-23 18:47:23 +01:00
|
|
|
module.exports = StrategyForm;
|