From 442133ea2bcf7b1cf1ca42eab1ab83ccda6ff324 Mon Sep 17 00:00:00 2001 From: MrMugame <40832361+MrMugame@users.noreply.github.com> Date: Fri, 7 Jun 2024 08:21:16 +0200 Subject: [PATCH] Add subscript and superscript (#879) * Added superscript and subscript to markdown * Added docs for Superscript and subscript * Remove leftover brace --- common/markdown_parser/customtags.ts | 3 +++ common/markdown_parser/parser.ts | 9 +++++++-- plugs/markdown/markdown_render.ts | 10 ++++++++++ web/cm_plugins/hide_mark.ts | 4 ++++ web/style.ts | 2 ++ web/styles/colors.scss | 17 +++++++++++++---- website/Markdown/Extensions.md | 1 + 7 files changed, 40 insertions(+), 6 deletions(-) diff --git a/common/markdown_parser/customtags.ts b/common/markdown_parser/customtags.ts index 3e5bcd4f..b30a2dbe 100644 --- a/common/markdown_parser/customtags.ts +++ b/common/markdown_parser/customtags.ts @@ -29,3 +29,6 @@ export const NakedURLTag = Tag.define(); export const DirectiveMarkTag = Tag.define(); export const DirectiveTag = Tag.define(); + +export const SubscriptTag = Tag.define(); +export const SuperscriptTag = Tag.define(); diff --git a/common/markdown_parser/parser.ts b/common/markdown_parser/parser.ts index ec04daf3..4c59e146 100644 --- a/common/markdown_parser/parser.ts +++ b/common/markdown_parser/parser.ts @@ -8,6 +8,8 @@ import { Line, MarkdownConfig, Strikethrough, + Subscript, + Superscript, } from "@lezer/markdown"; import { markdown } from "@codemirror/lang-markdown"; import { StreamLanguage } from "@codemirror/language"; @@ -624,6 +626,8 @@ export const extendedMarkdownLanguage = markdown({ Hashtag, TaskDeadline, NamedAnchor, + Superscript, + Subscript, { props: [ foldNodeProp.add({ @@ -646,8 +650,9 @@ export const extendedMarkdownLanguage = markdown({ Task: ct.TaskTag, TaskMark: ct.TaskMarkTag, Comment: ct.CommentTag, - "TableDelimiter SubscriptMark SuperscriptMark StrikethroughMark": - t.processingInstruction, + "Subscript": ct.SubscriptTag, + "Superscript": ct.SuperscriptTag, + "TableDelimiter StrikethroughMark": t.processingInstruction, "TableHeader/...": t.heading, TableCell: t.content, CodeInfo: ct.CodeInfoTag, diff --git a/plugs/markdown/markdown_render.ts b/plugs/markdown/markdown_render.ts index 87d581b4..c579e605 100644 --- a/plugs/markdown/markdown_render.ts +++ b/plugs/markdown/markdown_render.ts @@ -477,6 +477,16 @@ function render( body: renderToText(t), }; } + case "Superscript": + return { + name: "sup", + body: cleanTags(mapRender(t.children!)), + }; + case "Subscript": + return { + name: "sub", + body: cleanTags(mapRender(t.children!)), + }; // Text case undefined: diff --git a/web/cm_plugins/hide_mark.ts b/web/cm_plugins/hide_mark.ts index 3a20e0a2..c9f70ffb 100644 --- a/web/cm_plugins/hide_mark.ts +++ b/web/cm_plugins/hide_mark.ts @@ -21,6 +21,8 @@ const typesWithMarks = [ "InlineCode", "Highlight", "Strikethrough", + "Superscript", + "Subscript", ]; /** * The elements which are used as marks. @@ -30,6 +32,8 @@ const markTypes = [ "CodeMark", "HighlightMark", "StrikethroughMark", + "SuperscriptMark", + "SubscriptMark", ]; /** diff --git a/web/style.ts b/web/style.ts index 5396bbc6..c59505e9 100644 --- a/web/style.ts +++ b/web/style.ts @@ -53,6 +53,8 @@ export default function highlightStyles() { { tag: ct.NakedURLTag, class: "sb-naked-url" }, { tag: ct.TaskDeadlineTag, class: "sb-task-deadline" }, { tag: ct.NamedAnchorTag, class: "sb-named-anchor" }, + { tag: ct.SubscriptTag, class: "sb-sub" }, + { tag: ct.SuperscriptTag, class: "sb-sup" }, { tag: ct.DirectiveMarkTag, class: "sb-directive-mark" }, { tag: ct.DirectiveTag, class: "sb-directive" }, diff --git a/web/styles/colors.scss b/web/styles/colors.scss index 05b866bd..4bdee6a8 100644 --- a/web/styles/colors.scss +++ b/web/styles/colors.scss @@ -218,9 +218,9 @@ .sb-line-h3 .sb-meta, .sb-line-h4 .sb-meta, .sb-line-h5 .sb-meta, - .sb-line-h6 .sb-meta, - { - color: var(--editor-heading-meta-color); + .sb-line-h6 .sb-meta { + color: var(--editor-heading-meta-color); + } } .sb-hashtag, @@ -386,6 +386,16 @@ tbody tr:nth-of-type(even) { font-weight: 900; } +.sb-sub { + vertical-align: sub; + font-size: smaller; +} + +.sb-sup { + vertical-align: super; + font-size: smaller; +} + .sb-line-code-outside .sb-code-info { color: var(--editor-code-info-color); } @@ -432,5 +442,4 @@ a.sb-wiki-link-page-missing, .sb-line-comment { background-color: var(--editor-code-comment-color); // rgba(255, 255, 0, 0.5); -} } \ No newline at end of file diff --git a/website/Markdown/Extensions.md b/website/Markdown/Extensions.md index dba29fac..dcbc23c6 100644 --- a/website/Markdown/Extensions.md +++ b/website/Markdown/Extensions.md @@ -15,4 +15,5 @@ In addition to supporting [[Markdown/Basics|markdown basics]] as standardized by * [Task lists](https://www.markdownguide.org/extended-syntax/#task-lists) * [Highlight](https://www.markdownguide.org/extended-syntax/#highlight) * [Automatic URL linking](https://www.markdownguide.org/extended-syntax/#automatic-url-linking) +* [Subscript](https://www.markdownguide.org/extended-syntax/#subscript) and [superscript](https://www.markdownguide.org/extended-syntax/#superscript) * Any addition custom markdown extensions provided by [[Plugs]]