import ReactMarkdown, { Components } from "react-markdown";
import remarkGfm from "remark-gfm";
import rehypeRaw from "rehype-raw";
import { Label } from "./ui/Label";
import { createElement } from "react";
export const createMarkdownElement = (tag: keyof JSX.IntrinsicElements, props: any) =>
createElement(tag, {
...props,
});
// Styling for HTML attributes for markdown component
const REACT_MARKDOWN_CONFIG: Components = {
img: ({ node, className, ...props }) =>
createMarkdownElement("img", {
className: `${className} py-10`,
...props,
}),
a: ({ node, ...props }) =>
createMarkdownElement("a", {
className: "text-orange",
target: "_blank",
...props,
}),
u: ({ node, ...props }) =>
createMarkdownElement("span", {
className: "underline",
...props,
}),
ins: ({ node, ...props }) =>
createMarkdownElement("span", {
className: "underline",
...props,
}),
strong: ({ node, ...props }) =>
createMarkdownElement("span", {
className: "underline",
...props,
}),
b: ({ node, ...props }) =>
createMarkdownElement("b", {
className: "text-bold",
...props,
}),
span: ({ ...props }: any) => ,
p: ({ ...props }: any) => ,
};
interface MarkdownProps {
children: string;
customComponents?: Components;
}
export const AppMarkdown = ({ children, customComponents, ...props }: MarkdownProps) => {
return (
{children}
);
};