require('./splitPane.less'); const React = require('react'); const { useState, useEffect, useRef } = React; const cx = require('classnames'); const SplitPane = (props)=>{ const { storageKey = 'naturalcrit-pane-split', onDragFinish = ()=>{}, showDividerButtons = true } = props; const [isDragging, setIsDragging] = useState(false); const [dividerPos, setDividerPos] = useState(null); // Initial divider position is set to `null` const [moveSource, setMoveSource] = useState(false); const [moveBrew, setMoveBrew] = useState(false); const [showMoveArrows, setShowMoveArrows] = useState(true); const [liveScroll, setLiveScroll] = useState(false); const dividerRef = useRef(null); // Set initial divider position and liveScroll only after mounting useEffect(()=>{ const savedPos = window.localStorage.getItem(storageKey); setDividerPos(savedPos ? parseInt(savedPos, 10) : window.innerWidth / 2); setLiveScroll(window.localStorage.getItem('liveScroll') === 'true'); const handleResize = ()=>{ setDividerPos((pos)=>limitPosition(pos,0.1 * (window.innerWidth - 13), 0.9 * (window.innerWidth - 13)) ); }; window.addEventListener('resize', handleResize); return ()=>window.removeEventListener('resize', handleResize); }, [storageKey]); const limitPosition = (x, min = 1, max = window.innerWidth - 13)=>{ return Math.round(Math.min(max, Math.max(min, x))); }; const handleUp =(e)=>{ e.preventDefault(); if(isDragging) { onDragFinish(dividerPos); window.localStorage.setItem(storageKey, dividerPos); } setIsDragging(false); }; const handleDown = (e)=>{ e.preventDefault(); setIsDragging(true); }; const handleMove = (e)=>{ if(!isDragging) return; e.preventDefault(); const newSize = limitPosition(e.pageX); setDividerPos(newSize); }; const liveScrollToggle = ()=>{ window.localStorage.setItem('liveScroll', String(!liveScroll)); setLiveScroll(!liveScroll); }; const moveArrows = showMoveArrows && ( <> {['left', 'right'].map((direction, index) => (
setMoveSource(!moveSource) : () => setMoveBrew(!moveBrew)} >
))}
); const renderDivider = ()=>(
{showDividerButtons && moveArrows}
); return (
{props.children[0]} {renderDivider()} {props.children[1]}
); }; const Pane = ({ width, children, isDragging, className, moveBrew, moveSource, liveScroll, setMoveArrows })=>{ const styles = width ? { flex: 'none', width: `${width}px` } : { pointerEvents: isDragging ? 'none' : 'auto' }; return (
{React.cloneElement(children, { moveBrew, moveSource, liveScroll, setMoveArrows })}
); }; module.exports = SplitPane;