From 29fc03a34cbd98fa470e52f1ea7ecdf0fba95337 Mon Sep 17 00:00:00 2001 From: Rowan Cockett Date: Sun, 22 Oct 2023 11:26:19 -0600 Subject: [PATCH] =?UTF-8?q?=E3=80=B0=20Add=20line=20for=20algorithms=20(#2?= =?UTF-8?q?51)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/myst-to-react/src/basic.tsx | 13 +++++++++++++ styles/app.css | 1 + styles/proof.css | 16 ++++++++++++++++ 3 files changed, 30 insertions(+) create mode 100644 styles/proof.css diff --git a/packages/myst-to-react/src/basic.tsx b/packages/myst-to-react/src/basic.tsx index 81564a956..01d6e7d01 100644 --- a/packages/myst-to-react/src/basic.tsx +++ b/packages/myst-to-react/src/basic.tsx @@ -4,6 +4,7 @@ import type { NodeRenderer } from '@myst-theme/providers'; import classNames from 'classnames'; import { Tooltip } from './components/index.js'; import { MyST } from './MyST.js'; +import type { GenericNode } from 'myst-common'; type TableExts = { rowspan?: number; @@ -46,6 +47,7 @@ type BasicNodeRenderers = { emphasis: NodeRenderer; link: NodeRenderer; paragraph: NodeRenderer; + algorithmLine: NodeRenderer; break: NodeRenderer; inlineMath: NodeRenderer; math: NodeRenderer; @@ -129,6 +131,17 @@ const BASIC_RENDERERS: BasicNodeRenderers = {

); }, + algorithmLine({ node }) { + // Used in algorithms + const style = { + paddingLeft: `${(node.indent ?? 0) + 2}rem`, + }; + return ( +

+ +

+ ); + }, break() { return
; }, diff --git a/styles/app.css b/styles/app.css index 7fb65d115..cb03d6d0d 100644 --- a/styles/app.css +++ b/styles/app.css @@ -12,3 +12,4 @@ @import './tasklists.css'; @import './grid.css'; @import './hover.css'; +@import './proof.css'; diff --git a/styles/proof.css b/styles/proof.css new file mode 100644 index 000000000..bf4469bba --- /dev/null +++ b/styles/proof.css @@ -0,0 +1,16 @@ +p[data-line-number].line::before { + content: attr(data-line-number); + position: absolute; + left: 0; + font-family: monospace; + width: 1.25em; + text-align: right; + user-select: none; + color: gray; + overflow: hidden; +} + +p.line { + position: relative; + margin: 0; +}