UNPKG

gojs

Version:

Interactive diagrams, charts, and graphs, such as trees, flowcharts, orgcharts, UML, BPMN, or business diagrams

267 lines (256 loc) 11.9 kB
window.byId = (id) => { return document.getElementById(id); } document.addEventListener("DOMContentLoaded", function() { var p1 = document.createElement("p"); window.dirName = location.pathname.split('/').slice(-2); window.samplePath = dirName.join('/'); // dir/name.html p1.innerHTML = "<a href='https://github.com/NorthwoodsSoftware/GoJS/blob/master/" + samplePath + "' target='_blank'>View this sample page's source on GitHub</a>"; byId("sample").parentElement.appendChild(p1); window.b1 = document.createElement("button"); window.b2 = document.createElement("button"); b1.onclick = goViewSource; b2.onclick = goDownload; b1.innerText = "View the code for this sample in-page"; b2.innerText = "Download the HTML and JS to use as a starting point"; byId("sample").parentElement.appendChild(b1); byId("sample").parentElement.appendChild(b2); var copyright = 'Copyright 1998-2022 by Northwoods Software.'; var p2 = document.createElement("p"); p2.classList = "text-xs"; p2.innerHTML = (window.go) ? 'GoJS version ' + go.version + '. ' + copyright : copyright; byId("sample").appendChild(p2); byId("navSide").innerHTML = (dirName[0] === 'samples') ? (navContent + navContent2) : (navContent + navContentExtensions); var sidebutton = byId("navButton"); var navList = byId("navList"); sidebutton.addEventListener("click", function() { this.classList.toggle("active"); navList.classList.toggle("hidden"); byId("navOpen").classList.toggle("hidden"); byId("navClosed").classList.toggle("hidden"); }); var url = window.location.href; var lindex = url.lastIndexOf('/'); url = url.slice(lindex + 1).toLowerCase(); var aTags = navList.getElementsByTagName("a"); var currentindex = -1; for (var i = 0; i < aTags.length; i++) { var lowerhref = aTags[i].href.toLowerCase(); if (lowerhref.indexOf('/' + url) !== -1) { currentindex = i; aTags[i].classList.add("bg-nwoods-secondary"); aTags[i].style = "color: white"; break; } } var s = document.createElement('script'); s.src = "https://www.googletagmanager.com/gtag/js?id=G-S5QK8VSK84"; document.body.appendChild(s); window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', 'G-S5QK8VSK84'); var getOutboundLink = function(url, label) { gtag('event', 'click', { 'event_category': 'outbound', 'event_label': label, 'transport_type': 'beacon' }); } // topnav var topButton = byId("topnavButton"); var topnavList = byId("topnavList"); topButton.addEventListener("click", function() { this.classList.toggle("active"); topnavList.classList.toggle("hidden"); byId("topnavOpen").classList.toggle("hidden"); byId("topnavClosed").classList.toggle("hidden"); }); _traverseDOM(document); }); function _traverseDOM(node) { if (node.nodeType === 1 && node.nodeName === "A" && !node.getAttribute("href")) { var inner = node.innerHTML; var text = [inner]; var isStatic = false; if (inner.indexOf(",") > 0) { text = inner.split(","); isStatic = true; node.innerHTML = inner.replace(",", "."); } else { text = inner.split("."); } if (text.length === 1) { node.setAttribute("href", "../api/symbols/" + text[0] + ".html"); node.setAttribute("target", "api"); } else if (text.length === 2) { node.setAttribute("href", "../api/symbols/" + text[0] + ".html" + "#" + (isStatic ? "static-" : "") + text[1]); node.setAttribute("target", "api"); } else { alert("Unknown API reference: " + node.innerHTML); } } if (node.nodeType === 1 && (node.nodeName === "H2" || node.nodeName === "H3" || node.nodeName === "H4") && node.id) { node.addEventListener("click", function (e) { window.location.hash = "#" + node.id; }); } for (var i = 0; i < node.childNodes.length; i++) { _traverseDOM(node.childNodes[i]); } } function goViewSource() { // load prism for code highlighting var elem = document.createElement('link'); elem.rel = 'stylesheet' elem.href= "../assets/css/prism.css"; document.head.appendChild(elem); var prism = document.createElement('script'); prism.onload = function () { var script = byId("code"); if (!script) return; var sp1 = document.createElement("pre"); sp1.classList.add("lang-js"); sp1.innerHTML = script.innerHTML; var samplediv = byId("sample") || document.body; samplediv.parentElement.appendChild(sp1); Prism.highlightElement(sp1); window.scrollBy(0,100); }; prism.src = "../assets/js/prism.js"; document.head.appendChild(prism); } function goDownload() { var sampleHTML = byId("allSampleContent"); // or "sample" + "code", but this contains both and more var title = location.href.substring(location.href.lastIndexOf('/')+1); var sampleParent = byId("sample").parentElement; sampleParent.removeChild(b1); sampleParent.removeChild(b2); var text = ` <!DOCTYPE html> <html lang="en"> <body> <script src="https://unpkg.com/gojs@${go.version}/release/go.js"><\/script> <p> This is a minimalist HTML and JavaScript skeleton of the GoJS Sample <a href="https://gojs.net/latest/${samplePath}">${title}<\/a>. It was automatically generated from a button on the sample page, and does not contain the full HTML. It is intended as a starting point to adapt for your own usage. For many samples, you may need to inspect the <a href="https://github.com/NorthwoodsSoftware/GoJS/blob/master/${samplePath}">full source on Github<\/a> and copy other files or scripts. <\/p> ${sampleHTML.outerHTML} </body> </html>`; // replace all uses of '../extensions' with unpkg equivalent text = text.replace(/\.\.\/extensions/g, `https://unpkg.com/gojs@${go.version}/extensions`); // any src that does not begin with 'http' should get `https://unpkg.com/gojs@${go.version}/CURRENTFOLDER/` text = text.replace(/<script src="(?:(?!http))+/g, `https://unpkg.com/gojs@${go.version}/${dirName}`); var element = document.createElement('a'); element.setAttribute('href', 'data:text/html;charset=utf-8,' + encodeURIComponent(text)); element.setAttribute('download', title); element.style.display = 'none'; document.body.appendChild(element); element.click(); document.body.removeChild(element); sampleParent.appendChild(b1); sampleParent.appendChild(b2); } var navContent = ` <div class="flex-shrink-0 px-8 py-4"> <button id="navButton" class="rounded-lg md:hidden focus:outline-none focus:ring" aria-label="Navigation"> <svg fill="currentColor" viewBox="0 0 20 20" class="w-6 h-6"> <path id="navOpen" fill-rule="evenodd" d="M3 5a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1zM3 10a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1zM9 15a1 1 0 011-1h6a1 1 0 110 2h-6a1 1 0 01-1-1z" clip-rule="evenodd"></path> <path id="navClosed" class="hidden" fill-rule="evenodd" d="M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z" clip-rule="evenodd"></path> </svg> </button> </div> <nav id="navList" class="min-h-screen hidden md:block sidebar-nav flex-grow px-4 pb-4 md:pb-0 md:overflow-y-auto break-words"> `; var navContent2 = `<a href="index.html">Samples Index</a> <hr> <a href="../samples/orgChartStatic.html">OrgChart (Static)</a> <a href="../samples/orgChartEditor.html">OrgChart Editor</a> <a href="../samples/familyTree.html">Family Tree</a> <a href="../samples/genogram.html">Genogram</a> <a href="../samples/doubleTree.html">Double Tree</a> <a href="../samples/mindMap.html">Mind Map</a> <a href="../samples/decisionTree.html">Decision Tree</a> <a href="../samples/IVRtree.html">IVR Tree</a> <a href="../samples/incrementalTree.html">Incremental Tree</a> <a href="../samples/parseTree.html">Parse Tree</a> <a href="../samples/treeView.html">Tree View</a> <a href="../samples/tournament.html">Tournament</a> <a href="../samples/localView.html">Local View</a> <hr> <a href="../samples/flowchart.html">Flowchart</a> <a href="../samples/blockEditor.html">Block Editor</a> <a href="../samples/pageFlow.html">Page Flow</a> <a href="../samples/processFlow.html">Process Flow</a> <a href="../samples/systemDynamics.html">System Dynamics</a> <a href="../samples/stateChart.html">State Chart</a> <a href="../samples/kanban.html">Kanban Board</a> <a href="../samples/sequentialFunction.html">Sequential Function</a> <a href="../samples/grafcet.html">Grafcet Diagrams</a> <a href="../samples/sequenceDiagram.html">Sequence Diagram</a> <a href="../samples/logicCircuit.html">Logic Circuit</a> <a href="../samples/records.html">Record Mapper</a> <a href="../samples/dataFlow.html">Data Flow</a> <a href="../samples/dynamicPorts.html">Dynamic Ports</a> <a href="../samples/planogram.html">Planogram</a> <a href="../samples/seatingChart.html">Seating Chart</a> <a href="../samples/regrouping.html">Regrouping</a> <a href="../samples/pipes.html">Pipes</a> <a href="../samples/draggableLink.html">Draggable Link</a> <a href="../samples/linksToLinks.html">Links to Links</a> <hr> <a href="../samples/beatPaths.html">Beat Paths</a> <a href="../samples/conceptMap.html">Concept Map</a> <a href="../samples/euler.html">Euler Diagram</a> <a href="../samples/dataVisualization.html">Data Visualization</a> <a href="../samples/entityRelationship.html">Entity Relationship</a> <a href="../samples/friendWheel.html">Friend Wheel</a> <a href="../samples/radial.html">Recentering Radial</a> <a href="../samples/radialPartition.html">Radial Partition</a> <a href="../samples/distances.html">Distances and Paths</a> <a href="../samples/sankey.html">Sankey</a> <a href="../samples/PERT.html">PERT</a> <a href="../samples/gantt.html">Gantt</a> <a href="../samples/shopFloorMonitor.html">Shop Floor Monitor</a> <a href="../samples/kittenMonitor.html">Kitten Monitor</a> <a href="../samples/grouping.html">Grouping</a> <a href="../samples/swimBands.html">Layer Bands</a> <a href="../samples/swimLanes.html">Swim Lanes</a> <a href="../samples/umlClass.html">UML Class</a> <hr> <a href="../samples/minimal.html">Minimal</a> <a href="../samples/basic.html">Basic (editing)</a> <a href="../samples/classHierarchy.html">Class Hierarchy</a> <a href="../samples/DOMTree.html">DOM Tree</a> <a href="../samples/visualTree.html">Visual Tree</a> <a href="../samples/shapes.html">Shape Figures</a> <a href="../samples/icons.html">SVG Icons</a> <a href="../samples/arrowheads.html">Arrowheads</a> <a href="../samples/navigation.html">Navigation</a> <a href="../samples/updateDemo.html">Update Demo</a> <a href="../samples/contentAlign.html">Content Alignment</a> <a href="../samples/htmlInteraction.html">HTML Interaction</a> <a href="../samples/customContextMenu.html">Context Menu</a> <a href="../samples/canvases.html">Canvases</a> <a href="../samples/comments.html">Comments</a> <hr> <a href="../samples/gLayout.html">Grid Layout</a> <a href="../samples/tLayout.html">Tree Layout</a> <a href="../samples/fdLayout.html">Force Directed</a> <a href="../samples/ldLayout.html">Layered Digraph</a> <a href="../samples/cLayout.html">Circular Layout</a> <a href="../samples/interactiveForce.html">Interactive Force</a> <hr> <a href="../samples/index.html#extensions">GoJS Extensions</a> <a href="../projects/index.html">GoJS Projects</a> <a href="../samples/all.html">Complete List</a> </nav> `; var navContentExtensions = ` <a href="../samples/index.html#extensions">Index of Extensions</a> </nav> `;