diff --git a/docs/src/about_guide.md b/docs/src/about_guide.md
index 6f709b580d..5422478e59 100644
--- a/docs/src/about_guide.md
+++ b/docs/src/about_guide.md
@@ -35,6 +35,8 @@ Horizontal Rule
\--- | Horizontal Rule
\*\*\* | Horizontal Rule
\`Inline code\` with backticks | |`Inline code` with backticks
\`\`\`
\# code block
print '3 backticks or'
print 'indent 4 spaces'
\`\`\` | ····\# code block
····print '3 backticks or'
····print 'indent 4 spaces' | \# code block
print '3 backticks or'
print 'indent 4 spaces'
::: spoiler hidden or nsfw stuff
*a bunch of spoilers here*
::: | | hidden or nsfw stuff
a bunch of spoilers here
+Some ~subscript~ text | | Some subscript text
+Some ^superscript^ text | | ome superscript text
[CommonMark Tutorial](https://commonmark.org/help/tutorial/)
diff --git a/ui/package.json b/ui/package.json
index 1bd07e8637..f59b86255c 100644
--- a/ui/package.json
+++ b/ui/package.json
@@ -37,6 +37,8 @@
"markdown-it": "^10.0.0",
"markdown-it-container": "^2.0.0",
"markdown-it-emoji": "^1.4.0",
+ "markdown-it-sub": "^1.0.0",
+ "markdown-it-sup": "^1.0.0",
"moment": "^2.24.0",
"node-fetch": "^2.6.0",
"prettier": "^2.0.4",
diff --git a/ui/src/components/markdown-textarea.tsx b/ui/src/components/markdown-textarea.tsx
index 2f6d0a7ecd..04838b2c8c 100644
--- a/ui/src/components/markdown-textarea.tsx
+++ b/ui/src/components/markdown-textarea.tsx
@@ -469,6 +469,16 @@ export class MarkdownTextArea extends Component<
i.simpleInsert('#');
}
+ handleInsertSubscript(i: MarkdownTextArea, event: any) {
+ event.preventDefault();
+ i.simpleInsert('~');
+ }
+
+ handleInsertSuperscript(i: MarkdownTextArea, event: any) {
+ event.preventDefault();
+ i.simpleInsert('^');
+ }
+
simpleInsert(chars: string) {
if (!this.state.content) {
this.state.content = `${chars} `;
diff --git a/ui/src/utils.ts b/ui/src/utils.ts
index 960477650d..892516bff2 100644
--- a/ui/src/utils.ts
+++ b/ui/src/utils.ts
@@ -49,6 +49,8 @@ import { UserService, WebSocketService } from './services';
import Tribute from 'tributejs/src/Tribute.js';
import markdown_it from 'markdown-it';
+import markdown_it_sub from 'markdown-it-sub';
+import markdown_it_sup from 'markdown-it-sup';
import markdownitEmoji from 'markdown-it-emoji/light';
import markdown_it_container from 'markdown-it-container';
import emojiShortName from 'emoji-short-name';
@@ -148,6 +150,8 @@ export const md = new markdown_it({
linkify: true,
typographer: true,
})
+ .use(markdown_it_sub)
+ .use(markdown_it_sup)
.use(markdown_it_container, 'spoiler', {
validate: function (params: any) {
return params.trim().match(/^spoiler\s+(.*)$/);
diff --git a/ui/yarn.lock b/ui/yarn.lock
index c39f1dc4b0..ad77fffd7d 100644
--- a/ui/yarn.lock
+++ b/ui/yarn.lock
@@ -4317,6 +4317,16 @@ markdown-it-emoji@^1.4.0:
resolved "https://registry.yarnpkg.com/markdown-it-emoji/-/markdown-it-emoji-1.4.0.tgz#9bee0e9a990a963ba96df6980c4fddb05dfb4dcc"
integrity sha1-m+4OmpkKljupbfaYDE/dsF37Tcw=
+markdown-it-sub@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/markdown-it-sub/-/markdown-it-sub-1.0.0.tgz#375fd6026eae7ddcb012497f6411195ea1e3afe8"
+ integrity sha1-N1/WAm6ufdywEkl/ZBEZXqHjr+g=
+
+markdown-it-sup@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/markdown-it-sup/-/markdown-it-sup-1.0.0.tgz#cb9c9ff91a5255ac08f3fd3d63286e15df0a1fc3"
+ integrity sha1-y5yf+RpSVawI8/09YyhuFd8KH8M=
+
markdown-it@^10.0.0:
version "10.0.0"
resolved "https://registry.yarnpkg.com/markdown-it/-/markdown-it-10.0.0.tgz#abfc64f141b1722d663402044e43927f1f50a8dc"