mirror of
https://github.com/d0zingcat/NotionNext.git
synced 2026-06-03 07:26:45 +00:00
feature:通用组件
This commit is contained in:
38
components/CollapseLeft.js
Normal file
38
components/CollapseLeft.js
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
import React, { useEffect, useRef } from 'react'
|
||||||
|
|
||||||
|
const Collapse = props => {
|
||||||
|
const collapseRef = useRef(null)
|
||||||
|
const collapseSection = element => {
|
||||||
|
const sectionWidth = element.scrollWidth
|
||||||
|
requestAnimationFrame(function () {
|
||||||
|
element.style.width = sectionWidth + 'px'
|
||||||
|
requestAnimationFrame(function () {
|
||||||
|
element.style.width = 0 + 'px'
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
const expandSection = element => {
|
||||||
|
const sectionWidth = element.scrollWidth
|
||||||
|
element.style.width = sectionWidth + 'px'
|
||||||
|
const clearTime = setTimeout(() => {
|
||||||
|
element.style.width = 'auto'
|
||||||
|
}, 400)
|
||||||
|
clearTimeout(clearTime)
|
||||||
|
}
|
||||||
|
useEffect(() => {
|
||||||
|
const element = collapseRef.current
|
||||||
|
if (props.isOpen) {
|
||||||
|
expandSection(element)
|
||||||
|
} else {
|
||||||
|
collapseSection(element)
|
||||||
|
}
|
||||||
|
}, [props.isOpen])
|
||||||
|
return (
|
||||||
|
<div ref={collapseRef} style={{ width: '0px' }} className={'overflow-hidden duration-200 ' + props.className}>
|
||||||
|
{props.children}
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
Collapse.defaultProps = { isOpen: false }
|
||||||
|
|
||||||
|
export default Collapse
|
||||||
55
components/SideBarDrawer.js
Normal file
55
components/SideBarDrawer.js
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
import { useRouter } from 'next/router'
|
||||||
|
import React from 'react'
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 侧边栏抽屉面板,可以从侧面拉出
|
||||||
|
* @returns {JSX.Element}
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
|
const SideBarDrawer = ({ children, isOpen, onOpen, onClose, className }) => {
|
||||||
|
const router = useRouter()
|
||||||
|
React.useEffect(() => {
|
||||||
|
// 页面渲染后删除hidden属性
|
||||||
|
// const sideBarWrapperElement = document.getElementById('sidebar-wrapper')
|
||||||
|
// sideBarWrapperElement?.classList?.remove('hidden')
|
||||||
|
|
||||||
|
const sideBarDrawerRouteListener = () => {
|
||||||
|
switchSideDrawerVisible(false)
|
||||||
|
}
|
||||||
|
router.events.on('routeChangeComplete', sideBarDrawerRouteListener)
|
||||||
|
return () => {
|
||||||
|
router.events.off('routeChangeComplete', sideBarDrawerRouteListener)
|
||||||
|
}
|
||||||
|
}, [router.events])
|
||||||
|
|
||||||
|
// 点击按钮更改侧边抽屉状态
|
||||||
|
const switchSideDrawerVisible = (showStatus) => {
|
||||||
|
if (window) {
|
||||||
|
if (showStatus) {
|
||||||
|
onOpen()
|
||||||
|
} else {
|
||||||
|
onClose()
|
||||||
|
}
|
||||||
|
const sideBarDrawer = window.document.getElementById('sidebar-drawer')
|
||||||
|
const sideBarDrawerBackground = window.document.getElementById('sidebar-drawer-background')
|
||||||
|
|
||||||
|
if (showStatus) {
|
||||||
|
sideBarDrawer.classList.replace('-ml-80', 'ml-0')
|
||||||
|
sideBarDrawerBackground.classList.replace('hidden', 'block')
|
||||||
|
} else {
|
||||||
|
sideBarDrawer.classList.replace('ml-0', '-ml-80')
|
||||||
|
sideBarDrawerBackground.classList.replace('block', 'hidden')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return <div id='sidebar-wrapper' className={' ' + className}>
|
||||||
|
<div id='sidebar-drawer' className={`${isOpen ? 'ml-0' : '-ml-80'} bg-white dark:bg-gray-900 flex flex-col duration-300 fixed h-full left-0 overflow-y-scroll scroll-hidden top-0 z-50`}>
|
||||||
|
{children}
|
||||||
|
</div>
|
||||||
|
{/* 背景蒙版 */}
|
||||||
|
<div id='sidebar-drawer-background' onClick={() => { switchSideDrawerVisible(false) }}
|
||||||
|
className={`${isOpen ? 'block' : 'hidden'} animate__animated animate__fadeIn fixed top-0 duration-300 left-0 z-30 w-full h-full glassmorphism`}/>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
export default SideBarDrawer
|
||||||
Reference in New Issue
Block a user