mirror of
https://github.com/ascribe/onion.git
synced 2025-01-12 14:00:24 +01:00
39 lines
923 B
JavaScript
39 lines
923 B
JavaScript
'use strict';
|
|
|
|
import React from 'react';
|
|
|
|
let CollapsibleButton = React.createClass({
|
|
|
|
propTypes: {
|
|
panel: React.PropTypes.object,
|
|
button: React.PropTypes.object,
|
|
children: React.PropTypes.oneOfType([
|
|
React.PropTypes.object,
|
|
React.PropTypes.array
|
|
])
|
|
},
|
|
|
|
getInitialState() {
|
|
return {expanded: false};
|
|
},
|
|
handleToggle(e){
|
|
e.preventDefault();
|
|
this.setState({expanded: !this.state.expanded});
|
|
},
|
|
render() {
|
|
let isVisible = (this.state.expanded) ? '' : 'invisible';
|
|
return (
|
|
<span>
|
|
<span onClick={this.handleToggle}>
|
|
{this.props.button}
|
|
</span>
|
|
<div ref='panel' className={isVisible}>
|
|
{this.props.panel}
|
|
</div>
|
|
</span>
|
|
);
|
|
}
|
|
});
|
|
|
|
export default CollapsibleButton;
|