UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

24 lines 730 B
import * as React from 'react'; import { useEvent } from '@rc-component/util'; function voidFunc() {} const WatermarkContext = /*#__PURE__*/React.createContext({ add: voidFunc, remove: voidFunc }); export function usePanelRef(panelSelector) { const watermark = React.useContext(WatermarkContext); const panelEleRef = React.useRef(null); const panelRef = useEvent(ele => { if (ele) { const innerContentEle = panelSelector ? ele.querySelector(panelSelector) : ele; if (innerContentEle) { watermark.add(innerContentEle); panelEleRef.current = innerContentEle; } } else { watermark.remove(panelEleRef.current); } }); return panelRef; } export default WatermarkContext;