aboutsummaryrefslogtreecommitdiff
path: root/src/settings/components
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2017-11-26 12:18:12 +0900
committerShin'ya Ueoka <ueokande@i-beam.org>2017-11-26 12:18:12 +0900
commit0967304ebe713bc24078b20ac3a710fd42f2f611 (patch)
tree2a07ac2cf7151fe36c86711593f0dfd5919d4e99 /src/settings/components
parentd195890eb957e5b6e40f7c01ce34d07e7ccf22b5 (diff)
add SearchForm test
Diffstat (limited to 'src/settings/components')
-rw-r--r--src/settings/components/form/search-form.jsx18
1 files changed, 11 insertions, 7 deletions
diff --git a/src/settings/components/form/search-form.jsx b/src/settings/components/form/search-form.jsx
index 9bafb8d..98b0655 100644
--- a/src/settings/components/form/search-form.jsx
+++ b/src/settings/components/form/search-form.jsx
@@ -10,10 +10,9 @@ class SearchForm extends Component {
if (!value) {
value = { default: '', engines: []};
}
- let {
- default: defaultEngine,
- engines
- } = value;
+ if (!value.engines) {
+ value.engines = [];
+ }
return <div className='form-search-form'>
<div className='form-search-form-header'>
@@ -22,7 +21,7 @@ class SearchForm extends Component {
<div className='column-option'>Default</div>
</div>
{
- engines.map((engine, index) => {
+ value.engines.map((engine, index) => {
return <div key={index} className='form-search-form-row'>
<input data-index={index} type='text' name='name'
className='column-name' value={engine[0]}
@@ -33,7 +32,7 @@ class SearchForm extends Component {
onChange={this.bindValue.bind(this)} />
<div className='column-option'>
<input data-index={index} type='radio' name='default'
- checked={defaultEngine === engine[0]}
+ checked={value.default === engine[0]}
onChange={this.bindValue.bind(this)} />
<DeleteButton data-index={index} name='delete'
onClick={this.bindValue.bind(this)} />
@@ -50,12 +49,17 @@ class SearchForm extends Component {
return;
}
+ let value = this.props.value;
let name = e.target.name;
let index = e.target.getAttribute('data-index');
- let next = Object.assign({}, this.props.value);
+ let next = Object.assign({}, {
+ default: value.default,
+ engines: value.engines ? value.engines.slice() : [],
+ });
if (name === 'name') {
next.engines[index][0] = e.target.value;
+ next.default = this.props.value.engines[index][0];
} else if (name === 'url') {
next.engines[index][1] = e.target.value;
} else if (name === 'default') {