feat: support markdown

This commit is contained in:
guanghechen 2024-07-10 16:17:23 +08:00
parent bd230ddd4f
commit 85d144a1e9
34 changed files with 2350 additions and 4 deletions

View file

@ -0,0 +1,42 @@
import { css, cx } from "@emotion/css";
import type { Blockquote } from "@yozora/ast";
import React from "react";
import { astClasses } from "../context";
import { NodesRenderer } from "../NodesRenderer";
/**
* Render `blockquote`.
*
* @see https://www.npmjs.com/package/@yozora/ast#blockquote
* @see https://www.npmjs.com/package/@yozora/tokenizer-blockquote
*/
export class BlockquoteRenderer extends React.Component<Blockquote> {
public override shouldComponentUpdate(nextProps: Readonly<Blockquote>): boolean {
const props = this.props;
return props.children !== nextProps.children;
}
public override render(): React.ReactElement {
const childNodes = this.props.children;
return (
<blockquote className={cls}>
<NodesRenderer nodes={childNodes} />
</blockquote>
);
}
}
const cls = cx(
astClasses.blockquote,
css({
boxSizing: "border-box",
padding: "0.625em 1em",
borderLeft: "0.25em solid var(--colorBorderBlockquote)",
margin: "0px 0px 1.25em 0px",
background: "var(--colorBgBlockquote)",
boxShadow: "0 1px 2px 0 hsla(0deg, 0%, 0%, 0.1)",
"> :last-child": {
marginBottom: 0,
},
}),
);