mirror of
https://github.com/stefanpejcic/openpanel
synced 2025-06-26 18:28:26 +00:00
35 lines
968 B
TypeScript
35 lines
968 B
TypeScript
import React from "react";
|
|
import clsx from "clsx";
|
|
import { Details as DetailsGeneric } from "@docusaurus/theme-common/Details";
|
|
|
|
export const CommonDetails = (props) => {
|
|
const items = React.Children.toArray(props.children);
|
|
|
|
const summary = items.find(
|
|
(item) =>
|
|
React.isValidElement(item) && item.props?.mdxType === "summary",
|
|
);
|
|
|
|
const children = <>{items.filter((item) => item !== summary)}</>;
|
|
|
|
return (
|
|
<DetailsGeneric
|
|
{...props}
|
|
className={clsx(
|
|
props.className,
|
|
"refine-details",
|
|
"border dark:border-gray-700 border-gray-300",
|
|
"rounded-lg",
|
|
"overflow-hidden",
|
|
"mb-4",
|
|
"refine-wider-container",
|
|
)}
|
|
summary={summary}
|
|
>
|
|
<div className={clsx("p-4")}>{children}</div>
|
|
</DetailsGeneric>
|
|
);
|
|
};
|
|
|
|
export default CommonDetails;
|