61 lines
1.3 KiB
JavaScript
61 lines
1.3 KiB
JavaScript
|
import React from 'react'
|
||
|
import {connect} from 'react-redux'
|
||
|
import * as actions from '../actions'
|
||
|
import {bindActionCreators} from 'redux'
|
||
|
import {getSelectedTags, getTagsToSelect} from '../selectors'
|
||
|
|
||
|
|
||
|
export default class TagNavigation extends React.Component {
|
||
|
render(){
|
||
|
let {tagsToSelect, selectedTags, actions: {selectTag}} = this.props
|
||
|
return (
|
||
|
<section id="tag-navigation">
|
||
|
<ul id="selected">
|
||
|
{selectedTags.map(([name, value]) => <li>
|
||
|
{name + ': ' + value}
|
||
|
</li>)
|
||
|
}
|
||
|
</ul>
|
||
|
<ul id="to-select">
|
||
|
{tagsToSelect.map(tag =>
|
||
|
<Tag selectTag={selectTag} key={tag.name} tag={tag} />
|
||
|
)}
|
||
|
</ul>
|
||
|
|
||
|
</section>
|
||
|
)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
class Tag extends React.Component {
|
||
|
render(){
|
||
|
let {tag: {name, choices, number}, selectTag} = this.props
|
||
|
return (<li>
|
||
|
<span className="name">{`${name} (${number} variables)`}</span>
|
||
|
<ul className="choices">
|
||
|
{[...choices].map(c =>
|
||
|
<li key={c} onClick={() => selectTag(name, c)}>
|
||
|
{c}
|
||
|
</li>
|
||
|
)}
|
||
|
</ul>
|
||
|
</li>)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
const mapStateToProps = state => (
|
||
|
{
|
||
|
selectedTags: state.selectedTags,
|
||
|
tagsToSelect: getTagsToSelect(state)
|
||
|
}
|
||
|
)
|
||
|
|
||
|
const actionsToProps = dispatch => ({
|
||
|
actions: bindActionCreators(actions, dispatch)
|
||
|
})
|
||
|
|
||
|
export default connect(mapStateToProps, actionsToProps)(TagNavigation)
|