antd
Version:
An enterprise-class UI design language and React components implementation
33 lines (32 loc) • 823 B
JavaScript
"use client";
import React from 'react';
import { createPortal } from 'react-dom';
import { clsx } from 'clsx';
const supportPortalHost = hostDom => typeof HTMLElement !== 'undefined' && hostDom instanceof HTMLElement;
const BorderBeamEffectElement = props => {
const {
prefixCls,
className,
...rest
} = props;
return /*#__PURE__*/React.createElement("div", {
"aria-hidden": "true",
className: clsx(prefixCls, className),
...rest
});
};
const BorderBeamEffect = props => {
const {
prefixCls,
hostDom,
...rest
} = props;
if (!hostDom || !supportPortalHost(hostDom)) {
return null;
}
return /*#__PURE__*/createPortal(/*#__PURE__*/React.createElement(BorderBeamEffectElement, {
prefixCls: prefixCls,
...rest
}), hostDom);
};
export default BorderBeamEffect;