mirror of
https://github.com/XTLS/Xray-docs-next.git
synced 2025-02-01 07:21:40 +03:00
68 lines
1.5 KiB
Vue
68 lines
1.5 KiB
Vue
|
<template>
|
||
|
<div v-html="payload.innerHtml"></div>
|
||
|
</template>
|
||
|
|
||
|
<script lang="ts">
|
||
|
import {
|
||
|
defineComponent,
|
||
|
onMounted,
|
||
|
nextTick,
|
||
|
toRef,
|
||
|
watch,
|
||
|
reactive,
|
||
|
} from "vue";
|
||
|
import { useDarkMode } from "@vuepress/theme-default/lib/client";
|
||
|
export default defineComponent({
|
||
|
name: "Mermaid",
|
||
|
props: {
|
||
|
identifier: String,
|
||
|
graph: String,
|
||
|
},
|
||
|
setup(props) {
|
||
|
const dark = useDarkMode();
|
||
|
const chartID = toRef(props, "identifier");
|
||
|
const rawGraph = toRef(props, "graph");
|
||
|
const html = reactive({ innerHtml: "" });
|
||
|
onMounted(() => {
|
||
|
nextTick(async function () {
|
||
|
console.log(chartID, rawGraph);
|
||
|
const mermaid = await import("mermaid");
|
||
|
mermaid.default.initialize({
|
||
|
startOnLoad: false,
|
||
|
theme: dark.value ? "dark" : "default",
|
||
|
});
|
||
|
mermaid.default.render(
|
||
|
chartID.value,
|
||
|
rawGraph.value,
|
||
|
(svgCode, bindFunc) => {
|
||
|
html.innerHtml = svgCode;
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
watch(dark, async () => {
|
||
|
const mermaid = await import("mermaid");
|
||
|
mermaid.default.initialize({
|
||
|
startOnLoad: false,
|
||
|
theme: dark.value ? "dark" : "default",
|
||
|
});
|
||
|
mermaid.default.render(
|
||
|
chartID.value,
|
||
|
rawGraph.value,
|
||
|
(svgCode, bindFunc) => {
|
||
|
html.innerHtml = svgCode;
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
|
||
|
return {
|
||
|
tag: chartID,
|
||
|
payload: html,
|
||
|
};
|
||
|
},
|
||
|
});
|
||
|
</script>
|
||
|
|
||
|
<style scoped></style>
|