feat: support markdown
This commit is contained in:
parent
bd230ddd4f
commit
85d144a1e9
34 changed files with 2350 additions and 4 deletions
53
ui/components/Markdown/renderer/list.tsx
Normal file
53
ui/components/Markdown/renderer/list.tsx
Normal file
|
@ -0,0 +1,53 @@
|
|||
import { css, cx } from "@emotion/css";
|
||||
import type { List } from "@yozora/ast";
|
||||
import React from "react";
|
||||
import { astClasses } from "../context";
|
||||
import { NodesRenderer } from "../NodesRenderer";
|
||||
|
||||
/**
|
||||
* Render `list`.
|
||||
*
|
||||
* @see https://www.npmjs.com/package/@yozora/ast#list
|
||||
* @see https://www.npmjs.com/package/@yozora/tokenizer-list
|
||||
*/
|
||||
export class ListRenderer extends React.Component<List> {
|
||||
public override shouldComponentUpdate(nextProps: Readonly<List>): boolean {
|
||||
const props = this.props;
|
||||
return (
|
||||
props.ordered !== nextProps.ordered ||
|
||||
props.orderType !== nextProps.orderType ||
|
||||
props.start !== nextProps.start ||
|
||||
props.children !== nextProps.children
|
||||
);
|
||||
}
|
||||
|
||||
public override render(): React.ReactElement {
|
||||
const { ordered, orderType, start, children } = this.props;
|
||||
|
||||
if (ordered) {
|
||||
return (
|
||||
<ol className={cls} type={orderType} start={start}>
|
||||
<NodesRenderer nodes={children} />
|
||||
</ol>
|
||||
);
|
||||
}
|
||||
|
||||
return (
|
||||
<ul className={cls}>
|
||||
<NodesRenderer nodes={children} />
|
||||
</ul>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
const cls = cx(
|
||||
astClasses.list,
|
||||
css({
|
||||
padding: "0px",
|
||||
margin: "0 0 1em 2em",
|
||||
lineHeight: "2",
|
||||
"> :last-child": {
|
||||
marginBottom: "0px",
|
||||
},
|
||||
}),
|
||||
);
|
Loading…
Add table
Add a link
Reference in a new issue