????JFIF??x?x????'
| Server IP : 104.21.30.238 / Your IP : 216.73.216.87 Web Server : LiteSpeed System : Linux premium151.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 User : tempvsty ( 647) PHP Version : 8.0.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /././proc/self/root/opt/alt/alt-nodejs12/root/lib/node_modules/npm/docs/src/components/ |
Upload File : |
import React from 'react'
import styled from 'styled-components'
import downCarrot from '../images/down-carrot.svg'
import upCarrot from '../images/up-carrot.svg'
const SectionButton = styled.button`
outline: none;
background-color: transparent;
cursor: pointer;
color: red;
border: none;
font-size: 18px;
font-weight: bold;
padding: 5px 0;
transition: opacity .5s;
&:after {
background: center / contain no-repeat url(${(props) => props.isOpen ? upCarrot : downCarrot});
content: '';
height: 11px;
width: 28px;
display: inline-block;
}
&:hover {
opacity: .6;
}
`
class Accordion extends React.Component {
constructor (props) {
super(props)
this.state = {
isOpen: true
}
this.onHide = this.onHide.bind(this)
}
onHide () {
this.setState({isOpen: !this.state.isOpen})
}
render () {
return (
<div>
<SectionButton isOpen={this.state.isOpen} onClick={this.onHide}>{this.props.section}</SectionButton>
{this.state.isOpen &&
<div>
{this.props.children}
</div>
}
</div>
)
}
}
export default Accordion