mirror of
https://github.com/d0zingcat/NotionNext.git
synced 2026-05-14 07:26:52 +00:00
39 lines
1016 B
JavaScript
39 lines
1016 B
JavaScript
import React, { useEffect, useRef } from 'react'
|
|
|
|
const Collapse = props => {
|
|
const collapseRef = useRef(null)
|
|
const collapseSection = element => {
|
|
const sectionHeight = element.scrollHeight
|
|
requestAnimationFrame(function () {
|
|
element.style.height = sectionHeight + 'px'
|
|
requestAnimationFrame(function () {
|
|
element.style.height = 0 + 'px'
|
|
})
|
|
})
|
|
}
|
|
const expandSection = element => {
|
|
const sectionHeight = element.scrollHeight
|
|
element.style.height = sectionHeight + 'px'
|
|
const clearTime = setTimeout(() => {
|
|
element.style.height = 'auto'
|
|
}, 400)
|
|
clearTimeout(clearTime)
|
|
}
|
|
useEffect(() => {
|
|
const element = collapseRef.current
|
|
if (props.isOpen) {
|
|
expandSection(element)
|
|
} else {
|
|
collapseSection(element)
|
|
}
|
|
}, [props.isOpen])
|
|
return (
|
|
<div ref={collapseRef} className=' overflow-hidden duration-200'>
|
|
{props.children}
|
|
</div>
|
|
)
|
|
}
|
|
Collapse.defaultProps = { isOpen: false }
|
|
|
|
export default Collapse
|