livecode-static/docs/assets/js/ca96397b.806510c9.js
2025-06-11 22:23:49 +08:00

1 line
36 KiB
JavaScript

"use strict";(self.webpackChunkdocs=self.webpackChunkdocs||[]).push([["6467"],{8317:function(e,n,a){a.r(n),a.d(n,{default:()=>g,frontMatter:()=>d,metadata:()=>i,assets:()=>r,toc:()=>h,contentTitle:()=>c});var i=JSON.parse('{"id":"languages/diagrams","title":"Diagrams","description":"Overview","source":"@site/docs/languages/diagrams.mdx","sourceDirName":"languages","slug":"/languages/diagrams","permalink":"/docs/languages/diagrams","draft":false,"unlisted":false,"editUrl":"https://github.com/live-codes/livecodes/tree/develop/docs/docs/languages/diagrams.mdx","tags":[],"version":"current","frontMatter":{},"sidebar":"docsSidebar","previous":{"title":"cssnano","permalink":"/docs/languages/cssnano"},"next":{"title":"doT","permalink":"/docs/languages/dot"}}'),t=a("5893"),l=a("65");function s(e){let n=e.id?`/?x=id/${e.id}`:e.template?`/?template=${e.template}`:"/";return(0,t.jsx)("a",{href:n,target:"_blank",children:e.children||"open in LiveCodes"})}let d={},c="Diagrams",r={},h=[{value:"Overview",id:"overview",level:2},{value:"Usage",id:"usage",level:2},{value:"1. Add a diagram target:",id:"1-add-a-diagram-target",level:4},{value:"2. Add a script element with the diagram syntax:",id:"2-add-a-script-element-with-the-diagram-syntax",level:4},{value:"Supported Libraries",id:"supported-libraries",level:2},{value:"Cytoscape",id:"cytoscape",level:3},{value:"ELK",id:"elk",level:3},{value:"Gnuplot",id:"gnuplot",level:3},{value:"Graphviz",id:"graphviz",level:3},{value:"Mermaid",id:"mermaid",level:3},{value:"Nomnoml",id:"nomnoml",level:3},{value:"Pintora",id:"pintora",level:3},{value:"Plotly",id:"plotly",level:3},{value:"Svgbob",id:"svgbob",level:3},{value:"Vega",id:"vega",level:3},{value:"VegaLite",id:"vegalite",level:3},{value:"WaveDrom",id:"wavedrom",level:3}];function o(e){let n={a:"a",code:"code",h1:"h1",h2:"h2",h3:"h3",h4:"h4",header:"header",img:"img",li:"li",p:"p",pre:"pre",ul:"ul",...(0,l.a)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(n.header,{children:(0,t.jsx)(n.h1,{id:"diagrams",children:"Diagrams"})}),"\n","\n",(0,t.jsx)(n.h2,{id:"overview",children:"Overview"}),"\n",(0,t.jsx)(n.p,{children:"Diagrams-as-code."}),"\n",(0,t.jsxs)(n.p,{children:["Allows using syntax for multiple visualization libraries inside HTML to produce diagrams.\nThe rendered diagrams are added to the ",(0,t.jsx)(n.a,{href:"/docs/features/result",children:"result page"})," as either:"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:"SVG elements (which you can style with CSS or manipulate with JavaScript)"}),"\n",(0,t.jsx)(n.li,{children:"HTML images (which you can right-click and save or open in a new window)"}),"\n"]}),"\n",(0,t.jsx)(n.p,{children:"Diagrams from multiple libraries can be used in the same page. Only the libraries used will be loaded in the LiveCodes playground. The result page will have no libraries (only the output SVG or images)."}),"\n",(0,t.jsx)(s,{template:"diagrams",children:"Open starter template in LiveCodes"}),"\n",(0,t.jsx)(n.h2,{id:"usage",children:"Usage"}),"\n",(0,t.jsxs)(n.p,{children:["This code: (",(0,t.jsx)(s,{id:"2m8u9hgeiq4"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="my-diagram"></div>\n\n<script type="application/diagram-mermaid" data-output="my-diagram">\n graph TD\n A--\x3eB\n A--\x3eC\n B--\x3eD\n C--\x3eD\n<\/script>\n'})}),"\n",(0,t.jsx)(n.p,{children:"produces this output:"}),"\n",(0,t.jsx)(n.p,{children:(0,t.jsx)(n.img,{alt:"flow-chart",src:a(2356).Z+"",width:"125",height:"232"})}),"\n",(0,t.jsx)("h3",{children:"Steps"}),"\n",(0,t.jsx)(n.h4,{id:"1-add-a-diagram-target",children:"1. Add a diagram target:"}),"\n",(0,t.jsxs)(n.p,{children:["The target element should have a ",(0,t.jsx)(n.code,{children:"data-src"})," attribute."]}),"\n",(0,t.jsx)(n.p,{children:"It can be an HTML element (the SVG of the diagram will be embedded as a child element)"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="my-diagram"></div>\n'})}),"\n",(0,t.jsx)(n.p,{children:"becomes"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="my-diagram"><svg ...>...</svg></div>\n'})}),"\n",(0,t.jsxs)(n.p,{children:["or an HTML image element (the diagram will be added to its ",(0,t.jsx)(n.code,{children:"src"})," attribute as a ",(0,t.jsx)(n.a,{href:"https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URLs",children:"data URL"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<img data-src="my-diagram" />\n'})}),"\n",(0,t.jsx)(n.p,{children:"becomes"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<img data-src="my-diagram" src="data:image/svg+xml;base64,..." />\n'})}),"\n",(0,t.jsxs)(n.p,{children:["There can be more that one target element for the same diagram if they have the same ",(0,t.jsx)(n.code,{children:"data-src"})," attribute."]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="my-diagram"></div>\n<img data-src="my-diagram" />\n'})}),"\n",(0,t.jsx)(n.h4,{id:"2-add-a-script-element-with-the-diagram-syntax",children:"2. Add a script element with the diagram syntax:"}),"\n",(0,t.jsx)(n.p,{children:"It should have:"}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsxs)(n.li,{children:["an attribute ",(0,t.jsx)(n.code,{children:'type="application/diagram-{diagram type}"'})," that specifies the diagram type (e.g. ",(0,t.jsx)(n.code,{children:'type="application/diagram-mermaid"'}),")."]}),"\n",(0,t.jsxs)(n.li,{children:["a ",(0,t.jsx)(n.code,{children:"data-output"})," attribute that matches the ",(0,t.jsx)(n.code,{children:"data-src"})," attribute of the target element."]}),"\n",(0,t.jsxs)(n.li,{children:["the syntax of the diagram is the content of the script element or the content of a file linked by the ",(0,t.jsx)(n.code,{children:"src"})," attribute."]}),"\n"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<script type="application/diagram-mermaid" data-output="my-diagram">\n graph TD\n A--\x3eB\n A--\x3eC\n B--\x3eD\n C--\x3eD\n<\/script>\n\n<script\n type="application/diagram-mermaid"\n data-output="second-diagram"\n src="/url/to/diagram/syntax"\n><\/script>\n'})}),"\n",(0,t.jsx)(n.h2,{id:"supported-libraries",children:"Supported Libraries"}),"\n",(0,t.jsx)(n.h3,{id:"cytoscape",children:(0,t.jsx)(n.a,{href:"https://js.cytoscape.org/",children:"Cytoscape"})}),"\n",(0,t.jsxs)(n.p,{children:["The diagram syntax is JSON representing ",(0,t.jsx)(n.a,{href:"https://js.cytoscape.org/#getting-started/specifying-basic-options",children:"Cytoscape options"}),"."]}),"\n",(0,t.jsxs)(n.p,{children:["Please note that reference to JavaScript objects cannot be used.",(0,t.jsx)("br",{})," e.g. do not use ",(0,t.jsx)(n.code,{children:"{container: document.getElementById('cy')}"}),"."]}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"nq6954cuvgs"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="cytoscape.svg"></div>\n<script type="application/diagram-cytoscape" data-output="cytoscape.svg">\n {\n "elements": [\n {\n "data": { "id": "a" }},\n {\n "data": { "id": "b" }},\n {\n "data": { "id": "ab", "source": "a", "target": "b" }}],\n\n "style": [\n {\n "selector": "node",\n "style": {\n "background-color": "#666",\n "label": "data(id)"}\n },\n\n {\n "selector": "edge",\n "style": {\n "width": 3,\n "line-color": "#ccc",\n "target-arrow-color": "#ccc",\n "target-arrow-shape": "triangle",\n "curve-style": "bezier"\n }\n }\n ],\n\n "layout": {\n "name": "grid",\n "rows": 1\n }\n\n }\n<\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"elk",children:(0,t.jsx)(n.a,{href:"https://www.eclipse.org/elk/",children:"ELK"})}),"\n",(0,t.jsxs)(n.p,{children:["Diagram layout is produced using ",(0,t.jsx)(n.a,{href:"https://github.com/kieler/elkjs",children:"elkjs"})," and rendered using ",(0,t.jsx)(n.a,{href:"https://github.com/EmilStenstrom/elkjs-svg",children:"elkjs-svg"}),"."]}),"\n",(0,t.jsxs)(n.p,{children:["The syntax used is ",(0,t.jsx)(n.a,{href:"https://www.eclipse.org/elk/documentation/tooldevelopers/graphdatastructure/jsonformat.html",children:"ELK JSON"})," format. ",(0,t.jsx)("br",{}),"ELK text format is not supported! (You may use ",(0,t.jsx)(n.a,{href:"https://rtsys.informatik.uni-kiel.de/elklive/conversion.html",children:"this tool"})," to convert formats)"]}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"49cbr5k3z69"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="elk.svg"></div>\n<script type="application/diagram-elk" data-output="elk.svg">\n {\n "id": "root",\n "layoutOptions": {\n "elk.algorithm": "layered"\n },\n "children": [\n {"id": "n1", "width": 70, "height": 70},\n {"id": "n2", "width": 70, "height": 70},\n {"id": "n3", "width": 70, "height": 70},\n {"id": "n4", "width": 70, "height": 70},\n {"id": "n5", "width": 70, "height": 70},\n {"id": "n6", "width": 70, "height": 70}\n ],\n "edges": [\n {"id": "e1", "sources": ["n1"], "targets": ["n2"]},\n {"id": "e2", "sources": ["n1"], "targets": ["n3"]},\n {"id": "e3", "sources": ["n2"], "targets": ["n4"]},\n {"id": "e4", "sources": ["n3"], "targets": ["n5"]},\n {"id": "e5", "sources": ["n5"], "targets": ["n6"]},\n {"id": "e6", "sources": ["n4"], "targets": ["n6"]}\n ]\n }\n<\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"gnuplot",children:(0,t.jsx)(n.a,{href:"http://www.gnuplot.info/",children:"Gnuplot"})}),"\n",(0,t.jsxs)(n.p,{children:["using ",(0,t.jsx)(n.a,{href:"https://github.com/chhu/gnuplot-JS",children:"gnuplot-JS"})]}),"\n",(0,t.jsxs)(n.p,{children:["Instead of using ",(0,t.jsx)(n.code,{children:"data-output"})," attribute in the ",(0,t.jsx)(n.a,{href:"#2-add-a-script-element-with-the-diagram-syntax",children:"script element"}),", the statement ",(0,t.jsx)(n.code,{children:"set output"})," is used in the diagram syntax (see highlighted lines below)."]}),"\n",(0,t.jsxs)(n.p,{children:["Data files are also specified in the diagram syntax (see highlighted lines below).\nThey are defined in script elements with the attribute ",(0,t.jsx)(n.code,{children:'type="application/diagram-gnuplot-file"'}),". The file name is specified in ",(0,t.jsx)(n.code,{children:"data-file"})," attribute and either have inline content or linked to with a ",(0,t.jsx)(n.code,{children:"src"})," attribute."]}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"45tardc2qaz"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",metastring:"{4,22}",children:'<div data-src="contour.svg"></div>\n<script type="application/diagram-gnuplot">\n set terminal svg size 600,400 enhanced fname \'arial\' fsize 10 butt solid\n set output \'contour.svg\'\n set view 60, 30, 0.85, 1.1\n set samples 25, 25\n set isosamples 26, 26\n set contour base\n set cntrparam bspline\n set cntrparam levels auto 10\n set style data lines\n set title "3D gnuplot demo - contour of data grid plotting"\n set xlabel "X axis"\n set xrange [ 0.00000 : 15.0000 ] noreverse nowriteback\n set ylabel "Y axis"\n set yrange [ 0.00000 : 15.0000 ] noreverse nowriteback\n set zlabel "Z axis"\n set zlabel offset character 1, 0, 0 font "" textcolor lt -1 norotate\n set zrange [ -1.20000 : 1.20000 ] noreverse nowriteback\n\n # "glass.dat" is defined below\n splot "glass.dat" using 1\n<\/script>\n\n\x3c!-- data file --\x3e\n<script\n type="application/diagram-gnuplot-file"\n data-file="glass.dat"\n src="https://raw.githubusercontent.com/gnuplot/gnuplot/master/demo/glass.dat"\n><\/script>\n\n\x3c!-- or inline data in a script block --\x3e\n<script type="application/diagram-gnuplot-file" data-file="another-file.dat">\n 0.568000 0.000000 -0.911000\n 0.518894 0.231026 -0.911000\n 0.380066 0.422106 -0.911000\n 0.175522 0.540200 -0.911000\n -0.059372 0.564888 -0.911000\n<\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"graphviz",children:(0,t.jsx)(n.a,{href:"https://graphviz.org/",children:"Graphviz"})}),"\n",(0,t.jsxs)(n.p,{children:["using ",(0,t.jsx)(n.a,{href:"https://github.com/hpcc-systems/hpcc-js-wasm",children:"@hpcc-js/wasm"})]}),"\n",(0,t.jsxs)(n.p,{children:["The following ",(0,t.jsx)(n.a,{href:"https://graphviz.org/docs/layouts/",children:"layout engines"})," are supported:"]}),"\n",(0,t.jsxs)(n.ul,{children:["\n",(0,t.jsx)(n.li,{children:"dot"}),"\n",(0,t.jsx)(n.li,{children:"neato"}),"\n",(0,t.jsx)(n.li,{children:"fdp"}),"\n",(0,t.jsx)(n.li,{children:"sfdp"}),"\n",(0,t.jsx)(n.li,{children:"circo"}),"\n",(0,t.jsx)(n.li,{children:"twopi"}),"\n",(0,t.jsx)(n.li,{children:"osage"}),"\n",(0,t.jsx)(n.li,{children:"patchwork"}),"\n"]}),"\n",(0,t.jsxs)(n.p,{children:["By default, the ",(0,t.jsx)(n.code,{children:"dot"})," layout engine is used. To use a different engine add the attribute ",(0,t.jsx)(n.code,{children:"data-layout"})," to the ",(0,t.jsx)(n.a,{href:"#2-add-a-script-element-with-the-diagram-syntax",children:"script element"})," with the value of the required engine name, like this:"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<script type="application/diagram-graphviz" data-layout="fdp" data-output="my-diagram">\n ...\n<\/script>\n'})}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"ms2c6jc4vnj"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="flow-chart.svg"></div>\n<script type="application/diagram-graphviz" data-output="flow-chart.svg">\n digraph G {\n node [shape=rect];\n\n subgraph cluster_0 {\n style=filled;\n color=lightgrey;\n node [style=filled,color=white];\n a0 -> a1 -> a2 -> a3;\n label = "Hello";\n }\n\n subgraph cluster_1 {\n node [style=filled];\n b0 -> b1 -> b2 -> b3;\n label = "World!";\n color=blue\n }\n\n start -> a0;\n start -> b0;\n a1 -> b3;\n b2 -> a3;\n a3 -> a0;\n a3 -> end;\n b3 -> end;\n\n start [shape=Mdiamond];\n end [shape=Msquare];\n }\n<\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"mermaid",children:(0,t.jsx)(n.a,{href:"https://mermaid-js.github.io/mermaid/",children:"Mermaid"})}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"r9y3ubytquj"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="class-diagram.svg"></div>\n<script type="application/diagram-mermaid" data-output="class-diagram.svg">\n classDiagram\n Class01 <|-- AveryLongClass : Cool\n Class03 *-- Class04\n Class05 o-- Class06\n Class07 .. Class08\n Class09 --\x3e C2 : Where am i?\n Class09 --* C3\n Class09 --|> Class07\n Class07 : equals()\n Class07 : Object[] elementData\n Class01 : size()\n Class01 : int chimp\n Class01 : int gorilla\n Class08 <--\x3e C2: Cool label\n<\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"nomnoml",children:(0,t.jsx)(n.a,{href:"https://nomnoml.com/",children:"Nomnoml"})}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"8x45vzfnxw5"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="nomnoml.svg"></div>\n<script type="application/diagram-nomnoml" data-output="nomnoml.svg">\n [Pirate|eyeCount: Int|raid();pillage()|\n [beard]--[parrot]\n [beard]-:>[foul mouth]\n ]\n\n [<table>mischief | bawl | sing || yell | drink]\n\n [<abstract>Marauder]<:--[Pirate]\n [Pirate]- 0..7[mischief]\n [jollyness]->[Pirate]\n [jollyness]->[rum]\n [jollyness]->[singing]\n [Pirate]-> *[rum|tastiness: Int|swig()]\n [Pirate]->[singing]\n [singing]<->[rum]\n<\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"pintora",children:(0,t.jsx)(n.a,{href:"https://pintorajs.vercel.app/",children:"Pintora"})}),"\n",(0,t.jsxs)(n.p,{children:[(0,t.jsx)(n.a,{href:"https://pintorajs.vercel.app/docs/configuration/config",children:"Pintora config"})," object can be specified in ",(0,t.jsx)(n.a,{href:"/docs/advanced/custom-settings",children:"custom settings"}),", under the key ",(0,t.jsx)(n.code,{children:"pintora"}),"."]}),"\n",(0,t.jsx)(n.p,{children:"Example Custom Settings:"}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-json",children:'{\n "pintora": {\n "themeConfig": {\n "theme": "dark"\n }\n }\n}\n'})}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"9ygd8w4jfai"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="pintora.svg"></div>\n<script type="application/diagram-pintora" data-output="pintora.svg">\n sequenceDiagram\n Frida--\x3e>Georgia: Flowers are beautiful\n @note over Frida,Georgia: Painters\n @note right of Georgia: Right\n @note left of Georgia\n multiline\n note\n @end_note\n<\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"plotly",children:(0,t.jsx)(n.a,{href:"https://plotly.com/graphing-libraries/",children:"Plotly"})}),"\n",(0,t.jsxs)(n.p,{children:["The diagram syntax is a JSON object with ",(0,t.jsx)(n.code,{children:"data"})," and ",(0,t.jsx)(n.code,{children:"layout"})," properties (see ",(0,t.jsx)(n.a,{href:"https://plotly.com/javascript/reference/index/",children:"Plotly reference"}),")."]}),"\n",(0,t.jsx)(n.p,{children:"Please note that the output is a non-interactive SVG element or image. The plotly library is not loaded in the result page, so any JavaScript functionality is not available."}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"c9teuatsfk6"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="plotly.svg"></div>\n<script type="application/diagram-plotly" data-output="plotly.svg">\n {\n "data": [\n {\n "y": [\n 0.2,\n 0.2,\n 0.6,\n 1,\n 0.5,\n 0.4,\n 0.2,\n 0.7,\n 0.9,\n 0.1,\n 0.5,\n 0.3\n ],\n "x": [\n "day 1",\n "day 1",\n "day 1",\n "day 1",\n "day 1",\n "day 1",\n "day 2",\n "day 2",\n "day 2",\n "day 2",\n "day 2",\n "day 2"\n ],\n "name": "kale",\n "marker": {\n "color": "#3D9970"\n },\n "type": "box"\n },\n {\n "y": [\n 0.6,\n 0.7,\n 0.3,\n 0.6,\n 0,\n 0.5,\n 0.7,\n 0.9,\n 0.5,\n 0.8,\n 0.7,\n 0.2\n ],\n "x": [\n "day 1",\n "day 1",\n "day 1",\n "day 1",\n "day 1",\n "day 1",\n "day 2",\n "day 2",\n "day 2",\n "day 2",\n "day 2",\n "day 2"\n ],\n "name": "radishes",\n "marker": {\n "color": "#FF4136"\n },\n "type": "box"\n },\n {\n "y": [\n 0.1,\n 0.3,\n 0.1,\n 0.9,\n 0.6,\n 0.6,\n 0.9,\n 1,\n 0.3,\n 0.6,\n 0.8,\n 0.5\n ],\n "x": [\n "day 1",\n "day 1",\n "day 1",\n "day 1",\n "day 1",\n "day 1",\n "day 2",\n "day 2",\n "day 2",\n "day 2",\n "day 2",\n "day 2"\n ],\n "name": "carrots",\n "marker": {\n "color": "#FF851B"\n },\n "type": "box"\n }\n ],\n "layout": {\n "yaxis": {\n "title": "normalized moisture",\n "zeroline": false\n },\n "boxmode": "group"\n }\n }\n<\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"svgbob",children:(0,t.jsx)(n.a,{href:"https://github.com/ivanceras/svgbob",children:"Svgbob"})}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"fqe7devefsm"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="svgbob.svg"></div>\n<script type="application/diagram-svgbob" data-output="svgbob.svg">\n o-> Graphics Diagram\n\n 0 3 P *\n *-------* +y \\\n 1 /| 2 /| ^ \\\n *-+-----* | | v0 \\ v3\n | |4 | |7 | \u25C4\u256E *----\\-----*\n | *-----|-* \u2939 +-----\x3e +x / v X \\\n |/ |/ / \u2934 / o \\\n *-------* v / \\\n 5 6 +z v1 *------------------* v2\n<\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"vega",children:(0,t.jsx)(n.a,{href:"https://vega.github.io/vega/",children:"Vega"})}),"\n",(0,t.jsxs)(n.p,{children:["The diagram syntax is ",(0,t.jsx)(n.a,{href:"https://vega.github.io/vega/docs/#specification",children:"Vega JSON specification"}),"."]}),"\n",(0,t.jsx)(n.p,{children:"Please note that the output is a non-interactive SVG element or image. The Vega library is not loaded in the result page, so any JavaScript functionality is not available."}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"m8ynr8vj7b2"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="vega.svg"></div>\n<script\n type="application/diagram-vega"\n data-output="vega.svg"\n src="https://vega.github.io/vega/examples/stacked-bar-chart.vg.json"\n><\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"vegalite",children:(0,t.jsx)(n.a,{href:"https://vega.github.io/vega-lite/",children:"VegaLite"})}),"\n",(0,t.jsxs)(n.p,{children:["The diagram syntax is ",(0,t.jsx)(n.a,{href:"https://vega.github.io/vega-lite/docs/spec.html",children:"Vega-Lite View JSON Specification"}),"."]}),"\n",(0,t.jsx)(n.p,{children:"Please note that the output is a non-interactive SVG element or image. The Vega-Lite library is not loaded in the result page, so any JavaScript functionality is not available."}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"sui8eux6siv"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="vega-lite.svg"></div>\n<script\n type="application/diagram-vega-lite"\n data-output="vega-lite.svg"\n src="https://vega.github.io/vega-lite/examples/sequence_line_fold.vl.json"\n><\/script>\n'})}),"\n",(0,t.jsx)(n.h3,{id:"wavedrom",children:(0,t.jsx)(n.a,{href:"https://wavedrom.com/",children:"WaveDrom"})}),"\n",(0,t.jsxs)(n.p,{children:["The diagram syntax is ",(0,t.jsx)(n.a,{href:"https://wavedrom.com/tutorial.html",children:"WaveJSON"})," format."]}),"\n",(0,t.jsxs)(n.p,{children:["Example: (",(0,t.jsx)(s,{id:"ey74x6q6cq3"}),")"]}),"\n",(0,t.jsx)(n.pre,{children:(0,t.jsx)(n.code,{className:"language-html",children:'<div data-src="wavedrom.svg"></div>\n<script type="application/diagram-wavedrom" data-output="wavedrom.svg">\n { signal : [\n { name: "clk", wave: "p......" },\n { name: "bus", wave: "x.34.5x", data: "head body tail" },\n { name: "wire", wave: "0.1..0." },\n ]}\n<\/script>\n'})})]})}function g(e={}){let{wrapper:n}={...(0,l.a)(),...e.components};return n?(0,t.jsx)(n,{...e,children:(0,t.jsx)(o,{...e})}):o(e)}},2356:function(e,n,a){a.d(n,{Z:function(){return i}});let i=""},65:function(e,n,a){a.d(n,{Z:function(){return d},a:function(){return s}});var i=a(7294);let t={},l=i.createContext(t);function s(e){let n=i.useContext(l);return i.useMemo(function(){return"function"==typeof e?e(n):{...n,...e}},[n,e])}function d(e){let n;return n=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:s(e.components),i.createElement(l.Provider,{value:n},e.children)}}}]);