implement version badges rehype plugin
This commit is contained in:
parent
2e8261241f
commit
398318cae2
|
@ -6,6 +6,7 @@ import starlightUtils from "@lorenzo_lewis/starlight-utils";
|
|||
import wasm from "vite-plugin-wasm";
|
||||
|
||||
import shikiConfig from "./src/utils/shiki";
|
||||
import remarkVersionBadges from "./src/remark-plugins/version-badges";
|
||||
|
||||
const playgroundSidebarEntry = {
|
||||
label: 'Playground',
|
||||
|
@ -67,6 +68,9 @@ export default defineConfig({
|
|||
Pagination: "./src/components/override/Pagination.astro",
|
||||
SocialIcons: './src/components/override/SocialIcons.astro',
|
||||
},
|
||||
customCss: [
|
||||
'./src/remark-plugins/version-badges.css',
|
||||
],
|
||||
sidebar: [
|
||||
{
|
||||
label: "leadingNavLinks",
|
||||
|
@ -131,5 +135,10 @@ export default defineConfig({
|
|||
plugins: [
|
||||
wasm(),
|
||||
],
|
||||
}
|
||||
},
|
||||
markdown: {
|
||||
remarkPlugins: [
|
||||
remarkVersionBadges,
|
||||
],
|
||||
},
|
||||
});
|
||||
|
|
|
@ -21,8 +21,10 @@
|
|||
"@mui/icons-material": "^6.1.1",
|
||||
"@mui/material": "^6.1.1",
|
||||
"@shikijs/monaco": "^1.7.0",
|
||||
"@types/mdast": "^4.0.4",
|
||||
"@types/react": "^18.3.3",
|
||||
"@types/react-dom": "^18.3.0",
|
||||
"@types/unist": "^3.0.3",
|
||||
"astro": "^4.15.9",
|
||||
"react": "^18.3.1",
|
||||
"react-dom": "^18.3.1",
|
||||
|
@ -32,6 +34,8 @@
|
|||
"starlight-links-validator": "^0.12.1",
|
||||
"tm-themes": "^1.4.3",
|
||||
"typescript": "^5.4.5",
|
||||
"unified": "^11.0.5",
|
||||
"unist-util-visit": "^5.0.0",
|
||||
"use-immer": "^0.10.0",
|
||||
"vite-plugin-wasm": "^3.3.0"
|
||||
},
|
||||
|
|
|
@ -38,12 +38,18 @@ importers:
|
|||
'@shikijs/monaco':
|
||||
specifier: ^1.7.0
|
||||
version: 1.7.0
|
||||
'@types/mdast':
|
||||
specifier: ^4.0.4
|
||||
version: 4.0.4
|
||||
'@types/react':
|
||||
specifier: ^18.3.3
|
||||
version: 18.3.3
|
||||
'@types/react-dom':
|
||||
specifier: ^18.3.0
|
||||
version: 18.3.0
|
||||
'@types/unist':
|
||||
specifier: ^3.0.3
|
||||
version: 3.0.3
|
||||
astro:
|
||||
specifier: ^4.15.9
|
||||
version: 4.15.9(rollup@4.22.5)(sass@1.77.6)(typescript@5.4.5)
|
||||
|
@ -71,6 +77,12 @@ importers:
|
|||
typescript:
|
||||
specifier: ^5.4.5
|
||||
version: 5.4.5
|
||||
unified:
|
||||
specifier: ^11.0.5
|
||||
version: 11.0.5
|
||||
unist-util-visit:
|
||||
specifier: ^5.0.0
|
||||
version: 5.0.0
|
||||
use-immer:
|
||||
specifier: ^0.10.0
|
||||
version: 0.10.0(immer@10.1.1)(react@18.3.1)
|
||||
|
@ -1014,8 +1026,8 @@ packages:
|
|||
'@types/unist@2.0.10':
|
||||
resolution: {integrity: sha512-IfYcSBWE3hLpBg8+X2SEa8LVkJdJEkT2Ese2aaLs3ptGdVtABxndrMaxuFlQ1qdFf9Q5rDvDpxI3WwgvKFAsQA==}
|
||||
|
||||
'@types/unist@3.0.2':
|
||||
resolution: {integrity: sha512-dqId9J8K/vGi5Zr7oo212BGii5m3q5Hxlkwy3WpYuKPklmBEvsbMYYyLxAQpSffdLl/gdW0XUpKWFvYmyoWCoQ==}
|
||||
'@types/unist@3.0.3':
|
||||
resolution: {integrity: sha512-ko/gIFJRv177XgZsZcBwnqJN5x/Gien8qNOn0D5bQU/zAzVf9Zt3BlcUiLqhV9y4ARk0GbT3tnUiPNgnTXzc/Q==}
|
||||
|
||||
'@ungap/structured-clone@1.2.0':
|
||||
resolution: {integrity: sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==}
|
||||
|
@ -3754,11 +3766,11 @@ snapshots:
|
|||
|
||||
'@types/hast@3.0.4':
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
|
||||
'@types/mdast@4.0.4':
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
|
||||
'@types/mdx@2.0.13': {}
|
||||
|
||||
|
@ -3766,7 +3778,7 @@ snapshots:
|
|||
|
||||
'@types/nlcst@2.0.3':
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
|
||||
'@types/node@17.0.45': {}
|
||||
|
||||
|
@ -3795,7 +3807,7 @@ snapshots:
|
|||
|
||||
'@types/unist@2.0.10': {}
|
||||
|
||||
'@types/unist@3.0.2': {}
|
||||
'@types/unist@3.0.3': {}
|
||||
|
||||
'@ungap/structured-clone@1.2.0': {}
|
||||
|
||||
|
@ -4277,7 +4289,7 @@ snapshots:
|
|||
estree-util-visit@2.0.0:
|
||||
dependencies:
|
||||
'@types/estree-jsx': 1.0.5
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
|
||||
estree-walker@2.0.2: {}
|
||||
|
||||
|
@ -4387,7 +4399,7 @@ snapshots:
|
|||
hast-util-from-parse5@8.0.1:
|
||||
dependencies:
|
||||
'@types/hast': 3.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
devlop: 1.1.0
|
||||
hastscript: 8.0.0
|
||||
property-information: 6.5.0
|
||||
|
@ -4422,7 +4434,7 @@ snapshots:
|
|||
hast-util-raw@9.0.3:
|
||||
dependencies:
|
||||
'@types/hast': 3.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
'@ungap/structured-clone': 1.2.0
|
||||
hast-util-from-parse5: 8.0.1
|
||||
hast-util-to-parse5: 8.0.0
|
||||
|
@ -4438,7 +4450,7 @@ snapshots:
|
|||
hast-util-select@6.0.2:
|
||||
dependencies:
|
||||
'@types/hast': 3.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
bcp-47-match: 2.0.3
|
||||
comma-separated-tokens: 2.0.3
|
||||
css-selector-parser: 3.0.5
|
||||
|
@ -4478,7 +4490,7 @@ snapshots:
|
|||
hast-util-to-html@9.0.1:
|
||||
dependencies:
|
||||
'@types/hast': 3.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
ccount: 2.0.1
|
||||
comma-separated-tokens: 2.0.3
|
||||
hast-util-raw: 9.0.3
|
||||
|
@ -4493,7 +4505,7 @@ snapshots:
|
|||
hast-util-to-html@9.0.3:
|
||||
dependencies:
|
||||
'@types/hast': 3.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
ccount: 2.0.1
|
||||
comma-separated-tokens: 2.0.3
|
||||
hast-util-whitespace: 3.0.0
|
||||
|
@ -4508,7 +4520,7 @@ snapshots:
|
|||
dependencies:
|
||||
'@types/estree': 1.0.5
|
||||
'@types/hast': 3.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
comma-separated-tokens: 2.0.3
|
||||
devlop: 1.1.0
|
||||
estree-util-is-identifier-name: 3.0.0
|
||||
|
@ -4541,7 +4553,7 @@ snapshots:
|
|||
hast-util-to-text@4.0.2:
|
||||
dependencies:
|
||||
'@types/hast': 3.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
hast-util-is-element: 3.0.0
|
||||
unist-util-find-after: 5.0.0
|
||||
|
||||
|
@ -4731,13 +4743,13 @@ snapshots:
|
|||
mdast-util-definitions@6.0.0:
|
||||
dependencies:
|
||||
'@types/mdast': 4.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
unist-util-visit: 5.0.0
|
||||
|
||||
mdast-util-directive@3.0.0:
|
||||
dependencies:
|
||||
'@types/mdast': 4.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
devlop: 1.1.0
|
||||
mdast-util-from-markdown: 2.0.1
|
||||
mdast-util-to-markdown: 2.1.0
|
||||
|
@ -4757,7 +4769,7 @@ snapshots:
|
|||
mdast-util-from-markdown@2.0.1:
|
||||
dependencies:
|
||||
'@types/mdast': 4.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
decode-named-character-reference: 1.0.2
|
||||
devlop: 1.1.0
|
||||
mdast-util-to-string: 4.0.0
|
||||
|
@ -4844,7 +4856,7 @@ snapshots:
|
|||
'@types/estree-jsx': 1.0.5
|
||||
'@types/hast': 3.0.4
|
||||
'@types/mdast': 4.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
ccount: 2.0.1
|
||||
devlop: 1.1.0
|
||||
mdast-util-from-markdown: 2.0.1
|
||||
|
@ -4898,7 +4910,7 @@ snapshots:
|
|||
mdast-util-to-markdown@2.1.0:
|
||||
dependencies:
|
||||
'@types/mdast': 4.0.4
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
longest-streak: 3.1.0
|
||||
mdast-util-phrasing: 4.1.0
|
||||
mdast-util-to-string: 4.0.0
|
||||
|
@ -5130,7 +5142,7 @@ snapshots:
|
|||
dependencies:
|
||||
'@types/acorn': 4.0.6
|
||||
'@types/estree': 1.0.5
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
devlop: 1.1.0
|
||||
estree-util-visit: 2.0.0
|
||||
micromark-util-symbol: 2.0.0
|
||||
|
@ -5302,7 +5314,7 @@ snapshots:
|
|||
parse-latin@7.0.0:
|
||||
dependencies:
|
||||
'@types/nlcst': 2.0.3
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
nlcst-to-string: 4.0.0
|
||||
unist-util-modify-children: 4.0.0
|
||||
unist-util-visit-children: 3.0.0
|
||||
|
@ -5812,7 +5824,7 @@ snapshots:
|
|||
|
||||
unified@11.0.5:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
bail: 2.0.2
|
||||
devlop: 1.1.0
|
||||
extend: 3.0.2
|
||||
|
@ -5822,47 +5834,47 @@ snapshots:
|
|||
|
||||
unist-util-find-after@5.0.0:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
unist-util-is: 6.0.0
|
||||
|
||||
unist-util-is@6.0.0:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
|
||||
unist-util-modify-children@4.0.0:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
array-iterate: 2.0.1
|
||||
|
||||
unist-util-position-from-estree@2.0.0:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
|
||||
unist-util-position@5.0.0:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
|
||||
unist-util-remove-position@5.0.0:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
unist-util-visit: 5.0.0
|
||||
|
||||
unist-util-stringify-position@4.0.0:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
|
||||
unist-util-visit-children@3.0.0:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
|
||||
unist-util-visit-parents@6.0.1:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
unist-util-is: 6.0.0
|
||||
|
||||
unist-util-visit@5.0.0:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
unist-util-is: 6.0.0
|
||||
unist-util-visit-parents: 6.0.1
|
||||
|
||||
|
@ -5881,17 +5893,17 @@ snapshots:
|
|||
|
||||
vfile-location@5.0.2:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
vfile: 6.0.3
|
||||
|
||||
vfile-message@4.0.2:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
unist-util-stringify-position: 4.0.0
|
||||
|
||||
vfile@6.0.3:
|
||||
dependencies:
|
||||
'@types/unist': 3.0.2
|
||||
'@types/unist': 3.0.3
|
||||
vfile-message: 4.0.2
|
||||
|
||||
vite-plugin-wasm@3.3.0(vite@5.4.8(sass@1.77.6)):
|
||||
|
|
|
@ -0,0 +1,55 @@
|
|||
.version-badges {
|
||||
display: flex;
|
||||
gap: 0.5rem;
|
||||
margin: 0.5em 0 !important;
|
||||
margin-bottom: 0 !important;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.version-badges + p {
|
||||
margin-top: 0.5rem !important;
|
||||
}
|
||||
|
||||
.version-badges span {
|
||||
font-size: 0.75rem;
|
||||
padding: 2px 6px;
|
||||
border-radius: 4px;
|
||||
white-space: nowrap;
|
||||
border: 1px solid transparent;
|
||||
}
|
||||
|
||||
html[data-theme='light'] .version-badges .since-badge {
|
||||
background-color: #e0f7fa;
|
||||
color: #00796b;
|
||||
border-color: #b2ebf2;
|
||||
}
|
||||
|
||||
html[data-theme='light'] .version-badges .changed-badge {
|
||||
background-color: #fff8e1;
|
||||
color: #795548;
|
||||
border-color: #ffe082;
|
||||
}
|
||||
|
||||
html[data-theme='light'] .version-badges .deprecated-badge {
|
||||
background-color: #ffebee;
|
||||
color: #b71c1c;
|
||||
border-color: #ffcdd2;
|
||||
}
|
||||
|
||||
html[data-theme='dark'] .version-badges .since-badge {
|
||||
background-color: #004d40;
|
||||
color: #b2dfdb;
|
||||
border-color: #00695c;
|
||||
}
|
||||
|
||||
html[data-theme='dark'] .version-badges .changed-badge {
|
||||
background-color: #3e2723;
|
||||
color: #ffe0b2;
|
||||
border-color: #6d5037;
|
||||
}
|
||||
|
||||
html[data-theme='dark'] .version-badges .deprecated-badge {
|
||||
background-color: #4a0000;
|
||||
color: #ffcdd2;
|
||||
border-color: #b71c1c;
|
||||
}
|
|
@ -0,0 +1,64 @@
|
|||
import { visit } from 'unist-util-visit';
|
||||
import type { Plugin } from 'unified';
|
||||
import type { Parent } from 'unist';
|
||||
import type { Paragraph, Text } from 'mdast';
|
||||
|
||||
const INLINE_REGEX = /!(since|changed|deprecated)\[([^\]]+)\]/g;
|
||||
|
||||
const remarkVersionBadges: Plugin = () => {
|
||||
return (tree) => {
|
||||
visit(tree, 'paragraph', (node, index, parent) => {
|
||||
const paragraph = node as Paragraph;
|
||||
const parentNode = parent as Parent;
|
||||
|
||||
if (!paragraph.children || paragraph.children.length !== 1) return;
|
||||
|
||||
const child = paragraph.children[0];
|
||||
if(child.type !== 'text') return;
|
||||
|
||||
const value = child.value;
|
||||
|
||||
const matches = [...value.matchAll(INLINE_REGEX)];
|
||||
if(matches.length === 0) return;
|
||||
|
||||
const isOnlyBadges = matches.reduce((allMatched, match) => {
|
||||
return allMatched && match[0] === value.slice(match.index!, match.index! + match[0].length)
|
||||
}, true);
|
||||
|
||||
if (!isOnlyBadges) return;
|
||||
|
||||
const badges: string[] = matches.map(([_, type, version]) => {
|
||||
let label = '';
|
||||
let className = '';
|
||||
let title = '';
|
||||
switch(type) {
|
||||
case 'since':
|
||||
label = `Since v${version}`;
|
||||
className = 'since-badge';
|
||||
title = `This feature was added in v${version}`;
|
||||
break;
|
||||
case 'changed':
|
||||
label = `Changed in v${version}`;
|
||||
className = 'changed-badge';
|
||||
title = `This feature was changed in v${version}`;
|
||||
break;
|
||||
case 'deprecated':
|
||||
label = `Deprecated since v${version}`;
|
||||
className = 'deprecated-badge'
|
||||
title = `This feature is deprecated since v${version}`;
|
||||
break;
|
||||
}
|
||||
return `<span class="${className}" title="${title}">${label}</span>`;
|
||||
});
|
||||
|
||||
const htmlNode = {
|
||||
type: 'html',
|
||||
value: `<div class="version-badges">${badges.join('')}</div>`,
|
||||
} as const;
|
||||
|
||||
parentNode.children.splice(index!, 1, htmlNode);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
export default remarkVersionBadges;
|
Loading…
Reference in New Issue