diff --git a/README-02.md b/README-02.md index f17c00250..55d0f27f3 100755 --- a/README-02.md +++ b/README-02.md @@ -1,3 +1,110 @@ + +Here is the quickstart video clip. + +
+ TopoViewer - Quickstart video clip +
+ + + +## How-to guides + +* **See node Properties** +
+ Simply click the node + +
+ +* **See link Properties** +
+ Simply click the node + +
+ +* **Get to the node console** +
+ web console + +
+ +
+ terminal console + +
+ + +* **Packet capture** +
+ + Wireshark Client Helper + +

There are two type of suported client here, Windows version and MAC version, both of the clients can be find in "Setting Menu, TopoViewer Helper App". Once the Wireshark client helper installed, simply click Cross Launch Button in link Properties. +

+

+ Using Windows version of Wireshark Client Helper: +

+

+

+ Using MAC version of Wireshark Client Helper: +

+

+
+ +* **Link impairment** + + + + +## Tested Environment +- containerlab version: 0.41.2, 0.44.3, 0.46.0 +- docker-ce version: 24.0.2 + + +## Build TopoViewer Binary - Linux +build linux amd64 binary +```Shell +vscode ➜ /workspaces/topoViewer (development) $ GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -o topoviewer cloudshellwrap +per/cmd/main.go +``` + +## Run TopoViewer Binary +Ensure to run binary file in the same directory with html folder +Running inside dist folder +```Shell +vscode ➜ /workspaces/topoViewer/dist (development ✗) $ ./topoviewer clab -t topo-topoViewerDemo.yaml +``` + +## Create Distribution Folder +```Shell +vscode ➜ /workspaces/topoViewer (development ✗) $ ./tools/dist.sh +``` + +## Run TopoViewer Code +```Shell +vscode ➜ /workspaces/topoViewer (development ✗) go run go_cloudshellwrapper/cmd/main.go clab --allowed-hostnames 149.204.21.68 --clab-user aarafat --server-port 8087 --topology-file-json ./rawTopoFile/clab/nokia-MultiAccessGateway-lab/clab-nokia-MAGc-lab/topology-data.json +``` + +## Run TopoViewer Binary +```Shell + [aarafat@nsp-clab1 topoViewer]$ sudo topoviewer clab --allowed-hostnames 149.204.21.68 --clab-user aarafat --server-port 8087 --topology-file-json /home/aarafat/topoViewer/rawTopoFile/clab/nokia-MultiAccessGateway-lab/clab-nokia-MAGc-lab/topology-data.json + ``` + + ## Run CloudshellWrapper Go Code ```Shell vscode ➜ /workspaces/topoViewer (development) $ pwd @@ -58,4 +165,8 @@ docker exec -it clab-nokia-MAGc-lab-topoviewer /opt/topoviewer/topoviewer clab - go run go_cloudshellwrapper/cmd/main.go clab --allowed-hostnames 149.204.21.68 --clab-user aarafat --server-port 8087 --topology-file-json ./rawTopoFile/clab/nokia-MultiAccessGateway-lab/clab-nokia-MAGc-lab/topology-data.json vscode ➜ /workspaces/topoViewer/dist (development ✗) $ ./topoviewer clab -t topo-topoViewerDemo.yaml -``` \ No newline at end of file +``` + + + + diff --git a/README.md b/README.md index 92e0d6889..3eb87311e 100755 --- a/README.md +++ b/README.md @@ -1,128 +1,25 @@ -# Topoviewer - ## Overview -Yo, listen up! This mind-blowing project is all about hooking you up with the dopest network visualization tool out there. We're talking about taking your topology data and turning it into a sick cytoscape graph model that you can peep using https://js.cytoscape.org. It's like having a virtual eye candy for your network! - -Now, let's break it down into two rad sections: - -TopoEngine: This bad boy is all about converting your topology data (right now it's Container Lab) into a sick cytoscape graph model. Once translated, you can visualize that bad boy and watch your network come to life. - -CloudshellWrapper: Here's the deal, we've got a wicked wrapper for https://github.com/zephinzer/cloudshell. It's like having your own personal Xterm.js frontend that connects to a Go backend and gives you a shell right in your browser. Yeah, you heard it right, access your shell using your browser. It's like having a virtual command center at your fingertips. And guess what? If you're running CloudshellWrapper on the same host as containerlab, you can even access the nodes of containerlab through your browser. How cool is that? - -But hey, keep in mind, exposing your shell via a browser can be risky business. We're just putting it out there, so if you decide to dive in, do it at your own risk. Stay rad, my friend! - - -## Quickstart -The simplest approach to utilise TopoViewer with Containerlab is to include the under the 'nodes:' section to a topology YAML file. - -copy paste below start-up script, to deploy a Containerlab topology with topoviewer. - -```Shell -bash -c "$(wget -qO - https://raw.githubusercontent.com/asadarafat/nokia-DataCenterFabric-lab/main/demo-deploy.sh)" -``` - -Here is the quickstart video clip. - -
- TopoViewer - Quickstart video clip -
- - - -## How-to guides - -* **See node Properties** -
- Simply click the node - -
- -* **See link Properties** -
- Simply click the node - -
- -* **Get to the node console** -
- web console - -
- -
- terminal console - -
- - -* **Packet capture** -
- - Wireshark Client Helper - -

There are two type of suported client here, Windows version and MAC version, both of the clients can be find in "Setting Menu, TopoViewer Helper App". Once the Wireshark client helper installed, simply click Cross Launch Button in link Properties. -

-

- Using Windows version of Wireshark Client Helper: -

-

-

- Using MAC version of Wireshark Client Helper: -

-

-
- -* **Link impairment** +`TopoViewer` is a network visualization tool that converts topology data into a Cytoscape graph model, allowing you to visualize your network using [Cytoscape.js](https://js.cytoscape.org). +The project is divided into two main components: +- **TopoEngine**: Converts topology data (currently supports Container Lab) into a Cytoscape graph model. This component handles the core logic for processing and visualizing network topologies, including parsing topology files and generating visual representations. -## Tested Environment -- containerlab version: 0.41.2, 0.44.3, 0.46.0 -- docker-ce version: 24.0.2 +- **CloudshellWrapper**: A wrapper for [cloudshell](https://github.com/zephinzer/cloudshell) that provides an Xterm.js frontend connected to a Go backend, allowing you to access your shell via a browser. If CloudshellWrapper is running on the same host as Containerlab, it can also access the nodes of Containerlab through the browser. +> **Note**: Exposing your shell via a browser can be risky. Use at your own risk. -## Build TopoViewer Binary - Linux -build linux amd64 binary -```Shell -vscode ➜ /workspaces/topoViewer (development) $ GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -o topoviewer cloudshellwrap -per/cmd/main.go -``` +The codebase is organized into several folders with the prefix `go_`, each serving a specific purpose: -## Run TopoViewer Binary -Ensure to run binary file in the same directory with html folder -Running inside dist folder -```Shell -vscode ➜ /workspaces/topoViewer/dist (development ✗) $ ./topoviewer clab -t topo-topoViewerDemo.yaml -``` +- **go_cloudshellwrapper**: Contains the main logic for running `TopoViewer`. Key files include: + - `cmd/main.go`: The entry point for running `TopoViewer`. + - `cmdClab.go`: Handles CLAB-specific commands. + - `cmdNsp.go`: Handles NSP-specific commands. + - Additionally, the `clabHandlers` directory contains handlers specific to Containerlab operations. -## Create Distribution Folder -```Shell -vscode ➜ /workspaces/topoViewer (development ✗) $ ./tools/dist.sh -``` +- **go_topoengine**: Contains the core logic for processing and visualizing network topologies. This includes parsing topology files and generating visual representations. -## Run TopoViewer Code -```Shell -vscode ➜ /workspaces/topoViewer (development ✗) go run go_cloudshellwrapper/cmd/main.go clab --allowed-hostnames 149.204.21.68 --clab-user aarafat --server-port 8087 --topology-file-json ./rawTopoFile/clab/nokia-MultiAccessGateway-lab/clab-nokia-MAGc-lab/topology-data.json -``` +- **go_xtermjs**: Integrates `xterm.js` for terminal emulation within the `TopoViewer`interface. This allows users to interact with the terminal directly from the web interface. -## Run TopoViewer Binary -```Shell - [aarafat@nsp-clab1 topoViewer]$ sudo topoviewer clab --allowed-hostnames 149.204.21.68 --clab-user aarafat --server-port 8087 --topology-file-json /home/aarafat/topoViewer/rawTopoFile/clab/nokia-MultiAccessGateway-lab/clab-nokia-MAGc-lab/topology-data.json - ``` - \ No newline at end of file +- **go_tools**: Contains various utility functions and tools used by `TopoViewer`. \ No newline at end of file diff --git a/dist/clab-client-mac/ClabPumbaDelay.app.zip b/dist/clab-client-mac/ClabPumbaDelay.app.zip deleted file mode 100755 index 11b590c9b..000000000 Binary files a/dist/clab-client-mac/ClabPumbaDelay.app.zip and /dev/null differ diff --git a/dist/clab-client-windows/ClabCapture.app.zip b/dist/clab-client-windows/ClabCapture.app.zip index 0a682b8fa..dfafebd68 100755 Binary files a/dist/clab-client-windows/ClabCapture.app.zip and b/dist/clab-client-windows/ClabCapture.app.zip differ diff --git a/dist/dist.zip b/dist/dist.zip index 5dc2e8a08..5fe449160 100644 Binary files a/dist/dist.zip and b/dist/dist.zip differ diff --git a/dist/html-static/clab-client/clab-client-mac/ClabPumbaDelay.app.zip b/dist/html-static/clab-client/clab-client-mac/ClabPumbaDelay.app.zip deleted file mode 100755 index 11b590c9b..000000000 Binary files a/dist/html-static/clab-client/clab-client-mac/ClabPumbaDelay.app.zip and /dev/null differ diff --git a/dist/html-static/clab-client/clab-client-windows/ClabCapture.app.zip b/dist/html-static/clab-client/clab-client-windows/ClabCapture.app.zip index 0a682b8fa..dfafebd68 100755 Binary files a/dist/html-static/clab-client/clab-client-windows/ClabCapture.app.zip and b/dist/html-static/clab-client/clab-client-windows/ClabCapture.app.zip differ diff --git a/dist/html-static/js/cloudshell/terminal.js b/dist/html-static/js/cloudshell/terminal.js index d39b2c372..f1124e57c 100644 --- a/dist/html-static/js/cloudshell/terminal.js +++ b/dist/html-static/js/cloudshell/terminal.js @@ -9,7 +9,8 @@ // Retrieve the RouterID query parameter var routerId = urlParam('RouterID'); - console.log(routerId); + + console.log("routerId:", routerId); // Process the routerId string var split1 = routerId.toString().split("?"); @@ -65,7 +66,11 @@ fitAddon.fit(); }); // Uncomment the following lines if needed to send commands to the WebSocket - ws.send("ssh -q -o StrictHostKeyChecking=no admin@" + routerId.toString().split("?")[0]); + // ws.send("ssh -q -o StrictHostKeyChecking=no admin@" + routerId.toString().split("?")[0]); + console.log("ssh -q -o StrictHostKeyChecking=no admin@" + urlParam('RouterName')); + ws.send("ssh -q -o StrictHostKeyChecking=no admin@" + urlParam('RouterName')); + + terminal.onResize(function(event) { var rows = event.rows; diff --git a/dist/html-static/js/index copy.js b/dist/html-static/js/index copy.js deleted file mode 100644 index ba8364ead..000000000 --- a/dist/html-static/js/index copy.js +++ /dev/null @@ -1,2443 +0,0 @@ -// Initialize a state variable to track the element's presence -var isPanel01Cy = false; -var nodeClicked = false; -var edgeClicked = false; - -var cy - -var globalSelectedNode -var globalSelectedEdge - -var linkEndpointVisibility = true; -var nodeContainerStatusVisibility = false; - - -var globalShellUrl = "/js/cloudshell" - -var labName -var deploymentType - -document.addEventListener("DOMContentLoaded", async function() { - - detectColorScheme() - - await changeTitle() - - - // Reusable function to initialize a WebSocket connection - function initializeWebSocket(url, onMessageCallback) { - const protocol = location.protocol === "https:" ? "wss://" : "ws://"; - const socket = new WebSocket(protocol + location.host + url); - - socket.onopen = () => { - console.log(`Successfully connected WebSocket to ${url}`); - if (socket.readyState === WebSocket.OPEN) { - socket.send(`Hi From the WebSocketClient-${url}`); - } - }; - - socket.onclose = (event) => { - console.log(`Socket to ${url} closed: `, event); - socket.send("Client Closed!"); - }; - - socket.onerror = (error) => { - console.log(`Socket to ${url} error: `, error); - }; - - socket.onmessage = onMessageCallback; - - return socket; - } - - - // WebSocket for uptime - // WebSocket for uptime - const socketUptime = initializeWebSocket("/uptime", async (msgUptime) => { - environments = await getEnvironments(); - labName = environments["clab-name"] - deploymentType = environments["deploymentType"] - - console.log("initializeWebSocket - getEnvironments", environments) - console.log("initializeWebSocket - labName", environments["clab-name"]) - - const string01 = "Containerlab Topology: " + labName; - const string02 = " ::: Uptime: " + msgUptime.data; - - const ClabSubtitle = document.getElementById("ClabSubtitle"); - const messageBody = string01 + string02; - - ClabSubtitle.innerText = messageBody; - console.log(ClabSubtitle.innerText); - }); - - // WebSocket for ContainerNodeStatus - const socketContainerNodeStatusInitial = initializeWebSocket( - "/containerNodeStatus", - (msgContainerNodeStatus) => { - try { - const { - Names, - Status, - State - } = JSON.parse(msgContainerNodeStatus.data); - setNodeContainerStatus(Names, Status); - console.log(JSON.parse(msgContainerNodeStatus.data)); - - setNodeDataWithContainerAttribute(Names, Status, State); - } catch (error) { - console.error("Error parsing JSON:", error); - } - }, - ); - - //- Instantiate Cytoscape.js - cy = cytoscape({ - container: document.getElementById("cy"), - elements: [], - style: [{ - selector: "node", - style: { - "background-color": "#3498db", - label: "data(label)", - }, - }, ], - }); - - - loadCytoStyle(); - - function loadCytoStyle() { - - // detect light or dark mode - const colorScheme = detectColorScheme(); - console.log('The user prefers:', colorScheme); - - //- Load and apply Cytoscape styles from cy-style.json using fetch - if (colorScheme == "light") { - fetch("css/cy-style.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } else if (colorScheme == "dark") { - fetch("css/cy-style-dark.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } - } - - // Enable grid guide extension - cy.gridGuide({ - // On/Off Modules - - snapToGridOnRelease: true, - snapToGridDuringDrag: false, - snapToAlignmentLocationOnRelease: true, - snapToAlignmentLocationDuringDrag: false, - distributionGuidelines: false, - geometricGuideline: false, - initPosAlignment: false, - centerToEdgeAlignment: false, - resize: false, - parentPadding: false, - drawGrid: false, - - // General - gridSpacing: 10, - snapToGridCenter: true, - - // Draw Grid - zoomDash: true, - panGrid: true, - gridStackOrder: -1, - gridColor: '#dedede', - lineWidth: 1.0, - - // Guidelines - guidelinesStackOrder: 4, - guidelinesTolerance: 2.00, - guidelinesStyle: { - strokeStyle: "#8b7d6b", - geometricGuidelineRange: 400, - range: 100, - minDistRange: 10, - distGuidelineOffset: 10, - horizontalDistColor: "#ff0000", - verticalDistColor: "#00ff00", - initPosAlignmentColor: "#0000ff", - lineDash: [0, 0], - horizontalDistLine: [0, 0], - verticalDistLine: [0, 0], - initPosAlignmentLine: [0, 0], - }, - - // Parent Padding - parentSpacing: -1 - }); - - // Fetch and load element data from a JSON file - // fetch("dataCytoMarshall-" + labName + ".json") - fetch("dataCytoMarshall.json") - - .then((response) => response.json()) - .then((elements) => { - // Add the elements to the Cytoscape instance - // Add the elements to the Cytoscape instance - cy.add(elements); - //- run layout - //- run layout - // const layout = cy.layout({ - // name: "cola", - // nodeGap: 5, - // edgeLength: 100, - // animate: true, - // randomize: false, - // maxSimulationTime: 1500, - // }); - // layout.run(); - - // Dynamically create clusters for CISE layout - // var clustersMap = {}; - // cy.nodes().filter('[parent != "newGroup"]').forEach(function (node) { - // var parent = node.data('parent'); - // if (!clustersMap[parent]) { - // clustersMap[parent] = []; - // } - // clustersMap[parent].push(node.id()); - // }); - // var clusters = Object.values(clustersMap); - - // // Apply CISE layout to existing nodes - // var ciseLayout = cy.layout({ - // name: 'cise', - // clusters: clusters, - // animate: "end", - // padding: 20, - // nodeSeparation: 10, - // idealInterClusterEdgeLengthCoefficient: 1.4, - // allowNodesInsideCircle: false, - // maxRatioOfNodesInsideCircle: 0.1, - // nodeRepulsion: 4500 - // }); - // ciseLayout.run() - // Apply force-directed layout (cose) to new nodes - var coseLayout = cy.layout({ - name: 'cose', - animate: "end", - padding: 20, - nodeOverlap: 10, - idealEdgeLength: 50, - edgeElasticity: 100, - nodeRepulsion: 40, - numIter: 100, - initialTemp: 200, - coolingFactor: 0.95, - gravity: 2.2 - }); - - coseLayout.run(); - - // remove node topoviewer - topoViewerNode = cy.filter('node[name = "topoviewer"]'); - topoViewerNode.remove(); - }) - .catch((error) => { - console.error("Error loading graph data:", error); - }); - - // Instantiate hover text element - const hoverText = document.createElement("box"); - hoverText.classList.add( - "hover-text", - "is-hidden", - "box", - "has-text-weight-normal", - "is-warning", - "is-smallest", - ); - hoverText.textContent = "Launch CloudShell."; - document.body.appendChild(hoverText); - - //- Toggle the Panel(s) when clicking on the cy container - //- Toggle the Panel(s) when clicking on the cy container - document.getElementById("cy").addEventListener("click", function(event) { - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - - loadCytoStyle(); - - if (!nodeClicked && !edgeClicked) { - if (!isPanel01Cy) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - var ViewPortDrawerElements = - document.getElementsByClassName("ViewPortDrawer"); - var ViewPortDrawerArray = Array.from(ViewPortDrawerElements); - ViewPortDrawerArray.forEach(function(element) { - element.style.display = "none"; - }); - - } else { - removeElementById("Panel-01"); - appendMessage(`"try to remove panel01-Cy"`); - } - } - nodeClicked = false; - edgeClicked = false; - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - }); - - // Click event listener for nodes - // Click event listener for nodes - cy.on("click", "node", function(event) { - // This code will be executed when you click on a node - // This code will be executed when you click on a node - const node = event.target; - nodeClicked = true; - - if (!node.isParent()) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - console.log(node) - console.log(node.data("containerDockerExtraAttribute").status) - console.log(node.data("extraData")) - - if (document.getElementById("panel-node").style.display === "none") { - document.getElementById("panel-node").style.display = "block"; - } else { - document.getElementById("panel-node").style.display = "none"; - } - - document.getElementById("panel-node-name").textContent = node.data("extraData").longname - document.getElementById("panel-node-status").textContent = node.data("containerDockerExtraAttribute").status - document.getElementById("panel-node-kind").textContent = node.data("extraData").kind - document.getElementById("panel-node-image").textContent = node.data("extraData").image - document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss - document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn - document.getElementById("panel-node-group").textContent = node.data("extraData").group - document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") - - // set selected node-long-name to global variable - globalSelectedNode = node.data("extraData").longname - console.log("internal: ", globalSelectedNode) - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - } - }); - - // Click event listener for edges - // Click event listener for edges - cy.on("click", "edge", async function(event) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - // This code will be executed when you click on a node - // You can add logic specific to nodes here - const clickedEdge = event.target; - const defaultEdgeColor = "#969799"; - edgeClicked = true; - - console.log(defaultEdgeColor); - - // Change the color of the clicked edge (for example, to red) - clickedEdge.style("line-color", "#0043BF"); - - // Revert the color of other edges that were not clicked (e.g., back to their default color) - cy.edges().forEach(function(edge) { - if (edge !== clickedEdge) { - edge.style("line-color", defaultEdgeColor); - } - }); - - - - - document.getElementById("panel-link").style.display = "none"; - - if (document.getElementById("panel-link").style.display === "none") { - document.getElementById("panel-link").style.display = "block"; - } else { - document.getElementById("panel-link").style.display = "none"; - } - - document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` - - document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` - - document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` - - - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API - clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] - clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) - - if (clabSourceLinkImpairmentClabData && typeof clabSourceLinkImpairmentClabData === 'object' && Object.keys(clabSourceLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabSourceLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabSourceLinkImpairmentClabData returnd data", clabSourceLinkImpairmentClabData["return data"]["delay"]); - - if (clabSourceLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-a-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-delay").value = clabSourceLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-a-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-jitter").value = clabSourceLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-a-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-rate").value = clabSourceLinkImpairmentClabData["return data"]["rate"] - } - - if (clabSourceLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-a-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-loss").value = clabSourceLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // setting default impairment endpoint-b values by getting the data from clab via /clab-link-impairment GET API - clabTargetLinkArgsList = [`${clickedEdge.data("extraData").clabTargetLongName}`,`${clickedEdge.data("extraData").clabTargetPort}`] - clabTargetLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabTargetLinkArgsList) - - if (clabTargetLinkImpairmentClabData && typeof clabTargetLinkImpairmentClabData === 'object' && Object.keys(clabTargetLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabTargetLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabTargetLinkImpairmentClabData returnd data", clabTargetLinkImpairmentClabData["return data"]["delay"]); - - if (clabTargetLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-b-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-delay").value = clabTargetLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-b-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-jitter").value = clabTargetLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-b-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-rate").value = clabTargetLinkImpairmentClabData["return data"]["rate"] - } - - if (clabTargetLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-b-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-loss").value = clabTargetLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // set selected edge-id to global variable - globalSelectedEdge = clickedEdge.data("id") - - appendMessage(`"edgeClicked: " ${edgeClicked}`); - }); - - - - - function generateNodesEvent(event) { - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - console.log("generateNodesButton clicked"); - const numNodes = document.getElementById("generateNodesInput").value; - console.log(numNodes); - //- Check if the number of node is empty - //- Check if the number of node is empty - if (numNodes === null) { - //- if node number empty do nothing - //- if node number empty do nothing - return; - } - const numNodesToGenerate = parseInt(numNodes, 10); - //- Check if the number of node is positive - //- Check if the number of node is positive - if (isNaN(numNodesToGenerate) || numNodesToGenerate <= 0) { - //- Invalid input - //- Invalid input - appendMessage( - "Error:" + "Bro, you gotta enter a valid positive number, come on!", - ); - return; - } - //- Generate nodes with random positions - //- Generate nodes with random positions - for (let i = 0; i < numNodesToGenerate; i++) { - const nodeName = `node-${i + 1}`; - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - }, - position: { - x: Math.random() * 400, - y: Math.random() * 400, - }, - }; - //-cy.add(newNode); - //-cy.add(newNode); - try { - cy.add(newNode); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred:" + error); - } - } - //- Generate random edges between nodes - //- Generate random edges between nodes - for (let i = 0; i < numNodesToGenerate; i++) { - const sourceNode = `node-${i + 1}`; - const targetNode = `node-${Math.floor(Math.random() * numNodesToGenerate) + 1}`; - if (sourceNode !== targetNode) { - const newEdge = { - group: "edges", - data: { - id: "from-" + sourceNode + "-to-" + targetNode, - name: "from-" + sourceNode + "-to-" + targetNode, - source: sourceNode, - target: targetNode, - }, - }; - try { - cy.add(newEdge); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred::" + error); - } - } - } - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //-//- Append a notification message to the textarea - //-//- Append a notification message to the textarea - console.log( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - appendMessage( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - } - - function spawnNodeEvent(event) { - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - const nodeName = document.getElementById("nodeName").value; - console.log(nodeName); - //- Check if a node name is empty - //- Check if a node name is empty - if (nodeName == "") { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Enter node name."); - return; - } - //- Check if a node with the same name already exists - //- Check if a node with the same name already exists - if (cy.$(`node[id = "${nodeName}"]`).length > 0) { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Node with this name already exists."); - return; - } - //- Create a new node element - //- Create a new node element - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - label: nodeName, - }, - }; - //- Add the new node to Cytoscape.js - //- Add the new node to Cytoscape.js - cy.add(newNode); - //- Randomize the positions and center the graph - //- Randomize the positions and center the graph - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //- Append a notification message to the textarea - //- Append a notification message to the textarea - console.log("Info: " + `Nice! Node "${nodeName}" added successfully.`); - appendMessage("Info: " + `Nice! Node "${nodeName}" added successfully.`); - } - - function nodeFindEvent(event) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById("nodeFindInput").value; - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } - } - - function zoomToFitDrawer() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); - } - - function pathFinderDijkstraEvent(event) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "pathFinderSourceNodeInput", - ).value; - const targetNodeId = document.getElementById( - "pathFinderTargetNodeInput", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } - } - - function setNodeContainerStatus(containerNodeName, containerNodeStatus) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - - // Find the corresponding status nodes based on node ID - // Find the corresponding status nodes based on node ID - var statusGreenNode = cy.$(`node[name="${nodeId}-statusGreen"]`); - var statusOrangeNode = cy.$(`node[name="${nodeId}-statusOrange"]`); - var statusRedNode = cy.$(`node[name="${nodeId}-statusRed"]`); - - if (statusGreenNode.length === 0 || statusRedNode.length === 0) { - // If status nodes are not found, skip this node - return; - } - - // Update positions of status nodes relative to the node - var nodePosition = node.position(); - var offset = { - x: -4, - y: -10 - }; - var statusGreenNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - var statusRedNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - - // Check if the nodeContainerStatusVisibility is true - if (nodeContainerStatusVisibility) { - // Check if the containerNodeName includes nodeId and containerNodeStatus includes 'healthy' - if ( - containerNodeName.includes(nodeId) && - (containerNodeStatus.includes("Up") || - containerNodeStatus.includes("healthy")) - ) { - statusGreenNode.show(); - statusRedNode.hide(); - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("(health: starting)") - ) { - statusGreenNode.hide(); - statusOrangeNode.show(); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("Exited") - ) { - statusGreenNode.hide(); - statusRedNode.show(); - } - } else { - statusGreenNode.hide(); - statusRedNode.hide(); - } - - statusGreenNode.position(statusGreenNodePosition); - statusRedNode.position(statusRedNodePosition); - }); - } - - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - if (containerNodeName.includes(nodeId)) { - var containerDockerExtraAttributeData = { - state: state, - status: status, - }; - - node.data( - "containerDockerExtraAttribute", - containerDockerExtraAttributeData, - ); - } - }); - } - - // - // End of JS Functions Event Handling section - // End of JS Functions Event Handling section - // - - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - - - //- Function to get the default node style from cy-style.json - //- Function to get the default node style from cy-style.json - async function getDefaultNodeStyle(node) { - try { - //- Fetch the cy-style.json file - //- Fetch the cy-style.json file - const response = await fetch("cy-style.json"); - //- Check if the response is successful (status code 200) - //- Check if the response is successful (status code 200) - if (!response.ok) { - throw new Error( - `Failed to fetch cy-style.json (${response.status} ${response.statusText})`, - ); - } - //- Parse the JSON response - //- Parse the JSON response - const styleData = await response.json(); - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - const defaultNodeStyle = styleData[0].style; - return defaultNodeStyle; - } catch (error) { - console.error("Error loading cy-style.json:", error); - appendMessage(`Error loading cy-style.json: ${error}`); - //- Return a default style in case of an error - //- Return a default style in case of an error - return { - "background-color": "blue", - "border-color": "gray", - "border-width": "1px", - }; - } - } - - ///-logMessagesPanel Function to add a click event listener to the copy button - ///-logMessagesPanel Function to add a click event listener to the copy button - const copyButton = document.getElementById("copyToClipboardButton"); - copyButton.className = "button is-smallest-element"; - copyButton.addEventListener("click", copyToClipboard); - - /// logMessagesPanel Function to copy textarea content to clipboard - /// logMessagesPanel Function to copy textarea content to clipboard - function copyToClipboard() { - const textarea = document.getElementById("notificationTextarea"); - textarea.select(); - document.execCommand("copy"); - } - - - - // function closePanelEvent(event, panel) { - // panel.style.display = "block"; - // console.log(panel.style.display); - // panel.style.display = "none"; - // } - - function createModal(modalId, modalContent) { - // Create the modal - // Create the modal - const htmlContent = ` - - `; - - const modalDiv = document.createElement("div"); - modalDiv.innerHTML = htmlContent; - modalDiv.id = "modalDivExportViewport"; - - document.body.appendChild(modalDiv); - const modalBackground = document.getElementById( - `${modalId}-modalBackgroundId`, - ); - - modalBackground.addEventListener("click", function() { - const modal = modalBackground.parentNode; - modal.classList.remove("is-active"); - }); - } - - function showModalCaptureViewport(modalId) { - const modalContentSaveViewport = ` - - `; - - // Instantiate modal - // Instantiate modal - createModal("modalSaveViewport", modalContentSaveViewport); - - // create event listener - // create event listener - const performActionButton = document.getElementById("performActionButton"); - performActionButton.addEventListener("click", function() { - const checkboxName = "checkboxSaveViewPort"; - const checkboxes = document.querySelectorAll( - `input[type="checkbox"][name="${checkboxName}"]`, - ); - const selectedOptions = []; - - checkboxes.forEach(function(checkbox) { - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - }); - - // show modal - // show modal - modal = document.getElementById(modalId); - modal.classList.add("is-active"); - } - - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // -}); - -// aarafat-tag: -//// REFACTOR START -//// to-do: -//// - re-create about-panel -//// - re-create log-messages -//// - re-create viewport - -async function initEnv() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - deploymentType = await environments["deployment-type"] - - console.log("Lab-Name: ", labName) - console.log("DeploymentType: ", deploymentType) - return environments, labName - } - -async function changeTitle() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - - console.log("changeTitle() - labName: ", labName) - document.title = `TopoViewer::${labName}`; -} - -async function sshWebBased(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - - console.log("sshWebBased: ", `${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`) - - window.open(`${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`); - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - -async function sshCliCommandCopy(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - clabServerAddress = environments["clab-server-address"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - clabUser = routerData["data"]["extraData"]["clabServerUsername"] - - sshCopyString = `ssh -t ${clabUser}@${clabServerAddress} "ssh admin@${routerName}"` - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(sshCopyString).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = sshCopyString; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - - - -async function linkImpairmentClab(event, impairDirection) { - console.log("linkImpairmentClab - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - var deploymentType = environments["deployment-type"] - var command - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkImpairment- edgeData: ", edgeData) - console.log("linkImpairment- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (impairDirection == "a-to-b") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-a-delay").value - jitterValue = document.getElementById("panel-link-endpoint-a-jitter").value - rateValue = document.getElementById("panel-link-endpoint-a-rate").value - lossValue = document.getElementById("panel-link-endpoint-a-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - - - } else if (impairDirection == "b-to-a") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-b-delay").value - jitterValue = document.getElementById("panel-link-endpoint-b-jitter").value - rateValue = document.getElementById("panel-link-endpoint-b-rate").value - lossValue = document.getElementById("panel-link-endpoint-b-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - - -async function linkWireshark(event, option, endpoint) { - console.log("linkWireshark - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkWireshark - environments: ", environments) - - var deploymentType = environments["deployment-type"] - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkWireshark- edgeData: ", edgeData) - console.log("linkWireshark- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (option == "app") { - if (endpoint == "source") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabSourceLongName}?${clabSourcePort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - - } else if (endpoint == "target") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabTargetLongName}?${clabTargetPort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - } - - window.open(wiresharkHref); - - } else if (option == "copy") { - if (endpoint == "source") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } - } else if (endpoint == "target") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } - } - - console.log("linkWireshark- wiresharkSShCommand: ", wiresharkSshCommand) - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(wiresharkSshCommand).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = wiresharkSshCommand; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - -async function showPanelLogMessages(event) { - document.getElementById("panel-log-messages").style.display = "block"; -} - -///-logMessagesPanel Function to add a click event listener to the close button -document.getElementById("panel-log-messages-close-button").addEventListener("click", () => { - document.getElementById("panel-log-messages").style.display = "none"; -}); - -async function showPanelTopoViewerClient(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - clabServerAddress = environments["clab-server-address"] - clabServerPort = environments["clab-server-port"] - - hrefWindows = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-windows/ClabCapture.app.zip` - hrefMac = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-mac/ClabCapture.app.zip` - - document.getElementById("panel-topoviewer-helper").style.display = "block"; - - const htmlContent = ` -
Wireshark Capture
-

- Please download the following helper app: -

- -

- TopoViewer offers a remote capture feature for intercepting ContainerLab node endpoints. - For the best experience, it's recommended to have both TopoViewer and its helper app installed on client-side. - With the TopoViewer helper app, you can effortlessly automate the launch of Wireshark's GUI. -

-

- Alternatively, if you don't have the helper app, you can simply copy and paste an SSH command to initiate Wireshark manually. - This setup provides flexibility in how you utilize this feature.
-

- `; - document.getElementById("panel-topoviewer-helper-content").innerHTML = htmlContent; -} - -async function showPanelAbout(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - topoViewerVersion = environments["topoviewer-version"] - - document.getElementById("panel-topoviewer-about").style.display = "block"; - - const htmlContent = ` -
-
Version: ${topoViewerVersion}
- -

- Designed and developed by Asad Arafat
-

-

- Special Thanks: -

-

- - -
- `; - document.getElementById("panel-topoviewer-about-content").innerHTML = htmlContent; -} - -async function sidebarButtonFitScreen(event) { - - // --sidebar-button-background-color-default: rgba(54,58, 69, 1); - // --sidebar-button-background-color-active: rgba(76, 82, 97, 1); - - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - const sidebarButtonColorDefault = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-default'); - const sidebarButtonColorActive = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-active'); - - drawer = document.getElementById("drawer") - if (drawer.style.display === 'block') { - drawer.style.display = 'none'; - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - sidebarButtonFitScreen.style.background = sidebarButtonColorDefault.trim(); - sidebarButtonFitScreen.style.border = sidebarButtonColorActive.trim(); - } else { - drawer.style.display = 'block'; - var sidebarButtons = document.getElementsByClassName("is-sidebar"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < sidebarButtons.length; i++) { - sidebarButtons[i].style.background = sidebarButtonColorDefault.trim(); - sidebarButtons[i].style.border = sidebarButtonColorDefault.trim(); - } - sidebarButtonFitScreen.style.background = sidebarButtonColorActive.trim(); - } - -} - -async function getActualNodesEndpoints(event) { - try { - bulmaToast.toast({ - message: `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - appendMessage( - `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - ); - - showLoadingSpinnerGlobal() - const CyTopoJson = await sendRequestToEndpointGet("/actual-nodes-endpoints", argsList = []) - location.reload(true); - - // Handle the response data - if (CyTopoJson && typeof CyTopoJson === 'object' && Object.keys(CyTopoJson).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", CyTopoJson); - - hideLoadingSpinnerGlobal(); - - - - return CyTopoJson - - } else { - - hideLoadingSpinnerGlobal(); - - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - hideLoadingSpinnerGlobal(); - console.error("Error occurred:", error); - // Handle errors as needed - } -} - -function viewportButtonsZoomToFit() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); -} - -function viewportButtonsLayoutAlgo() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - viewportDrawerLayout = document.getElementById("viewport-drawer-layout") - viewportDrawerLayout.style.display = "block" -} - - - - -async function layoutAlgoChange(event) { - - try { - console.log("layoutAlgoChange clicked"); - - var selectElement = document.getElementById("select-layout-algo"); - var selectedOption = selectElement.value; - - if (selectedOption === "Force Directed") { - console.log("Force Directed algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-force-directed") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-force-directed-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-force-directed")) - console.log(document.getElementById("viewport-drawer-force-directed-reset-start")) - - } else if (selectedOption === "Vertical") { - console.log("Vertical algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-vertical") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-vertical-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-vertical")) - console.log(document.getElementById("viewport-drawer-dc-vertical-reset-start")) - - } else if (selectedOption === "Horizontal") { - console.log("Horizontal algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-horizontal") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-horizontal-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-horizontal")) - console.log(document.getElementById("viewport-drawer-dc-horizontal-reset-start")) - } - - }catch (error) { - console.error("Error occurred:", error); - // Handle errors as needed - } -} - - -function viewportButtonsTopologyOverview() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyOverview clicked") - viewportDrawerLayout = document.getElementById("viewport-drawer-topology-overview") - viewportDrawerLayout.style.display = "block" - - viewportDrawerLayoutContent = document.getElementById("viewport-drawer-topology-overview-content") - viewportDrawerLayoutContent.style.display = "block" -} - -function viewportButtonsTopologyCapture() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyCapture clicked") - - viewportDrawerCapture = document.getElementById("viewport-drawer-capture-sceenshoot") - viewportDrawerCapture.style.display = "block" - - viewportDrawerCaptureContent = document.getElementById("viewport-drawer-capture-sceenshoot-content") - viewportDrawerCaptureContent.style.display = "block" -} - -function viewportButtonsLabelEndpoint() { - if (linkEndpointVisibility) { - cy.edges().forEach(function(edge) { - // edge.style("source-label", "."); - // edge.style("target-label", "."); - edge.style("text-opacity", 0); - edge.style("text-background-opacity", 0); - - - linkEndpointVisibility = false; - }); - } else { - cy.edges().forEach(function(edge) { - edge.style("text-opacity", 1); - edge.style("text-background-opacity", 0.7); - linkEndpointVisibility = true; - }); - } -} - -function viewportButtonContainerStatusVisibility() { - if (nodeContainerStatusVisibility) { - nodeContainerStatusVisibility = false; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `Alright, mission control, we're standing down. 🛑🔍 Container status probing aborted. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - nodeContainerStatusVisibility = true; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `🕵️‍♂️ Bro, we're currently on a mission to probe that container status! Stay tuned for the results. 🔍🚀👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } -} - - -function viewportDrawerLayoutForceDirected() { - edgeLengthSlider = document.getElementById("force-directed-slider-link-lenght"); - nodeGapSlider = document.getElementById("force-directed-slider-node-gap"); - - const edgeLengthValue = parseFloat(edgeLengthSlider.value); - const nodeGapValue = parseFloat(nodeGapSlider.value); - - console.log("edgeLengthValue", edgeLengthValue); - console.log("nodeGapValue", nodeGapValue); - - cy.layout( - { - fit: true, - name: "cola", - animate: true, - randomize: false, - maxSimulationTime: 400, - edgeLength: function(e) { - return edgeLengthValue / e.data("weight"); - }, - nodeGap: function(e) { - return nodeGapValue / e.data("weight"); - }, - }) - .run(); -} - -function viewportDrawerLayoutVertical() { - nodevGap = document.getElementById("vertical-layout-slider-node-v-gap"); - groupvGap = document.getElementById("vertical-layout-slider-group-v-gap"); - - const nodevGapValue = parseFloat(nodevGap.value); - const groupvGapValue = parseFloat(groupvGap.value); - - console.log("nodevGapValue", nodevGapValue); - console.log("groupvGapValue", groupvGapValue); - - const xOffset = parseFloat(nodevGapValue); - const yOffset = parseFloat(groupvGapValue); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numRows = 1; - - const cellWidth = node.width() / children.length; - // const xOffset = 5 - - children.forEach(function(child, index) { - // Position children in rows - const xPos = index * (cellWidth + xOffset); - const yPos = 0; - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxWidth = 0; - var centerX = 0; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const width = node.width(); - if (width > maxWidth) { - maxWidth = width; - console.log("ParentMaxWidth: ", maxWidth); - } - } - }); - - const divisionFactor = maxWidth / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let yPos = 0; - // const yOffset = 50; - // const yOffset = 50; - - // Position parent nodes vertically and center them horizontally - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const xPos = centerX - parent.width() / divisionFactor; - // to the left compared to the center of the widest parent node. - parent.position({ - x: xPos, - y: yPos - }); - yPos += yOffset; - }); - cy.fit(); - }, delay); -} - -function viewportDrawerLayoutHorizontal() { - nodehGap = document.getElementById("horizontal-layout-slider-node-h-gap"); - grouphGap = document.getElementById("horizontal-layout-slider-group-h-gap"); - - const horizontalNodeGap = parseFloat(nodehGap.value); - const horizontalGroupGap = parseFloat(grouphGap.value); - - console.log("nodevGapValue", horizontalNodeGap); - console.log("groupvGapValue", horizontalGroupGap); - - const yOffset = parseFloat(horizontalNodeGap); - const xOffset = parseFloat(horizontalGroupGap); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numColumns = 1; - const cellHeight = node.height() / children.length; - // const yOffset = 5; - - children.forEach(function(child, index) { - // Position children in columns - const xPos = 0; - const yPos = index * (cellHeight + yOffset); - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxHeight = 0; - var centerX = cy.width() / 2; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const height = node.height(); - if (height > maxHeight) { - maxHeight = height; - console.log("ParentMaxHeight: ", maxHeight); - } - } - }); - - const divisionFactor = maxHeight / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let xPos = 0; - // const xOffset = 50; - - // Position parent nodes horizontally and center them vertically - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const yPos = centerY - parent.height() / divisionFactor; - parent.position({ - x: xPos, - y: yPos - }); - xPos -= xOffset; - }); - - cy.fit(); - }, delay); - -} - - -function viewportDrawerCaptureButton() { - - console.log ("viewportDrawerCaptureButton() - clicked") - - - - - // Get all checkbox inputs within the specific div - const checkboxes = document.querySelectorAll('#viewport-drawer-capture-sceenshoot-content .checkbox-input'); - - // Initialize an array to store the values of checked checkboxes - const selectedOptions = []; - - // Iterate through the NodeList of checkboxes - checkboxes.forEach((checkbox) => { - // If the checkbox is checked, push its value to the array - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - console.log ("viewportDrawerCaptureButton() - ", selectedOptions) - - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - -} - -async function captureAndSaveViewportAsDrawIo(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - const drawIoWidht = canvasElement.width / 10; - const drawIoHeight = canvasElement.height / 10; - const drawIoaAspectRatio = drawIoWidht / drawIoHeight; - - const mxGraphHeader = ` - - - `; - - const mxGraphFooter = ` - `; - - const mxCells = []; - - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - function createMxCellForNode(node, imageURL) { - if (node.isParent()) { - return ` - - - `; - } else if ( - !node.data("id").includes("statusGreen") && - !node.data("id").includes("statusRed") - ) { - return ` - - - `; - } - } - - cy.nodes().forEach(function(node) { - let imageURL; - switch (node.data("topoViewerRole")) { - case "pe": - imageURL = `http://${location.host}/images/clab-pe-light-blue.png`; - break; - case "controller": - imageURL = - `http://${location.host}/images/clab-controller-light-blue.png`; - break; - case "pon": - imageURL = `http://${location.host}/images/clab-pon-dark-blue.png`; - break; - case "dcgw": - imageURL = `http://${location.host}/images/clab-dcgw-dark-blue.png`; - break; - case "leaf": - imageURL = `http://${location.host}/images/clab-leaf-light-blue.png`; - break; - case "spine": - imageURL = `http://${location.host}/images/clab-spine-dark-blue.png`; - break; - case "super-spine": - imageURL = `http://${location.host}/images/clab-spine-light-blue.png`; - break; - } - mxCells.push(createMxCellForNode(node, imageURL)); - }); - - cy.edges().forEach(function(edge) { - mxCells.push(` - - - - - - - - - - - - - - `); - }); - - // Combine all parts and create XML - const mxGraphXML = mxGraphHeader + mxCells.join("") + mxGraphFooter; - - // Create a Blob from the XML - const blob = new Blob([mxGraphXML], { - type: "application/xml", - }); - - // Create a URL for the Blob - const url = window.URL.createObjectURL(blob); - - // Create a download link and trigger a click event - const a = document.createElement("a"); - a.style.display = "none"; - a.href = url; - a.download = "filename.drawio"; - document.body.appendChild(a); - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - a.click(); - - // Clean up by revoking the URL and removing the download link - window.URL.revokeObjectURL(url); - document.body.removeChild(a); -} -async function captureAndSaveViewportAsPng(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - - const zoomScaleFactor = 1; - - // Check if the canvas element exists and is an HTMLCanvasElement - // Check if the canvas element exists and is an HTMLCanvasElement - if (canvasElement instanceof HTMLCanvasElement) { - // Calculate the new canvas dimensions based on the high resolution factor - // Calculate the new canvas dimensions based on the high resolution factor - const newWidth = canvasElement.width * zoomScaleFactor; - const newHeight = canvasElement.height * zoomScaleFactor; - - // Create a new canvas element with the increased dimensions - // Create a new canvas element with the increased dimensions - const newCanvas = document.createElement("canvas"); - newCanvas.width = newWidth; - newCanvas.height = newHeight; - const newCanvasContext = newCanvas.getContext("2d"); - - // Scale the canvas content to the new dimensions - // Scale the canvas content to the new dimensions - newCanvasContext.scale(zoomScaleFactor, zoomScaleFactor); - - // Fill the new canvas with a white background - // Fill the new canvas with a white background - newCanvasContext.fillStyle = "white"; - newCanvasContext.fillRect(0, 0, newWidth, newHeight); - - // Draw the original canvas content on the new canvas - // Draw the original canvas content on the new canvas - newCanvasContext.drawImage(canvasElement, 0, 0); - - // Convert the new canvas to a data URL with a white background - // Convert the new canvas to a data URL with a white background - const dataUrl = newCanvas.toDataURL("image/png"); - - // Create an anchor element to trigger the download - // Create an anchor element to trigger the download - const link = document.createElement("a"); - link.href = dataUrl; - link.download = "cytoscape-viewport.png"; - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - // Simulate a click to trigger the download - link.click(); - } else { - console.error( - "Canvas element for layer2-node is not found or is not a valid HTML canvas element.", - ); - } -} - - - -// aarafat-tag: -//// REFACTOR END - -// logMessagesPanel manager -///-logMessagesPanel Function to append message function -function appendMessage(message) { - // const textarea = document.getElementById('notificationTextarea'); - const textarea = document.getElementById("notificationTextarea"); - - // Get the current date and time - const timestamp = new Date().toLocaleString(); - - textarea.value += `[${timestamp}] ${message}\n`; - textarea.scrollTop = textarea.scrollHeight; -} - -function nodeFindDrawer(cy) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById( - "panelBlock-viewportButtons-buttonfindNode-divPanelBlock-columnContainerlabelFindNodeNodeName-panelContentlabelFindNodeNodeName-columnsPanelContentlabelFindNodeNodeName-labelColumnlabelFindNodeNodeName-inputColumnlabelFindNodeNodeName-labellabelFindNodeNodeName", - ).value; - - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } -} - -function pathFinderDijkstraDrawer(cy) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteSource-panelContentlabelFindRouteSource-columnsPanelContentlabelFindRouteSource-labelColumnlabelFindRouteSource-inputColumnlabelFindRouteSource-labellabelFindRouteSource", - ).value; - const targetNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteTarget-panelContentlabelFindRouteTarget-columnsPanelContentlabelFindRouteTarget-labelColumnlabelFindRouteTarget-inputColumnlabelFindRouteTarget-labellabelFindRouteTarget", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } -} - -// sleep funtion -function sleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); -} \ No newline at end of file diff --git a/dist/html-static/js/index.js b/dist/html-static/js/index.js index 8e598e014..727434d77 100644 --- a/dist/html-static/js/index.js +++ b/dist/html-static/js/index.js @@ -84,7 +84,19 @@ document.addEventListener("DOMContentLoaded", async function() { setNodeContainerStatus(Names, Status); console.log(JSON.parse(msgContainerNodeStatus.data)); - setNodeDataWithContainerAttribute(Names, Status, State); + const IPAddress = JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.IPAddress; + const GlobalIPv6Address= JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.GlobalIPv6Address + + // console.log("IPAddress: ",JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.IPAddress); + // console.log("IPPrefixLen: ",JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.IPPrefixLen); + + // console.log("GlobalIPv6Address: ",JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.GlobalIPv6Address); + // console.log("GlobalIPv6PrefixLen: ",JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.GlobalIPv6PrefixLen); + + + + setNodeDataWithContainerAttribute(Names, Status, State, IPAddress, GlobalIPv6Address); + } catch (error) { console.error("Error parsing JSON:", error); } @@ -319,7 +331,7 @@ document.addEventListener("DOMContentLoaded", async function() { document.getElementById("panel-node-kind").textContent = node.data("extraData").kind document.getElementById("panel-node-image").textContent = node.data("extraData").image document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss + document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Address document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn document.getElementById("panel-node-group").textContent = node.data("extraData").group document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") @@ -366,6 +378,8 @@ document.addEventListener("DOMContentLoaded", async function() { + + document.getElementById("panel-link").style.display = "none"; if (document.getElementById("panel-link").style.display === "none") { @@ -377,12 +391,27 @@ document.addEventListener("DOMContentLoaded", async function() { document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` + // document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` + document.getElementById("panel-link-endpoint-a-mac-address").textContent = "getting the MAC address" document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` + // document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` + document.getElementById("panel-link-endpoint-b-mac-address").textContent = "getting the MAC address" + + + // setting clabSourceLinkArgsList + clabLinkMacArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabTargetLongName}`] + + // setting MAC address endpoint-a values by getting the data from clab via /clab-link-mac GET API + const actualLinkMacPair = await sendRequestToEndpointGetV2("/clab-link-mac", clabLinkMacArgsList) + console.log("actualLinkMacPair-Source: ", actualLinkMacPair[0].sourceIfMac) + console.log("actualLinkMacPair-Target: ", actualLinkMacPair[0].targetIfMac) + + document.getElementById("panel-link-endpoint-a-mac-address").textContent = actualLinkMacPair[0].sourceIfMac + document.getElementById("panel-link-endpoint-b-mac-address").textContent = actualLinkMacPair[0].targetIfMac + + - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) @@ -929,7 +958,7 @@ document.addEventListener("DOMContentLoaded", async function() { }); } - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { + function setNodeDataWithContainerAttribute(containerNodeName, status, state, IPAddress, GlobalIPv6Address) { cy.nodes().forEach(function(node) { var nodeId = node.data("id"); if (containerNodeName.includes(nodeId)) { @@ -942,6 +971,9 @@ document.addEventListener("DOMContentLoaded", async function() { "containerDockerExtraAttribute", containerDockerExtraAttributeData, ); + node.data("extraData").mgmtIpv4Addresss = IPAddress; + node.data("extraData").mgmtIpv6Address = GlobalIPv6Address; + } }); } diff --git a/dist/html-static/js/index.js.bak b/dist/html-static/js/index.js.bak deleted file mode 100644 index 8e598e014..000000000 --- a/dist/html-static/js/index.js.bak +++ /dev/null @@ -1,2402 +0,0 @@ -// Initialize a state variable to track the element's presence -var isPanel01Cy = false; -var nodeClicked = false; -var edgeClicked = false; - -var cy - -var globalSelectedNode -var globalSelectedEdge - -var linkEndpointVisibility = true; -var nodeContainerStatusVisibility = false; - - -var globalShellUrl = "/js/cloudshell" - -var labName -var deploymentType - -document.addEventListener("DOMContentLoaded", async function() { - - detectColorScheme() - - await changeTitle() - - - // Reusable function to initialize a WebSocket connection - function initializeWebSocket(url, onMessageCallback) { - const protocol = location.protocol === "https:" ? "wss://" : "ws://"; - const socket = new WebSocket(protocol + location.host + url); - - socket.onopen = () => { - console.log(`Successfully connected WebSocket to ${url}`); - if (socket.readyState === WebSocket.OPEN) { - socket.send(`Hi From the WebSocketClient-${url}`); - } - }; - - socket.onclose = (event) => { - console.log(`Socket to ${url} closed: `, event); - socket.send("Client Closed!"); - }; - - socket.onerror = (error) => { - console.log(`Socket to ${url} error: `, error); - }; - - socket.onmessage = onMessageCallback; - - return socket; - } - - - // WebSocket for uptime - // WebSocket for uptime - const socketUptime = initializeWebSocket("/uptime", async (msgUptime) => { - environments = await getEnvironments(); - labName = environments["clab-name"] - deploymentType = environments["deploymentType"] - - console.log("initializeWebSocket - getEnvironments", environments) - console.log("initializeWebSocket - labName", environments["clab-name"]) - - const string01 = "Containerlab Topology: " + labName; - const string02 = " ::: Uptime: " + msgUptime.data; - - const ClabSubtitle = document.getElementById("ClabSubtitle"); - const messageBody = string01 + string02; - - ClabSubtitle.innerText = messageBody; - console.log(ClabSubtitle.innerText); - }); - - // WebSocket for ContainerNodeStatus - const socketContainerNodeStatusInitial = initializeWebSocket( - "/containerNodeStatus", - (msgContainerNodeStatus) => { - try { - const { - Names, - Status, - State - } = JSON.parse(msgContainerNodeStatus.data); - setNodeContainerStatus(Names, Status); - console.log(JSON.parse(msgContainerNodeStatus.data)); - - setNodeDataWithContainerAttribute(Names, Status, State); - } catch (error) { - console.error("Error parsing JSON:", error); - } - }, - ); - - //- Instantiate Cytoscape.js - cy = cytoscape({ - container: document.getElementById("cy"), - elements: [], - style: [{ - selector: "node", - style: { - "background-color": "#3498db", - label: "data(label)", - }, - }, ], - }); - - - loadCytoStyle(); - - function loadCytoStyle() { - - // detect light or dark mode - const colorScheme = detectColorScheme(); - console.log('The user prefers:', colorScheme); - - //- Load and apply Cytoscape styles from cy-style.json using fetch - if (colorScheme == "light") { - fetch("css/cy-style.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } else if (colorScheme == "dark") { - fetch("css/cy-style-dark.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } - } - - // Enable grid guide extension - cy.gridGuide({ - // On/Off Modules - - snapToGridOnRelease: true, - snapToGridDuringDrag: false, - snapToAlignmentLocationOnRelease: true, - snapToAlignmentLocationDuringDrag: false, - distributionGuidelines: false, - geometricGuideline: false, - initPosAlignment: false, - centerToEdgeAlignment: false, - resize: false, - parentPadding: false, - drawGrid: false, - - // General - gridSpacing: 10, - snapToGridCenter: true, - - // Draw Grid - zoomDash: true, - panGrid: true, - gridStackOrder: -1, - gridColor: '#dedede', - lineWidth: 1.0, - - // Guidelines - guidelinesStackOrder: 4, - guidelinesTolerance: 2.00, - guidelinesStyle: { - strokeStyle: "#8b7d6b", - geometricGuidelineRange: 400, - range: 100, - minDistRange: 10, - distGuidelineOffset: 10, - horizontalDistColor: "#ff0000", - verticalDistColor: "#00ff00", - initPosAlignmentColor: "#0000ff", - lineDash: [0, 0], - horizontalDistLine: [0, 0], - verticalDistLine: [0, 0], - initPosAlignmentLine: [0, 0], - }, - - // Parent Padding - parentSpacing: -1 - }); - - // Fetch and load element data from a JSON file - // fetch("dataCytoMarshall-" + labName + ".json") - fetch("dataCytoMarshall.json") - - .then((response) => response.json()) - .then((elements) => { - // Add the elements to the Cytoscape instance - // Add the elements to the Cytoscape instance - cy.add(elements); - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLength: 100, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - - // remove node topoviewer - topoViewerNode = cy.filter('node[name = "topoviewer"]'); - topoViewerNode.remove(); - }) - .catch((error) => { - console.error("Error loading graph data:", error); - }); - - // Instantiate hover text element - const hoverText = document.createElement("box"); - hoverText.classList.add( - "hover-text", - "is-hidden", - "box", - "has-text-weight-normal", - "is-warning", - "is-smallest", - ); - hoverText.textContent = "Launch CloudShell."; - document.body.appendChild(hoverText); - - //- Toggle the Panel(s) when clicking on the cy container - //- Toggle the Panel(s) when clicking on the cy container - document.getElementById("cy").addEventListener("click", function(event) { - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - - loadCytoStyle(); - - if (!nodeClicked && !edgeClicked) { - if (!isPanel01Cy) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - var ViewPortDrawerElements = - document.getElementsByClassName("ViewPortDrawer"); - var ViewPortDrawerArray = Array.from(ViewPortDrawerElements); - ViewPortDrawerArray.forEach(function(element) { - element.style.display = "none"; - }); - - } else { - removeElementById("Panel-01"); - appendMessage(`"try to remove panel01-Cy"`); - } - } - nodeClicked = false; - edgeClicked = false; - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - }); - - // Click event listener for nodes - // Click event listener for nodes - cy.on("click", "node", function(event) { - // This code will be executed when you click on a node - // This code will be executed when you click on a node - const node = event.target; - nodeClicked = true; - - if (!node.isParent()) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - console.log(node) - console.log(node.data("containerDockerExtraAttribute").status) - console.log(node.data("extraData")) - - if (document.getElementById("panel-node").style.display === "none") { - document.getElementById("panel-node").style.display = "block"; - } else { - document.getElementById("panel-node").style.display = "none"; - } - - document.getElementById("panel-node-name").textContent = node.data("extraData").longname - document.getElementById("panel-node-status").textContent = node.data("containerDockerExtraAttribute").status - document.getElementById("panel-node-kind").textContent = node.data("extraData").kind - document.getElementById("panel-node-image").textContent = node.data("extraData").image - document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss - document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn - document.getElementById("panel-node-group").textContent = node.data("extraData").group - document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") - - // set selected node-long-name to global variable - globalSelectedNode = node.data("extraData").longname - console.log("internal: ", globalSelectedNode) - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - } - }); - - // Click event listener for edges - // Click event listener for edges - cy.on("click", "edge", async function(event) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - // This code will be executed when you click on a node - // You can add logic specific to nodes here - const clickedEdge = event.target; - const defaultEdgeColor = "#969799"; - edgeClicked = true; - - console.log(defaultEdgeColor); - - // Change the color of the clicked edge (for example, to red) - clickedEdge.style("line-color", "#0043BF"); - - // Revert the color of other edges that were not clicked (e.g., back to their default color) - cy.edges().forEach(function(edge) { - if (edge !== clickedEdge) { - edge.style("line-color", defaultEdgeColor); - } - }); - - - - - document.getElementById("panel-link").style.display = "none"; - - if (document.getElementById("panel-link").style.display === "none") { - document.getElementById("panel-link").style.display = "block"; - } else { - document.getElementById("panel-link").style.display = "none"; - } - - document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` - - document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` - - document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` - - - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API - clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] - clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) - - if (clabSourceLinkImpairmentClabData && typeof clabSourceLinkImpairmentClabData === 'object' && Object.keys(clabSourceLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabSourceLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabSourceLinkImpairmentClabData returnd data", clabSourceLinkImpairmentClabData["return data"]["delay"]); - - if (clabSourceLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-a-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-delay").value = clabSourceLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-a-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-jitter").value = clabSourceLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-a-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-rate").value = clabSourceLinkImpairmentClabData["return data"]["rate"] - } - - if (clabSourceLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-a-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-loss").value = clabSourceLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // setting default impairment endpoint-b values by getting the data from clab via /clab-link-impairment GET API - clabTargetLinkArgsList = [`${clickedEdge.data("extraData").clabTargetLongName}`,`${clickedEdge.data("extraData").clabTargetPort}`] - clabTargetLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabTargetLinkArgsList) - - if (clabTargetLinkImpairmentClabData && typeof clabTargetLinkImpairmentClabData === 'object' && Object.keys(clabTargetLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabTargetLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabTargetLinkImpairmentClabData returnd data", clabTargetLinkImpairmentClabData["return data"]["delay"]); - - if (clabTargetLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-b-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-delay").value = clabTargetLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-b-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-jitter").value = clabTargetLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-b-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-rate").value = clabTargetLinkImpairmentClabData["return data"]["rate"] - } - - if (clabTargetLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-b-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-loss").value = clabTargetLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // set selected edge-id to global variable - globalSelectedEdge = clickedEdge.data("id") - - appendMessage(`"edgeClicked: " ${edgeClicked}`); - }); - - - - - function generateNodesEvent(event) { - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - console.log("generateNodesButton clicked"); - const numNodes = document.getElementById("generateNodesInput").value; - console.log(numNodes); - //- Check if the number of node is empty - //- Check if the number of node is empty - if (numNodes === null) { - //- if node number empty do nothing - //- if node number empty do nothing - return; - } - const numNodesToGenerate = parseInt(numNodes, 10); - //- Check if the number of node is positive - //- Check if the number of node is positive - if (isNaN(numNodesToGenerate) || numNodesToGenerate <= 0) { - //- Invalid input - //- Invalid input - appendMessage( - "Error:" + "Bro, you gotta enter a valid positive number, come on!", - ); - return; - } - //- Generate nodes with random positions - //- Generate nodes with random positions - for (let i = 0; i < numNodesToGenerate; i++) { - const nodeName = `node-${i + 1}`; - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - }, - position: { - x: Math.random() * 400, - y: Math.random() * 400, - }, - }; - //-cy.add(newNode); - //-cy.add(newNode); - try { - cy.add(newNode); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred:" + error); - } - } - //- Generate random edges between nodes - //- Generate random edges between nodes - for (let i = 0; i < numNodesToGenerate; i++) { - const sourceNode = `node-${i + 1}`; - const targetNode = `node-${Math.floor(Math.random() * numNodesToGenerate) + 1}`; - if (sourceNode !== targetNode) { - const newEdge = { - group: "edges", - data: { - id: "from-" + sourceNode + "-to-" + targetNode, - name: "from-" + sourceNode + "-to-" + targetNode, - source: sourceNode, - target: targetNode, - }, - }; - try { - cy.add(newEdge); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred::" + error); - } - } - } - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //-//- Append a notification message to the textarea - //-//- Append a notification message to the textarea - console.log( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - appendMessage( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - } - - function spawnNodeEvent(event) { - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - const nodeName = document.getElementById("nodeName").value; - console.log(nodeName); - //- Check if a node name is empty - //- Check if a node name is empty - if (nodeName == "") { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Enter node name."); - return; - } - //- Check if a node with the same name already exists - //- Check if a node with the same name already exists - if (cy.$(`node[id = "${nodeName}"]`).length > 0) { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Node with this name already exists."); - return; - } - //- Create a new node element - //- Create a new node element - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - label: nodeName, - }, - }; - //- Add the new node to Cytoscape.js - //- Add the new node to Cytoscape.js - cy.add(newNode); - //- Randomize the positions and center the graph - //- Randomize the positions and center the graph - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //- Append a notification message to the textarea - //- Append a notification message to the textarea - console.log("Info: " + `Nice! Node "${nodeName}" added successfully.`); - appendMessage("Info: " + `Nice! Node "${nodeName}" added successfully.`); - } - - function nodeFindEvent(event) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById("nodeFindInput").value; - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } - } - - function zoomToFitDrawer() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); - } - - function pathFinderDijkstraEvent(event) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "pathFinderSourceNodeInput", - ).value; - const targetNodeId = document.getElementById( - "pathFinderTargetNodeInput", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } - } - - function setNodeContainerStatus(containerNodeName, containerNodeStatus) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - - // Find the corresponding status nodes based on node ID - // Find the corresponding status nodes based on node ID - var statusGreenNode = cy.$(`node[name="${nodeId}-statusGreen"]`); - var statusOrangeNode = cy.$(`node[name="${nodeId}-statusOrange"]`); - var statusRedNode = cy.$(`node[name="${nodeId}-statusRed"]`); - - if (statusGreenNode.length === 0 || statusRedNode.length === 0) { - // If status nodes are not found, skip this node - return; - } - - // Update positions of status nodes relative to the node - var nodePosition = node.position(); - var offset = { - x: -4, - y: -10 - }; - var statusGreenNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - var statusRedNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - - // Check if the nodeContainerStatusVisibility is true - if (nodeContainerStatusVisibility) { - // Check if the containerNodeName includes nodeId and containerNodeStatus includes 'healthy' - if ( - containerNodeName.includes(nodeId) && - (containerNodeStatus.includes("Up") || - containerNodeStatus.includes("healthy")) - ) { - statusGreenNode.show(); - statusRedNode.hide(); - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("(health: starting)") - ) { - statusGreenNode.hide(); - statusOrangeNode.show(); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("Exited") - ) { - statusGreenNode.hide(); - statusRedNode.show(); - } - } else { - statusGreenNode.hide(); - statusRedNode.hide(); - } - - statusGreenNode.position(statusGreenNodePosition); - statusRedNode.position(statusRedNodePosition); - }); - } - - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - if (containerNodeName.includes(nodeId)) { - var containerDockerExtraAttributeData = { - state: state, - status: status, - }; - - node.data( - "containerDockerExtraAttribute", - containerDockerExtraAttributeData, - ); - } - }); - } - - // - // End of JS Functions Event Handling section - // End of JS Functions Event Handling section - // - - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - - - //- Function to get the default node style from cy-style.json - //- Function to get the default node style from cy-style.json - async function getDefaultNodeStyle(node) { - try { - //- Fetch the cy-style.json file - //- Fetch the cy-style.json file - const response = await fetch("cy-style.json"); - //- Check if the response is successful (status code 200) - //- Check if the response is successful (status code 200) - if (!response.ok) { - throw new Error( - `Failed to fetch cy-style.json (${response.status} ${response.statusText})`, - ); - } - //- Parse the JSON response - //- Parse the JSON response - const styleData = await response.json(); - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - const defaultNodeStyle = styleData[0].style; - return defaultNodeStyle; - } catch (error) { - console.error("Error loading cy-style.json:", error); - appendMessage(`Error loading cy-style.json: ${error}`); - //- Return a default style in case of an error - //- Return a default style in case of an error - return { - "background-color": "blue", - "border-color": "gray", - "border-width": "1px", - }; - } - } - - ///-logMessagesPanel Function to add a click event listener to the copy button - ///-logMessagesPanel Function to add a click event listener to the copy button - const copyButton = document.getElementById("copyToClipboardButton"); - copyButton.className = "button is-smallest-element"; - copyButton.addEventListener("click", copyToClipboard); - - /// logMessagesPanel Function to copy textarea content to clipboard - /// logMessagesPanel Function to copy textarea content to clipboard - function copyToClipboard() { - const textarea = document.getElementById("notificationTextarea"); - textarea.select(); - document.execCommand("copy"); - } - - - - // function closePanelEvent(event, panel) { - // panel.style.display = "block"; - // console.log(panel.style.display); - // panel.style.display = "none"; - // } - - function createModal(modalId, modalContent) { - // Create the modal - // Create the modal - const htmlContent = ` - - `; - - const modalDiv = document.createElement("div"); - modalDiv.innerHTML = htmlContent; - modalDiv.id = "modalDivExportViewport"; - - document.body.appendChild(modalDiv); - const modalBackground = document.getElementById( - `${modalId}-modalBackgroundId`, - ); - - modalBackground.addEventListener("click", function() { - const modal = modalBackground.parentNode; - modal.classList.remove("is-active"); - }); - } - - function showModalCaptureViewport(modalId) { - const modalContentSaveViewport = ` - - `; - - // Instantiate modal - // Instantiate modal - createModal("modalSaveViewport", modalContentSaveViewport); - - // create event listener - // create event listener - const performActionButton = document.getElementById("performActionButton"); - performActionButton.addEventListener("click", function() { - const checkboxName = "checkboxSaveViewPort"; - const checkboxes = document.querySelectorAll( - `input[type="checkbox"][name="${checkboxName}"]`, - ); - const selectedOptions = []; - - checkboxes.forEach(function(checkbox) { - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - }); - - // show modal - // show modal - modal = document.getElementById(modalId); - modal.classList.add("is-active"); - } - - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // -}); - -// aarafat-tag: -//// REFACTOR START -//// to-do: -//// - re-create about-panel -//// - re-create log-messages -//// - re-create viewport - -async function initEnv() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - deploymentType = await environments["deployment-type"] - - console.log("Lab-Name: ", labName) - console.log("DeploymentType: ", deploymentType) - return environments, labName - } - -async function changeTitle() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - - console.log("changeTitle() - labName: ", labName) - document.title = `TopoViewer::${labName}`; -} - -async function sshWebBased(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - - console.log("sshWebBased: ", `${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`) - - window.open(`${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`); - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - -async function sshCliCommandCopy(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - clabServerAddress = environments["clab-server-address"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - clabUser = routerData["data"]["extraData"]["clabServerUsername"] - - sshCopyString = `ssh -t ${clabUser}@${clabServerAddress} "ssh admin@${routerName}"` - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(sshCopyString).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = sshCopyString; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - - - -async function linkImpairmentClab(event, impairDirection) { - console.log("linkImpairmentClab - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - var deploymentType = environments["deployment-type"] - var command - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkImpairment- edgeData: ", edgeData) - console.log("linkImpairment- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (impairDirection == "a-to-b") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-a-delay").value - jitterValue = document.getElementById("panel-link-endpoint-a-jitter").value - rateValue = document.getElementById("panel-link-endpoint-a-rate").value - lossValue = document.getElementById("panel-link-endpoint-a-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - - - } else if (impairDirection == "b-to-a") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-b-delay").value - jitterValue = document.getElementById("panel-link-endpoint-b-jitter").value - rateValue = document.getElementById("panel-link-endpoint-b-rate").value - lossValue = document.getElementById("panel-link-endpoint-b-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - - -async function linkWireshark(event, option, endpoint) { - console.log("linkWireshark - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkWireshark - environments: ", environments) - - var deploymentType = environments["deployment-type"] - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkWireshark- edgeData: ", edgeData) - console.log("linkWireshark- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (option == "app") { - if (endpoint == "source") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabSourceLongName}?${clabSourcePort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - - } else if (endpoint == "target") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabTargetLongName}?${clabTargetPort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - } - - window.open(wiresharkHref); - - } else if (option == "copy") { - if (endpoint == "source") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } - } else if (endpoint == "target") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } - } - - console.log("linkWireshark- wiresharkSShCommand: ", wiresharkSshCommand) - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(wiresharkSshCommand).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = wiresharkSshCommand; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - -async function showPanelLogMessages(event) { - document.getElementById("panel-log-messages").style.display = "block"; -} - -///-logMessagesPanel Function to add a click event listener to the close button -document.getElementById("panel-log-messages-close-button").addEventListener("click", () => { - document.getElementById("panel-log-messages").style.display = "none"; -}); - -async function showPanelTopoViewerClient(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - clabServerAddress = environments["clab-server-address"] - clabServerPort = environments["clab-server-port"] - - hrefWindows = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-windows/ClabCapture.app.zip` - hrefMac = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-mac/ClabCapture.app.zip` - - document.getElementById("panel-topoviewer-helper").style.display = "block"; - - const htmlContent = ` -
Wireshark Capture
-

- Please download the following helper app: -

- -

- TopoViewer offers a remote capture feature for intercepting ContainerLab node endpoints. - For the best experience, it's recommended to have both TopoViewer and its helper app installed on client-side. - With the TopoViewer helper app, you can effortlessly automate the launch of Wireshark's GUI. -

-

- Alternatively, if you don't have the helper app, you can simply copy and paste an SSH command to initiate Wireshark manually. - This setup provides flexibility in how you utilize this feature.
-

- `; - document.getElementById("panel-topoviewer-helper-content").innerHTML = htmlContent; -} - -async function showPanelAbout(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - topoViewerVersion = environments["topoviewer-version"] - - document.getElementById("panel-topoviewer-about").style.display = "block"; - - const htmlContent = ` -
-
Version: ${topoViewerVersion}
- -

- Designed and developed by Asad Arafat
-

-

- Special Thanks: -

-

- - -
- `; - document.getElementById("panel-topoviewer-about-content").innerHTML = htmlContent; -} - -async function sidebarButtonFitScreen(event) { - - // --sidebar-button-background-color-default: rgba(54,58, 69, 1); - // --sidebar-button-background-color-active: rgba(76, 82, 97, 1); - - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - const sidebarButtonColorDefault = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-default'); - const sidebarButtonColorActive = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-active'); - - drawer = document.getElementById("drawer") - if (drawer.style.display === 'block') { - drawer.style.display = 'none'; - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - sidebarButtonFitScreen.style.background = sidebarButtonColorDefault.trim(); - sidebarButtonFitScreen.style.border = sidebarButtonColorActive.trim(); - } else { - drawer.style.display = 'block'; - var sidebarButtons = document.getElementsByClassName("is-sidebar"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < sidebarButtons.length; i++) { - sidebarButtons[i].style.background = sidebarButtonColorDefault.trim(); - sidebarButtons[i].style.border = sidebarButtonColorDefault.trim(); - } - sidebarButtonFitScreen.style.background = sidebarButtonColorActive.trim(); - } - -} - -async function getActualNodesEndpoints(event) { - try { - bulmaToast.toast({ - message: `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - appendMessage( - `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - ); - - showLoadingSpinnerGlobal() - const CyTopoJson = await sendRequestToEndpointGet("/actual-nodes-endpoints", argsList = []) - location.reload(true); - - // Handle the response data - if (CyTopoJson && typeof CyTopoJson === 'object' && Object.keys(CyTopoJson).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", CyTopoJson); - - hideLoadingSpinnerGlobal(); - - - - return CyTopoJson - - } else { - - hideLoadingSpinnerGlobal(); - - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - hideLoadingSpinnerGlobal(); - console.error("Error occurred:", error); - // Handle errors as needed - } -} - -function viewportButtonsZoomToFit() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); -} - -function viewportButtonsLayoutAlgo() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - viewportDrawerLayout = document.getElementById("viewport-drawer-layout") - viewportDrawerLayout.style.display = "block" -} - - - - -async function layoutAlgoChange(event) { - - try { - console.log("layoutAlgoChange clicked"); - - var selectElement = document.getElementById("select-layout-algo"); - var selectedOption = selectElement.value; - - if (selectedOption === "Force Directed") { - console.log("Force Directed algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-force-directed") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-force-directed-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-force-directed")) - console.log(document.getElementById("viewport-drawer-force-directed-reset-start")) - - } else if (selectedOption === "Vertical") { - console.log("Vertical algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-vertical") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-vertical-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-vertical")) - console.log(document.getElementById("viewport-drawer-dc-vertical-reset-start")) - - } else if (selectedOption === "Horizontal") { - console.log("Horizontal algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-horizontal") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-horizontal-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-horizontal")) - console.log(document.getElementById("viewport-drawer-dc-horizontal-reset-start")) - } - - }catch (error) { - console.error("Error occurred:", error); - // Handle errors as needed - } -} - - -function viewportButtonsTopologyOverview() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyOverview clicked") - viewportDrawerLayout = document.getElementById("viewport-drawer-topology-overview") - viewportDrawerLayout.style.display = "block" - - viewportDrawerLayoutContent = document.getElementById("viewport-drawer-topology-overview-content") - viewportDrawerLayoutContent.style.display = "block" -} - -function viewportButtonsTopologyCapture() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyCapture clicked") - - viewportDrawerCapture = document.getElementById("viewport-drawer-capture-sceenshoot") - viewportDrawerCapture.style.display = "block" - - viewportDrawerCaptureContent = document.getElementById("viewport-drawer-capture-sceenshoot-content") - viewportDrawerCaptureContent.style.display = "block" -} - -function viewportButtonsLabelEndpoint() { - if (linkEndpointVisibility) { - cy.edges().forEach(function(edge) { - // edge.style("source-label", "."); - // edge.style("target-label", "."); - edge.style("text-opacity", 0); - edge.style("text-background-opacity", 0); - - - linkEndpointVisibility = false; - }); - } else { - cy.edges().forEach(function(edge) { - edge.style("text-opacity", 1); - edge.style("text-background-opacity", 0.7); - linkEndpointVisibility = true; - }); - } -} - -function viewportButtonContainerStatusVisibility() { - if (nodeContainerStatusVisibility) { - nodeContainerStatusVisibility = false; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `Alright, mission control, we're standing down. 🛑🔍 Container status probing aborted. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - nodeContainerStatusVisibility = true; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `🕵️‍♂️ Bro, we're currently on a mission to probe that container status! Stay tuned for the results. 🔍🚀👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } -} - - -function viewportDrawerLayoutForceDirected() { - edgeLengthSlider = document.getElementById("force-directed-slider-link-lenght"); - nodeGapSlider = document.getElementById("force-directed-slider-node-gap"); - - const edgeLengthValue = parseFloat(edgeLengthSlider.value); - const nodeGapValue = parseFloat(nodeGapSlider.value); - - console.log("edgeLengthValue", edgeLengthValue); - console.log("nodeGapValue", nodeGapValue); - - cy.layout( - { - fit: true, - name: "cola", - animate: true, - randomize: false, - maxSimulationTime: 400, - edgeLength: function(e) { - return edgeLengthValue / e.data("weight"); - }, - nodeGap: function(e) { - return nodeGapValue / e.data("weight"); - }, - }) - .run(); -} - -function viewportDrawerLayoutVertical() { - nodevGap = document.getElementById("vertical-layout-slider-node-v-gap"); - groupvGap = document.getElementById("vertical-layout-slider-group-v-gap"); - - const nodevGapValue = parseFloat(nodevGap.value); - const groupvGapValue = parseFloat(groupvGap.value); - - console.log("nodevGapValue", nodevGapValue); - console.log("groupvGapValue", groupvGapValue); - - const xOffset = parseFloat(nodevGapValue); - const yOffset = parseFloat(groupvGapValue); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numRows = 1; - - const cellWidth = node.width() / children.length; - // const xOffset = 5 - - children.forEach(function(child, index) { - // Position children in rows - const xPos = index * (cellWidth + xOffset); - const yPos = 0; - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxWidth = 0; - var centerX = 0; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const width = node.width(); - if (width > maxWidth) { - maxWidth = width; - console.log("ParentMaxWidth: ", maxWidth); - } - } - }); - - const divisionFactor = maxWidth / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let yPos = 0; - // const yOffset = 50; - // const yOffset = 50; - - // Position parent nodes vertically and center them horizontally - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const xPos = centerX - parent.width() / divisionFactor; - // to the left compared to the center of the widest parent node. - parent.position({ - x: xPos, - y: yPos - }); - yPos += yOffset; - }); - cy.fit(); - }, delay); -} - -function viewportDrawerLayoutHorizontal() { - nodehGap = document.getElementById("horizontal-layout-slider-node-h-gap"); - grouphGap = document.getElementById("horizontal-layout-slider-group-h-gap"); - - const horizontalNodeGap = parseFloat(nodehGap.value); - const horizontalGroupGap = parseFloat(grouphGap.value); - - console.log("nodevGapValue", horizontalNodeGap); - console.log("groupvGapValue", horizontalGroupGap); - - const yOffset = parseFloat(horizontalNodeGap); - const xOffset = parseFloat(horizontalGroupGap); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numColumns = 1; - const cellHeight = node.height() / children.length; - // const yOffset = 5; - - children.forEach(function(child, index) { - // Position children in columns - const xPos = 0; - const yPos = index * (cellHeight + yOffset); - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxHeight = 0; - var centerX = cy.width() / 2; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const height = node.height(); - if (height > maxHeight) { - maxHeight = height; - console.log("ParentMaxHeight: ", maxHeight); - } - } - }); - - const divisionFactor = maxHeight / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let xPos = 0; - // const xOffset = 50; - - // Position parent nodes horizontally and center them vertically - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const yPos = centerY - parent.height() / divisionFactor; - parent.position({ - x: xPos, - y: yPos - }); - xPos -= xOffset; - }); - - cy.fit(); - }, delay); - -} - - -function viewportDrawerCaptureButton() { - - console.log ("viewportDrawerCaptureButton() - clicked") - - - - - // Get all checkbox inputs within the specific div - const checkboxes = document.querySelectorAll('#viewport-drawer-capture-sceenshoot-content .checkbox-input'); - - // Initialize an array to store the values of checked checkboxes - const selectedOptions = []; - - // Iterate through the NodeList of checkboxes - checkboxes.forEach((checkbox) => { - // If the checkbox is checked, push its value to the array - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - console.log ("viewportDrawerCaptureButton() - ", selectedOptions) - - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - -} - -async function captureAndSaveViewportAsDrawIo(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - const drawIoWidht = canvasElement.width / 10; - const drawIoHeight = canvasElement.height / 10; - const drawIoaAspectRatio = drawIoWidht / drawIoHeight; - - const mxGraphHeader = ` - - - `; - - const mxGraphFooter = ` - `; - - const mxCells = []; - - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - function createMxCellForNode(node, imageURL) { - if (node.isParent()) { - return ` - - - `; - } else if ( - !node.data("id").includes("statusGreen") && - !node.data("id").includes("statusRed") - ) { - return ` - - - `; - } - } - - cy.nodes().forEach(function(node) { - let imageURL; - switch (node.data("topoViewerRole")) { - case "pe": - imageURL = `http://${location.host}/images/clab-pe-light-blue.png`; - break; - case "controller": - imageURL = - `http://${location.host}/images/clab-controller-light-blue.png`; - break; - case "pon": - imageURL = `http://${location.host}/images/clab-pon-dark-blue.png`; - break; - case "dcgw": - imageURL = `http://${location.host}/images/clab-dcgw-dark-blue.png`; - break; - case "leaf": - imageURL = `http://${location.host}/images/clab-leaf-light-blue.png`; - break; - case "spine": - imageURL = `http://${location.host}/images/clab-spine-dark-blue.png`; - break; - case "super-spine": - imageURL = `http://${location.host}/images/clab-spine-light-blue.png`; - break; - } - mxCells.push(createMxCellForNode(node, imageURL)); - }); - - cy.edges().forEach(function(edge) { - mxCells.push(` - - - - - - - - - - - - - - `); - }); - - // Combine all parts and create XML - const mxGraphXML = mxGraphHeader + mxCells.join("") + mxGraphFooter; - - // Create a Blob from the XML - const blob = new Blob([mxGraphXML], { - type: "application/xml", - }); - - // Create a URL for the Blob - const url = window.URL.createObjectURL(blob); - - // Create a download link and trigger a click event - const a = document.createElement("a"); - a.style.display = "none"; - a.href = url; - a.download = "filename.drawio"; - document.body.appendChild(a); - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - a.click(); - - // Clean up by revoking the URL and removing the download link - window.URL.revokeObjectURL(url); - document.body.removeChild(a); -} -async function captureAndSaveViewportAsPng(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - - const zoomScaleFactor = 1; - - // Check if the canvas element exists and is an HTMLCanvasElement - // Check if the canvas element exists and is an HTMLCanvasElement - if (canvasElement instanceof HTMLCanvasElement) { - // Calculate the new canvas dimensions based on the high resolution factor - // Calculate the new canvas dimensions based on the high resolution factor - const newWidth = canvasElement.width * zoomScaleFactor; - const newHeight = canvasElement.height * zoomScaleFactor; - - // Create a new canvas element with the increased dimensions - // Create a new canvas element with the increased dimensions - const newCanvas = document.createElement("canvas"); - newCanvas.width = newWidth; - newCanvas.height = newHeight; - const newCanvasContext = newCanvas.getContext("2d"); - - // Scale the canvas content to the new dimensions - // Scale the canvas content to the new dimensions - newCanvasContext.scale(zoomScaleFactor, zoomScaleFactor); - - // Fill the new canvas with a white background - // Fill the new canvas with a white background - newCanvasContext.fillStyle = "white"; - newCanvasContext.fillRect(0, 0, newWidth, newHeight); - - // Draw the original canvas content on the new canvas - // Draw the original canvas content on the new canvas - newCanvasContext.drawImage(canvasElement, 0, 0); - - // Convert the new canvas to a data URL with a white background - // Convert the new canvas to a data URL with a white background - const dataUrl = newCanvas.toDataURL("image/png"); - - // Create an anchor element to trigger the download - // Create an anchor element to trigger the download - const link = document.createElement("a"); - link.href = dataUrl; - link.download = "cytoscape-viewport.png"; - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - // Simulate a click to trigger the download - link.click(); - } else { - console.error( - "Canvas element for layer2-node is not found or is not a valid HTML canvas element.", - ); - } -} - - - -// aarafat-tag: -//// REFACTOR END - -// logMessagesPanel manager -///-logMessagesPanel Function to append message function -function appendMessage(message) { - // const textarea = document.getElementById('notificationTextarea'); - const textarea = document.getElementById("notificationTextarea"); - - // Get the current date and time - const timestamp = new Date().toLocaleString(); - - textarea.value += `[${timestamp}] ${message}\n`; - textarea.scrollTop = textarea.scrollHeight; -} - -function nodeFindDrawer(cy) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById( - "panelBlock-viewportButtons-buttonfindNode-divPanelBlock-columnContainerlabelFindNodeNodeName-panelContentlabelFindNodeNodeName-columnsPanelContentlabelFindNodeNodeName-labelColumnlabelFindNodeNodeName-inputColumnlabelFindNodeNodeName-labellabelFindNodeNodeName", - ).value; - - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } -} - -function pathFinderDijkstraDrawer(cy) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteSource-panelContentlabelFindRouteSource-columnsPanelContentlabelFindRouteSource-labelColumnlabelFindRouteSource-inputColumnlabelFindRouteSource-labellabelFindRouteSource", - ).value; - const targetNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteTarget-panelContentlabelFindRouteTarget-columnsPanelContentlabelFindRouteTarget-labelColumnlabelFindRouteTarget-inputColumnlabelFindRouteTarget-labellabelFindRouteTarget", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } -} - -// sleep funtion -function sleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); -} \ No newline at end of file diff --git a/dist/html-static/template/clab/clab-cytoscape-export.tmpl b/dist/html-static/template/clab/clab-cytoscape-export.tmpl index 1da6c19a2..48102f9a8 100755 --- a/dist/html-static/template/clab/clab-cytoscape-export.tmpl +++ b/dist/html-static/template/clab/clab-cytoscape-export.tmpl @@ -1,70 +1,57 @@ -[ - {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}}{{end}} - { - "data": { - "index": "{{$c.Index}}", - "id": "{{$c.ShortName}}", - "name": "{{$c.ShortName}}", - "longname": "{{$c.LongName}}", - "fqdn": "{{$c.Fqdn}}", - "clabGroup": "{{$c.Group}}", - "binds": "{{$c.Binds}}", - "labdir": "{{$c.LabDir}}", - "kind": "{{$c.Kind}}", - "image": "{{$c.Image}}", - "mgmt-net": "{{$c.MgmtNet}}", - "mgmt-intf": "{{$c.MgmtIntf}}", - "mgmt-ipv4-address": "{{$c.MgmtIPv4Address}}", - "mgmt-ipv4-prefix-length": {{$c.MgmtIPv4PrefixLength}}, - "mgmt-ipv6-address": "{{$c.MgmtIPv6Address}}", - "mgmt-ipv6-prefix-length": {{$c.MgmtIPv6PrefixLength}}, - "mac-address": "{{$c.MacAddress}}", - "labels": {{ToJSONPretty $c.Labels " " " "}} +{{/* This template support containerlab version: 0.44.3 */}} +{ + "name": "{{ .Name }}", + "type": "{{ .Type }}", + {{ $labName := .Name }} + {{ $type := .Type }} + "clab": { + "config": { + "prefix": "{{ .Clab.Config.Prefix }}", + "mgmt": {{ ToJSONPretty .Clab.Config.Mgmt " " " "}} + } }, - "position": { - "x": 0, - "y": 0 - }, - "removed": false, - "group": "nodes", - "selected": false, - "selectable": true, - "locked": false, - "grabbed": false, - "grabbable": true, - "classes": "" - }, - {{$i = add $i 1}}{{end}} - {{range $i, $l := .Clab.Links}}{{if $i}},{{end}} - { - "data": { - "id": "{{ $l.A.Node.ShortName }}::{{ $l.A.EndpointName }}<-->{{ $l.B.Node.ShortName }}::{{ $l.B.EndpointName }}", - "source": "{{ $l.A.Node.ShortName }}", - "target": "{{ $l.B.Node.ShortName }}", - "weight": "1", - "name": " "{{ $l.A.Node.ShortName }}::{{ $l.A.EndpointName }}<-->{{ $l.B.Node.ShortName }}::{{ $l.B.EndpointName }}", - "parent": "", - "kind": "", - "sourceEndpoint": "{{ $l.A.EndpointName }}", - "targetEndpoint": "{{ $l.B.EndpointName }}", - "sourceMac": "{{ $l.A.MAC }}", - "targetMac": "{{ $l.B.MAC }}", - "endpoint": { - "sourceEndpoint": "{{ $l.A.EndpointName }}", - "targetEndpoint": "{{ $l.B.EndpointName }}" - } - }, - "position": { - "x": 0, - "y": 0 - }, - "removed": false, - "group": "edges", - "selected": false, - "selectable": true, - "locked": false, - "grabbed": false, - "grabbable": true, - "classes": "" - }{{end}} -] \ No newline at end of file +"nodes": [ + {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}},{{end}} + { + "id": "{{$n}}", + "index": "{{$c.Index}}", + "shortname": "{{$c.ShortName}}", + "longname": "{{$c.LongName}}", + "fqdn": "{{$c.Fqdn}}", + "group": "{{$c.Group}}", + "labdir": "{{$c.LabDir}}", + "kind": "{{$c.Kind}}", + "image": "{{$c.Image}}", + "mgmt-net": "{{$c.MgmtNet}}", + "mgmt-intf": "{{$c.MgmtIntf}}", + "mgmt-ipv4-address": "{{$c.MgmtIPv4Address}}", + "mgmt-ipv4-prefix-length": {{$c.MgmtIPv4PrefixLength}}, + "mgmt-ipv6-address": "{{$c.MgmtIPv6Address}}", + "mgmt-ipv6-prefix-length": {{$c.MgmtIPv6PrefixLength}}, + "mac-address": "{{$c.MacAddress}}", + "labels": {{ToJSONPretty $c.Labels " " " "}} + {{$i = add $i 1}}}{{end}} + ], +"links": [{{range $i, $l := .Clab.Links}}{{if $i}},{{end}}{{ $endpointA := index $l.Endpoints 0 }}{{ $endpointB := index $l.Endpoints 1 }}{{ $endpointAList := split (printf "%s" + $endpointA) ":" }}{{ $endpointBList := split (printf "%s" $endpointB) ":" }} + {{- $eps := $l.GetEndpoints }} + {{- $ep := index $eps 0 }} + { + "a": { + "node": "{{ index $endpointAList 0 }}", + "nodeLongName": "{{ $type }}-{{ $labName}}-{{ index $endpointAList 0 }}", + "interface": "{{ $ep.GetIfaceName }}", + "mac": "{{ $ep.GetMac }}", + "peer": "z" + }, + {{- $ep := index $eps 1 }} + "z": { + "node": "{{ index $endpointBList 0 }}", + "nodeLongName": "{{ $type }}-{{ $labName}}-{{ index $endpointBList 0 }}", + "interface": "{{ $ep.GetIfaceName }}", + "mac": "{{ $ep.GetMac }}", + "peer": "a" + } + }{{end}} + ] +} \ No newline at end of file diff --git a/dist/pumba_linux_amd64 b/dist/pumba_linux_amd64 deleted file mode 100755 index e39eeec1e..000000000 Binary files a/dist/pumba_linux_amd64 and /dev/null differ diff --git a/dist/topoviewer b/dist/topoviewer index 3fd6ce822..ebd25931b 100755 --- a/dist/topoviewer +++ b/dist/topoviewer @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:adf75e0d9d39e5699400fe21b6bc7eade7aec632df8452d6ef0ebc7218cbccac -size 77803672 +oid sha256:c6a3d1c90af1895137ad54cbd5347ffa65837e1caee8a167e300fad57af96b4e +size 77795480 diff --git a/go_cloudshellwrapper/cmdClab.go b/go_cloudshellwrapper/cmdClab.go index 1f8f25088..af1a8fd6e 100755 --- a/go_cloudshellwrapper/cmdClab.go +++ b/go_cloudshellwrapper/cmdClab.go @@ -700,6 +700,8 @@ func Clab(_ *cobra.Command, _ []string) error { // get docker status via unix socket x, err := cyTopo.GetDockerNodeStatusViaUnixSocket(n.Longname, clabHost[0]) + //fmt.Print(cyTopo.GetDockerConnectedInterfacesViaUnixSocket("clab-demo-Spine-02", "clab-demo-Leaf-02")) + if err != nil { log.Error(err) return // Return to exit the handler if an error occurs @@ -829,6 +831,33 @@ func Clab(_ *cobra.Command, _ []string) error { }).Methods("GET") + //// API endpoint to get clab-link-mac value + router.HandleFunc("/clab-link-mac", + func(w http.ResponseWriter, r *http.Request) { + // sourceContainer := "clab-demo-Spine-01" + // targetContainer := "clab-demo-Leaf-03" + + query := r.URL.Query() + + queriesList := make([]string, 0) + for _, values := range query { + queriesList = append(queriesList, values...) + } + + log.Info(" { - console.log(`Successfully connected WebSocket to ${url}`); - if (socket.readyState === WebSocket.OPEN) { - socket.send(`Hi From the WebSocketClient-${url}`); - } - }; - - socket.onclose = (event) => { - console.log(`Socket to ${url} closed: `, event); - socket.send("Client Closed!"); - }; - - socket.onerror = (error) => { - console.log(`Socket to ${url} error: `, error); - }; - - socket.onmessage = onMessageCallback; - - return socket; - } - - - // WebSocket for uptime - // WebSocket for uptime - const socketUptime = initializeWebSocket("/uptime", async (msgUptime) => { - environments = await getEnvironments(); - labName = environments["clab-name"] - deploymentType = environments["deploymentType"] - - console.log("initializeWebSocket - getEnvironments", environments) - console.log("initializeWebSocket - labName", environments["clab-name"]) - - const string01 = "Containerlab Topology: " + labName; - const string02 = " ::: Uptime: " + msgUptime.data; - - const ClabSubtitle = document.getElementById("ClabSubtitle"); - const messageBody = string01 + string02; - - ClabSubtitle.innerText = messageBody; - console.log(ClabSubtitle.innerText); - }); - - // WebSocket for ContainerNodeStatus - const socketContainerNodeStatusInitial = initializeWebSocket( - "/containerNodeStatus", - (msgContainerNodeStatus) => { - try { - const { - Names, - Status, - State - } = JSON.parse(msgContainerNodeStatus.data); - setNodeContainerStatus(Names, Status); - console.log(JSON.parse(msgContainerNodeStatus.data)); - - setNodeDataWithContainerAttribute(Names, Status, State); - } catch (error) { - console.error("Error parsing JSON:", error); - } - }, - ); - - //- Instantiate Cytoscape.js - cy = cytoscape({ - container: document.getElementById("cy"), - elements: [], - style: [{ - selector: "node", - style: { - "background-color": "#3498db", - label: "data(label)", - }, - }, ], - }); - - - loadCytoStyle(); - - function loadCytoStyle() { - - // detect light or dark mode - const colorScheme = detectColorScheme(); - console.log('The user prefers:', colorScheme); - - //- Load and apply Cytoscape styles from cy-style.json using fetch - if (colorScheme == "light") { - fetch("css/cy-style.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } else if (colorScheme == "dark") { - fetch("css/cy-style-dark.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } - } - - // Enable grid guide extension - cy.gridGuide({ - // On/Off Modules - - snapToGridOnRelease: true, - snapToGridDuringDrag: false, - snapToAlignmentLocationOnRelease: true, - snapToAlignmentLocationDuringDrag: false, - distributionGuidelines: false, - geometricGuideline: false, - initPosAlignment: false, - centerToEdgeAlignment: false, - resize: false, - parentPadding: false, - drawGrid: false, - - // General - gridSpacing: 10, - snapToGridCenter: true, - - // Draw Grid - zoomDash: true, - panGrid: true, - gridStackOrder: -1, - gridColor: '#dedede', - lineWidth: 1.0, - - // Guidelines - guidelinesStackOrder: 4, - guidelinesTolerance: 2.00, - guidelinesStyle: { - strokeStyle: "#8b7d6b", - geometricGuidelineRange: 400, - range: 100, - minDistRange: 10, - distGuidelineOffset: 10, - horizontalDistColor: "#ff0000", - verticalDistColor: "#00ff00", - initPosAlignmentColor: "#0000ff", - lineDash: [0, 0], - horizontalDistLine: [0, 0], - verticalDistLine: [0, 0], - initPosAlignmentLine: [0, 0], - }, - - // Parent Padding - parentSpacing: -1 - }); - - // Fetch and load element data from a JSON file - // fetch("dataCytoMarshall-" + labName + ".json") - fetch("dataCytoMarshall.json") - - .then((response) => response.json()) - .then((elements) => { - // Add the elements to the Cytoscape instance - // Add the elements to the Cytoscape instance - cy.add(elements); - //- run layout - //- run layout - // const layout = cy.layout({ - // name: "cola", - // nodeGap: 5, - // edgeLength: 100, - // animate: true, - // randomize: false, - // maxSimulationTime: 1500, - // }); - // layout.run(); - - // Dynamically create clusters for CISE layout - // var clustersMap = {}; - // cy.nodes().filter('[parent != "newGroup"]').forEach(function (node) { - // var parent = node.data('parent'); - // if (!clustersMap[parent]) { - // clustersMap[parent] = []; - // } - // clustersMap[parent].push(node.id()); - // }); - // var clusters = Object.values(clustersMap); - - // // Apply CISE layout to existing nodes - // var ciseLayout = cy.layout({ - // name: 'cise', - // clusters: clusters, - // animate: "end", - // padding: 20, - // nodeSeparation: 10, - // idealInterClusterEdgeLengthCoefficient: 1.4, - // allowNodesInsideCircle: false, - // maxRatioOfNodesInsideCircle: 0.1, - // nodeRepulsion: 4500 - // }); - // ciseLayout.run() - // Apply force-directed layout (cose) to new nodes - var coseLayout = cy.layout({ - name: 'cose', - animate: "end", - padding: 20, - nodeOverlap: 10, - idealEdgeLength: 50, - edgeElasticity: 100, - nodeRepulsion: 40, - numIter: 100, - initialTemp: 200, - coolingFactor: 0.95, - gravity: 2.2 - }); - - coseLayout.run(); - - // remove node topoviewer - topoViewerNode = cy.filter('node[name = "topoviewer"]'); - topoViewerNode.remove(); - }) - .catch((error) => { - console.error("Error loading graph data:", error); - }); - - // Instantiate hover text element - const hoverText = document.createElement("box"); - hoverText.classList.add( - "hover-text", - "is-hidden", - "box", - "has-text-weight-normal", - "is-warning", - "is-smallest", - ); - hoverText.textContent = "Launch CloudShell."; - document.body.appendChild(hoverText); - - //- Toggle the Panel(s) when clicking on the cy container - //- Toggle the Panel(s) when clicking on the cy container - document.getElementById("cy").addEventListener("click", function(event) { - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - - loadCytoStyle(); - - if (!nodeClicked && !edgeClicked) { - if (!isPanel01Cy) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - var ViewPortDrawerElements = - document.getElementsByClassName("ViewPortDrawer"); - var ViewPortDrawerArray = Array.from(ViewPortDrawerElements); - ViewPortDrawerArray.forEach(function(element) { - element.style.display = "none"; - }); - - } else { - removeElementById("Panel-01"); - appendMessage(`"try to remove panel01-Cy"`); - } - } - nodeClicked = false; - edgeClicked = false; - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - }); - - // Click event listener for nodes - // Click event listener for nodes - cy.on("click", "node", function(event) { - // This code will be executed when you click on a node - // This code will be executed when you click on a node - const node = event.target; - nodeClicked = true; - - if (!node.isParent()) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - console.log(node) - console.log(node.data("containerDockerExtraAttribute").status) - console.log(node.data("extraData")) - - if (document.getElementById("panel-node").style.display === "none") { - document.getElementById("panel-node").style.display = "block"; - } else { - document.getElementById("panel-node").style.display = "none"; - } - - document.getElementById("panel-node-name").textContent = node.data("extraData").longname - document.getElementById("panel-node-status").textContent = node.data("containerDockerExtraAttribute").status - document.getElementById("panel-node-kind").textContent = node.data("extraData").kind - document.getElementById("panel-node-image").textContent = node.data("extraData").image - document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss - document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn - document.getElementById("panel-node-group").textContent = node.data("extraData").group - document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") - - // set selected node-long-name to global variable - globalSelectedNode = node.data("extraData").longname - console.log("internal: ", globalSelectedNode) - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - } - }); - - // Click event listener for edges - // Click event listener for edges - cy.on("click", "edge", async function(event) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - // This code will be executed when you click on a node - // You can add logic specific to nodes here - const clickedEdge = event.target; - const defaultEdgeColor = "#969799"; - edgeClicked = true; - - console.log(defaultEdgeColor); - - // Change the color of the clicked edge (for example, to red) - clickedEdge.style("line-color", "#0043BF"); - - // Revert the color of other edges that were not clicked (e.g., back to their default color) - cy.edges().forEach(function(edge) { - if (edge !== clickedEdge) { - edge.style("line-color", defaultEdgeColor); - } - }); - - - - - document.getElementById("panel-link").style.display = "none"; - - if (document.getElementById("panel-link").style.display === "none") { - document.getElementById("panel-link").style.display = "block"; - } else { - document.getElementById("panel-link").style.display = "none"; - } - - document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` - - document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` - - document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` - - - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API - clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] - clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) - - if (clabSourceLinkImpairmentClabData && typeof clabSourceLinkImpairmentClabData === 'object' && Object.keys(clabSourceLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabSourceLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabSourceLinkImpairmentClabData returnd data", clabSourceLinkImpairmentClabData["return data"]["delay"]); - - if (clabSourceLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-a-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-delay").value = clabSourceLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-a-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-jitter").value = clabSourceLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-a-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-rate").value = clabSourceLinkImpairmentClabData["return data"]["rate"] - } - - if (clabSourceLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-a-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-loss").value = clabSourceLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // setting default impairment endpoint-b values by getting the data from clab via /clab-link-impairment GET API - clabTargetLinkArgsList = [`${clickedEdge.data("extraData").clabTargetLongName}`,`${clickedEdge.data("extraData").clabTargetPort}`] - clabTargetLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabTargetLinkArgsList) - - if (clabTargetLinkImpairmentClabData && typeof clabTargetLinkImpairmentClabData === 'object' && Object.keys(clabTargetLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabTargetLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabTargetLinkImpairmentClabData returnd data", clabTargetLinkImpairmentClabData["return data"]["delay"]); - - if (clabTargetLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-b-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-delay").value = clabTargetLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-b-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-jitter").value = clabTargetLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-b-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-rate").value = clabTargetLinkImpairmentClabData["return data"]["rate"] - } - - if (clabTargetLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-b-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-loss").value = clabTargetLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // set selected edge-id to global variable - globalSelectedEdge = clickedEdge.data("id") - - appendMessage(`"edgeClicked: " ${edgeClicked}`); - }); - - - - - function generateNodesEvent(event) { - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - console.log("generateNodesButton clicked"); - const numNodes = document.getElementById("generateNodesInput").value; - console.log(numNodes); - //- Check if the number of node is empty - //- Check if the number of node is empty - if (numNodes === null) { - //- if node number empty do nothing - //- if node number empty do nothing - return; - } - const numNodesToGenerate = parseInt(numNodes, 10); - //- Check if the number of node is positive - //- Check if the number of node is positive - if (isNaN(numNodesToGenerate) || numNodesToGenerate <= 0) { - //- Invalid input - //- Invalid input - appendMessage( - "Error:" + "Bro, you gotta enter a valid positive number, come on!", - ); - return; - } - //- Generate nodes with random positions - //- Generate nodes with random positions - for (let i = 0; i < numNodesToGenerate; i++) { - const nodeName = `node-${i + 1}`; - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - }, - position: { - x: Math.random() * 400, - y: Math.random() * 400, - }, - }; - //-cy.add(newNode); - //-cy.add(newNode); - try { - cy.add(newNode); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred:" + error); - } - } - //- Generate random edges between nodes - //- Generate random edges between nodes - for (let i = 0; i < numNodesToGenerate; i++) { - const sourceNode = `node-${i + 1}`; - const targetNode = `node-${Math.floor(Math.random() * numNodesToGenerate) + 1}`; - if (sourceNode !== targetNode) { - const newEdge = { - group: "edges", - data: { - id: "from-" + sourceNode + "-to-" + targetNode, - name: "from-" + sourceNode + "-to-" + targetNode, - source: sourceNode, - target: targetNode, - }, - }; - try { - cy.add(newEdge); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred::" + error); - } - } - } - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //-//- Append a notification message to the textarea - //-//- Append a notification message to the textarea - console.log( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - appendMessage( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - } - - function spawnNodeEvent(event) { - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - const nodeName = document.getElementById("nodeName").value; - console.log(nodeName); - //- Check if a node name is empty - //- Check if a node name is empty - if (nodeName == "") { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Enter node name."); - return; - } - //- Check if a node with the same name already exists - //- Check if a node with the same name already exists - if (cy.$(`node[id = "${nodeName}"]`).length > 0) { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Node with this name already exists."); - return; - } - //- Create a new node element - //- Create a new node element - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - label: nodeName, - }, - }; - //- Add the new node to Cytoscape.js - //- Add the new node to Cytoscape.js - cy.add(newNode); - //- Randomize the positions and center the graph - //- Randomize the positions and center the graph - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //- Append a notification message to the textarea - //- Append a notification message to the textarea - console.log("Info: " + `Nice! Node "${nodeName}" added successfully.`); - appendMessage("Info: " + `Nice! Node "${nodeName}" added successfully.`); - } - - function nodeFindEvent(event) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById("nodeFindInput").value; - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } - } - - function zoomToFitDrawer() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); - } - - function pathFinderDijkstraEvent(event) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "pathFinderSourceNodeInput", - ).value; - const targetNodeId = document.getElementById( - "pathFinderTargetNodeInput", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } - } - - function setNodeContainerStatus(containerNodeName, containerNodeStatus) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - - // Find the corresponding status nodes based on node ID - // Find the corresponding status nodes based on node ID - var statusGreenNode = cy.$(`node[name="${nodeId}-statusGreen"]`); - var statusOrangeNode = cy.$(`node[name="${nodeId}-statusOrange"]`); - var statusRedNode = cy.$(`node[name="${nodeId}-statusRed"]`); - - if (statusGreenNode.length === 0 || statusRedNode.length === 0) { - // If status nodes are not found, skip this node - return; - } - - // Update positions of status nodes relative to the node - var nodePosition = node.position(); - var offset = { - x: -4, - y: -10 - }; - var statusGreenNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - var statusRedNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - - // Check if the nodeContainerStatusVisibility is true - if (nodeContainerStatusVisibility) { - // Check if the containerNodeName includes nodeId and containerNodeStatus includes 'healthy' - if ( - containerNodeName.includes(nodeId) && - (containerNodeStatus.includes("Up") || - containerNodeStatus.includes("healthy")) - ) { - statusGreenNode.show(); - statusRedNode.hide(); - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("(health: starting)") - ) { - statusGreenNode.hide(); - statusOrangeNode.show(); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("Exited") - ) { - statusGreenNode.hide(); - statusRedNode.show(); - } - } else { - statusGreenNode.hide(); - statusRedNode.hide(); - } - - statusGreenNode.position(statusGreenNodePosition); - statusRedNode.position(statusRedNodePosition); - }); - } - - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - if (containerNodeName.includes(nodeId)) { - var containerDockerExtraAttributeData = { - state: state, - status: status, - }; - - node.data( - "containerDockerExtraAttribute", - containerDockerExtraAttributeData, - ); - } - }); - } - - // - // End of JS Functions Event Handling section - // End of JS Functions Event Handling section - // - - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - - - //- Function to get the default node style from cy-style.json - //- Function to get the default node style from cy-style.json - async function getDefaultNodeStyle(node) { - try { - //- Fetch the cy-style.json file - //- Fetch the cy-style.json file - const response = await fetch("cy-style.json"); - //- Check if the response is successful (status code 200) - //- Check if the response is successful (status code 200) - if (!response.ok) { - throw new Error( - `Failed to fetch cy-style.json (${response.status} ${response.statusText})`, - ); - } - //- Parse the JSON response - //- Parse the JSON response - const styleData = await response.json(); - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - const defaultNodeStyle = styleData[0].style; - return defaultNodeStyle; - } catch (error) { - console.error("Error loading cy-style.json:", error); - appendMessage(`Error loading cy-style.json: ${error}`); - //- Return a default style in case of an error - //- Return a default style in case of an error - return { - "background-color": "blue", - "border-color": "gray", - "border-width": "1px", - }; - } - } - - ///-logMessagesPanel Function to add a click event listener to the copy button - ///-logMessagesPanel Function to add a click event listener to the copy button - const copyButton = document.getElementById("copyToClipboardButton"); - copyButton.className = "button is-smallest-element"; - copyButton.addEventListener("click", copyToClipboard); - - /// logMessagesPanel Function to copy textarea content to clipboard - /// logMessagesPanel Function to copy textarea content to clipboard - function copyToClipboard() { - const textarea = document.getElementById("notificationTextarea"); - textarea.select(); - document.execCommand("copy"); - } - - - - // function closePanelEvent(event, panel) { - // panel.style.display = "block"; - // console.log(panel.style.display); - // panel.style.display = "none"; - // } - - function createModal(modalId, modalContent) { - // Create the modal - // Create the modal - const htmlContent = ` - - `; - - const modalDiv = document.createElement("div"); - modalDiv.innerHTML = htmlContent; - modalDiv.id = "modalDivExportViewport"; - - document.body.appendChild(modalDiv); - const modalBackground = document.getElementById( - `${modalId}-modalBackgroundId`, - ); - - modalBackground.addEventListener("click", function() { - const modal = modalBackground.parentNode; - modal.classList.remove("is-active"); - }); - } - - function showModalCaptureViewport(modalId) { - const modalContentSaveViewport = ` - - `; - - // Instantiate modal - // Instantiate modal - createModal("modalSaveViewport", modalContentSaveViewport); - - // create event listener - // create event listener - const performActionButton = document.getElementById("performActionButton"); - performActionButton.addEventListener("click", function() { - const checkboxName = "checkboxSaveViewPort"; - const checkboxes = document.querySelectorAll( - `input[type="checkbox"][name="${checkboxName}"]`, - ); - const selectedOptions = []; - - checkboxes.forEach(function(checkbox) { - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - }); - - // show modal - // show modal - modal = document.getElementById(modalId); - modal.classList.add("is-active"); - } - - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // -}); - -// aarafat-tag: -//// REFACTOR START -//// to-do: -//// - re-create about-panel -//// - re-create log-messages -//// - re-create viewport - -async function initEnv() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - deploymentType = await environments["deployment-type"] - - console.log("Lab-Name: ", labName) - console.log("DeploymentType: ", deploymentType) - return environments, labName - } - -async function changeTitle() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - - console.log("changeTitle() - labName: ", labName) - document.title = `TopoViewer::${labName}`; -} - -async function sshWebBased(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - - console.log("sshWebBased: ", `${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`) - - window.open(`${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`); - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - -async function sshCliCommandCopy(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - clabServerAddress = environments["clab-server-address"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - clabUser = routerData["data"]["extraData"]["clabServerUsername"] - - sshCopyString = `ssh -t ${clabUser}@${clabServerAddress} "ssh admin@${routerName}"` - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(sshCopyString).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = sshCopyString; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - - - -async function linkImpairmentClab(event, impairDirection) { - console.log("linkImpairmentClab - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - var deploymentType = environments["deployment-type"] - var command - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkImpairment- edgeData: ", edgeData) - console.log("linkImpairment- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (impairDirection == "a-to-b") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-a-delay").value - jitterValue = document.getElementById("panel-link-endpoint-a-jitter").value - rateValue = document.getElementById("panel-link-endpoint-a-rate").value - lossValue = document.getElementById("panel-link-endpoint-a-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - - - } else if (impairDirection == "b-to-a") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-b-delay").value - jitterValue = document.getElementById("panel-link-endpoint-b-jitter").value - rateValue = document.getElementById("panel-link-endpoint-b-rate").value - lossValue = document.getElementById("panel-link-endpoint-b-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - - -async function linkWireshark(event, option, endpoint) { - console.log("linkWireshark - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkWireshark - environments: ", environments) - - var deploymentType = environments["deployment-type"] - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkWireshark- edgeData: ", edgeData) - console.log("linkWireshark- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (option == "app") { - if (endpoint == "source") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabSourceLongName}?${clabSourcePort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - - } else if (endpoint == "target") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabTargetLongName}?${clabTargetPort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - } - - window.open(wiresharkHref); - - } else if (option == "copy") { - if (endpoint == "source") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } - } else if (endpoint == "target") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } - } - - console.log("linkWireshark- wiresharkSShCommand: ", wiresharkSshCommand) - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(wiresharkSshCommand).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = wiresharkSshCommand; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - -async function showPanelLogMessages(event) { - document.getElementById("panel-log-messages").style.display = "block"; -} - -///-logMessagesPanel Function to add a click event listener to the close button -document.getElementById("panel-log-messages-close-button").addEventListener("click", () => { - document.getElementById("panel-log-messages").style.display = "none"; -}); - -async function showPanelTopoViewerClient(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - clabServerAddress = environments["clab-server-address"] - clabServerPort = environments["clab-server-port"] - - hrefWindows = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-windows/ClabCapture.app.zip` - hrefMac = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-mac/ClabCapture.app.zip` - - document.getElementById("panel-topoviewer-helper").style.display = "block"; - - const htmlContent = ` -
Wireshark Capture
-

- Please download the following helper app: -

- -

- TopoViewer offers a remote capture feature for intercepting ContainerLab node endpoints. - For the best experience, it's recommended to have both TopoViewer and its helper app installed on client-side. - With the TopoViewer helper app, you can effortlessly automate the launch of Wireshark's GUI. -

-

- Alternatively, if you don't have the helper app, you can simply copy and paste an SSH command to initiate Wireshark manually. - This setup provides flexibility in how you utilize this feature.
-

- `; - document.getElementById("panel-topoviewer-helper-content").innerHTML = htmlContent; -} - -async function showPanelAbout(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - topoViewerVersion = environments["topoviewer-version"] - - document.getElementById("panel-topoviewer-about").style.display = "block"; - - const htmlContent = ` -
-
Version: ${topoViewerVersion}
- -

- Designed and developed by Asad Arafat
-

-

- Special Thanks: -

    -
  • Siva Sivakumar - For pioneering the integration of Bulma CSS, significantly enhancing TopoViewer design and usability.
  • -
  • Gatot Susilo - For seamlessly incorporating TopoViewer into the Komodo2 tool, bridging functionality with innovation.
  • -
  • Gusman Dharma Putra - For his invaluable contribution in integrating TopoViewer into Komodo2, enriching its capabilities.
  • -
  • Sven Wisotzky - For offering insightful feedback that led to significant full stack optimizations.
  • -
-

- - -
- `; - document.getElementById("panel-topoviewer-about-content").innerHTML = htmlContent; -} - -async function sidebarButtonFitScreen(event) { - - // --sidebar-button-background-color-default: rgba(54,58, 69, 1); - // --sidebar-button-background-color-active: rgba(76, 82, 97, 1); - - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - const sidebarButtonColorDefault = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-default'); - const sidebarButtonColorActive = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-active'); - - drawer = document.getElementById("drawer") - if (drawer.style.display === 'block') { - drawer.style.display = 'none'; - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - sidebarButtonFitScreen.style.background = sidebarButtonColorDefault.trim(); - sidebarButtonFitScreen.style.border = sidebarButtonColorActive.trim(); - } else { - drawer.style.display = 'block'; - var sidebarButtons = document.getElementsByClassName("is-sidebar"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < sidebarButtons.length; i++) { - sidebarButtons[i].style.background = sidebarButtonColorDefault.trim(); - sidebarButtons[i].style.border = sidebarButtonColorDefault.trim(); - } - sidebarButtonFitScreen.style.background = sidebarButtonColorActive.trim(); - } - -} - -async function getActualNodesEndpoints(event) { - try { - bulmaToast.toast({ - message: `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - appendMessage( - `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - ); - - showLoadingSpinnerGlobal() - const CyTopoJson = await sendRequestToEndpointGet("/actual-nodes-endpoints", argsList = []) - location.reload(true); - - // Handle the response data - if (CyTopoJson && typeof CyTopoJson === 'object' && Object.keys(CyTopoJson).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", CyTopoJson); - - hideLoadingSpinnerGlobal(); - - - - return CyTopoJson - - } else { - - hideLoadingSpinnerGlobal(); - - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - hideLoadingSpinnerGlobal(); - console.error("Error occurred:", error); - // Handle errors as needed - } -} - -function viewportButtonsZoomToFit() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); -} - -function viewportButtonsLayoutAlgo() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - viewportDrawerLayout = document.getElementById("viewport-drawer-layout") - viewportDrawerLayout.style.display = "block" -} - - - - -async function layoutAlgoChange(event) { - - try { - console.log("layoutAlgoChange clicked"); - - var selectElement = document.getElementById("select-layout-algo"); - var selectedOption = selectElement.value; - - if (selectedOption === "Force Directed") { - console.log("Force Directed algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-force-directed") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-force-directed-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-force-directed")) - console.log(document.getElementById("viewport-drawer-force-directed-reset-start")) - - } else if (selectedOption === "Vertical") { - console.log("Vertical algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-vertical") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-vertical-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-vertical")) - console.log(document.getElementById("viewport-drawer-dc-vertical-reset-start")) - - } else if (selectedOption === "Horizontal") { - console.log("Horizontal algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-horizontal") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-horizontal-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-horizontal")) - console.log(document.getElementById("viewport-drawer-dc-horizontal-reset-start")) - } - - }catch (error) { - console.error("Error occurred:", error); - // Handle errors as needed - } -} - - -function viewportButtonsTopologyOverview() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyOverview clicked") - viewportDrawerLayout = document.getElementById("viewport-drawer-topology-overview") - viewportDrawerLayout.style.display = "block" - - viewportDrawerLayoutContent = document.getElementById("viewport-drawer-topology-overview-content") - viewportDrawerLayoutContent.style.display = "block" -} - -function viewportButtonsTopologyCapture() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyCapture clicked") - - viewportDrawerCapture = document.getElementById("viewport-drawer-capture-sceenshoot") - viewportDrawerCapture.style.display = "block" - - viewportDrawerCaptureContent = document.getElementById("viewport-drawer-capture-sceenshoot-content") - viewportDrawerCaptureContent.style.display = "block" -} - -function viewportButtonsLabelEndpoint() { - if (linkEndpointVisibility) { - cy.edges().forEach(function(edge) { - // edge.style("source-label", "."); - // edge.style("target-label", "."); - edge.style("text-opacity", 0); - edge.style("text-background-opacity", 0); - - - linkEndpointVisibility = false; - }); - } else { - cy.edges().forEach(function(edge) { - edge.style("text-opacity", 1); - edge.style("text-background-opacity", 0.7); - linkEndpointVisibility = true; - }); - } -} - -function viewportButtonContainerStatusVisibility() { - if (nodeContainerStatusVisibility) { - nodeContainerStatusVisibility = false; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `Alright, mission control, we're standing down. 🛑🔍 Container status probing aborted. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - nodeContainerStatusVisibility = true; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `🕵️‍♂️ Bro, we're currently on a mission to probe that container status! Stay tuned for the results. 🔍🚀👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } -} - - -function viewportDrawerLayoutForceDirected() { - edgeLengthSlider = document.getElementById("force-directed-slider-link-lenght"); - nodeGapSlider = document.getElementById("force-directed-slider-node-gap"); - - const edgeLengthValue = parseFloat(edgeLengthSlider.value); - const nodeGapValue = parseFloat(nodeGapSlider.value); - - console.log("edgeLengthValue", edgeLengthValue); - console.log("nodeGapValue", nodeGapValue); - - cy.layout( - { - fit: true, - name: "cola", - animate: true, - randomize: false, - maxSimulationTime: 400, - edgeLength: function(e) { - return edgeLengthValue / e.data("weight"); - }, - nodeGap: function(e) { - return nodeGapValue / e.data("weight"); - }, - }) - .run(); -} - -function viewportDrawerLayoutVertical() { - nodevGap = document.getElementById("vertical-layout-slider-node-v-gap"); - groupvGap = document.getElementById("vertical-layout-slider-group-v-gap"); - - const nodevGapValue = parseFloat(nodevGap.value); - const groupvGapValue = parseFloat(groupvGap.value); - - console.log("nodevGapValue", nodevGapValue); - console.log("groupvGapValue", groupvGapValue); - - const xOffset = parseFloat(nodevGapValue); - const yOffset = parseFloat(groupvGapValue); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numRows = 1; - - const cellWidth = node.width() / children.length; - // const xOffset = 5 - - children.forEach(function(child, index) { - // Position children in rows - const xPos = index * (cellWidth + xOffset); - const yPos = 0; - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxWidth = 0; - var centerX = 0; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const width = node.width(); - if (width > maxWidth) { - maxWidth = width; - console.log("ParentMaxWidth: ", maxWidth); - } - } - }); - - const divisionFactor = maxWidth / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let yPos = 0; - // const yOffset = 50; - // const yOffset = 50; - - // Position parent nodes vertically and center them horizontally - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const xPos = centerX - parent.width() / divisionFactor; - // to the left compared to the center of the widest parent node. - parent.position({ - x: xPos, - y: yPos - }); - yPos += yOffset; - }); - cy.fit(); - }, delay); -} - -function viewportDrawerLayoutHorizontal() { - nodehGap = document.getElementById("horizontal-layout-slider-node-h-gap"); - grouphGap = document.getElementById("horizontal-layout-slider-group-h-gap"); - - const horizontalNodeGap = parseFloat(nodehGap.value); - const horizontalGroupGap = parseFloat(grouphGap.value); - - console.log("nodevGapValue", horizontalNodeGap); - console.log("groupvGapValue", horizontalGroupGap); - - const yOffset = parseFloat(horizontalNodeGap); - const xOffset = parseFloat(horizontalGroupGap); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numColumns = 1; - const cellHeight = node.height() / children.length; - // const yOffset = 5; - - children.forEach(function(child, index) { - // Position children in columns - const xPos = 0; - const yPos = index * (cellHeight + yOffset); - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxHeight = 0; - var centerX = cy.width() / 2; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const height = node.height(); - if (height > maxHeight) { - maxHeight = height; - console.log("ParentMaxHeight: ", maxHeight); - } - } - }); - - const divisionFactor = maxHeight / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let xPos = 0; - // const xOffset = 50; - - // Position parent nodes horizontally and center them vertically - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const yPos = centerY - parent.height() / divisionFactor; - parent.position({ - x: xPos, - y: yPos - }); - xPos -= xOffset; - }); - - cy.fit(); - }, delay); - -} - - -function viewportDrawerCaptureButton() { - - console.log ("viewportDrawerCaptureButton() - clicked") - - - - - // Get all checkbox inputs within the specific div - const checkboxes = document.querySelectorAll('#viewport-drawer-capture-sceenshoot-content .checkbox-input'); - - // Initialize an array to store the values of checked checkboxes - const selectedOptions = []; - - // Iterate through the NodeList of checkboxes - checkboxes.forEach((checkbox) => { - // If the checkbox is checked, push its value to the array - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - console.log ("viewportDrawerCaptureButton() - ", selectedOptions) - - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - -} - -async function captureAndSaveViewportAsDrawIo(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - const drawIoWidht = canvasElement.width / 10; - const drawIoHeight = canvasElement.height / 10; - const drawIoaAspectRatio = drawIoWidht / drawIoHeight; - - const mxGraphHeader = ` - - - `; - - const mxGraphFooter = ` - `; - - const mxCells = []; - - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - function createMxCellForNode(node, imageURL) { - if (node.isParent()) { - return ` - - - `; - } else if ( - !node.data("id").includes("statusGreen") && - !node.data("id").includes("statusRed") - ) { - return ` - - - `; - } - } - - cy.nodes().forEach(function(node) { - let imageURL; - switch (node.data("topoViewerRole")) { - case "pe": - imageURL = `http://${location.host}/images/clab-pe-light-blue.png`; - break; - case "controller": - imageURL = - `http://${location.host}/images/clab-controller-light-blue.png`; - break; - case "pon": - imageURL = `http://${location.host}/images/clab-pon-dark-blue.png`; - break; - case "dcgw": - imageURL = `http://${location.host}/images/clab-dcgw-dark-blue.png`; - break; - case "leaf": - imageURL = `http://${location.host}/images/clab-leaf-light-blue.png`; - break; - case "spine": - imageURL = `http://${location.host}/images/clab-spine-dark-blue.png`; - break; - case "super-spine": - imageURL = `http://${location.host}/images/clab-spine-light-blue.png`; - break; - } - mxCells.push(createMxCellForNode(node, imageURL)); - }); - - cy.edges().forEach(function(edge) { - mxCells.push(` - - - - - - - - - - - - - - `); - }); - - // Combine all parts and create XML - const mxGraphXML = mxGraphHeader + mxCells.join("") + mxGraphFooter; - - // Create a Blob from the XML - const blob = new Blob([mxGraphXML], { - type: "application/xml", - }); - - // Create a URL for the Blob - const url = window.URL.createObjectURL(blob); - - // Create a download link and trigger a click event - const a = document.createElement("a"); - a.style.display = "none"; - a.href = url; - a.download = "filename.drawio"; - document.body.appendChild(a); - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - a.click(); - - // Clean up by revoking the URL and removing the download link - window.URL.revokeObjectURL(url); - document.body.removeChild(a); -} -async function captureAndSaveViewportAsPng(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - - const zoomScaleFactor = 1; - - // Check if the canvas element exists and is an HTMLCanvasElement - // Check if the canvas element exists and is an HTMLCanvasElement - if (canvasElement instanceof HTMLCanvasElement) { - // Calculate the new canvas dimensions based on the high resolution factor - // Calculate the new canvas dimensions based on the high resolution factor - const newWidth = canvasElement.width * zoomScaleFactor; - const newHeight = canvasElement.height * zoomScaleFactor; - - // Create a new canvas element with the increased dimensions - // Create a new canvas element with the increased dimensions - const newCanvas = document.createElement("canvas"); - newCanvas.width = newWidth; - newCanvas.height = newHeight; - const newCanvasContext = newCanvas.getContext("2d"); - - // Scale the canvas content to the new dimensions - // Scale the canvas content to the new dimensions - newCanvasContext.scale(zoomScaleFactor, zoomScaleFactor); - - // Fill the new canvas with a white background - // Fill the new canvas with a white background - newCanvasContext.fillStyle = "white"; - newCanvasContext.fillRect(0, 0, newWidth, newHeight); - - // Draw the original canvas content on the new canvas - // Draw the original canvas content on the new canvas - newCanvasContext.drawImage(canvasElement, 0, 0); - - // Convert the new canvas to a data URL with a white background - // Convert the new canvas to a data URL with a white background - const dataUrl = newCanvas.toDataURL("image/png"); - - // Create an anchor element to trigger the download - // Create an anchor element to trigger the download - const link = document.createElement("a"); - link.href = dataUrl; - link.download = "cytoscape-viewport.png"; - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - // Simulate a click to trigger the download - link.click(); - } else { - console.error( - "Canvas element for layer2-node is not found or is not a valid HTML canvas element.", - ); - } -} - - - -// aarafat-tag: -//// REFACTOR END - -// logMessagesPanel manager -///-logMessagesPanel Function to append message function -function appendMessage(message) { - // const textarea = document.getElementById('notificationTextarea'); - const textarea = document.getElementById("notificationTextarea"); - - // Get the current date and time - const timestamp = new Date().toLocaleString(); - - textarea.value += `[${timestamp}] ${message}\n`; - textarea.scrollTop = textarea.scrollHeight; -} - -function nodeFindDrawer(cy) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById( - "panelBlock-viewportButtons-buttonfindNode-divPanelBlock-columnContainerlabelFindNodeNodeName-panelContentlabelFindNodeNodeName-columnsPanelContentlabelFindNodeNodeName-labelColumnlabelFindNodeNodeName-inputColumnlabelFindNodeNodeName-labellabelFindNodeNodeName", - ).value; - - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } -} - -function pathFinderDijkstraDrawer(cy) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteSource-panelContentlabelFindRouteSource-columnsPanelContentlabelFindRouteSource-labelColumnlabelFindRouteSource-inputColumnlabelFindRouteSource-labellabelFindRouteSource", - ).value; - const targetNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteTarget-panelContentlabelFindRouteTarget-columnsPanelContentlabelFindRouteTarget-labelColumnlabelFindRouteTarget-inputColumnlabelFindRouteTarget-labellabelFindRouteTarget", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } -} - -// sleep funtion -function sleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); -} \ No newline at end of file diff --git a/html-static/js/index.js b/html-static/js/index.js index 8e598e014..727434d77 100644 --- a/html-static/js/index.js +++ b/html-static/js/index.js @@ -84,7 +84,19 @@ document.addEventListener("DOMContentLoaded", async function() { setNodeContainerStatus(Names, Status); console.log(JSON.parse(msgContainerNodeStatus.data)); - setNodeDataWithContainerAttribute(Names, Status, State); + const IPAddress = JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.IPAddress; + const GlobalIPv6Address= JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.GlobalIPv6Address + + // console.log("IPAddress: ",JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.IPAddress); + // console.log("IPPrefixLen: ",JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.IPPrefixLen); + + // console.log("GlobalIPv6Address: ",JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.GlobalIPv6Address); + // console.log("GlobalIPv6PrefixLen: ",JSON.parse(msgContainerNodeStatus.data).Networks.Networks.clab.GlobalIPv6PrefixLen); + + + + setNodeDataWithContainerAttribute(Names, Status, State, IPAddress, GlobalIPv6Address); + } catch (error) { console.error("Error parsing JSON:", error); } @@ -319,7 +331,7 @@ document.addEventListener("DOMContentLoaded", async function() { document.getElementById("panel-node-kind").textContent = node.data("extraData").kind document.getElementById("panel-node-image").textContent = node.data("extraData").image document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss + document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Address document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn document.getElementById("panel-node-group").textContent = node.data("extraData").group document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") @@ -366,6 +378,8 @@ document.addEventListener("DOMContentLoaded", async function() { + + document.getElementById("panel-link").style.display = "none"; if (document.getElementById("panel-link").style.display === "none") { @@ -377,12 +391,27 @@ document.addEventListener("DOMContentLoaded", async function() { document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` + // document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` + document.getElementById("panel-link-endpoint-a-mac-address").textContent = "getting the MAC address" document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` + // document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` + document.getElementById("panel-link-endpoint-b-mac-address").textContent = "getting the MAC address" + + + // setting clabSourceLinkArgsList + clabLinkMacArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabTargetLongName}`] + + // setting MAC address endpoint-a values by getting the data from clab via /clab-link-mac GET API + const actualLinkMacPair = await sendRequestToEndpointGetV2("/clab-link-mac", clabLinkMacArgsList) + console.log("actualLinkMacPair-Source: ", actualLinkMacPair[0].sourceIfMac) + console.log("actualLinkMacPair-Target: ", actualLinkMacPair[0].targetIfMac) + + document.getElementById("panel-link-endpoint-a-mac-address").textContent = actualLinkMacPair[0].sourceIfMac + document.getElementById("panel-link-endpoint-b-mac-address").textContent = actualLinkMacPair[0].targetIfMac + + - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) @@ -929,7 +958,7 @@ document.addEventListener("DOMContentLoaded", async function() { }); } - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { + function setNodeDataWithContainerAttribute(containerNodeName, status, state, IPAddress, GlobalIPv6Address) { cy.nodes().forEach(function(node) { var nodeId = node.data("id"); if (containerNodeName.includes(nodeId)) { @@ -942,6 +971,9 @@ document.addEventListener("DOMContentLoaded", async function() { "containerDockerExtraAttribute", containerDockerExtraAttributeData, ); + node.data("extraData").mgmtIpv4Addresss = IPAddress; + node.data("extraData").mgmtIpv6Address = GlobalIPv6Address; + } }); } diff --git a/html-static/js/index.js.bak b/html-static/js/index.js.bak deleted file mode 100644 index 8e598e014..000000000 --- a/html-static/js/index.js.bak +++ /dev/null @@ -1,2402 +0,0 @@ -// Initialize a state variable to track the element's presence -var isPanel01Cy = false; -var nodeClicked = false; -var edgeClicked = false; - -var cy - -var globalSelectedNode -var globalSelectedEdge - -var linkEndpointVisibility = true; -var nodeContainerStatusVisibility = false; - - -var globalShellUrl = "/js/cloudshell" - -var labName -var deploymentType - -document.addEventListener("DOMContentLoaded", async function() { - - detectColorScheme() - - await changeTitle() - - - // Reusable function to initialize a WebSocket connection - function initializeWebSocket(url, onMessageCallback) { - const protocol = location.protocol === "https:" ? "wss://" : "ws://"; - const socket = new WebSocket(protocol + location.host + url); - - socket.onopen = () => { - console.log(`Successfully connected WebSocket to ${url}`); - if (socket.readyState === WebSocket.OPEN) { - socket.send(`Hi From the WebSocketClient-${url}`); - } - }; - - socket.onclose = (event) => { - console.log(`Socket to ${url} closed: `, event); - socket.send("Client Closed!"); - }; - - socket.onerror = (error) => { - console.log(`Socket to ${url} error: `, error); - }; - - socket.onmessage = onMessageCallback; - - return socket; - } - - - // WebSocket for uptime - // WebSocket for uptime - const socketUptime = initializeWebSocket("/uptime", async (msgUptime) => { - environments = await getEnvironments(); - labName = environments["clab-name"] - deploymentType = environments["deploymentType"] - - console.log("initializeWebSocket - getEnvironments", environments) - console.log("initializeWebSocket - labName", environments["clab-name"]) - - const string01 = "Containerlab Topology: " + labName; - const string02 = " ::: Uptime: " + msgUptime.data; - - const ClabSubtitle = document.getElementById("ClabSubtitle"); - const messageBody = string01 + string02; - - ClabSubtitle.innerText = messageBody; - console.log(ClabSubtitle.innerText); - }); - - // WebSocket for ContainerNodeStatus - const socketContainerNodeStatusInitial = initializeWebSocket( - "/containerNodeStatus", - (msgContainerNodeStatus) => { - try { - const { - Names, - Status, - State - } = JSON.parse(msgContainerNodeStatus.data); - setNodeContainerStatus(Names, Status); - console.log(JSON.parse(msgContainerNodeStatus.data)); - - setNodeDataWithContainerAttribute(Names, Status, State); - } catch (error) { - console.error("Error parsing JSON:", error); - } - }, - ); - - //- Instantiate Cytoscape.js - cy = cytoscape({ - container: document.getElementById("cy"), - elements: [], - style: [{ - selector: "node", - style: { - "background-color": "#3498db", - label: "data(label)", - }, - }, ], - }); - - - loadCytoStyle(); - - function loadCytoStyle() { - - // detect light or dark mode - const colorScheme = detectColorScheme(); - console.log('The user prefers:', colorScheme); - - //- Load and apply Cytoscape styles from cy-style.json using fetch - if (colorScheme == "light") { - fetch("css/cy-style.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } else if (colorScheme == "dark") { - fetch("css/cy-style-dark.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } - } - - // Enable grid guide extension - cy.gridGuide({ - // On/Off Modules - - snapToGridOnRelease: true, - snapToGridDuringDrag: false, - snapToAlignmentLocationOnRelease: true, - snapToAlignmentLocationDuringDrag: false, - distributionGuidelines: false, - geometricGuideline: false, - initPosAlignment: false, - centerToEdgeAlignment: false, - resize: false, - parentPadding: false, - drawGrid: false, - - // General - gridSpacing: 10, - snapToGridCenter: true, - - // Draw Grid - zoomDash: true, - panGrid: true, - gridStackOrder: -1, - gridColor: '#dedede', - lineWidth: 1.0, - - // Guidelines - guidelinesStackOrder: 4, - guidelinesTolerance: 2.00, - guidelinesStyle: { - strokeStyle: "#8b7d6b", - geometricGuidelineRange: 400, - range: 100, - minDistRange: 10, - distGuidelineOffset: 10, - horizontalDistColor: "#ff0000", - verticalDistColor: "#00ff00", - initPosAlignmentColor: "#0000ff", - lineDash: [0, 0], - horizontalDistLine: [0, 0], - verticalDistLine: [0, 0], - initPosAlignmentLine: [0, 0], - }, - - // Parent Padding - parentSpacing: -1 - }); - - // Fetch and load element data from a JSON file - // fetch("dataCytoMarshall-" + labName + ".json") - fetch("dataCytoMarshall.json") - - .then((response) => response.json()) - .then((elements) => { - // Add the elements to the Cytoscape instance - // Add the elements to the Cytoscape instance - cy.add(elements); - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLength: 100, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - - // remove node topoviewer - topoViewerNode = cy.filter('node[name = "topoviewer"]'); - topoViewerNode.remove(); - }) - .catch((error) => { - console.error("Error loading graph data:", error); - }); - - // Instantiate hover text element - const hoverText = document.createElement("box"); - hoverText.classList.add( - "hover-text", - "is-hidden", - "box", - "has-text-weight-normal", - "is-warning", - "is-smallest", - ); - hoverText.textContent = "Launch CloudShell."; - document.body.appendChild(hoverText); - - //- Toggle the Panel(s) when clicking on the cy container - //- Toggle the Panel(s) when clicking on the cy container - document.getElementById("cy").addEventListener("click", function(event) { - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - - loadCytoStyle(); - - if (!nodeClicked && !edgeClicked) { - if (!isPanel01Cy) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - var ViewPortDrawerElements = - document.getElementsByClassName("ViewPortDrawer"); - var ViewPortDrawerArray = Array.from(ViewPortDrawerElements); - ViewPortDrawerArray.forEach(function(element) { - element.style.display = "none"; - }); - - } else { - removeElementById("Panel-01"); - appendMessage(`"try to remove panel01-Cy"`); - } - } - nodeClicked = false; - edgeClicked = false; - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - }); - - // Click event listener for nodes - // Click event listener for nodes - cy.on("click", "node", function(event) { - // This code will be executed when you click on a node - // This code will be executed when you click on a node - const node = event.target; - nodeClicked = true; - - if (!node.isParent()) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - console.log(node) - console.log(node.data("containerDockerExtraAttribute").status) - console.log(node.data("extraData")) - - if (document.getElementById("panel-node").style.display === "none") { - document.getElementById("panel-node").style.display = "block"; - } else { - document.getElementById("panel-node").style.display = "none"; - } - - document.getElementById("panel-node-name").textContent = node.data("extraData").longname - document.getElementById("panel-node-status").textContent = node.data("containerDockerExtraAttribute").status - document.getElementById("panel-node-kind").textContent = node.data("extraData").kind - document.getElementById("panel-node-image").textContent = node.data("extraData").image - document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss - document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn - document.getElementById("panel-node-group").textContent = node.data("extraData").group - document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") - - // set selected node-long-name to global variable - globalSelectedNode = node.data("extraData").longname - console.log("internal: ", globalSelectedNode) - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - } - }); - - // Click event listener for edges - // Click event listener for edges - cy.on("click", "edge", async function(event) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - // This code will be executed when you click on a node - // You can add logic specific to nodes here - const clickedEdge = event.target; - const defaultEdgeColor = "#969799"; - edgeClicked = true; - - console.log(defaultEdgeColor); - - // Change the color of the clicked edge (for example, to red) - clickedEdge.style("line-color", "#0043BF"); - - // Revert the color of other edges that were not clicked (e.g., back to their default color) - cy.edges().forEach(function(edge) { - if (edge !== clickedEdge) { - edge.style("line-color", defaultEdgeColor); - } - }); - - - - - document.getElementById("panel-link").style.display = "none"; - - if (document.getElementById("panel-link").style.display === "none") { - document.getElementById("panel-link").style.display = "block"; - } else { - document.getElementById("panel-link").style.display = "none"; - } - - document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` - - document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` - - document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` - - - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API - clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] - clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) - - if (clabSourceLinkImpairmentClabData && typeof clabSourceLinkImpairmentClabData === 'object' && Object.keys(clabSourceLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabSourceLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabSourceLinkImpairmentClabData returnd data", clabSourceLinkImpairmentClabData["return data"]["delay"]); - - if (clabSourceLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-a-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-delay").value = clabSourceLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-a-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-jitter").value = clabSourceLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-a-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-rate").value = clabSourceLinkImpairmentClabData["return data"]["rate"] - } - - if (clabSourceLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-a-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-loss").value = clabSourceLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // setting default impairment endpoint-b values by getting the data from clab via /clab-link-impairment GET API - clabTargetLinkArgsList = [`${clickedEdge.data("extraData").clabTargetLongName}`,`${clickedEdge.data("extraData").clabTargetPort}`] - clabTargetLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabTargetLinkArgsList) - - if (clabTargetLinkImpairmentClabData && typeof clabTargetLinkImpairmentClabData === 'object' && Object.keys(clabTargetLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabTargetLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabTargetLinkImpairmentClabData returnd data", clabTargetLinkImpairmentClabData["return data"]["delay"]); - - if (clabTargetLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-b-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-delay").value = clabTargetLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-b-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-jitter").value = clabTargetLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-b-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-rate").value = clabTargetLinkImpairmentClabData["return data"]["rate"] - } - - if (clabTargetLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-b-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-loss").value = clabTargetLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // set selected edge-id to global variable - globalSelectedEdge = clickedEdge.data("id") - - appendMessage(`"edgeClicked: " ${edgeClicked}`); - }); - - - - - function generateNodesEvent(event) { - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - console.log("generateNodesButton clicked"); - const numNodes = document.getElementById("generateNodesInput").value; - console.log(numNodes); - //- Check if the number of node is empty - //- Check if the number of node is empty - if (numNodes === null) { - //- if node number empty do nothing - //- if node number empty do nothing - return; - } - const numNodesToGenerate = parseInt(numNodes, 10); - //- Check if the number of node is positive - //- Check if the number of node is positive - if (isNaN(numNodesToGenerate) || numNodesToGenerate <= 0) { - //- Invalid input - //- Invalid input - appendMessage( - "Error:" + "Bro, you gotta enter a valid positive number, come on!", - ); - return; - } - //- Generate nodes with random positions - //- Generate nodes with random positions - for (let i = 0; i < numNodesToGenerate; i++) { - const nodeName = `node-${i + 1}`; - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - }, - position: { - x: Math.random() * 400, - y: Math.random() * 400, - }, - }; - //-cy.add(newNode); - //-cy.add(newNode); - try { - cy.add(newNode); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred:" + error); - } - } - //- Generate random edges between nodes - //- Generate random edges between nodes - for (let i = 0; i < numNodesToGenerate; i++) { - const sourceNode = `node-${i + 1}`; - const targetNode = `node-${Math.floor(Math.random() * numNodesToGenerate) + 1}`; - if (sourceNode !== targetNode) { - const newEdge = { - group: "edges", - data: { - id: "from-" + sourceNode + "-to-" + targetNode, - name: "from-" + sourceNode + "-to-" + targetNode, - source: sourceNode, - target: targetNode, - }, - }; - try { - cy.add(newEdge); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred::" + error); - } - } - } - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //-//- Append a notification message to the textarea - //-//- Append a notification message to the textarea - console.log( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - appendMessage( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - } - - function spawnNodeEvent(event) { - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - const nodeName = document.getElementById("nodeName").value; - console.log(nodeName); - //- Check if a node name is empty - //- Check if a node name is empty - if (nodeName == "") { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Enter node name."); - return; - } - //- Check if a node with the same name already exists - //- Check if a node with the same name already exists - if (cy.$(`node[id = "${nodeName}"]`).length > 0) { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Node with this name already exists."); - return; - } - //- Create a new node element - //- Create a new node element - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - label: nodeName, - }, - }; - //- Add the new node to Cytoscape.js - //- Add the new node to Cytoscape.js - cy.add(newNode); - //- Randomize the positions and center the graph - //- Randomize the positions and center the graph - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //- Append a notification message to the textarea - //- Append a notification message to the textarea - console.log("Info: " + `Nice! Node "${nodeName}" added successfully.`); - appendMessage("Info: " + `Nice! Node "${nodeName}" added successfully.`); - } - - function nodeFindEvent(event) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById("nodeFindInput").value; - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } - } - - function zoomToFitDrawer() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); - } - - function pathFinderDijkstraEvent(event) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "pathFinderSourceNodeInput", - ).value; - const targetNodeId = document.getElementById( - "pathFinderTargetNodeInput", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } - } - - function setNodeContainerStatus(containerNodeName, containerNodeStatus) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - - // Find the corresponding status nodes based on node ID - // Find the corresponding status nodes based on node ID - var statusGreenNode = cy.$(`node[name="${nodeId}-statusGreen"]`); - var statusOrangeNode = cy.$(`node[name="${nodeId}-statusOrange"]`); - var statusRedNode = cy.$(`node[name="${nodeId}-statusRed"]`); - - if (statusGreenNode.length === 0 || statusRedNode.length === 0) { - // If status nodes are not found, skip this node - return; - } - - // Update positions of status nodes relative to the node - var nodePosition = node.position(); - var offset = { - x: -4, - y: -10 - }; - var statusGreenNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - var statusRedNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - - // Check if the nodeContainerStatusVisibility is true - if (nodeContainerStatusVisibility) { - // Check if the containerNodeName includes nodeId and containerNodeStatus includes 'healthy' - if ( - containerNodeName.includes(nodeId) && - (containerNodeStatus.includes("Up") || - containerNodeStatus.includes("healthy")) - ) { - statusGreenNode.show(); - statusRedNode.hide(); - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("(health: starting)") - ) { - statusGreenNode.hide(); - statusOrangeNode.show(); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("Exited") - ) { - statusGreenNode.hide(); - statusRedNode.show(); - } - } else { - statusGreenNode.hide(); - statusRedNode.hide(); - } - - statusGreenNode.position(statusGreenNodePosition); - statusRedNode.position(statusRedNodePosition); - }); - } - - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - if (containerNodeName.includes(nodeId)) { - var containerDockerExtraAttributeData = { - state: state, - status: status, - }; - - node.data( - "containerDockerExtraAttribute", - containerDockerExtraAttributeData, - ); - } - }); - } - - // - // End of JS Functions Event Handling section - // End of JS Functions Event Handling section - // - - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - - - //- Function to get the default node style from cy-style.json - //- Function to get the default node style from cy-style.json - async function getDefaultNodeStyle(node) { - try { - //- Fetch the cy-style.json file - //- Fetch the cy-style.json file - const response = await fetch("cy-style.json"); - //- Check if the response is successful (status code 200) - //- Check if the response is successful (status code 200) - if (!response.ok) { - throw new Error( - `Failed to fetch cy-style.json (${response.status} ${response.statusText})`, - ); - } - //- Parse the JSON response - //- Parse the JSON response - const styleData = await response.json(); - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - const defaultNodeStyle = styleData[0].style; - return defaultNodeStyle; - } catch (error) { - console.error("Error loading cy-style.json:", error); - appendMessage(`Error loading cy-style.json: ${error}`); - //- Return a default style in case of an error - //- Return a default style in case of an error - return { - "background-color": "blue", - "border-color": "gray", - "border-width": "1px", - }; - } - } - - ///-logMessagesPanel Function to add a click event listener to the copy button - ///-logMessagesPanel Function to add a click event listener to the copy button - const copyButton = document.getElementById("copyToClipboardButton"); - copyButton.className = "button is-smallest-element"; - copyButton.addEventListener("click", copyToClipboard); - - /// logMessagesPanel Function to copy textarea content to clipboard - /// logMessagesPanel Function to copy textarea content to clipboard - function copyToClipboard() { - const textarea = document.getElementById("notificationTextarea"); - textarea.select(); - document.execCommand("copy"); - } - - - - // function closePanelEvent(event, panel) { - // panel.style.display = "block"; - // console.log(panel.style.display); - // panel.style.display = "none"; - // } - - function createModal(modalId, modalContent) { - // Create the modal - // Create the modal - const htmlContent = ` - - `; - - const modalDiv = document.createElement("div"); - modalDiv.innerHTML = htmlContent; - modalDiv.id = "modalDivExportViewport"; - - document.body.appendChild(modalDiv); - const modalBackground = document.getElementById( - `${modalId}-modalBackgroundId`, - ); - - modalBackground.addEventListener("click", function() { - const modal = modalBackground.parentNode; - modal.classList.remove("is-active"); - }); - } - - function showModalCaptureViewport(modalId) { - const modalContentSaveViewport = ` - - `; - - // Instantiate modal - // Instantiate modal - createModal("modalSaveViewport", modalContentSaveViewport); - - // create event listener - // create event listener - const performActionButton = document.getElementById("performActionButton"); - performActionButton.addEventListener("click", function() { - const checkboxName = "checkboxSaveViewPort"; - const checkboxes = document.querySelectorAll( - `input[type="checkbox"][name="${checkboxName}"]`, - ); - const selectedOptions = []; - - checkboxes.forEach(function(checkbox) { - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - }); - - // show modal - // show modal - modal = document.getElementById(modalId); - modal.classList.add("is-active"); - } - - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // -}); - -// aarafat-tag: -//// REFACTOR START -//// to-do: -//// - re-create about-panel -//// - re-create log-messages -//// - re-create viewport - -async function initEnv() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - deploymentType = await environments["deployment-type"] - - console.log("Lab-Name: ", labName) - console.log("DeploymentType: ", deploymentType) - return environments, labName - } - -async function changeTitle() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - - console.log("changeTitle() - labName: ", labName) - document.title = `TopoViewer::${labName}`; -} - -async function sshWebBased(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - - console.log("sshWebBased: ", `${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`) - - window.open(`${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`); - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - -async function sshCliCommandCopy(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - clabServerAddress = environments["clab-server-address"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - clabUser = routerData["data"]["extraData"]["clabServerUsername"] - - sshCopyString = `ssh -t ${clabUser}@${clabServerAddress} "ssh admin@${routerName}"` - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(sshCopyString).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = sshCopyString; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - - - -async function linkImpairmentClab(event, impairDirection) { - console.log("linkImpairmentClab - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - var deploymentType = environments["deployment-type"] - var command - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkImpairment- edgeData: ", edgeData) - console.log("linkImpairment- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (impairDirection == "a-to-b") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-a-delay").value - jitterValue = document.getElementById("panel-link-endpoint-a-jitter").value - rateValue = document.getElementById("panel-link-endpoint-a-rate").value - lossValue = document.getElementById("panel-link-endpoint-a-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - - - } else if (impairDirection == "b-to-a") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-b-delay").value - jitterValue = document.getElementById("panel-link-endpoint-b-jitter").value - rateValue = document.getElementById("panel-link-endpoint-b-rate").value - lossValue = document.getElementById("panel-link-endpoint-b-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - - -async function linkWireshark(event, option, endpoint) { - console.log("linkWireshark - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkWireshark - environments: ", environments) - - var deploymentType = environments["deployment-type"] - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkWireshark- edgeData: ", edgeData) - console.log("linkWireshark- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (option == "app") { - if (endpoint == "source") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabSourceLongName}?${clabSourcePort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - - } else if (endpoint == "target") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabTargetLongName}?${clabTargetPort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - } - - window.open(wiresharkHref); - - } else if (option == "copy") { - if (endpoint == "source") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } - } else if (endpoint == "target") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } - } - - console.log("linkWireshark- wiresharkSShCommand: ", wiresharkSshCommand) - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(wiresharkSshCommand).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = wiresharkSshCommand; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - -async function showPanelLogMessages(event) { - document.getElementById("panel-log-messages").style.display = "block"; -} - -///-logMessagesPanel Function to add a click event listener to the close button -document.getElementById("panel-log-messages-close-button").addEventListener("click", () => { - document.getElementById("panel-log-messages").style.display = "none"; -}); - -async function showPanelTopoViewerClient(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - clabServerAddress = environments["clab-server-address"] - clabServerPort = environments["clab-server-port"] - - hrefWindows = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-windows/ClabCapture.app.zip` - hrefMac = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-mac/ClabCapture.app.zip` - - document.getElementById("panel-topoviewer-helper").style.display = "block"; - - const htmlContent = ` -
Wireshark Capture
-

- Please download the following helper app: -

- -

- TopoViewer offers a remote capture feature for intercepting ContainerLab node endpoints. - For the best experience, it's recommended to have both TopoViewer and its helper app installed on client-side. - With the TopoViewer helper app, you can effortlessly automate the launch of Wireshark's GUI. -

-

- Alternatively, if you don't have the helper app, you can simply copy and paste an SSH command to initiate Wireshark manually. - This setup provides flexibility in how you utilize this feature.
-

- `; - document.getElementById("panel-topoviewer-helper-content").innerHTML = htmlContent; -} - -async function showPanelAbout(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - topoViewerVersion = environments["topoviewer-version"] - - document.getElementById("panel-topoviewer-about").style.display = "block"; - - const htmlContent = ` -
-
Version: ${topoViewerVersion}
- -

- Designed and developed by Asad Arafat
-

-

- Special Thanks: -

    -
  • Siva Sivakumar - For pioneering the integration of Bulma CSS, significantly enhancing TopoViewer design and usability.
  • -
  • Gatot Susilo - For seamlessly incorporating TopoViewer into the Komodo2 tool, bridging functionality with innovation.
  • -
  • Gusman Dharma Putra - For his invaluable contribution in integrating TopoViewer into Komodo2, enriching its capabilities.
  • -
  • Sven Wisotzky - For offering insightful feedback that led to significant full stack optimizations.
  • -
-

- - -
- `; - document.getElementById("panel-topoviewer-about-content").innerHTML = htmlContent; -} - -async function sidebarButtonFitScreen(event) { - - // --sidebar-button-background-color-default: rgba(54,58, 69, 1); - // --sidebar-button-background-color-active: rgba(76, 82, 97, 1); - - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - const sidebarButtonColorDefault = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-default'); - const sidebarButtonColorActive = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-active'); - - drawer = document.getElementById("drawer") - if (drawer.style.display === 'block') { - drawer.style.display = 'none'; - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - sidebarButtonFitScreen.style.background = sidebarButtonColorDefault.trim(); - sidebarButtonFitScreen.style.border = sidebarButtonColorActive.trim(); - } else { - drawer.style.display = 'block'; - var sidebarButtons = document.getElementsByClassName("is-sidebar"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < sidebarButtons.length; i++) { - sidebarButtons[i].style.background = sidebarButtonColorDefault.trim(); - sidebarButtons[i].style.border = sidebarButtonColorDefault.trim(); - } - sidebarButtonFitScreen.style.background = sidebarButtonColorActive.trim(); - } - -} - -async function getActualNodesEndpoints(event) { - try { - bulmaToast.toast({ - message: `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - appendMessage( - `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - ); - - showLoadingSpinnerGlobal() - const CyTopoJson = await sendRequestToEndpointGet("/actual-nodes-endpoints", argsList = []) - location.reload(true); - - // Handle the response data - if (CyTopoJson && typeof CyTopoJson === 'object' && Object.keys(CyTopoJson).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", CyTopoJson); - - hideLoadingSpinnerGlobal(); - - - - return CyTopoJson - - } else { - - hideLoadingSpinnerGlobal(); - - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - hideLoadingSpinnerGlobal(); - console.error("Error occurred:", error); - // Handle errors as needed - } -} - -function viewportButtonsZoomToFit() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); -} - -function viewportButtonsLayoutAlgo() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - viewportDrawerLayout = document.getElementById("viewport-drawer-layout") - viewportDrawerLayout.style.display = "block" -} - - - - -async function layoutAlgoChange(event) { - - try { - console.log("layoutAlgoChange clicked"); - - var selectElement = document.getElementById("select-layout-algo"); - var selectedOption = selectElement.value; - - if (selectedOption === "Force Directed") { - console.log("Force Directed algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-force-directed") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-force-directed-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-force-directed")) - console.log(document.getElementById("viewport-drawer-force-directed-reset-start")) - - } else if (selectedOption === "Vertical") { - console.log("Vertical algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-vertical") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-vertical-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-vertical")) - console.log(document.getElementById("viewport-drawer-dc-vertical-reset-start")) - - } else if (selectedOption === "Horizontal") { - console.log("Horizontal algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-horizontal") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-horizontal-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-horizontal")) - console.log(document.getElementById("viewport-drawer-dc-horizontal-reset-start")) - } - - }catch (error) { - console.error("Error occurred:", error); - // Handle errors as needed - } -} - - -function viewportButtonsTopologyOverview() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyOverview clicked") - viewportDrawerLayout = document.getElementById("viewport-drawer-topology-overview") - viewportDrawerLayout.style.display = "block" - - viewportDrawerLayoutContent = document.getElementById("viewport-drawer-topology-overview-content") - viewportDrawerLayoutContent.style.display = "block" -} - -function viewportButtonsTopologyCapture() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyCapture clicked") - - viewportDrawerCapture = document.getElementById("viewport-drawer-capture-sceenshoot") - viewportDrawerCapture.style.display = "block" - - viewportDrawerCaptureContent = document.getElementById("viewport-drawer-capture-sceenshoot-content") - viewportDrawerCaptureContent.style.display = "block" -} - -function viewportButtonsLabelEndpoint() { - if (linkEndpointVisibility) { - cy.edges().forEach(function(edge) { - // edge.style("source-label", "."); - // edge.style("target-label", "."); - edge.style("text-opacity", 0); - edge.style("text-background-opacity", 0); - - - linkEndpointVisibility = false; - }); - } else { - cy.edges().forEach(function(edge) { - edge.style("text-opacity", 1); - edge.style("text-background-opacity", 0.7); - linkEndpointVisibility = true; - }); - } -} - -function viewportButtonContainerStatusVisibility() { - if (nodeContainerStatusVisibility) { - nodeContainerStatusVisibility = false; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `Alright, mission control, we're standing down. 🛑🔍 Container status probing aborted. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - nodeContainerStatusVisibility = true; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `🕵️‍♂️ Bro, we're currently on a mission to probe that container status! Stay tuned for the results. 🔍🚀👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } -} - - -function viewportDrawerLayoutForceDirected() { - edgeLengthSlider = document.getElementById("force-directed-slider-link-lenght"); - nodeGapSlider = document.getElementById("force-directed-slider-node-gap"); - - const edgeLengthValue = parseFloat(edgeLengthSlider.value); - const nodeGapValue = parseFloat(nodeGapSlider.value); - - console.log("edgeLengthValue", edgeLengthValue); - console.log("nodeGapValue", nodeGapValue); - - cy.layout( - { - fit: true, - name: "cola", - animate: true, - randomize: false, - maxSimulationTime: 400, - edgeLength: function(e) { - return edgeLengthValue / e.data("weight"); - }, - nodeGap: function(e) { - return nodeGapValue / e.data("weight"); - }, - }) - .run(); -} - -function viewportDrawerLayoutVertical() { - nodevGap = document.getElementById("vertical-layout-slider-node-v-gap"); - groupvGap = document.getElementById("vertical-layout-slider-group-v-gap"); - - const nodevGapValue = parseFloat(nodevGap.value); - const groupvGapValue = parseFloat(groupvGap.value); - - console.log("nodevGapValue", nodevGapValue); - console.log("groupvGapValue", groupvGapValue); - - const xOffset = parseFloat(nodevGapValue); - const yOffset = parseFloat(groupvGapValue); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numRows = 1; - - const cellWidth = node.width() / children.length; - // const xOffset = 5 - - children.forEach(function(child, index) { - // Position children in rows - const xPos = index * (cellWidth + xOffset); - const yPos = 0; - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxWidth = 0; - var centerX = 0; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const width = node.width(); - if (width > maxWidth) { - maxWidth = width; - console.log("ParentMaxWidth: ", maxWidth); - } - } - }); - - const divisionFactor = maxWidth / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let yPos = 0; - // const yOffset = 50; - // const yOffset = 50; - - // Position parent nodes vertically and center them horizontally - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const xPos = centerX - parent.width() / divisionFactor; - // to the left compared to the center of the widest parent node. - parent.position({ - x: xPos, - y: yPos - }); - yPos += yOffset; - }); - cy.fit(); - }, delay); -} - -function viewportDrawerLayoutHorizontal() { - nodehGap = document.getElementById("horizontal-layout-slider-node-h-gap"); - grouphGap = document.getElementById("horizontal-layout-slider-group-h-gap"); - - const horizontalNodeGap = parseFloat(nodehGap.value); - const horizontalGroupGap = parseFloat(grouphGap.value); - - console.log("nodevGapValue", horizontalNodeGap); - console.log("groupvGapValue", horizontalGroupGap); - - const yOffset = parseFloat(horizontalNodeGap); - const xOffset = parseFloat(horizontalGroupGap); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numColumns = 1; - const cellHeight = node.height() / children.length; - // const yOffset = 5; - - children.forEach(function(child, index) { - // Position children in columns - const xPos = 0; - const yPos = index * (cellHeight + yOffset); - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxHeight = 0; - var centerX = cy.width() / 2; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const height = node.height(); - if (height > maxHeight) { - maxHeight = height; - console.log("ParentMaxHeight: ", maxHeight); - } - } - }); - - const divisionFactor = maxHeight / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let xPos = 0; - // const xOffset = 50; - - // Position parent nodes horizontally and center them vertically - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const yPos = centerY - parent.height() / divisionFactor; - parent.position({ - x: xPos, - y: yPos - }); - xPos -= xOffset; - }); - - cy.fit(); - }, delay); - -} - - -function viewportDrawerCaptureButton() { - - console.log ("viewportDrawerCaptureButton() - clicked") - - - - - // Get all checkbox inputs within the specific div - const checkboxes = document.querySelectorAll('#viewport-drawer-capture-sceenshoot-content .checkbox-input'); - - // Initialize an array to store the values of checked checkboxes - const selectedOptions = []; - - // Iterate through the NodeList of checkboxes - checkboxes.forEach((checkbox) => { - // If the checkbox is checked, push its value to the array - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - console.log ("viewportDrawerCaptureButton() - ", selectedOptions) - - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - -} - -async function captureAndSaveViewportAsDrawIo(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - const drawIoWidht = canvasElement.width / 10; - const drawIoHeight = canvasElement.height / 10; - const drawIoaAspectRatio = drawIoWidht / drawIoHeight; - - const mxGraphHeader = ` - - - `; - - const mxGraphFooter = ` - `; - - const mxCells = []; - - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - function createMxCellForNode(node, imageURL) { - if (node.isParent()) { - return ` - - - `; - } else if ( - !node.data("id").includes("statusGreen") && - !node.data("id").includes("statusRed") - ) { - return ` - - - `; - } - } - - cy.nodes().forEach(function(node) { - let imageURL; - switch (node.data("topoViewerRole")) { - case "pe": - imageURL = `http://${location.host}/images/clab-pe-light-blue.png`; - break; - case "controller": - imageURL = - `http://${location.host}/images/clab-controller-light-blue.png`; - break; - case "pon": - imageURL = `http://${location.host}/images/clab-pon-dark-blue.png`; - break; - case "dcgw": - imageURL = `http://${location.host}/images/clab-dcgw-dark-blue.png`; - break; - case "leaf": - imageURL = `http://${location.host}/images/clab-leaf-light-blue.png`; - break; - case "spine": - imageURL = `http://${location.host}/images/clab-spine-dark-blue.png`; - break; - case "super-spine": - imageURL = `http://${location.host}/images/clab-spine-light-blue.png`; - break; - } - mxCells.push(createMxCellForNode(node, imageURL)); - }); - - cy.edges().forEach(function(edge) { - mxCells.push(` - - - - - - - - - - - - - - `); - }); - - // Combine all parts and create XML - const mxGraphXML = mxGraphHeader + mxCells.join("") + mxGraphFooter; - - // Create a Blob from the XML - const blob = new Blob([mxGraphXML], { - type: "application/xml", - }); - - // Create a URL for the Blob - const url = window.URL.createObjectURL(blob); - - // Create a download link and trigger a click event - const a = document.createElement("a"); - a.style.display = "none"; - a.href = url; - a.download = "filename.drawio"; - document.body.appendChild(a); - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - a.click(); - - // Clean up by revoking the URL and removing the download link - window.URL.revokeObjectURL(url); - document.body.removeChild(a); -} -async function captureAndSaveViewportAsPng(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - - const zoomScaleFactor = 1; - - // Check if the canvas element exists and is an HTMLCanvasElement - // Check if the canvas element exists and is an HTMLCanvasElement - if (canvasElement instanceof HTMLCanvasElement) { - // Calculate the new canvas dimensions based on the high resolution factor - // Calculate the new canvas dimensions based on the high resolution factor - const newWidth = canvasElement.width * zoomScaleFactor; - const newHeight = canvasElement.height * zoomScaleFactor; - - // Create a new canvas element with the increased dimensions - // Create a new canvas element with the increased dimensions - const newCanvas = document.createElement("canvas"); - newCanvas.width = newWidth; - newCanvas.height = newHeight; - const newCanvasContext = newCanvas.getContext("2d"); - - // Scale the canvas content to the new dimensions - // Scale the canvas content to the new dimensions - newCanvasContext.scale(zoomScaleFactor, zoomScaleFactor); - - // Fill the new canvas with a white background - // Fill the new canvas with a white background - newCanvasContext.fillStyle = "white"; - newCanvasContext.fillRect(0, 0, newWidth, newHeight); - - // Draw the original canvas content on the new canvas - // Draw the original canvas content on the new canvas - newCanvasContext.drawImage(canvasElement, 0, 0); - - // Convert the new canvas to a data URL with a white background - // Convert the new canvas to a data URL with a white background - const dataUrl = newCanvas.toDataURL("image/png"); - - // Create an anchor element to trigger the download - // Create an anchor element to trigger the download - const link = document.createElement("a"); - link.href = dataUrl; - link.download = "cytoscape-viewport.png"; - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - // Simulate a click to trigger the download - link.click(); - } else { - console.error( - "Canvas element for layer2-node is not found or is not a valid HTML canvas element.", - ); - } -} - - - -// aarafat-tag: -//// REFACTOR END - -// logMessagesPanel manager -///-logMessagesPanel Function to append message function -function appendMessage(message) { - // const textarea = document.getElementById('notificationTextarea'); - const textarea = document.getElementById("notificationTextarea"); - - // Get the current date and time - const timestamp = new Date().toLocaleString(); - - textarea.value += `[${timestamp}] ${message}\n`; - textarea.scrollTop = textarea.scrollHeight; -} - -function nodeFindDrawer(cy) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById( - "panelBlock-viewportButtons-buttonfindNode-divPanelBlock-columnContainerlabelFindNodeNodeName-panelContentlabelFindNodeNodeName-columnsPanelContentlabelFindNodeNodeName-labelColumnlabelFindNodeNodeName-inputColumnlabelFindNodeNodeName-labellabelFindNodeNodeName", - ).value; - - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } -} - -function pathFinderDijkstraDrawer(cy) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteSource-panelContentlabelFindRouteSource-columnsPanelContentlabelFindRouteSource-labelColumnlabelFindRouteSource-inputColumnlabelFindRouteSource-labellabelFindRouteSource", - ).value; - const targetNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteTarget-panelContentlabelFindRouteTarget-columnsPanelContentlabelFindRouteTarget-labelColumnlabelFindRouteTarget-inputColumnlabelFindRouteTarget-labellabelFindRouteTarget", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } -} - -// sleep funtion -function sleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); -} \ No newline at end of file diff --git a/html-static/template/clab/clab-cytoscape-export.tmpl b/html-static/template/clab/clab-cytoscape-export.tmpl index 1da6c19a2..48102f9a8 100755 --- a/html-static/template/clab/clab-cytoscape-export.tmpl +++ b/html-static/template/clab/clab-cytoscape-export.tmpl @@ -1,70 +1,57 @@ -[ - {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}}{{end}} - { - "data": { - "index": "{{$c.Index}}", - "id": "{{$c.ShortName}}", - "name": "{{$c.ShortName}}", - "longname": "{{$c.LongName}}", - "fqdn": "{{$c.Fqdn}}", - "clabGroup": "{{$c.Group}}", - "binds": "{{$c.Binds}}", - "labdir": "{{$c.LabDir}}", - "kind": "{{$c.Kind}}", - "image": "{{$c.Image}}", - "mgmt-net": "{{$c.MgmtNet}}", - "mgmt-intf": "{{$c.MgmtIntf}}", - "mgmt-ipv4-address": "{{$c.MgmtIPv4Address}}", - "mgmt-ipv4-prefix-length": {{$c.MgmtIPv4PrefixLength}}, - "mgmt-ipv6-address": "{{$c.MgmtIPv6Address}}", - "mgmt-ipv6-prefix-length": {{$c.MgmtIPv6PrefixLength}}, - "mac-address": "{{$c.MacAddress}}", - "labels": {{ToJSONPretty $c.Labels " " " "}} +{{/* This template support containerlab version: 0.44.3 */}} +{ + "name": "{{ .Name }}", + "type": "{{ .Type }}", + {{ $labName := .Name }} + {{ $type := .Type }} + "clab": { + "config": { + "prefix": "{{ .Clab.Config.Prefix }}", + "mgmt": {{ ToJSONPretty .Clab.Config.Mgmt " " " "}} + } }, - "position": { - "x": 0, - "y": 0 - }, - "removed": false, - "group": "nodes", - "selected": false, - "selectable": true, - "locked": false, - "grabbed": false, - "grabbable": true, - "classes": "" - }, - {{$i = add $i 1}}{{end}} - {{range $i, $l := .Clab.Links}}{{if $i}},{{end}} - { - "data": { - "id": "{{ $l.A.Node.ShortName }}::{{ $l.A.EndpointName }}<-->{{ $l.B.Node.ShortName }}::{{ $l.B.EndpointName }}", - "source": "{{ $l.A.Node.ShortName }}", - "target": "{{ $l.B.Node.ShortName }}", - "weight": "1", - "name": " "{{ $l.A.Node.ShortName }}::{{ $l.A.EndpointName }}<-->{{ $l.B.Node.ShortName }}::{{ $l.B.EndpointName }}", - "parent": "", - "kind": "", - "sourceEndpoint": "{{ $l.A.EndpointName }}", - "targetEndpoint": "{{ $l.B.EndpointName }}", - "sourceMac": "{{ $l.A.MAC }}", - "targetMac": "{{ $l.B.MAC }}", - "endpoint": { - "sourceEndpoint": "{{ $l.A.EndpointName }}", - "targetEndpoint": "{{ $l.B.EndpointName }}" - } - }, - "position": { - "x": 0, - "y": 0 - }, - "removed": false, - "group": "edges", - "selected": false, - "selectable": true, - "locked": false, - "grabbed": false, - "grabbable": true, - "classes": "" - }{{end}} -] \ No newline at end of file +"nodes": [ + {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}},{{end}} + { + "id": "{{$n}}", + "index": "{{$c.Index}}", + "shortname": "{{$c.ShortName}}", + "longname": "{{$c.LongName}}", + "fqdn": "{{$c.Fqdn}}", + "group": "{{$c.Group}}", + "labdir": "{{$c.LabDir}}", + "kind": "{{$c.Kind}}", + "image": "{{$c.Image}}", + "mgmt-net": "{{$c.MgmtNet}}", + "mgmt-intf": "{{$c.MgmtIntf}}", + "mgmt-ipv4-address": "{{$c.MgmtIPv4Address}}", + "mgmt-ipv4-prefix-length": {{$c.MgmtIPv4PrefixLength}}, + "mgmt-ipv6-address": "{{$c.MgmtIPv6Address}}", + "mgmt-ipv6-prefix-length": {{$c.MgmtIPv6PrefixLength}}, + "mac-address": "{{$c.MacAddress}}", + "labels": {{ToJSONPretty $c.Labels " " " "}} + {{$i = add $i 1}}}{{end}} + ], +"links": [{{range $i, $l := .Clab.Links}}{{if $i}},{{end}}{{ $endpointA := index $l.Endpoints 0 }}{{ $endpointB := index $l.Endpoints 1 }}{{ $endpointAList := split (printf "%s" + $endpointA) ":" }}{{ $endpointBList := split (printf "%s" $endpointB) ":" }} + {{- $eps := $l.GetEndpoints }} + {{- $ep := index $eps 0 }} + { + "a": { + "node": "{{ index $endpointAList 0 }}", + "nodeLongName": "{{ $type }}-{{ $labName}}-{{ index $endpointAList 0 }}", + "interface": "{{ $ep.GetIfaceName }}", + "mac": "{{ $ep.GetMac }}", + "peer": "z" + }, + {{- $ep := index $eps 1 }} + "z": { + "node": "{{ index $endpointBList 0 }}", + "nodeLongName": "{{ $type }}-{{ $labName}}-{{ index $endpointBList 0 }}", + "interface": "{{ $ep.GetIfaceName }}", + "mac": "{{ $ep.GetMac }}", + "peer": "a" + } + }{{end}} + ] +} \ No newline at end of file diff --git a/rawTopoFile/.topo-clab-demo.yaml.bak b/rawTopoFile/.topo-clab-demo.yaml.bak deleted file mode 100644 index ef7da5491..000000000 --- a/rawTopoFile/.topo-clab-demo.yaml.bak +++ /dev/null @@ -1,163 +0,0 @@ -name: demo - -topology: - nodes: - - - topoviewer: - kind: linux - image: ghcr.io/asadarafat/topoviewer:nightly-24.10.26c - ports: - - 8088:8088 - startup-delay: 5 - binds: - - /var/run/docker.sock:/var/run/docker.sock:ro - # - __clabDir__/topology-data.json:/opt/topoviewer/local-bind/topo-file.json:ro - - - topo-clab-demo.yaml:/opt/topoviewer/local-bind/topo-clab-demo.yaml:ro - - entrypoint.sh:/opt/topoviewer/local-bind/entrypoint.sh:ro - # - entrypoint.sh:/opt/topoviewer/entrypoint.sh:ro - - ### __clabDir__/topology-data.json is path to clab's json file which generated by "clab --export-template" and /opt/topoviewer/local-bind/topo-file.json is the mount path of topoviever's topology file. - # - ../dist/topoviewer:/opt/topoviewer/topoviewer:ro - ### This is to access docker.sock from topoviewer container - - env: - ALLOWED_HOSTNAME: "nsp-clab1.nice.nokia.net" - CLAB_USER: "asad" - CLAB_PASS: "Lab-Her0" - SERVER_PORT: "8088" - CLAB_TOPO_YAML: "topo-clab-demo.yaml" - - ### These are the environment variables for topoviewer container - - labels: - topoviewer-role: controller - - # exec: - # - '/opt/topoviewer/entrypoint.sh' - ### This is the entrypoint script of topoviewer container - - - Spine-01: - kind: srl - image: ghcr.io/nokia/srlinux - binds: - - ./topo-clab-demo.yaml:/opt/topo-file.yaml:ro - group: "Data Center Spine" - labels: - topoViewer-role: spine - - - Spine-02: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Spine" - labels: - topoViewer-role: spine - - # Borderl-Leaf-01: - # kind: srl - # image: ghcr.io/nokia/srlinux - # group: "Data Center Leaf" - # labels: - # topoViewer-role: leaf - - # Borderl-Leaf-02: - # kind: srl - # image: ghcr.io/nokia/srlinux - # group: "Data Center Leaf" - # labels: - # topoViewer-role: leaf - - Leaf-01: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Leaf" - labels: - topoViewer-role: leaf - - Leaf-02: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Leaf" - labels: - topoViewer-role: leaf - - Leaf-03: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Leaf" - labels: - topoViewer-role: leaf - - Leaf-04: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Leaf" - labels: - topoViewer-role: leaf - - # PE-01: - # kind: vr-sros - # image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - # type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - # license: license.txt - # group: "Back Bone" - # labels: - # topoViewer-role: pe - - # PE-02: - # kind: vr-sros - # image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - # type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - # license: license.txt - # group: "Back Bone" - # labels: - # topoViewer-role: pe - - # DCGW-03: - # kind: vr-sros - # image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - # type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - # license: license.txt - # group: "Data Center - DCGW" - # labels: - # topoViewer-role: dcgw - - # DCGW-04: - # kind: vr-sros - # image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - # type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - # license: license.txt - # group: "Data Center - DCGW" - # labels: - # topoViewer-role: dcgw - - links: - - # - endpoints: ["PE-01:eth2", "PE-02:eth2"] - # - endpoints: ["PE-01:eth3", "DCGW-03:eth3"] - - # - endpoints: ["PE-02:eth4", "DCGW-03:eth4"] - # - endpoints: ["PE-02:eth5", "DCGW-04:eth5"] - - # - endpoints: ["PE-01:eth4", "DCGW-04:eth4"] - - # - endpoints: ["DCGW-03:eth1", "Borderl-Leaf-01:e1-1"] - # - endpoints: ["DCGW-04:eth1", "Borderl-Leaf-02:e1-1"] - - # - endpoints: ["Spine-01:e1-5", "Borderl-Leaf-01:e1-5"] - # - endpoints: ["Spine-02:e1-5", "Borderl-Leaf-02:e1-5"] - - - endpoints: ["Spine-01:e1-1", "Leaf-01:e1-1"] - - endpoints: ["Spine-01:e1-2", "Leaf-02:e1-1"] - - endpoints: ["Spine-01:e1-3", "Leaf-03:e1-3"] - - endpoints: ["Spine-01:e1-4", "Leaf-04:e1-3"] - - - endpoints: ["Spine-02:e1-1", "Leaf-01:e1-2"] - - endpoints: ["Spine-02:e1-2", "Leaf-02:e1-2"] - - endpoints: ["Spine-02:e1-3", "Leaf-03:e1-4"] - - endpoints: ["Spine-02:e1-4", "Leaf-04:e1-4"] - - diff --git a/rawTopoFile/.topoViewerDemo.yaml.bak b/rawTopoFile/.topoViewerDemo.yaml.bak deleted file mode 100755 index 0f7020b9f..000000000 --- a/rawTopoFile/.topoViewerDemo.yaml.bak +++ /dev/null @@ -1,154 +0,0 @@ -name: topoViewerDemo - -mgmt: - ipv4-subnet: 20.20.20.0/24 # ipv4 range - -topology: - # defaults: - # env: - # topoFilePath: /home/suuser/clab/topo-topoViewerDemo.yml - - nodes: - topoviewer: - kind: linux - image: ghcr.io/asadarafat/topoviewer:development - ports: - - 8080:8080 - exec: - - /opt/topoviewer/topoviewer clab -H 138.203.26.59 -j local-bind/topo-file.yaml -u root & - # "138.203.26.59" is the server IP where clab is running - # "root" is the ContainerLab host user name - entrypoint: /bin/bash - binds: - - /root/topoViewer/rawTopoFile/clab-topoViewerDemo/topology-data.json:/opt/topoviewer/local-bind/topo-file.yaml:rw - # There is caveat on this bind, the directory and file (/root/topoViewer/rawTopoFile/clab-topoViewerDemo/topology-data.json) should be exist be for clab deploy executed. - # otherwise the clab deploy will be failed. - - - #topoviewer: - # role: dcgw / spine / leaf / workload / pe / agg / core - # color: default-mapping based on role.. red / black / green - # mapping the icon based on role - - Spine-01: - kind: srl - mgmt-ipv4: 20.20.20.201 - image: ghcr.io/nokia/srlinux - labels: - topo-viewer-role: spine - - - Spine-02: - kind: srl - mgmt-ipv4: 20.20.20.202 - image: ghcr.io/nokia/srlinux - labels: - topo-viewer-role: spine - - Borderl-Leaf-01: - kind: srl - mgmt-ipv4: 20.20.20.211 - image: ghcr.io/nokia/srlinux - labels: - topo-viewer-role: leaf - - Borderl-Leaf-02: - kind: srl - mgmt-ipv4: 20.20.20.212 - image: ghcr.io/nokia/srlinux - labels: - topo-viewer-role: leaf - - Leaf-01: - kind: srl - mgmt-ipv4: 20.20.20.221 - image: ghcr.io/nokia/srlinux - labels: - topo-viewer-role: leaf - - Leaf-02: - kind: srl - mgmt-ipv4: 20.20.20.222 - image: ghcr.io/nokia/srlinux - labels: - topo-viewer-role: leaf - - Leaf-03: - kind: srl - mgmt-ipv4: 20.20.20.223 - image: ghcr.io/nokia/srlinux - labels: - topo-viewer-role: leaf - - Leaf-04: - kind: srl - mgmt-ipv4: 20.20.20.224 - image: ghcr.io/nokia/srlinux - labels: - topo-viewer-role: leaf - - PE-01: - kind: vr-sros - mgmt-ipv4: 20.20.20.101 - group: "1" - image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - license: clab/license.txt - labels: - topo-viewer-role: pe - - PE-02: - kind: vr-sros - mgmt-ipv4: 20.20.20.102 - group: "1" - image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - license: clab/license.txt - labels: - topo-viewer-role: pe - - DCGW-03: - kind: vr-sros - mgmt-ipv4: 20.20.20.103 - group: "1" - image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - license: clab/license.txt - labels: - topo-viewer-role: dcgw - - DCGW-04: - kind: vr-sros - mgmt-ipv4: 20.20.20.104 - group: "1" - image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - license: clab/license.txt - labels: - topo-viewer-role: dcgw - - links: - - - endpoints: ["PE-01:eth2", "PE-02:eth2"] - - endpoints: ["PE-01:eth3", "DCGW-03:eth3"] - - - endpoints: ["PE-02:eth4", "DCGW-03:eth4"] - - endpoints: ["PE-02:eth5", "DCGW-04:eth5"] - - - endpoints: ["PE-01:eth4", "DCGW-04:eth4"] - - - endpoints: ["DCGW-03:eth1", "Borderl-Leaf-01:e1-1"] - - endpoints: ["DCGW-04:eth1", "Borderl-Leaf-02:e1-1"] - - - endpoints: ["Spine-01:e1-5", "Borderl-Leaf-01:e1-5"] - - endpoints: ["Spine-02:e1-5", "Borderl-Leaf-02:e1-5"] - - - endpoints: ["Spine-01:e1-1", "Leaf-01:e1-1"] - - endpoints: ["Spine-01:e1-2", "Leaf-02:e1-1"] - - endpoints: ["Spine-01:e1-3", "Leaf-03:e1-3"] - - endpoints: ["Spine-01:e1-4", "Leaf-04:e1-3"] - - - endpoints: ["Spine-02:e1-1", "Leaf-01:e1-2"] - - endpoints: ["Spine-02:e1-2", "Leaf-02:e1-2"] - - endpoints: ["Spine-02:e1-3", "Leaf-03:e1-4"] - - endpoints: ["Spine-02:e1-4", "Leaf-04:e1-4"] diff --git a/rawTopoFile/topoviewer/local-bind/topo-file.yaml b/rawTopoFile/clab-demo.yaml similarity index 82% rename from rawTopoFile/topoviewer/local-bind/topo-file.yaml rename to rawTopoFile/clab-demo.yaml index 740d3e47a..daa76c141 100644 --- a/rawTopoFile/topoviewer/local-bind/topo-file.yaml +++ b/rawTopoFile/clab-demo.yaml @@ -2,48 +2,34 @@ name: demo topology: nodes: - - topoviewer: kind: linux - image: ghcr.io/asadarafat/topoviewer:nightly-24.10.26b + image: ghcr.io/asadarafat/topoviewer:nightly-24.10.27a ports: - 8088:8088 startup-delay: 5 binds: - /var/run/docker.sock:/var/run/docker.sock:ro - ### This is to access docker.sock from topoviewer container - - __clabDir__/topology-data.json:/opt/topoviewer/local-bind/topo-file.json:ro - ### __clabDir__/topology-data.json is path to clab's json file which generated by "clab --export-template" and /opt/topoviewer/local-bind/topo-file.json is the mount path of topoviever's topology file. - # - ../dist/topoviewer:/opt/topoviewer/topoviewer:ro - - ./topo-clab-demo.yaml:/opt/topoviewer/local-bind/topo-file.yaml:ro - - entrypoint.sh:/opt/topoviewer/local-bind/entrypoint.sh:ro - - entrypoint.sh:/opt/topoviewer/entrypoint.sh:ro - - - - - + - clab-demo.yaml:/opt/topoviewer/local-bind/clab-demo.yaml:ro env: + ### These are the environment variables for topoviewer container ALLOWED_HOSTNAME: "nsp-clab1.nice.nokia.net" CLAB_USER: "asad" CLAB_PASS: "Lab-Her0" SERVER_PORT: "8088" - ### These are the environment variables for topoviewer container - + CLAB_TOPO_YAML: "clab-demo.yaml" labels: topoviewer-role: controller - - # exec: - # - '/opt/topoviewer/entrypoint.sh' - - - ### This is the entrypoint script of topoviewer container + exec: + ## This is the entrypoint script of topoviewer container + - '/opt/topoviewer/entrypoint.sh' Spine-01: kind: srl image: ghcr.io/nokia/srlinux + binds: + - ./clab-demo.yaml:/opt/topo-file.yaml:ro group: "Data Center Spine" labels: topoViewer-role: spine diff --git a/rawTopoFile/clab-topo-export-template-example/clab-topo-auto.tmpl b/rawTopoFile/clab-topo-export-template-example/clab-topo-auto.tmpl deleted file mode 100755 index bbd303251..000000000 --- a/rawTopoFile/clab-topo-export-template-example/clab-topo-auto.tmpl +++ /dev/null @@ -1,46 +0,0 @@ -{ - "name": "{{ .Name }}", - "type": "{{ .Type }}", - "clab": { - "config": { - "prefix": "{{ .Clab.Config.Prefix }}", - "mgmt": {{ ToJSONPretty .Clab.Config.Mgmt " " " "}} - } - }, - "nodes": { {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}},{{end}} - "{{$n}}": { - "index": "{{$c.Index}}", - "shortname": "{{$c.ShortName}}", - "longname": "{{$c.LongName}}", - "fqdn": "{{$c.Fqdn}}", - "group": "{{$c.Group}}", - "labdir": "{{$c.LabDir}}", - "kind": "{{$c.Kind}}", - "image": "{{$c.Image}}", - "mgmt-net": "{{$c.MgmtNet}}", - "mgmt-intf": "{{$c.MgmtIntf}}", - "mgmt-ipv4-address": "{{$c.MgmtIPv4Address}}", - "mgmt-ipv4-prefix-length": {{$c.MgmtIPv4PrefixLength}}, - "mgmt-ipv6-address": "{{$c.MgmtIPv6Address}}", - "mgmt-ipv6-prefix-length": {{$c.MgmtIPv6PrefixLength}}, - "mac-address": "{{$c.MacAddress}}", - "labels": {{ToJSONPretty $c.Labels " " " "}} - }{{$i = add $i 1}}{{end}} - }, - "links": [{{range $i, $l := .Clab.Links}}{{if $i}},{{end}} - { - "a": { - "node": "{{ $l.A.Node.ShortName }}", - "interface": "{{ $l.A.EndpointName }}", - "mac": "{{ $l.A.MAC }}", - "peer": "z" - }, - "z": { - "node": "{{ $l.B.Node.ShortName }}", - "interface": "{{ $l.B.EndpointName }}", - "mac": "{{ $l.B.MAC }}", - "peer": "a" - } - }{{end}} - ] -} diff --git a/rawTopoFile/clab-topo-export-template-example/clab-topo-cytoscape.tmpl b/rawTopoFile/clab-topo-export-template-example/clab-topo-cytoscape.tmpl deleted file mode 100755 index 004092c14..000000000 --- a/rawTopoFile/clab-topo-export-template-example/clab-topo-cytoscape.tmpl +++ /dev/null @@ -1,51 +0,0 @@ -{{/* This template support containerlabversion: 0.41.2 and below */}} -{ - "name": "{{ .Name }}", - "type": "{{ .Type }}", - "clab": { - "config": { - "prefix": "{{ .Clab.Config.Prefix }}", - "mgmt": {{ ToJSONPretty .Clab.Config.Mgmt " " " "}} - } - }, - "nodes": [ - {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}},{{end}} - { - "id": "{{$n}}", - "index": "{{$c.Index}}", - "shortname": "{{$c.ShortName}}", - "longname": "{{$c.LongName}}", - "fqdn": "{{$c.Fqdn}}", - "group": "{{$c.Group}}", - "labdir": "{{$c.LabDir}}", - "kind": "{{$c.Kind}}", - "image": "{{$c.Image}}", - "mgmt-net": "{{$c.MgmtNet}}", - "mgmt-intf": "{{$c.MgmtIntf}}", - "mgmt-ipv4-address": "{{$c.MgmtIPv4Address}}", - "mgmt-ipv4-prefix-length": {{$c.MgmtIPv4PrefixLength}}, - "mgmt-ipv6-address": "{{$c.MgmtIPv6Address}}", - "mgmt-ipv6-prefix-length": {{$c.MgmtIPv6PrefixLength}}, - "mac-address": "{{$c.MacAddress}}", - "labels": {{ToJSONPretty $c.Labels " " " "}} - {{$i = add $i 1}}}{{end}} - ], - "links": [{{range $i, $l := .Clab.Links}}{{if $i}},{{end}} - { - "a": { - "node": "{{ $l.A.Node.ShortName }}", - "nodeLongName": "{{ $l.A.Node.LongName }}", - "interface": "{{ $l.A.EndpointName }}", - "mac": "{{ $l.A.MAC }}", - "peer": "z" - }, - "z": { - "node": "{{ $l.B.Node.ShortName }}", - "nodeLongName": "{{ $l.B.Node.LongName }}", - "interface": "{{ $l.B.EndpointName }}", - "mac": "{{ $l.B.MAC }}", - "peer": "a" - } - }{{end}} - ] -} \ No newline at end of file diff --git a/rawTopoFile/clab-topo-export-template-example/clab-topo-export.tmpl b/rawTopoFile/clab-topo-export-template-example/clab-topo-export.tmpl deleted file mode 100755 index 19087689e..000000000 --- a/rawTopoFile/clab-topo-export-template-example/clab-topo-export.tmpl +++ /dev/null @@ -1,24 +0,0 @@ -{ - "name": "{{ .Name }}", - "type": "{{ .Type }}", - "clab": {{ ToJSONPretty .Clab " " " "}}, - "nodes": { {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}},{{end}}{{ $k := dict "tls-key" $c.TLSKey }} - "{{$n}}":{{ $cj := $c | data.ToJSON | data.JSON }} {{ $dst := coll.Merge $cj $k }}{{ ToJSONPretty $dst " " " " }}{{$i = add $i 1}}{{end}} - }, - "links": [{{range $i, $l := .Clab.Links}}{{if $i}},{{end}} - { - "a": { - "node": "{{ $l.A.Node.ShortName }}", - "interface": "{{ $l.A.EndpointName }}", - "mac": "{{ $l.A.MAC }}", - "peer": "z" - }, - "z": { - "node": "{{ $l.B.Node.ShortName }}", - "interface": "{{ $l.B.EndpointName }}", - "mac": "{{ $l.B.MAC }}", - "peer": "a" - } - }{{end}} - ] -} diff --git a/rawTopoFile/clab-topo-export-template-example/clab-topo-full-export.tmpl b/rawTopoFile/clab-topo-export-template-example/clab-topo-full-export.tmpl deleted file mode 100755 index 19087689e..000000000 --- a/rawTopoFile/clab-topo-export-template-example/clab-topo-full-export.tmpl +++ /dev/null @@ -1,24 +0,0 @@ -{ - "name": "{{ .Name }}", - "type": "{{ .Type }}", - "clab": {{ ToJSONPretty .Clab " " " "}}, - "nodes": { {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}},{{end}}{{ $k := dict "tls-key" $c.TLSKey }} - "{{$n}}":{{ $cj := $c | data.ToJSON | data.JSON }} {{ $dst := coll.Merge $cj $k }}{{ ToJSONPretty $dst " " " " }}{{$i = add $i 1}}{{end}} - }, - "links": [{{range $i, $l := .Clab.Links}}{{if $i}},{{end}} - { - "a": { - "node": "{{ $l.A.Node.ShortName }}", - "interface": "{{ $l.A.EndpointName }}", - "mac": "{{ $l.A.MAC }}", - "peer": "z" - }, - "z": { - "node": "{{ $l.B.Node.ShortName }}", - "interface": "{{ $l.B.EndpointName }}", - "mac": "{{ $l.B.MAC }}", - "peer": "a" - } - }{{end}} - ] -} diff --git a/rawTopoFile/template-cyto-export.json b/rawTopoFile/clab-topology-export-demo.json similarity index 100% rename from rawTopoFile/template-cyto-export.json rename to rawTopoFile/clab-topology-export-demo.json diff --git a/rawTopoFile/topology-data-sample-serviceProvider.json b/rawTopoFile/clab-topology-export-serviceProvider.json similarity index 100% rename from rawTopoFile/topology-data-sample-serviceProvider.json rename to rawTopoFile/clab-topology-export-serviceProvider.json diff --git a/rawTopoFile/demo-clab-topology-export.json b/rawTopoFile/demo-clab-topology-export.json deleted file mode 100755 index 04141a6bb..000000000 --- a/rawTopoFile/demo-clab-topology-export.json +++ /dev/null @@ -1,270 +0,0 @@ - -{ - "name": "demo", - "type": "clab", - - - "clab": { - "config": { - "prefix": "clab", - "mgmt": { - "network": "clab", - "bridge": "br-9aae3a0b0e60", - "ipv4-subnet": "172.20.20.0/24", - "ipv4-gw": "172.20.20.1", - "ipv6-subnet": "2001:172:20:20::/64", - "ipv6-gw": "2001:172:20:20::1", - "mtu": 1500, - "external-access": true - } - } - }, -"nodes": [ - { - "id": "barcelona", - "index": "0", - "shortname": "barcelona", - "longname": "clab-demo-barcelona", - "fqdn": "barcelona.demo.io", - "group": "EUROPE", - "labdir": "/opt/containerlab/clab-demo/barcelona", - "kind": "nokia_srlinux", - "image": "srlinux:23.10-latest", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.4", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "2001:172:20:20::4", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "1a:ff:00:00:00:00", - "labels": { - "clab-mgmt-net-bridge": "br-9aae3a0b0e60", - "clab-node-group": "EUROPE", - "clab-node-kind": "nokia_srlinux", - "clab-node-lab-dir": "/opt/containerlab/clab-demo/barcelona", - "clab-node-name": "barcelona", - "clab-node-type": "ixr6e", - "clab-topo-file": "/opt/containerlab/nspcloud_topology.yaml", - "containerlab": "demo", - "topoviewer-role": "pe" - } - }, - { - "id": "berlin", - "index": "1", - "shortname": "berlin", - "longname": "clab-demo-berlin", - "fqdn": "berlin.demo.io", - "group": "EUROPE", - "labdir": "/opt/containerlab/clab-demo/berlin", - "kind": "nokia_sros", - "image": "registry.srlinux.dev/pub/vr-sros:23.10.R1", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.5", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "2001:172:20:20::5", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "", - "labels": { - "clab-mgmt-net-bridge": "br-9aae3a0b0e60", - "clab-node-group": "EUROPE", - "clab-node-kind": "nokia_sros", - "clab-node-lab-dir": "/opt/containerlab/clab-demo/berlin", - "clab-node-name": "berlin", - "clab-node-type": "sr-1", - "clab-topo-file": "/opt/containerlab/nspcloud_topology.yaml", - "containerlab": "demo", - "topoviewer-role": "pe" - } - }, - { - "id": "frankfurt", - "index": "2", - "shortname": "frankfurt", - "longname": "clab-demo-frankfurt", - "fqdn": "frankfurt.demo.io", - "group": "EUROPE", - "labdir": "/opt/containerlab/clab-demo/frankfurt", - "kind": "nokia_sros", - "image": "registry.srlinux.dev/pub/vr-sros:23.10.R1", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.3", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "2001:172:20:20::3", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "", - "labels": { - "clab-mgmt-net-bridge": "br-9aae3a0b0e60", - "clab-node-group": "EUROPE", - "clab-node-kind": "nokia_sros", - "clab-node-lab-dir": "/opt/containerlab/clab-demo/frankfurt", - "clab-node-name": "frankfurt", - "clab-node-type": "sr-1", - "clab-topo-file": "/opt/containerlab/nspcloud_topology.yaml", - "containerlab": "demo", - "topoviewer-role": "pe" - } - }, - { - "id": "madrid", - "index": "3", - "shortname": "madrid", - "longname": "clab-demo-madrid", - "fqdn": "madrid.demo.io", - "group": "EUROPE", - "labdir": "/opt/containerlab/clab-demo/madrid", - "kind": "nokia_srlinux", - "image": "srlinux:23.10-latest", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.2", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "2001:172:20:20::2", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "1a:7f:03:00:00:00", - "labels": { - "clab-mgmt-net-bridge": "br-9aae3a0b0e60", - "clab-node-group": "EUROPE", - "clab-node-kind": "nokia_srlinux", - "clab-node-lab-dir": "/opt/containerlab/clab-demo/madrid", - "clab-node-name": "madrid", - "clab-node-type": "ixr6e", - "clab-topo-file": "/opt/containerlab/nspcloud_topology.yaml", - "containerlab": "demo", - "topoviewer-role": "pe" - } - } - ], -"links": [ - { - "a": { - "node": "barcelona", - "nodeLongName": "demo-barcelona", - "interface": "e1-1", - "mac": "", - "peer": "z" - }, - "z": { - "node": "madrid", - "nodeLongName": "demo-madrid", - "interface": "e1-1", - "mac": "", - "peer": "a" - } - }, - { - "a": { - "node": "frankfurt", - "nodeLongName": "demo-frankfurt", - "interface": "eth1", - "mac": "", - "peer": "z" - }, - "z": { - "node": "berlin", - "nodeLongName": "demo-berlin", - "interface": "eth1", - "mac": "", - "peer": "a" - } - }, - { - "a": { - "node": "barcelona", - "nodeLongName": "demo-barcelona", - "interface": "e1-2", - "mac": "", - "peer": "z" - }, - "z": { - "node": "frankfurt", - "nodeLongName": "demo-frankfurt", - "interface": "eth2", - "mac": "", - "peer": "a" - } - }, - { - "a": { - "node": "madrid", - "nodeLongName": "demo-madrid", - "interface": "e1-2", - "mac": "", - "peer": "z" - }, - "z": { - "node": "berlin", - "nodeLongName": "demo-berlin", - "interface": "eth2", - "mac": "", - "peer": "a" - } - }, - { - "a": { - "node": "barcelona", - "nodeLongName": "demo-barcelona", - "interface": "e1-3", - "mac": "", - "peer": "z" - }, - "z": { - "node": "barcelona", - "nodeLongName": "demo-barcelona", - "interface": "e1-4", - "mac": "", - "peer": "a" - } - }, - { - "a": { - "node": "madrid", - "nodeLongName": "demo-madrid", - "interface": "e1-3", - "mac": "", - "peer": "z" - }, - "z": { - "node": "madrid", - "nodeLongName": "demo-madrid", - "interface": "e1-4", - "mac": "", - "peer": "a" - } - }, - { - "a": { - "node": "frankfurt", - "nodeLongName": "demo-frankfurt", - "interface": "eth3", - "mac": "", - "peer": "z" - }, - "z": { - "node": "frankfurt", - "nodeLongName": "demo-frankfurt", - "interface": "eth4", - "mac": "", - "peer": "a" - } - }, - { - "a": { - "node": "berlin", - "nodeLongName": "demo-berlin", - "interface": "eth3", - "mac": "", - "peer": "z" - }, - "z": { - "node": "berlin", - "nodeLongName": "demo-berlin", - "interface": "eth4", - "mac": "", - "peer": "a" - } - } - ] -} diff --git a/rawTopoFile/entrypoint.sh b/rawTopoFile/entrypoint.sh deleted file mode 100755 index 734b485f2..000000000 --- a/rawTopoFile/entrypoint.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/bash -/opt/topoviewer/topoviewer clab --allowed-hostnames $ALLOWED_HOSTNAME --clab-user $CLAB_USER --clab-pass $CLAB_PASS --server-port $SERVER_PORT --topology-file-yaml local-bind/$CLAB_TOPO_YAML & \ No newline at end of file diff --git a/rawTopoFile/impairment-element.html b/rawTopoFile/impairment-element.html deleted file mode 100755 index cdd437c2b..000000000 --- a/rawTopoFile/impairment-element.html +++ /dev/null @@ -1,247 +0,0 @@ -
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- -
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- -
-
-
-
- - - - -
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- -
-
-
-
-
-
\ No newline at end of file diff --git a/rawTopoFile/start.sh b/rawTopoFile/start.sh deleted file mode 100755 index 098b5acd9..000000000 --- a/rawTopoFile/start.sh +++ /dev/null @@ -1 +0,0 @@ -/opt/topoviewer/topoviewer clab --allowed-hostnames $ALLOWED_HOSTNAME --clab-user $CLAB_USER --clab-pass $CLAB_PASS --server-port $SERVER_PORT --topology-file-json local-bind/topo-file.json & \ No newline at end of file diff --git a/rawTopoFile/topo-clab-demo.yaml b/rawTopoFile/topo-clab-demo.yaml deleted file mode 100644 index ef7da5491..000000000 --- a/rawTopoFile/topo-clab-demo.yaml +++ /dev/null @@ -1,163 +0,0 @@ -name: demo - -topology: - nodes: - - - topoviewer: - kind: linux - image: ghcr.io/asadarafat/topoviewer:nightly-24.10.26c - ports: - - 8088:8088 - startup-delay: 5 - binds: - - /var/run/docker.sock:/var/run/docker.sock:ro - # - __clabDir__/topology-data.json:/opt/topoviewer/local-bind/topo-file.json:ro - - - topo-clab-demo.yaml:/opt/topoviewer/local-bind/topo-clab-demo.yaml:ro - - entrypoint.sh:/opt/topoviewer/local-bind/entrypoint.sh:ro - # - entrypoint.sh:/opt/topoviewer/entrypoint.sh:ro - - ### __clabDir__/topology-data.json is path to clab's json file which generated by "clab --export-template" and /opt/topoviewer/local-bind/topo-file.json is the mount path of topoviever's topology file. - # - ../dist/topoviewer:/opt/topoviewer/topoviewer:ro - ### This is to access docker.sock from topoviewer container - - env: - ALLOWED_HOSTNAME: "nsp-clab1.nice.nokia.net" - CLAB_USER: "asad" - CLAB_PASS: "Lab-Her0" - SERVER_PORT: "8088" - CLAB_TOPO_YAML: "topo-clab-demo.yaml" - - ### These are the environment variables for topoviewer container - - labels: - topoviewer-role: controller - - # exec: - # - '/opt/topoviewer/entrypoint.sh' - ### This is the entrypoint script of topoviewer container - - - Spine-01: - kind: srl - image: ghcr.io/nokia/srlinux - binds: - - ./topo-clab-demo.yaml:/opt/topo-file.yaml:ro - group: "Data Center Spine" - labels: - topoViewer-role: spine - - - Spine-02: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Spine" - labels: - topoViewer-role: spine - - # Borderl-Leaf-01: - # kind: srl - # image: ghcr.io/nokia/srlinux - # group: "Data Center Leaf" - # labels: - # topoViewer-role: leaf - - # Borderl-Leaf-02: - # kind: srl - # image: ghcr.io/nokia/srlinux - # group: "Data Center Leaf" - # labels: - # topoViewer-role: leaf - - Leaf-01: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Leaf" - labels: - topoViewer-role: leaf - - Leaf-02: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Leaf" - labels: - topoViewer-role: leaf - - Leaf-03: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Leaf" - labels: - topoViewer-role: leaf - - Leaf-04: - kind: srl - image: ghcr.io/nokia/srlinux - group: "Data Center Leaf" - labels: - topoViewer-role: leaf - - # PE-01: - # kind: vr-sros - # image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - # type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - # license: license.txt - # group: "Back Bone" - # labels: - # topoViewer-role: pe - - # PE-02: - # kind: vr-sros - # image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - # type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - # license: license.txt - # group: "Back Bone" - # labels: - # topoViewer-role: pe - - # DCGW-03: - # kind: vr-sros - # image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - # type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - # license: license.txt - # group: "Data Center - DCGW" - # labels: - # topoViewer-role: dcgw - - # DCGW-04: - # kind: vr-sros - # image: registry.srlinux.dev/pub/vr-sros:22.7.R1 - # type: "cp: cpu=2 ram=6 chassis=SR-2s slot=A card=cpm-2s ___ lc: cpu=2 ram=4 max_nics=10 chassis=SR-2s slot=1 card=xcm-2s mda/1=s18-100gb-qsfp28" - # license: license.txt - # group: "Data Center - DCGW" - # labels: - # topoViewer-role: dcgw - - links: - - # - endpoints: ["PE-01:eth2", "PE-02:eth2"] - # - endpoints: ["PE-01:eth3", "DCGW-03:eth3"] - - # - endpoints: ["PE-02:eth4", "DCGW-03:eth4"] - # - endpoints: ["PE-02:eth5", "DCGW-04:eth5"] - - # - endpoints: ["PE-01:eth4", "DCGW-04:eth4"] - - # - endpoints: ["DCGW-03:eth1", "Borderl-Leaf-01:e1-1"] - # - endpoints: ["DCGW-04:eth1", "Borderl-Leaf-02:e1-1"] - - # - endpoints: ["Spine-01:e1-5", "Borderl-Leaf-01:e1-5"] - # - endpoints: ["Spine-02:e1-5", "Borderl-Leaf-02:e1-5"] - - - endpoints: ["Spine-01:e1-1", "Leaf-01:e1-1"] - - endpoints: ["Spine-01:e1-2", "Leaf-02:e1-1"] - - endpoints: ["Spine-01:e1-3", "Leaf-03:e1-3"] - - endpoints: ["Spine-01:e1-4", "Leaf-04:e1-3"] - - - endpoints: ["Spine-02:e1-1", "Leaf-01:e1-2"] - - endpoints: ["Spine-02:e1-2", "Leaf-02:e1-2"] - - endpoints: ["Spine-02:e1-3", "Leaf-03:e1-4"] - - endpoints: ["Spine-02:e1-4", "Leaf-04:e1-4"] - - diff --git a/rawTopoFile/topoviewer/clab-client-mac/ClabCapture.app.zip b/rawTopoFile/topoviewer/clab-client-mac/ClabCapture.app.zip deleted file mode 100755 index f85373d97..000000000 Binary files a/rawTopoFile/topoviewer/clab-client-mac/ClabCapture.app.zip and /dev/null differ diff --git a/rawTopoFile/topoviewer/clab-client-mac/ClabPumbaDelay.app.zip b/rawTopoFile/topoviewer/clab-client-mac/ClabPumbaDelay.app.zip deleted file mode 100755 index 11b590c9b..000000000 Binary files a/rawTopoFile/topoviewer/clab-client-mac/ClabPumbaDelay.app.zip and /dev/null differ diff --git a/rawTopoFile/topoviewer/clab-client-windows/ClabCapture.app.zip b/rawTopoFile/topoviewer/clab-client-windows/ClabCapture.app.zip deleted file mode 100755 index dfafebd68..000000000 Binary files a/rawTopoFile/topoviewer/clab-client-windows/ClabCapture.app.zip and /dev/null differ diff --git a/rawTopoFile/topoviewer/clab-client-windows/ClabPumbaDelay.app.zip b/rawTopoFile/topoviewer/clab-client-windows/ClabPumbaDelay.app.zip deleted file mode 100755 index 774de39c3..000000000 Binary files a/rawTopoFile/topoviewer/clab-client-windows/ClabPumbaDelay.app.zip and /dev/null differ diff --git a/rawTopoFile/topoviewer/clab-topoviewer.tmpl b/rawTopoFile/topoviewer/clab-topoviewer.tmpl deleted file mode 100755 index 5e6ff65b2..000000000 --- a/rawTopoFile/topoviewer/clab-topoviewer.tmpl +++ /dev/null @@ -1,57 +0,0 @@ -{{/* This template support containerlab version: 0.44.3 */}} -{ - "name": "{{ .Name }}", - "type": "{{ .Type }}", - {{ $labName := .Name }} - {{ $type := .Type }} - "clab": { - "config": { - "prefix": "{{ .Clab.Config.Prefix }}", - "mgmt": {{ ToJSONPretty .Clab.Config.Mgmt " " " "}} - } - }, -"nodes": [ - {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}},{{end}} - { - "id": "{{$n}}", - "index": "{{$c.Index}}", - "shortname": "{{$c.ShortName}}", - "longname": "{{$c.LongName}}", - "fqdn": "{{$c.Fqdn}}", - "group": "{{$c.Group}}", - "labdir": "{{$c.LabDir}}", - "kind": "{{$c.Kind}}", - "image": "{{$c.Image}}", - "mgmt-net": "{{$c.MgmtNet}}", - "mgmt-intf": "{{$c.MgmtIntf}}", - "mgmt-ipv4-address": "{{$c.MgmtIPv4Address}}", - "mgmt-ipv4-prefix-length": {{$c.MgmtIPv4PrefixLength}}, - "mgmt-ipv6-address": "{{$c.MgmtIPv6Address}}", - "mgmt-ipv6-prefix-length": {{$c.MgmtIPv6PrefixLength}}, - "mac-address": "{{$c.MacAddress}}", - "labels": {{ToJSONPretty $c.Labels " " " "}} - {{$i = add $i 1}}}{{end}} - ], -"links": [{{range $i, $l := .Clab.Links}}{{if $i}},{{end}}{{ $endpointA := index $l.Endpoints 0 }}{{ $endpointB := index $l.Endpoints 1 }}{{ $endpointAList := split (printf "%s" - $endpointA) ":" }}{{ $endpointBList := split (printf "%s" $endpointB) ":" }} - {{- $eps := $l.GetEndpoints }} - {{- $ep := index $eps 0 }} - { - "a": { - "node": "{{ index $endpointAList 0 }}", - "nodeLongName": "{{ $type }}-{{ $labName}}-{{ index $endpointAList 0 }}", - "interface": "{{ $ep.GetIfaceName }}", - "mac": "{{ $ep.GetMac }}", - "peer": "z" - }, - {{- $ep := index $eps 1 }} - "z": { - "node": "{{ index $endpointBList 0 }}", - "nodeLongName": "{{ $type }}-{{ $labName}}-{{ index $endpointBList 0 }}", - "interface": "{{ $ep.GetIfaceName }}", - "mac": "{{ $ep.GetMac }}", - "peer": "a" - } - }{{end}} - ] -} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/config/antareja-config.yaml b/rawTopoFile/topoviewer/config/antareja-config.yaml deleted file mode 100644 index cc0bd8002..000000000 --- a/rawTopoFile/topoviewer/config/antareja-config.yaml +++ /dev/null @@ -1,31 +0,0 @@ -loki: - url: "http://100.124.41.83:3100" - -ssh: - remoteHost: "100.124.41.65" - remotePort: "22" - remoteUser: "asad" - remotePassword: "Lab-Her0" - -pods: - - namespace: "nsp-psa-restricted" - podName: "nspos-app2-tomcat" - podNameWildCard: true - containerName: "nspos-app2-tomcat" - logFilePath: "tail -f /opt/nsp/os/app2-tomcat/logs/restconf.log" - - namespace: "nsp-psa-privileged" - podName: "mdm-server-0" - podNameWildCard: false - containerName: "cn-nsp-mdm-server" - logFilePath: "tail -f /opt/nsp/mediation/log/MdmServer.log" - - namespace: "nsp-psa-restricted" - podName: "nspos-resync-fw-0" - podNameWildCard: false - containerName: "md-resync-fw" - logFilePath: "tail -f /opt/nsp/os/resync-fw/logs/mdResync.log" - - namespace: "nsp-psa-restricted" - podName: "nsp-mdt-ac-0" - podNameWildCard: false - containerName: "nsp-mdt-ac" - logFilePath: " /bin/sh -c './bin/client <<< \"log; tail;\"' " - diff --git a/rawTopoFile/topoviewer/config/kafka-client-config.yaml b/rawTopoFile/topoviewer/config/kafka-client-config.yaml deleted file mode 100644 index aea85eedf..000000000 --- a/rawTopoFile/topoviewer/config/kafka-client-config.yaml +++ /dev/null @@ -1,8 +0,0 @@ -client_cert_file: /home/aarafat/atlantic-client.cer.pem -client_key_file: /home/aarafat/atlantic-client.key.pem -ca_cert_file: /home/aarafat/atlantic-server.cer.pem -kafka_brokers: - - atlanticnsp.nice.nokia.net:9192 -topic: nsp-yang-model.change-notif -offset_strategy: latest -num_latest_events: 50 \ No newline at end of file diff --git a/rawTopoFile/topoviewer/config/topoviewer-config.yaml b/rawTopoFile/topoviewer/config/topoviewer-config.yaml deleted file mode 100755 index 0e248f177..000000000 --- a/rawTopoFile/topoviewer/config/topoviewer-config.yaml +++ /dev/null @@ -1,22 +0,0 @@ -topoviewer: - env: "development" - consumerbroker: "first.example.com:9092" - producerbroker: "second.example.com:9092" - -nsp: - nspOsIP: "thalesnsp.ion.de.alcatel-lucent.com" # API gateway - nspIprcIP: "thalesnsp.ion.de.alcatel-lucent.com" # API gateway - username: "admin" - password: "NokiaNsp1!" - nspIeftTopoL2: "rawTopoFile/topo-ietf-L2.json" - nspIeftTopoL3_0: "rawTopoFile/topo-ietf-L3-TopologyId-0:55000:2-isis.json" - nspIeftTopoL3_1: "rawTopoFile/topo-ietf-L3-TopologyId-1:65000:1-isis.json" - nspIeftTopoL3_2: "rawTopoFile/topo-ietf-L3-TopologyId-0:65000:1-isis.json" - multi-layer: "enabled" - - - - # nspOsIP: "147.75.102.178" # API gateway - # nspIprcIP: "147.75.102.178" # API gateway - # username: "admin" - # password: "zkw3VSs6" diff --git a/rawTopoFile/topoviewer/dist.zip b/rawTopoFile/topoviewer/dist.zip deleted file mode 100644 index 0791992d7..000000000 Binary files a/rawTopoFile/topoviewer/dist.zip and /dev/null differ diff --git a/rawTopoFile/topoviewer/entrypoint.sh b/rawTopoFile/topoviewer/entrypoint.sh deleted file mode 100755 index d088b2a5a..000000000 --- a/rawTopoFile/topoviewer/entrypoint.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/bash -/opt/topoviewer/topoviewer clab --allowed-hostnames $ALLOWED_HOSTNAME --clab-user $CLAB_USER --clab-pass $CLAB_PASS --server-port $SERVER_PORT --topology-file-yaml local-bind/topo-file.yaml & \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-public/put-html-asset-here.txt b/rawTopoFile/topoviewer/html-public/put-html-asset-here.txt deleted file mode 100644 index e69de29bb..000000000 diff --git a/rawTopoFile/topoviewer/html-static/actions/backupRestoreScript/README.MD b/rawTopoFile/topoviewer/html-static/actions/backupRestoreScript/README.MD deleted file mode 100644 index f35ca7668..000000000 --- a/rawTopoFile/topoviewer/html-static/actions/backupRestoreScript/README.MD +++ /dev/null @@ -1,30 +0,0 @@ -This is python action script for backup and restore - -install python requirement -``` -pip3 install -r requirements.txt --user -``` - -``` -usage: backupRestoreScript.py --ip_address IPADDRESS --username USERNAME --password PASSWORD --devicename DEVICENAME --kind KIND --directory DIRECTORY [--backup] [--restore] - -Examples: - python3 backupRestoreScript.py --ip_address 10.2.1.110 --username admin --password admin --devicename Router1 --directory /path/to/backup --backup - python3 backupRestoreScript.py --ip_address 10.2.1.110 --username admin --password admin --devicename Router1 --directory /path/to/backup --restore - -Backup and Restore device configuration. - -optional arguments: - -h, --help show this help message and exit - --ip_address IP_ADDRESS - IP address of the device - --username USERNAME Username for SSH login - --password PASSWORD Password for SSH login - --devicename DEVICENAME - Name of the device for backup/restore file naming - --directory DIRECTORY, -d DIRECTORY - Directory where backup/restore files should be saved - --kind KIND Device kind ie: sros - --backup Backup the device configuration - --restore Restore the configuration -``` \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/actions/backupRestoreScript/backupRestoreScript.py b/rawTopoFile/topoviewer/html-static/actions/backupRestoreScript/backupRestoreScript.py deleted file mode 100644 index 040804fd9..000000000 --- a/rawTopoFile/topoviewer/html-static/actions/backupRestoreScript/backupRestoreScript.py +++ /dev/null @@ -1,239 +0,0 @@ -import argparse -import os -import logging -from logging.handlers import TimedRotatingFileHandler -from netmiko import ConnectHandler, file_transfer -from pylogrus import PyLogrus, TextFormatter -import sys -from datetime import datetime - - - -def get_logger(log_directory): - logging.setLoggerClass(PyLogrus) - logger = logging.getLogger(__name__) # type: PyLogrus - logger.setLevel(logging.DEBUG) - - formatter = TextFormatter(datefmt="Z", colorize=True) - - # Console handler - ch = logging.StreamHandler() - ch.setLevel(logging.DEBUG) - ch.setFormatter(formatter) - logger.addHandler(ch) - - # File handler with rolling deletion - log_filename = os.path.join(log_directory, "backup_restore.log") - fh = TimedRotatingFileHandler(log_filename, when="midnight", interval=1, backupCount=7) # Keep logs for 7 days - fh.setLevel(logging.DEBUG) - fh.setFormatter(formatter) - logger.addHandler(fh) - - return logger - - -def NokiaSrosBackup(ip_address, username, password, config_name, directory, log_directory): - log = get_logger(log_directory) # Initialize logger - device = { - "device_type": "nokia_sros", # Device type is fixed, you shouldn't change this - "ip": ip_address, # IP address to connect to your device via SSH - "username": username, # Username for SSH - "password": password # Password for SSH - } - - # Get the current date and time - now = datetime.now() - - # Format the timestamp - formatted_now = now.strftime("%Y-%m-%d-%H-%M-%S") - - log.info("Device Id :%s", ip_address) - log.info("Device Config Name :%s", config_name) - log.info("Device Config Directory :%s", directory) - - # join config_name + formatted_now - config_name = f"{config_name}--{formatted_now}.cfg" - - - # Establish SSH connection to device - SSH = ConnectHandler(**device) - if SSH.check_config_mode: - try: - log.info("Device is SROS MD-CLI...") - - # Send a command and print output - version = SSH.send_command("show version") - log.info(version) - - log.info(SSH.send_command("environment more false")) - - # Get configuration output - config_output = SSH.send_command("admin show configuration configure") - log.info (config_output) - - # Determine the backup file path - backup_filename = config_name - backup_path = os.path.join(directory, backup_filename) - - # Save the output to a file with the device name in the specified directory - with open(backup_path, "w") as file: - file.write(config_output) - - # Revert the environment setting and close SSH connection - log.info(SSH.send_command("exit")) - log.info(SSH.send_command("environment more true")) - - except Exception as e: - log.error("An error occurred during config backup: %s", e) - - finally: - log.info(SSH.disconnect()) - log.info("SSH connection closed") - else: - log.info("Device is Classic CLI... Script does not support Classic CLI...") - - SSH.disconnect() - - -def NokiaSrosRestore(ip_address, username, password, config_name, directory, log_directory): - log = get_logger(log_directory) # Initialize logger - device = { - "device_type": "nokia_sros", # Device type is fixed, you shouldn't change this - "ip": ip_address, # IP address to connect to your device via SSH - "username": username, # Username for SSH - "password": password # Password for SSH - } - - log.info("Device Id :%s", ip_address) - log.info("Device Config Name :%s.cfg", config_name) - log.info("Device Config Directory :%s", directory) - - SSH = ConnectHandler(**device) - if SSH.check_config_mode: - log.info("Device is SROS MD-CLI...") - try: - log.info("SSH connection established to device: %s", ip_address) - - # Determine the restore file path - restore_filename = f"{config_name}" - restore_path = os.path.join(directory, restore_filename) - - transfer = file_transfer( - SSH, - source_file=restore_path, - dest_file=config_name, - file_system="cf3:/", - direction="put", - overwrite_file=True - ) - log.info("File transferred to device: %s", transfer) - - log.info(SSH.send_command("configure private")) - log.info(SSH.send_command(f"load full-replace cf3:{config_name}")) - log.info(SSH.send_command("commit")) - - except Exception as e: - log.error("An error occurred during SCP: %s", e) - - finally: - log.info(SSH.disconnect()) - log.info("SSH connection closed") - -def NokiaSrosGet(ip_address, username, password, config_name, directory, log_directory): - log = get_logger(log_directory) # Initialize logger - device = { - "device_type": "nokia_sros", # Device type is fixed, you shouldn't change this - "ip": ip_address, # IP address to connect to your device via SSH - "username": username, # Username for SSH - "password": password # Password for SSH - } - - config_name = f"{config_name}-running.cfg" - - log.info("Device Id :%s", ip_address) - log.info("Device Config Name :%s", config_name) - log.info("Device Config Directory :%s", directory) - - - # Establish SSH connection to device - SSH = ConnectHandler(**device) - if SSH.check_config_mode: - try: - log.info("Device is SROS MD-CLI...") - - # Send a command and print output - version = SSH.send_command("show version") - log.info(version) - - log.info(SSH.send_command("environment more false")) - - # Get configuration output - config_output = SSH.send_command("admin show configuration configure") - log.info (config_output) - - # Determine the backup file path - backup_filename = config_name - backup_path = os.path.join(directory, backup_filename) - - # Save the output to a file with the device name in the specified directory - with open(backup_path, "w") as file: - file.write(config_output) - - # Revert the environment setting and close SSH connection - log.info(SSH.send_command("exit")) - log.info(SSH.send_command("environment more true")) - - except Exception as e: - log.error("An error occurred during config backup: %s", e) - - finally: - log.info(SSH.disconnect()) - log.info("SSH connection closed") - else: - log.info("Device is Classic CLI... Script does not support Classic CLI...") - - SSH.disconnect() - -def main(): - parser = argparse.ArgumentParser( - description="Backup and Restore device configuration.", - formatter_class=argparse.RawTextHelpFormatter, - usage="""backupRestoreScript.py --ip_address IPADDRESS --username USERNAME --password PASSWORD --configname CONFIGNAME --kind KIND --directory DIRECTORY --log_directory LOG_DIRECTORY [--backup] [--restore] - -Examples: - python3 backupRestoreScript.py --ip_address 10.2.1.110 --username admin --password admin --configname Router10-2024-06-26T08:46:41Z.cfg --kind vr-sros --directory /path/to/backup --log_directory /path/to/logs --backup - python3 backupRestoreScript.py --ip_address 10.2.1.110 --username admin --password admin --configname Router10-2024-06-26T08:46:41Z.cfg --kind vr-sros --directory /path/to/backup --log_directory /path/to/logs --restore -""" - ) - - parser.add_argument("--ip_address", required=True, help="IP address of the device") - parser.add_argument("--username", required=True, help="Username for SSH login") - parser.add_argument("--password", required=True, help="Password for SSH login") - parser.add_argument("--configname", required=True, help="Name of the device config for backup/restore file naming") - parser.add_argument("--directory", "-d", required=True, help="Directory where backup/restore files should be saved") - parser.add_argument("--kind", required=True, help="Device kind ie: sros") - parser.add_argument("--log_directory", required=True, help="Directory where logs should be saved") - parser.add_argument("--backup", action="store_true", help="Backup the device configuration") - parser.add_argument("--restore", action="store_true", help="Restore the configuration") - parser.add_argument("--get", action="store_true", help="Get the running configuration") - - - args = parser.parse_args() - - if not any(vars(args).values()): - parser.print_help() - elif args.backup: - if args.kind == "vr-sros": - NokiaSrosBackup(args.ip_address, args.username, args.password, args.configname, args.directory, args.log_directory) - elif args.restore: - if args.kind == "vr-sros": - NokiaSrosRestore(args.ip_address, args.username, args.password, args.configname, args.directory, args.log_directory) - elif args.get: - if args.kind == "vr-sros": - NokiaSrosGet(args.ip_address, args.username, args.password, args.configname, args.directory, args.log_directory) - else: - parser.print_help() - - -if __name__ == "__main__": - main() diff --git a/rawTopoFile/topoviewer/html-static/actions/backupRestoreScript/requirements.txt b/rawTopoFile/topoviewer/html-static/actions/backupRestoreScript/requirements.txt deleted file mode 100644 index 1bb4ab37e..000000000 --- a/rawTopoFile/topoviewer/html-static/actions/backupRestoreScript/requirements.txt +++ /dev/null @@ -1,3 +0,0 @@ -netmiko -pylogrus -argparse diff --git a/rawTopoFile/topoviewer/html-static/actions/exampleScript.py b/rawTopoFile/topoviewer/html-static/actions/exampleScript.py deleted file mode 100644 index e22a4e3e6..000000000 --- a/rawTopoFile/topoviewer/html-static/actions/exampleScript.py +++ /dev/null @@ -1,18 +0,0 @@ -# exampleScript.py - -import sys - -def main(): - # Example of receiving arguments from command line - if len(sys.argv) > 1: - arg1 = sys.argv[1] - arg2 = sys.argv[2] - print(f"Argument 1: {arg1}") - print(f"Argument 2: {arg2}") - - # Example of printing some output - print("Python script execution successful!") - print("Here is some output from the Python script.") - -if __name__ == "__main__": - main() diff --git a/rawTopoFile/topoviewer/html-static/actions/rebootScript/README.MD b/rawTopoFile/topoviewer/html-static/actions/rebootScript/README.MD deleted file mode 100644 index eedd62e00..000000000 --- a/rawTopoFile/topoviewer/html-static/actions/rebootScript/README.MD +++ /dev/null @@ -1,26 +0,0 @@ -This is python action script for rebooting device - -install python requirement -``` -pip3 install -r requirements.txt --user -``` - -``` -usage: backupRestoreScript.py --ip_address IPADDRESS --username USERNAME --password PASSWORD --devicename DEVICENAME --kind KIND --directory DIRECTORY [--reboot] -Examples: - python3 rebootScript.py --ip_address 10.2.1.110 --username admin --password admin --devicename Router1 --directory /path/to/backup --reboot - -Backup and Restore device configuration. - -optional arguments: - -h, --help show this help message and exit - --ip_address IP_ADDRESS - IP address of the device - --username USERNAME Username for SSH login - --password PASSWORD Password for SSH login - --devicename DEVICENAME - Name of the device for backup/restore file naming - --directory DIRECTORY, -d DIRECTORY - Directory where backup/restore files should be saved - --kind KIND Device kind ie: sros - --reboot Reboot the device \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/actions/rebootScript/rebootScript.py b/rawTopoFile/topoviewer/html-static/actions/rebootScript/rebootScript.py deleted file mode 100644 index 3e1153dc9..000000000 --- a/rawTopoFile/topoviewer/html-static/actions/rebootScript/rebootScript.py +++ /dev/null @@ -1,86 +0,0 @@ -import argparse -import os -import logging -from netmiko import ConnectHandler, file_transfer -from pylogrus import PyLogrus, TextFormatter - - -def get_logger(): - logging.setLoggerClass(PyLogrus) - - logger = logging.getLogger(__name__) # type: PyLogrus - logger.setLevel(logging.DEBUG) - - formatter = TextFormatter(datefmt="Z", colorize=True) - # formatter.override_level_names({"CRITICAL": "CRIT", "ERROR": "ERRO", "WARNING": "WARN", "DEBUG": "DEBU"}) - # formatter.override_colors({"prefix": CL_BLDYLW}) - - ch = logging.StreamHandler() - ch.setLevel(logging.DEBUG) - ch.setFormatter(formatter) - logger.addHandler(ch) - - return logger - -def NokiaSrosReboot(ip_address, username, password, device_name, directory): - log = get_logger() ## init logger - device = { - "device_type": "nokia_sros", # device type is fixed, you shouldn"t change this - "ip": ip_address, # IP address to connect to your device via SSH - "username": username, # username for SSH - "password": password # password for SSH - } - - # Establish SSH connection to device - SSH = ConnectHandler(**device) - if SSH.check_config_mode: - try: - log.info ("Device is MD-CLI...") - - # Send a command and print output - log.info (SSH.send_command("show version")) - log.info ("Rebooting the device..") - SSH.send_command("admin reboot now") - - except Exception as e: - log.error("An error occurred during device reboot: %s", e) - - finally: - log.info (SSH.disconnect()) - log.info("SSH connection closed") - else: - log.info ("Device is Classic CLI... Script does not support Classic CLI...") - - SSH.disconnect() - - -def main(): - - parser = argparse.ArgumentParser( - description="Backup and Restore device configuration.", - formatter_class=argparse.RawTextHelpFormatter, - usage="""backupRestoreScript.py --ip_address IPADDRESS --username USERNAME --password PASSWORD --devicename DEVICENAME --kind KIND --directory DIRECTORY [--reboot] -Examples: - python3 rebootScript.py --ip_address 10.2.1.110 --username admin --password admin --devicename Router1 --directory /path/to/backup --reboot -""") - - parser.add_argument("--ip_address", required=True, help="IP address of the device") - parser.add_argument("--username", required=True, help="Username for SSH login") - parser.add_argument("--password", required=True, help="Password for SSH login") - parser.add_argument("--devicename", required=True, help="Name of the device for backup/restore file naming") - parser.add_argument("--directory", "-d", required=True, help="Directory where backup/restore files should be saved") - parser.add_argument("--kind", required=True, help="Device kind ie: sros") - parser.add_argument("--reboot", action="store_true", help="Reboot the device") - - args = parser.parse_args() - - if not any(vars(args).values()): - parser.print_help() - elif args.reboot: - if args.kind == "vr-sros": - NokiaSrosReboot(args.ip_address, args.username, args.password, args.devicename, args.directory) - else: - parser.print_help() - -if __name__ == "__main__": - main() diff --git a/rawTopoFile/topoviewer/html-static/actions/rebootScript/requirements.txt b/rawTopoFile/topoviewer/html-static/actions/rebootScript/requirements.txt deleted file mode 100644 index 1bb4ab37e..000000000 --- a/rawTopoFile/topoviewer/html-static/actions/rebootScript/requirements.txt +++ /dev/null @@ -1,3 +0,0 @@ -netmiko -pylogrus -argparse diff --git a/rawTopoFile/topoviewer/html-static/clab-client/clab-client-mac/ClabCapture.app.zip b/rawTopoFile/topoviewer/html-static/clab-client/clab-client-mac/ClabCapture.app.zip deleted file mode 100755 index f85373d97..000000000 Binary files a/rawTopoFile/topoviewer/html-static/clab-client/clab-client-mac/ClabCapture.app.zip and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/clab-client/clab-client-mac/ClabPumbaDelay.app.zip b/rawTopoFile/topoviewer/html-static/clab-client/clab-client-mac/ClabPumbaDelay.app.zip deleted file mode 100755 index 11b590c9b..000000000 Binary files a/rawTopoFile/topoviewer/html-static/clab-client/clab-client-mac/ClabPumbaDelay.app.zip and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/clab-client/clab-client-windows/ClabCapture.app.zip b/rawTopoFile/topoviewer/html-static/clab-client/clab-client-windows/ClabCapture.app.zip deleted file mode 100755 index dfafebd68..000000000 Binary files a/rawTopoFile/topoviewer/html-static/clab-client/clab-client-windows/ClabCapture.app.zip and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/clab-client/clab-client-windows/ClabPumbaDelay.app.zip b/rawTopoFile/topoviewer/html-static/clab-client/clab-client-windows/ClabPumbaDelay.app.zip deleted file mode 100755 index 774de39c3..000000000 Binary files a/rawTopoFile/topoviewer/html-static/clab-client/clab-client-windows/ClabPumbaDelay.app.zip and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/css/cy-style-dark.json b/rawTopoFile/topoviewer/html-static/css/cy-style-dark.json deleted file mode 100644 index 9ee69acc4..000000000 --- a/rawTopoFile/topoviewer/html-static/css/cy-style-dark.json +++ /dev/null @@ -1,262 +0,0 @@ -[ - { - "selector": "core", - "style": { - "selection-box-color": "#AAD8FF", - "selection-box-border-color": "#8BB0D0", - "selection-box-opacity": "0.5" - } - }, - { - "selector": "node", - "style": { - "shape": "rectangle", - "width": "10", - "height": "10", - "content": "data(name)", - "label": "data(name)", - "font-size": "7px", - "text-valign": "bottom", - "text-halign": "center", - "background-color": "#8F96AC", - "min-zoomed-font-size": "7px", - "color": "#F5F5F5", - "text-outline-color": "#3C3E41", - "text-outline-width": "0.3px", - "text-background-color": "#FFFF", - "text-background-opacity": 0.7, - "text-background-shape": "roundrectangle", - "text-background-padding": "1px", - "overlay-padding": "0.3px", - "z-index": "10" - } - }, - { - "selector": "node[?attr]", - "style": { - "shape": "rectangle", - "background-color": "#aaa", - "text-outline-color": "#aaa", - "width": "10px", - "height": "10x", - "font-size": "8px", - "z-index": "1" - } - }, - { - "selector": "node[?query]", - "style": {"background-clip": "none", "background-fit": "contain"} - }, - { - "selector": "node:parent", - "style": { - "shape": "rectangle", - "border-width": "0.5px", - "border-color": "#DDDDDD", - "background-color": "#d9d9d9", - "background-opacity": "0.2", - "color": "#EBECF0", - "text-outline-color": "#000000", - "width": "3px", - "height": "3x", - "font-size": "8px", - "z-index": "1" - } - }, - { - "selector": "node:selected", - "style": { - "border-width": "1.5px", - "border-color": "#282828", - "border-opacity": "0.5", - "background-color": "#77828C", - "text-outline-color": "#282828" - } - }, - { - "selector": "node[name*=\"statusGreen\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#F5F5F5", - "border-width": "0.5", - "border-color": "#00A500" - } - }, - { - "selector": "node[name*=\"statusRed\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#FD1C03", - "border-width": "0.5", - "border-color": "#AD0000" - } - }, - { - "selector": "node[topoViewerRole=\"pe\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"p\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"controller\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-controller-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"pon\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-pon-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"dcgw\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-dcgw-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"leaf\"]", - "style": { - "background-image": "images/clab-leaf-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"rgw\"]", - "style": { - "background-image": "images/clab-rgw-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"super-spine\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-spine-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"spine\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-spine-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"server\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-server-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"bridge\"]", - "style": { - "width": "8", - "height": "8", - "background-image": "images/clab-bridge-light-grey.png", - "background-fit": "cover" - } - }, - { - "selector": "edge", - "style": { - "targetArrowShape": "none", - "source-text-offset": 13, - "target-text-offset": 13, - "font-size": "7px", - "source-label": "data(sourceEndpoint)", - "target-label": "data(targetEndpoint)", - "arrow-scale": "0.5", - "color": "#FFFF", - "text-outline-width": "0.3px", - "text-outline-color": "#FFFFFF", - "text-background-color": "#CACBCC", - "text-background-opacity": 0.7, - "text-background-shape": "roundrectangle", - "text-background-padding": "1px", - "curve-style": "bezier", - "opacity": "1", - "line-color": "#969799", - "width": "1.5", - "overlay-padding": "2px" - } - }, - { - "selector": ".edgeEndpointLabel", - "style": { - "source-label": "data(sourceEndpoint)", - "target-label": "data(targetEndpoint)" - } - }, - {"selector": "node.unhighlighted", "style": {"opacity": "0.2"}}, - {"selector": "edge.unhighlighted", "style": {"opacity": "0.05"}}, - {"selector": ".highlighted", "style": {"z-index": "999999"}}, - { - "selector": "node.highlighted", - "style": { - "border-width": "7px", - "border-color": "#282828", - "border-opacity": "0.5", - "background-color": "#282828", - "text-outline-color": "#282828" - } - }, - {"selector": "edge.filtered", "style": {"opacity": "0"}}, - - {"selector": ".spf", "style": - {"opacity": "1", - "line-color": "#FF0000", - "line-style": "solid" - } - }, - - - {"selector": "edge[group=\"coexp\"]", "style": {"line-color": "#d0b7d5"}}, - {"selector": "edge[group=\"coloc\"]", "style": {"line-color": "#a0b3dc"}}, - {"selector": "edge[group=\"gi\"]", "style": {"line-color": "#90e190"}}, - {"selector": "edge[group=\"path\"]", "style": {"line-color": "#9bd8de"}}, - {"selector": "edge[group=\"pi\"]", "style": {"line-color": "#eaa2a2"}}, - {"selector": "edge[group=\"predict\"]", "style": {"line-color": "#f6c384"}}, - {"selector": "edge[group=\"spd\"]", "style": {"line-color": "#dad4a2"}}, - {"selector": "edge[group=\"spd_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"user\"]", "style": {"line-color": "#f0ec86"}} -] \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/css/cy-style.json b/rawTopoFile/topoviewer/html-static/css/cy-style.json deleted file mode 100644 index 2d877a5c5..000000000 --- a/rawTopoFile/topoviewer/html-static/css/cy-style.json +++ /dev/null @@ -1,256 +0,0 @@ -[ - { - "selector": "core", - "style": { - "selection-box-color": "#AAD8FF", - "selection-box-border-color": "#8BB0D0", - "selection-box-opacity": "0.5" - } - }, - { - "selector": "node", - "style": { - "shape": "rectangle", - "width": "10", - "height": "10", - "content": "data(name)", - "label": "data(name)", - "font-size": "6px", - "text-valign": "bottom", - "text-halign": "center", - "background-color": "#8F96AC", - "text-outline-color": "#F2F2F2", - "text-outline-width": "0.3px", - "color": "#353535", - "overlay-padding": "0.3px", - "z-index": "10" - } - }, - { - "selector": "node[?attr]", - "style": { - "shape": "rectangle", - "background-color": "#aaa", - "text-outline-color": "#aaa", - "width": "10px", - "height": "10x", - "font-size": "8px", - "z-index": "1" - } - }, - { - "selector": "node[?query]", - "style": {"background-clip": "none", "background-fit": "contain"} - }, - { - "selector": "node:parent", - "style": { - "shape": "rectangle", - "border-width": "0.5px", - "border-color": "#DDDDDD", - "background-color": "#d9d9d9", - "background-opacity": "0.2", - "text-outline-color": "#F2F2F2", - "width": "3px", - "height": "3x", - "font-size": "5px", - "z-index": "1" - } - }, - { - "selector": "node:selected", - "style": { - "border-width": "1.5px", - "border-color": "#F2F2F2", - "border-opacity": "0.5", - "background-color": "#77828C", - "text-outline-color": "#F2F2F2" - } - }, - { - "selector": "node[name*=\"statusGreen\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#0FFF50", - "border-width": "0.5", - "border-color": "#00A500" - } - }, - { - "selector": "node[name*=\"statusRed\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#FD1C03", - "border-width": "0.5", - "border-color": "#AD0000" - } - }, - { - "selector": "node[topoViewerRole=\"pe\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"p\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"controller\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-controller-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"pon\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-pon-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"dcgw\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-dcgw-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"leaf\"]", - "style": { - "background-image": "images/clab-leaf-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"rgw\"]", - "style": { - "background-image": "images/clab-rgw-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"super-spine\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-spine-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"spine\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-spine-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"server\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-server-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"bridge\"]", - "style": { - "width": "8", - "height": "8", - "background-image": "images/clab-bridge-light-grey.png", - "background-fit": "cover" - } - }, - { - "selector": "edge", - "style": { - "targetArrowShape": "none", - "source-text-offset": 10, - "target-text-offset": 10, - "font-size": "5px", - "source-label": "data(sourceEndpoint)", - "target-label": "data(targetEndpoint)", - "arrow-scale": "0.5", - "color": "#FFFFFF", - "text-outline-width": "0.3px", - "text-outline-color": "#000000", - "text-background-color": "#000000", - "text-background-opacity": 0.9, - "text-background-shape": "roundrectangle", - "text-background-padding": "1px", - "curve-style": "bezier", - "opacity": "0.5", - "line-color": "#B1BCC8", - "width": "1.5", - "overlay-padding": "2px" - } - }, - { - "selector": ".edgeEndpointLabel", - "style": { - "source-label": "data(sourceEndpoint)", - "target-label": "data(targetEndpoint)" - } - }, - {"selector": "node.unhighlighted", "style": {"opacity": "0.2"}}, - {"selector": "edge.unhighlighted", "style": {"opacity": "0.05"}}, - {"selector": ".highlighted", "style": {"z-index": "999999"}}, - { - "selector": "node.highlighted", - "style": { - "border-width": "6px", - "border-color": "#F2F2F2", - "border-opacity": "0.5", - "background-color": "#F2F2F2", - "text-outline-color": "#F2F2F2" - } - }, - {"selector": "edge.filtered", "style": {"opacity": "0"}}, - - {"selector": ".spf", "style": - {"opacity": "1", - "line-color": "#FF0000", - "line-style": "solid" - } - }, - - - {"selector": "edge[group=\"coexp\"]", "style": {"line-color": "#d0b7d5"}}, - {"selector": "edge[group=\"coloc\"]", "style": {"line-color": "#a0b3dc"}}, - {"selector": "edge[group=\"gi\"]", "style": {"line-color": "#90e190"}}, - {"selector": "edge[group=\"path\"]", "style": {"line-color": "#9bd8de"}}, - {"selector": "edge[group=\"pi\"]", "style": {"line-color": "#eaa2a2"}}, - {"selector": "edge[group=\"predict\"]", "style": {"line-color": "#f6c384"}}, - {"selector": "edge[group=\"spd\"]", "style": {"line-color": "#dad4a2"}}, - {"selector": "edge[group=\"spd_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"user\"]", "style": {"line-color": "#f0ec86"}} -] \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/css/style.css b/rawTopoFile/topoviewer/html-static/css/style.css deleted file mode 100755 index 5662cb1d7..000000000 --- a/rawTopoFile/topoviewer/html-static/css/style.css +++ /dev/null @@ -1,357 +0,0 @@ -body { - font: 14px helvetica neue, helvetica, arial, sans-serif; -} -#settings { - /*top: 70px; - */ - bottom: 0px; - right: 25px; - width: 300px; - position: absolute; -} - - -.has-background-4a { - z-index: 9999; - background-color:rgba(70,86, 246, 1); - box-shadow: 0px 3px 6px rgba(255, 255, 255, 0.4); -} -.panel-block { - background-color: white; -} -.panel { - box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.4); - background-color: white; -} -.column { - background-color: white; -} -.box { - background-color: white; -} -.panel-tabs { - background-color: white; -} -.panel-tabContainer { - background-color: white; - padding: 0px 0px 0px 0px; -} -#sidebar { - background-color: white; -} - -#edgeLength, #nodeSpacing #nodeGap { - width: 100%; -} -#cy { - height: 100vh; - position: fixed; - left: 0em; - right: 0em; - top: 5em; - bottom: 0em; -} - -#logo { - top: 20px; - left: 30px; - z-index: 9999; - position: absolute; -} - -#viewport-buttons { - top: 75px; - left: 40px; - position: fixed; - z-index: 9999; -} - -.viewport-drawer { - top: 75px; - left: 90px; - width: 300px; - position: fixed; - z-index: 9998; -} - -.panel-tabContainer { - padding: 0px 0px 0px 0px; -} -.is-smallest { - font-size: 10px; -} -.is-smaller { - font-size: 12.5px; -} -.is-smallish { - font-size: 13px; -} -.is-smallest-element { - font-size: 11px; - padding: 0px 8px; - height: 24px; -} -.vertical-align-top { - display: flex; - flex-direction: column; - align-items: flex-start; - padding-top: 0 -} -.button { - height: 24px; -} -.button-modal { - height: 30px; -} -.input { - height: 24px; -} -.link-impairment-widht { - width: 190px; - white-space: wrap; -} -.drawer-box-input-widht { - width: 100px; - white-space: nowrap; -} -.with-outline { - position: relative; -} -.with-outline::before { - content: ''; - position: absolute; - bottom: 0; - left: 0; - width: 100%; - border-bottom: 2px solid #3498db; - pointer-events: none; -} -.hover-text.is-hidden { - display: none; -} -.hover-text { - position: absolute; - border: 1px solid #e8a010; - padding: 2px; - padding-left: 5px; - padding-right: 5px; - box-shadow: 2px 3px 4px rgba(0, 0, 0, 0.6); - z-index: 100; -} -@media (prefers-reduced-motion: reduce) { -} -.notification { - transform: translateY(60px); -} - -#panel-node { - top: 85px; - right: 40px; - width: 340px; - max-height: 700px; - overflow-y: auto; - overflow-x: hidden; - position: fixed; -} - -#panel-link { - top: 85px; - right: 40px; - width: 340px; - max-height: 700px; - overflow-y: auto; - overflow-x: hidden; - position: fixed; -} - -#panel-introduction { - bottom: 10px; - right: 40px; - width: 340px; - max-height: 700px; - overflow-y: auto; - position: fixed; -} - -#panel-log-messages { - bottom: 10px; - left: 40px; - width: 640px; - max-height: 700px; - overflow-y: auto; - position: fixed; -} - -#panel-topoviewer-helper { - bottom: 10px; - right: 40px; - width: 340px; - max-height: 700px; - overflow-y: auto; - position: fixed; -} - -#panel-topoviewer-about { - bottom: 10px; - right: 40px; - width: 340px; - max-height: 700px; - overflow-y: auto; - position: fixed; -} - -#panel-backup-restore { - top: 100px; - right: 100px; - left: 100px; - height: calc(85vh - 50px); - position: fixed; - display: block; -} - -#sidebar { - height: 100vh; - width: 60px; - position: fixed; - left: 5em; -} - -#sidebar-control { - height: 30px; -} - -#drawer { - height: 100vh; - width: 300px; - position: fixed; - left: calc(5em + 60px); - display: none; /* Initially hidden */ - -} - -#editor-container { - height: calc(80vh - 80px); - /* height: auto; */ - width: 100%; - overflow: hidden; -} - -#original-title, #modified-title { - width: 50%; - text-align: center; -} - -#loading-spinner-global-button { - width: 50px; - height: 50px; -} - -.loading { - position: absolute; - top: 50%; - left: 50%; - width: 100px ; - height: 100px ; - transform: translate(-50%, -50%); -} -.monaco-editor .inputarea { - position: fixed ; - top: 0 ; - left: 0 ; - width: 100px ; - height: 100px ; -} - -[data-theme=dark], -.theme-dark { - .has-background-4a { - z-index: 9999; - background-color:rgba(24,24, 24, 1); - box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.4); - } - .panel-block { - background-color: rgba(40, 40, 40, 1); - } - .panel { - box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.4); - background-color: rgba(40, 40, 40, 1); - } - .column { - background-color: rgba(40, 40, 40, 1); - } - .box { - background-color: rgba(40, 40, 40, 1); - box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.4); - } - .panel-tabs { - background-color: rgba(40, 40, 40, 1); - } - .panel-tabContainer { - background-color: rgba(40, 40, 40, 1); - padding: 0px 0px 0px 0px; - } - #sidebar { - background-color: rgba(40, 40, 40, 1); - } - #drawer { - background-color: rgba(76,82, 97, 1); - } - .ViewPortDrawer { - background-color: rgba(40, 40, 40, 1); - box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.4); - } - #ViewPortButtons { - background-color: rgba(40, 40, 40, 1); - box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.4); - } - - #viewport-buttons { - background-color: rgba(40, 40, 40, 1); - box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.4); - } - .button.is-sidebar { - border-top-right-radius: 2px; - border-bottom-right-radius: 2px; - outline: none; - background-color: rgba(54,58, 69, 1); - height: 50px; - --sidebar-button-background-color-default:rgba(40, 40, 40, 1); - --sidebar-button-background-color-active: rgba(76, 82, 97, 1); - } - .button.is-sidebar:hover { - background-color: rgba(40, 40, 40, 1); - border: rgba(54,58, 69, 1); - } -} - -[data-theme=light], -.theme-light { - .has-background-4a { - z-index: 9999; - background-color:rgba(70,86, 246, 1); - box-shadow: 0px 3px 6px rgba(255, 255, 255, 0.4); - } - .panel-block { - background-color: white; - } - .panel { - box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.4); - background-color: white; - } - .column { - background-color: white; - } - .box { - background-color: white; - } - .panel-tabs { - background-color: white; - } - .panel-tabContainer { - background-color: white; - padding: 0px 0px 0px 0px; - } - #sidebar { - background-color: white; - } -} diff --git a/rawTopoFile/topoviewer/html-static/images/clab-bridge-light-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-bridge-light-grey.png deleted file mode 100755 index d92de143b..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-bridge-light-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-controller-light-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-controller-light-blue.png deleted file mode 100755 index 139c01946..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-controller-light-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-dcgw-dark-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-dcgw-dark-blue.png deleted file mode 100755 index d1ae1b2b6..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-dcgw-dark-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-dcgw-dark-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-dcgw-dark-grey.png deleted file mode 100755 index 8d2b8ca1b..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-dcgw-dark-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-dcgw-light-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-dcgw-light-blue.png deleted file mode 100755 index 856837703..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-dcgw-light-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-dcgw-light-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-dcgw-light-grey.png deleted file mode 100755 index 90f25ae69..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-dcgw-light-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-generic-router-dark-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-generic-router-dark-blue.png deleted file mode 100755 index 39a38911e..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-generic-router-dark-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-generic-router-dark-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-generic-router-dark-grey.png deleted file mode 100755 index 16e024df3..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-generic-router-dark-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-generic-router-light-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-generic-router-light-blue.png deleted file mode 100755 index 5f7b80ac0..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-generic-router-light-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-generic-router-light-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-generic-router-light-grey.png deleted file mode 100755 index c933ab257..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-generic-router-light-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-leaf-dark-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-leaf-dark-blue.png deleted file mode 100755 index ca570ddbe..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-leaf-dark-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-leaf-dark-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-leaf-dark-grey.png deleted file mode 100755 index 970297ca9..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-leaf-dark-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-leaf-light-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-leaf-light-blue.png deleted file mode 100755 index b5485fbc0..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-leaf-light-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-leaf-light-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-leaf-light-grey.png deleted file mode 100755 index 461711d99..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-leaf-light-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-pe-dark-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-pe-dark-blue.png deleted file mode 100755 index 97382f89d..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-pe-dark-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-pe-dark-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-pe-dark-grey.png deleted file mode 100755 index 66677f8ad..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-pe-dark-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-pe-light-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-pe-light-blue.png deleted file mode 100755 index 3ec49df95..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-pe-light-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-pe-light-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-pe-light-grey.png deleted file mode 100755 index 9a3736011..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-pe-light-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-pon-dark-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-pon-dark-blue.png deleted file mode 100755 index 59dec08b2..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-pon-dark-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-rgw-dark-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-rgw-dark-blue.png deleted file mode 100755 index ff5f3e9e6..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-rgw-dark-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-rgw-light-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-rgw-light-blue.png deleted file mode 100755 index 867014a33..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-rgw-light-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-server-dark-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-server-dark-blue.png deleted file mode 100755 index 80eea7a0e..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-server-dark-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-spine-dark-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-spine-dark-blue.png deleted file mode 100755 index 7e3d1a6df..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-spine-dark-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-spine-dark-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-spine-dark-grey.png deleted file mode 100755 index a9379c872..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-spine-dark-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-spine-light-blue.png b/rawTopoFile/topoviewer/html-static/images/clab-spine-light-blue.png deleted file mode 100755 index 3f25eed51..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-spine-light-blue.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/clab-spine-light-grey.png b/rawTopoFile/topoviewer/html-static/images/clab-spine-light-grey.png deleted file mode 100755 index 1b05ccf3f..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/clab-spine-light-grey.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/nokia-logo.png b/rawTopoFile/topoviewer/html-static/images/nokia-logo.png deleted file mode 100644 index 3172b3b78..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/nokia-logo.png and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/images/nu-logo.jpg b/rawTopoFile/topoviewer/html-static/images/nu-logo.jpg deleted file mode 100755 index 1190d0b8c..000000000 Binary files a/rawTopoFile/topoviewer/html-static/images/nu-logo.jpg and /dev/null differ diff --git a/rawTopoFile/topoviewer/html-static/js/backupRestore.js b/rawTopoFile/topoviewer/html-static/js/backupRestore.js deleted file mode 100644 index 9091825eb..000000000 --- a/rawTopoFile/topoviewer/html-static/js/backupRestore.js +++ /dev/null @@ -1,521 +0,0 @@ - - -var files = []; -var filteredFiles = []; -var OriginalModelFileName; - -// environments variables -var routerName -var routerID -var routerKind -var routerUsername -var routerPassword -var workingDirectory -var clabName - -// Define default kind credential -const supportedRouterKindsDefaultCredential = [ - ["srl", "admin", "NokiaSrl1!"], - ["nokia_srl", "admin", "NokiaSrl1!"], - ["vr-sros", "admin", "admin"], - ["nokia_sros", "admin", "admin"], - ["vr-vmx", "admin", "admin@123"], - ["vr-juniper_vmx", "admin", "admin@123"], - ["vr-xrv9k", "clab", "clab@123"], - ["vr-cisco_xrv9k", "clab", "clab@123"] -]; - -// Function to check if a router kind is supported -function isRouterKindSupported(routerKind) { - return supportedRouterKindsDefaultCredential.some(function(entry) { - const kind = entry[0]; // Extract the router kind from the entry - return kind === routerKind; - }); -} - -function getCredentialsForRouterKind(routerKind) { - // Find the entry for the given router kind - const credentialEntry = supportedRouterKindsDefaultCredential.find(function(entry) { - const kind = entry[0]; - return kind === routerKind; - }); - - // Check if the credential entry was found - if (credentialEntry) { - const [, user, password] = credentialEntry; // Destructure to get user and password - return { user, password }; - } - - return null; // Return null if not found -} - -async function backupRestoreNodeConfig(event) { - - // init environments variables - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - workingDirectory = environments["working-directory"]; - clabName = environments["clab-name"]; - nodeData = findCytoElementByLongname(environments["EnvCyTopoJsonBytes"], globalSelectedNode) - routerName = globalSelectedNode; - routerID = nodeData["data"]["extraData"]["mgmtIpv4Addresss"] - routerKind = nodeData["data"]["extraData"]["kind"]; - credentials = getCredentialsForRouterKind(routerKind); - routerUsername = credentials.user - routerPassword = credentials.password - - // console.log("backupRestoreNodeConfig - credentials: ", routerUsername + ":" + routerPassword) - // console.log("backupRestoreNodeConfig - routerName: ", routerName) - console.log("backupRestoreNodeConfig - routerID: ", routerID) - - // if (supportedRouterKinds.includes(routerKind)) { - if (isRouterKindSupported(routerKind)) { - - - // init the backupRestore monaco editor - initializeMonacoEditor() - - // init the running config to be loaded - handleLoadRunningConfig(event) - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - try { - - document.getElementById("panel-backup-restore").style.display = "block"; - document.getElementById("panel-backup-restore").style.height = "calc(85vh - 50px)"; - document.getElementById("editor-container").style.height = "calc(80vh - 80px)"; - - // Output the values to console - console.log('routerID:', routerID); - console.log('routerName:', routerName); - - // Update the text of the file browser title - const fileBrowserTitle = document.getElementById('diff-panel-title'); - if (fileBrowserTitle && routerID) { - fileBrowserTitle.textContent = `${routerName}`; - } - if (routerName) { - loadFileList(routerName); - } else { - console.error('No routerName specified in URL'); - } - - const searchInput = document.getElementById('search-input'); - searchInput.addEventListener('input', (event) => { - const filter = event.target.value.toLowerCase(); - console.log ("filter", filter) - filterFileList(filter); - - }); - - // Add event listener to the buttonRestoreConfig - const buttonRestoreConfig = document.getElementById('buttonRestoreConfig'); - buttonRestoreConfig.addEventListener('click', handleRestoreConfig); - - // Add event listener to the buttonBackupConfig - const buttonBackupConfig = document.getElementById('buttonBackupConfig'); - buttonBackupConfig.addEventListener('click', handleBackupConfig); - - // Add event listener to the buttonLoadRunningConfig - const buttonLoadRunningConfig = document.getElementById('buttonLoadRunningConfig'); - buttonLoadRunningConfig.addEventListener('click', handleLoadRunningConfig); - - - } catch (error) { - console.error('Error executing restore configuration:', error); - } - } else { - - appendMessage( - `Router Kind ${routerKind} is not supported for backup-restore`, - ); - bulmaToast.toast({ - message: `Sorry, Router Kind ${routerKind} is not supported for backup-restore 👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - - } - - - -} - -// Function to initialize the Monaco Editor with default content -function initializeMonacoEditor() { - // Create the original and modified models with default messages - const originalModel = monaco.editor.createModel( - 'Please select the configuration file you wish to restore.. \nthen click "Restore Saved Config. \nThe selected config will be displayed here. \n\n\nMeanwhile please enjoy this poem.\n \n Die Eule \n ----\n Abends gegen neune \n In der alten scheune \n Hört man ien Geheule \n So ruft die Schleireule \n Schlafen nachts die Leute \n Jagt sie ihre Beute \n Schuhu Schuhu \n Um mitternacht ist Ruh\n\n', - 'text/plain' - ); - const modifiedModel = monaco.editor.createModel( - 'Please click the "Backup Running Config" button to save the current configuration. \nThe results of the backup will be displayed here.', - 'text/plain' - ); - - // Set up the diff editor with the created models - diffEditor.setModel({ - original: originalModel, - modified: modifiedModel - }); -} - -// Monaco Editor setup -require.config({ - paths: { - 'vs': 'https://cdn.jsdelivr.net/npm/monaco-editor@0.50.0/min/vs' - } -}); -require(['vs/editor/editor.main'], function() { - const colorScheme = detectColorScheme(); - let vsCodeTheme = "vs"; // Default theme - if (colorScheme === "dark") { - vsCodeTheme = "vs-dark"; - } else if (colorScheme !== "light") { - console.log("unsupported colorScheme: ", colorScheme); - } - - // Initialize the Monaco Editor with configuration options - window.diffEditor = monaco.editor.createDiffEditor(document.getElementById('editor-container'), { - theme: vsCodeTheme, - originalEditable: false, - readOnly: true, - smoothScrolling: false, - fontFamily: "menlo", - fontSize: 11, - fontLigatures: true, - enableSplitViewResizing: true, - automaticLayout: true, - splitViewDefaultRatio: 0.52, - renderGutterMenu: false, - }); - - // Call the initialization function to set default content - initializeMonacoEditor(); - - // Ensure the editor layout adjusts when the window resizes - window.addEventListener('resize', () => { - diffEditor.layout(); - }); - - // Adjust the layout after initialization - diffEditor.layout(); -}); - -// Function to handle loading running configuration -async function handleLoadRunningConfig(event) { - - - event.preventDefault(); // Prevent default form submission if inside a form - var configName = OriginalModelFileName; - - // Output the values to console - console.log('############################################################'); - console.log('routerID:', routerID); - console.log('routerName:', routerName); - - const arg01 = routerID; // Replace with actual arguments as needed - const arg02 = routerName; // Replace with actual arguments as needed - const arg03 = 'get'; // Replace with actual arguments as needed - - - try { - actionName = "backupRestoreScript"; - - showLoadingSpinnerGlobal() - appendMessage( - "Loading Running Config", - ); - bulmaToast.toast({ - message: `Alright, we're Loading the Running Config. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - - console.log("handleLoadRunningConfig - showLoadingSpinner") - var postPayload = []; - - // Create an object with attributes and values - var payload = { - routerKind: routerKind, - routerID: routerID, - routerUsername: routerUsername, - routerPassword: routerPassword, - configNamePrefix: routerName, - backupPath: `${workingDirectory}/html-public/nokia-ServiceProvider/node-backup/${routerName}`, - action: "running" - }; - - var postPayloadJSON = JSON.stringify(payload); - postPayload[0] = postPayloadJSON; - await sendRequestToEndpointPost("/node-backup-restore", postPayload); - - loadFileList(routerName); - loadFileContentModified(`${routerName}-running.cfg`); - - hideLoadingSpinnerGlobal() - - } catch (error) { - console.error('Error executing load running configuration:', error); - } - - -} - -// Function to handle restore configuration - async function handleRestoreConfig(event) { - event.preventDefault(); // Prevent default form submission if inside a form - var configName = OriginalModelFileName; - - // Output the values to console - console.log('############################################################'); - console.log('routerID:', routerID); - console.log('routerName:', routerName); - console.log("OriginalModelFileName: ", OriginalModelFileName); - console.log("configName: ", configName); - - try { - actionName = "backupRestoreScript"; - - showLoadingSpinnerGlobal() - appendMessage( - "Restoring up the Config", - ); - bulmaToast.toast({ - message: `Alright, we're restoring the config. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - var postPayload = []; - - // Create an object with attributes and values - var payload = { - routerKind: routerKind, - routerID: routerID, - routerUsername: routerUsername, - routerPassword: routerPassword, - configNamePrefix: configName, - backupPath: `${workingDirectory}/html-public/${clabName}/node-backup/${routerName}`, - action: "restore" - }; - - var postPayloadJSON = JSON.stringify(payload); - postPayload[0] = postPayloadJSON; - console.log("handleRestoreConfig - postPayload : ", postPayload); - await sendRequestToEndpointPost("/node-backup-restore", postPayload); - loadFileList(routerName); - hideLoadingSpinnerGlobal() - - } catch (error) { - console.error('Error executing restore configuration:', error); - } - } - -// Function to handle backup configuration -async function handleBackupConfig(event) { - event.preventDefault(); // Prevent default form submission if inside a form - var configName = OriginalModelFileName; - - // Output the values to console - console.log('############################################################'); - console.log('routerID:', routerID); - console.log('routerName:', routerName); - console.log("OriginalModelFileName: ", OriginalModelFileName); - - const arg01 = routerID; // Replace with actual arguments as needed - const arg02 = routerName; // Replace with actual arguments as needed - const arg03 = 'backup'; // Replace with actual arguments as needed - - try { - actionName = "backupRestoreScript"; - - showLoadingSpinnerGlobal() - appendMessage( - "Backing up the Config", - ); - bulmaToast.toast({ - message: `Alright, we're making the config backup. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - - var postPayload = []; - - // Create an object with attributes and values - var payload = { - routerKind: routerKind, - routerID: routerID, - routerUsername: routerUsername, - routerPassword: routerPassword, - configNamePrefix: routerName, - backupPath: `${workingDirectory}/html-public/${clabName}/node-backup/${routerName}`, - action: "backup" - }; - - var postPayloadJSON = JSON.stringify(payload); - postPayload[0] = postPayloadJSON; - console.log("handleBackupConfig - postPayload : ", postPayload); - await sendRequestToEndpointPost("/node-backup-restore", postPayload); - loadFileList(routerName); - - hideLoadingSpinnerGlobal() - - } catch (error) { - console.error('Error executing backup configuration:', error); - } -} - -function loadFileList(routerName) { - fetch(`/files?RouterName=${encodeURIComponent(routerName)}`) - .then(response => response.json()) - .then(data => { - if (!data || !data.files || data.files.length === 0) { - console.warn('No backup files found for this router.'); - // Handle empty response here, e.g., show a message to the user - renderFileList([]); - } else { - files = data.files; - let filteredFileList = files.filter(file => !file.includes('running')); - - console.log("loadFileList: ", filteredFileList) - renderFileList(filteredFileList); - } - }) - .catch(error => console.error('Error fetching file list:', error)); -} - -function renderFileList(fileList) { - const panel = document.getElementById('panel-file-browser'); - const searchBox = panel.firstElementChild; - const searchInput = document.getElementById('search-input'); - const searchValue = searchInput.value; - - panel.innerHTML = ''; - panel.appendChild(searchBox); - - fileList.forEach(file => { - const fileElement = document.createElement('a'); - fileElement.classList.add('panel-block'); - fileElement.innerHTML = ` - - - - ${file} - `; - fileElement.addEventListener('click', () => loadFileContentOriginal(file)); - panel.appendChild(fileElement); - }); - - searchInput.value = searchValue; - searchInput.focus(); -} - -function filterFileList(filter) { - - console.log("filteredFiles() - filter: ", filter) - console.log("filteredFiles() - files: ", files) - - - filteredFiles = files.filter(file => file.toLowerCase().includes(filter)); - - console.log("filteredFiles() - filteredFiles: ", filteredFiles) - - renderFileList(filteredFiles); -} - -function loadFileContentOriginal(fileName) { - showLoadingSpinnerGlobal(); - - // set Global Var - OriginalModelFileName = fileName; - console.log("OriginalModelFileName", OriginalModelFileName) - - // Get the current URL - const currentUrl = new URL(window.location.href); - - // Get query parameters using URLSearchParams - const params = new URLSearchParams(currentUrl.search); - - // Output the values to console - console.log('routerID:', routerID); - console.log('routerName:', routerName); - - fetch(`/file?RouterName=${encodeURIComponent(routerName)}&name=${encodeURIComponent(fileName)}`) - .then(response => response.json()) - .then(data => { - - - if (data.success) { - const originalModel = monaco.editor.createModel(data.content, 'text/plain'); - diffEditor.setModel({ - original: originalModel, - modified: diffEditor.getModel() - .modified - }); - } else { - console.error('Error loading file content:', data.message); - } - hideLoadingSpinnerGlobal(); - }) - .catch(error => { - console.error('Error fetching file content:', error); - hideLoadingSpinnerGlobal(); - }); -} - -function loadFileContentModified(fileName) { - showLoadingSpinnerGlobal(); - - // set Global Var - OriginalModelFileName = fileName; - console.log("OriginalModelFileName", OriginalModelFileName) - - // Get the current URL - const currentUrl = new URL(window.location.href); - - // Get query parameters using URLSearchParams - const params = new URLSearchParams(currentUrl.search); - - // Output the values to console - console.log('routerID:', routerID); - console.log('routerName:', routerName); - - fetch(`/file?RouterName=${encodeURIComponent(routerName)}&name=${encodeURIComponent(fileName)}`) - .then(response => response.json()) - .then(data => { - - - if (data.success) { - const modifiedModel = monaco.editor.createModel(data.content, 'text/plain'); - diffEditor.setModel({ - original: diffEditor.getModel() - .original, - modified: modifiedModel - }); - } else { - console.error('Error loading file content:', data.message); - } - hideLoadingSpinnerGlobal(); - }) - .catch(error => { - - console.error('Error fetching file content:', error); - hideLoadingSpinnerGlobal(); - }); -} - diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/index.html b/rawTopoFile/topoviewer/html-static/js/cloudshell/index.html deleted file mode 100644 index 8c08bb170..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/index.html +++ /dev/null @@ -1,65 +0,0 @@ - - - - - - - - - - - - - - - - - - - - -
- - - - - - diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/.package-lock.json b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/.package-lock.json deleted file mode 100755 index 70f8cef19..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/.package-lock.json +++ /dev/null @@ -1,53 +0,0 @@ -{ - "name": "cloudshell", - "version": "1.0.0", - "lockfileVersion": 2, - "requires": true, - "packages": { - "node_modules/xterm": { - "version": "4.11.0", - "resolved": "https://registry.npmjs.org/xterm/-/xterm-4.11.0.tgz", - "integrity": "sha512-NeJH909WTO2vth/ZlC0gkP3AGzupbvVHVlmtrpBw56/sGFXaF9bNdKgqKa3tf8qbGvXMzL2JhCcHVklqFztIRw==" - }, - "node_modules/xterm-addon-attach": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/xterm-addon-attach/-/xterm-addon-attach-0.6.0.tgz", - "integrity": "sha512-Mo8r3HTjI/EZfczVCwRU6jh438B4WLXxdFO86OB7bx0jGhwh2GdF4ifx/rP+OB+Cb2vmLhhVIZ00/7x3YSP3dg==", - "peerDependencies": { - "xterm": "^4.0.0" - } - }, - "node_modules/xterm-addon-fit": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/xterm-addon-fit/-/xterm-addon-fit-0.5.0.tgz", - "integrity": "sha512-DsS9fqhXHacEmsPxBJZvfj2la30Iz9xk+UKjhQgnYNkrUIN5CYLbw7WEfz117c7+S86S/tpHPfvNxJsF5/G8wQ==", - "peerDependencies": { - "xterm": "^4.0.0" - } - }, - "node_modules/xterm-addon-serialize": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/xterm-addon-serialize/-/xterm-addon-serialize-0.5.0.tgz", - "integrity": "sha512-NueZvbBGQvWDNBhA02/ZkPDq2yFlCqvwy7XhYLqRWAsvjGYkqZg3Py9eoLw4j7+WIhuLK4czswUYa2ntwKC3QQ==", - "peerDependencies": { - "xterm": "^4.0.0" - } - }, - "node_modules/xterm-addon-unicode11": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/xterm-addon-unicode11/-/xterm-addon-unicode11-0.2.0.tgz", - "integrity": "sha512-rjFDItPc/IDoSiEnoDFwKroNwLD/7t9vYKENjrcKVZg5tgJuuUj8D4rZtP6iVCjSB1LTLYmUs4L/EmCqIyLR/Q==", - "peerDependencies": { - "xterm": "^4.0.0" - } - }, - "node_modules/xterm-addon-web-links": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/xterm-addon-web-links/-/xterm-addon-web-links-0.4.0.tgz", - "integrity": "sha512-xv8GeiINmx0zENO9hf5k+5bnkaE8mRzF+OBAr9WeFq2eLaQSudioQSiT34M1ofKbzcdjSsKiZm19Rw3i4eXamg==", - "peerDependencies": { - "xterm": "^4.0.0" - } - } - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/LICENSE b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/LICENSE deleted file mode 100755 index e597698cc..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/LICENSE +++ /dev/null @@ -1,19 +0,0 @@ -Copyright (c) 2017, The xterm.js authors (https://github.com/xtermjs/xterm.js) - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/README.md b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/README.md deleted file mode 100755 index 67ebf17b0..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/README.md +++ /dev/null @@ -1,22 +0,0 @@ -## xterm-addon-attach - -An addon for [xterm.js](https://github.com/xtermjs/xterm.js) that enables attaching to a web socket. This addon requires xterm.js v4+. - -### Install - -```bash -npm install --save xterm-addon-attach -``` - -### Usage - -```ts -import { Terminal } from 'xterm'; -import { AttachAddon } from 'xterm-addon-attach'; - -const terminal = new Terminal(); -const attachAddon = new AttachAddon(webSocket); -terminal.loadAddon(attachAddon); -``` - -See the full [API](https://github.com/xtermjs/xterm.js/blob/master/addons/xterm-addon-attach/typings/xterm-addon-attach.d.ts) for more advanced usage. diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/lib/xterm-addon-attach.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/lib/xterm-addon-attach.js deleted file mode 100755 index d5a892909..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/lib/xterm-addon-attach.js +++ /dev/null @@ -1,2 +0,0 @@ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.AttachAddon=e():t.AttachAddon=e()}(window,(function(){return function(t){var e={};function n(o){if(e[o])return e[o].exports;var r=e[o]={i:o,l:!1,exports:{}};return t[o].call(r.exports,r,r.exports,n),r.l=!0,r.exports}return n.m=t,n.c=e,n.d=function(t,e,o){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:o})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var o=Object.create(null);if(n.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var r in t)n.d(o,r,function(e){return t[e]}.bind(null,r));return o},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=0)}([function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.AttachAddon=void 0;var o=function(){function t(t,e){this._disposables=[],this._socket=t,this._socket.binaryType="arraybuffer",this._bidirectional=!e||!1!==e.bidirectional}return t.prototype.activate=function(t){var e=this;this._disposables.push(r(this._socket,"message",(function(e){var n=e.data;t.write("string"==typeof n?n:new Uint8Array(n))}))),this._bidirectional&&(this._disposables.push(t.onData((function(t){return e._sendData(t)}))),this._disposables.push(t.onBinary((function(t){return e._sendBinary(t)})))),this._disposables.push(r(this._socket,"close",(function(){return e.dispose()}))),this._disposables.push(r(this._socket,"error",(function(){return e.dispose()})))},t.prototype.dispose=function(){this._disposables.forEach((function(t){return t.dispose()}))},t.prototype._sendData=function(t){1===this._socket.readyState&&this._socket.send(t)},t.prototype._sendBinary=function(t){if(1===this._socket.readyState){for(var e=new Uint8Array(t.length),n=0;n {\n const data: ArrayBuffer | string = ev.data;\n terminal.write(typeof data === 'string' ? data : new Uint8Array(data));\n })\n );\n\n if (this._bidirectional) {\n this._disposables.push(terminal.onData(data => this._sendData(data)));\n this._disposables.push(terminal.onBinary(data => this._sendBinary(data)));\n }\n\n this._disposables.push(addSocketListener(this._socket, 'close', () => this.dispose()));\n this._disposables.push(addSocketListener(this._socket, 'error', () => this.dispose()));\n }\n\n public dispose(): void {\n this._disposables.forEach(d => d.dispose());\n }\n\n private _sendData(data: string): void {\n // TODO: do something better than just swallowing\n // the data if the socket is not in a working condition\n if (this._socket.readyState !== 1) {\n return;\n }\n this._socket.send(data);\n }\n\n private _sendBinary(data: string): void {\n if (this._socket.readyState !== 1) {\n return;\n }\n const buffer = new Uint8Array(data.length);\n for (let i = 0; i < data.length; ++i) {\n buffer[i] = data.charCodeAt(i) & 255;\n }\n this._socket.send(buffer);\n }\n}\n\nfunction addSocketListener(socket: WebSocket, type: K, handler: (this: WebSocket, ev: WebSocketEventMap[K]) => any): IDisposable {\n socket.addEventListener(type, handler);\n return {\n dispose: () => {\n if (!handler) {\n // Already disposed\n return;\n }\n socket.removeEventListener(type, handler);\n }\n };\n}\n"],"sourceRoot":""} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/out/AttachAddon.api.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/out/AttachAddon.api.js.map deleted file mode 100755 index 6083561f9..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/out/AttachAddon.api.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"AttachAddon.api.js","sourceRoot":"","sources":["../src/AttachAddon.api.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/out/AttachAddon.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/out/AttachAddon.js deleted file mode 100755 index a607f5f7f..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/out/AttachAddon.js +++ /dev/null @@ -1,57 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.AttachAddon = void 0; -var AttachAddon = (function () { - function AttachAddon(socket, options) { - this._disposables = []; - this._socket = socket; - this._socket.binaryType = 'arraybuffer'; - this._bidirectional = (options && options.bidirectional === false) ? false : true; - } - AttachAddon.prototype.activate = function (terminal) { - var _this = this; - this._disposables.push(addSocketListener(this._socket, 'message', function (ev) { - var data = ev.data; - terminal.write(typeof data === 'string' ? data : new Uint8Array(data)); - })); - if (this._bidirectional) { - this._disposables.push(terminal.onData(function (data) { return _this._sendData(data); })); - this._disposables.push(terminal.onBinary(function (data) { return _this._sendBinary(data); })); - } - this._disposables.push(addSocketListener(this._socket, 'close', function () { return _this.dispose(); })); - this._disposables.push(addSocketListener(this._socket, 'error', function () { return _this.dispose(); })); - }; - AttachAddon.prototype.dispose = function () { - this._disposables.forEach(function (d) { return d.dispose(); }); - }; - AttachAddon.prototype._sendData = function (data) { - if (this._socket.readyState !== 1) { - return; - } - this._socket.send(data); - }; - AttachAddon.prototype._sendBinary = function (data) { - if (this._socket.readyState !== 1) { - return; - } - var buffer = new Uint8Array(data.length); - for (var i = 0; i < data.length; ++i) { - buffer[i] = data.charCodeAt(i) & 255; - } - this._socket.send(buffer); - }; - return AttachAddon; -}()); -exports.AttachAddon = AttachAddon; -function addSocketListener(socket, type, handler) { - socket.addEventListener(type, handler); - return { - dispose: function () { - if (!handler) { - return; - } - socket.removeEventListener(type, handler); - } - }; -} -//# sourceMappingURL=AttachAddon.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/out/AttachAddon.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/out/AttachAddon.js.map deleted file mode 100755 index c099fddd3..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/out/AttachAddon.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"AttachAddon.js","sourceRoot":"","sources":["../src/AttachAddon.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/src/AttachAddon.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/src/AttachAddon.ts deleted file mode 100755 index 279d1b2ee..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/src/AttachAddon.ts +++ /dev/null @@ -1,79 +0,0 @@ -/** - * Copyright (c) 2014, 2019 The xterm.js authors. All rights reserved. - * @license MIT - * - * Implements the attach method, that attaches the terminal to a WebSocket stream. - */ - -import { Terminal, IDisposable, ITerminalAddon } from 'xterm'; - -interface IAttachOptions { - bidirectional?: boolean; -} - -export class AttachAddon implements ITerminalAddon { - private _socket: WebSocket; - private _bidirectional: boolean; - private _disposables: IDisposable[] = []; - - constructor(socket: WebSocket, options?: IAttachOptions) { - this._socket = socket; - // always set binary type to arraybuffer, we do not handle blobs - this._socket.binaryType = 'arraybuffer'; - this._bidirectional = (options && options.bidirectional === false) ? false : true; - } - - public activate(terminal: Terminal): void { - this._disposables.push( - addSocketListener(this._socket, 'message', ev => { - const data: ArrayBuffer | string = ev.data; - terminal.write(typeof data === 'string' ? data : new Uint8Array(data)); - }) - ); - - if (this._bidirectional) { - this._disposables.push(terminal.onData(data => this._sendData(data))); - this._disposables.push(terminal.onBinary(data => this._sendBinary(data))); - } - - this._disposables.push(addSocketListener(this._socket, 'close', () => this.dispose())); - this._disposables.push(addSocketListener(this._socket, 'error', () => this.dispose())); - } - - public dispose(): void { - this._disposables.forEach(d => d.dispose()); - } - - private _sendData(data: string): void { - // TODO: do something better than just swallowing - // the data if the socket is not in a working condition - if (this._socket.readyState !== 1) { - return; - } - this._socket.send(data); - } - - private _sendBinary(data: string): void { - if (this._socket.readyState !== 1) { - return; - } - const buffer = new Uint8Array(data.length); - for (let i = 0; i < data.length; ++i) { - buffer[i] = data.charCodeAt(i) & 255; - } - this._socket.send(buffer); - } -} - -function addSocketListener(socket: WebSocket, type: K, handler: (this: WebSocket, ev: WebSocketEventMap[K]) => any): IDisposable { - socket.addEventListener(type, handler); - return { - dispose: () => { - if (!handler) { - // Already disposed - return; - } - socket.removeEventListener(type, handler); - } - }; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/typings/xterm-addon-attach.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/typings/xterm-addon-attach.d.ts deleted file mode 100755 index 1aa213574..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-attach/typings/xterm-addon-attach.d.ts +++ /dev/null @@ -1,21 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { Terminal, ILinkMatcherOptions, ITerminalAddon } from 'xterm'; - -declare module 'xterm-addon-attach' { - export interface IAttachOptions { - /** - * Whether input should be written to the backend. Defaults to `true`. - */ - bidirectional?: boolean; - } - - export class AttachAddon implements ITerminalAddon { - constructor(socket: WebSocket, options?: IAttachOptions); - public activate(terminal: Terminal): void; - public dispose(): void; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/LICENSE b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/LICENSE deleted file mode 100755 index 8f1789258..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/LICENSE +++ /dev/null @@ -1,19 +0,0 @@ -Copyright (c) 2019, The xterm.js authors (https://github.com/xtermjs/xterm.js) - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/README.md b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/README.md deleted file mode 100755 index 321b2cf70..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/README.md +++ /dev/null @@ -1,24 +0,0 @@ -## xterm-addon-fit - -An addon for [xterm.js](https://github.com/xtermjs/xterm.js) that enables fitting the terminal's dimensions to a containing element. This addon requires xterm.js v4+. - -### Install - -```bash -npm install --save xterm-addon-fit -``` - -### Usage - -```ts -import { Terminal } from 'xterm'; -import { FitAddon } from 'xterm-addon-fit'; - -const terminal = new Terminal(); -const fitAddon = new FitAddon(); -terminal.loadAddon(fitAddon); -terminal.open(containerElement); -fitAddon.fit(); -``` - -See the full [API](https://github.com/xtermjs/xterm.js/blob/master/addons/xterm-addon-fit/typings/xterm-addon-fit.d.ts) for more advanced usage. diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/lib/xterm-addon-fit.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/lib/xterm-addon-fit.js deleted file mode 100755 index a6b3cdc60..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/lib/xterm-addon-fit.js +++ /dev/null @@ -1,2 +0,0 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.FitAddon=t():e.FitAddon=t()}(self,(function(){return(()=>{"use strict";var e={775:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.FitAddon=void 0;var r=function(){function e(){}return e.prototype.activate=function(e){this._terminal=e},e.prototype.dispose=function(){},e.prototype.fit=function(){var e=this.proposeDimensions();if(e&&this._terminal){var t=this._terminal._core;this._terminal.rows===e.rows&&this._terminal.cols===e.cols||(t._renderService.clear(),this._terminal.resize(e.cols,e.rows))}},e.prototype.proposeDimensions=function(){if(this._terminal&&this._terminal.element&&this._terminal.element.parentElement){var e=this._terminal._core;if(0!==e._renderService.dimensions.actualCellWidth&&0!==e._renderService.dimensions.actualCellHeight){var t=window.getComputedStyle(this._terminal.element.parentElement),r=parseInt(t.getPropertyValue("height")),i=Math.max(0,parseInt(t.getPropertyValue("width"))),n=window.getComputedStyle(this._terminal.element),o=r-(parseInt(n.getPropertyValue("padding-top"))+parseInt(n.getPropertyValue("padding-bottom"))),a=i-(parseInt(n.getPropertyValue("padding-right"))+parseInt(n.getPropertyValue("padding-left")))-e.viewport.scrollBarWidth;return{cols:Math.max(2,Math.floor(a/e._renderService.dimensions.actualCellWidth)),rows:Math.max(1,Math.floor(o/e._renderService.dimensions.actualCellHeight))}}}},e}();t.FitAddon=r}},t={};return function r(i){if(t[i])return t[i].exports;var n=t[i]={exports:{}};return e[i](n,n.exports,r),n.exports}(775)})()})); -//# sourceMappingURL=xterm-addon-fit.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/lib/xterm-addon-fit.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/lib/xterm-addon-fit.js.map deleted file mode 100755 index f61662886..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/lib/xterm-addon-fit.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"sources":["webpack://FitAddon/webpack/universalModuleDefinition","webpack://FitAddon/./src/FitAddon.ts","webpack://FitAddon/webpack/bootstrap","webpack://FitAddon/webpack/startup"],"names":["root","factory","exports","module","define","amd","self","activate","terminal","this","_terminal","dispose","fit","dims","proposeDimensions","core","_core","rows","cols","_renderService","clear","resize","element","parentElement","dimensions","actualCellWidth","actualCellHeight","parentElementStyle","window","getComputedStyle","parentElementHeight","parseInt","getPropertyValue","parentElementWidth","Math","max","elementStyle","availableHeight","availableWidth","viewport","scrollBarWidth","floor","FitAddon","__webpack_module_cache__","__webpack_require__","moduleId","__webpack_modules__"],"mappings":"CAAA,SAA2CA,EAAMC,GAC1B,iBAAZC,SAA0C,iBAAXC,OACxCA,OAAOD,QAAUD,IACQ,mBAAXG,QAAyBA,OAAOC,IAC9CD,OAAO,GAAIH,GACe,iBAAZC,QACdA,QAAkB,SAAID,IAEtBD,EAAe,SAAIC,IARrB,CASGK,MAAM,WACT,M,yGCSA,IAGA,aAGE,cA4DF,OA1DS,YAAAC,SAAP,SAAgBC,GACdC,KAAKC,UAAYF,GAGZ,YAAAG,QAAP,aAEO,YAAAC,IAAP,WACE,IAAMC,EAAOJ,KAAKK,oBAClB,GAAKD,GAASJ,KAAKC,UAAnB,CAKA,IAAMK,EAAQN,KAAKC,UAAkBM,MAGjCP,KAAKC,UAAUO,OAASJ,EAAKI,MAAQR,KAAKC,UAAUQ,OAASL,EAAKK,OACpEH,EAAKI,eAAeC,QACpBX,KAAKC,UAAUW,OAAOR,EAAKK,KAAML,EAAKI,SAInC,YAAAH,kBAAP,WACE,GAAKL,KAAKC,WAILD,KAAKC,UAAUY,SAAYb,KAAKC,UAAUY,QAAQC,cAAvD,CAKA,IAAMR,EAAQN,KAAKC,UAAkBM,MAErC,GAAuD,IAAnDD,EAAKI,eAAeK,WAAWC,iBAA6E,IAApDV,EAAKI,eAAeK,WAAWE,iBAA3F,CAIA,IAAMC,EAAqBC,OAAOC,iBAAiBpB,KAAKC,UAAUY,QAAQC,eACpEO,EAAsBC,SAASJ,EAAmBK,iBAAiB,WACnEC,EAAqBC,KAAKC,IAAI,EAAGJ,SAASJ,EAAmBK,iBAAiB,WAC9EI,EAAeR,OAAOC,iBAAiBpB,KAAKC,UAAUY,SAStDe,EAAkBP,GAPjBC,SAASK,EAAaJ,iBAAiB,gBACpCD,SAASK,EAAaJ,iBAAiB,oBAO3CM,EAAiBL,GANdF,SAASK,EAAaJ,iBAAiB,kBACxCD,SAASK,EAAaJ,iBAAiB,kBAKiBjB,EAAKwB,SAASC,eAK9E,MAJiB,CACftB,KAAMgB,KAAKC,IA7DI,EA6DcD,KAAKO,MAAMH,EAAiBvB,EAAKI,eAAeK,WAAWC,kBACxFR,KAAMiB,KAAKC,IA7DI,EA6DcD,KAAKO,MAAMJ,EAAkBtB,EAAKI,eAAeK,WAAWE,uBAI/F,EA/DA,GAAa,EAAAgB,aCrBTC,EAA2B,GCE/B,ODCA,SAASC,EAAoBC,GAE5B,GAAGF,EAAyBE,GAC3B,OAAOF,EAAyBE,GAAU3C,QAG3C,IAAIC,EAASwC,EAAyBE,GAAY,CAGjD3C,QAAS,IAOV,OAHA4C,EAAoBD,GAAU1C,EAAQA,EAAOD,QAAS0C,GAG/CzC,EAAOD,QCjBR0C,CAAoB,M","file":"xterm-addon-fit.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"FitAddon\"] = factory();\n\telse\n\t\troot[\"FitAddon\"] = factory();\n})(self, function() {\nreturn ","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Terminal, ITerminalAddon } from 'xterm';\n\ninterface ITerminalDimensions {\n /**\n * The number of rows in the terminal.\n */\n rows: number;\n\n /**\n * The number of columns in the terminal.\n */\n cols: number;\n}\n\nconst MINIMUM_COLS = 2;\nconst MINIMUM_ROWS = 1;\n\nexport class FitAddon implements ITerminalAddon {\n private _terminal: Terminal | undefined;\n\n constructor() {}\n\n public activate(terminal: Terminal): void {\n this._terminal = terminal;\n }\n\n public dispose(): void {}\n\n public fit(): void {\n const dims = this.proposeDimensions();\n if (!dims || !this._terminal) {\n return;\n }\n\n // TODO: Remove reliance on private API\n const core = (this._terminal as any)._core;\n\n // Force a full render\n if (this._terminal.rows !== dims.rows || this._terminal.cols !== dims.cols) {\n core._renderService.clear();\n this._terminal.resize(dims.cols, dims.rows);\n }\n }\n\n public proposeDimensions(): ITerminalDimensions | undefined {\n if (!this._terminal) {\n return undefined;\n }\n\n if (!this._terminal.element || !this._terminal.element.parentElement) {\n return undefined;\n }\n\n // TODO: Remove reliance on private API\n const core = (this._terminal as any)._core;\n\n if (core._renderService.dimensions.actualCellWidth === 0 || core._renderService.dimensions.actualCellHeight === 0) {\n return undefined;\n }\n\n const parentElementStyle = window.getComputedStyle(this._terminal.element.parentElement);\n const parentElementHeight = parseInt(parentElementStyle.getPropertyValue('height'));\n const parentElementWidth = Math.max(0, parseInt(parentElementStyle.getPropertyValue('width')));\n const elementStyle = window.getComputedStyle(this._terminal.element);\n const elementPadding = {\n top: parseInt(elementStyle.getPropertyValue('padding-top')),\n bottom: parseInt(elementStyle.getPropertyValue('padding-bottom')),\n right: parseInt(elementStyle.getPropertyValue('padding-right')),\n left: parseInt(elementStyle.getPropertyValue('padding-left'))\n };\n const elementPaddingVer = elementPadding.top + elementPadding.bottom;\n const elementPaddingHor = elementPadding.right + elementPadding.left;\n const availableHeight = parentElementHeight - elementPaddingVer;\n const availableWidth = parentElementWidth - elementPaddingHor - core.viewport.scrollBarWidth;\n const geometry = {\n cols: Math.max(MINIMUM_COLS, Math.floor(availableWidth / core._renderService.dimensions.actualCellWidth)),\n rows: Math.max(MINIMUM_ROWS, Math.floor(availableHeight / core._renderService.dimensions.actualCellHeight))\n };\n return geometry;\n }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tif(__webpack_module_cache__[moduleId]) {\n\t\treturn __webpack_module_cache__[moduleId].exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// module exports must be returned from runtime so entry inlining is disabled\n// startup\n// Load entry module and return exports\nreturn __webpack_require__(775);\n"],"sourceRoot":""} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/out-test/FitAddon.api.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/out-test/FitAddon.api.js.map deleted file mode 100755 index d9ae6a025..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/out-test/FitAddon.api.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"FitAddon.api.js","sourceRoot":"","sources":["../test/FitAddon.api.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/out/FitAddon.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/out/FitAddon.js deleted file mode 100755 index 898f1571d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/out/FitAddon.js +++ /dev/null @@ -1,58 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.FitAddon = void 0; -var MINIMUM_COLS = 2; -var MINIMUM_ROWS = 1; -var FitAddon = (function () { - function FitAddon() { - } - FitAddon.prototype.activate = function (terminal) { - this._terminal = terminal; - }; - FitAddon.prototype.dispose = function () { }; - FitAddon.prototype.fit = function () { - var dims = this.proposeDimensions(); - if (!dims || !this._terminal) { - return; - } - var core = this._terminal._core; - if (this._terminal.rows !== dims.rows || this._terminal.cols !== dims.cols) { - core._renderService.clear(); - this._terminal.resize(dims.cols, dims.rows); - } - }; - FitAddon.prototype.proposeDimensions = function () { - if (!this._terminal) { - return undefined; - } - if (!this._terminal.element || !this._terminal.element.parentElement) { - return undefined; - } - var core = this._terminal._core; - if (core._renderService.dimensions.actualCellWidth === 0 || core._renderService.dimensions.actualCellHeight === 0) { - return undefined; - } - var parentElementStyle = window.getComputedStyle(this._terminal.element.parentElement); - var parentElementHeight = parseInt(parentElementStyle.getPropertyValue('height')); - var parentElementWidth = Math.max(0, parseInt(parentElementStyle.getPropertyValue('width'))); - var elementStyle = window.getComputedStyle(this._terminal.element); - var elementPadding = { - top: parseInt(elementStyle.getPropertyValue('padding-top')), - bottom: parseInt(elementStyle.getPropertyValue('padding-bottom')), - right: parseInt(elementStyle.getPropertyValue('padding-right')), - left: parseInt(elementStyle.getPropertyValue('padding-left')) - }; - var elementPaddingVer = elementPadding.top + elementPadding.bottom; - var elementPaddingHor = elementPadding.right + elementPadding.left; - var availableHeight = parentElementHeight - elementPaddingVer; - var availableWidth = parentElementWidth - elementPaddingHor - core.viewport.scrollBarWidth; - var geometry = { - cols: Math.max(MINIMUM_COLS, Math.floor(availableWidth / core._renderService.dimensions.actualCellWidth)), - rows: Math.max(MINIMUM_ROWS, Math.floor(availableHeight / core._renderService.dimensions.actualCellHeight)) - }; - return geometry; - }; - return FitAddon; -}()); -exports.FitAddon = FitAddon; -//# sourceMappingURL=FitAddon.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/out/FitAddon.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/out/FitAddon.js.map deleted file mode 100755 index 9f1533da2..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/out/FitAddon.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"FitAddon.js","sourceRoot":"","sources":["../src/FitAddon.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/src/FitAddon.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/src/FitAddon.ts deleted file mode 100755 index f4e5c772c..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/src/FitAddon.ts +++ /dev/null @@ -1,86 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { Terminal, ITerminalAddon } from 'xterm'; - -interface ITerminalDimensions { - /** - * The number of rows in the terminal. - */ - rows: number; - - /** - * The number of columns in the terminal. - */ - cols: number; -} - -const MINIMUM_COLS = 2; -const MINIMUM_ROWS = 1; - -export class FitAddon implements ITerminalAddon { - private _terminal: Terminal | undefined; - - constructor() {} - - public activate(terminal: Terminal): void { - this._terminal = terminal; - } - - public dispose(): void {} - - public fit(): void { - const dims = this.proposeDimensions(); - if (!dims || !this._terminal) { - return; - } - - // TODO: Remove reliance on private API - const core = (this._terminal as any)._core; - - // Force a full render - if (this._terminal.rows !== dims.rows || this._terminal.cols !== dims.cols) { - core._renderService.clear(); - this._terminal.resize(dims.cols, dims.rows); - } - } - - public proposeDimensions(): ITerminalDimensions | undefined { - if (!this._terminal) { - return undefined; - } - - if (!this._terminal.element || !this._terminal.element.parentElement) { - return undefined; - } - - // TODO: Remove reliance on private API - const core = (this._terminal as any)._core; - - if (core._renderService.dimensions.actualCellWidth === 0 || core._renderService.dimensions.actualCellHeight === 0) { - return undefined; - } - - const parentElementStyle = window.getComputedStyle(this._terminal.element.parentElement); - const parentElementHeight = parseInt(parentElementStyle.getPropertyValue('height')); - const parentElementWidth = Math.max(0, parseInt(parentElementStyle.getPropertyValue('width'))); - const elementStyle = window.getComputedStyle(this._terminal.element); - const elementPadding = { - top: parseInt(elementStyle.getPropertyValue('padding-top')), - bottom: parseInt(elementStyle.getPropertyValue('padding-bottom')), - right: parseInt(elementStyle.getPropertyValue('padding-right')), - left: parseInt(elementStyle.getPropertyValue('padding-left')) - }; - const elementPaddingVer = elementPadding.top + elementPadding.bottom; - const elementPaddingHor = elementPadding.right + elementPadding.left; - const availableHeight = parentElementHeight - elementPaddingVer; - const availableWidth = parentElementWidth - elementPaddingHor - core.viewport.scrollBarWidth; - const geometry = { - cols: Math.max(MINIMUM_COLS, Math.floor(availableWidth / core._renderService.dimensions.actualCellWidth)), - rows: Math.max(MINIMUM_ROWS, Math.floor(availableHeight / core._renderService.dimensions.actualCellHeight)) - }; - return geometry; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/typings/xterm-addon-fit.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/typings/xterm-addon-fit.d.ts deleted file mode 100755 index c3b0b4af0..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-fit/typings/xterm-addon-fit.d.ts +++ /dev/null @@ -1,55 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { Terminal, ITerminalAddon } from 'xterm'; - -declare module 'xterm-addon-fit' { - /** - * An xterm.js addon that enables resizing the terminal to the dimensions of - * its containing element. - */ - export class FitAddon implements ITerminalAddon { - /** - * Creates a new fit addon. - */ - constructor(); - - /** - * Activates the addon - * @param terminal The terminal the addon is being loaded in. - */ - public activate(terminal: Terminal): void; - - /** - * Disposes the addon. - */ - public dispose(): void; - - /** - * Resizes the terminal to the dimensions of its containing element. - */ - public fit(): void; - - /** - * Gets the proposed dimensions that will be used for a fit. - */ - public proposeDimensions(): ITerminalDimensions; - } - - /** - * Reprepresents the dimensions of a terminal. - */ - export interface ITerminalDimensions { - /** - * The number of rows in the terminal. - */ - rows: number; - - /** - * The number of columns in the terminal. - */ - cols: number; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/README.md b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/README.md deleted file mode 100755 index 12e0ac876..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/README.md +++ /dev/null @@ -1,42 +0,0 @@ -## xterm-addon-serialize - -An addon for [xterm.js](https://github.com/xtermjs/xterm.js) that enables xterm.js to serialize a terminal framebuffer into string or html. This addon requires xterm.js v4+. - -⚠️ This is an experimental addon that is still under construction ⚠️ - -### Install - -```bash -npm install --save xterm-addon-serialize -``` - -### Usage - -```ts -import { Terminal } from "xterm"; -import { SerializeAddon } from "xterm-addon-serialize"; - -const terminal = new Terminal(); -const serializeAddon = new SerializeAddon(); -terminal.loadAddon(serializeAddon); - -terminal.write("something...", () => { - console.log(serializeAddon.serialize()); -}); -``` - -See the full [API](https://github.com/xtermjs/xterm.js/blob/master/addons/xterm-addon-serialize/typings/xterm-addon-serialize.d.ts) for more advanced usage. - -### Benchmark - -⚠️ Ensure you have `lolcat`, `hexdump` programs installed in your computer - -```shell -$ git clone https://github.com/xtermjs/xterm.js.git -$ cd xterm.js -$ yarn -$ cd addons/xterm-addon-serialize -$ yarn benchmark && yarn benchmark-baseline -$ # change some code in `xterm-addon-serialize` -$ yarn benchmark-eval -``` diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/benchmark/SerializeAddon.benchmark.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/benchmark/SerializeAddon.benchmark.ts deleted file mode 100755 index 0147631d8..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/benchmark/SerializeAddon.benchmark.ts +++ /dev/null @@ -1,65 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { perfContext, before, ThroughputRuntimeCase } from 'xterm-benchmark'; - -import { spawn } from 'node-pty'; -import { Utf8ToUtf32, stringFromCodePoint } from 'common/input/TextDecoder'; -import { Terminal } from 'browser/public/Terminal'; -import { SerializeAddon } from 'SerializeAddon'; - -class TestTerminal extends Terminal { - public writeSync(data: string): void { - (this as any)._core.writeSync(data); - } -} - -perfContext('Terminal: sh -c "dd if=/dev/urandom count=40 bs=1k | hexdump | lolcat -f"', () => { - let content = ''; - let contentUtf8: Uint8Array; - - before(async () => { - const p = spawn('sh', ['-c', 'dd if=/dev/urandom count=40 bs=1k | hexdump | lolcat -f'], { - name: 'xterm-256color', - cols: 80, - rows: 25, - cwd: process.env.HOME, - env: process.env, - encoding: (null as unknown as string) // needs to be fixed in node-pty - }); - const chunks: Buffer[] = []; - let length = 0; - p.on('data', data => { - chunks.push(data as unknown as Buffer); - length += data.length; - }); - await new Promise(resolve => p.on('exit', () => resolve())); - contentUtf8 = Buffer.concat(chunks, length); - // translate to content string - const buffer = new Uint32Array(contentUtf8.length); - const decoder = new Utf8ToUtf32(); - const codepoints = decoder.decode(contentUtf8, buffer); - for (let i = 0; i < codepoints; ++i) { - content += stringFromCodePoint(buffer[i]); - // peek into content to force flat repr in v8 - if (!(i % 10000000)) { - content[i]; - } - } - }); - - perfContext('serialize', () => { - let terminal: TestTerminal; - const serializeAddon = new SerializeAddon(); - before(() => { - terminal = new TestTerminal({ cols: 80, rows: 25, scrollback: 5000 }); - serializeAddon.activate(terminal); - terminal.writeSync(content); - }); - new ThroughputRuntimeCase('', () => { - return { payloadSize: serializeAddon.serialize().length }; - }, { fork: false }).showAverageThroughput(); - }); -}); diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/benchmark/benchmark.json b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/benchmark/benchmark.json deleted file mode 100755 index f8b99b556..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/benchmark/benchmark.json +++ /dev/null @@ -1,19 +0,0 @@ -{ - "APP_PATH": ".benchmark", - "evalConfig": { - "tolerance": { - "*": [0.75, 1.5], - "*.dev": [0.01, 1.5], - "*.cv": [0.01, 1.5], - "EscapeSequenceParser.benchmark.js.*.averageThroughput.mean": [0.9, 5] - }, - "skip": [ - "*.median", - "*.runs", - "*.dev", - "*.cv", - "EscapeSequenceParser.benchmark.js.*.averageRuntime", - "Terminal.benchmark.js.*.averageRuntime" - ] - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/lib/xterm-addon-serialize.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/lib/xterm-addon-serialize.js deleted file mode 100755 index e63819725..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/lib/xterm-addon-serialize.js +++ /dev/null @@ -1,2 +0,0 @@ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.SerializeAddon=e():t.SerializeAddon=e()}(self,(function(){return(()=>{"use strict";var t={44:function(t,e){var r,i=this&&this.__extends||(r=function(t,e){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&(t[r]=e[r])})(t,e)},function(t,e){function i(){this.constructor=t}r(t,e),t.prototype=null===e?Object.create(e):(i.prototype=e.prototype,new i)});function s(t,e){return t.getBgColorMode()===e.getBgColorMode()&&t.getBgColor()===e.getBgColor()}Object.defineProperty(e,"__esModule",{value:!0}),e.SerializeAddon=void 0;var o=function(t){function e(e,r){var i=t.call(this,e)||this;return i._buffer1=e,i._terminal=r,i._rowIndex=0,i._allRows=new Array,i._allRowSeparators=new Array,i._currentRow="",i._nullCellCount=0,i._cursorStyle=i._buffer1.getNullCell(),i._cursorStyleRow=0,i._cursorStyleCol=0,i._backgroundCell=i._buffer1.getNullCell(),i._firstRow=0,i._lastCursorRow=0,i._lastCursorCol=0,i._lastContentCursorRow=0,i._lastContentCursorCol=0,i._thisRowLastChar=i._buffer1.getNullCell(),i._thisRowLastSecondChar=i._buffer1.getNullCell(),i._nextRowFirstChar=i._buffer1.getNullCell(),i}return i(e,t),e.prototype._beforeSerialize=function(t,e,r){this._allRows=new Array(t),this._lastContentCursorRow=e,this._lastCursorRow=e,this._firstRow=e},e.prototype._rowEnd=function(t,e){var r;this._nullCellCount>0&&!s(this._cursorStyle,this._backgroundCell)&&(this._currentRow+="["+this._nullCellCount+"X");var i="";if(!e){t-this._firstRow>=this._terminal.rows&&(null===(r=this._buffer1.getLine(this._cursorStyleRow))||void 0===r||r.getCell(this._cursorStyleCol,this._backgroundCell));var o=this._buffer1.getLine(t),l=this._buffer1.getLine(t+1);if(l.isWrapped){i="";var n=o.getCell(o.length-1,this._thisRowLastChar),u=o.getCell(o.length-2,this._thisRowLastSecondChar),h=l.getCell(0,this._nextRowFirstChar),_=h.getWidth()>1,a=!1;(h.getChars()&&_?this._nullCellCount<=1:this._nullCellCount<=0)&&((n.getChars()||0===n.getWidth())&&s(n,h)&&(a=!0),_&&(u.getChars()||0===u.getWidth())&&s(n,h)&&s(u,h)&&(a=!0)),a||(i="-".repeat(this._nullCellCount+1),i+="",this._nullCellCount>0&&(i+="",i+="["+(o.length-this._nullCellCount)+"C",i+="["+this._nullCellCount+"X",i+="["+(o.length-this._nullCellCount)+"D",i+=""),this._lastContentCursorRow=t+1,this._lastContentCursorCol=0,this._lastCursorRow=t+1,this._lastCursorCol=0)}else i="\r\n",this._lastCursorRow=t+1,this._lastCursorCol=0}this._allRows[this._rowIndex]=this._currentRow,this._allRowSeparators[this._rowIndex++]=i,this._currentRow="",this._nullCellCount=0},e.prototype._diffStyle=function(t,e){var r,i,o=[],l=(i=e,!((r=t).getFgColorMode()===i.getFgColorMode()&&r.getFgColor()===i.getFgColor())),n=!s(t,e),u=!function(t,e){return t.isInverse()===e.isInverse()&&t.isBold()===e.isBold()&&t.isUnderline()===e.isUnderline()&&t.isBlink()===e.isBlink()&&t.isInvisible()===e.isInvisible()&&t.isItalic()===e.isItalic()&&t.isDim()===e.isDim()}(t,e);if(l||n||u)if(t.isAttributeDefault())e.isAttributeDefault()||o.push(0);else{if(l){var h=t.getFgColor();t.isFgRGB()?o.push(38,2,h>>>16&255,h>>>8&255,255&h):t.isFgPalette()?h>=16?o.push(38,5,h):o.push(8&h?90+(7&h):30+(7&h)):o.push(39)}n&&(h=t.getBgColor(),t.isBgRGB()?o.push(48,2,h>>>16&255,h>>>8&255,255&h):t.isBgPalette()?h>=16?o.push(48,5,h):o.push(8&h?100+(7&h):40+(7&h)):o.push(49)),u&&(t.isInverse()!==e.isInverse()&&o.push(t.isInverse()?7:27),t.isBold()!==e.isBold()&&o.push(t.isBold()?1:22),t.isUnderline()!==e.isUnderline()&&o.push(t.isUnderline()?4:24),t.isBlink()!==e.isBlink()&&o.push(t.isBlink()?5:25),t.isInvisible()!==e.isInvisible()&&o.push(t.isInvisible()?8:28),t.isItalic()!==e.isItalic()&&o.push(t.isItalic()?3:23),t.isDim()!==e.isDim()&&o.push(t.isDim()?2:22))}return o},e.prototype._nextCell=function(t,e,r,i){if(0!==t.getWidth()){var o=""===t.getChars(),l=this._diffStyle(t,this._cursorStyle);if(o?!s(this._cursorStyle,t):l.length>0){this._nullCellCount>0&&(s(this._cursorStyle,this._backgroundCell)||(this._currentRow+="["+this._nullCellCount+"X"),this._currentRow+="["+this._nullCellCount+"C",this._nullCellCount=0),this._lastContentCursorRow=this._lastCursorRow=r,this._lastContentCursorCol=this._lastCursorCol=i,this._currentRow+="["+l.join(";")+"m";var n=this._buffer1.getLine(r);void 0!==n&&(n.getCell(i,this._cursorStyle),this._cursorStyleRow=r,this._cursorStyleCol=i)}o?this._nullCellCount+=t.getWidth():(this._nullCellCount>0&&(s(this._cursorStyle,this._backgroundCell)||(this._currentRow+="["+this._nullCellCount+"X"),this._currentRow+="["+this._nullCellCount+"C",this._nullCellCount=0),this._currentRow+=t.getChars(),this._lastContentCursorRow=this._lastCursorRow=r,this._lastContentCursorCol=this._lastCursorCol=i+t.getWidth())}},e.prototype._serializeString=function(){var t=this._allRows.length;this._buffer1.length-this._firstRow<=this._terminal.rows&&(t=this._lastContentCursorRow+1-this._firstRow,this._lastCursorCol=this._lastContentCursorCol,this._lastCursorRow=this._lastContentCursorRow);for(var e="",r=0;r0?e+="["+i+"B":i<0&&(e+="["+-i+"A"),function(t){t>0?e+="["+t+"C":t<0&&(e+="["+-t+"D")}(o-this._lastCursorCol)),e},e}(function(){function t(t){this._buffer=t}return t.prototype.serialize=function(t,e){var r=this._buffer.getNullCell(),i=this._buffer.getNullCell(),s=r;this._beforeSerialize(e-t,t,e);for(var o=t;o();\n private _allRowSeparators: string[] = new Array();\n private _currentRow: string = '';\n private _nullCellCount: number = 0;\n\n // we can see a full colored cell and a null cell that only have background the same style\n // but the information isn't preserved by null cell itself\n // so wee need to record it when required.\n private _cursorStyle: IBufferCell = this._buffer1.getNullCell();\n\n // where exact the cursor styles comes from\n // because we can't copy the cell directly\n // so we remember where the content comes from instead\n private _cursorStyleRow: number = 0;\n private _cursorStyleCol: number = 0;\n\n // this is a null cell for reference for checking whether background is empty or not\n private _backgroundCell: IBufferCell = this._buffer1.getNullCell();\n\n private _firstRow: number = 0;\n private _lastCursorRow: number = 0;\n private _lastCursorCol: number = 0;\n private _lastContentCursorRow: number = 0;\n private _lastContentCursorCol: number = 0;\n\n constructor(private _buffer1: IBuffer, private _terminal: Terminal) {\n super(_buffer1);\n }\n\n protected _beforeSerialize(rows: number, start: number, end: number): void {\n this._allRows = new Array(rows);\n this._lastContentCursorRow = start;\n this._lastCursorRow = start;\n this._firstRow = start;\n }\n\n private _thisRowLastChar: IBufferCell = this._buffer1.getNullCell();\n private _thisRowLastSecondChar: IBufferCell = this._buffer1.getNullCell();\n private _nextRowFirstChar: IBufferCell = this._buffer1.getNullCell();\n protected _rowEnd(row: number, isLastRow: boolean): void {\n // if there is colorful empty cell at line end, whe must pad it back, or the the color block will missing\n if (this._nullCellCount > 0 && !equalBg(this._cursorStyle, this._backgroundCell)) {\n // use clear right to set background.\n this._currentRow += `\\x1b[${this._nullCellCount}X`;\n }\n\n let rowSeparator = '';\n\n // handle row separator\n if (!isLastRow) {\n // Enable BCE\n if (row - this._firstRow >= this._terminal.rows) {\n this._buffer1.getLine(this._cursorStyleRow)?.getCell(this._cursorStyleCol, this._backgroundCell);\n }\n\n // Fetch current line\n const currentLine = this._buffer1.getLine(row)!;\n // Fetch next line\n const nextLine = this._buffer1.getLine(row + 1)!;\n\n if (!nextLine.isWrapped) {\n // just insert the line break\n rowSeparator = '\\r\\n';\n // we sended the enter\n this._lastCursorRow = row + 1;\n this._lastCursorCol = 0;\n } else {\n rowSeparator = '';\n const thisRowLastChar = currentLine.getCell(currentLine.length - 1, this._thisRowLastChar)!;\n const thisRowLastSecondChar = currentLine.getCell(currentLine.length - 2, this._thisRowLastSecondChar)!;\n const nextRowFirstChar = nextLine.getCell(0, this._nextRowFirstChar)!;\n const isNextRowFirstCharDoubleWidth = nextRowFirstChar.getWidth() > 1;\n\n // validate whether this line wrap is ever possible\n // which mean whether cursor can placed at a overflow position (x === row) naturally\n let isValid = false;\n\n if (\n // you must output character to cause overflow, control sequence can't do this\n nextRowFirstChar.getChars() &&\n isNextRowFirstCharDoubleWidth ? this._nullCellCount <= 1 : this._nullCellCount <= 0\n ) {\n if (\n // the last character can't be null,\n // you can't use control sequence to move cursor to (x === row)\n (thisRowLastChar.getChars() || thisRowLastChar.getWidth() === 0) &&\n // change background of the first wrapped cell also affects BCE\n // so we mark it as invalid to simply the process to determine line separator\n equalBg(thisRowLastChar, nextRowFirstChar)\n ) {\n isValid = true;\n }\n\n if (\n // the second to last character can't be null if the next line starts with CJK,\n // you can't use control sequence to move cursor to (x === row)\n isNextRowFirstCharDoubleWidth &&\n (thisRowLastSecondChar.getChars() || thisRowLastSecondChar.getWidth() === 0) &&\n // change background of the first wrapped cell also affects BCE\n // so we mark it as invalid to simply the process to determine line separator\n equalBg(thisRowLastChar, nextRowFirstChar) &&\n equalBg(thisRowLastSecondChar, nextRowFirstChar)\n ) {\n isValid = true;\n }\n }\n\n if (!isValid) {\n // force the wrap with magic\n // insert enough character to force the wrap\n rowSeparator = '-'.repeat(this._nullCellCount + 1);\n // move back and erase next line head\n rowSeparator += '\\x1b[1D\\x1b[1X';\n\n if (this._nullCellCount > 0) {\n // do these because we filled the last several null slot, which we shouldn't\n rowSeparator += '\\x1b[A';\n rowSeparator += `\\x1b[${currentLine.length - this._nullCellCount}C`;\n rowSeparator += `\\x1b[${this._nullCellCount}X`;\n rowSeparator += `\\x1b[${currentLine.length - this._nullCellCount}D`;\n rowSeparator += '\\x1b[B';\n }\n\n // This is content and need the be serialized even it is invisible.\n // without this, wrap will be missing from outputs.\n this._lastContentCursorRow = row + 1;\n this._lastContentCursorCol = 0;\n\n // force commit the cursor position\n this._lastCursorRow = row + 1;\n this._lastCursorCol = 0;\n }\n }\n }\n\n this._allRows[this._rowIndex] = this._currentRow;\n this._allRowSeparators[this._rowIndex++] = rowSeparator;\n this._currentRow = '';\n this._nullCellCount = 0;\n }\n\n private _diffStyle(cell: IBufferCell, oldCell: IBufferCell): number[] {\n const sgrSeq: number[] = [];\n const fgChanged = !equalFg(cell, oldCell);\n const bgChanged = !equalBg(cell, oldCell);\n const flagsChanged = !equalFlags(cell, oldCell);\n\n if (fgChanged || bgChanged || flagsChanged) {\n if (cell.isAttributeDefault()) {\n if (!oldCell.isAttributeDefault()) {\n sgrSeq.push(0);\n }\n } else {\n if (fgChanged) {\n const color = cell.getFgColor();\n if (cell.isFgRGB()) { sgrSeq.push(38, 2, (color >>> 16) & 0xFF, (color >>> 8) & 0xFF, color & 0xFF); }\n else if (cell.isFgPalette()) {\n if (color >= 16) { sgrSeq.push(38, 5, color); }\n else { sgrSeq.push(color & 8 ? 90 + (color & 7) : 30 + (color & 7)); }\n }\n else { sgrSeq.push(39); }\n }\n if (bgChanged) {\n const color = cell.getBgColor();\n if (cell.isBgRGB()) { sgrSeq.push(48, 2, (color >>> 16) & 0xFF, (color >>> 8) & 0xFF, color & 0xFF); }\n else if (cell.isBgPalette()) {\n if (color >= 16) { sgrSeq.push(48, 5, color); }\n else { sgrSeq.push(color & 8 ? 100 + (color & 7) : 40 + (color & 7)); }\n }\n else { sgrSeq.push(49); }\n }\n if (flagsChanged) {\n if (cell.isInverse() !== oldCell.isInverse()) { sgrSeq.push(cell.isInverse() ? 7 : 27); }\n if (cell.isBold() !== oldCell.isBold()) { sgrSeq.push(cell.isBold() ? 1 : 22); }\n if (cell.isUnderline() !== oldCell.isUnderline()) { sgrSeq.push(cell.isUnderline() ? 4 : 24); }\n if (cell.isBlink() !== oldCell.isBlink()) { sgrSeq.push(cell.isBlink() ? 5 : 25); }\n if (cell.isInvisible() !== oldCell.isInvisible()) { sgrSeq.push(cell.isInvisible() ? 8 : 28); }\n if (cell.isItalic() !== oldCell.isItalic()) { sgrSeq.push(cell.isItalic() ? 3 : 23); }\n if (cell.isDim() !== oldCell.isDim()) { sgrSeq.push(cell.isDim() ? 2 : 22); }\n }\n }\n }\n\n return sgrSeq;\n }\n\n protected _nextCell(cell: IBufferCell, oldCell: IBufferCell, row: number, col: number): void {\n // a width 0 cell don't need to be count because it is just a placeholder after a CJK character;\n const isPlaceHolderCell = cell.getWidth() === 0;\n\n if (isPlaceHolderCell) {\n return;\n }\n\n // this cell don't have content\n const isEmptyCell = cell.getChars() === '';\n\n const sgrSeq = this._diffStyle(cell, this._cursorStyle);\n\n // the empty cell style is only assumed to be changed when background changed, because foreground is always 0.\n const styleChanged = isEmptyCell ? !equalBg(this._cursorStyle, cell) : sgrSeq.length > 0;\n\n /**\n * handles style change\n */\n if (styleChanged) {\n // before update the style, we need to fill empty cell back\n if (this._nullCellCount > 0) {\n // use clear right to set background.\n if (!equalBg(this._cursorStyle, this._backgroundCell)) {\n this._currentRow += `\\x1b[${this._nullCellCount}X`;\n }\n // use move right to move cursor.\n this._currentRow += `\\x1b[${this._nullCellCount}C`;\n this._nullCellCount = 0;\n }\n\n this._lastContentCursorRow = this._lastCursorRow = row;\n this._lastContentCursorCol = this._lastCursorCol = col;\n\n this._currentRow += `\\x1b[${sgrSeq.join(';')}m`;\n\n // update the last cursor style\n const line = this._buffer1.getLine(row);\n if (line !== undefined) {\n line.getCell(col, this._cursorStyle);\n this._cursorStyleRow = row;\n this._cursorStyleCol = col;\n }\n }\n\n /**\n * handles actual content\n */\n if (isEmptyCell) {\n this._nullCellCount += cell.getWidth();\n } else {\n if (this._nullCellCount > 0) {\n // we can just assume we have same style with previous one here\n // because style change is handled by previous stage\n // use move right when background is empty, use clear right when there is background.\n if (equalBg(this._cursorStyle, this._backgroundCell)) {\n this._currentRow += `\\x1b[${this._nullCellCount}C`;\n } else {\n this._currentRow += `\\x1b[${this._nullCellCount}X`;\n this._currentRow += `\\x1b[${this._nullCellCount}C`;\n }\n this._nullCellCount = 0;\n }\n\n this._currentRow += cell.getChars();\n\n // update cursor\n this._lastContentCursorRow = this._lastCursorRow = row;\n this._lastContentCursorCol = this._lastCursorCol = col + cell.getWidth();\n }\n }\n\n protected _serializeString(): string {\n let rowEnd = this._allRows.length;\n\n // the fixup is only required for data without scrollback\n // because it will always be placed at last line otherwise\n if (this._buffer1.length - this._firstRow <= this._terminal.rows) {\n rowEnd = this._lastContentCursorRow + 1 - this._firstRow;\n this._lastCursorCol = this._lastContentCursorCol;\n this._lastCursorRow = this._lastContentCursorRow;\n }\n\n let content = '';\n\n for (let i = 0; i < rowEnd; i++) {\n content += this._allRows[i];\n if (i + 1 < rowEnd) {\n content += this._allRowSeparators[i];\n }\n }\n\n // restore the cursor\n const realCursorRow = this._buffer1.baseY + this._buffer1.cursorY;\n const realCursorCol = this._buffer1.cursorX;\n\n const cursorMoved = (realCursorRow !== this._lastCursorRow || realCursorCol !== this._lastCursorCol);\n\n const moveRight = (offset: number): void => {\n if (offset > 0) {\n content += `\\u001b[${offset}C`;\n } else if (offset < 0) {\n content += `\\u001b[${-offset}D`;\n }\n };\n const moveDown = (offset: number): void => {\n if (offset > 0) {\n content += `\\u001b[${offset}B`;\n } else if (offset < 0) {\n content += `\\u001b[${-offset}A`;\n }\n };\n\n if (cursorMoved) {\n moveDown(realCursorRow - this._lastCursorRow);\n moveRight(realCursorCol - this._lastCursorCol);\n }\n\n\n return content;\n }\n}\n\nexport class SerializeAddon implements ITerminalAddon {\n private _terminal: Terminal | undefined;\n\n constructor() { }\n\n public activate(terminal: Terminal): void {\n this._terminal = terminal;\n }\n\n private _getString(buffer: IBuffer, scrollback?: number): string {\n const maxRows = buffer.length;\n const handler = new StringSerializeHandler(buffer, this._terminal!);\n\n const correctRows = (scrollback === undefined) ? maxRows : constrain(scrollback + this!._terminal!.rows, 0, maxRows);\n const result = handler.serialize(maxRows - correctRows, maxRows);\n\n return result;\n }\n\n public serialize(scrollback?: number): string {\n // TODO: Add combinedData support\n if (!this._terminal) {\n throw new Error('Cannot use addon until it has been loaded');\n }\n\n if (this._terminal.buffer.active.type === 'normal') {\n return this._getString(this._terminal.buffer.active, scrollback);\n }\n\n const normalScreenContent = this._getString(this._terminal.buffer.normal, scrollback);\n // alt screen don't have scrollback\n const alternativeScreenContent = this._getString(this._terminal.buffer.alternate, undefined);\n\n return normalScreenContent\n + '\\u001b[?1049h\\u001b[H'\n + alternativeScreenContent;\n }\n\n public dispose(): void { }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tif(__webpack_module_cache__[moduleId]) {\n\t\treturn __webpack_module_cache__[moduleId].exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// module exports must be returned from runtime so entry inlining is disabled\n// startup\n// Load entry module and return exports\nreturn __webpack_require__(44);\n"],"sourceRoot":""} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out-benchmark/benchmark/SerializeAddon.benchmark.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out-benchmark/benchmark/SerializeAddon.benchmark.js deleted file mode 100755 index af7085056..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out-benchmark/benchmark/SerializeAddon.benchmark.js +++ /dev/null @@ -1,70 +0,0 @@ -"use strict"; -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ -var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { - function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } - return new (P || (P = Promise))(function (resolve, reject) { - function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } - function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } - function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } - step((generator = generator.apply(thisArg, _arguments || [])).next()); - }); -}; -Object.defineProperty(exports, "__esModule", { value: true }); -const xterm_benchmark_1 = require("xterm-benchmark"); -const node_pty_1 = require("node-pty"); -const TextDecoder_1 = require("common/input/TextDecoder"); -const Terminal_1 = require("browser/public/Terminal"); -const SerializeAddon_1 = require("SerializeAddon"); -class TestTerminal extends Terminal_1.Terminal { - writeSync(data) { - this._core.writeSync(data); - } -} -xterm_benchmark_1.perfContext('Terminal: sh -c "dd if=/dev/urandom count=40 bs=1k | hexdump | lolcat -f"', () => { - let content = ''; - let contentUtf8; - xterm_benchmark_1.before(() => __awaiter(void 0, void 0, void 0, function* () { - const p = node_pty_1.spawn('sh', ['-c', 'dd if=/dev/urandom count=40 bs=1k | hexdump | lolcat -f'], { - name: 'xterm-256color', - cols: 80, - rows: 25, - cwd: process.env.HOME, - env: process.env, - encoding: null // needs to be fixed in node-pty - }); - const chunks = []; - let length = 0; - p.on('data', data => { - chunks.push(data); - length += data.length; - }); - yield new Promise(resolve => p.on('exit', () => resolve())); - contentUtf8 = Buffer.concat(chunks, length); - // translate to content string - const buffer = new Uint32Array(contentUtf8.length); - const decoder = new TextDecoder_1.Utf8ToUtf32(); - const codepoints = decoder.decode(contentUtf8, buffer); - for (let i = 0; i < codepoints; ++i) { - content += TextDecoder_1.stringFromCodePoint(buffer[i]); - // peek into content to force flat repr in v8 - if (!(i % 10000000)) { - content[i]; - } - } - })); - xterm_benchmark_1.perfContext('serialize', () => { - let terminal; - const serializeAddon = new SerializeAddon_1.SerializeAddon(); - xterm_benchmark_1.before(() => { - terminal = new TestTerminal({ cols: 80, rows: 25, scrollback: 5000 }); - serializeAddon.activate(terminal); - terminal.writeSync(content); - }); - new xterm_benchmark_1.ThroughputRuntimeCase('', () => { - return { payloadSize: serializeAddon.serialize().length }; - }, { fork: false }).showAverageThroughput(); - }); -}); diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out-benchmark/src/SerializeAddon.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out-benchmark/src/SerializeAddon.js deleted file mode 100755 index 6719b64c7..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out-benchmark/src/SerializeAddon.js +++ /dev/null @@ -1,396 +0,0 @@ -"use strict"; -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - * - * (EXPERIMENTAL) This Addon is still under development - */ -Object.defineProperty(exports, "__esModule", { value: true }); -exports.SerializeAddon = void 0; -function constrain(value, low, high) { - return Math.max(low, Math.min(value, high)); -} -// TODO: Refine this template class later -class BaseSerializeHandler { - constructor(_buffer) { - this._buffer = _buffer; - } - serialize(startRow, endRow) { - // we need two of them to flip between old and new cell - const cell1 = this._buffer.getNullCell(); - const cell2 = this._buffer.getNullCell(); - let oldCell = cell1; - this._beforeSerialize(endRow - startRow, startRow, endRow); - for (let row = startRow; row < endRow; row++) { - const line = this._buffer.getLine(row); - if (line) { - for (let col = 0; col < line.length; col++) { - const c = line.getCell(col, oldCell === cell1 ? cell2 : cell1); - if (!c) { - console.warn(`Can't get cell at row=${row}, col=${col}`); - continue; - } - this._nextCell(c, oldCell, row, col); - oldCell = c; - } - } - this._rowEnd(row, row === endRow - 1); - } - this._afterSerialize(); - return this._serializeString(); - } - _nextCell(cell, oldCell, row, col) { } - _rowEnd(row, isLastRow) { } - _beforeSerialize(rows, startRow, endRow) { } - _afterSerialize() { } - _serializeString() { return ''; } -} -function equalFg(cell1, cell2) { - return cell1.getFgColorMode() === cell2.getFgColorMode() - && cell1.getFgColor() === cell2.getFgColor(); -} -function equalBg(cell1, cell2) { - return cell1.getBgColorMode() === cell2.getBgColorMode() - && cell1.getBgColor() === cell2.getBgColor(); -} -function equalFlags(cell1, cell2) { - return cell1.isInverse() === cell2.isInverse() - && cell1.isBold() === cell2.isBold() - && cell1.isUnderline() === cell2.isUnderline() - && cell1.isBlink() === cell2.isBlink() - && cell1.isInvisible() === cell2.isInvisible() - && cell1.isItalic() === cell2.isItalic() - && cell1.isDim() === cell2.isDim(); -} -class StringSerializeHandler extends BaseSerializeHandler { - constructor(_buffer1, _terminal) { - super(_buffer1); - this._buffer1 = _buffer1; - this._terminal = _terminal; - this._rowIndex = 0; - this._allRows = new Array(); - this._allRowSeparators = new Array(); - this._currentRow = ''; - this._nullCellCount = 0; - // we can see a full colored cell and a null cell that only have background the same style - // but the information isn't preserved by null cell itself - // so wee need to record it when required. - this._cursorStyle = this._buffer1.getNullCell(); - // where exact the cursor styles comes from - // because we can't copy the cell directly - // so we remember where the content comes from instead - this._cursorStyleRow = 0; - this._cursorStyleCol = 0; - // this is a null cell for reference for checking whether background is empty or not - this._backgroundCell = this._buffer1.getNullCell(); - this._firstRow = 0; - this._lastCursorRow = 0; - this._lastCursorCol = 0; - this._lastContentCursorRow = 0; - this._lastContentCursorCol = 0; - this._thisRowLastChar = this._buffer1.getNullCell(); - this._thisRowLastSecondChar = this._buffer1.getNullCell(); - this._nextRowFirstChar = this._buffer1.getNullCell(); - } - _beforeSerialize(rows, start, end) { - this._allRows = new Array(rows); - this._lastContentCursorRow = start; - this._lastCursorRow = start; - this._firstRow = start; - } - _rowEnd(row, isLastRow) { - var _a; - // if there is colorful empty cell at line end, whe must pad it back, or the the color block will missing - if (this._nullCellCount > 0 && !equalBg(this._cursorStyle, this._backgroundCell)) { - // use clear right to set background. - this._currentRow += `\x1b[${this._nullCellCount}X`; - } - let rowSeparator = ''; - // handle row separator - if (!isLastRow) { - // Enable BCE - if (row - this._firstRow >= this._terminal.rows) { - (_a = this._buffer1.getLine(this._cursorStyleRow)) === null || _a === void 0 ? void 0 : _a.getCell(this._cursorStyleCol, this._backgroundCell); - } - // Fetch current line - const currentLine = this._buffer1.getLine(row); - // Fetch next line - const nextLine = this._buffer1.getLine(row + 1); - if (!nextLine.isWrapped) { - // just insert the line break - rowSeparator = '\r\n'; - // we sended the enter - this._lastCursorRow = row + 1; - this._lastCursorCol = 0; - } - else { - rowSeparator = ''; - const thisRowLastChar = currentLine.getCell(currentLine.length - 1, this._thisRowLastChar); - const thisRowLastSecondChar = currentLine.getCell(currentLine.length - 2, this._thisRowLastSecondChar); - const nextRowFirstChar = nextLine.getCell(0, this._nextRowFirstChar); - const isNextRowFirstCharDoubleWidth = nextRowFirstChar.getWidth() > 1; - // validate whether this line wrap is ever possible - // which mean whether cursor can placed at a overflow position (x === row) naturally - let isValid = false; - if ( - // you must output character to cause overflow, control sequence can't do this - nextRowFirstChar.getChars() && - isNextRowFirstCharDoubleWidth ? this._nullCellCount <= 1 : this._nullCellCount <= 0) { - if ( - // the last character can't be null, - // you can't use control sequence to move cursor to (x === row) - (thisRowLastChar.getChars() || thisRowLastChar.getWidth() === 0) && - // change background of the first wrapped cell also affects BCE - // so we mark it as invalid to simply the process to determine line separator - equalBg(thisRowLastChar, nextRowFirstChar)) { - isValid = true; - } - if ( - // the second to last character can't be null if the next line starts with CJK, - // you can't use control sequence to move cursor to (x === row) - isNextRowFirstCharDoubleWidth && - (thisRowLastSecondChar.getChars() || thisRowLastSecondChar.getWidth() === 0) && - // change background of the first wrapped cell also affects BCE - // so we mark it as invalid to simply the process to determine line separator - equalBg(thisRowLastChar, nextRowFirstChar) && - equalBg(thisRowLastSecondChar, nextRowFirstChar)) { - isValid = true; - } - } - if (!isValid) { - // force the wrap with magic - // insert enough character to force the wrap - rowSeparator = '-'.repeat(this._nullCellCount + 1); - // move back and erase next line head - rowSeparator += '\x1b[1D\x1b[1X'; - if (this._nullCellCount > 0) { - // do these because we filled the last several null slot, which we shouldn't - rowSeparator += '\x1b[A'; - rowSeparator += `\x1b[${currentLine.length - this._nullCellCount}C`; - rowSeparator += `\x1b[${this._nullCellCount}X`; - rowSeparator += `\x1b[${currentLine.length - this._nullCellCount}D`; - rowSeparator += '\x1b[B'; - } - // This is content and need the be serialized even it is invisible. - // without this, wrap will be missing from outputs. - this._lastContentCursorRow = row + 1; - this._lastContentCursorCol = 0; - // force commit the cursor position - this._lastCursorRow = row + 1; - this._lastCursorCol = 0; - } - } - } - this._allRows[this._rowIndex] = this._currentRow; - this._allRowSeparators[this._rowIndex++] = rowSeparator; - this._currentRow = ''; - this._nullCellCount = 0; - } - _diffStyle(cell, oldCell) { - const sgrSeq = []; - const fgChanged = !equalFg(cell, oldCell); - const bgChanged = !equalBg(cell, oldCell); - const flagsChanged = !equalFlags(cell, oldCell); - if (fgChanged || bgChanged || flagsChanged) { - if (cell.isAttributeDefault()) { - if (!oldCell.isAttributeDefault()) { - sgrSeq.push(0); - } - } - else { - if (fgChanged) { - const color = cell.getFgColor(); - if (cell.isFgRGB()) { - sgrSeq.push(38, 2, (color >>> 16) & 0xFF, (color >>> 8) & 0xFF, color & 0xFF); - } - else if (cell.isFgPalette()) { - if (color >= 16) { - sgrSeq.push(38, 5, color); - } - else { - sgrSeq.push(color & 8 ? 90 + (color & 7) : 30 + (color & 7)); - } - } - else { - sgrSeq.push(39); - } - } - if (bgChanged) { - const color = cell.getBgColor(); - if (cell.isBgRGB()) { - sgrSeq.push(48, 2, (color >>> 16) & 0xFF, (color >>> 8) & 0xFF, color & 0xFF); - } - else if (cell.isBgPalette()) { - if (color >= 16) { - sgrSeq.push(48, 5, color); - } - else { - sgrSeq.push(color & 8 ? 100 + (color & 7) : 40 + (color & 7)); - } - } - else { - sgrSeq.push(49); - } - } - if (flagsChanged) { - if (cell.isInverse() !== oldCell.isInverse()) { - sgrSeq.push(cell.isInverse() ? 7 : 27); - } - if (cell.isBold() !== oldCell.isBold()) { - sgrSeq.push(cell.isBold() ? 1 : 22); - } - if (cell.isUnderline() !== oldCell.isUnderline()) { - sgrSeq.push(cell.isUnderline() ? 4 : 24); - } - if (cell.isBlink() !== oldCell.isBlink()) { - sgrSeq.push(cell.isBlink() ? 5 : 25); - } - if (cell.isInvisible() !== oldCell.isInvisible()) { - sgrSeq.push(cell.isInvisible() ? 8 : 28); - } - if (cell.isItalic() !== oldCell.isItalic()) { - sgrSeq.push(cell.isItalic() ? 3 : 23); - } - if (cell.isDim() !== oldCell.isDim()) { - sgrSeq.push(cell.isDim() ? 2 : 22); - } - } - } - } - return sgrSeq; - } - _nextCell(cell, oldCell, row, col) { - // a width 0 cell don't need to be count because it is just a placeholder after a CJK character; - const isPlaceHolderCell = cell.getWidth() === 0; - if (isPlaceHolderCell) { - return; - } - // this cell don't have content - const isEmptyCell = cell.getChars() === ''; - const sgrSeq = this._diffStyle(cell, this._cursorStyle); - // the empty cell style is only assumed to be changed when background changed, because foreground is always 0. - const styleChanged = isEmptyCell ? !equalBg(this._cursorStyle, cell) : sgrSeq.length > 0; - /** - * handles style change - */ - if (styleChanged) { - // before update the style, we need to fill empty cell back - if (this._nullCellCount > 0) { - // use clear right to set background. - if (!equalBg(this._cursorStyle, this._backgroundCell)) { - this._currentRow += `\x1b[${this._nullCellCount}X`; - } - // use move right to move cursor. - this._currentRow += `\x1b[${this._nullCellCount}C`; - this._nullCellCount = 0; - } - this._lastContentCursorRow = this._lastCursorRow = row; - this._lastContentCursorCol = this._lastCursorCol = col; - this._currentRow += `\x1b[${sgrSeq.join(';')}m`; - // update the last cursor style - const line = this._buffer1.getLine(row); - if (line !== undefined) { - line.getCell(col, this._cursorStyle); - this._cursorStyleRow = row; - this._cursorStyleCol = col; - } - } - /** - * handles actual content - */ - if (isEmptyCell) { - this._nullCellCount += cell.getWidth(); - } - else { - if (this._nullCellCount > 0) { - // we can just assume we have same style with previous one here - // because style change is handled by previous stage - // use move right when background is empty, use clear right when there is background. - if (equalBg(this._cursorStyle, this._backgroundCell)) { - this._currentRow += `\x1b[${this._nullCellCount}C`; - } - else { - this._currentRow += `\x1b[${this._nullCellCount}X`; - this._currentRow += `\x1b[${this._nullCellCount}C`; - } - this._nullCellCount = 0; - } - this._currentRow += cell.getChars(); - // update cursor - this._lastContentCursorRow = this._lastCursorRow = row; - this._lastContentCursorCol = this._lastCursorCol = col + cell.getWidth(); - } - } - _serializeString() { - let rowEnd = this._allRows.length; - // the fixup is only required for data without scrollback - // because it will always be placed at last line otherwise - if (this._buffer1.length - this._firstRow <= this._terminal.rows) { - rowEnd = this._lastContentCursorRow + 1 - this._firstRow; - this._lastCursorCol = this._lastContentCursorCol; - this._lastCursorRow = this._lastContentCursorRow; - } - let content = ''; - for (let i = 0; i < rowEnd; i++) { - content += this._allRows[i]; - if (i + 1 < rowEnd) { - content += this._allRowSeparators[i]; - } - } - // restore the cursor - const realCursorRow = this._buffer1.baseY + this._buffer1.cursorY; - const realCursorCol = this._buffer1.cursorX; - const cursorMoved = (realCursorRow !== this._lastCursorRow || realCursorCol !== this._lastCursorCol); - const moveRight = (offset) => { - if (offset > 0) { - content += `\u001b[${offset}C`; - } - else if (offset < 0) { - content += `\u001b[${-offset}D`; - } - }; - const moveDown = (offset) => { - if (offset > 0) { - content += `\u001b[${offset}B`; - } - else if (offset < 0) { - content += `\u001b[${-offset}A`; - } - }; - if (cursorMoved) { - moveDown(realCursorRow - this._lastCursorRow); - moveRight(realCursorCol - this._lastCursorCol); - } - return content; - } -} -class SerializeAddon { - constructor() { } - activate(terminal) { - this._terminal = terminal; - } - _getString(buffer, scrollback) { - const maxRows = buffer.length; - const handler = new StringSerializeHandler(buffer, this._terminal); - const correctRows = (scrollback === undefined) ? maxRows : constrain(scrollback + this._terminal.rows, 0, maxRows); - const result = handler.serialize(maxRows - correctRows, maxRows); - return result; - } - serialize(scrollback) { - // TODO: Add combinedData support - if (!this._terminal) { - throw new Error('Cannot use addon until it has been loaded'); - } - if (this._terminal.buffer.active.type === 'normal') { - return this._getString(this._terminal.buffer.active, scrollback); - } - const normalScreenContent = this._getString(this._terminal.buffer.normal, scrollback); - // alt screen don't have scrollback - const alternativeScreenContent = this._getString(this._terminal.buffer.alternate, undefined); - return normalScreenContent - + '\u001b[?1049h\u001b[H' - + alternativeScreenContent; - } - dispose() { } -} -exports.SerializeAddon = SerializeAddon; diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out-test/SerializeAddon.api.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out-test/SerializeAddon.api.js.map deleted file mode 100755 index 857ab3ff2..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out-test/SerializeAddon.api.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"SerializeAddon.api.js","sourceRoot":"","sources":["../test/SerializeAddon.api.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,6BAA8B;AAC9B,6DAA0F;AAG1F,IAAM,GAAG,GAAG,4BAA4B,CAAC;AAEzC,IAAI,OAAgB,CAAC;AACrB,IAAI,IAAU,CAAC;AACf,IAAM,KAAK,GAAG,GAAG,CAAC;AAClB,IAAM,MAAM,GAAG,GAAG,CAAC;AAEnB,IAAM,YAAY,GAAG,UAAC,IAAS,EAAE,GAAW,IAAoB,OAAA,qBAAS,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,EAAtD,CAAsD,CAAC;AAEvH,IAAM,qBAAqB,GAAG,UAAO,IAAS,EAAE,GAAW;;;;oBACzD,WAAM,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC,EAAA;;gBAA7B,SAA6B,CAAC;gBACP,WAAM,IAAI,CAAC,QAAQ,CAAC,oCAAoC,CAAC,EAAA;;gBAA1E,cAAc,GAAG,SAAyD;gBAEjE,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;gBAA3D,MAAM,GAAG,SAA4D;gBAC3E,WAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAA;;gBAApC,SAAoC,CAAC;gBACrC,WAAM,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,EAAA;;gBAAhC,SAAgC,CAAC;gBACf,WAAM,IAAI,CAAC,QAAQ,CAAC,oCAAoC,CAAC,EAAA;;gBAArE,SAAS,GAAG,SAAyD;gBAI3E,aAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC;;;;KACzE,CAAC;AAEF,QAAQ,CAAC,gBAAgB,EAAE;IACzB,MAAM,CAAC;;;;;;wBACC,WAAW,GAAG,0BAAc,EAAE,CAAC;wBAC3B,WAAM,WAAW,CAAC,MAAM,CAAC;gCACjC,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;6BACpD,CAAC,EAAA;;wBAFF,OAAO,GAAG,SAER,CAAC;wBACW,WAAM,OAAO,CAAC,UAAU,EAAE,EAAA;4BAAjC,WAAM,CAAC,SAA0B,CAAC,CAAC,OAAO,EAAE,EAAA;;wBAAnD,IAAI,GAAG,SAA4C,CAAC;wBACpD,WAAM,IAAI,CAAC,eAAe,CAAC,EAAE,KAAK,OAAA,EAAE,MAAM,QAAA,EAAE,CAAC,EAAA;;wBAA7C,SAA6C,CAAC;wBAC9C,WAAM,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAA;;wBAApB,SAAoB,CAAC;wBACrB,WAAM,wBAAY,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,EAAA;;wBAArE,SAAqE,CAAC;wBACtE,WAAM,IAAI,CAAC,QAAQ,CAAC,oiBAgBnB,CAAC,EAAA;;wBAhBF,SAgBE,CAAC;;;;;KACJ,CAAC,CAAC;IAEH,KAAK,CAAC;;oBAAY,WAAM,OAAO,CAAC,KAAK,EAAE,EAAA;oBAArB,WAAA,SAAqB,EAAA;;aAAA,CAAC,CAAC;IACzC,UAAU,CAAC;;oBAAY,WAAM,IAAI,CAAC,QAAQ,CAAC,qBAAqB,CAAC,EAAA;oBAA1C,WAAA,SAA0C,EAAA;;aAAA,CAAC,CAAC;IAEnE,EAAE,CAAC,qEAAqE,EAAE;;;;;4BACxE,WAAM,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,EAAA;;wBAAjC,SAAiC,CAAC;wBAClB,WAAM,IAAI,CAAC,QAAQ,CAAC,oCAAoC,CAAC,EAAA;;wBAAnE,OAAO,GAAG,SAAyD;wBAEzE,WAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAA;;wBAApC,SAAoC,CAAC;wBACrC,WAAM,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,EAAA;;wBAAjC,SAAiC,CAAC;wBAClB,WAAM,IAAI,CAAC,QAAQ,CAAC,oCAAoC,CAAC,EAAA;;wBAAnE,OAAO,GAAG,SAAyD;wBAEzE,aAAM,CAAC,KAAK,CAAC;4BACX,aAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;wBACjE,CAAC,CAAC,CAAC;;;;;KACJ,CAAC,CAAC;IAEH,EAAE,CAAC,0EAA0E,EAAE;;;;;4BAC7E,WAAM,YAAY,CAAC,IAAI,EAAE,qBAAqB,CAAC,EAAA;;wBAA/C,SAA+C,CAAC;wBAChC,WAAM,IAAI,CAAC,QAAQ,CAAC,oCAAoC,CAAC,EAAA;;wBAAnE,OAAO,GAAG,SAAyD;wBAEzE,WAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAA;;wBAApC,SAAoC,CAAC;wBACrC,WAAM,YAAY,CAAC,IAAI,EAAE,kBAAkB,CAAC,EAAA;;wBAA5C,SAA4C,CAAC;wBAC7B,WAAM,IAAI,CAAC,QAAQ,CAAC,oCAAoC,CAAC,EAAA;;wBAAnE,OAAO,GAAG,SAAyD;wBAEzE,aAAM,CAAC,KAAK,CAAC;4BACX,aAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;wBACjE,CAAC,CAAC,CAAC;;;;;KACJ,CAAC,CAAC;IAEH,EAAE,CAAC,eAAe,EAAE;;;;;;wBACZ,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,EAAE,CAAC;wBAChB,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,EAAE,EAAC,CAAC;;;;;KACtE,CAAC,CAAC;IAEH,EAAE,CAAC,qBAAqB,EAAE;;;;;;wBAClB,KAAK,GAAG,CAAC,oBAAoB,CAAC,CAAC;wBACrC,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;;;;;;wBAC/B,KAAK,GAAG;4BACZ,WAAW;4BACX,WAAW;yBACZ,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAGH,EAAE,CAAC,2BAA2B,EAAE;;;;;;wBACxB,IAAI,GAAG,EAAE,CAAC;wBACV,KAAK,GAAG;4BACZ,EAAE;4BACF,EAAE;4BACF,YAAY,CAAC,IAAI,CAAC;4BAClB,YAAY,CAAC,IAAI,CAAC;4BAClB,EAAE;4BACF,EAAE;4BACF,YAAY,CAAC,IAAI,CAAC;4BAClB,YAAY,CAAC,IAAI,CAAC;4BAClB,EAAE;4BACF,EAAE;4BACF,EAAE;yBACH,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,gBAAgB,EAAE;;;;;;wBACb,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,EAAE,CAAC;wBACV,UAAU,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;wBAChC,KAAK,GAAG,QAAQ,CAAS,UAAU,EAAE,IAAI,CAAC,CAAC;wBACjD,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE;;;;;;wBAChC,IAAI,GAAG,EAAE,CAAC;wBACV,UAAU,GAAG,IAAI,GAAG,EAAE,CAAC;wBACvB,cAAc,GAAG,UAAU,GAAG,CAAC,CAAC;wBAChC,IAAI,GAAG,EAAE,CAAC;wBACV,KAAK,GAAG,QAAQ,CAAS,UAAC,KAAa,IAAK,OAAA,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,EAAzB,CAAyB,EAAE,IAAI,CAAC,CAAC;wBACnF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,8BAA4B,cAAc,OAAI,CAAC,EAAA;;wBAAhF,cAAa,SAAmE,EAAE,KAAK,CAAC,KAAK,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACnI,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;;;;;;wBAC7B,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,EAAE,CAAC;wBACV,KAAK,GAAG,QAAQ,CAAS,UAAC,KAAa,IAAK,OAAA,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,EAAzB,CAAyB,EAAE,IAAI,CAAC,CAAC;wBACnF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,8BAA8B,CAAC,EAAA;;wBAAhE,cAAa,SAAmD,EAAE,KAAK,CAAC,KAAK,CAAC,IAAI,GAAG,EAAE,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KAC9G,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE;;;;;;wBACzC,IAAI,GAAG,EAAE,CAAC;wBACV,OAAO,GAAG;4BACd,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE;4BAC9B,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE;4BAC9B,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE;4BAC9B,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;yBAClC,CAAC;wBACI,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC;wBACtB,KAAK,GAAG,QAAQ,CACpB,UAAC,KAAa,IAAK,OAAA,YAAY,CAAC,IAAI,EAAE,KAAK,EAAE,YAAQ,OAAO,CAAC,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,MAAG,CAAC,EAArE,CAAqE,EACxF,IAAI,CACL,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE;;;;;;wBAC7C,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;wBACxB,KAAK,GAAa;4BACtB,KAAK,CAAC,YAAY,CAAC,GAAG,IAAI;4BAC1B,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI;4BACrB,KAAK,CAAC,IAAI,CAAC,GAAG,IAAI;4BAClB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,KAAK,CAAC,GAAG,IAAI;4BACnB,KAAK,CAAC,SAAS,CAAC,GAAG,IAAI;4BACvB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI;4BACrB,KAAK,CAAC,aAAa,CAAC,GAAG,IAAI;4BAC3B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,YAAY,CAAC,GAAG,IAAI;yBAC3B,CAAC;wBACI,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC;wBAC1B,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE;;;;;;wBAC1C,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,EAAE,CAAC;wBACV,KAAK,GAAG,QAAQ,CACpB,UAAC,KAAa,IAAK,OAAA,YAAY,CAAC,IAAI,EAAE,KAAK,EAAE,kBAAa,EAAE,GAAG,KAAK,OAAG,CAAC,EAArD,CAAqD,EACxE,IAAI,CACL,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,iEAAiE,EAAE;;;;;;wBAC9D,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;wBACxB,KAAK,GAAa;4BACtB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,YAAY,CAAC,GAAG,IAAI;4BAC1B,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI;4BACrB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI;4BACrB,KAAK,CAAC,aAAa,CAAC,GAAG,IAAI;4BAC3B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI;yBACrB,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE;;;;;;wBAC5D,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;wBACxB,KAAK,GAAa;4BACtB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,YAAY,EAAE,aAAa,CAAC,GAAG,IAAI;4BACzC,KAAK,CAAC,UAAU,EAAE,MAAM,CAAC,GAAG,IAAI;4BAChC,KAAK,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,IAAI;4BACtC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAI;4BAC9B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI;4BACpB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,YAAY,EAAE,aAAa,CAAC,GAAG,IAAI;4BACzC,KAAK,CAAC,UAAU,EAAE,MAAM,CAAC,GAAG,IAAI;4BAChC,KAAK,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,IAAI;4BACtC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAI;4BAC9B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;yBACvB,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,kEAAkE,EAAE;;;;;;wBAC/D,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;wBACxB,KAAK,GAAa;4BACtB,KAAK,CAAC,WAAW,CAAC,GAAG,IAAI;4BACzB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,aAAa,CAAC,GAAG,IAAI;4BAC3B,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI;4BACrB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI;4BACrB,KAAK,CAAC,cAAc,CAAC,GAAG,IAAI;4BAC5B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI;yBACrB,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,gEAAgE,EAAE;;;;;;wBAC7D,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;wBACxB,KAAK,GAAa;4BACtB,KAAK,CAAC,WAAW,CAAC,GAAG,IAAI;4BACzB,KAAK,CAAC,aAAa,EAAE,cAAc,CAAC,GAAG,IAAI;4BAC3C,KAAK,CAAC,UAAU,EAAE,MAAM,CAAC,GAAG,IAAI;4BAChC,KAAK,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,IAAI;4BACtC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAI;4BAC9B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI;4BACpB,KAAK,CAAC,WAAW,CAAC,GAAG,IAAI;4BACzB,KAAK,CAAC,aAAa,EAAE,cAAc,CAAC,GAAG,IAAI;4BAC3C,KAAK,CAAC,UAAU,EAAE,MAAM,CAAC,GAAG,IAAI;4BAChC,KAAK,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,IAAI;4BACtC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAI;4BAC9B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;yBACvB,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,kEAAkE,EAAE;;;;;;wBAC/D,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;wBACxB,KAAK,GAAa;4BACtB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,YAAY,CAAC,GAAG,IAAI;4BAC1B,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI;4BACrB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI;4BACrB,KAAK,CAAC,aAAa,CAAC,GAAG,IAAI;4BAC3B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI;yBACrB,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,gEAAgE,EAAE;;;;;;wBAC7D,IAAI,GAAG,EAAE,CAAC;wBACV,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;wBACxB,KAAK,GAAa;4BACtB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,YAAY,EAAE,aAAa,CAAC,GAAG,IAAI;4BACzC,KAAK,CAAC,UAAU,EAAE,MAAM,CAAC,GAAG,IAAI;4BAChC,KAAK,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,IAAI;4BACtC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAI;4BAC9B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;4BACtB,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI;4BACpB,KAAK,CAAC,UAAU,CAAC,GAAG,IAAI;4BACxB,KAAK,CAAC,YAAY,EAAE,aAAa,CAAC,GAAG,IAAI;4BACzC,KAAK,CAAC,UAAU,EAAE,MAAM,CAAC,GAAG,IAAI;4BAChC,KAAK,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,IAAI;4BACtC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,IAAI;4BAC9B,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI;yBACvB,CAAC;wBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;wBAA3C,SAA2C,CAAC;wBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;wBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;wBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;;KACtF,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE;;;;;oBACvB,KAAK,GAAG;wBACZ,MAAM;wBACN,OAAO;wBACP,QAAQ;qBACT,CAAC;oBACI,QAAQ,GAAG;wBACf,WAAW;wBACX,YAAY;wBACZ,aAAa;qBACd,CAAC;oBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;oBAA3C,SAA2C,CAAC;oBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;oBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;oBAA/D,cAAa,SAAkD,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;SACzF,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE;;;;;oBACtB,KAAK,GAAG;wBACZ,MAAM;wBACN,MAAM;wBACN,MAAM;wBAMN,QAAQ;qBACT,CAAC;oBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;oBAA3C,SAA2C,CAAC;oBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;oBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;oBAA/D,cAAa,SAAkD,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;SACtF,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE;;;;;oBACrC,KAAK,GAAG;wBACZ,QAAQ;qBACT,CAAC;oBACI,QAAQ,GAAG;wBACf,aAAa;qBACd,CAAC;oBACF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;oBAA3C,SAA2C,CAAC;oBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;oBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;oBAA/D,cAAa,SAAkD,EAAE,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;;;;SACzF,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE;;;;;oBAClC,KAAK,GAAG,eAAe,CAAC;oBACxB,GAAG,GAAG,UAAU,CAAC;oBAEjB,KAAK,GAAG;wBACZ,MAAI,KAAK,GAAG,GAAG,MAAG;qBACnB,CAAC;oBACI,QAAQ,GAAG;wBACf,MAAI,KAAK,GAAG,GAAG,MAAG;qBACnB,CAAC;oBAEF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;oBAA3C,SAA2C,CAAC;oBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;oBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,gCAAgC,CAAC,EAAA;;oBAAlE,cAAa,SAAqD,EAAE,WAAW,EAAC,CAAC;oBACjF,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;oBAAC,KAAA,CAAA,KAAA,IAAI,CAAA,CAAC,SAAS,CAAA;oBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;oBAA9E,cAAa,cAAe,SAAkD,EAAC,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAC,CAAC;;;;SACzH,CAAC,CAAC;IAEH,EAAE,CAAC,wCAAwC,EAAE;;;;;oBACrC,KAAK,GAAG,eAAe,CAAC;oBACxB,KAAK,GAAG,eAAe,CAAC;oBAExB,KAAK,GAAG;wBACZ,MAAI,KAAK,SAAI,KAAO;qBACrB,CAAC;oBACI,QAAQ,GAAG;wBACf,GAAG;qBACJ,CAAC;oBAEF,WAAM,qBAAS,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAA;;oBAA3C,SAA2C,CAAC;oBAC5C,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;oBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,gCAAgC,CAAC,EAAA;;oBAAlE,cAAa,SAAqD,EAAE,QAAQ,EAAC,CAAC;oBAC9E,KAAA,CAAA,KAAA,aAAM,CAAA,CAAC,KAAK,CAAA;oBAAC,KAAA,CAAA,KAAA,IAAI,CAAA,CAAC,SAAS,CAAA;oBAAC,WAAM,IAAI,CAAC,QAAQ,CAAC,6BAA6B,CAAC,EAAA;;oBAA9E,cAAa,cAAe,SAAkD,EAAC,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAC,CAAC;;;;SACzH,CAAC,CAAC;IAEH,EAAE,CAAC,2BAA2B,EAAE;;;;;oBACxB,WAAW,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBAEpD,KAAK,GAAG;wBACZ,gBAAc,WAAW,CAAC,CAAC,CAAG;wBAC9B,MAAI,WAAW,CAAC,CAAC,CAAG;qBACrB,CAAC;oBAEF,WAAM,qBAAqB,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAA;;oBAArD,SAAqD,CAAC;;;;SACvD,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE;;;;;oBACtB,WAAW,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBAEpD,QAAQ,GAAG,QAAQ,CACvB,UAAC,KAAa,IAAK,OAAA,YAAY,CAAC,EAAE,EAAE,KAAK,CAAC,EAAvB,CAAuB,EAC1C,EAAE,CACH,CAAC;oBAEI,KAAK,kBACN,QAAQ;wBACX,eAAa,WAAW,CAAC,CAAC,CAAC,qBAAkB;sBAC9C,CAAC;oBAEF,WAAM,qBAAqB,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,EAAA;;oBAArD,SAAqD,CAAC;;;;SACvD,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE;;;;;oBAChC,WAAW,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBACpD,OAAO,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBAChD,SAAS,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBAClD,SAAS,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBAKlD,QAAQ,GAAG;wBACf,iBAAiB;wBACjB,OAAO,CAAC,CAAC,CAAC;wBACV,WAAW,CAAC,CAAC,CAAC;wBACd,SAAS,CAAC,CAAC,CAAC;wBACZ,SAAS,CAAC,CAAC,CAAC;wBACZ,WAAW,CAAC,CAAC,CAAC;wBACd,OAAO,CAAC,CAAC,CAAC;wBACV,GAAG;qBACJ,CAAC;oBAEF,WAAM,qBAAqB,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAA;;oBAApD,SAAoD,CAAC;;;;SACtD,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE;;;;;oBAC/B,WAAW,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBACpD,OAAO,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBAChD,SAAS,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBAClD,SAAS,GAAG,UAAC,CAAS,IAAa,OAAA,YAAU,CAAC,MAAG,EAAd,CAAc,CAAC;oBAElD,QAAQ,GAAG,QAAQ,CACvB,UAAC,KAAa,IAAK,OAAA,YAAY,CAAC,EAAE,EAAE,KAAK,CAAC,EAAvB,CAAuB,EAC1C,EAAE,CACH,CAAC;oBAKI,KAAK,GAAG;wBACZ,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC;wBACrB,MAAM;wBACN,iBAAiB;wBACjB,OAAO,CAAC,CAAC,CAAC;wBACV,WAAW,CAAC,CAAC,CAAC;wBACd,SAAS,CAAC,CAAC,CAAC;wBACZ,SAAS,CAAC,CAAC,CAAC;wBACZ,WAAW,CAAC,CAAC,CAAC;wBACd,OAAO,CAAC,CAAC,CAAC;wBACV,GAAG;qBACJ,CAAC;oBAEF,WAAM,qBAAqB,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAA;;oBAAjD,SAAiD,CAAC;;;;SACnD,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,SAAS,QAAQ,CAAI,OAAmC,EAAE,KAAa;IACrE,IAAM,KAAK,GAAQ,IAAI,KAAK,CAAI,KAAK,CAAC,CAAC;IACvC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACrC,IAAI,OAAO,OAAO,KAAK,UAAU,EAAE;YACjC,KAAK,CAAC,CAAC,CAAC,GAA0B,OAAQ,CAAC,CAAC,CAAC,CAAC;SAC/C;aAAM;YACL,KAAK,CAAC,CAAC,CAAC,GAAM,OAAO,CAAC;SACvB;KACF;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,YAAY,CAAC,MAAc,EAAE,IAAgB,EAAE,GAAgB;IAAlC,qBAAA,EAAA,QAAgB;IAAE,oBAAA,EAAA,QAAgB;IACtE,IAAI,CAAC,GAAG,GAAG,CAAC;IACZ,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,EAAE;QAC/B,CAAC,IAAI,KAAG,CAAC,IAAI,EAAE,CAAC,GAAG,EAAI,CAAC;KACzB;IACD,OAAO,CAAC,CAAC;AACX,CAAC;AAED,SAAS,KAAK;IAAC,aAAgB;SAAhB,UAAgB,EAAhB,qBAAgB,EAAhB,IAAgB;QAAhB,wBAAgB;;IAC7B,OAAO,YAAQ,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,MAAG,CAAC;AAClC,CAAC;AAED,IAAM,MAAM,GAAG,GAAG,CAAC;AAEnB,IAAM,UAAU,GAAG,IAAI,CAAC;AACxB,IAAM,YAAY,GAAG,IAAI,CAAC;AAC1B,IAAM,aAAa,GAAG,IAAI,CAAC;AAC3B,IAAM,WAAW,GAAG,UAAU,CAAC;AAC/B,IAAM,aAAa,GAAG,SAAS,CAAC;AAChC,IAAM,cAAc,GAAG,UAAU,CAAC;AAClC,IAAM,UAAU,GAAG,cAAc,CAAC;AAClC,IAAM,YAAY,GAAG,cAAc,CAAC;AACpC,IAAM,aAAa,GAAG,gBAAgB,CAAC;AACvC,IAAM,QAAQ,GAAG,IAAI,CAAC;AAGtB,IAAM,UAAU,GAAG,IAAI,CAAC;AACxB,IAAM,YAAY,GAAG,IAAI,CAAC;AAC1B,IAAM,aAAa,GAAG,IAAI,CAAC;AAC3B,IAAM,WAAW,GAAG,UAAU,CAAC;AAC/B,IAAM,aAAa,GAAG,SAAS,CAAC;AAChC,IAAM,cAAc,GAAG,UAAU,CAAC;AAClC,IAAM,UAAU,GAAG,cAAc,CAAC;AAClC,IAAM,YAAY,GAAG,cAAc,CAAC;AACpC,IAAM,aAAa,GAAG,gBAAgB,CAAC;AACvC,IAAM,QAAQ,GAAG,IAAI,CAAC;AAEtB,IAAM,OAAO,GAAG,GAAG,CAAC;AACpB,IAAM,IAAI,GAAG,GAAG,CAAC;AACjB,IAAM,UAAU,GAAG,GAAG,CAAC;AACvB,IAAM,KAAK,GAAG,GAAG,CAAC;AAClB,IAAM,SAAS,GAAG,GAAG,CAAC;AAEtB,IAAM,UAAU,GAAG,IAAI,CAAC;AACxB,IAAM,OAAO,GAAG,IAAI,CAAC;AACrB,IAAM,aAAa,GAAG,IAAI,CAAC;AAC3B,IAAM,QAAQ,GAAG,IAAI,CAAC;AACtB,IAAM,YAAY,GAAG,IAAI,CAAC;AAE1B,IAAM,MAAM,GAAG,GAAG,CAAC;AACnB,IAAM,GAAG,GAAG,GAAG,CAAC;AAEhB,IAAM,SAAS,GAAG,IAAI,CAAC;AACvB,IAAM,MAAM,GAAG,IAAI,CAAC"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out/SerializeAddon.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out/SerializeAddon.js deleted file mode 100755 index 5f0b45b48..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out/SerializeAddon.js +++ /dev/null @@ -1,350 +0,0 @@ -"use strict"; -var __extends = (this && this.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; -})(); -Object.defineProperty(exports, "__esModule", { value: true }); -exports.SerializeAddon = void 0; -function constrain(value, low, high) { - return Math.max(low, Math.min(value, high)); -} -var BaseSerializeHandler = (function () { - function BaseSerializeHandler(_buffer) { - this._buffer = _buffer; - } - BaseSerializeHandler.prototype.serialize = function (startRow, endRow) { - var cell1 = this._buffer.getNullCell(); - var cell2 = this._buffer.getNullCell(); - var oldCell = cell1; - this._beforeSerialize(endRow - startRow, startRow, endRow); - for (var row = startRow; row < endRow; row++) { - var line = this._buffer.getLine(row); - if (line) { - for (var col = 0; col < line.length; col++) { - var c = line.getCell(col, oldCell === cell1 ? cell2 : cell1); - if (!c) { - console.warn("Can't get cell at row=" + row + ", col=" + col); - continue; - } - this._nextCell(c, oldCell, row, col); - oldCell = c; - } - } - this._rowEnd(row, row === endRow - 1); - } - this._afterSerialize(); - return this._serializeString(); - }; - BaseSerializeHandler.prototype._nextCell = function (cell, oldCell, row, col) { }; - BaseSerializeHandler.prototype._rowEnd = function (row, isLastRow) { }; - BaseSerializeHandler.prototype._beforeSerialize = function (rows, startRow, endRow) { }; - BaseSerializeHandler.prototype._afterSerialize = function () { }; - BaseSerializeHandler.prototype._serializeString = function () { return ''; }; - return BaseSerializeHandler; -}()); -function equalFg(cell1, cell2) { - return cell1.getFgColorMode() === cell2.getFgColorMode() - && cell1.getFgColor() === cell2.getFgColor(); -} -function equalBg(cell1, cell2) { - return cell1.getBgColorMode() === cell2.getBgColorMode() - && cell1.getBgColor() === cell2.getBgColor(); -} -function equalFlags(cell1, cell2) { - return cell1.isInverse() === cell2.isInverse() - && cell1.isBold() === cell2.isBold() - && cell1.isUnderline() === cell2.isUnderline() - && cell1.isBlink() === cell2.isBlink() - && cell1.isInvisible() === cell2.isInvisible() - && cell1.isItalic() === cell2.isItalic() - && cell1.isDim() === cell2.isDim(); -} -var StringSerializeHandler = (function (_super) { - __extends(StringSerializeHandler, _super); - function StringSerializeHandler(_buffer1, _terminal) { - var _this = _super.call(this, _buffer1) || this; - _this._buffer1 = _buffer1; - _this._terminal = _terminal; - _this._rowIndex = 0; - _this._allRows = new Array(); - _this._allRowSeparators = new Array(); - _this._currentRow = ''; - _this._nullCellCount = 0; - _this._cursorStyle = _this._buffer1.getNullCell(); - _this._cursorStyleRow = 0; - _this._cursorStyleCol = 0; - _this._backgroundCell = _this._buffer1.getNullCell(); - _this._firstRow = 0; - _this._lastCursorRow = 0; - _this._lastCursorCol = 0; - _this._lastContentCursorRow = 0; - _this._lastContentCursorCol = 0; - _this._thisRowLastChar = _this._buffer1.getNullCell(); - _this._thisRowLastSecondChar = _this._buffer1.getNullCell(); - _this._nextRowFirstChar = _this._buffer1.getNullCell(); - return _this; - } - StringSerializeHandler.prototype._beforeSerialize = function (rows, start, end) { - this._allRows = new Array(rows); - this._lastContentCursorRow = start; - this._lastCursorRow = start; - this._firstRow = start; - }; - StringSerializeHandler.prototype._rowEnd = function (row, isLastRow) { - var _a; - if (this._nullCellCount > 0 && !equalBg(this._cursorStyle, this._backgroundCell)) { - this._currentRow += "\u001B[" + this._nullCellCount + "X"; - } - var rowSeparator = ''; - if (!isLastRow) { - if (row - this._firstRow >= this._terminal.rows) { - (_a = this._buffer1.getLine(this._cursorStyleRow)) === null || _a === void 0 ? void 0 : _a.getCell(this._cursorStyleCol, this._backgroundCell); - } - var currentLine = this._buffer1.getLine(row); - var nextLine = this._buffer1.getLine(row + 1); - if (!nextLine.isWrapped) { - rowSeparator = '\r\n'; - this._lastCursorRow = row + 1; - this._lastCursorCol = 0; - } - else { - rowSeparator = ''; - var thisRowLastChar = currentLine.getCell(currentLine.length - 1, this._thisRowLastChar); - var thisRowLastSecondChar = currentLine.getCell(currentLine.length - 2, this._thisRowLastSecondChar); - var nextRowFirstChar = nextLine.getCell(0, this._nextRowFirstChar); - var isNextRowFirstCharDoubleWidth = nextRowFirstChar.getWidth() > 1; - var isValid = false; - if (nextRowFirstChar.getChars() && - isNextRowFirstCharDoubleWidth ? this._nullCellCount <= 1 : this._nullCellCount <= 0) { - if ((thisRowLastChar.getChars() || thisRowLastChar.getWidth() === 0) && - equalBg(thisRowLastChar, nextRowFirstChar)) { - isValid = true; - } - if (isNextRowFirstCharDoubleWidth && - (thisRowLastSecondChar.getChars() || thisRowLastSecondChar.getWidth() === 0) && - equalBg(thisRowLastChar, nextRowFirstChar) && - equalBg(thisRowLastSecondChar, nextRowFirstChar)) { - isValid = true; - } - } - if (!isValid) { - rowSeparator = '-'.repeat(this._nullCellCount + 1); - rowSeparator += '\x1b[1D\x1b[1X'; - if (this._nullCellCount > 0) { - rowSeparator += '\x1b[A'; - rowSeparator += "\u001B[" + (currentLine.length - this._nullCellCount) + "C"; - rowSeparator += "\u001B[" + this._nullCellCount + "X"; - rowSeparator += "\u001B[" + (currentLine.length - this._nullCellCount) + "D"; - rowSeparator += '\x1b[B'; - } - this._lastContentCursorRow = row + 1; - this._lastContentCursorCol = 0; - this._lastCursorRow = row + 1; - this._lastCursorCol = 0; - } - } - } - this._allRows[this._rowIndex] = this._currentRow; - this._allRowSeparators[this._rowIndex++] = rowSeparator; - this._currentRow = ''; - this._nullCellCount = 0; - }; - StringSerializeHandler.prototype._diffStyle = function (cell, oldCell) { - var sgrSeq = []; - var fgChanged = !equalFg(cell, oldCell); - var bgChanged = !equalBg(cell, oldCell); - var flagsChanged = !equalFlags(cell, oldCell); - if (fgChanged || bgChanged || flagsChanged) { - if (cell.isAttributeDefault()) { - if (!oldCell.isAttributeDefault()) { - sgrSeq.push(0); - } - } - else { - if (fgChanged) { - var color = cell.getFgColor(); - if (cell.isFgRGB()) { - sgrSeq.push(38, 2, (color >>> 16) & 0xFF, (color >>> 8) & 0xFF, color & 0xFF); - } - else if (cell.isFgPalette()) { - if (color >= 16) { - sgrSeq.push(38, 5, color); - } - else { - sgrSeq.push(color & 8 ? 90 + (color & 7) : 30 + (color & 7)); - } - } - else { - sgrSeq.push(39); - } - } - if (bgChanged) { - var color = cell.getBgColor(); - if (cell.isBgRGB()) { - sgrSeq.push(48, 2, (color >>> 16) & 0xFF, (color >>> 8) & 0xFF, color & 0xFF); - } - else if (cell.isBgPalette()) { - if (color >= 16) { - sgrSeq.push(48, 5, color); - } - else { - sgrSeq.push(color & 8 ? 100 + (color & 7) : 40 + (color & 7)); - } - } - else { - sgrSeq.push(49); - } - } - if (flagsChanged) { - if (cell.isInverse() !== oldCell.isInverse()) { - sgrSeq.push(cell.isInverse() ? 7 : 27); - } - if (cell.isBold() !== oldCell.isBold()) { - sgrSeq.push(cell.isBold() ? 1 : 22); - } - if (cell.isUnderline() !== oldCell.isUnderline()) { - sgrSeq.push(cell.isUnderline() ? 4 : 24); - } - if (cell.isBlink() !== oldCell.isBlink()) { - sgrSeq.push(cell.isBlink() ? 5 : 25); - } - if (cell.isInvisible() !== oldCell.isInvisible()) { - sgrSeq.push(cell.isInvisible() ? 8 : 28); - } - if (cell.isItalic() !== oldCell.isItalic()) { - sgrSeq.push(cell.isItalic() ? 3 : 23); - } - if (cell.isDim() !== oldCell.isDim()) { - sgrSeq.push(cell.isDim() ? 2 : 22); - } - } - } - } - return sgrSeq; - }; - StringSerializeHandler.prototype._nextCell = function (cell, oldCell, row, col) { - var isPlaceHolderCell = cell.getWidth() === 0; - if (isPlaceHolderCell) { - return; - } - var isEmptyCell = cell.getChars() === ''; - var sgrSeq = this._diffStyle(cell, this._cursorStyle); - var styleChanged = isEmptyCell ? !equalBg(this._cursorStyle, cell) : sgrSeq.length > 0; - if (styleChanged) { - if (this._nullCellCount > 0) { - if (!equalBg(this._cursorStyle, this._backgroundCell)) { - this._currentRow += "\u001B[" + this._nullCellCount + "X"; - } - this._currentRow += "\u001B[" + this._nullCellCount + "C"; - this._nullCellCount = 0; - } - this._lastContentCursorRow = this._lastCursorRow = row; - this._lastContentCursorCol = this._lastCursorCol = col; - this._currentRow += "\u001B[" + sgrSeq.join(';') + "m"; - var line = this._buffer1.getLine(row); - if (line !== undefined) { - line.getCell(col, this._cursorStyle); - this._cursorStyleRow = row; - this._cursorStyleCol = col; - } - } - if (isEmptyCell) { - this._nullCellCount += cell.getWidth(); - } - else { - if (this._nullCellCount > 0) { - if (equalBg(this._cursorStyle, this._backgroundCell)) { - this._currentRow += "\u001B[" + this._nullCellCount + "C"; - } - else { - this._currentRow += "\u001B[" + this._nullCellCount + "X"; - this._currentRow += "\u001B[" + this._nullCellCount + "C"; - } - this._nullCellCount = 0; - } - this._currentRow += cell.getChars(); - this._lastContentCursorRow = this._lastCursorRow = row; - this._lastContentCursorCol = this._lastCursorCol = col + cell.getWidth(); - } - }; - StringSerializeHandler.prototype._serializeString = function () { - var rowEnd = this._allRows.length; - if (this._buffer1.length - this._firstRow <= this._terminal.rows) { - rowEnd = this._lastContentCursorRow + 1 - this._firstRow; - this._lastCursorCol = this._lastContentCursorCol; - this._lastCursorRow = this._lastContentCursorRow; - } - var content = ''; - for (var i = 0; i < rowEnd; i++) { - content += this._allRows[i]; - if (i + 1 < rowEnd) { - content += this._allRowSeparators[i]; - } - } - var realCursorRow = this._buffer1.baseY + this._buffer1.cursorY; - var realCursorCol = this._buffer1.cursorX; - var cursorMoved = (realCursorRow !== this._lastCursorRow || realCursorCol !== this._lastCursorCol); - var moveRight = function (offset) { - if (offset > 0) { - content += "\u001B[" + offset + "C"; - } - else if (offset < 0) { - content += "\u001B[" + -offset + "D"; - } - }; - var moveDown = function (offset) { - if (offset > 0) { - content += "\u001B[" + offset + "B"; - } - else if (offset < 0) { - content += "\u001B[" + -offset + "A"; - } - }; - if (cursorMoved) { - moveDown(realCursorRow - this._lastCursorRow); - moveRight(realCursorCol - this._lastCursorCol); - } - return content; - }; - return StringSerializeHandler; -}(BaseSerializeHandler)); -var SerializeAddon = (function () { - function SerializeAddon() { - } - SerializeAddon.prototype.activate = function (terminal) { - this._terminal = terminal; - }; - SerializeAddon.prototype._getString = function (buffer, scrollback) { - var maxRows = buffer.length; - var handler = new StringSerializeHandler(buffer, this._terminal); - var correctRows = (scrollback === undefined) ? maxRows : constrain(scrollback + this._terminal.rows, 0, maxRows); - var result = handler.serialize(maxRows - correctRows, maxRows); - return result; - }; - SerializeAddon.prototype.serialize = function (scrollback) { - if (!this._terminal) { - throw new Error('Cannot use addon until it has been loaded'); - } - if (this._terminal.buffer.active.type === 'normal') { - return this._getString(this._terminal.buffer.active, scrollback); - } - var normalScreenContent = this._getString(this._terminal.buffer.normal, scrollback); - var alternativeScreenContent = this._getString(this._terminal.buffer.alternate, undefined); - return normalScreenContent - + '\u001b[?1049h\u001b[H' - + alternativeScreenContent; - }; - SerializeAddon.prototype.dispose = function () { }; - return SerializeAddon; -}()); -exports.SerializeAddon = SerializeAddon; -//# sourceMappingURL=SerializeAddon.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out/SerializeAddon.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out/SerializeAddon.js.map deleted file mode 100755 index cd1f61ef5..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/out/SerializeAddon.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"SerializeAddon.js","sourceRoot":"","sources":["../src/SerializeAddon.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/src/SerializeAddon.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/src/SerializeAddon.ts deleted file mode 100755 index 0caaaa039..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/src/SerializeAddon.ts +++ /dev/null @@ -1,426 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - * - * (EXPERIMENTAL) This Addon is still under development - */ - -import { Terminal, ITerminalAddon, IBuffer, IBufferCell } from 'xterm'; - -function constrain(value: number, low: number, high: number): number { - return Math.max(low, Math.min(value, high)); -} - -// TODO: Refine this template class later -abstract class BaseSerializeHandler { - constructor(private _buffer: IBuffer) { } - - public serialize(startRow: number, endRow: number): string { - // we need two of them to flip between old and new cell - const cell1 = this._buffer.getNullCell(); - const cell2 = this._buffer.getNullCell(); - let oldCell = cell1; - - this._beforeSerialize(endRow - startRow, startRow, endRow); - - for (let row = startRow; row < endRow; row++) { - const line = this._buffer.getLine(row); - if (line) { - for (let col = 0; col < line.length; col++) { - const c = line.getCell(col, oldCell === cell1 ? cell2 : cell1); - if (!c) { - console.warn(`Can't get cell at row=${row}, col=${col}`); - continue; - } - this._nextCell(c, oldCell, row, col); - oldCell = c; - } - } - this._rowEnd(row, row === endRow - 1); - } - - this._afterSerialize(); - - return this._serializeString(); - } - - protected _nextCell(cell: IBufferCell, oldCell: IBufferCell, row: number, col: number): void { } - protected _rowEnd(row: number, isLastRow: boolean): void { } - protected _beforeSerialize(rows: number, startRow: number, endRow: number): void { } - protected _afterSerialize(): void { } - protected _serializeString(): string { return ''; } -} - -function equalFg(cell1: IBufferCell, cell2: IBufferCell): boolean { - return cell1.getFgColorMode() === cell2.getFgColorMode() - && cell1.getFgColor() === cell2.getFgColor(); -} - -function equalBg(cell1: IBufferCell, cell2: IBufferCell): boolean { - return cell1.getBgColorMode() === cell2.getBgColorMode() - && cell1.getBgColor() === cell2.getBgColor(); -} - -function equalFlags(cell1: IBufferCell, cell2: IBufferCell): boolean { - return cell1.isInverse() === cell2.isInverse() - && cell1.isBold() === cell2.isBold() - && cell1.isUnderline() === cell2.isUnderline() - && cell1.isBlink() === cell2.isBlink() - && cell1.isInvisible() === cell2.isInvisible() - && cell1.isItalic() === cell2.isItalic() - && cell1.isDim() === cell2.isDim(); -} - - - -class StringSerializeHandler extends BaseSerializeHandler { - private _rowIndex: number = 0; - private _allRows: string[] = new Array(); - private _allRowSeparators: string[] = new Array(); - private _currentRow: string = ''; - private _nullCellCount: number = 0; - - // we can see a full colored cell and a null cell that only have background the same style - // but the information isn't preserved by null cell itself - // so wee need to record it when required. - private _cursorStyle: IBufferCell = this._buffer1.getNullCell(); - - // where exact the cursor styles comes from - // because we can't copy the cell directly - // so we remember where the content comes from instead - private _cursorStyleRow: number = 0; - private _cursorStyleCol: number = 0; - - // this is a null cell for reference for checking whether background is empty or not - private _backgroundCell: IBufferCell = this._buffer1.getNullCell(); - - private _firstRow: number = 0; - private _lastCursorRow: number = 0; - private _lastCursorCol: number = 0; - private _lastContentCursorRow: number = 0; - private _lastContentCursorCol: number = 0; - - constructor(private _buffer1: IBuffer, private _terminal: Terminal) { - super(_buffer1); - } - - protected _beforeSerialize(rows: number, start: number, end: number): void { - this._allRows = new Array(rows); - this._lastContentCursorRow = start; - this._lastCursorRow = start; - this._firstRow = start; - } - - private _thisRowLastChar: IBufferCell = this._buffer1.getNullCell(); - private _thisRowLastSecondChar: IBufferCell = this._buffer1.getNullCell(); - private _nextRowFirstChar: IBufferCell = this._buffer1.getNullCell(); - protected _rowEnd(row: number, isLastRow: boolean): void { - // if there is colorful empty cell at line end, whe must pad it back, or the the color block will missing - if (this._nullCellCount > 0 && !equalBg(this._cursorStyle, this._backgroundCell)) { - // use clear right to set background. - this._currentRow += `\x1b[${this._nullCellCount}X`; - } - - let rowSeparator = ''; - - // handle row separator - if (!isLastRow) { - // Enable BCE - if (row - this._firstRow >= this._terminal.rows) { - this._buffer1.getLine(this._cursorStyleRow)?.getCell(this._cursorStyleCol, this._backgroundCell); - } - - // Fetch current line - const currentLine = this._buffer1.getLine(row)!; - // Fetch next line - const nextLine = this._buffer1.getLine(row + 1)!; - - if (!nextLine.isWrapped) { - // just insert the line break - rowSeparator = '\r\n'; - // we sended the enter - this._lastCursorRow = row + 1; - this._lastCursorCol = 0; - } else { - rowSeparator = ''; - const thisRowLastChar = currentLine.getCell(currentLine.length - 1, this._thisRowLastChar)!; - const thisRowLastSecondChar = currentLine.getCell(currentLine.length - 2, this._thisRowLastSecondChar)!; - const nextRowFirstChar = nextLine.getCell(0, this._nextRowFirstChar)!; - const isNextRowFirstCharDoubleWidth = nextRowFirstChar.getWidth() > 1; - - // validate whether this line wrap is ever possible - // which mean whether cursor can placed at a overflow position (x === row) naturally - let isValid = false; - - if ( - // you must output character to cause overflow, control sequence can't do this - nextRowFirstChar.getChars() && - isNextRowFirstCharDoubleWidth ? this._nullCellCount <= 1 : this._nullCellCount <= 0 - ) { - if ( - // the last character can't be null, - // you can't use control sequence to move cursor to (x === row) - (thisRowLastChar.getChars() || thisRowLastChar.getWidth() === 0) && - // change background of the first wrapped cell also affects BCE - // so we mark it as invalid to simply the process to determine line separator - equalBg(thisRowLastChar, nextRowFirstChar) - ) { - isValid = true; - } - - if ( - // the second to last character can't be null if the next line starts with CJK, - // you can't use control sequence to move cursor to (x === row) - isNextRowFirstCharDoubleWidth && - (thisRowLastSecondChar.getChars() || thisRowLastSecondChar.getWidth() === 0) && - // change background of the first wrapped cell also affects BCE - // so we mark it as invalid to simply the process to determine line separator - equalBg(thisRowLastChar, nextRowFirstChar) && - equalBg(thisRowLastSecondChar, nextRowFirstChar) - ) { - isValid = true; - } - } - - if (!isValid) { - // force the wrap with magic - // insert enough character to force the wrap - rowSeparator = '-'.repeat(this._nullCellCount + 1); - // move back and erase next line head - rowSeparator += '\x1b[1D\x1b[1X'; - - if (this._nullCellCount > 0) { - // do these because we filled the last several null slot, which we shouldn't - rowSeparator += '\x1b[A'; - rowSeparator += `\x1b[${currentLine.length - this._nullCellCount}C`; - rowSeparator += `\x1b[${this._nullCellCount}X`; - rowSeparator += `\x1b[${currentLine.length - this._nullCellCount}D`; - rowSeparator += '\x1b[B'; - } - - // This is content and need the be serialized even it is invisible. - // without this, wrap will be missing from outputs. - this._lastContentCursorRow = row + 1; - this._lastContentCursorCol = 0; - - // force commit the cursor position - this._lastCursorRow = row + 1; - this._lastCursorCol = 0; - } - } - } - - this._allRows[this._rowIndex] = this._currentRow; - this._allRowSeparators[this._rowIndex++] = rowSeparator; - this._currentRow = ''; - this._nullCellCount = 0; - } - - private _diffStyle(cell: IBufferCell, oldCell: IBufferCell): number[] { - const sgrSeq: number[] = []; - const fgChanged = !equalFg(cell, oldCell); - const bgChanged = !equalBg(cell, oldCell); - const flagsChanged = !equalFlags(cell, oldCell); - - if (fgChanged || bgChanged || flagsChanged) { - if (cell.isAttributeDefault()) { - if (!oldCell.isAttributeDefault()) { - sgrSeq.push(0); - } - } else { - if (fgChanged) { - const color = cell.getFgColor(); - if (cell.isFgRGB()) { sgrSeq.push(38, 2, (color >>> 16) & 0xFF, (color >>> 8) & 0xFF, color & 0xFF); } - else if (cell.isFgPalette()) { - if (color >= 16) { sgrSeq.push(38, 5, color); } - else { sgrSeq.push(color & 8 ? 90 + (color & 7) : 30 + (color & 7)); } - } - else { sgrSeq.push(39); } - } - if (bgChanged) { - const color = cell.getBgColor(); - if (cell.isBgRGB()) { sgrSeq.push(48, 2, (color >>> 16) & 0xFF, (color >>> 8) & 0xFF, color & 0xFF); } - else if (cell.isBgPalette()) { - if (color >= 16) { sgrSeq.push(48, 5, color); } - else { sgrSeq.push(color & 8 ? 100 + (color & 7) : 40 + (color & 7)); } - } - else { sgrSeq.push(49); } - } - if (flagsChanged) { - if (cell.isInverse() !== oldCell.isInverse()) { sgrSeq.push(cell.isInverse() ? 7 : 27); } - if (cell.isBold() !== oldCell.isBold()) { sgrSeq.push(cell.isBold() ? 1 : 22); } - if (cell.isUnderline() !== oldCell.isUnderline()) { sgrSeq.push(cell.isUnderline() ? 4 : 24); } - if (cell.isBlink() !== oldCell.isBlink()) { sgrSeq.push(cell.isBlink() ? 5 : 25); } - if (cell.isInvisible() !== oldCell.isInvisible()) { sgrSeq.push(cell.isInvisible() ? 8 : 28); } - if (cell.isItalic() !== oldCell.isItalic()) { sgrSeq.push(cell.isItalic() ? 3 : 23); } - if (cell.isDim() !== oldCell.isDim()) { sgrSeq.push(cell.isDim() ? 2 : 22); } - } - } - } - - return sgrSeq; - } - - protected _nextCell(cell: IBufferCell, oldCell: IBufferCell, row: number, col: number): void { - // a width 0 cell don't need to be count because it is just a placeholder after a CJK character; - const isPlaceHolderCell = cell.getWidth() === 0; - - if (isPlaceHolderCell) { - return; - } - - // this cell don't have content - const isEmptyCell = cell.getChars() === ''; - - const sgrSeq = this._diffStyle(cell, this._cursorStyle); - - // the empty cell style is only assumed to be changed when background changed, because foreground is always 0. - const styleChanged = isEmptyCell ? !equalBg(this._cursorStyle, cell) : sgrSeq.length > 0; - - /** - * handles style change - */ - if (styleChanged) { - // before update the style, we need to fill empty cell back - if (this._nullCellCount > 0) { - // use clear right to set background. - if (!equalBg(this._cursorStyle, this._backgroundCell)) { - this._currentRow += `\x1b[${this._nullCellCount}X`; - } - // use move right to move cursor. - this._currentRow += `\x1b[${this._nullCellCount}C`; - this._nullCellCount = 0; - } - - this._lastContentCursorRow = this._lastCursorRow = row; - this._lastContentCursorCol = this._lastCursorCol = col; - - this._currentRow += `\x1b[${sgrSeq.join(';')}m`; - - // update the last cursor style - const line = this._buffer1.getLine(row); - if (line !== undefined) { - line.getCell(col, this._cursorStyle); - this._cursorStyleRow = row; - this._cursorStyleCol = col; - } - } - - /** - * handles actual content - */ - if (isEmptyCell) { - this._nullCellCount += cell.getWidth(); - } else { - if (this._nullCellCount > 0) { - // we can just assume we have same style with previous one here - // because style change is handled by previous stage - // use move right when background is empty, use clear right when there is background. - if (equalBg(this._cursorStyle, this._backgroundCell)) { - this._currentRow += `\x1b[${this._nullCellCount}C`; - } else { - this._currentRow += `\x1b[${this._nullCellCount}X`; - this._currentRow += `\x1b[${this._nullCellCount}C`; - } - this._nullCellCount = 0; - } - - this._currentRow += cell.getChars(); - - // update cursor - this._lastContentCursorRow = this._lastCursorRow = row; - this._lastContentCursorCol = this._lastCursorCol = col + cell.getWidth(); - } - } - - protected _serializeString(): string { - let rowEnd = this._allRows.length; - - // the fixup is only required for data without scrollback - // because it will always be placed at last line otherwise - if (this._buffer1.length - this._firstRow <= this._terminal.rows) { - rowEnd = this._lastContentCursorRow + 1 - this._firstRow; - this._lastCursorCol = this._lastContentCursorCol; - this._lastCursorRow = this._lastContentCursorRow; - } - - let content = ''; - - for (let i = 0; i < rowEnd; i++) { - content += this._allRows[i]; - if (i + 1 < rowEnd) { - content += this._allRowSeparators[i]; - } - } - - // restore the cursor - const realCursorRow = this._buffer1.baseY + this._buffer1.cursorY; - const realCursorCol = this._buffer1.cursorX; - - const cursorMoved = (realCursorRow !== this._lastCursorRow || realCursorCol !== this._lastCursorCol); - - const moveRight = (offset: number): void => { - if (offset > 0) { - content += `\u001b[${offset}C`; - } else if (offset < 0) { - content += `\u001b[${-offset}D`; - } - }; - const moveDown = (offset: number): void => { - if (offset > 0) { - content += `\u001b[${offset}B`; - } else if (offset < 0) { - content += `\u001b[${-offset}A`; - } - }; - - if (cursorMoved) { - moveDown(realCursorRow - this._lastCursorRow); - moveRight(realCursorCol - this._lastCursorCol); - } - - - return content; - } -} - -export class SerializeAddon implements ITerminalAddon { - private _terminal: Terminal | undefined; - - constructor() { } - - public activate(terminal: Terminal): void { - this._terminal = terminal; - } - - private _getString(buffer: IBuffer, scrollback?: number): string { - const maxRows = buffer.length; - const handler = new StringSerializeHandler(buffer, this._terminal!); - - const correctRows = (scrollback === undefined) ? maxRows : constrain(scrollback + this!._terminal!.rows, 0, maxRows); - const result = handler.serialize(maxRows - correctRows, maxRows); - - return result; - } - - public serialize(scrollback?: number): string { - // TODO: Add combinedData support - if (!this._terminal) { - throw new Error('Cannot use addon until it has been loaded'); - } - - if (this._terminal.buffer.active.type === 'normal') { - return this._getString(this._terminal.buffer.active, scrollback); - } - - const normalScreenContent = this._getString(this._terminal.buffer.normal, scrollback); - // alt screen don't have scrollback - const alternativeScreenContent = this._getString(this._terminal.buffer.alternate, undefined); - - return normalScreenContent - + '\u001b[?1049h\u001b[H' - + alternativeScreenContent; - } - - public dispose(): void { } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/typings/xterm-addon-serialize.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/typings/xterm-addon-serialize.d.ts deleted file mode 100755 index 58be9a973..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-serialize/typings/xterm-addon-serialize.d.ts +++ /dev/null @@ -1,38 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - - -import { Terminal, ITerminalAddon } from 'xterm'; - -declare module 'xterm-addon-serialize' { - /** - * An xterm.js addon that enables web links. - */ - export class SerializeAddon implements ITerminalAddon { - - constructor(); - - /** - * Activates the addon - * @param terminal The terminal the addon is being loaded in. - */ - public activate(terminal: Terminal): void; - - /** - * Serializes terminal rows into a string that can be written back to the terminal - * to restore the state. The cursor will also be positioned to the correct cell. - * When restoring a terminal it is best to do before `Terminal.open` is called - * to avoid wasting CPU cycles rendering incomplete frames. - * @param scrollback The number of rows in scrollback buffer to serialize, starting from the bottom of the - * scrollback buffer. This defaults to the all available rows in the scrollback buffer. - */ - public serialize(scrollback?: number): string; - - /** - * Disposes the addon. - */ - public dispose(): void; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/LICENSE b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/LICENSE deleted file mode 100755 index 8f1789258..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/LICENSE +++ /dev/null @@ -1,19 +0,0 @@ -Copyright (c) 2019, The xterm.js authors (https://github.com/xtermjs/xterm.js) - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/README.md b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/README.md deleted file mode 100755 index ec01203e9..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/README.md +++ /dev/null @@ -1,23 +0,0 @@ -## xterm-addon-unicode11 - -An addon providing Unicode version 11 rules for xterm.js. - -### Install - -```bash -npm install --save xterm-addon-unicode11 -``` - -### Usage - -```ts -import { Terminal } from 'xterm'; -import { Unicode11Addon } from 'xterm-addon-unicode11'; - -const terminal = new Terminal(); -const unicode11Addon = new Unicode11Addon(); -terminal.loadAddon(unicode11Addon); - -// activate the new version -terminal.unicode.activeVersion = '11'; -``` diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/lib/xterm-addon-unicode11.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/lib/xterm-addon-unicode11.js deleted file mode 100755 index 15494cdc2..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/lib/xterm-addon-unicode11.js +++ /dev/null @@ -1,2 +0,0 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.Unicode11Addon=t():e.Unicode11Addon=t()}(window,(function(){return function(e){var t={};function n(o){if(t[o])return t[o].exports;var r=t[o]={i:o,l:!1,exports:{}};return e[o].call(r.exports,r,r.exports,n),r.l=!0,r.exports}return n.m=e,n.c=t,n.d=function(e,t,o){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:o})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var o=Object.create(null);if(n.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var r in e)n.d(o,r,function(t){return e[t]}.bind(null,r));return o},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=0)}([function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.Unicode11Addon=void 0;const o=n(1);t.Unicode11Addon=class{activate(e){e.unicode.register(new o.UnicodeV11)}dispose(){}}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.UnicodeV11=void 0;const o=n(2),r=[[768,879],[1155,1161],[1425,1469],[1471,1471],[1473,1474],[1476,1477],[1479,1479],[1536,1541],[1552,1562],[1564,1564],[1611,1631],[1648,1648],[1750,1757],[1759,1764],[1767,1768],[1770,1773],[1807,1807],[1809,1809],[1840,1866],[1958,1968],[2027,2035],[2045,2045],[2070,2073],[2075,2083],[2085,2087],[2089,2093],[2137,2139],[2259,2306],[2362,2362],[2364,2364],[2369,2376],[2381,2381],[2385,2391],[2402,2403],[2433,2433],[2492,2492],[2497,2500],[2509,2509],[2530,2531],[2558,2558],[2561,2562],[2620,2620],[2625,2626],[2631,2632],[2635,2637],[2641,2641],[2672,2673],[2677,2677],[2689,2690],[2748,2748],[2753,2757],[2759,2760],[2765,2765],[2786,2787],[2810,2815],[2817,2817],[2876,2876],[2879,2879],[2881,2884],[2893,2893],[2902,2902],[2914,2915],[2946,2946],[3008,3008],[3021,3021],[3072,3072],[3076,3076],[3134,3136],[3142,3144],[3146,3149],[3157,3158],[3170,3171],[3201,3201],[3260,3260],[3263,3263],[3270,3270],[3276,3277],[3298,3299],[3328,3329],[3387,3388],[3393,3396],[3405,3405],[3426,3427],[3530,3530],[3538,3540],[3542,3542],[3633,3633],[3636,3642],[3655,3662],[3761,3761],[3764,3772],[3784,3789],[3864,3865],[3893,3893],[3895,3895],[3897,3897],[3953,3966],[3968,3972],[3974,3975],[3981,3991],[3993,4028],[4038,4038],[4141,4144],[4146,4151],[4153,4154],[4157,4158],[4184,4185],[4190,4192],[4209,4212],[4226,4226],[4229,4230],[4237,4237],[4253,4253],[4448,4607],[4957,4959],[5906,5908],[5938,5940],[5970,5971],[6002,6003],[6068,6069],[6071,6077],[6086,6086],[6089,6099],[6109,6109],[6155,6158],[6277,6278],[6313,6313],[6432,6434],[6439,6440],[6450,6450],[6457,6459],[6679,6680],[6683,6683],[6742,6742],[6744,6750],[6752,6752],[6754,6754],[6757,6764],[6771,6780],[6783,6783],[6832,6846],[6912,6915],[6964,6964],[6966,6970],[6972,6972],[6978,6978],[7019,7027],[7040,7041],[7074,7077],[7080,7081],[7083,7085],[7142,7142],[7144,7145],[7149,7149],[7151,7153],[7212,7219],[7222,7223],[7376,7378],[7380,7392],[7394,7400],[7405,7405],[7412,7412],[7416,7417],[7616,7673],[7675,7679],[8203,8207],[8234,8238],[8288,8292],[8294,8303],[8400,8432],[11503,11505],[11647,11647],[11744,11775],[12330,12333],[12441,12442],[42607,42610],[42612,42621],[42654,42655],[42736,42737],[43010,43010],[43014,43014],[43019,43019],[43045,43046],[43204,43205],[43232,43249],[43263,43263],[43302,43309],[43335,43345],[43392,43394],[43443,43443],[43446,43449],[43452,43453],[43493,43493],[43561,43566],[43569,43570],[43573,43574],[43587,43587],[43596,43596],[43644,43644],[43696,43696],[43698,43700],[43703,43704],[43710,43711],[43713,43713],[43756,43757],[43766,43766],[44005,44005],[44008,44008],[44013,44013],[64286,64286],[65024,65039],[65056,65071],[65279,65279],[65529,65531]],i=[[66045,66045],[66272,66272],[66422,66426],[68097,68099],[68101,68102],[68108,68111],[68152,68154],[68159,68159],[68325,68326],[68900,68903],[69446,69456],[69633,69633],[69688,69702],[69759,69761],[69811,69814],[69817,69818],[69821,69821],[69837,69837],[69888,69890],[69927,69931],[69933,69940],[70003,70003],[70016,70017],[70070,70078],[70089,70092],[70191,70193],[70196,70196],[70198,70199],[70206,70206],[70367,70367],[70371,70378],[70400,70401],[70459,70460],[70464,70464],[70502,70508],[70512,70516],[70712,70719],[70722,70724],[70726,70726],[70750,70750],[70835,70840],[70842,70842],[70847,70848],[70850,70851],[71090,71093],[71100,71101],[71103,71104],[71132,71133],[71219,71226],[71229,71229],[71231,71232],[71339,71339],[71341,71341],[71344,71349],[71351,71351],[71453,71455],[71458,71461],[71463,71467],[71727,71735],[71737,71738],[72148,72151],[72154,72155],[72160,72160],[72193,72202],[72243,72248],[72251,72254],[72263,72263],[72273,72278],[72281,72283],[72330,72342],[72344,72345],[72752,72758],[72760,72765],[72767,72767],[72850,72871],[72874,72880],[72882,72883],[72885,72886],[73009,73014],[73018,73018],[73020,73021],[73023,73029],[73031,73031],[73104,73105],[73109,73109],[73111,73111],[73459,73460],[78896,78904],[92912,92916],[92976,92982],[94031,94031],[94095,94098],[113821,113822],[113824,113827],[119143,119145],[119155,119170],[119173,119179],[119210,119213],[119362,119364],[121344,121398],[121403,121452],[121461,121461],[121476,121476],[121499,121503],[121505,121519],[122880,122886],[122888,122904],[122907,122913],[122915,122916],[122918,122922],[123184,123190],[123628,123631],[125136,125142],[125252,125258],[917505,917505],[917536,917631],[917760,917999]],l=[[4352,4447],[8986,8987],[9001,9002],[9193,9196],[9200,9200],[9203,9203],[9725,9726],[9748,9749],[9800,9811],[9855,9855],[9875,9875],[9889,9889],[9898,9899],[9917,9918],[9924,9925],[9934,9934],[9940,9940],[9962,9962],[9970,9971],[9973,9973],[9978,9978],[9981,9981],[9989,9989],[9994,9995],[10024,10024],[10060,10060],[10062,10062],[10067,10069],[10071,10071],[10133,10135],[10160,10160],[10175,10175],[11035,11036],[11088,11088],[11093,11093],[11904,11929],[11931,12019],[12032,12245],[12272,12283],[12288,12329],[12334,12350],[12353,12438],[12443,12543],[12549,12591],[12593,12686],[12688,12730],[12736,12771],[12784,12830],[12832,12871],[12880,19903],[19968,42124],[42128,42182],[43360,43388],[44032,55203],[63744,64255],[65040,65049],[65072,65106],[65108,65126],[65128,65131],[65281,65376],[65504,65510]],u=[[94176,94179],[94208,100343],[100352,101106],[110592,110878],[110928,110930],[110948,110951],[110960,111355],[126980,126980],[127183,127183],[127374,127374],[127377,127386],[127488,127490],[127504,127547],[127552,127560],[127568,127569],[127584,127589],[127744,127776],[127789,127797],[127799,127868],[127870,127891],[127904,127946],[127951,127955],[127968,127984],[127988,127988],[127992,128062],[128064,128064],[128066,128252],[128255,128317],[128331,128334],[128336,128359],[128378,128378],[128405,128406],[128420,128420],[128507,128591],[128640,128709],[128716,128716],[128720,128722],[128725,128725],[128747,128748],[128756,128762],[128992,129003],[129293,129393],[129395,129398],[129402,129442],[129445,129450],[129454,129482],[129485,129535],[129648,129651],[129656,129658],[129664,129666],[129680,129685],[131072,196605],[196608,262141]];let f;function c(e,t){let n,o=0,r=t.length-1;if(et[r][1])return!1;for(;r>=o;)if(n=o+r>>1,e>t[n][1])o=n+1;else{if(!(e=e.length)return e;n=(e.length+n)%e.length,o=o>=e.length?e.length:(e.length+o)%e.length;for(var r=n;r data[max][1]) {\n return false;\n }\n while (max >= min) {\n mid = (min + max) >> 1;\n if (ucs > data[mid][1]) {\n min = mid + 1;\n } else if (ucs < data[mid][0]) {\n max = mid - 1;\n } else {\n return true;\n }\n }\n return false;\n}\n\n\nexport class UnicodeV11 implements IUnicodeVersionProvider {\n public readonly version = '11';\n\n constructor() {\n if (!table) {\n table = new Uint8Array(65536);\n fill(table, 1);\n table[0] = 0;\n fill(table, 0, 1, 32);\n fill(table, 0, 0x7f, 0xa0);\n for (let r = 0; r < BMP_COMBINING.length; ++r) {\n fill(table, 0, BMP_COMBINING[r][0], BMP_COMBINING[r][1] + 1);\n }\n for (let r = 0; r < BMP_WIDE.length; ++r) {\n fill(table, 2, BMP_WIDE[r][0], BMP_WIDE[r][1] + 1);\n }\n }\n }\n\n public wcwidth(num: number): CharWidth {\n if (num < 32) return 0;\n if (num < 127) return 1;\n if (num < 65536) return table[num] as CharWidth;\n if (bisearch(num, HIGH_COMBINING)) return 0;\n if (bisearch(num, HIGH_WIDE)) return 2;\n return 1;\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nexport type TypedArray = Uint8Array | Uint16Array | Uint32Array | Uint8ClampedArray | Int8Array | Int16Array | Int32Array | Float32Array | Float64Array;\n\n\n/**\n * polyfill for TypedArray.fill\n * This is needed to support .fill in all safari versions and IE 11.\n */\nexport function fill(array: T, value: number, start?: number, end?: number): T {\n // all modern engines that support .fill\n if (array.fill) {\n return array.fill(value, start, end) as T;\n }\n return fillFallback(array, value, start, end);\n}\n\nexport function fillFallback(array: T, value: number, start: number = 0, end: number = array.length): T {\n // safari and IE 11\n // since IE 11 does not support Array.prototype.fill either\n // we cannot use the suggested polyfill from MDN\n // instead we simply fall back to looping\n if (start >= array.length) {\n return array;\n }\n start = (array.length + start) % array.length;\n if (end >= array.length) {\n end = array.length;\n } else {\n end = (array.length + end) % array.length;\n }\n for (let i = start; i < end; ++i) {\n array[i] = value;\n }\n return array;\n}\n\n/**\n * Concat two typed arrays `a` and `b`.\n * Returns a new typed array.\n */\nexport function concat(a: T, b: T): T {\n const result = new (a.constructor as any)(a.length + b.length);\n result.set(a);\n result.set(b, a.length);\n return result;\n}\n"],"sourceRoot":""} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/Unicode11Addon.api.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/Unicode11Addon.api.js.map deleted file mode 100755 index 634b89150..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/Unicode11Addon.api.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"Unicode11Addon.api.js","sourceRoot":"","sources":["../src/Unicode11Addon.api.ts"],"names":[],"mappings":";;;;;;;;;;;AAKA,+BAA8B;AAC9B,+DAA+E;AAG/E,MAAM,GAAG,GAAG,4BAA4B,CAAC;AAEzC,IAAI,OAAgB,CAAC;AACrB,IAAI,IAAU,CAAC;AACf,MAAM,KAAK,GAAG,GAAG,CAAC;AAClB,MAAM,MAAM,GAAG,GAAG,CAAC;AAEnB,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,MAAM,CAAC;;YACL,MAAM,WAAW,GAAG,0BAAc,EAAE,CAAC;YACrC,OAAO,GAAG,MAAM,WAAW,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,IAAI;gBAC/C,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;aACpD,CAAC,CAAC;YACH,IAAI,GAAG,MAAM,CAAC,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;YACpD,MAAM,IAAI,CAAC,eAAe,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;QAChD,CAAC;KAAA,CAAC,CAAC;IAEH,KAAK,CAAC,GAAS,EAAE;QACf,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC,CAAA,CAAC,CAAC;IAEH,UAAU,CAAC;;YACT,MAAM,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACrB,MAAM,wBAAY,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC;KAAA,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE,GAAS,EAAE;QACtC,MAAM,IAAI,CAAC,QAAQ,CAAC;;;KAGnB,CAAC,CAAC;QAEH,aAAM,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,8BAA8B,CAAC,EAAE,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;QAEnF,MAAM,IAAI,CAAC,QAAQ,CAAC,2CAA2C,CAAC,CAAC;QACjE,aAAM,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,mCAAmC,CAAC,EAAE,IAAI,CAAC,CAAC;QAEjF,aAAM,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,6EAA6E,CAAC,EAAE,EAAE,CAAC,CAAC;IAC3H,CAAC,CAAA,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/Unicode11Addon.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/Unicode11Addon.js deleted file mode 100755 index 4a74adb42..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/Unicode11Addon.js +++ /dev/null @@ -1,12 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.Unicode11Addon = void 0; -const UnicodeV11_1 = require("./UnicodeV11"); -class Unicode11Addon { - activate(terminal) { - terminal.unicode.register(new UnicodeV11_1.UnicodeV11()); - } - dispose() { } -} -exports.Unicode11Addon = Unicode11Addon; -//# sourceMappingURL=Unicode11Addon.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/Unicode11Addon.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/Unicode11Addon.js.map deleted file mode 100755 index 6aa2359a7..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/Unicode11Addon.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"Unicode11Addon.js","sourceRoot":"","sources":["../src/Unicode11Addon.ts"],"names":[],"mappings":";;;AAQA,6CAA0C;AAE1C,MAAa,cAAc;IAClB,QAAQ,CAAC,QAAkB;QAChC,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,uBAAU,EAAE,CAAC,CAAC;IAC9C,CAAC;IACM,OAAO,KAAW,CAAC;CAC3B;AALD,wCAKC"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/UnicodeV11.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/UnicodeV11.js deleted file mode 100755 index d15608958..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/UnicodeV11.js +++ /dev/null @@ -1,218 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.UnicodeV11 = void 0; -const TypedArrayUtils_1 = require("common/TypedArrayUtils"); -const BMP_COMBINING = [ - [0x0300, 0x036F], [0x0483, 0x0489], [0x0591, 0x05BD], - [0x05BF, 0x05BF], [0x05C1, 0x05C2], [0x05C4, 0x05C5], - [0x05C7, 0x05C7], [0x0600, 0x0605], [0x0610, 0x061A], - [0x061C, 0x061C], [0x064B, 0x065F], [0x0670, 0x0670], - [0x06D6, 0x06DD], [0x06DF, 0x06E4], [0x06E7, 0x06E8], - [0x06EA, 0x06ED], [0x070F, 0x070F], [0x0711, 0x0711], - [0x0730, 0x074A], [0x07A6, 0x07B0], [0x07EB, 0x07F3], - [0x07FD, 0x07FD], [0x0816, 0x0819], [0x081B, 0x0823], - [0x0825, 0x0827], [0x0829, 0x082D], [0x0859, 0x085B], - [0x08D3, 0x0902], [0x093A, 0x093A], [0x093C, 0x093C], - [0x0941, 0x0948], [0x094D, 0x094D], [0x0951, 0x0957], - [0x0962, 0x0963], [0x0981, 0x0981], [0x09BC, 0x09BC], - [0x09C1, 0x09C4], [0x09CD, 0x09CD], [0x09E2, 0x09E3], - [0x09FE, 0x09FE], [0x0A01, 0x0A02], [0x0A3C, 0x0A3C], - [0x0A41, 0x0A42], [0x0A47, 0x0A48], [0x0A4B, 0x0A4D], - [0x0A51, 0x0A51], [0x0A70, 0x0A71], [0x0A75, 0x0A75], - [0x0A81, 0x0A82], [0x0ABC, 0x0ABC], [0x0AC1, 0x0AC5], - [0x0AC7, 0x0AC8], [0x0ACD, 0x0ACD], [0x0AE2, 0x0AE3], - [0x0AFA, 0x0AFF], [0x0B01, 0x0B01], [0x0B3C, 0x0B3C], - [0x0B3F, 0x0B3F], [0x0B41, 0x0B44], [0x0B4D, 0x0B4D], - [0x0B56, 0x0B56], [0x0B62, 0x0B63], [0x0B82, 0x0B82], - [0x0BC0, 0x0BC0], [0x0BCD, 0x0BCD], [0x0C00, 0x0C00], - [0x0C04, 0x0C04], [0x0C3E, 0x0C40], [0x0C46, 0x0C48], - [0x0C4A, 0x0C4D], [0x0C55, 0x0C56], [0x0C62, 0x0C63], - [0x0C81, 0x0C81], [0x0CBC, 0x0CBC], [0x0CBF, 0x0CBF], - [0x0CC6, 0x0CC6], [0x0CCC, 0x0CCD], [0x0CE2, 0x0CE3], - [0x0D00, 0x0D01], [0x0D3B, 0x0D3C], [0x0D41, 0x0D44], - [0x0D4D, 0x0D4D], [0x0D62, 0x0D63], [0x0DCA, 0x0DCA], - [0x0DD2, 0x0DD4], [0x0DD6, 0x0DD6], [0x0E31, 0x0E31], - [0x0E34, 0x0E3A], [0x0E47, 0x0E4E], [0x0EB1, 0x0EB1], - [0x0EB4, 0x0EBC], [0x0EC8, 0x0ECD], [0x0F18, 0x0F19], - [0x0F35, 0x0F35], [0x0F37, 0x0F37], [0x0F39, 0x0F39], - [0x0F71, 0x0F7E], [0x0F80, 0x0F84], [0x0F86, 0x0F87], - [0x0F8D, 0x0F97], [0x0F99, 0x0FBC], [0x0FC6, 0x0FC6], - [0x102D, 0x1030], [0x1032, 0x1037], [0x1039, 0x103A], - [0x103D, 0x103E], [0x1058, 0x1059], [0x105E, 0x1060], - [0x1071, 0x1074], [0x1082, 0x1082], [0x1085, 0x1086], - [0x108D, 0x108D], [0x109D, 0x109D], [0x1160, 0x11FF], - [0x135D, 0x135F], [0x1712, 0x1714], [0x1732, 0x1734], - [0x1752, 0x1753], [0x1772, 0x1773], [0x17B4, 0x17B5], - [0x17B7, 0x17BD], [0x17C6, 0x17C6], [0x17C9, 0x17D3], - [0x17DD, 0x17DD], [0x180B, 0x180E], [0x1885, 0x1886], - [0x18A9, 0x18A9], [0x1920, 0x1922], [0x1927, 0x1928], - [0x1932, 0x1932], [0x1939, 0x193B], [0x1A17, 0x1A18], - [0x1A1B, 0x1A1B], [0x1A56, 0x1A56], [0x1A58, 0x1A5E], - [0x1A60, 0x1A60], [0x1A62, 0x1A62], [0x1A65, 0x1A6C], - [0x1A73, 0x1A7C], [0x1A7F, 0x1A7F], [0x1AB0, 0x1ABE], - [0x1B00, 0x1B03], [0x1B34, 0x1B34], [0x1B36, 0x1B3A], - [0x1B3C, 0x1B3C], [0x1B42, 0x1B42], [0x1B6B, 0x1B73], - [0x1B80, 0x1B81], [0x1BA2, 0x1BA5], [0x1BA8, 0x1BA9], - [0x1BAB, 0x1BAD], [0x1BE6, 0x1BE6], [0x1BE8, 0x1BE9], - [0x1BED, 0x1BED], [0x1BEF, 0x1BF1], [0x1C2C, 0x1C33], - [0x1C36, 0x1C37], [0x1CD0, 0x1CD2], [0x1CD4, 0x1CE0], - [0x1CE2, 0x1CE8], [0x1CED, 0x1CED], [0x1CF4, 0x1CF4], - [0x1CF8, 0x1CF9], [0x1DC0, 0x1DF9], [0x1DFB, 0x1DFF], - [0x200B, 0x200F], [0x202A, 0x202E], [0x2060, 0x2064], - [0x2066, 0x206F], [0x20D0, 0x20F0], [0x2CEF, 0x2CF1], - [0x2D7F, 0x2D7F], [0x2DE0, 0x2DFF], [0x302A, 0x302D], - [0x3099, 0x309A], [0xA66F, 0xA672], [0xA674, 0xA67D], - [0xA69E, 0xA69F], [0xA6F0, 0xA6F1], [0xA802, 0xA802], - [0xA806, 0xA806], [0xA80B, 0xA80B], [0xA825, 0xA826], - [0xA8C4, 0xA8C5], [0xA8E0, 0xA8F1], [0xA8FF, 0xA8FF], - [0xA926, 0xA92D], [0xA947, 0xA951], [0xA980, 0xA982], - [0xA9B3, 0xA9B3], [0xA9B6, 0xA9B9], [0xA9BC, 0xA9BD], - [0xA9E5, 0xA9E5], [0xAA29, 0xAA2E], [0xAA31, 0xAA32], - [0xAA35, 0xAA36], [0xAA43, 0xAA43], [0xAA4C, 0xAA4C], - [0xAA7C, 0xAA7C], [0xAAB0, 0xAAB0], [0xAAB2, 0xAAB4], - [0xAAB7, 0xAAB8], [0xAABE, 0xAABF], [0xAAC1, 0xAAC1], - [0xAAEC, 0xAAED], [0xAAF6, 0xAAF6], [0xABE5, 0xABE5], - [0xABE8, 0xABE8], [0xABED, 0xABED], [0xFB1E, 0xFB1E], - [0xFE00, 0xFE0F], [0xFE20, 0xFE2F], [0xFEFF, 0xFEFF], - [0xFFF9, 0xFFFB] -]; -const HIGH_COMBINING = [ - [0x101FD, 0x101FD], [0x102E0, 0x102E0], - [0x10376, 0x1037A], [0x10A01, 0x10A03], [0x10A05, 0x10A06], - [0x10A0C, 0x10A0F], [0x10A38, 0x10A3A], [0x10A3F, 0x10A3F], - [0x10AE5, 0x10AE6], [0x10D24, 0x10D27], [0x10F46, 0x10F50], - [0x11001, 0x11001], [0x11038, 0x11046], [0x1107F, 0x11081], - [0x110B3, 0x110B6], [0x110B9, 0x110BA], [0x110BD, 0x110BD], - [0x110CD, 0x110CD], [0x11100, 0x11102], [0x11127, 0x1112B], - [0x1112D, 0x11134], [0x11173, 0x11173], [0x11180, 0x11181], - [0x111B6, 0x111BE], [0x111C9, 0x111CC], [0x1122F, 0x11231], - [0x11234, 0x11234], [0x11236, 0x11237], [0x1123E, 0x1123E], - [0x112DF, 0x112DF], [0x112E3, 0x112EA], [0x11300, 0x11301], - [0x1133B, 0x1133C], [0x11340, 0x11340], [0x11366, 0x1136C], - [0x11370, 0x11374], [0x11438, 0x1143F], [0x11442, 0x11444], - [0x11446, 0x11446], [0x1145E, 0x1145E], [0x114B3, 0x114B8], - [0x114BA, 0x114BA], [0x114BF, 0x114C0], [0x114C2, 0x114C3], - [0x115B2, 0x115B5], [0x115BC, 0x115BD], [0x115BF, 0x115C0], - [0x115DC, 0x115DD], [0x11633, 0x1163A], [0x1163D, 0x1163D], - [0x1163F, 0x11640], [0x116AB, 0x116AB], [0x116AD, 0x116AD], - [0x116B0, 0x116B5], [0x116B7, 0x116B7], [0x1171D, 0x1171F], - [0x11722, 0x11725], [0x11727, 0x1172B], [0x1182F, 0x11837], - [0x11839, 0x1183A], [0x119D4, 0x119D7], [0x119DA, 0x119DB], - [0x119E0, 0x119E0], [0x11A01, 0x11A0A], [0x11A33, 0x11A38], - [0x11A3B, 0x11A3E], [0x11A47, 0x11A47], [0x11A51, 0x11A56], - [0x11A59, 0x11A5B], [0x11A8A, 0x11A96], [0x11A98, 0x11A99], - [0x11C30, 0x11C36], [0x11C38, 0x11C3D], [0x11C3F, 0x11C3F], - [0x11C92, 0x11CA7], [0x11CAA, 0x11CB0], [0x11CB2, 0x11CB3], - [0x11CB5, 0x11CB6], [0x11D31, 0x11D36], [0x11D3A, 0x11D3A], - [0x11D3C, 0x11D3D], [0x11D3F, 0x11D45], [0x11D47, 0x11D47], - [0x11D90, 0x11D91], [0x11D95, 0x11D95], [0x11D97, 0x11D97], - [0x11EF3, 0x11EF4], [0x13430, 0x13438], [0x16AF0, 0x16AF4], - [0x16B30, 0x16B36], [0x16F4F, 0x16F4F], [0x16F8F, 0x16F92], - [0x1BC9D, 0x1BC9E], [0x1BCA0, 0x1BCA3], [0x1D167, 0x1D169], - [0x1D173, 0x1D182], [0x1D185, 0x1D18B], [0x1D1AA, 0x1D1AD], - [0x1D242, 0x1D244], [0x1DA00, 0x1DA36], [0x1DA3B, 0x1DA6C], - [0x1DA75, 0x1DA75], [0x1DA84, 0x1DA84], [0x1DA9B, 0x1DA9F], - [0x1DAA1, 0x1DAAF], [0x1E000, 0x1E006], [0x1E008, 0x1E018], - [0x1E01B, 0x1E021], [0x1E023, 0x1E024], [0x1E026, 0x1E02A], - [0x1E130, 0x1E136], [0x1E2EC, 0x1E2EF], [0x1E8D0, 0x1E8D6], - [0x1E944, 0x1E94A], [0xE0001, 0xE0001], [0xE0020, 0xE007F], - [0xE0100, 0xE01EF] -]; -const BMP_WIDE = [ - [0x1100, 0x115F], [0x231A, 0x231B], [0x2329, 0x232A], - [0x23E9, 0x23EC], [0x23F0, 0x23F0], [0x23F3, 0x23F3], - [0x25FD, 0x25FE], [0x2614, 0x2615], [0x2648, 0x2653], - [0x267F, 0x267F], [0x2693, 0x2693], [0x26A1, 0x26A1], - [0x26AA, 0x26AB], [0x26BD, 0x26BE], [0x26C4, 0x26C5], - [0x26CE, 0x26CE], [0x26D4, 0x26D4], [0x26EA, 0x26EA], - [0x26F2, 0x26F3], [0x26F5, 0x26F5], [0x26FA, 0x26FA], - [0x26FD, 0x26FD], [0x2705, 0x2705], [0x270A, 0x270B], - [0x2728, 0x2728], [0x274C, 0x274C], [0x274E, 0x274E], - [0x2753, 0x2755], [0x2757, 0x2757], [0x2795, 0x2797], - [0x27B0, 0x27B0], [0x27BF, 0x27BF], [0x2B1B, 0x2B1C], - [0x2B50, 0x2B50], [0x2B55, 0x2B55], [0x2E80, 0x2E99], - [0x2E9B, 0x2EF3], [0x2F00, 0x2FD5], [0x2FF0, 0x2FFB], - [0x3000, 0x3029], [0x302E, 0x303E], [0x3041, 0x3096], - [0x309B, 0x30FF], [0x3105, 0x312F], [0x3131, 0x318E], - [0x3190, 0x31BA], [0x31C0, 0x31E3], [0x31F0, 0x321E], - [0x3220, 0x3247], [0x3250, 0x4DBF], [0x4E00, 0xA48C], - [0xA490, 0xA4C6], [0xA960, 0xA97C], [0xAC00, 0xD7A3], - [0xF900, 0xFAFF], [0xFE10, 0xFE19], [0xFE30, 0xFE52], - [0xFE54, 0xFE66], [0xFE68, 0xFE6B], [0xFF01, 0xFF60], - [0xFFE0, 0xFFE6] -]; -const HIGH_WIDE = [ - [0x16FE0, 0x16FE3], [0x17000, 0x187F7], - [0x18800, 0x18AF2], [0x1B000, 0x1B11E], [0x1B150, 0x1B152], - [0x1B164, 0x1B167], [0x1B170, 0x1B2FB], [0x1F004, 0x1F004], - [0x1F0CF, 0x1F0CF], [0x1F18E, 0x1F18E], [0x1F191, 0x1F19A], - [0x1F200, 0x1F202], [0x1F210, 0x1F23B], [0x1F240, 0x1F248], - [0x1F250, 0x1F251], [0x1F260, 0x1F265], [0x1F300, 0x1F320], - [0x1F32D, 0x1F335], [0x1F337, 0x1F37C], [0x1F37E, 0x1F393], - [0x1F3A0, 0x1F3CA], [0x1F3CF, 0x1F3D3], [0x1F3E0, 0x1F3F0], - [0x1F3F4, 0x1F3F4], [0x1F3F8, 0x1F43E], [0x1F440, 0x1F440], - [0x1F442, 0x1F4FC], [0x1F4FF, 0x1F53D], [0x1F54B, 0x1F54E], - [0x1F550, 0x1F567], [0x1F57A, 0x1F57A], [0x1F595, 0x1F596], - [0x1F5A4, 0x1F5A4], [0x1F5FB, 0x1F64F], [0x1F680, 0x1F6C5], - [0x1F6CC, 0x1F6CC], [0x1F6D0, 0x1F6D2], [0x1F6D5, 0x1F6D5], - [0x1F6EB, 0x1F6EC], [0x1F6F4, 0x1F6FA], [0x1F7E0, 0x1F7EB], - [0x1F90D, 0x1F971], [0x1F973, 0x1F976], [0x1F97A, 0x1F9A2], - [0x1F9A5, 0x1F9AA], [0x1F9AE, 0x1F9CA], [0x1F9CD, 0x1F9FF], - [0x1FA70, 0x1FA73], [0x1FA78, 0x1FA7A], [0x1FA80, 0x1FA82], - [0x1FA90, 0x1FA95], [0x20000, 0x2FFFD], [0x30000, 0x3FFFD] -]; -let table; -function bisearch(ucs, data) { - let min = 0; - let max = data.length - 1; - let mid; - if (ucs < data[0][0] || ucs > data[max][1]) { - return false; - } - while (max >= min) { - mid = (min + max) >> 1; - if (ucs > data[mid][1]) { - min = mid + 1; - } - else if (ucs < data[mid][0]) { - max = mid - 1; - } - else { - return true; - } - } - return false; -} -class UnicodeV11 { - constructor() { - this.version = '11'; - if (!table) { - table = new Uint8Array(65536); - TypedArrayUtils_1.fill(table, 1); - table[0] = 0; - TypedArrayUtils_1.fill(table, 0, 1, 32); - TypedArrayUtils_1.fill(table, 0, 0x7f, 0xa0); - for (let r = 0; r < BMP_COMBINING.length; ++r) { - TypedArrayUtils_1.fill(table, 0, BMP_COMBINING[r][0], BMP_COMBINING[r][1] + 1); - } - for (let r = 0; r < BMP_WIDE.length; ++r) { - TypedArrayUtils_1.fill(table, 2, BMP_WIDE[r][0], BMP_WIDE[r][1] + 1); - } - } - } - wcwidth(num) { - if (num < 32) - return 0; - if (num < 127) - return 1; - if (num < 65536) - return table[num]; - if (bisearch(num, HIGH_COMBINING)) - return 0; - if (bisearch(num, HIGH_WIDE)) - return 2; - return 1; - } -} -exports.UnicodeV11 = UnicodeV11; -//# sourceMappingURL=UnicodeV11.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/UnicodeV11.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/UnicodeV11.js.map deleted file mode 100755 index a4ff61457..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/out/UnicodeV11.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"UnicodeV11.js","sourceRoot":"","sources":["../src/UnicodeV11.ts"],"names":[],"mappings":";;;AAMA,4DAA8C;AAI9C,MAAM,aAAa,GAAG;IACpB,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC;CACjB,CAAC;AACF,MAAM,cAAc,GAAG;IACrB,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IACtC,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC;CACnB,CAAC;AACF,MAAM,QAAQ,GAAG;IACf,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;IACpD,CAAC,MAAM,EAAE,MAAM,CAAC;CACjB,CAAC;AACF,MAAM,SAAS,GAAG;IAChB,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IACtC,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1D,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;CAC3D,CAAC;AAGF,IAAI,KAAiB,CAAC;AAEtB,SAAS,QAAQ,CAAC,GAAW,EAAE,IAAgB;IAC7C,IAAI,GAAG,GAAG,CAAC,CAAC;IACZ,IAAI,GAAG,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;IAC1B,IAAI,GAAG,CAAC;IACR,IAAI,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;QAC1C,OAAO,KAAK,CAAC;KACd;IACD,OAAO,GAAG,IAAI,GAAG,EAAE;QACjB,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,IAAI,CAAC,CAAC;QACvB,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;YACtB,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC;SACf;aAAM,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;YAC7B,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC;SACf;aAAM;YACL,OAAO,IAAI,CAAC;SACb;KACF;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAGD,MAAa,UAAU;IAGrB;QAFgB,YAAO,GAAG,IAAI,CAAC;QAG7B,IAAI,CAAC,KAAK,EAAE;YACV,KAAK,GAAG,IAAI,UAAU,CAAC,KAAK,CAAC,CAAC;YAC9B,sBAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YACf,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACb,sBAAI,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;YACtB,sBAAI,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;YAC3B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;gBAC7C,sBAAI,CAAC,KAAK,EAAE,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aAC9D;YACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;gBACxC,sBAAI,CAAC,KAAK,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;aACpD;SACF;IACH,CAAC;IAEM,OAAO,CAAC,GAAW;QACxB,IAAI,GAAG,GAAG,EAAE;YAAE,OAAO,CAAC,CAAC;QACvB,IAAI,GAAG,GAAG,GAAG;YAAE,OAAO,CAAC,CAAC;QACxB,IAAI,GAAG,GAAG,KAAK;YAAE,OAAO,KAAK,CAAC,GAAG,CAAc,CAAC;QAChD,IAAI,QAAQ,CAAC,GAAG,EAAE,cAAc,CAAC;YAAE,OAAO,CAAC,CAAC;QAC5C,IAAI,QAAQ,CAAC,GAAG,EAAE,SAAS,CAAC;YAAE,OAAO,CAAC,CAAC;QACvC,OAAO,CAAC,CAAC;IACX,CAAC;CACF;AA3BD,gCA2BC"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/src/Unicode11Addon.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/src/Unicode11Addon.ts deleted file mode 100755 index cb8c9c563..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/src/Unicode11Addon.ts +++ /dev/null @@ -1,16 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - * - * UnicodeVersionProvider for V11. - */ - -import { Terminal, ITerminalAddon } from 'xterm'; -import { UnicodeV11 } from './UnicodeV11'; - -export class Unicode11Addon implements ITerminalAddon { - public activate(terminal: Terminal): void { - terminal.unicode.register(new UnicodeV11()); - } - public dispose(): void { } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/src/UnicodeV11.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/src/UnicodeV11.ts deleted file mode 100755 index d9d548d6e..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/src/UnicodeV11.ts +++ /dev/null @@ -1,222 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IUnicodeVersionProvider } from 'xterm'; -import { fill } from 'common/TypedArrayUtils'; - -type CharWidth = 0 | 1 | 2; - -const BMP_COMBINING = [ - [0x0300, 0x036F], [0x0483, 0x0489], [0x0591, 0x05BD], - [0x05BF, 0x05BF], [0x05C1, 0x05C2], [0x05C4, 0x05C5], - [0x05C7, 0x05C7], [0x0600, 0x0605], [0x0610, 0x061A], - [0x061C, 0x061C], [0x064B, 0x065F], [0x0670, 0x0670], - [0x06D6, 0x06DD], [0x06DF, 0x06E4], [0x06E7, 0x06E8], - [0x06EA, 0x06ED], [0x070F, 0x070F], [0x0711, 0x0711], - [0x0730, 0x074A], [0x07A6, 0x07B0], [0x07EB, 0x07F3], - [0x07FD, 0x07FD], [0x0816, 0x0819], [0x081B, 0x0823], - [0x0825, 0x0827], [0x0829, 0x082D], [0x0859, 0x085B], - [0x08D3, 0x0902], [0x093A, 0x093A], [0x093C, 0x093C], - [0x0941, 0x0948], [0x094D, 0x094D], [0x0951, 0x0957], - [0x0962, 0x0963], [0x0981, 0x0981], [0x09BC, 0x09BC], - [0x09C1, 0x09C4], [0x09CD, 0x09CD], [0x09E2, 0x09E3], - [0x09FE, 0x09FE], [0x0A01, 0x0A02], [0x0A3C, 0x0A3C], - [0x0A41, 0x0A42], [0x0A47, 0x0A48], [0x0A4B, 0x0A4D], - [0x0A51, 0x0A51], [0x0A70, 0x0A71], [0x0A75, 0x0A75], - [0x0A81, 0x0A82], [0x0ABC, 0x0ABC], [0x0AC1, 0x0AC5], - [0x0AC7, 0x0AC8], [0x0ACD, 0x0ACD], [0x0AE2, 0x0AE3], - [0x0AFA, 0x0AFF], [0x0B01, 0x0B01], [0x0B3C, 0x0B3C], - [0x0B3F, 0x0B3F], [0x0B41, 0x0B44], [0x0B4D, 0x0B4D], - [0x0B56, 0x0B56], [0x0B62, 0x0B63], [0x0B82, 0x0B82], - [0x0BC0, 0x0BC0], [0x0BCD, 0x0BCD], [0x0C00, 0x0C00], - [0x0C04, 0x0C04], [0x0C3E, 0x0C40], [0x0C46, 0x0C48], - [0x0C4A, 0x0C4D], [0x0C55, 0x0C56], [0x0C62, 0x0C63], - [0x0C81, 0x0C81], [0x0CBC, 0x0CBC], [0x0CBF, 0x0CBF], - [0x0CC6, 0x0CC6], [0x0CCC, 0x0CCD], [0x0CE2, 0x0CE3], - [0x0D00, 0x0D01], [0x0D3B, 0x0D3C], [0x0D41, 0x0D44], - [0x0D4D, 0x0D4D], [0x0D62, 0x0D63], [0x0DCA, 0x0DCA], - [0x0DD2, 0x0DD4], [0x0DD6, 0x0DD6], [0x0E31, 0x0E31], - [0x0E34, 0x0E3A], [0x0E47, 0x0E4E], [0x0EB1, 0x0EB1], - [0x0EB4, 0x0EBC], [0x0EC8, 0x0ECD], [0x0F18, 0x0F19], - [0x0F35, 0x0F35], [0x0F37, 0x0F37], [0x0F39, 0x0F39], - [0x0F71, 0x0F7E], [0x0F80, 0x0F84], [0x0F86, 0x0F87], - [0x0F8D, 0x0F97], [0x0F99, 0x0FBC], [0x0FC6, 0x0FC6], - [0x102D, 0x1030], [0x1032, 0x1037], [0x1039, 0x103A], - [0x103D, 0x103E], [0x1058, 0x1059], [0x105E, 0x1060], - [0x1071, 0x1074], [0x1082, 0x1082], [0x1085, 0x1086], - [0x108D, 0x108D], [0x109D, 0x109D], [0x1160, 0x11FF], - [0x135D, 0x135F], [0x1712, 0x1714], [0x1732, 0x1734], - [0x1752, 0x1753], [0x1772, 0x1773], [0x17B4, 0x17B5], - [0x17B7, 0x17BD], [0x17C6, 0x17C6], [0x17C9, 0x17D3], - [0x17DD, 0x17DD], [0x180B, 0x180E], [0x1885, 0x1886], - [0x18A9, 0x18A9], [0x1920, 0x1922], [0x1927, 0x1928], - [0x1932, 0x1932], [0x1939, 0x193B], [0x1A17, 0x1A18], - [0x1A1B, 0x1A1B], [0x1A56, 0x1A56], [0x1A58, 0x1A5E], - [0x1A60, 0x1A60], [0x1A62, 0x1A62], [0x1A65, 0x1A6C], - [0x1A73, 0x1A7C], [0x1A7F, 0x1A7F], [0x1AB0, 0x1ABE], - [0x1B00, 0x1B03], [0x1B34, 0x1B34], [0x1B36, 0x1B3A], - [0x1B3C, 0x1B3C], [0x1B42, 0x1B42], [0x1B6B, 0x1B73], - [0x1B80, 0x1B81], [0x1BA2, 0x1BA5], [0x1BA8, 0x1BA9], - [0x1BAB, 0x1BAD], [0x1BE6, 0x1BE6], [0x1BE8, 0x1BE9], - [0x1BED, 0x1BED], [0x1BEF, 0x1BF1], [0x1C2C, 0x1C33], - [0x1C36, 0x1C37], [0x1CD0, 0x1CD2], [0x1CD4, 0x1CE0], - [0x1CE2, 0x1CE8], [0x1CED, 0x1CED], [0x1CF4, 0x1CF4], - [0x1CF8, 0x1CF9], [0x1DC0, 0x1DF9], [0x1DFB, 0x1DFF], - [0x200B, 0x200F], [0x202A, 0x202E], [0x2060, 0x2064], - [0x2066, 0x206F], [0x20D0, 0x20F0], [0x2CEF, 0x2CF1], - [0x2D7F, 0x2D7F], [0x2DE0, 0x2DFF], [0x302A, 0x302D], - [0x3099, 0x309A], [0xA66F, 0xA672], [0xA674, 0xA67D], - [0xA69E, 0xA69F], [0xA6F0, 0xA6F1], [0xA802, 0xA802], - [0xA806, 0xA806], [0xA80B, 0xA80B], [0xA825, 0xA826], - [0xA8C4, 0xA8C5], [0xA8E0, 0xA8F1], [0xA8FF, 0xA8FF], - [0xA926, 0xA92D], [0xA947, 0xA951], [0xA980, 0xA982], - [0xA9B3, 0xA9B3], [0xA9B6, 0xA9B9], [0xA9BC, 0xA9BD], - [0xA9E5, 0xA9E5], [0xAA29, 0xAA2E], [0xAA31, 0xAA32], - [0xAA35, 0xAA36], [0xAA43, 0xAA43], [0xAA4C, 0xAA4C], - [0xAA7C, 0xAA7C], [0xAAB0, 0xAAB0], [0xAAB2, 0xAAB4], - [0xAAB7, 0xAAB8], [0xAABE, 0xAABF], [0xAAC1, 0xAAC1], - [0xAAEC, 0xAAED], [0xAAF6, 0xAAF6], [0xABE5, 0xABE5], - [0xABE8, 0xABE8], [0xABED, 0xABED], [0xFB1E, 0xFB1E], - [0xFE00, 0xFE0F], [0xFE20, 0xFE2F], [0xFEFF, 0xFEFF], - [0xFFF9, 0xFFFB] -]; -const HIGH_COMBINING = [ - [0x101FD, 0x101FD], [0x102E0, 0x102E0], - [0x10376, 0x1037A], [0x10A01, 0x10A03], [0x10A05, 0x10A06], - [0x10A0C, 0x10A0F], [0x10A38, 0x10A3A], [0x10A3F, 0x10A3F], - [0x10AE5, 0x10AE6], [0x10D24, 0x10D27], [0x10F46, 0x10F50], - [0x11001, 0x11001], [0x11038, 0x11046], [0x1107F, 0x11081], - [0x110B3, 0x110B6], [0x110B9, 0x110BA], [0x110BD, 0x110BD], - [0x110CD, 0x110CD], [0x11100, 0x11102], [0x11127, 0x1112B], - [0x1112D, 0x11134], [0x11173, 0x11173], [0x11180, 0x11181], - [0x111B6, 0x111BE], [0x111C9, 0x111CC], [0x1122F, 0x11231], - [0x11234, 0x11234], [0x11236, 0x11237], [0x1123E, 0x1123E], - [0x112DF, 0x112DF], [0x112E3, 0x112EA], [0x11300, 0x11301], - [0x1133B, 0x1133C], [0x11340, 0x11340], [0x11366, 0x1136C], - [0x11370, 0x11374], [0x11438, 0x1143F], [0x11442, 0x11444], - [0x11446, 0x11446], [0x1145E, 0x1145E], [0x114B3, 0x114B8], - [0x114BA, 0x114BA], [0x114BF, 0x114C0], [0x114C2, 0x114C3], - [0x115B2, 0x115B5], [0x115BC, 0x115BD], [0x115BF, 0x115C0], - [0x115DC, 0x115DD], [0x11633, 0x1163A], [0x1163D, 0x1163D], - [0x1163F, 0x11640], [0x116AB, 0x116AB], [0x116AD, 0x116AD], - [0x116B0, 0x116B5], [0x116B7, 0x116B7], [0x1171D, 0x1171F], - [0x11722, 0x11725], [0x11727, 0x1172B], [0x1182F, 0x11837], - [0x11839, 0x1183A], [0x119D4, 0x119D7], [0x119DA, 0x119DB], - [0x119E0, 0x119E0], [0x11A01, 0x11A0A], [0x11A33, 0x11A38], - [0x11A3B, 0x11A3E], [0x11A47, 0x11A47], [0x11A51, 0x11A56], - [0x11A59, 0x11A5B], [0x11A8A, 0x11A96], [0x11A98, 0x11A99], - [0x11C30, 0x11C36], [0x11C38, 0x11C3D], [0x11C3F, 0x11C3F], - [0x11C92, 0x11CA7], [0x11CAA, 0x11CB0], [0x11CB2, 0x11CB3], - [0x11CB5, 0x11CB6], [0x11D31, 0x11D36], [0x11D3A, 0x11D3A], - [0x11D3C, 0x11D3D], [0x11D3F, 0x11D45], [0x11D47, 0x11D47], - [0x11D90, 0x11D91], [0x11D95, 0x11D95], [0x11D97, 0x11D97], - [0x11EF3, 0x11EF4], [0x13430, 0x13438], [0x16AF0, 0x16AF4], - [0x16B30, 0x16B36], [0x16F4F, 0x16F4F], [0x16F8F, 0x16F92], - [0x1BC9D, 0x1BC9E], [0x1BCA0, 0x1BCA3], [0x1D167, 0x1D169], - [0x1D173, 0x1D182], [0x1D185, 0x1D18B], [0x1D1AA, 0x1D1AD], - [0x1D242, 0x1D244], [0x1DA00, 0x1DA36], [0x1DA3B, 0x1DA6C], - [0x1DA75, 0x1DA75], [0x1DA84, 0x1DA84], [0x1DA9B, 0x1DA9F], - [0x1DAA1, 0x1DAAF], [0x1E000, 0x1E006], [0x1E008, 0x1E018], - [0x1E01B, 0x1E021], [0x1E023, 0x1E024], [0x1E026, 0x1E02A], - [0x1E130, 0x1E136], [0x1E2EC, 0x1E2EF], [0x1E8D0, 0x1E8D6], - [0x1E944, 0x1E94A], [0xE0001, 0xE0001], [0xE0020, 0xE007F], - [0xE0100, 0xE01EF] -]; -const BMP_WIDE = [ - [0x1100, 0x115F], [0x231A, 0x231B], [0x2329, 0x232A], - [0x23E9, 0x23EC], [0x23F0, 0x23F0], [0x23F3, 0x23F3], - [0x25FD, 0x25FE], [0x2614, 0x2615], [0x2648, 0x2653], - [0x267F, 0x267F], [0x2693, 0x2693], [0x26A1, 0x26A1], - [0x26AA, 0x26AB], [0x26BD, 0x26BE], [0x26C4, 0x26C5], - [0x26CE, 0x26CE], [0x26D4, 0x26D4], [0x26EA, 0x26EA], - [0x26F2, 0x26F3], [0x26F5, 0x26F5], [0x26FA, 0x26FA], - [0x26FD, 0x26FD], [0x2705, 0x2705], [0x270A, 0x270B], - [0x2728, 0x2728], [0x274C, 0x274C], [0x274E, 0x274E], - [0x2753, 0x2755], [0x2757, 0x2757], [0x2795, 0x2797], - [0x27B0, 0x27B0], [0x27BF, 0x27BF], [0x2B1B, 0x2B1C], - [0x2B50, 0x2B50], [0x2B55, 0x2B55], [0x2E80, 0x2E99], - [0x2E9B, 0x2EF3], [0x2F00, 0x2FD5], [0x2FF0, 0x2FFB], - [0x3000, 0x3029], [0x302E, 0x303E], [0x3041, 0x3096], - [0x309B, 0x30FF], [0x3105, 0x312F], [0x3131, 0x318E], - [0x3190, 0x31BA], [0x31C0, 0x31E3], [0x31F0, 0x321E], - [0x3220, 0x3247], [0x3250, 0x4DBF], [0x4E00, 0xA48C], - [0xA490, 0xA4C6], [0xA960, 0xA97C], [0xAC00, 0xD7A3], - [0xF900, 0xFAFF], [0xFE10, 0xFE19], [0xFE30, 0xFE52], - [0xFE54, 0xFE66], [0xFE68, 0xFE6B], [0xFF01, 0xFF60], - [0xFFE0, 0xFFE6] -]; -const HIGH_WIDE = [ - [0x16FE0, 0x16FE3], [0x17000, 0x187F7], - [0x18800, 0x18AF2], [0x1B000, 0x1B11E], [0x1B150, 0x1B152], - [0x1B164, 0x1B167], [0x1B170, 0x1B2FB], [0x1F004, 0x1F004], - [0x1F0CF, 0x1F0CF], [0x1F18E, 0x1F18E], [0x1F191, 0x1F19A], - [0x1F200, 0x1F202], [0x1F210, 0x1F23B], [0x1F240, 0x1F248], - [0x1F250, 0x1F251], [0x1F260, 0x1F265], [0x1F300, 0x1F320], - [0x1F32D, 0x1F335], [0x1F337, 0x1F37C], [0x1F37E, 0x1F393], - [0x1F3A0, 0x1F3CA], [0x1F3CF, 0x1F3D3], [0x1F3E0, 0x1F3F0], - [0x1F3F4, 0x1F3F4], [0x1F3F8, 0x1F43E], [0x1F440, 0x1F440], - [0x1F442, 0x1F4FC], [0x1F4FF, 0x1F53D], [0x1F54B, 0x1F54E], - [0x1F550, 0x1F567], [0x1F57A, 0x1F57A], [0x1F595, 0x1F596], - [0x1F5A4, 0x1F5A4], [0x1F5FB, 0x1F64F], [0x1F680, 0x1F6C5], - [0x1F6CC, 0x1F6CC], [0x1F6D0, 0x1F6D2], [0x1F6D5, 0x1F6D5], - [0x1F6EB, 0x1F6EC], [0x1F6F4, 0x1F6FA], [0x1F7E0, 0x1F7EB], - [0x1F90D, 0x1F971], [0x1F973, 0x1F976], [0x1F97A, 0x1F9A2], - [0x1F9A5, 0x1F9AA], [0x1F9AE, 0x1F9CA], [0x1F9CD, 0x1F9FF], - [0x1FA70, 0x1FA73], [0x1FA78, 0x1FA7A], [0x1FA80, 0x1FA82], - [0x1FA90, 0x1FA95], [0x20000, 0x2FFFD], [0x30000, 0x3FFFD] -]; - -// BMP lookup table, lazy initialized during first addon loading -let table: Uint8Array; - -function bisearch(ucs: number, data: number[][]): boolean { - let min = 0; - let max = data.length - 1; - let mid; - if (ucs < data[0][0] || ucs > data[max][1]) { - return false; - } - while (max >= min) { - mid = (min + max) >> 1; - if (ucs > data[mid][1]) { - min = mid + 1; - } else if (ucs < data[mid][0]) { - max = mid - 1; - } else { - return true; - } - } - return false; -} - - -export class UnicodeV11 implements IUnicodeVersionProvider { - public readonly version = '11'; - - constructor() { - if (!table) { - table = new Uint8Array(65536); - fill(table, 1); - table[0] = 0; - fill(table, 0, 1, 32); - fill(table, 0, 0x7f, 0xa0); - for (let r = 0; r < BMP_COMBINING.length; ++r) { - fill(table, 0, BMP_COMBINING[r][0], BMP_COMBINING[r][1] + 1); - } - for (let r = 0; r < BMP_WIDE.length; ++r) { - fill(table, 2, BMP_WIDE[r][0], BMP_WIDE[r][1] + 1); - } - } - } - - public wcwidth(num: number): CharWidth { - if (num < 32) return 0; - if (num < 127) return 1; - if (num < 65536) return table[num] as CharWidth; - if (bisearch(num, HIGH_COMBINING)) return 0; - if (bisearch(num, HIGH_WIDE)) return 2; - return 1; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/typings/xterm-addon-unicode11.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/typings/xterm-addon-unicode11.d.ts deleted file mode 100755 index 1d0dce1b1..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-unicode11/typings/xterm-addon-unicode11.d.ts +++ /dev/null @@ -1,14 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { Terminal, ITerminalAddon } from 'xterm'; - -declare module 'xterm-addon-unicode11' { - export class Unicode11Addon implements ITerminalAddon { - constructor(); - public activate(terminal: Terminal): void; - public dispose(): void; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/LICENSE b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/LICENSE deleted file mode 100755 index e597698cc..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/LICENSE +++ /dev/null @@ -1,19 +0,0 @@ -Copyright (c) 2017, The xterm.js authors (https://github.com/xtermjs/xterm.js) - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/README.md b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/README.md deleted file mode 100755 index e53f4edf7..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/README.md +++ /dev/null @@ -1,21 +0,0 @@ -## xterm-addon-web-links - -An addon for [xterm.js](https://github.com/xtermjs/xterm.js) that enables web links. This addon requires xterm.js v4+. - -### Install - -```bash -npm install --save xterm-addon-web-links -``` - -### Usage - -```ts -import { Terminal } from 'xterm'; -import { WebLinksAddon } from 'xterm-addon-web-links'; - -const terminal = new Terminal(); -terminal.loadAddon(new WebLinksAddon()); -``` - -See the full [API](https://github.com/xtermjs/xterm.js/blob/master/addons/xterm-addon-web-links/typings/xterm-addon-web-links.d.ts) for more advanced usage. diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/lib/xterm-addon-web-links.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/lib/xterm-addon-web-links.js deleted file mode 100755 index d8cefec15..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/lib/xterm-addon-web-links.js +++ /dev/null @@ -1,2 +0,0 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.WebLinksAddon=t():e.WebLinksAddon=t()}(window,(function(){return function(e){var t={};function n(r){if(t[r])return t[r].exports;var i=t[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}return n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)n.d(r,i,function(t){return e[t]}.bind(null,i));return r},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=0)}([function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.WebLinksAddon=void 0;var r=n(1),i=new RegExp("(?:^|[^\\da-z\\.-]+)((https?:\\/\\/)((([\\da-z\\.-]+)\\.([a-z\\.]{2,6}))|((\\d{1,3}\\.){3}\\d{1,3})|(localhost))(:\\d{1,5})?((\\/[\\/\\w\\.\\-%~:+@]*)*([^:\"'\\s]))?(\\?[0-9\\w\\[\\]\\(\\)\\/\\?\\!#@$%&'*+,:;~\\=\\.\\-]*)?(#[0-9\\w\\[\\]\\(\\)\\/\\?\\!#@$%&'*+,:;~\\=\\.\\-]*)?)($|[^\\/\\w\\.\\-%]+)");function o(e,t){var n=window.open();n?(n.opener=null,n.location.href=t):console.warn("Opening link blocked as opener could not be cleared")}var a=function(){function e(e,t,n){void 0===e&&(e=o),void 0===t&&(t={}),void 0===n&&(n=!1),this._handler=e,this._options=t,this._useLinkProvider=n,this._options.matchIndex=1}return e.prototype.activate=function(e){this._terminal=e,this._useLinkProvider&&"registerLinkProvider"in this._terminal?this._linkProvider=this._terminal.registerLinkProvider(new r.WebLinkProvider(this._terminal,i,this._handler)):this._linkMatcherId=this._terminal.registerLinkMatcher(i,this._handler,this._options)},e.prototype.dispose=function(){var e;void 0!==this._linkMatcherId&&void 0!==this._terminal&&this._terminal.deregisterLinkMatcher(this._linkMatcherId),null===(e=this._linkProvider)||void 0===e||e.dispose()},e}();t.WebLinksAddon=a},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.LinkComputer=t.WebLinkProvider=void 0;var r=function(){function e(e,t,n){this._terminal=e,this._regex=t,this._handler=n}return e.prototype.provideLinks=function(e,t){t(i.computeLink(e,this._regex,this._terminal,this._handler))},e}();t.WebLinkProvider=r;var i=function(){function e(){}return e.computeLink=function(t,n,r,i){for(var o,a=new RegExp(n.source,(n.flags||"")+"g"),s=e._translateBufferLineToStringWithWrap(t-1,!1,r),u=s[0],d=s[1],l=-1,c=[];null!==(o=a.exec(u));){var f=o[1];if(!f){console.log("match found without corresponding matchIndex");break}if(l=u.indexOf(f,l+1),a.lastIndex=l+f.length,l<0)break;for(var p=l+f.length,h=d+1;p>r.cols;)p-=r.cols,h++;var v={start:{x:l+1,y:d+1},end:{x:p,y:h}};c.push({range:v,text:f,activate:i})}return c},e._translateBufferLineToStringWithWrap=function(e,t,n){var r,i,o="";do{if(!(s=n.buffer.active.getLine(e)))break;s.isWrapped&&e--,i=s.isWrapped}while(i);var a=e;do{var s,u=n.buffer.active.getLine(e+1);if(r=!!u&&u.isWrapped,!(s=n.buffer.active.getLine(e)))break;o+=s.translateToString(!r&&t).substring(0,n.cols),e++}while(r);return[o,a]},e}();t.LinkComputer=i}])})); -//# sourceMappingURL=xterm-addon-web-links.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/lib/xterm-addon-web-links.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/lib/xterm-addon-web-links.js.map deleted file mode 100755 index e75049c1a..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/lib/xterm-addon-web-links.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"sources":["webpack://WebLinksAddon/webpack/universalModuleDefinition","webpack://WebLinksAddon/webpack/bootstrap","webpack://WebLinksAddon/./src/WebLinksAddon.ts","webpack://WebLinksAddon/./src/WebLinkProvider.ts"],"names":["root","factory","exports","module","define","amd","window","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","strictUrlRegex","RegExp","start","handleLink","event","uri","newWindow","open","opener","location","href","console","warn","_handler","_options","_useLinkProvider","this","matchIndex","activate","terminal","_terminal","_linkProvider","registerLinkProvider","WebLinkProvider","_linkMatcherId","registerLinkMatcher","dispose","undefined","deregisterLinkMatcher","WebLinksAddon","_regex","provideLinks","y","callback","LinkComputer","computeLink","regex","handler","match","rex","source","flags","_translateBufferLineToStringWithWrap","line","startLineIndex","stringIndex","result","exec","text","log","indexOf","lastIndex","length","endX","endY","cols","range","x","end","push","lineIndex","trimRight","lineWrapsToNext","prevLinesToWrap","lineString","buffer","active","getLine","isWrapped","nextLine","translateToString","substring"],"mappings":"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","file":"xterm-addon-web-links.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"WebLinksAddon\"] = factory();\n\telse\n\t\troot[\"WebLinksAddon\"] = factory();\n})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Terminal, ILinkMatcherOptions, ITerminalAddon, IDisposable } from 'xterm';\nimport { WebLinkProvider } from './WebLinkProvider';\n\nconst protocolClause = '(https?:\\\\/\\\\/)';\nconst domainCharacterSet = '[\\\\da-z\\\\.-]+';\nconst negatedDomainCharacterSet = '[^\\\\da-z\\\\.-]+';\nconst domainBodyClause = '(' + domainCharacterSet + ')';\nconst tldClause = '([a-z\\\\.]{2,6})';\nconst ipClause = '((\\\\d{1,3}\\\\.){3}\\\\d{1,3})';\nconst localHostClause = '(localhost)';\nconst portClause = '(:\\\\d{1,5})';\nconst hostClause = '((' + domainBodyClause + '\\\\.' + tldClause + ')|' + ipClause + '|' + localHostClause + ')' + portClause + '?';\nconst pathCharacterSet = '(\\\\/[\\\\/\\\\w\\\\.\\\\-%~:+@]*)*([^:\"\\'\\\\s])';\nconst pathClause = '(' + pathCharacterSet + ')?';\nconst queryStringHashFragmentCharacterSet = '[0-9\\\\w\\\\[\\\\]\\\\(\\\\)\\\\/\\\\?\\\\!#@$%&\\'*+,:;~\\\\=\\\\.\\\\-]*';\nconst queryStringClause = '(\\\\?' + queryStringHashFragmentCharacterSet + ')?';\nconst hashFragmentClause = '(#' + queryStringHashFragmentCharacterSet + ')?';\nconst negatedPathCharacterSet = '[^\\\\/\\\\w\\\\.\\\\-%]+';\nconst bodyClause = hostClause + pathClause + queryStringClause + hashFragmentClause;\nconst start = '(?:^|' + negatedDomainCharacterSet + ')(';\nconst end = ')($|' + negatedPathCharacterSet + ')';\nconst strictUrlRegex = new RegExp(start + protocolClause + bodyClause + end);\n\nfunction handleLink(event: MouseEvent, uri: string): void {\n const newWindow = window.open();\n if (newWindow) {\n newWindow.opener = null;\n newWindow.location.href = uri;\n } else {\n console.warn('Opening link blocked as opener could not be cleared');\n }\n}\n\nexport class WebLinksAddon implements ITerminalAddon {\n private _linkMatcherId: number | undefined;\n private _terminal: Terminal | undefined;\n private _linkProvider: IDisposable | undefined;\n\n constructor(\n private _handler: (event: MouseEvent, uri: string) => void = handleLink,\n private _options: ILinkMatcherOptions = {},\n private _useLinkProvider: boolean = false\n ) {\n this._options.matchIndex = 1;\n }\n\n public activate(terminal: Terminal): void {\n this._terminal = terminal;\n\n if (this._useLinkProvider && 'registerLinkProvider' in this._terminal) {\n this._linkProvider = this._terminal.registerLinkProvider(new WebLinkProvider(this._terminal, strictUrlRegex, this._handler));\n } else {\n // TODO: This should be removed eventually\n this._linkMatcherId = (this._terminal as Terminal).registerLinkMatcher(strictUrlRegex, this._handler, this._options);\n }\n }\n\n public dispose(): void {\n if (this._linkMatcherId !== undefined && this._terminal !== undefined) {\n this._terminal.deregisterLinkMatcher(this._linkMatcherId);\n }\n\n this._linkProvider?.dispose();\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ILinkProvider, IBufferCellPosition, ILink, Terminal } from 'xterm';\n\nexport class WebLinkProvider implements ILinkProvider {\n\n constructor(\n private readonly _terminal: Terminal,\n private readonly _regex: RegExp,\n private readonly _handler: (event: MouseEvent, uri: string) => void\n ) {\n\n }\n\n public provideLinks(y: number, callback: (links: ILink[] | undefined) => void): void {\n callback(LinkComputer.computeLink(y, this._regex, this._terminal, this._handler));\n }\n}\n\nexport class LinkComputer {\n public static computeLink(y: number, regex: RegExp, terminal: Terminal, handler: (event: MouseEvent, uri: string) => void): ILink[] {\n const rex = new RegExp(regex.source, (regex.flags || '') + 'g');\n\n const [line, startLineIndex] = LinkComputer._translateBufferLineToStringWithWrap(y - 1, false, terminal);\n\n let match;\n let stringIndex = -1;\n const result: ILink[] = [];\n\n while ((match = rex.exec(line)) !== null) {\n const text = match[1];\n if (!text) {\n // something matched but does not comply with the given matchIndex\n // since this is most likely a bug the regex itself we simply do nothing here\n console.log('match found without corresponding matchIndex');\n break;\n }\n\n // Get index, match.index is for the outer match which includes negated chars\n // therefore we cannot use match.index directly, instead we search the position\n // of the match group in text again\n // also correct regex and string search offsets for the next loop run\n stringIndex = line.indexOf(text, stringIndex + 1);\n rex.lastIndex = stringIndex + text.length;\n if (stringIndex < 0) {\n // invalid stringIndex (should not have happened)\n break;\n }\n\n let endX = stringIndex + text.length;\n let endY = startLineIndex + 1;\n\n while (endX > terminal.cols) {\n endX -= terminal.cols;\n endY++;\n }\n\n const range = {\n start: {\n x: stringIndex + 1,\n y: startLineIndex + 1\n },\n end: {\n x: endX,\n y: endY\n }\n };\n\n result.push({ range, text, activate: handler });\n }\n\n return result;\n }\n\n /**\n * Gets the entire line for the buffer line\n * @param line The line being translated.\n * @param trimRight Whether to trim whitespace to the right.\n * @param terminal The terminal\n */\n private static _translateBufferLineToStringWithWrap(lineIndex: number, trimRight: boolean, terminal: Terminal): [string, number] {\n let lineString = '';\n let lineWrapsToNext: boolean;\n let prevLinesToWrap: boolean;\n\n do {\n const line = terminal.buffer.active.getLine(lineIndex);\n if (!line) {\n break;\n }\n\n if (line.isWrapped) {\n lineIndex--;\n }\n\n prevLinesToWrap = line.isWrapped;\n } while (prevLinesToWrap);\n\n const startLineIndex = lineIndex;\n\n do {\n const nextLine = terminal.buffer.active.getLine(lineIndex + 1);\n lineWrapsToNext = nextLine ? nextLine.isWrapped : false;\n const line = terminal.buffer.active.getLine(lineIndex);\n if (!line) {\n break;\n }\n lineString += line.translateToString(!lineWrapsToNext && trimRight).substring(0, terminal.cols);\n lineIndex++;\n } while (lineWrapsToNext);\n\n return [lineString, startLineIndex];\n }\n}\n"],"sourceRoot":""} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinkProvider.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinkProvider.js deleted file mode 100755 index 6d3caba23..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinkProvider.js +++ /dev/null @@ -1,86 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.LinkComputer = exports.WebLinkProvider = void 0; -var WebLinkProvider = (function () { - function WebLinkProvider(_terminal, _regex, _handler) { - this._terminal = _terminal; - this._regex = _regex; - this._handler = _handler; - } - WebLinkProvider.prototype.provideLinks = function (y, callback) { - callback(LinkComputer.computeLink(y, this._regex, this._terminal, this._handler)); - }; - return WebLinkProvider; -}()); -exports.WebLinkProvider = WebLinkProvider; -var LinkComputer = (function () { - function LinkComputer() { - } - LinkComputer.computeLink = function (y, regex, terminal, handler) { - var rex = new RegExp(regex.source, (regex.flags || '') + 'g'); - var _a = LinkComputer._translateBufferLineToStringWithWrap(y - 1, false, terminal), line = _a[0], startLineIndex = _a[1]; - var match; - var stringIndex = -1; - var result = []; - while ((match = rex.exec(line)) !== null) { - var text = match[1]; - if (!text) { - console.log('match found without corresponding matchIndex'); - break; - } - stringIndex = line.indexOf(text, stringIndex + 1); - rex.lastIndex = stringIndex + text.length; - if (stringIndex < 0) { - break; - } - var endX = stringIndex + text.length; - var endY = startLineIndex + 1; - while (endX > terminal.cols) { - endX -= terminal.cols; - endY++; - } - var range = { - start: { - x: stringIndex + 1, - y: startLineIndex + 1 - }, - end: { - x: endX, - y: endY - } - }; - result.push({ range: range, text: text, activate: handler }); - } - return result; - }; - LinkComputer._translateBufferLineToStringWithWrap = function (lineIndex, trimRight, terminal) { - var lineString = ''; - var lineWrapsToNext; - var prevLinesToWrap; - do { - var line = terminal.buffer.active.getLine(lineIndex); - if (!line) { - break; - } - if (line.isWrapped) { - lineIndex--; - } - prevLinesToWrap = line.isWrapped; - } while (prevLinesToWrap); - var startLineIndex = lineIndex; - do { - var nextLine = terminal.buffer.active.getLine(lineIndex + 1); - lineWrapsToNext = nextLine ? nextLine.isWrapped : false; - var line = terminal.buffer.active.getLine(lineIndex); - if (!line) { - break; - } - lineString += line.translateToString(!lineWrapsToNext && trimRight).substring(0, terminal.cols); - lineIndex++; - } while (lineWrapsToNext); - return [lineString, startLineIndex]; - }; - return LinkComputer; -}()); -exports.LinkComputer = LinkComputer; -//# sourceMappingURL=WebLinkProvider.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinkProvider.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinkProvider.js.map deleted file mode 100755 index fe42519e6..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinkProvider.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"WebLinkProvider.js","sourceRoot":"","sources":["../src/WebLinkProvider.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinksAddon.api.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinksAddon.api.js.map deleted file mode 100755 index 07681daf8..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinksAddon.api.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"WebLinksAddon.api.js","sourceRoot":"","sources":["../src/WebLinksAddon.api.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinksAddon.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinksAddon.js deleted file mode 100755 index 6ae2af9ab..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinksAddon.js +++ /dev/null @@ -1,63 +0,0 @@ -"use strict"; -Object.defineProperty(exports, "__esModule", { value: true }); -exports.WebLinksAddon = void 0; -var WebLinkProvider_1 = require("./WebLinkProvider"); -var protocolClause = '(https?:\\/\\/)'; -var domainCharacterSet = '[\\da-z\\.-]+'; -var negatedDomainCharacterSet = '[^\\da-z\\.-]+'; -var domainBodyClause = '(' + domainCharacterSet + ')'; -var tldClause = '([a-z\\.]{2,6})'; -var ipClause = '((\\d{1,3}\\.){3}\\d{1,3})'; -var localHostClause = '(localhost)'; -var portClause = '(:\\d{1,5})'; -var hostClause = '((' + domainBodyClause + '\\.' + tldClause + ')|' + ipClause + '|' + localHostClause + ')' + portClause + '?'; -var pathCharacterSet = '(\\/[\\/\\w\\.\\-%~:+@]*)*([^:"\'\\s])'; -var pathClause = '(' + pathCharacterSet + ')?'; -var queryStringHashFragmentCharacterSet = '[0-9\\w\\[\\]\\(\\)\\/\\?\\!#@$%&\'*+,:;~\\=\\.\\-]*'; -var queryStringClause = '(\\?' + queryStringHashFragmentCharacterSet + ')?'; -var hashFragmentClause = '(#' + queryStringHashFragmentCharacterSet + ')?'; -var negatedPathCharacterSet = '[^\\/\\w\\.\\-%]+'; -var bodyClause = hostClause + pathClause + queryStringClause + hashFragmentClause; -var start = '(?:^|' + negatedDomainCharacterSet + ')('; -var end = ')($|' + negatedPathCharacterSet + ')'; -var strictUrlRegex = new RegExp(start + protocolClause + bodyClause + end); -function handleLink(event, uri) { - var newWindow = window.open(); - if (newWindow) { - newWindow.opener = null; - newWindow.location.href = uri; - } - else { - console.warn('Opening link blocked as opener could not be cleared'); - } -} -var WebLinksAddon = (function () { - function WebLinksAddon(_handler, _options, _useLinkProvider) { - if (_handler === void 0) { _handler = handleLink; } - if (_options === void 0) { _options = {}; } - if (_useLinkProvider === void 0) { _useLinkProvider = false; } - this._handler = _handler; - this._options = _options; - this._useLinkProvider = _useLinkProvider; - this._options.matchIndex = 1; - } - WebLinksAddon.prototype.activate = function (terminal) { - this._terminal = terminal; - if (this._useLinkProvider && 'registerLinkProvider' in this._terminal) { - this._linkProvider = this._terminal.registerLinkProvider(new WebLinkProvider_1.WebLinkProvider(this._terminal, strictUrlRegex, this._handler)); - } - else { - this._linkMatcherId = this._terminal.registerLinkMatcher(strictUrlRegex, this._handler, this._options); - } - }; - WebLinksAddon.prototype.dispose = function () { - var _a; - if (this._linkMatcherId !== undefined && this._terminal !== undefined) { - this._terminal.deregisterLinkMatcher(this._linkMatcherId); - } - (_a = this._linkProvider) === null || _a === void 0 ? void 0 : _a.dispose(); - }; - return WebLinksAddon; -}()); -exports.WebLinksAddon = WebLinksAddon; -//# sourceMappingURL=WebLinksAddon.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinksAddon.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinksAddon.js.map deleted file mode 100755 index 3c40a5d10..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/out/WebLinksAddon.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"WebLinksAddon.js","sourceRoot":"","sources":["../src/WebLinksAddon.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/src/WebLinkProvider.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/src/WebLinkProvider.ts deleted file mode 100755 index af6ad7d36..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/src/WebLinkProvider.ts +++ /dev/null @@ -1,117 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ILinkProvider, IBufferCellPosition, ILink, Terminal } from 'xterm'; - -export class WebLinkProvider implements ILinkProvider { - - constructor( - private readonly _terminal: Terminal, - private readonly _regex: RegExp, - private readonly _handler: (event: MouseEvent, uri: string) => void - ) { - - } - - public provideLinks(y: number, callback: (links: ILink[] | undefined) => void): void { - callback(LinkComputer.computeLink(y, this._regex, this._terminal, this._handler)); - } -} - -export class LinkComputer { - public static computeLink(y: number, regex: RegExp, terminal: Terminal, handler: (event: MouseEvent, uri: string) => void): ILink[] { - const rex = new RegExp(regex.source, (regex.flags || '') + 'g'); - - const [line, startLineIndex] = LinkComputer._translateBufferLineToStringWithWrap(y - 1, false, terminal); - - let match; - let stringIndex = -1; - const result: ILink[] = []; - - while ((match = rex.exec(line)) !== null) { - const text = match[1]; - if (!text) { - // something matched but does not comply with the given matchIndex - // since this is most likely a bug the regex itself we simply do nothing here - console.log('match found without corresponding matchIndex'); - break; - } - - // Get index, match.index is for the outer match which includes negated chars - // therefore we cannot use match.index directly, instead we search the position - // of the match group in text again - // also correct regex and string search offsets for the next loop run - stringIndex = line.indexOf(text, stringIndex + 1); - rex.lastIndex = stringIndex + text.length; - if (stringIndex < 0) { - // invalid stringIndex (should not have happened) - break; - } - - let endX = stringIndex + text.length; - let endY = startLineIndex + 1; - - while (endX > terminal.cols) { - endX -= terminal.cols; - endY++; - } - - const range = { - start: { - x: stringIndex + 1, - y: startLineIndex + 1 - }, - end: { - x: endX, - y: endY - } - }; - - result.push({ range, text, activate: handler }); - } - - return result; - } - - /** - * Gets the entire line for the buffer line - * @param line The line being translated. - * @param trimRight Whether to trim whitespace to the right. - * @param terminal The terminal - */ - private static _translateBufferLineToStringWithWrap(lineIndex: number, trimRight: boolean, terminal: Terminal): [string, number] { - let lineString = ''; - let lineWrapsToNext: boolean; - let prevLinesToWrap: boolean; - - do { - const line = terminal.buffer.active.getLine(lineIndex); - if (!line) { - break; - } - - if (line.isWrapped) { - lineIndex--; - } - - prevLinesToWrap = line.isWrapped; - } while (prevLinesToWrap); - - const startLineIndex = lineIndex; - - do { - const nextLine = terminal.buffer.active.getLine(lineIndex + 1); - lineWrapsToNext = nextLine ? nextLine.isWrapped : false; - const line = terminal.buffer.active.getLine(lineIndex); - if (!line) { - break; - } - lineString += line.translateToString(!lineWrapsToNext && trimRight).substring(0, terminal.cols); - lineIndex++; - } while (lineWrapsToNext); - - return [lineString, startLineIndex]; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/src/WebLinksAddon.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/src/WebLinksAddon.ts deleted file mode 100755 index 3f0e317ed..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/src/WebLinksAddon.ts +++ /dev/null @@ -1,70 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { Terminal, ILinkMatcherOptions, ITerminalAddon, IDisposable } from 'xterm'; -import { WebLinkProvider } from 'xterm-addon-web-links/src/WebLinkProvider'; - -const protocolClause = '(https?:\\/\\/)'; -const domainCharacterSet = '[\\da-z\\.-]+'; -const negatedDomainCharacterSet = '[^\\da-z\\.-]+'; -const domainBodyClause = '(' + domainCharacterSet + ')'; -const tldClause = '([a-z\\.]{2,6})'; -const ipClause = '((\\d{1,3}\\.){3}\\d{1,3})'; -const localHostClause = '(localhost)'; -const portClause = '(:\\d{1,5})'; -const hostClause = '((' + domainBodyClause + '\\.' + tldClause + ')|' + ipClause + '|' + localHostClause + ')' + portClause + '?'; -const pathCharacterSet = '(\\/[\\/\\w\\.\\-%~:+@]*)*([^:"\'\\s])'; -const pathClause = '(' + pathCharacterSet + ')?'; -const queryStringHashFragmentCharacterSet = '[0-9\\w\\[\\]\\(\\)\\/\\?\\!#@$%&\'*+,:;~\\=\\.\\-]*'; -const queryStringClause = '(\\?' + queryStringHashFragmentCharacterSet + ')?'; -const hashFragmentClause = '(#' + queryStringHashFragmentCharacterSet + ')?'; -const negatedPathCharacterSet = '[^\\/\\w\\.\\-%]+'; -const bodyClause = hostClause + pathClause + queryStringClause + hashFragmentClause; -const start = '(?:^|' + negatedDomainCharacterSet + ')('; -const end = ')($|' + negatedPathCharacterSet + ')'; -const strictUrlRegex = new RegExp(start + protocolClause + bodyClause + end); - -function handleLink(event: MouseEvent, uri: string): void { - const newWindow = window.open(); - if (newWindow) { - newWindow.opener = null; - newWindow.location.href = uri; - } else { - console.warn('Opening link blocked as opener could not be cleared'); - } -} - -export class WebLinksAddon implements ITerminalAddon { - private _linkMatcherId: number | undefined; - private _terminal: Terminal | undefined; - private _linkProvider: IDisposable | undefined; - - constructor( - private _handler: (event: MouseEvent, uri: string) => void = handleLink, - private _options: ILinkMatcherOptions = {}, - private _useLinkProvider: boolean = false - ) { - this._options.matchIndex = 1; - } - - public activate(terminal: Terminal): void { - this._terminal = terminal; - - if (this._useLinkProvider && 'registerLinkProvider' in this._terminal) { - this._linkProvider = this._terminal.registerLinkProvider(new WebLinkProvider(this._terminal, strictUrlRegex, this._handler)); - } else { - // TODO: This should be removed eventually - this._linkMatcherId = (this._terminal as Terminal).registerLinkMatcher(strictUrlRegex, this._handler, this._options); - } - } - - public dispose(): void { - if (this._linkMatcherId !== undefined && this._terminal !== undefined) { - this._terminal.deregisterLinkMatcher(this._linkMatcherId); - } - - this._linkProvider?.dispose(); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/typings/xterm-addon-web-links.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/typings/xterm-addon-web-links.d.ts deleted file mode 100755 index f05647049..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm-addon-web-links/typings/xterm-addon-web-links.d.ts +++ /dev/null @@ -1,36 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - - -import { Terminal, ILinkMatcherOptions, ITerminalAddon } from 'xterm'; - -declare module 'xterm-addon-web-links' { - /** - * An xterm.js addon that enables web links. - */ - export class WebLinksAddon implements ITerminalAddon { - /** - * Creates a new web links addon. - * @param handler The callback when the link is called. - * @param options Options for the link matcher. - * @param useLinkProvider Whether to use the new link provider API to create - * the links. This is an option because use of both link matcher (old) and - * link provider (new) may cause issues. Link provider will eventually be - * the default and only option. - */ - constructor(handler?: (event: MouseEvent, uri: string) => void, options?: ILinkMatcherOptions, useLinkProvider?: boolean); - - /** - * Activates the addon - * @param terminal The terminal the addon is being loaded in. - */ - public activate(terminal: Terminal): void; - - /** - * Disposes the addon. - */ - public dispose(): void; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/.eslintrc.json b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/.eslintrc.json deleted file mode 100755 index 8c416f159..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/.eslintrc.json +++ /dev/null @@ -1,164 +0,0 @@ -{ - "env": { - "browser": true, - "es6": true, - "node": true - }, - "parser": "@typescript-eslint/parser", - "parserOptions": { - "project": [ - "src/browser/tsconfig.json", - "src/common/tsconfig.json", - "test/api/tsconfig.json", - "test/benchmark/tsconfig.json", - "addons/xterm-addon-attach/src/tsconfig.json", - "addons/xterm-addon-attach/test/tsconfig.json", - "addons/xterm-addon-fit/src/tsconfig.json", - "addons/xterm-addon-fit/test/tsconfig.json", - "addons/xterm-addon-ligatures/src/tsconfig.json", - "addons/xterm-addon-search/src/tsconfig.json", - "addons/xterm-addon-search/test/tsconfig.json", - "addons/xterm-addon-serialize/src/tsconfig.json", - "addons/xterm-addon-serialize/test/tsconfig.json", - "addons/xterm-addon-serialize/benchmark/tsconfig.json", - "addons/xterm-addon-unicode11/src/tsconfig.json", - "addons/xterm-addon-unicode11/test/tsconfig.json", - "addons/xterm-addon-web-links/src/tsconfig.json", - "addons/xterm-addon-web-links/test/tsconfig.json", - "addons/xterm-addon-webgl/src/tsconfig.json", - "addons/xterm-addon-webgl/test/tsconfig.json" - ], - "sourceType": "module" - }, - "ignorePatterns": [ - "**/typings/*.d.ts", - "**/node_modules", - "**/*.js" - ], - "plugins": [ - "@typescript-eslint" - ], - "rules": { - "no-extra-semi": "error", - "@typescript-eslint/array-type": [ - "warn", - { - "default": "array-simple", - "readonly": "generic" - } - ], - "@typescript-eslint/consistent-type-definitions": "warn", - "@typescript-eslint/explicit-function-return-type": [ - "warn", - { - "allowExpressions": true - } - ], - "@typescript-eslint/explicit-member-accessibility": [ - "warn", - { - "accessibility": "explicit", - "overrides": { - "constructors": "off" - } - } - ], - "@typescript-eslint/indent": [ - "warn", - 2 - ], - "@typescript-eslint/member-delimiter-style": [ - "warn", - { - "multiline": { - "delimiter": "semi", - "requireLast": true - }, - "singleline": { - "delimiter": "comma", - "requireLast": false - } - } - ], - "@typescript-eslint/naming-convention": [ - "warn", - { "selector": "default", "format": ["camelCase"] }, - // variableLike - { "selector": "variable", "format": ["camelCase", "UPPER_CASE"] }, - { "selector": "variable", "filter": "^I.+Service$", "format": ["PascalCase"], "prefix": ["I"] }, - // memberLike - { "selector": "memberLike", "modifiers": ["private"], "format": ["camelCase"], "leadingUnderscore": "require" }, - { "selector": "memberLike", "modifiers": ["protected"], "format": ["camelCase"], "leadingUnderscore": "require" }, - { "selector": "enumMember", "format": ["UPPER_CASE"] }, - // memberLike - Allow enum-like objects to use UPPER_CASE - { "selector": "property", "modifiers": ["public"], "format": ["camelCase", "UPPER_CASE"] }, - { "selector": "method", "modifiers": ["public"], "format": ["camelCase", "UPPER_CASE"] }, - // typeLike - { "selector": "typeLike", "format": ["PascalCase"] }, - { "selector": "interface", "format": ["PascalCase"], "prefix": ["I"] } - ], - "@typescript-eslint/prefer-namespace-keyword": "warn", - "@typescript-eslint/type-annotation-spacing": "warn", - "@typescript-eslint/quotes": [ - "warn", - "single", - { "allowTemplateLiterals": true } - ], - "@typescript-eslint/semi": [ - "warn", - "always" - ], - "comma-dangle": [ - "warn", - { - "objects": "never", - "arrays": "never", - "functions": "never" - } - ], - "curly": [ - "warn", - "multi-line" - ], - "eol-last": "warn", - "eqeqeq": [ - "warn", - "always" - ], - "keyword-spacing": "warn", - "new-parens": "warn", - "no-duplicate-imports": "warn", - "no-else-return": [ - "warn", - { - "allowElseIf": false - } - ], - "no-eval": "warn", - "no-irregular-whitespace": "warn", - "no-restricted-imports": [ - "warn", - { - "patterns": [ - ".*\\/out\\/.*" - ] - } - ], - "no-trailing-spaces": "warn", - "no-unsafe-finally": "warn", - "no-var": "warn", - "one-var": [ - "warn", - "never" - ], - "prefer-const": "warn", - "spaced-comment": [ - "warn", - "always", - { - "markers": ["/"], - "exceptions": ["-"] - } - ] - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/LICENSE b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/LICENSE deleted file mode 100755 index 4472336c9..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/LICENSE +++ /dev/null @@ -1,21 +0,0 @@ -Copyright (c) 2017-2019, The xterm.js authors (https://github.com/xtermjs/xterm.js) -Copyright (c) 2014-2016, SourceLair Private Company (https://www.sourcelair.com) -Copyright (c) 2012-2013, Christopher Jeffrey (https://github.com/chjj/) - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -THE SOFTWARE. diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/README.md b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/README.md deleted file mode 100755 index 26db59d0d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/README.md +++ /dev/null @@ -1,205 +0,0 @@ -# [![xterm.js logo](logo-full.png)](https://xtermjs.org) - -[![Build Status](https://dev.azure.com/xtermjs/xterm.js/_apis/build/status/xtermjs.xterm.js)](https://dev.azure.com/xtermjs/xterm.js/_build/latest?definitionId=3) - -Xterm.js is a front-end component written in TypeScript that lets applications bring fully-featured terminals to their users in the browser. It's used by popular projects such as VS Code, Hyper and Theia. - -## Features - -- **Terminal apps just work**: Xterm.js works with most terminal apps such as `bash`, `vim` and `tmux`, this includes support for curses-based apps and mouse event support. -- **Performant**: Xterm.js is *really* fast, it even includes a GPU-accelerated renderer. -- **Rich unicode support**: Supports CJK, emojis and IMEs. -- **Self-contained**: Requires zero dependencies to work. -- **Accessible**: Screen reader and minimum contrast ratio support can be turned on -- **And much more**: Links, theming, addons, well documented API, etc. - -## What xterm.js is not - -- Xterm.js is not a terminal application that you can download and use on your computer. -- Xterm.js is not `bash`. Xterm.js can be connected to processes like `bash` and let you interact with them (provide input, receive output). - -## Getting Started - -First you need to install the module, we ship exclusively through [npm](https://www.npmjs.com/) so you need that installed and then add xterm.js as a dependency by running: - -``` -npm install xterm -``` - -To start using xterm.js on your browser, add the `xterm.js` and `xterm.css` to the head of your html page. Then create a `
` onto which xterm can attach itself. Finally instantiate the `Terminal` object and then call the `open` function with the DOM object of the `div`. - -```html - - - - - - - -
- - - -``` - -### Importing - -The recommended way to load xterm.js is via the ES6 module syntax: - -```javascript -import { Terminal } from 'xterm'; -``` - -### Addons - -⚠️ *This section describes the new addon format introduced in v3.14.0, see [here](https://github.com/xtermjs/xterm.js/blob/3.14.2/README.md#addons) for the instructions on the old format* - -Addons are separate modules that extend the `Terminal` by building on the [xterm.js API](https://github.com/xtermjs/xterm.js/blob/master/typings/xterm.d.ts). To use an addon you first need to install it in your project: - -```bash -npm i -S xterm-addon-web-links -``` - -Then import the addon, instantiate it and call `Terminal.loadAddon`: - -```ts -import { Terminal } from 'xterm'; -import { WebLinksAddon } from 'xterm-addon-web-links'; - -const terminal = new Terminal(); -// Load WebLinksAddon on terminal, this is all that's needed to get web links -// working in the terminal. -terminal.loadAddon(new WebLinksAddon()); -``` - -The xterm.js team maintains the following addons but they can be built by anyone: - -- [`xterm-addon-attach`](https://github.com/xtermjs/xterm.js/tree/master/addons/xterm-addon-attach): Attaches to a server running a process via a websocket -- [`xterm-addon-fit`](https://github.com/xtermjs/xterm.js/tree/master/addons/xterm-addon-fit): Fits the terminal to the containing element -- [`xterm-addon-search`](https://github.com/xtermjs/xterm.js/tree/master/addons/xterm-addon-search): Adds search functionality -- [`xterm-addon-web-links`](https://github.com/xtermjs/xterm.js/tree/master/addons/xterm-addon-web-links): Adds web link detection and interaction - -## Browser Support - -Since xterm.js is typically implemented as a developer tool, only modern browsers are supported officially. Specifically the latest versions of *Chrome*, *Edge*, *Firefox* and *Safari*. - -We also partially support *Internet Explorer 11*, meaning xterm.js should work for the most part, but we reserve the right to not provide workarounds specifically for it unless it's absolutely necessary to get the basic input/output flow working. - -Xterm.js works seamlessly in [Electron](https://electronjs.org/) apps and may even work on earlier versions of the browsers, these are the versions we strive to keep working. - -## API - -The full API for xterm.js is contained within the [TypeScript declaration file](https://github.com/xtermjs/xterm.js/blob/master/typings/xterm.d.ts), use the branch/tag picker in GitHub (`w`) to navigate to the correct version of the API. - -Note that some APIs are marked *experimental*, these are added to enable experimentation with new ideas without committing to support it like a normal [semver](https://semver.org/) API. Note that these APIs can change radically between versions so be sure to read release notes if you plan on using experimental APIs. - -## Real-world uses -Xterm.js is used in several world-class applications to provide great terminal experiences. - -- [**SourceLair**](https://www.sourcelair.com/): In-browser IDE that provides its users with fully-featured Linux terminals based on xterm.js. -- [**Microsoft Visual Studio Code**](http://code.visualstudio.com/): Modern, versatile and powerful open source code editor that provides an integrated terminal based on xterm.js. -- [**ttyd**](https://github.com/tsl0922/ttyd): A command-line tool for sharing terminal over the web, with fully-featured terminal emulation based on xterm.js. -- [**Katacoda**](https://www.katacoda.com/): Katacoda is an Interactive Learning Platform for software developers, covering the latest Cloud Native technologies. -- [**Eclipse Che**](http://www.eclipse.org/che): Developer workspace server, cloud IDE, and Eclipse next-generation IDE. -- [**Codenvy**](http://www.codenvy.com): Cloud workspaces for development teams. -- [**CoderPad**](https://coderpad.io): Online interviewing platform for programmers. Run code in many programming languages, with results displayed by xterm.js. -- [**WebSSH2**](https://github.com/billchurch/WebSSH2): A web based SSH2 client using xterm.js, socket.io, and ssh2. -- [**Spyder Terminal**](https://github.com/spyder-ide/spyder-terminal): A full fledged system terminal embedded on Spyder IDE. -- [**Cloud Commander**](https://cloudcmd.io "Cloud Commander"): Orthodox web file manager with console and editor. -- [**Next Tech**](https://next.tech "Next Tech"): Online platform for interactive coding and web development courses. Live container-backed terminal uses xterm.js. -- [**RStudio**](https://www.rstudio.com/products/RStudio "RStudio"): RStudio is an integrated development environment (IDE) for R. -- [**Terminal for Atom**](https://github.com/jsmecham/atom-terminal-tab): A simple terminal for the Atom text editor. -- [**Eclipse Orion**](https://orionhub.org): A modern, open source software development environment that runs in the cloud. Code, deploy and run in the cloud. -- [**Gravitational Teleport**](https://github.com/gravitational/teleport): Gravitational Teleport is a modern SSH server for remotely accessing clusters of Linux servers via SSH or HTTPS. -- [**Hexlet**](https://en.hexlet.io): Practical programming courses (JavaScript, PHP, Unix, databases, functional programming). A steady path from the first line of code to the first job. -- [**Selenoid UI**](https://github.com/aerokube/selenoid-ui): Simple UI for the scallable golang implementation of Selenium Hub named Selenoid. We use XTerm for streaming logs over websockets from docker containers. -- [**Portainer**](https://portainer.io): Simple management UI for Docker. -- [**SSHy**](https://github.com/stuicey/SSHy): HTML5 Based SSHv2 Web Client with E2E encryption utilising xterm.js, SJCL & websockets. -- [**JupyterLab**](https://github.com/jupyterlab/jupyterlab): An extensible computational environment for Jupyter, supporting interactive data science and scientific computing across all programming languages. -- [**Theia**](https://github.com/theia-ide/theia): Theia is a cloud & desktop IDE framework implemented in TypeScript. -- [**Opshell**](https://github.com/ricktbaker/opshell) Ops Helper tool to make life easier working with AWS instances across multiple organizations. -- [**Proxmox VE**](https://www.proxmox.com/en/proxmox-ve): Proxmox VE is a complete open-source platform for enterprise virtualization. It uses xterm.js for container terminals and the host shell. -- [**Script Runner**](https://github.com/ioquatix/script-runner): Run scripts (or a shell) in Atom. -- [**Whack Whack Terminal**](https://github.com/Microsoft/WhackWhackTerminal): Terminal emulator for Visual Studio 2017. -- [**VTerm**](https://github.com/vterm/vterm): Extensible terminal emulator based on Electron and React. -- [**electerm**](http://electerm.html5beta.com): electerm is a terminal/ssh/sftp client(mac, win, linux) based on electron/node-pty/xterm. -- [**Kubebox**](https://github.com/astefanutti/kubebox): Terminal console for Kubernetes clusters. -- [**Azure Cloud Shell**](https://shell.azure.com): Azure Cloud Shell is a Microsoft-managed admin machine built on Azure, for Azure. -- [**atom-xterm**](https://atom.io/packages/atom-xterm): Atom plugin for providing terminals inside your Atom workspace. -- [**rtty**](https://github.com/zhaojh329/rtty): Access your terminals from anywhere via the web. -- [**Pisth**](https://github.com/ColdGrub1384/Pisth): An SFTP and SSH client for iOS. -- [**abstruse**](https://github.com/bleenco/abstruse): Abstruse CI is a continuous integration platform based on Node.JS and Docker. -- [**Azure Data Studio**](https://github.com/Microsoft/azuredatastudio): A data management tool that enables working with SQL Server, Azure SQL DB and SQL DW from Windows, macOS and Linux. -- [**FreeMAN**](https://github.com/matthew-matvei/freeman): A free, cross-platform file manager for power users. -- [**Fluent Terminal**](https://github.com/felixse/FluentTerminal): A terminal emulator based on UWP and web technologies. -- [**Hyper**](https://hyper.is): A terminal built on web technologies. -- [**Diag**](https://diag.ai): A better way to troubleshoot problems faster. Capture, share and reapply troubleshooting knowledge so you can focus on solving problems that matter. -- [**GoTTY**](https://github.com/yudai/gotty): A simple command line tool that shares your terminal as a web application based on xterm.js. -- [**genact**](https://github.com/svenstaro/genact): A nonsense activity generator. -- [**cPanel & WHM**](https://cpanel.com): The hosting platform of choice. -- [**Nutanix**](https://github.com/nutanix): Nutanix Enterprise Cloud uses xterm in the webssh functionality within Nutanix Calm, and is also looking to move our old noserial (termjs) functionality to xterm.js. -- [**SSH Web Client**](https://github.com/roke22/PHP-SSH2-Web-Client): SSH Web Client with PHP. -- [**Shellvault**](https://www.shellvault.io): The cloud-based SSH terminal you can access from anywhere. -- [**Juno**](http://junolab.org/): A flexible Julia IDE, based on Atom. -- [**webssh**](https://github.com/huashengdun/webssh): Web based ssh client. -- [**info-beamer hosted**](https://info-beamer.com): Uses xterm.js to manage digital signage devices from the web dashboard. -- [**Jumpserver**](https://github.com/jumpserver/luna): Jumpserver Luna project, Jumpserver is a bastion server project, Luna use xterm.js for web terminal emulation. -- [**LxdMosaic**](https://github.com/turtle0x1/LxdMosaic): Uses xterm.js to give terminal access to containers through LXD -- [**CodeInterview.io**](https://codeinterview.io): A coding interview platform in 25+ languages and many web frameworks. Uses xterm.js to provide shell access. -- [**Bastillion**](https://www.bastillion.io): Bastillion is an open-source web-based SSH console that centrally manages administrative access to systems. -- [**PHP App Server**](https://github.com/cubiclesoft/php-app-server/): Create lightweight, installable almost-native applications for desktop OSes. ExecTerminal (nicely wraps the xterm.js Terminal), TerminalManager, and RunProcessSDK are self-contained, reusable ES5+ compliant Javascript components. -- [**NgTerminal**](https://github.com/qwefgh90/ng-terminal): NgTerminal is a web terminal that leverages xterm.js on Angular 7+. You can easily add it into your application by adding `` into your component. -- [**tty-share**](https://tty-share.com): Extremely simple terminal sharing over the Internet. -- [**Ten Hands**](https://github.com/saisandeepvaddi/ten-hands): One place to run your command-line tasks. -- [**WebAssembly.sh**](https://webassembly.sh): A WebAssembly WASI browser terminal -- [**Gus**](https://gus.jp): A shared coding pad where you can run Python with xterm.js -- [**Linode**](https://linode.com): Linode uses xterm.js to provide users a web console for their Linode instances. -- [**FluffOS**](https://www.fluffos.info): Active maintained LPMUD driver with websocket support. -- [**x-terminal**](https://atom.io/packages/x-terminal): Atom plugin for providing terminals inside your Atom workspace. -- [**CoCalc**](https://cocalc.com/): Lots of free software pre-installed, to chat, collaborate, develop, program, publish, research, share, teach, in C++, HTML, Julia, Jupyter, LaTeX, Markdown, Python, R, SageMath, Scala, ... -- [**Dank Domain**](https://www.DDgame.us/): Open source multiuser medieval game supporting old & new terminal emulation. -- [**DockerStacks**](https://docker-stacks.com/): Local LAMP/LEMP development studio -- [**Codecademy**](https://codecademy.com/): Uses xterm.js in its courses on Bash. -- [**Laravel Ssh Web Client**](https://github.com/roke22/Laravel-ssh-client): Laravel server inventory with ssh web client to connect at server using xterm.js -- [**Repl.it**](https://repl.it): Collaborative browser based IDE with support for 50+ different languages. -- [**TeleType**](https://github.com/akshaykmr/TeleType): cli tool that allows you to share your terminal online conveniently. Show off mad cli-fu, help a colleague, teach, or troubleshoot. -- [**Intervue**](https://www.intervue.io): Pair programming for interviews. Multiple programming languages supported, with results displayed by xterm.js. -- [**TRASA**](https://trasa.io): Zero trust access to Web, SSH, RDP and Database services. -- [**Commas**](https://github.com/CyanSalt/commas): Commas is a hackable terminal and command runner. -- [**Devtron**](https://github.com/devtron-labs/devtron): Software Delivery Workflow For Kubernetes. -- [**NxShell**](https://github.com/nxshell/nxshell): An easy to use new terminal for SSH. -[And much more...](https://github.com/xtermjs/xterm.js/network/dependents) - -Do you use xterm.js in your application as well? Please [open a Pull Request](https://github.com/sourcelair/xterm.js/pulls) to include it here. We would love to have it in our list. Note: Please add any new contributions to the end of the list only. - -## Releases - -Xterm.js follows a monthly release cycle roughly. - -All current and past releases are available on this repo's [Releases page](https://github.com/sourcelair/xterm.js/releases), you can view the [high-level roadmap on the wiki](https://github.com/xtermjs/xterm.js/wiki/Roadmap) and see what we're working on now by looking through [Milestones](https://github.com/sourcelair/xterm.js/milestones). - -### Beta builds - -Our CI releases beta builds to npm for every change that goes into master, install the latest beta build with: - -``` -npm install -S xterm@beta -``` - -These should generally be stable but some bugs may slip in, we recommend using the beta build primarily to test out new features and for verifying bug fixes. - -## Contributing - -You can read the [guide on the wiki](https://github.com/xtermjs/xterm.js/wiki/Contributing) to learn how to contribute and setup xterm.js for development. - -## License Agreement - -If you contribute code to this project, you are implicitly allowing your code to be distributed under the MIT license. You are also implicitly verifying that all code is your original work. - -Copyright (c) 2017-2019, [The xterm.js authors](https://github.com/xtermjs/xterm.js/graphs/contributors) (MIT License)
-Copyright (c) 2014-2017, SourceLair, Private Company ([www.sourcelair.com](https://www.sourcelair.com/home)) (MIT License)
-Copyright (c) 2012-2013, Christopher Jeffrey (MIT License) diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/css/xterm.css b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/css/xterm.css deleted file mode 100755 index dcebea990..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/css/xterm.css +++ /dev/null @@ -1,285 +0,0 @@ -/** - * Copyright (c) 2014 The xterm.js authors. All rights reserved. - * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License) - * https://github.com/chjj/term.js - * @license MIT - * - * Permission is hereby granted, free of charge, to any person obtaining a copy - * of this software and associated documentation files (the "Software"), to deal - * in the Software without restriction, including without limitation the rights - * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell - * copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN - * THE SOFTWARE. - * - * Originally forked from (with the author's permission): - * Fabrice Bellard's javascript vt100 for jslinux: - * http://bellard.org/jslinux/ - * Copyright (c) 2011 Fabrice Bellard - * The original design remains. The terminal itself - * has been extended to include xterm CSI codes, among - * other features. - */ - -/** - * Default styles for xterm.js - */ - - .xterm { - cursor: text; - position: relative; - user-select: none; - -ms-user-select: none; - -webkit-user-select: none; -} - -.xterm.focus, -.xterm:focus { - outline: none; -} - -.xterm .xterm-helpers { - position: absolute; - top: 0; - /** - * The z-index of the helpers must be higher than the canvases in order for - * IMEs to appear on top. - */ - z-index: 5; -} - -.xterm .xterm-helper-textarea { - padding: 0; - border: 0; - margin: 0; - /* Move textarea out of the screen to the far left, so that the cursor is not visible */ - position: absolute; - opacity: 0; - left: -9999em; - top: 0; - width: 0; - height: 0; - z-index: -5; - /** Prevent wrapping so the IME appears against the textarea at the correct position */ - white-space: nowrap; - overflow: hidden; - resize: none; -} - -.xterm .composition-view { - /* TODO: Composition position got messed up somewhere */ - background: #000; - color: #FFF; - display: none; - position: absolute; - white-space: nowrap; - z-index: 1; -} - -.xterm .composition-view.active { - display: block; -} - -.xterm .xterm-viewport { - /* On OS X this is required in order for the scroll bar to appear fully opaque */ - background-color: #000; - overflow-y: scroll; - cursor: default; - position: absolute; - right: 0; - left: 0; - top: 0; - bottom: 0; -} - -.xterm .xterm-screen { - position: relative; -} - -.xterm .xterm-screen canvas { - position: absolute; - left: 0; - top: 0; -} - -.xterm-char-measure-element { - display: inline-block; - visibility: hidden; - position: absolute; - top: 0; - left: -9999em; - line-height: normal; -} - -.xterm.enable-mouse-events { - /* When mouse events are enabled (eg. tmux), revert to the standard pointer cursor */ - cursor: default; -} - -.xterm.xterm-cursor-pointer, -.xterm .xterm-cursor-pointer { - cursor: pointer; -} - -.xterm.column-select.focus { - /* Column selection mode */ - cursor: crosshair; -} - -.xterm .xterm-accessibility:not(.debug), -.xterm .xterm-message { - position: absolute; - left: 0; - top: 0; - bottom: 0; - right: 0; - z-index: 10; - color: transparent; - pointer-events: none; -} - -.xterm .xterm-accessibility-tree:not(.debug) *::selection { - color: transparent; -} - -.xterm .xterm-accessibility-tree { - font-family: monospace; - user-select: text; - white-space: pre; -} - -.xterm .xterm-accessibility-tree > div { - transform-origin: left; - width: fit-content; -} - -.xterm .live-region { - position: absolute; - left: -9999px; - width: 1px; - height: 1px; - overflow: hidden; -} - -.xterm-dim { - /* Dim should not apply to background, so the opacity of the foreground color is applied - * explicitly in the generated class and reset to 1 here */ - opacity: 1 !important; -} - -.xterm-underline-1 { text-decoration: underline; } -.xterm-underline-2 { text-decoration: double underline; } -.xterm-underline-3 { text-decoration: wavy underline; } -.xterm-underline-4 { text-decoration: dotted underline; } -.xterm-underline-5 { text-decoration: dashed underline; } - -.xterm-overline { - text-decoration: overline; -} - -.xterm-overline.xterm-underline-1 { text-decoration: overline underline; } -.xterm-overline.xterm-underline-2 { text-decoration: overline double underline; } -.xterm-overline.xterm-underline-3 { text-decoration: overline wavy underline; } -.xterm-overline.xterm-underline-4 { text-decoration: overline dotted underline; } -.xterm-overline.xterm-underline-5 { text-decoration: overline dashed underline; } - -.xterm-strikethrough { - text-decoration: line-through; -} - -.xterm-screen .xterm-decoration-container .xterm-decoration { - z-index: 6; - position: absolute; -} - -.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer { - z-index: 7; -} - -.xterm-decoration-overview-ruler { - z-index: 8; - position: absolute; - top: 0; - right: 0; - pointer-events: none; -} - -.xterm-decoration-top { - z-index: 2; - position: relative; -} - - - -/* Derived from vs/base/browser/ui/scrollbar/media/scrollbar.css */ - -/* xterm.js customization: Override xterm's cursor style */ -.xterm .xterm-scrollable-element > .scrollbar { - cursor: default; -} - -/* Arrows */ -.xterm .xterm-scrollable-element > .scrollbar > .scra { - cursor: pointer; - font-size: 11px !important; -} - -.xterm .xterm-scrollable-element > .visible { - opacity: 1; - - /* Background rule added for IE9 - to allow clicks on dom node */ - background:rgba(0,0,0,0); - - transition: opacity 100ms linear; - /* In front of peek view */ - z-index: 11; -} -.xterm .xterm-scrollable-element > .invisible { - opacity: 0; - pointer-events: none; -} -.xterm .xterm-scrollable-element > .invisible.fade { - transition: opacity 800ms linear; -} - -/* Scrollable Content Inset Shadow */ -.xterm .xterm-scrollable-element > .shadow { - position: absolute; - display: none; -} -.xterm .xterm-scrollable-element > .shadow.top { - display: block; - top: 0; - left: 3px; - height: 3px; - width: 100%; - box-shadow: var(--vscode-scrollbar-shadow, #000) 0 6px 6px -6px inset; -} -.xterm .xterm-scrollable-element > .shadow.left { - display: block; - top: 3px; - left: 0; - height: 100%; - width: 3px; - box-shadow: var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset; -} -.xterm .xterm-scrollable-element > .shadow.top-left-corner { - display: block; - top: 0; - left: 0; - height: 3px; - width: 3px; -} -.xterm .xterm-scrollable-element > .shadow.top.left { - box-shadow: var(--vscode-scrollbar-shadow, #000) 6px 0 6px -6px inset; -} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/lib/xterm.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/lib/xterm.js deleted file mode 100755 index 62af4a5dc..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/lib/xterm.js +++ /dev/null @@ -1,2 +0,0 @@ -!function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t();else if("function"==typeof define&&define.amd)define([],t);else{var r=t();for(var i in r)("object"==typeof exports?exports:e)[i]=r[i]}}(self,(function(){return(()=>{"use strict";var e={4567:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.AccessibilityManager=void 0;var o=r(9042),s=r(6114),a=r(6193),c=r(3656),l=r(844),h=r(5596),u=r(9631),f=function(e){function t(t,r){var i=e.call(this)||this;i._terminal=t,i._renderService=r,i._liveRegionLineCount=0,i._charsToConsume=[],i._charsToAnnounce="",i._accessibilityTreeRoot=document.createElement("div"),i._accessibilityTreeRoot.classList.add("xterm-accessibility"),i._rowContainer=document.createElement("div"),i._rowContainer.setAttribute("role","list"),i._rowContainer.classList.add("xterm-accessibility-tree"),i._rowElements=[];for(var n=0;ne;)this._rowContainer.removeChild(this._rowElements.pop());this._rowElements[this._rowElements.length-1].addEventListener("focus",this._bottomBoundaryFocusListener),this._refreshRowsDimensions()},t.prototype._createAccessibilityTreeNode=function(){var e=document.createElement("div");return e.setAttribute("role","listitem"),e.tabIndex=-1,this._refreshRowDimensions(e),e},t.prototype._onTab=function(e){for(var t=0;t0?this._charsToConsume.shift()!==e&&(this._charsToAnnounce+=e):this._charsToAnnounce+=e,"\n"===e&&(this._liveRegionLineCount++,21===this._liveRegionLineCount&&(this._liveRegion.textContent+=o.tooMuchOutput)),s.isMac&&this._liveRegion.textContent&&this._liveRegion.textContent.length>0&&!this._liveRegion.parentNode&&setTimeout((function(){t._accessibilityTreeRoot.appendChild(t._liveRegion)}),0))},t.prototype._clearLiveRegion=function(){this._liveRegion.textContent="",this._liveRegionLineCount=0,s.isMac&&u.removeElementFromParent(this._liveRegion)},t.prototype._onKey=function(e){this._clearLiveRegion(),this._charsToConsume.push(e)},t.prototype._refreshRows=function(e,t){this._renderRowsDebouncer.refresh(e,t,this._terminal.rows)},t.prototype._renderRows=function(e,t){for(var r=this._terminal.buffer,i=r.lines.length.toString(),n=e;n<=t;n++){var o=r.translateBufferLineToString(r.ydisp+n,!0),s=(r.ydisp+n+1).toString(),a=this._rowElements[n];a&&(0===o.length?a.innerText=" ":a.textContent=o,a.setAttribute("aria-posinset",s),a.setAttribute("aria-setsize",i))}this._announceCharacters()},t.prototype._refreshRowsDimensions=function(){if(this._renderService.dimensions.actualCellHeight){this._rowElements.length!==this._terminal.rows&&this._onResize(this._terminal.rows);for(var e=0;e{function r(e){return e.replace(/\r?\n/g,"\r")}function i(e,t){return t?"[200~"+e+"[201~":e}function n(e,t,n){e=i(e=r(e),n.decPrivateModes.bracketedPasteMode),n.triggerDataEvent(e,!0),t.value=""}function o(e,t,r){var i=r.getBoundingClientRect(),n=e.clientX-i.left-10,o=e.clientY-i.top-10;t.style.width="20px",t.style.height="20px",t.style.left=n+"px",t.style.top=o+"px",t.style.zIndex="1000",t.focus()}Object.defineProperty(t,"__esModule",{value:!0}),t.rightClickHandler=t.moveTextAreaUnderMouseCursor=t.paste=t.handlePasteEvent=t.copyHandler=t.bracketTextForPaste=t.prepareTextForTerminal=void 0,t.prepareTextForTerminal=r,t.bracketTextForPaste=i,t.copyHandler=function(e,t){e.clipboardData&&e.clipboardData.setData("text/plain",t.selectionText),e.preventDefault()},t.handlePasteEvent=function(e,t,r){e.stopPropagation(),e.clipboardData&&n(e.clipboardData.getData("text/plain"),t,r)},t.paste=n,t.moveTextAreaUnderMouseCursor=o,t.rightClickHandler=function(e,t,r,i,n){o(e,t,r),n&&i.rightClickSelect(e),t.value=i.selectionText,t.select()}},4774:(e,t)=>{var r,i,n,o;function s(e){var t=e.toString(16);return t.length<2?"0"+t:t}function a(e,t){return e>>0}}(r=t.channels||(t.channels={})),(i=t.color||(t.color={})).blend=function(e,t){var i=(255&t.rgba)/255;if(1===i)return{css:t.css,rgba:t.rgba};var n=t.rgba>>24&255,o=t.rgba>>16&255,s=t.rgba>>8&255,a=e.rgba>>24&255,c=e.rgba>>16&255,l=e.rgba>>8&255,h=a+Math.round((n-a)*i),u=c+Math.round((o-c)*i),f=l+Math.round((s-l)*i);return{css:r.toCss(h,u,f),rgba:r.toRgba(h,u,f)}},i.isOpaque=function(e){return 255==(255&e.rgba)},i.ensureContrastRatio=function(e,t,r){var i=o.ensureContrastRatio(e.rgba,t.rgba,r);if(i)return o.toColor(i>>24&255,i>>16&255,i>>8&255)},i.opaque=function(e){var t=(255|e.rgba)>>>0,i=o.toChannels(t),n=i[0],s=i[1],a=i[2];return{css:r.toCss(n,s,a),rgba:t}},i.opacity=function(e,t){var i=Math.round(255*t),n=o.toChannels(e.rgba),s=n[0],a=n[1],c=n[2];return{css:r.toCss(s,a,c,i),rgba:r.toRgba(s,a,c,i)}},(t.css||(t.css={})).toColor=function(e){switch(e.length){case 7:return{css:e,rgba:(parseInt(e.slice(1),16)<<8|255)>>>0};case 9:return{css:e,rgba:parseInt(e.slice(1),16)>>>0}}throw new Error("css.toColor: Unsupported css format")},function(e){function t(e,t,r){var i=e/255,n=t/255,o=r/255;return.2126*(i<=.03928?i/12.92:Math.pow((i+.055)/1.055,2.4))+.7152*(n<=.03928?n/12.92:Math.pow((n+.055)/1.055,2.4))+.0722*(o<=.03928?o/12.92:Math.pow((o+.055)/1.055,2.4))}e.relativeLuminance=function(e){return t(e>>16&255,e>>8&255,255&e)},e.relativeLuminance2=t}(n=t.rgb||(t.rgb={})),function(e){function t(e,t,r){for(var i=e>>24&255,o=e>>16&255,s=e>>8&255,c=t>>24&255,l=t>>16&255,h=t>>8&255,u=a(n.relativeLuminance2(c,h,l),n.relativeLuminance2(i,o,s));u0||l>0||h>0);)c-=Math.max(0,Math.ceil(.1*c)),l-=Math.max(0,Math.ceil(.1*l)),h-=Math.max(0,Math.ceil(.1*h)),u=a(n.relativeLuminance2(c,h,l),n.relativeLuminance2(i,o,s));return(c<<24|l<<16|h<<8|255)>>>0}function i(e,t,r){for(var i=e>>24&255,o=e>>16&255,s=e>>8&255,c=t>>24&255,l=t>>16&255,h=t>>8&255,u=a(n.relativeLuminance2(c,h,l),n.relativeLuminance2(i,o,s));u>>0}e.ensureContrastRatio=function(e,r,o){var s=n.relativeLuminance(e>>8),c=n.relativeLuminance(r>>8);if(a(s,c)>24&255,e>>16&255,e>>8&255,255&e]},e.toColor=function(e,t,i){return{css:r.toCss(e,t,i),rgba:r.toRgba(e,t,i)}}}(o=t.rgba||(t.rgba={})),t.toPaddedHex=s,t.contrastRatio=a},7239:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.ColorContrastCache=void 0;var r=function(){function e(){this._color={},this._rgba={}}return e.prototype.clear=function(){this._color={},this._rgba={}},e.prototype.setCss=function(e,t,r){this._rgba[e]||(this._rgba[e]={}),this._rgba[e][t]=r},e.prototype.getCss=function(e,t){return this._rgba[e]?this._rgba[e][t]:void 0},e.prototype.setColor=function(e,t,r){this._color[e]||(this._color[e]={}),this._color[e][t]=r},e.prototype.getColor=function(e,t){return this._color[e]?this._color[e][t]:void 0},e}();t.ColorContrastCache=r},5680:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.ColorManager=t.DEFAULT_ANSI_COLORS=void 0;var i=r(4774),n=r(7239),o=i.css.toColor("#ffffff"),s=i.css.toColor("#000000"),a=i.css.toColor("#ffffff"),c=i.css.toColor("#000000"),l={css:"rgba(255, 255, 255, 0.3)",rgba:4294967117};t.DEFAULT_ANSI_COLORS=Object.freeze(function(){for(var e=[i.css.toColor("#2e3436"),i.css.toColor("#cc0000"),i.css.toColor("#4e9a06"),i.css.toColor("#c4a000"),i.css.toColor("#3465a4"),i.css.toColor("#75507b"),i.css.toColor("#06989a"),i.css.toColor("#d3d7cf"),i.css.toColor("#555753"),i.css.toColor("#ef2929"),i.css.toColor("#8ae234"),i.css.toColor("#fce94f"),i.css.toColor("#729fcf"),i.css.toColor("#ad7fa8"),i.css.toColor("#34e2e2"),i.css.toColor("#eeeeec")],t=[0,95,135,175,215,255],r=0;r<216;r++){var n=t[r/36%6|0],o=t[r/6%6|0],s=t[r%6];e.push({css:i.channels.toCss(n,o,s),rgba:i.channels.toRgba(n,o,s)})}for(r=0;r<24;r++){var a=8+10*r;e.push({css:i.channels.toCss(a,a,a),rgba:i.channels.toRgba(a,a,a)})}return e}());var h=function(){function e(e,r){this.allowTransparency=r;var h=e.createElement("canvas");h.width=1,h.height=1;var u=h.getContext("2d");if(!u)throw new Error("Could not get rendering context");this._ctx=u,this._ctx.globalCompositeOperation="copy",this._litmusColor=this._ctx.createLinearGradient(0,0,1,1),this._contrastCache=new n.ColorContrastCache,this.colors={foreground:o,background:s,cursor:a,cursorAccent:c,selectionTransparent:l,selectionOpaque:i.color.blend(s,l),ansi:t.DEFAULT_ANSI_COLORS.slice(),contrastCache:this._contrastCache}}return e.prototype.onOptionsChange=function(e){"minimumContrastRatio"===e&&this._contrastCache.clear()},e.prototype.setTheme=function(e){void 0===e&&(e={}),this.colors.foreground=this._parseColor(e.foreground,o),this.colors.background=this._parseColor(e.background,s),this.colors.cursor=this._parseColor(e.cursor,a,!0),this.colors.cursorAccent=this._parseColor(e.cursorAccent,c,!0),this.colors.selectionTransparent=this._parseColor(e.selection,l,!0),this.colors.selectionOpaque=i.color.blend(this.colors.background,this.colors.selectionTransparent),i.color.isOpaque(this.colors.selectionTransparent)&&(this.colors.selectionTransparent=i.color.opacity(this.colors.selectionTransparent,.3)),this.colors.ansi[0]=this._parseColor(e.black,t.DEFAULT_ANSI_COLORS[0]),this.colors.ansi[1]=this._parseColor(e.red,t.DEFAULT_ANSI_COLORS[1]),this.colors.ansi[2]=this._parseColor(e.green,t.DEFAULT_ANSI_COLORS[2]),this.colors.ansi[3]=this._parseColor(e.yellow,t.DEFAULT_ANSI_COLORS[3]),this.colors.ansi[4]=this._parseColor(e.blue,t.DEFAULT_ANSI_COLORS[4]),this.colors.ansi[5]=this._parseColor(e.magenta,t.DEFAULT_ANSI_COLORS[5]),this.colors.ansi[6]=this._parseColor(e.cyan,t.DEFAULT_ANSI_COLORS[6]),this.colors.ansi[7]=this._parseColor(e.white,t.DEFAULT_ANSI_COLORS[7]),this.colors.ansi[8]=this._parseColor(e.brightBlack,t.DEFAULT_ANSI_COLORS[8]),this.colors.ansi[9]=this._parseColor(e.brightRed,t.DEFAULT_ANSI_COLORS[9]),this.colors.ansi[10]=this._parseColor(e.brightGreen,t.DEFAULT_ANSI_COLORS[10]),this.colors.ansi[11]=this._parseColor(e.brightYellow,t.DEFAULT_ANSI_COLORS[11]),this.colors.ansi[12]=this._parseColor(e.brightBlue,t.DEFAULT_ANSI_COLORS[12]),this.colors.ansi[13]=this._parseColor(e.brightMagenta,t.DEFAULT_ANSI_COLORS[13]),this.colors.ansi[14]=this._parseColor(e.brightCyan,t.DEFAULT_ANSI_COLORS[14]),this.colors.ansi[15]=this._parseColor(e.brightWhite,t.DEFAULT_ANSI_COLORS[15]),this._contrastCache.clear()},e.prototype._parseColor=function(e,t,r){if(void 0===r&&(r=this.allowTransparency),void 0===e)return t;if(this._ctx.fillStyle=this._litmusColor,this._ctx.fillStyle=e,"string"!=typeof this._ctx.fillStyle)return console.warn("Color: "+e+" is invalid using fallback "+t.css),t;this._ctx.fillRect(0,0,1,1);var n=this._ctx.getImageData(0,0,1,1).data;if(255!==n[3]){if(!r)return console.warn("Color: "+e+" is using transparency, but allowTransparency is false. Using fallback "+t.css+"."),t;var o=this._ctx.fillStyle.substring(5,this._ctx.fillStyle.length-1).split(",").map((function(e){return Number(e)})),s=o[0],a=o[1],c=o[2],l=o[3],h=Math.round(255*l);return{rgba:i.channels.toRgba(s,a,c,h),css:e}}return{css:this._ctx.fillStyle,rgba:i.channels.toRgba(n[0],n[1],n[2],n[3])}},e}();t.ColorManager=h},9631:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.removeElementFromParent=void 0,t.removeElementFromParent=function(){for(var e,t=[],r=0;r{Object.defineProperty(t,"__esModule",{value:!0}),t.addDisposableDomListener=void 0,t.addDisposableDomListener=function(e,t,r,i){e.addEventListener(t,r,i);var n=!1;return{dispose:function(){n||(n=!0,e.removeEventListener(t,r,i))}}}},3551:function(e,t,r){var i=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},n=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.MouseZone=t.Linkifier=void 0;var o=r(8460),s=r(2585),a=function(){function e(e,t,r){this._bufferService=e,this._logService=t,this._unicodeService=r,this._linkMatchers=[],this._nextLinkMatcherId=0,this._onShowLinkUnderline=new o.EventEmitter,this._onHideLinkUnderline=new o.EventEmitter,this._onLinkTooltip=new o.EventEmitter,this._rowsToLinkify={start:void 0,end:void 0}}return Object.defineProperty(e.prototype,"onShowLinkUnderline",{get:function(){return this._onShowLinkUnderline.event},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onHideLinkUnderline",{get:function(){return this._onHideLinkUnderline.event},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onLinkTooltip",{get:function(){return this._onLinkTooltip.event},enumerable:!1,configurable:!0}),e.prototype.attachToDom=function(e,t){this._element=e,this._mouseZoneManager=t},e.prototype.linkifyRows=function(t,r){var i=this;this._mouseZoneManager&&(void 0===this._rowsToLinkify.start||void 0===this._rowsToLinkify.end?(this._rowsToLinkify.start=t,this._rowsToLinkify.end=r):(this._rowsToLinkify.start=Math.min(this._rowsToLinkify.start,t),this._rowsToLinkify.end=Math.max(this._rowsToLinkify.end,r)),this._mouseZoneManager.clearAll(t,r),this._rowsTimeoutId&&clearTimeout(this._rowsTimeoutId),this._rowsTimeoutId=setTimeout((function(){return i._linkifyRows()}),e._timeBeforeLatency))},e.prototype._linkifyRows=function(){this._rowsTimeoutId=void 0;var e=this._bufferService.buffer;if(void 0!==this._rowsToLinkify.start&&void 0!==this._rowsToLinkify.end){var t=e.ydisp+this._rowsToLinkify.start;if(!(t>=e.lines.length)){for(var r=e.ydisp+Math.min(this._rowsToLinkify.end,this._bufferService.rows)+1,i=Math.ceil(2e3/this._bufferService.cols),n=this._bufferService.buffer.iterator(!1,t,r,i,i);n.hasNext();)for(var o=n.next(),s=0;s=0;t--)if(e.priority<=this._linkMatchers[t].priority)return void this._linkMatchers.splice(t+1,0,e);this._linkMatchers.splice(0,0,e)}else this._linkMatchers.push(e)},e.prototype.deregisterLinkMatcher=function(e){for(var t=0;t>9&511:void 0;r.validationCallback?r.validationCallback(a,(function(e){n._rowsTimeoutId||e&&n._addLink(l[1],l[0]-n._bufferService.buffer.ydisp,a,r,f)})):c._addLink(l[1],l[0]-c._bufferService.buffer.ydisp,a,r,f)},c=this;null!==(i=o.exec(t))&&"break"!==a(););},e.prototype._addLink=function(e,t,r,i,n){var o=this;if(this._mouseZoneManager&&this._element){var s=this._unicodeService.getStringCellWidth(r),a=e%this._bufferService.cols,l=t+Math.floor(e/this._bufferService.cols),h=(a+s)%this._bufferService.cols,u=l+Math.floor((a+s)/this._bufferService.cols);0===h&&(h=this._bufferService.cols,u--),this._mouseZoneManager.add(new c(a+1,l+1,h+1,u+1,(function(e){if(i.handler)return i.handler(e,r);var t=window.open();t?(t.opener=null,t.location.href=r):console.warn("Opening link blocked as opener could not be cleared")}),(function(){o._onShowLinkUnderline.fire(o._createLinkHoverEvent(a,l,h,u,n)),o._element.classList.add("xterm-cursor-pointer")}),(function(e){o._onLinkTooltip.fire(o._createLinkHoverEvent(a,l,h,u,n)),i.hoverTooltipCallback&&i.hoverTooltipCallback(e,r,{start:{x:a,y:l},end:{x:h,y:u}})}),(function(){o._onHideLinkUnderline.fire(o._createLinkHoverEvent(a,l,h,u,n)),o._element.classList.remove("xterm-cursor-pointer"),i.hoverLeaveCallback&&i.hoverLeaveCallback()}),(function(e){return!i.willLinkActivate||i.willLinkActivate(e,r)})))}},e.prototype._createLinkHoverEvent=function(e,t,r,i,n){return{x1:e,y1:t,x2:r,y2:i,cols:this._bufferService.cols,fg:n}},e._timeBeforeLatency=200,e=i([n(0,s.IBufferService),n(1,s.ILogService),n(2,s.IUnicodeService)],e)}();t.Linkifier=a;var c=function(e,t,r,i,n,o,s,a,c){this.x1=e,this.y1=t,this.x2=r,this.y2=i,this.clickCallback=n,this.hoverCallback=o,this.tooltipCallback=s,this.leaveCallback=a,this.willLinkActivate=c};t.MouseZone=c},6465:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}),o=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},s=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.Linkifier2=void 0;var a=r(2585),c=r(8460),l=r(844),h=r(3656),u=function(e){function t(t){var r=e.call(this)||this;return r._bufferService=t,r._linkProviders=[],r._linkCacheDisposables=[],r._isMouseOut=!0,r._activeLine=-1,r._onShowLinkUnderline=r.register(new c.EventEmitter),r._onHideLinkUnderline=r.register(new c.EventEmitter),r.register(l.getDisposeArrayDisposable(r._linkCacheDisposables)),r}return n(t,e),Object.defineProperty(t.prototype,"onShowLinkUnderline",{get:function(){return this._onShowLinkUnderline.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onHideLinkUnderline",{get:function(){return this._onHideLinkUnderline.event},enumerable:!1,configurable:!0}),t.prototype.registerLinkProvider=function(e){var t=this;return this._linkProviders.push(e),{dispose:function(){var r=t._linkProviders.indexOf(e);-1!==r&&t._linkProviders.splice(r,1)}}},t.prototype.attachToDom=function(e,t,r){var i=this;this._element=e,this._mouseService=t,this._renderService=r,this.register(h.addDisposableDomListener(this._element,"mouseleave",(function(){i._isMouseOut=!0,i._clearCurrentLink()}))),this.register(h.addDisposableDomListener(this._element,"mousemove",this._onMouseMove.bind(this))),this.register(h.addDisposableDomListener(this._element,"click",this._onClick.bind(this)))},t.prototype._onMouseMove=function(e){if(this._lastMouseEvent=e,this._element&&this._mouseService){var t=this._positionFromMouseEvent(e,this._element,this._mouseService);if(t){this._isMouseOut=!1;for(var r=e.composedPath(),i=0;ie?this._bufferService.cols:s.link.range.end.x,l=a;l<=c;l++){if(r.has(l)){n.splice(o--,1);break}r.add(l)}}},t.prototype._checkLinkProviderResult=function(e,t,r){var i,n=this;if(!this._activeProviderReplies)return r;for(var o=this._activeProviderReplies.get(e),s=!1,a=0;a=e&&this._currentLink.link.range.end.y<=t)&&(this._linkLeave(this._element,this._currentLink.link,this._lastMouseEvent),this._currentLink=void 0,l.disposeArray(this._linkCacheDisposables))},t.prototype._handleNewLink=function(e){var t=this;if(this._element&&this._lastMouseEvent&&this._mouseService){var r=this._positionFromMouseEvent(this._lastMouseEvent,this._element,this._mouseService);r&&this._linkAtPosition(e.link,r)&&(this._currentLink=e,this._currentLink.state={decorations:{underline:void 0===e.link.decorations||e.link.decorations.underline,pointerCursor:void 0===e.link.decorations||e.link.decorations.pointerCursor},isHovered:!0},this._linkHover(this._element,e.link,this._lastMouseEvent),e.link.decorations={},Object.defineProperties(e.link.decorations,{pointerCursor:{get:function(){var e,r;return null===(r=null===(e=t._currentLink)||void 0===e?void 0:e.state)||void 0===r?void 0:r.decorations.pointerCursor},set:function(e){var r,i;(null===(r=t._currentLink)||void 0===r?void 0:r.state)&&t._currentLink.state.decorations.pointerCursor!==e&&(t._currentLink.state.decorations.pointerCursor=e,t._currentLink.state.isHovered&&(null===(i=t._element)||void 0===i||i.classList.toggle("xterm-cursor-pointer",e)))}},underline:{get:function(){var e,r;return null===(r=null===(e=t._currentLink)||void 0===e?void 0:e.state)||void 0===r?void 0:r.decorations.underline},set:function(r){var i,n,o;(null===(i=t._currentLink)||void 0===i?void 0:i.state)&&(null===(o=null===(n=t._currentLink)||void 0===n?void 0:n.state)||void 0===o?void 0:o.decorations.underline)!==r&&(t._currentLink.state.decorations.underline=r,t._currentLink.state.isHovered&&t._fireUnderlineEvent(e.link,r))}}}),this._renderService&&this._linkCacheDisposables.push(this._renderService.onRenderedBufferChange((function(e){var r=0===e.start?0:e.start+1+t._bufferService.buffer.ydisp;t._clearCurrentLink(r,e.end+1+t._bufferService.buffer.ydisp)}))))}},t.prototype._linkHover=function(e,t,r){var i;(null===(i=this._currentLink)||void 0===i?void 0:i.state)&&(this._currentLink.state.isHovered=!0,this._currentLink.state.decorations.underline&&this._fireUnderlineEvent(t,!0),this._currentLink.state.decorations.pointerCursor&&e.classList.add("xterm-cursor-pointer")),t.hover&&t.hover(r,t.text)},t.prototype._fireUnderlineEvent=function(e,t){var r=e.range,i=this._bufferService.buffer.ydisp,n=this._createLinkUnderlineEvent(r.start.x-1,r.start.y-i-1,r.end.x,r.end.y-i-1,void 0);(t?this._onShowLinkUnderline:this._onHideLinkUnderline).fire(n)},t.prototype._linkLeave=function(e,t,r){var i;(null===(i=this._currentLink)||void 0===i?void 0:i.state)&&(this._currentLink.state.isHovered=!1,this._currentLink.state.decorations.underline&&this._fireUnderlineEvent(t,!1),this._currentLink.state.decorations.pointerCursor&&e.classList.remove("xterm-cursor-pointer")),t.leave&&t.leave(r,t.text)},t.prototype._linkAtPosition=function(e,t){var r=e.range.start.y===e.range.end.y,i=e.range.start.yt.y;return(r&&e.range.start.x<=t.x&&e.range.end.x>=t.x||i&&e.range.end.x>=t.x||n&&e.range.start.x<=t.x||i&&n)&&e.range.start.y<=t.y&&e.range.end.y>=t.y},t.prototype._positionFromMouseEvent=function(e,t,r){var i=r.getCoords(e,t,this._bufferService.cols,this._bufferService.rows);if(i)return{x:i[0],y:i[1]+this._bufferService.buffer.ydisp}},t.prototype._createLinkUnderlineEvent=function(e,t,r,i,n){return{x1:e,y1:t,x2:r,y2:i,cols:this._bufferService.cols,fg:n}},o([s(0,a.IBufferService)],t)}(l.Disposable);t.Linkifier2=u},9042:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.tooMuchOutput=t.promptLabel=void 0,t.promptLabel="Terminal input",t.tooMuchOutput="Too much output to announce, navigate to rows manually to read"},6954:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}),o=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},s=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.MouseZoneManager=void 0;var a=r(844),c=r(3656),l=r(4725),h=r(2585),u=function(e){function t(t,r,i,n,o,s){var a=e.call(this)||this;return a._element=t,a._screenElement=r,a._bufferService=i,a._mouseService=n,a._selectionService=o,a._optionsService=s,a._zones=[],a._areZonesActive=!1,a._lastHoverCoords=[void 0,void 0],a._initialSelectionLength=0,a.register(c.addDisposableDomListener(a._element,"mousedown",(function(e){return a._onMouseDown(e)}))),a._mouseMoveListener=function(e){return a._onMouseMove(e)},a._mouseLeaveListener=function(e){return a._onMouseLeave(e)},a._clickListener=function(e){return a._onClick(e)},a}return n(t,e),t.prototype.dispose=function(){e.prototype.dispose.call(this),this._deactivate()},t.prototype.add=function(e){this._zones.push(e),1===this._zones.length&&this._activate()},t.prototype.clearAll=function(e,t){if(0!==this._zones.length){e&&t||(e=0,t=this._bufferService.rows-1);for(var r=0;re&&i.y1<=t+1||i.y2>e&&i.y2<=t+1||i.y1t+1)&&(this._currentZone&&this._currentZone===i&&(this._currentZone.leaveCallback(),this._currentZone=void 0),this._zones.splice(r--,1))}0===this._zones.length&&this._deactivate()}},t.prototype._activate=function(){this._areZonesActive||(this._areZonesActive=!0,this._element.addEventListener("mousemove",this._mouseMoveListener),this._element.addEventListener("mouseleave",this._mouseLeaveListener),this._element.addEventListener("click",this._clickListener))},t.prototype._deactivate=function(){this._areZonesActive&&(this._areZonesActive=!1,this._element.removeEventListener("mousemove",this._mouseMoveListener),this._element.removeEventListener("mouseleave",this._mouseLeaveListener),this._element.removeEventListener("click",this._clickListener))},t.prototype._onMouseMove=function(e){this._lastHoverCoords[0]===e.pageX&&this._lastHoverCoords[1]===e.pageY||(this._onHover(e),this._lastHoverCoords=[e.pageX,e.pageY])},t.prototype._onHover=function(e){var t=this,r=this._findZoneEventAt(e);r!==this._currentZone&&(this._currentZone&&(this._currentZone.leaveCallback(),this._currentZone=void 0,this._tooltipTimeout&&clearTimeout(this._tooltipTimeout)),r&&(this._currentZone=r,r.hoverCallback&&r.hoverCallback(e),this._tooltipTimeout=window.setTimeout((function(){return t._onTooltip(e)}),this._optionsService.options.linkTooltipHoverDuration)))},t.prototype._onTooltip=function(e){this._tooltipTimeout=void 0;var t=this._findZoneEventAt(e);t&&t.tooltipCallback&&t.tooltipCallback(e)},t.prototype._onMouseDown=function(e){if(this._initialSelectionLength=this._getSelectionLength(),this._areZonesActive){var t=this._findZoneEventAt(e);(null==t?void 0:t.willLinkActivate(e))&&(e.preventDefault(),e.stopImmediatePropagation())}},t.prototype._onMouseLeave=function(e){this._currentZone&&(this._currentZone.leaveCallback(),this._currentZone=void 0,this._tooltipTimeout&&clearTimeout(this._tooltipTimeout))},t.prototype._onClick=function(e){var t=this._findZoneEventAt(e),r=this._getSelectionLength();t&&r===this._initialSelectionLength&&(t.clickCallback(e),e.preventDefault(),e.stopImmediatePropagation())},t.prototype._getSelectionLength=function(){var e=this._selectionService.selectionText;return e?e.length:0},t.prototype._findZoneEventAt=function(e){var t=this._mouseService.getCoords(e,this._screenElement,this._bufferService.cols,this._bufferService.rows);if(t)for(var r=t[0],i=t[1],n=0;n=o.x1&&r=o.x1||i===o.y2&&ro.y1&&i{Object.defineProperty(t,"__esModule",{value:!0}),t.RenderDebouncer=void 0;var r=function(){function e(e){this._renderCallback=e}return e.prototype.dispose=function(){this._animationFrame&&(window.cancelAnimationFrame(this._animationFrame),this._animationFrame=void 0)},e.prototype.refresh=function(e,t,r){var i=this;this._rowCount=r,e=void 0!==e?e:0,t=void 0!==t?t:this._rowCount-1,this._rowStart=void 0!==this._rowStart?Math.min(this._rowStart,e):e,this._rowEnd=void 0!==this._rowEnd?Math.max(this._rowEnd,t):t,this._animationFrame||(this._animationFrame=window.requestAnimationFrame((function(){return i._innerRefresh()})))},e.prototype._innerRefresh=function(){if(void 0!==this._rowStart&&void 0!==this._rowEnd&&void 0!==this._rowCount){var e=Math.max(this._rowStart,0),t=Math.min(this._rowEnd,this._rowCount-1);this._rowStart=void 0,this._rowEnd=void 0,this._animationFrame=void 0,this._renderCallback(e,t)}},e}();t.RenderDebouncer=r},5596:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.ScreenDprMonitor=void 0;var o=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t._currentDevicePixelRatio=window.devicePixelRatio,t}return n(t,e),t.prototype.setListener=function(e){var t=this;this._listener&&this.clearListener(),this._listener=e,this._outerListener=function(){t._listener&&(t._listener(window.devicePixelRatio,t._currentDevicePixelRatio),t._updateDpr())},this._updateDpr()},t.prototype.dispose=function(){e.prototype.dispose.call(this),this.clearListener()},t.prototype._updateDpr=function(){var e;this._outerListener&&(null===(e=this._resolutionMediaMatchList)||void 0===e||e.removeListener(this._outerListener),this._currentDevicePixelRatio=window.devicePixelRatio,this._resolutionMediaMatchList=window.matchMedia("screen and (resolution: "+window.devicePixelRatio+"dppx)"),this._resolutionMediaMatchList.addListener(this._outerListener))},t.prototype.clearListener=function(){this._resolutionMediaMatchList&&this._listener&&this._outerListener&&(this._resolutionMediaMatchList.removeListener(this._outerListener),this._resolutionMediaMatchList=void 0,this._listener=void 0,this._outerListener=void 0)},t}(r(844).Disposable);t.ScreenDprMonitor=o},3236:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.Terminal=void 0;var o=r(2950),s=r(1680),a=r(3614),c=r(2584),l=r(5435),h=r(3525),u=r(3551),f=r(9312),_=r(6114),d=r(3656),p=r(9042),v=r(357),g=r(6954),y=r(4567),b=r(1296),S=r(7399),m=r(8460),C=r(8437),w=r(5680),E=r(3230),L=r(4725),A=r(428),R=r(8934),k=r(6465),x=r(5114),D=r(8969),T=r(4774),O="undefined"!=typeof window?window.document:null,M=function(e){function t(t){void 0===t&&(t={});var r=e.call(this,t)||this;return r.browser=_,r._keyDownHandled=!1,r._onCursorMove=new m.EventEmitter,r._onKey=new m.EventEmitter,r._onRender=new m.EventEmitter,r._onSelectionChange=new m.EventEmitter,r._onTitleChange=new m.EventEmitter,r._onFocus=new m.EventEmitter,r._onBlur=new m.EventEmitter,r._onA11yCharEmitter=new m.EventEmitter,r._onA11yTabEmitter=new m.EventEmitter,r._setup(),r.linkifier=r._instantiationService.createInstance(u.Linkifier),r.linkifier2=r.register(r._instantiationService.createInstance(k.Linkifier2)),r.register(r._inputHandler.onRequestBell((function(){return r.bell()}))),r.register(r._inputHandler.onRequestRefreshRows((function(e,t){return r.refresh(e,t)}))),r.register(r._inputHandler.onRequestReset((function(){return r.reset()}))),r.register(r._inputHandler.onRequestScroll((function(e,t){return r.scroll(e,t||void 0)}))),r.register(r._inputHandler.onRequestWindowsOptionsReport((function(e){return r._reportWindowsOptions(e)}))),r.register(r._inputHandler.onAnsiColorChange((function(e){return r._changeAnsiColor(e)}))),r.register(m.forwardEvent(r._inputHandler.onCursorMove,r._onCursorMove)),r.register(m.forwardEvent(r._inputHandler.onTitleChange,r._onTitleChange)),r.register(m.forwardEvent(r._inputHandler.onA11yChar,r._onA11yCharEmitter)),r.register(m.forwardEvent(r._inputHandler.onA11yTab,r._onA11yTabEmitter)),r.register(r._bufferService.onResize((function(e){return r._afterResize(e.cols,e.rows)}))),r}return n(t,e),Object.defineProperty(t.prototype,"options",{get:function(){return this.optionsService.options},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onCursorMove",{get:function(){return this._onCursorMove.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onKey",{get:function(){return this._onKey.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRender",{get:function(){return this._onRender.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onSelectionChange",{get:function(){return this._onSelectionChange.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onTitleChange",{get:function(){return this._onTitleChange.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onFocus",{get:function(){return this._onFocus.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onBlur",{get:function(){return this._onBlur.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onA11yChar",{get:function(){return this._onA11yCharEmitter.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onA11yTab",{get:function(){return this._onA11yTabEmitter.event},enumerable:!1,configurable:!0}),t.prototype._changeAnsiColor=function(e){var t,r,i=this;this._colorManager&&(e.colors.forEach((function(e){var t=T.rgba.toColor(e.red,e.green,e.blue);i._colorManager.colors.ansi[e.colorIndex]=t})),null===(t=this._renderService)||void 0===t||t.setColors(this._colorManager.colors),null===(r=this.viewport)||void 0===r||r.onThemeChange(this._colorManager.colors))},t.prototype.dispose=function(){var t,r,i;this._isDisposed||(e.prototype.dispose.call(this),null===(t=this._renderService)||void 0===t||t.dispose(),this._customKeyEventHandler=void 0,this.write=function(){},null===(i=null===(r=this.element)||void 0===r?void 0:r.parentNode)||void 0===i||i.removeChild(this.element))},t.prototype._setup=function(){e.prototype._setup.call(this),this._customKeyEventHandler=void 0},Object.defineProperty(t.prototype,"buffer",{get:function(){return this.buffers.active},enumerable:!1,configurable:!0}),t.prototype.focus=function(){this.textarea&&this.textarea.focus({preventScroll:!0})},t.prototype._updateOptions=function(t){var r,i,n,o;switch(e.prototype._updateOptions.call(this,t),t){case"fontFamily":case"fontSize":null===(r=this._renderService)||void 0===r||r.clear(),null===(i=this._charSizeService)||void 0===i||i.measure();break;case"cursorBlink":case"cursorStyle":this.refresh(this.buffer.y,this.buffer.y);break;case"drawBoldTextInBrightColors":case"letterSpacing":case"lineHeight":case"fontWeight":case"fontWeightBold":case"minimumContrastRatio":this._renderService&&(this._renderService.clear(),this._renderService.onResize(this.cols,this.rows),this.refresh(0,this.rows-1));break;case"rendererType":this._renderService&&(this._renderService.setRenderer(this._createRenderer()),this._renderService.onResize(this.cols,this.rows));break;case"scrollback":null===(n=this.viewport)||void 0===n||n.syncScrollArea();break;case"screenReaderMode":this.optionsService.options.screenReaderMode?!this._accessibilityManager&&this._renderService&&(this._accessibilityManager=new y.AccessibilityManager(this,this._renderService)):(null===(o=this._accessibilityManager)||void 0===o||o.dispose(),this._accessibilityManager=void 0);break;case"tabStopWidth":this.buffers.setupTabStops();break;case"theme":this._setTheme(this.optionsService.options.theme)}},t.prototype._onTextAreaFocus=function(e){this._coreService.decPrivateModes.sendFocus&&this._coreService.triggerDataEvent(c.C0.ESC+"[I"),this.updateCursorStyle(e),this.element.classList.add("focus"),this._showCursor(),this._onFocus.fire()},t.prototype.blur=function(){var e;return null===(e=this.textarea)||void 0===e?void 0:e.blur()},t.prototype._onTextAreaBlur=function(){this.textarea.value="",this.refresh(this.buffer.y,this.buffer.y),this._coreService.decPrivateModes.sendFocus&&this._coreService.triggerDataEvent(c.C0.ESC+"[O"),this.element.classList.remove("focus"),this._onBlur.fire()},t.prototype._syncTextArea=function(){if(this.textarea&&this.buffer.isCursorInViewport&&!this._compositionHelper.isComposing){var e=Math.ceil(this._charSizeService.height*this.optionsService.options.lineHeight),t=this._bufferService.buffer.y*e,r=this._bufferService.buffer.x*this._charSizeService.width;this.textarea.style.left=r+"px",this.textarea.style.top=t+"px",this.textarea.style.width=this._charSizeService.width+"px",this.textarea.style.height=e+"px",this.textarea.style.lineHeight=e+"px",this.textarea.style.zIndex="-5"}},t.prototype._initGlobal=function(){var e=this;this._bindKeys(),this.register(d.addDisposableDomListener(this.element,"copy",(function(t){e.hasSelection()&&a.copyHandler(t,e._selectionService)})));var t=function(t){return a.handlePasteEvent(t,e.textarea,e._coreService)};this.register(d.addDisposableDomListener(this.textarea,"paste",t)),this.register(d.addDisposableDomListener(this.element,"paste",t)),_.isFirefox?this.register(d.addDisposableDomListener(this.element,"mousedown",(function(t){2===t.button&&a.rightClickHandler(t,e.textarea,e.screenElement,e._selectionService,e.options.rightClickSelectsWord)}))):this.register(d.addDisposableDomListener(this.element,"contextmenu",(function(t){a.rightClickHandler(t,e.textarea,e.screenElement,e._selectionService,e.options.rightClickSelectsWord)}))),_.isLinux&&this.register(d.addDisposableDomListener(this.element,"auxclick",(function(t){1===t.button&&a.moveTextAreaUnderMouseCursor(t,e.textarea,e.screenElement)})))},t.prototype._bindKeys=function(){var e=this;this.register(d.addDisposableDomListener(this.textarea,"keyup",(function(t){return e._keyUp(t)}),!0)),this.register(d.addDisposableDomListener(this.textarea,"keydown",(function(t){return e._keyDown(t)}),!0)),this.register(d.addDisposableDomListener(this.textarea,"keypress",(function(t){return e._keyPress(t)}),!0)),this.register(d.addDisposableDomListener(this.textarea,"compositionstart",(function(){return e._compositionHelper.compositionstart()}))),this.register(d.addDisposableDomListener(this.textarea,"compositionupdate",(function(t){return e._compositionHelper.compositionupdate(t)}))),this.register(d.addDisposableDomListener(this.textarea,"compositionend",(function(){return e._compositionHelper.compositionend()}))),this.register(this.onRender((function(){return e._compositionHelper.updateCompositionElements()}))),this.register(this.onRender((function(t){return e._queueLinkification(t.start,t.end)})))},t.prototype.open=function(e){var t=this;if(!e)throw new Error("Terminal requires a parent element.");e.isConnected||this._logService.debug("Terminal.open was called on an element that was not attached to the DOM"),this._document=e.ownerDocument,this.element=this._document.createElement("div"),this.element.dir="ltr",this.element.classList.add("terminal"),this.element.classList.add("xterm"),this.element.setAttribute("tabindex","0"),this.element.setAttribute("role","document"),e.appendChild(this.element);var r=O.createDocumentFragment();this._viewportElement=O.createElement("div"),this._viewportElement.classList.add("xterm-viewport"),r.appendChild(this._viewportElement),this._viewportScrollArea=O.createElement("div"),this._viewportScrollArea.classList.add("xterm-scroll-area"),this._viewportElement.appendChild(this._viewportScrollArea),this.screenElement=O.createElement("div"),this.screenElement.classList.add("xterm-screen"),this._helperContainer=O.createElement("div"),this._helperContainer.classList.add("xterm-helpers"),this.screenElement.appendChild(this._helperContainer),r.appendChild(this.screenElement),this.textarea=O.createElement("textarea"),this.textarea.classList.add("xterm-helper-textarea"),this.textarea.setAttribute("aria-label",p.promptLabel),this.textarea.setAttribute("aria-multiline","false"),this.textarea.setAttribute("autocorrect","off"),this.textarea.setAttribute("autocapitalize","off"),this.textarea.setAttribute("spellcheck","false"),this.textarea.tabIndex=0,this.register(d.addDisposableDomListener(this.textarea,"focus",(function(e){return t._onTextAreaFocus(e)}))),this.register(d.addDisposableDomListener(this.textarea,"blur",(function(){return t._onTextAreaBlur()}))),this._helperContainer.appendChild(this.textarea);var i=this._instantiationService.createInstance(x.CoreBrowserService,this.textarea);this._instantiationService.setService(L.ICoreBrowserService,i),this._charSizeService=this._instantiationService.createInstance(A.CharSizeService,this._document,this._helperContainer),this._instantiationService.setService(L.ICharSizeService,this._charSizeService),this._compositionView=O.createElement("div"),this._compositionView.classList.add("composition-view"),this._compositionHelper=this._instantiationService.createInstance(o.CompositionHelper,this.textarea,this._compositionView),this._helperContainer.appendChild(this._compositionView),this.element.appendChild(r),this._theme=this.options.theme||this._theme,this._colorManager=new w.ColorManager(O,this.options.allowTransparency),this.register(this.optionsService.onOptionChange((function(e){return t._colorManager.onOptionsChange(e)}))),this._colorManager.setTheme(this._theme);var n=this._createRenderer();this._renderService=this.register(this._instantiationService.createInstance(E.RenderService,n,this.rows,this.screenElement)),this._instantiationService.setService(L.IRenderService,this._renderService),this.register(this._renderService.onRenderedBufferChange((function(e){return t._onRender.fire(e)}))),this.onResize((function(e){return t._renderService.resize(e.cols,e.rows)})),this._soundService=this._instantiationService.createInstance(v.SoundService),this._instantiationService.setService(L.ISoundService,this._soundService),this._mouseService=this._instantiationService.createInstance(R.MouseService),this._instantiationService.setService(L.IMouseService,this._mouseService),this.viewport=this._instantiationService.createInstance(s.Viewport,(function(e,r){return t.scrollLines(e,r)}),this._viewportElement,this._viewportScrollArea),this.viewport.onThemeChange(this._colorManager.colors),this.register(this._inputHandler.onRequestSyncScrollBar((function(){return t.viewport.syncScrollArea()}))),this.register(this.viewport),this.register(this.onCursorMove((function(){t._renderService.onCursorMove(),t._syncTextArea()}))),this.register(this.onResize((function(){return t._renderService.onResize(t.cols,t.rows)}))),this.register(this.onBlur((function(){return t._renderService.onBlur()}))),this.register(this.onFocus((function(){return t._renderService.onFocus()}))),this.register(this._renderService.onDimensionsChange((function(){return t.viewport.syncScrollArea()}))),this._selectionService=this.register(this._instantiationService.createInstance(f.SelectionService,this.element,this.screenElement)),this._instantiationService.setService(L.ISelectionService,this._selectionService),this.register(this._selectionService.onRequestScrollLines((function(e){return t.scrollLines(e.amount,e.suppressScrollEvent)}))),this.register(this._selectionService.onSelectionChange((function(){return t._onSelectionChange.fire()}))),this.register(this._selectionService.onRequestRedraw((function(e){return t._renderService.onSelectionChanged(e.start,e.end,e.columnSelectMode)}))),this.register(this._selectionService.onLinuxMouseSelection((function(e){t.textarea.value=e,t.textarea.focus(),t.textarea.select()}))),this.register(this.onScroll((function(){t.viewport.syncScrollArea(),t._selectionService.refresh()}))),this.register(d.addDisposableDomListener(this._viewportElement,"scroll",(function(){return t._selectionService.refresh()}))),this._mouseZoneManager=this._instantiationService.createInstance(g.MouseZoneManager,this.element,this.screenElement),this.register(this._mouseZoneManager),this.register(this.onScroll((function(){return t._mouseZoneManager.clearAll()}))),this.linkifier.attachToDom(this.element,this._mouseZoneManager),this.linkifier2.attachToDom(this.element,this._mouseService,this._renderService),this.register(d.addDisposableDomListener(this.element,"mousedown",(function(e){return t._selectionService.onMouseDown(e)}))),this._coreMouseService.areMouseEventsActive?(this._selectionService.disable(),this.element.classList.add("enable-mouse-events")):this._selectionService.enable(),this.options.screenReaderMode&&(this._accessibilityManager=new y.AccessibilityManager(this,this._renderService)),this._charSizeService.measure(),this.refresh(0,this.rows-1),this._initGlobal(),this.bindMouse()},t.prototype._createRenderer=function(){switch(this.options.rendererType){case"canvas":return this._instantiationService.createInstance(h.Renderer,this._colorManager.colors,this.screenElement,this.linkifier,this.linkifier2);case"dom":return this._instantiationService.createInstance(b.DomRenderer,this._colorManager.colors,this.element,this.screenElement,this._viewportElement,this.linkifier,this.linkifier2);default:throw new Error('Unrecognized rendererType "'+this.options.rendererType+'"')}},t.prototype._setTheme=function(e){var t,r,i;this._theme=e,null===(t=this._colorManager)||void 0===t||t.setTheme(e),null===(r=this._renderService)||void 0===r||r.setColors(this._colorManager.colors),null===(i=this.viewport)||void 0===i||i.onThemeChange(this._colorManager.colors)},t.prototype.bindMouse=function(){var e=this,t=this,r=this.element;function i(e){var r,i,n=t._mouseService.getRawByteCoords(e,t.screenElement,t.cols,t.rows);if(!n)return!1;switch(e.overrideType||e.type){case"mousemove":i=32,void 0===e.buttons?(r=3,void 0!==e.button&&(r=e.button<3?e.button:3)):r=1&e.buttons?0:4&e.buttons?1:2&e.buttons?2:3;break;case"mouseup":i=0,r=e.button<3?e.button:3;break;case"mousedown":i=1,r=e.button<3?e.button:3;break;case"wheel":0!==e.deltaY&&(i=e.deltaY<0?0:1),r=4;break;default:return!1}return!(void 0===i||void 0===r||r>4)&&t._coreMouseService.triggerMouseEvent({col:n.x-33,row:n.y-33,button:r,action:i,ctrl:e.ctrlKey,alt:e.altKey,shift:e.shiftKey})}var n={mouseup:null,wheel:null,mousedrag:null,mousemove:null},o=function(t){return i(t),t.buttons||(e._document.removeEventListener("mouseup",n.mouseup),n.mousedrag&&e._document.removeEventListener("mousemove",n.mousedrag)),e.cancel(t)},s=function(t){return i(t),t.preventDefault(),e.cancel(t)},a=function(e){e.buttons&&i(e)},l=function(e){e.buttons||i(e)};this.register(this._coreMouseService.onProtocolChange((function(t){t?("debug"===e.optionsService.options.logLevel&&e._logService.debug("Binding to mouse events:",e._coreMouseService.explainEvents(t)),e.element.classList.add("enable-mouse-events"),e._selectionService.disable()):(e._logService.debug("Unbinding from mouse events."),e.element.classList.remove("enable-mouse-events"),e._selectionService.enable()),8&t?n.mousemove||(r.addEventListener("mousemove",l),n.mousemove=l):(r.removeEventListener("mousemove",n.mousemove),n.mousemove=null),16&t?n.wheel||(r.addEventListener("wheel",s,{passive:!1}),n.wheel=s):(r.removeEventListener("wheel",n.wheel),n.wheel=null),2&t?n.mouseup||(n.mouseup=o):(e._document.removeEventListener("mouseup",n.mouseup),n.mouseup=null),4&t?n.mousedrag||(n.mousedrag=a):(e._document.removeEventListener("mousemove",n.mousedrag),n.mousedrag=null)}))),this._coreMouseService.activeProtocol=this._coreMouseService.activeProtocol,this.register(d.addDisposableDomListener(r,"mousedown",(function(t){if(t.preventDefault(),e.focus(),e._coreMouseService.areMouseEventsActive&&!e._selectionService.shouldForceSelection(t))return i(t),n.mouseup&&e._document.addEventListener("mouseup",n.mouseup),n.mousedrag&&e._document.addEventListener("mousemove",n.mousedrag),e.cancel(t)}))),this.register(d.addDisposableDomListener(r,"wheel",(function(t){if(n.wheel);else if(!e.buffer.hasScrollback){var r=e.viewport.getLinesScrolled(t);if(0===r)return;for(var i=c.C0.ESC+(e._coreService.decPrivateModes.applicationCursorKeys?"O":"[")+(t.deltaY<0?"A":"B"),o="",s=0;s47)},t.prototype._keyUp=function(e){this._customKeyEventHandler&&!1===this._customKeyEventHandler(e)||(function(e){return 16===e.keyCode||17===e.keyCode||18===e.keyCode}(e)||this.focus(),this.updateCursorStyle(e))},t.prototype._keyPress=function(e){var t;if(this._keyDownHandled)return!1;if(this._customKeyEventHandler&&!1===this._customKeyEventHandler(e))return!1;if(this.cancel(e),e.charCode)t=e.charCode;else if(null===e.which||void 0===e.which)t=e.keyCode;else{if(0===e.which||0===e.charCode)return!1;t=e.which}return!(!t||(e.altKey||e.ctrlKey||e.metaKey)&&!this._isThirdLevelShift(this.browser,e)||(t=String.fromCharCode(t),this._onKey.fire({key:t,domEvent:e}),this._showCursor(),this._coreService.triggerDataEvent(t,!0),0))},t.prototype.bell=function(){this._soundBell()&&this._soundService.playBellSound()},t.prototype.resize=function(t,r){t!==this.cols||r!==this.rows?e.prototype.resize.call(this,t,r):this._charSizeService&&!this._charSizeService.hasValidSize&&this._charSizeService.measure()},t.prototype._afterResize=function(e,t){var r,i;null===(r=this._charSizeService)||void 0===r||r.measure(),null===(i=this.viewport)||void 0===i||i.syncScrollArea(!0)},t.prototype.clear=function(){if(0!==this.buffer.ybase||0!==this.buffer.y){this.buffer.lines.set(0,this.buffer.lines.get(this.buffer.ybase+this.buffer.y)),this.buffer.lines.length=1,this.buffer.ydisp=0,this.buffer.ybase=0,this.buffer.y=0;for(var e=1;e=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},s=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.Viewport=void 0;var a=r(844),c=r(3656),l=r(4725),h=r(2585),u=function(e){function t(t,r,i,n,o,s,a){var l=e.call(this)||this;return l._scrollLines=t,l._viewportElement=r,l._scrollArea=i,l._bufferService=n,l._optionsService=o,l._charSizeService=s,l._renderService=a,l.scrollBarWidth=0,l._currentRowHeight=0,l._lastRecordedBufferLength=0,l._lastRecordedViewportHeight=0,l._lastRecordedBufferHeight=0,l._lastTouchY=0,l._lastScrollTop=0,l._wheelPartialScroll=0,l._refreshAnimationFrame=null,l._ignoreNextScrollEvent=!1,l.scrollBarWidth=l._viewportElement.offsetWidth-l._scrollArea.offsetWidth||15,l.register(c.addDisposableDomListener(l._viewportElement,"scroll",l._onScroll.bind(l))),setTimeout((function(){return l.syncScrollArea()}),0),l}return n(t,e),t.prototype.onThemeChange=function(e){this._viewportElement.style.backgroundColor=e.background.css},t.prototype._refresh=function(e){var t=this;if(e)return this._innerRefresh(),void(null!==this._refreshAnimationFrame&&cancelAnimationFrame(this._refreshAnimationFrame));null===this._refreshAnimationFrame&&(this._refreshAnimationFrame=requestAnimationFrame((function(){return t._innerRefresh()})))},t.prototype._innerRefresh=function(){if(this._charSizeService.height>0){this._currentRowHeight=this._renderService.dimensions.scaledCellHeight/window.devicePixelRatio,this._lastRecordedViewportHeight=this._viewportElement.offsetHeight;var e=Math.round(this._currentRowHeight*this._lastRecordedBufferLength)+(this._lastRecordedViewportHeight-this._renderService.dimensions.canvasHeight);this._lastRecordedBufferHeight!==e&&(this._lastRecordedBufferHeight=e,this._scrollArea.style.height=this._lastRecordedBufferHeight+"px")}var t=this._bufferService.buffer.ydisp*this._currentRowHeight;this._viewportElement.scrollTop!==t&&(this._ignoreNextScrollEvent=!0,this._viewportElement.scrollTop=t),this._refreshAnimationFrame=null},t.prototype.syncScrollArea=function(e){if(void 0===e&&(e=!1),this._lastRecordedBufferLength!==this._bufferService.buffer.lines.length)return this._lastRecordedBufferLength=this._bufferService.buffer.lines.length,void this._refresh(e);if(this._lastRecordedViewportHeight===this._renderService.dimensions.canvasHeight){var t=this._bufferService.buffer.ydisp*this._currentRowHeight;this._lastScrollTop===t&&this._lastScrollTop===this._viewportElement.scrollTop&&this._renderService.dimensions.scaledCellHeight/window.devicePixelRatio===this._currentRowHeight||this._refresh(e)}else this._refresh(e)},t.prototype._onScroll=function(e){if(this._lastScrollTop=this._viewportElement.scrollTop,this._viewportElement.offsetParent)if(this._ignoreNextScrollEvent)this._ignoreNextScrollEvent=!1;else{var t=Math.round(this._lastScrollTop/this._currentRowHeight)-this._bufferService.buffer.ydisp;this._scrollLines(t,!0)}},t.prototype._bubbleScroll=function(e,t){var r=this._viewportElement.scrollTop+this._lastRecordedViewportHeight;return!(t<0&&0!==this._viewportElement.scrollTop||t>0&&r0?1:-1),this._wheelPartialScroll%=1):e.deltaMode===WheelEvent.DOM_DELTA_PAGE&&(t*=this._bufferService.rows),t},t.prototype._applyScrollModifier=function(e,t){var r=this._optionsService.options.fastScrollModifier;return"alt"===r&&t.altKey||"ctrl"===r&&t.ctrlKey||"shift"===r&&t.shiftKey?e*this._optionsService.options.fastScrollSensitivity*this._optionsService.options.scrollSensitivity:e*this._optionsService.options.scrollSensitivity},t.prototype.onTouchStart=function(e){this._lastTouchY=e.touches[0].pageY},t.prototype.onTouchMove=function(e){var t=this._lastTouchY-e.touches[0].pageY;return this._lastTouchY=e.touches[0].pageY,0!==t&&(this._viewportElement.scrollTop+=t,this._bubbleScroll(e,t))},o([s(3,h.IBufferService),s(4,h.IOptionsService),s(5,l.ICharSizeService),s(6,l.IRenderService)],t)}(a.Disposable);t.Viewport=u},2950:function(e,t,r){var i=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},n=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.CompositionHelper=void 0;var o=r(4725),s=r(2585),a=function(){function e(e,t,r,i,n,o){this._textarea=e,this._compositionView=t,this._bufferService=r,this._optionsService=i,this._charSizeService=n,this._coreService=o,this._isComposing=!1,this._isSendingComposition=!1,this._compositionPosition={start:0,end:0},this._dataAlreadySent=""}return Object.defineProperty(e.prototype,"isComposing",{get:function(){return this._isComposing},enumerable:!1,configurable:!0}),e.prototype.compositionstart=function(){this._isComposing=!0,this._compositionPosition.start=this._textarea.value.length,this._compositionView.textContent="",this._dataAlreadySent="",this._compositionView.classList.add("active")},e.prototype.compositionupdate=function(e){var t=this;this._compositionView.textContent=e.data,this.updateCompositionElements(),setTimeout((function(){t._compositionPosition.end=t._textarea.value.length}),0)},e.prototype.compositionend=function(){this._finalizeComposition(!0)},e.prototype.keydown=function(e){if(this._isComposing||this._isSendingComposition){if(229===e.keyCode)return!1;if(16===e.keyCode||17===e.keyCode||18===e.keyCode)return!1;this._finalizeComposition(!1)}return 229!==e.keyCode||(this._handleAnyTextareaChanges(),!1)},e.prototype._finalizeComposition=function(e){var t=this;if(this._compositionView.classList.remove("active"),this._isComposing=!1,e){var r={start:this._compositionPosition.start,end:this._compositionPosition.end};this._isSendingComposition=!0,setTimeout((function(){if(t._isSendingComposition){t._isSendingComposition=!1;var e;r.start+=t._dataAlreadySent.length,(e=t._isComposing?t._textarea.value.substring(r.start,r.end):t._textarea.value.substring(r.start)).length>0&&t._coreService.triggerDataEvent(e,!0)}}),0)}else{this._isSendingComposition=!1;var i=this._textarea.value.substring(this._compositionPosition.start,this._compositionPosition.end);this._coreService.triggerDataEvent(i,!0)}},e.prototype._handleAnyTextareaChanges=function(){var e=this,t=this._textarea.value;setTimeout((function(){if(!e._isComposing){var r=e._textarea.value.replace(t,"");r.length>0&&(e._dataAlreadySent=r,e._coreService.triggerDataEvent(r,!0))}}),0)},e.prototype.updateCompositionElements=function(e){var t=this;if(this._isComposing){if(this._bufferService.buffer.isCursorInViewport){var r=Math.ceil(this._charSizeService.height*this._optionsService.options.lineHeight),i=this._bufferService.buffer.y*r,n=this._bufferService.buffer.x*this._charSizeService.width;this._compositionView.style.left=n+"px",this._compositionView.style.top=i+"px",this._compositionView.style.height=r+"px",this._compositionView.style.lineHeight=r+"px",this._compositionView.style.fontFamily=this._optionsService.options.fontFamily,this._compositionView.style.fontSize=this._optionsService.options.fontSize+"px";var o=this._compositionView.getBoundingClientRect();this._textarea.style.left=n+"px",this._textarea.style.top=i+"px",this._textarea.style.width=o.width+"px",this._textarea.style.height=o.height+"px",this._textarea.style.lineHeight=o.height+"px"}e||setTimeout((function(){return t.updateCompositionElements(!0)}),0)}},i([n(2,s.IBufferService),n(3,s.IOptionsService),n(4,o.ICharSizeService),n(5,s.ICoreService)],e)}();t.CompositionHelper=a},9806:(e,t)=>{function r(e,t){var r=t.getBoundingClientRect();return[e.clientX-r.left,e.clientY-r.top]}Object.defineProperty(t,"__esModule",{value:!0}),t.getRawByteCoords=t.getCoords=t.getCoordsRelativeToElement=void 0,t.getCoordsRelativeToElement=r,t.getCoords=function(e,t,i,n,o,s,a,c){if(o){var l=r(e,t);if(l)return l[0]=Math.ceil((l[0]+(c?s/2:0))/s),l[1]=Math.ceil(l[1]/a),l[0]=Math.min(Math.max(l[0],1),i+(c?1:0)),l[1]=Math.min(Math.max(l[1],1),n),l}},t.getRawByteCoords=function(e){if(e)return{x:e[0]+32,y:e[1]+32}}},9504:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.moveToCellSequence=void 0;var i=r(2584);function n(e,t,r,i){var n=e-o(r,e),a=t-o(r,t);return l(Math.abs(n-a)-function(e,t,r){for(var i=0,n=e-o(r,e),a=t-o(r,t),c=0;c=0&&tt?"A":"B"}function a(e,t,r,i,n,o){for(var s=e,a=t,c="";s!==r||a!==i;)s+=n?1:-1,n&&s>o.cols-1?(c+=o.buffer.translateBufferLineToString(a,!1,e,s),s=0,e=0,a++):!n&&s<0&&(c+=o.buffer.translateBufferLineToString(a,!1,0,e+1),e=s=o.cols-1,a--);return c+o.buffer.translateBufferLineToString(a,!1,e,s)}function c(e,t){var r=t?"O":"[";return i.C0.ESC+r+e}function l(e,t){e=Math.floor(e);for(var r="",i=0;i0?i-o(s,i):t;var f=i,_=function(e,t,r,i,s,a){var c;return c=n(r,i,s,a).length>0?i-o(s,i):t,e=r&&ce?"D":"C",l(Math.abs(h-e),c(s,i));s=u>t?"D":"C";var f=Math.abs(u-t);return l(function(e,t){return t.cols-e}(u>t?e:h,r)+(f-1)*r.cols+1+((u>t?h:e)-1),c(s,i))}},244:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.AddonManager=void 0;var r=function(){function e(){this._addons=[]}return e.prototype.dispose=function(){for(var e=this._addons.length-1;e>=0;e--)this._addons[e].instance.dispose()},e.prototype.loadAddon=function(e,t){var r=this,i={instance:t,dispose:t.dispose,isDisposed:!1};this._addons.push(i),t.dispose=function(){return r._wrappedAddonDispose(i)},t.activate(e)},e.prototype._wrappedAddonDispose=function(e){if(!e.isDisposed){for(var t=-1,r=0;r{Object.defineProperty(t,"__esModule",{value:!0}),t.Terminal=void 0;var i=r(511),n=r(3236),o=r(9042),s=r(8460),a=r(244),c=function(){function e(e){this._core=new n.Terminal(e),this._addonManager=new a.AddonManager}return e.prototype._checkProposedApi=function(){if(!this._core.optionsService.options.allowProposedApi)throw new Error("You must set the allowProposedApi option to true to use proposed API")},Object.defineProperty(e.prototype,"onCursorMove",{get:function(){return this._core.onCursorMove},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onLineFeed",{get:function(){return this._core.onLineFeed},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onSelectionChange",{get:function(){return this._core.onSelectionChange},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onData",{get:function(){return this._core.onData},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onBinary",{get:function(){return this._core.onBinary},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onTitleChange",{get:function(){return this._core.onTitleChange},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onScroll",{get:function(){return this._core.onScroll},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onKey",{get:function(){return this._core.onKey},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onRender",{get:function(){return this._core.onRender},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onResize",{get:function(){return this._core.onResize},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"element",{get:function(){return this._core.element},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"parser",{get:function(){return this._checkProposedApi(),this._parser||(this._parser=new f(this._core)),this._parser},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"unicode",{get:function(){return this._checkProposedApi(),new _(this._core)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"textarea",{get:function(){return this._core.textarea},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"rows",{get:function(){return this._core.rows},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"cols",{get:function(){return this._core.cols},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"buffer",{get:function(){return this._checkProposedApi(),this._buffer||(this._buffer=new h(this._core)),this._buffer},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"markers",{get:function(){return this._checkProposedApi(),this._core.markers},enumerable:!1,configurable:!0}),e.prototype.blur=function(){this._core.blur()},e.prototype.focus=function(){this._core.focus()},e.prototype.resize=function(e,t){this._verifyIntegers(e,t),this._core.resize(e,t)},e.prototype.open=function(e){this._core.open(e)},e.prototype.attachCustomKeyEventHandler=function(e){this._core.attachCustomKeyEventHandler(e)},e.prototype.registerLinkMatcher=function(e,t,r){return this._checkProposedApi(),this._core.registerLinkMatcher(e,t,r)},e.prototype.deregisterLinkMatcher=function(e){this._checkProposedApi(),this._core.deregisterLinkMatcher(e)},e.prototype.registerLinkProvider=function(e){return this._checkProposedApi(),this._core.registerLinkProvider(e)},e.prototype.registerCharacterJoiner=function(e){return this._checkProposedApi(),this._core.registerCharacterJoiner(e)},e.prototype.deregisterCharacterJoiner=function(e){this._checkProposedApi(),this._core.deregisterCharacterJoiner(e)},e.prototype.registerMarker=function(e){return this._checkProposedApi(),this._verifyIntegers(e),this._core.addMarker(e)},e.prototype.addMarker=function(e){return this.registerMarker(e)},e.prototype.hasSelection=function(){return this._core.hasSelection()},e.prototype.select=function(e,t,r){this._verifyIntegers(e,t,r),this._core.select(e,t,r)},e.prototype.getSelection=function(){return this._core.getSelection()},e.prototype.getSelectionPosition=function(){return this._core.getSelectionPosition()},e.prototype.clearSelection=function(){this._core.clearSelection()},e.prototype.selectAll=function(){this._core.selectAll()},e.prototype.selectLines=function(e,t){this._verifyIntegers(e,t),this._core.selectLines(e,t)},e.prototype.dispose=function(){this._addonManager.dispose(),this._core.dispose()},e.prototype.scrollLines=function(e){this._verifyIntegers(e),this._core.scrollLines(e)},e.prototype.scrollPages=function(e){this._verifyIntegers(e),this._core.scrollPages(e)},e.prototype.scrollToTop=function(){this._core.scrollToTop()},e.prototype.scrollToBottom=function(){this._core.scrollToBottom()},e.prototype.scrollToLine=function(e){this._verifyIntegers(e),this._core.scrollToLine(e)},e.prototype.clear=function(){this._core.clear()},e.prototype.write=function(e,t){this._core.write(e,t)},e.prototype.writeUtf8=function(e,t){this._core.write(e,t)},e.prototype.writeln=function(e,t){this._core.write(e),this._core.write("\r\n",t)},e.prototype.paste=function(e){this._core.paste(e)},e.prototype.getOption=function(e){return this._core.optionsService.getOption(e)},e.prototype.setOption=function(e,t){this._core.optionsService.setOption(e,t)},e.prototype.refresh=function(e,t){this._verifyIntegers(e,t),this._core.refresh(e,t)},e.prototype.reset=function(){this._core.reset()},e.prototype.loadAddon=function(e){return this._addonManager.loadAddon(this,e)},Object.defineProperty(e,"strings",{get:function(){return o},enumerable:!1,configurable:!0}),e.prototype._verifyIntegers=function(){for(var e=[],t=0;t=this._line.length))return t?(this._line.loadCell(e,t),t):this._line.loadCell(e,new i.CellData)},e.prototype.translateToString=function(e,t,r){return this._line.translateToString(e,t,r)},e}(),f=function(){function e(e){this._core=e}return e.prototype.registerCsiHandler=function(e,t){return this._core.addCsiHandler(e,(function(e){return t(e.toArray())}))},e.prototype.addCsiHandler=function(e,t){return this.registerCsiHandler(e,t)},e.prototype.registerDcsHandler=function(e,t){return this._core.addDcsHandler(e,(function(e,r){return t(e,r.toArray())}))},e.prototype.addDcsHandler=function(e,t){return this.registerDcsHandler(e,t)},e.prototype.registerEscHandler=function(e,t){return this._core.addEscHandler(e,t)},e.prototype.addEscHandler=function(e,t){return this.registerEscHandler(e,t)},e.prototype.registerOscHandler=function(e,t){return this._core.addOscHandler(e,t)},e.prototype.addOscHandler=function(e,t){return this.registerOscHandler(e,t)},e}(),_=function(){function e(e){this._core=e}return e.prototype.register=function(e){this._core.unicodeService.register(e)},Object.defineProperty(e.prototype,"versions",{get:function(){return this._core.unicodeService.versions},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"activeVersion",{get:function(){return this._core.unicodeService.activeVersion},set:function(e){this._core.unicodeService.activeVersion=e},enumerable:!1,configurable:!0}),e}()},1546:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.BaseRenderLayer=void 0;var i=r(643),n=r(8803),o=r(1420),s=r(3734),a=r(1752),c=r(4774),l=r(9631),h=function(){function e(e,t,r,i,n,o,s,a){this._container=e,this._alpha=i,this._colors=n,this._rendererId=o,this._bufferService=s,this._optionsService=a,this._scaledCharWidth=0,this._scaledCharHeight=0,this._scaledCellWidth=0,this._scaledCellHeight=0,this._scaledCharLeft=0,this._scaledCharTop=0,this._currentGlyphIdentifier={chars:"",code:0,bg:0,fg:0,bold:!1,dim:!1,italic:!1},this._canvas=document.createElement("canvas"),this._canvas.classList.add("xterm-"+t+"-layer"),this._canvas.style.zIndex=r.toString(),this._initCanvas(),this._container.appendChild(this._canvas)}return e.prototype.dispose=function(){var e;l.removeElementFromParent(this._canvas),null===(e=this._charAtlas)||void 0===e||e.dispose()},e.prototype._initCanvas=function(){this._ctx=a.throwIfFalsy(this._canvas.getContext("2d",{alpha:this._alpha})),this._alpha||this._clearAll()},e.prototype.onOptionsChanged=function(){},e.prototype.onBlur=function(){},e.prototype.onFocus=function(){},e.prototype.onCursorMove=function(){},e.prototype.onGridChanged=function(e,t){},e.prototype.onSelectionChanged=function(e,t,r){void 0===r&&(r=!1)},e.prototype.setColors=function(e){this._refreshCharAtlas(e)},e.prototype._setTransparency=function(e){if(e!==this._alpha){var t=this._canvas;this._alpha=e,this._canvas=this._canvas.cloneNode(),this._initCanvas(),this._container.replaceChild(this._canvas,t),this._refreshCharAtlas(this._colors),this.onGridChanged(0,this._bufferService.rows-1)}},e.prototype._refreshCharAtlas=function(e){this._scaledCharWidth<=0&&this._scaledCharHeight<=0||(this._charAtlas=o.acquireCharAtlas(this._optionsService.options,this._rendererId,e,this._scaledCharWidth,this._scaledCharHeight),this._charAtlas.warmUp())},e.prototype.resize=function(e){this._scaledCellWidth=e.scaledCellWidth,this._scaledCellHeight=e.scaledCellHeight,this._scaledCharWidth=e.scaledCharWidth,this._scaledCharHeight=e.scaledCharHeight,this._scaledCharLeft=e.scaledCharLeft,this._scaledCharTop=e.scaledCharTop,this._canvas.width=e.scaledCanvasWidth,this._canvas.height=e.scaledCanvasHeight,this._canvas.style.width=e.canvasWidth+"px",this._canvas.style.height=e.canvasHeight+"px",this._alpha||this._clearAll(),this._refreshCharAtlas(this._colors)},e.prototype._fillCells=function(e,t,r,i){this._ctx.fillRect(e*this._scaledCellWidth,t*this._scaledCellHeight,r*this._scaledCellWidth,i*this._scaledCellHeight)},e.prototype._fillBottomLineAtCells=function(e,t,r){void 0===r&&(r=1),this._ctx.fillRect(e*this._scaledCellWidth,(t+1)*this._scaledCellHeight-window.devicePixelRatio-1,r*this._scaledCellWidth,window.devicePixelRatio)},e.prototype._fillLeftLineAtCell=function(e,t,r){this._ctx.fillRect(e*this._scaledCellWidth,t*this._scaledCellHeight,window.devicePixelRatio*r,this._scaledCellHeight)},e.prototype._strokeRectAtCell=function(e,t,r,i){this._ctx.lineWidth=window.devicePixelRatio,this._ctx.strokeRect(e*this._scaledCellWidth+window.devicePixelRatio/2,t*this._scaledCellHeight+window.devicePixelRatio/2,r*this._scaledCellWidth-window.devicePixelRatio,i*this._scaledCellHeight-window.devicePixelRatio)},e.prototype._clearAll=function(){this._alpha?this._ctx.clearRect(0,0,this._canvas.width,this._canvas.height):(this._ctx.fillStyle=this._colors.background.css,this._ctx.fillRect(0,0,this._canvas.width,this._canvas.height))},e.prototype._clearCells=function(e,t,r,i){this._alpha?this._ctx.clearRect(e*this._scaledCellWidth,t*this._scaledCellHeight,r*this._scaledCellWidth,i*this._scaledCellHeight):(this._ctx.fillStyle=this._colors.background.css,this._ctx.fillRect(e*this._scaledCellWidth,t*this._scaledCellHeight,r*this._scaledCellWidth,i*this._scaledCellHeight))},e.prototype._fillCharTrueColor=function(e,t,r){this._ctx.font=this._getFont(!1,!1),this._ctx.textBaseline="middle",this._clipRow(r),this._ctx.fillText(e.getChars(),t*this._scaledCellWidth+this._scaledCharLeft,r*this._scaledCellHeight+this._scaledCharTop+this._scaledCharHeight/2)},e.prototype._drawChars=function(e,t,r){var o,s,a=this._getContrastColor(e);a||e.isFgRGB()||e.isBgRGB()?this._drawUncachedChars(e,t,r,a):(e.isInverse()?(o=e.isBgDefault()?n.INVERTED_DEFAULT_COLOR:e.getBgColor(),s=e.isFgDefault()?n.INVERTED_DEFAULT_COLOR:e.getFgColor()):(s=e.isBgDefault()?i.DEFAULT_COLOR:e.getBgColor(),o=e.isFgDefault()?i.DEFAULT_COLOR:e.getFgColor()),o+=this._optionsService.options.drawBoldTextInBrightColors&&e.isBold()&&o<8?8:0,this._currentGlyphIdentifier.chars=e.getChars()||i.WHITESPACE_CELL_CHAR,this._currentGlyphIdentifier.code=e.getCode()||i.WHITESPACE_CELL_CODE,this._currentGlyphIdentifier.bg=s,this._currentGlyphIdentifier.fg=o,this._currentGlyphIdentifier.bold=!!e.isBold(),this._currentGlyphIdentifier.dim=!!e.isDim(),this._currentGlyphIdentifier.italic=!!e.isItalic(),this._charAtlas&&this._charAtlas.draw(this._ctx,this._currentGlyphIdentifier,t*this._scaledCellWidth+this._scaledCharLeft,r*this._scaledCellHeight+this._scaledCharTop)||this._drawUncachedChars(e,t,r))},e.prototype._drawUncachedChars=function(e,t,r,i){if(this._ctx.save(),this._ctx.font=this._getFont(!!e.isBold(),!!e.isItalic()),this._ctx.textBaseline="middle",e.isInverse())if(i)this._ctx.fillStyle=i.css;else if(e.isBgDefault())this._ctx.fillStyle=c.color.opaque(this._colors.background).css;else if(e.isBgRGB())this._ctx.fillStyle="rgb("+s.AttributeData.toColorRGB(e.getBgColor()).join(",")+")";else{var o=e.getBgColor();this._optionsService.options.drawBoldTextInBrightColors&&e.isBold()&&o<8&&(o+=8),this._ctx.fillStyle=this._colors.ansi[o].css}else if(i)this._ctx.fillStyle=i.css;else if(e.isFgDefault())this._ctx.fillStyle=this._colors.foreground.css;else if(e.isFgRGB())this._ctx.fillStyle="rgb("+s.AttributeData.toColorRGB(e.getFgColor()).join(",")+")";else{var a=e.getFgColor();this._optionsService.options.drawBoldTextInBrightColors&&e.isBold()&&a<8&&(a+=8),this._ctx.fillStyle=this._colors.ansi[a].css}this._clipRow(r),e.isDim()&&(this._ctx.globalAlpha=n.DIM_OPACITY),this._ctx.fillText(e.getChars(),t*this._scaledCellWidth+this._scaledCharLeft,r*this._scaledCellHeight+this._scaledCharTop+this._scaledCharHeight/2),this._ctx.restore()},e.prototype._clipRow=function(e){this._ctx.beginPath(),this._ctx.rect(0,e*this._scaledCellHeight,this._bufferService.cols*this._scaledCellWidth,this._scaledCellHeight),this._ctx.clip()},e.prototype._getFont=function(e,t){return(t?"italic":"")+" "+(e?this._optionsService.options.fontWeightBold:this._optionsService.options.fontWeight)+" "+this._optionsService.options.fontSize*window.devicePixelRatio+"px "+this._optionsService.options.fontFamily},e.prototype._getContrastColor=function(e){if(1!==this._optionsService.options.minimumContrastRatio){var t=this._colors.contrastCache.getColor(e.bg,e.fg);if(void 0!==t)return t||void 0;var r=e.getFgColor(),i=e.getFgColorMode(),n=e.getBgColor(),o=e.getBgColorMode(),s=!!e.isInverse(),a=!!e.isInverse();if(s){var l=r;r=n,n=l;var h=i;i=o,o=h}var u=this._resolveBackgroundRgba(o,n,s),f=this._resolveForegroundRgba(i,r,s,a),_=c.rgba.ensureContrastRatio(u,f,this._optionsService.options.minimumContrastRatio);if(_){var d={css:c.channels.toCss(_>>24&255,_>>16&255,_>>8&255),rgba:_};return this._colors.contrastCache.setColor(e.bg,e.fg,d),d}this._colors.contrastCache.setColor(e.bg,e.fg,null)}},e.prototype._resolveBackgroundRgba=function(e,t,r){switch(e){case 16777216:case 33554432:return this._colors.ansi[t].rgba;case 50331648:return t<<8;case 0:default:return r?this._colors.foreground.rgba:this._colors.background.rgba}},e.prototype._resolveForegroundRgba=function(e,t,r,i){switch(e){case 16777216:case 33554432:return this._optionsService.options.drawBoldTextInBrightColors&&i&&t<8&&(t+=8),this._colors.ansi[t].rgba;case 50331648:return t<<8;case 0:default:return r?this._colors.background.rgba:this._colors.foreground.rgba}},e}();t.BaseRenderLayer=h},5879:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.CharacterJoinerRegistry=t.JoinedCellData=void 0;var o=r(3734),s=r(643),a=r(511),c=function(e){function t(t,r,i){var n=e.call(this)||this;return n.content=0,n.combinedData="",n.fg=t.fg,n.bg=t.bg,n.combinedData=r,n._width=i,n}return n(t,e),t.prototype.isCombined=function(){return 2097152},t.prototype.getWidth=function(){return this._width},t.prototype.getChars=function(){return this.combinedData},t.prototype.getCode=function(){return 2097151},t.prototype.setFromCharData=function(e){throw new Error("not implemented")},t.prototype.getAsCharData=function(){return[this.fg,this.getChars(),this.getWidth(),this.getCode()]},t}(o.AttributeData);t.JoinedCellData=c;var l=function(){function e(e){this._bufferService=e,this._characterJoiners=[],this._nextCharacterJoinerId=0,this._workCell=new a.CellData}return e.prototype.registerCharacterJoiner=function(e){var t={id:this._nextCharacterJoinerId++,handler:e};return this._characterJoiners.push(t),t.id},e.prototype.deregisterCharacterJoiner=function(e){for(var t=0;t1)for(var u=this._getJoinedRanges(i,a,o,t,n),f=0;f1)for(u=this._getJoinedRanges(i,a,o,t,n),f=0;f=this._bufferService.rows)this._clearCursor();else{var i=Math.min(this._bufferService.buffer.x,this._bufferService.cols-1);if(this._bufferService.buffer.lines.get(t).loadCell(i,this._cell),void 0!==this._cell.content){if(!this._coreBrowserService.isFocused){this._clearCursor(),this._ctx.save(),this._ctx.fillStyle=this._colors.cursor.css;var n=this._optionsService.options.cursorStyle;return n&&"block"!==n?this._cursorRenderers[n](i,r,this._cell):this._renderBlurCursor(i,r,this._cell),this._ctx.restore(),this._state.x=i,this._state.y=r,this._state.isFocused=!1,this._state.style=n,void(this._state.width=this._cell.getWidth())}if(!this._cursorBlinkStateManager||this._cursorBlinkStateManager.isCursorVisible){if(this._state){if(this._state.x===i&&this._state.y===r&&this._state.isFocused===this._coreBrowserService.isFocused&&this._state.style===this._optionsService.options.cursorStyle&&this._state.width===this._cell.getWidth())return;this._clearCursor()}this._ctx.save(),this._cursorRenderers[this._optionsService.options.cursorStyle||"block"](i,r,this._cell),this._ctx.restore(),this._state.x=i,this._state.y=r,this._state.isFocused=!1,this._state.style=this._optionsService.options.cursorStyle,this._state.width=this._cell.getWidth()}else this._clearCursor()}}}else this._clearCursor()},t.prototype._clearCursor=function(){this._state&&(this._clearCells(this._state.x,this._state.y,this._state.width,1),this._state={x:0,y:0,isFocused:!1,style:"",width:0})},t.prototype._renderBarCursor=function(e,t,r){this._ctx.save(),this._ctx.fillStyle=this._colors.cursor.css,this._fillLeftLineAtCell(e,t,this._optionsService.options.cursorWidth),this._ctx.restore()},t.prototype._renderBlockCursor=function(e,t,r){this._ctx.save(),this._ctx.fillStyle=this._colors.cursor.css,this._fillCells(e,t,r.getWidth(),1),this._ctx.fillStyle=this._colors.cursorAccent.css,this._fillCharTrueColor(r,e,t),this._ctx.restore()},t.prototype._renderUnderlineCursor=function(e,t,r){this._ctx.save(),this._ctx.fillStyle=this._colors.cursor.css,this._fillBottomLineAtCells(e,t),this._ctx.restore()},t.prototype._renderBlurCursor=function(e,t,r){this._ctx.save(),this._ctx.strokeStyle=this._colors.cursor.css,this._strokeRectAtCell(e,t,r.getWidth(),1),this._ctx.restore()},t}(o.BaseRenderLayer);t.CursorRenderLayer=c;var l=function(){function e(e,t){this._renderCallback=t,this.isCursorVisible=!0,e&&this._restartInterval()}return Object.defineProperty(e.prototype,"isPaused",{get:function(){return!(this._blinkStartTimeout||this._blinkInterval)},enumerable:!1,configurable:!0}),e.prototype.dispose=function(){this._blinkInterval&&(window.clearInterval(this._blinkInterval),this._blinkInterval=void 0),this._blinkStartTimeout&&(window.clearTimeout(this._blinkStartTimeout),this._blinkStartTimeout=void 0),this._animationFrame&&(window.cancelAnimationFrame(this._animationFrame),this._animationFrame=void 0)},e.prototype.restartBlinkAnimation=function(){var e=this;this.isPaused||(this._animationTimeRestarted=Date.now(),this.isCursorVisible=!0,this._animationFrame||(this._animationFrame=window.requestAnimationFrame((function(){e._renderCallback(),e._animationFrame=void 0}))))},e.prototype._restartInterval=function(e){var t=this;void 0===e&&(e=a),this._blinkInterval&&window.clearInterval(this._blinkInterval),this._blinkStartTimeout=window.setTimeout((function(){if(t._animationTimeRestarted){var e=a-(Date.now()-t._animationTimeRestarted);if(t._animationTimeRestarted=void 0,e>0)return void t._restartInterval(e)}t.isCursorVisible=!1,t._animationFrame=window.requestAnimationFrame((function(){t._renderCallback(),t._animationFrame=void 0})),t._blinkInterval=window.setInterval((function(){if(t._animationTimeRestarted){var e=a-(Date.now()-t._animationTimeRestarted);return t._animationTimeRestarted=void 0,void t._restartInterval(e)}t.isCursorVisible=!t.isCursorVisible,t._animationFrame=window.requestAnimationFrame((function(){t._renderCallback(),t._animationFrame=void 0}))}),a)}),e)},e.prototype.pause=function(){this.isCursorVisible=!0,this._blinkInterval&&(window.clearInterval(this._blinkInterval),this._blinkInterval=void 0),this._blinkStartTimeout&&(window.clearTimeout(this._blinkStartTimeout),this._blinkStartTimeout=void 0),this._animationFrame&&(window.cancelAnimationFrame(this._animationFrame),this._animationFrame=void 0)},e.prototype.resume=function(){this.pause(),this._animationTimeRestarted=void 0,this._restartInterval(),this.restartBlinkAnimation()},e}()},3700:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.GridCache=void 0;var r=function(){function e(){this.cache=[]}return e.prototype.resize=function(e,t){for(var r=0;r0&&this._clearCells(0,this._state.y1+1,this._state.cols,e),this._clearCells(0,this._state.y2,this._state.x2,1),this._state=void 0}},t.prototype._onShowLinkUnderline=function(e){if(e.fg===s.INVERTED_DEFAULT_COLOR?this._ctx.fillStyle=this._colors.background.css:e.fg&&a.is256Color(e.fg)?this._ctx.fillStyle=this._colors.ansi[e.fg].css:this._ctx.fillStyle=this._colors.foreground.css,e.y1===e.y2)this._fillBottomLineAtCells(e.x1,e.y1,e.x2-e.x1);else{this._fillBottomLineAtCells(e.x1,e.y1,e.cols-e.x1);for(var t=e.y1+1;t=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},s=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.Renderer=void 0;var a=r(9596),c=r(4149),l=r(2512),h=r(5098),u=r(5879),f=r(844),_=r(4725),d=r(2585),p=r(1420),v=r(8460),g=1,y=function(e){function t(t,r,i,n,o,s,f,_,d){var p=e.call(this)||this;p._colors=t,p._screenElement=r,p._bufferService=o,p._charSizeService=s,p._optionsService=f,p._id=g++,p._onRequestRedraw=new v.EventEmitter;var y=p._optionsService.options.allowTransparency;return p._characterJoinerRegistry=new u.CharacterJoinerRegistry(p._bufferService),p._renderLayers=[new a.TextRenderLayer(p._screenElement,0,p._colors,p._characterJoinerRegistry,y,p._id,p._bufferService,f),new c.SelectionRenderLayer(p._screenElement,1,p._colors,p._id,p._bufferService,f),new h.LinkRenderLayer(p._screenElement,2,p._colors,p._id,i,n,p._bufferService,f),new l.CursorRenderLayer(p._screenElement,3,p._colors,p._id,p._onRequestRedraw,p._bufferService,f,_,d)],p.dimensions={scaledCharWidth:0,scaledCharHeight:0,scaledCellWidth:0,scaledCellHeight:0,scaledCharLeft:0,scaledCharTop:0,scaledCanvasWidth:0,scaledCanvasHeight:0,canvasWidth:0,canvasHeight:0,actualCellWidth:0,actualCellHeight:0},p._devicePixelRatio=window.devicePixelRatio,p._updateDimensions(),p.onOptionsChanged(),p}return n(t,e),Object.defineProperty(t.prototype,"onRequestRedraw",{get:function(){return this._onRequestRedraw.event},enumerable:!1,configurable:!0}),t.prototype.dispose=function(){for(var t=0,r=this._renderLayers;t{Object.defineProperty(t,"__esModule",{value:!0}),t.throwIfFalsy=void 0,t.throwIfFalsy=function(e){if(!e)throw new Error("value must not be falsy");return e}},4149:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.SelectionRenderLayer=void 0;var o=function(e){function t(t,r,i,n,o,s){var a=e.call(this,t,"selection",r,!0,i,n,o,s)||this;return a._clearState(),a}return n(t,e),t.prototype._clearState=function(){this._state={start:void 0,end:void 0,columnSelectMode:void 0,ydisp:void 0}},t.prototype.resize=function(t){e.prototype.resize.call(this,t),this._clearState()},t.prototype.reset=function(){this._state.start&&this._state.end&&(this._clearState(),this._clearAll())},t.prototype.onSelectionChanged=function(e,t,r){if(this._didStateChange(e,t,r,this._bufferService.buffer.ydisp))if(this._clearAll(),e&&t){var i=e[1]-this._bufferService.buffer.ydisp,n=t[1]-this._bufferService.buffer.ydisp,o=Math.max(i,0),s=Math.min(n,this._bufferService.rows-1);if(o>=this._bufferService.rows||s<0)this._state.ydisp=this._bufferService.buffer.ydisp;else{if(this._ctx.fillStyle=this._colors.selectionTransparent.css,r){var a=e[0],c=t[0]-a,l=s-o+1;this._fillCells(a,o,c,l)}else{a=i===o?e[0]:0;var h=o===n?t[0]:this._bufferService.cols;this._fillCells(a,o,h-a,1);var u=Math.max(s-o-1,0);if(this._fillCells(0,o+1,this._bufferService.cols,u),o!==s){var f=n===s?t[0]:this._bufferService.cols;this._fillCells(0,s,f,1)}}this._state.start=[e[0],e[1]],this._state.end=[t[0],t[1]],this._state.columnSelectMode=r,this._state.ydisp=this._bufferService.buffer.ydisp}}else this._clearState()},t.prototype._didStateChange=function(e,t,r,i){return!this._areCoordinatesEqual(e,this._state.start)||!this._areCoordinatesEqual(t,this._state.end)||r!==this._state.columnSelectMode||i!==this._state.ydisp},t.prototype._areCoordinatesEqual=function(e,t){return!(!e||!t)&&e[0]===t[0]&&e[1]===t[1]},t}(r(1546).BaseRenderLayer);t.SelectionRenderLayer=o},9596:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.TextRenderLayer=void 0;var o=r(3700),s=r(1546),a=r(3734),c=r(643),l=r(5879),h=r(511),u=function(e){function t(t,r,i,n,s,a,c,l){var u=e.call(this,t,"text",r,s,i,a,c,l)||this;return u._characterWidth=0,u._characterFont="",u._characterOverlapCache={},u._workCell=new h.CellData,u._state=new o.GridCache,u._characterJoinerRegistry=n,u}return n(t,e),t.prototype.resize=function(t){e.prototype.resize.call(this,t);var r=this._getFont(!1,!1);this._characterWidth===t.scaledCharWidth&&this._characterFont===r||(this._characterWidth=t.scaledCharWidth,this._characterFont=r,this._characterOverlapCache={}),this._state.clear(),this._state.resize(this._bufferService.cols,this._bufferService.rows)},t.prototype.reset=function(){this._state.clear(),this._clearAll()},t.prototype._forEachCell=function(e,t,r,i){for(var n=e;n<=t;n++)for(var o=n+this._bufferService.buffer.ydisp,s=this._bufferService.buffer.lines.get(o),a=r?r.getJoinedCharacters(o):[],h=0;h0&&h===a[0][0]){f=!0;var d=a.shift();u=new l.JoinedCellData(this._workCell,s.translateToString(!0,d[0],d[1]),d[1]-d[0]),_=d[1]-1}!f&&this._isOverlapping(u)&&_this._characterWidth;return this._ctx.restore(),this._characterOverlapCache[t]=r,r},t}(s.BaseRenderLayer);t.TextRenderLayer=u},9616:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.BaseCharAtlas=void 0;var r=function(){function e(){this._didWarmUp=!1}return e.prototype.dispose=function(){},e.prototype.warmUp=function(){this._didWarmUp||(this._doWarmUp(),this._didWarmUp=!0)},e.prototype._doWarmUp=function(){},e.prototype.beginFrame=function(){},e}();t.BaseCharAtlas=r},1420:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.removeTerminalFromCache=t.acquireCharAtlas=void 0;var i=r(2040),n=r(1906),o=[];t.acquireCharAtlas=function(e,t,r,s,a){for(var c=i.generateConfig(s,a,e,r),l=0;l=0){if(i.configEquals(u.config,c))return u.atlas;1===u.ownedBy.length?(u.atlas.dispose(),o.splice(l,1)):u.ownedBy.splice(h,1);break}}for(l=0;l{Object.defineProperty(t,"__esModule",{value:!0}),t.is256Color=t.configEquals=t.generateConfig=void 0;var i=r(643);t.generateConfig=function(e,t,r,i){var n={foreground:i.foreground,background:i.background,cursor:void 0,cursorAccent:void 0,selection:void 0,ansi:i.ansi};return{devicePixelRatio:window.devicePixelRatio,scaledCharWidth:e,scaledCharHeight:t,fontFamily:r.fontFamily,fontSize:r.fontSize,fontWeight:r.fontWeight,fontWeightBold:r.fontWeightBold,allowTransparency:r.allowTransparency,colors:n}},t.configEquals=function(e,t){for(var r=0;r{Object.defineProperty(t,"__esModule",{value:!0}),t.CHAR_ATLAS_CELL_SPACING=t.DIM_OPACITY=t.INVERTED_DEFAULT_COLOR=void 0,t.INVERTED_DEFAULT_COLOR=257,t.DIM_OPACITY=.5,t.CHAR_ATLAS_CELL_SPACING=1},1906:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.NoneCharAtlas=t.DynamicCharAtlas=t.getGlyphCacheKey=void 0;var o=r(8803),s=r(9616),a=r(5680),c=r(7001),l=r(6114),h=r(1752),u=r(4774),f={css:"rgba(0, 0, 0, 0)",rgba:0};function _(e){return e.code<<21|e.bg<<12|e.fg<<3|(e.bold?0:4)+(e.dim?0:2)+(e.italic?0:1)}t.getGlyphCacheKey=_;var d=function(e){function t(t,r){var i=e.call(this)||this;i._config=r,i._drawToCacheCount=0,i._glyphsWaitingOnBitmap=[],i._bitmapCommitTimeout=null,i._bitmap=null,i._cacheCanvas=t.createElement("canvas"),i._cacheCanvas.width=1024,i._cacheCanvas.height=1024,i._cacheCtx=h.throwIfFalsy(i._cacheCanvas.getContext("2d",{alpha:!0}));var n=t.createElement("canvas");n.width=i._config.scaledCharWidth,n.height=i._config.scaledCharHeight,i._tmpCtx=h.throwIfFalsy(n.getContext("2d",{alpha:i._config.allowTransparency})),i._width=Math.floor(1024/i._config.scaledCharWidth),i._height=Math.floor(1024/i._config.scaledCharHeight);var o=i._width*i._height;return i._cacheMap=new c.LRUMap(o),i._cacheMap.prealloc(o),i}return n(t,e),t.prototype.dispose=function(){null!==this._bitmapCommitTimeout&&(window.clearTimeout(this._bitmapCommitTimeout),this._bitmapCommitTimeout=null)},t.prototype.beginFrame=function(){this._drawToCacheCount=0},t.prototype.draw=function(e,t,r,i){if(32===t.code)return!0;if(!this._canCache(t))return!1;var n=_(t),o=this._cacheMap.get(n);if(null!=o)return this._drawFromCache(e,o,r,i),!0;if(this._drawToCacheCount<100){var s;s=this._cacheMap.size>>24,n=t.rgba>>>16&255,o=t.rgba>>>8&255,s=0;s{Object.defineProperty(t,"__esModule",{value:!0}),t.LRUMap=void 0;var r=function(){function e(e){this.capacity=e,this._map={},this._head=null,this._tail=null,this._nodePool=[],this.size=0}return e.prototype._unlinkNode=function(e){var t=e.prev,r=e.next;e===this._head&&(this._head=r),e===this._tail&&(this._tail=t),null!==t&&(t.next=r),null!==r&&(r.prev=t)},e.prototype._appendNode=function(e){var t=this._tail;null!==t&&(t.next=e),e.prev=t,e.next=null,this._tail=e,null===this._head&&(this._head=e)},e.prototype.prealloc=function(e){for(var t=this._nodePool,r=0;r=this.capacity)r=this._head,this._unlinkNode(r),delete this._map[r.key],r.key=e,r.value=t,this._map[e]=r;else{var i=this._nodePool;i.length>0?((r=i.pop()).key=e,r.value=t):r={prev:null,next:null,key:e,value:t},this._map[e]=r,this.size++}this._appendNode(r)},e}();t.LRUMap=r},1296:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}),o=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},s=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.DomRenderer=void 0;var a=r(3787),c=r(8803),l=r(844),h=r(4725),u=r(2585),f=r(8460),_=r(4774),d=r(9631),p="xterm-dom-renderer-owner-",v="xterm-fg-",g="xterm-bg-",y="xterm-focus",b=1,S=function(e){function t(t,r,i,n,o,s,c,l,h){var u=e.call(this)||this;return u._colors=t,u._element=r,u._screenElement=i,u._viewportElement=n,u._linkifier=o,u._linkifier2=s,u._charSizeService=c,u._optionsService=l,u._bufferService=h,u._terminalClass=b++,u._rowElements=[],u._rowContainer=document.createElement("div"),u._rowContainer.classList.add("xterm-rows"),u._rowContainer.style.lineHeight="normal",u._rowContainer.setAttribute("aria-hidden","true"),u._refreshRowElements(u._bufferService.cols,u._bufferService.rows),u._selectionContainer=document.createElement("div"),u._selectionContainer.classList.add("xterm-selection"),u._selectionContainer.setAttribute("aria-hidden","true"),u.dimensions={scaledCharWidth:0,scaledCharHeight:0,scaledCellWidth:0,scaledCellHeight:0,scaledCharLeft:0,scaledCharTop:0,scaledCanvasWidth:0,scaledCanvasHeight:0,canvasWidth:0,canvasHeight:0,actualCellWidth:0,actualCellHeight:0},u._updateDimensions(),u._injectCss(),u._rowFactory=new a.DomRendererRowFactory(document,u._optionsService,u._colors),u._element.classList.add(p+u._terminalClass),u._screenElement.appendChild(u._rowContainer),u._screenElement.appendChild(u._selectionContainer),u._linkifier.onShowLinkUnderline((function(e){return u._onLinkHover(e)})),u._linkifier.onHideLinkUnderline((function(e){return u._onLinkLeave(e)})),u._linkifier2.onShowLinkUnderline((function(e){return u._onLinkHover(e)})),u._linkifier2.onHideLinkUnderline((function(e){return u._onLinkLeave(e)})),u}return n(t,e),Object.defineProperty(t.prototype,"onRequestRedraw",{get:function(){return(new f.EventEmitter).event},enumerable:!1,configurable:!0}),t.prototype.dispose=function(){this._element.classList.remove(p+this._terminalClass),d.removeElementFromParent(this._rowContainer,this._selectionContainer,this._themeStyleElement,this._dimensionsStyleElement),e.prototype.dispose.call(this)},t.prototype._updateDimensions=function(){this.dimensions.scaledCharWidth=this._charSizeService.width*window.devicePixelRatio,this.dimensions.scaledCharHeight=Math.ceil(this._charSizeService.height*window.devicePixelRatio),this.dimensions.scaledCellWidth=this.dimensions.scaledCharWidth+Math.round(this._optionsService.options.letterSpacing),this.dimensions.scaledCellHeight=Math.floor(this.dimensions.scaledCharHeight*this._optionsService.options.lineHeight),this.dimensions.scaledCharLeft=0,this.dimensions.scaledCharTop=0,this.dimensions.scaledCanvasWidth=this.dimensions.scaledCellWidth*this._bufferService.cols,this.dimensions.scaledCanvasHeight=this.dimensions.scaledCellHeight*this._bufferService.rows,this.dimensions.canvasWidth=Math.round(this.dimensions.scaledCanvasWidth/window.devicePixelRatio),this.dimensions.canvasHeight=Math.round(this.dimensions.scaledCanvasHeight/window.devicePixelRatio),this.dimensions.actualCellWidth=this.dimensions.canvasWidth/this._bufferService.cols,this.dimensions.actualCellHeight=this.dimensions.canvasHeight/this._bufferService.rows;for(var e=0,t=this._rowElements;et;)this._rowContainer.removeChild(this._rowElements.pop())},t.prototype.onResize=function(e,t){this._refreshRowElements(e,t),this._updateDimensions()},t.prototype.onCharSizeChanged=function(){this._updateDimensions()},t.prototype.onBlur=function(){this._rowContainer.classList.remove(y)},t.prototype.onFocus=function(){this._rowContainer.classList.add(y)},t.prototype.onSelectionChanged=function(e,t,r){for(;this._selectionContainer.children.length;)this._selectionContainer.removeChild(this._selectionContainer.children[0]);if(e&&t){var i=e[1]-this._bufferService.buffer.ydisp,n=t[1]-this._bufferService.buffer.ydisp,o=Math.max(i,0),s=Math.min(n,this._bufferService.rows-1);if(!(o>=this._bufferService.rows||s<0)){var a=document.createDocumentFragment();if(r)a.appendChild(this._createSelectionElement(o,e[0],t[0],s-o+1));else{var c=i===o?e[0]:0,l=o===n?t[0]:this._bufferService.cols;a.appendChild(this._createSelectionElement(o,c,l));var h=s-o-1;if(a.appendChild(this._createSelectionElement(o+1,0,this._bufferService.cols,h)),o!==s){var u=n===s?t[0]:this._bufferService.cols;a.appendChild(this._createSelectionElement(s,0,u))}}this._selectionContainer.appendChild(a)}}},t.prototype._createSelectionElement=function(e,t,r,i){void 0===i&&(i=1);var n=document.createElement("div");return n.style.height=i*this.dimensions.actualCellHeight+"px",n.style.top=e*this.dimensions.actualCellHeight+"px",n.style.left=t*this.dimensions.actualCellWidth+"px",n.style.width=this.dimensions.actualCellWidth*(r-t)+"px",n},t.prototype.onCursorMove=function(){},t.prototype.onOptionsChanged=function(){this._updateDimensions(),this._injectCss()},t.prototype.clear=function(){for(var e=0,t=this._rowElements;e=n&&(e=0,r++)}},o([s(6,h.ICharSizeService),s(7,u.IOptionsService),s(8,u.IBufferService)],t)}(l.Disposable);t.DomRenderer=S},3787:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.DomRendererRowFactory=t.CURSOR_STYLE_UNDERLINE_CLASS=t.CURSOR_STYLE_BAR_CLASS=t.CURSOR_STYLE_BLOCK_CLASS=t.CURSOR_BLINK_CLASS=t.CURSOR_CLASS=t.UNDERLINE_CLASS=t.ITALIC_CLASS=t.DIM_CLASS=t.BOLD_CLASS=void 0;var i=r(8803),n=r(643),o=r(511),s=r(4774);t.BOLD_CLASS="xterm-bold",t.DIM_CLASS="xterm-dim",t.ITALIC_CLASS="xterm-italic",t.UNDERLINE_CLASS="xterm-underline",t.CURSOR_CLASS="xterm-cursor",t.CURSOR_BLINK_CLASS="xterm-cursor-blink",t.CURSOR_STYLE_BLOCK_CLASS="xterm-cursor-block",t.CURSOR_STYLE_BAR_CLASS="xterm-cursor-bar",t.CURSOR_STYLE_UNDERLINE_CLASS="xterm-cursor-underline";var a=function(){function e(e,t,r){this._document=e,this._optionsService=t,this._colors=r,this._workCell=new o.CellData}return e.prototype.setColors=function(e){this._colors=e},e.prototype.createRow=function(e,r,o,a,l,h,u){for(var f=this._document.createDocumentFragment(),_=0,d=Math.min(e.length,u)-1;d>=0;d--)if(e.loadCell(d,this._workCell).getCode()!==n.NULL_CELL_CODE||r&&d===a){_=d+1;break}for(d=0;d<_;d++){e.loadCell(d,this._workCell);var p=this._workCell.getWidth();if(0!==p){var v=this._document.createElement("span");if(p>1&&(v.style.width=h*p+"px"),r&&d===a)switch(v.classList.add(t.CURSOR_CLASS),l&&v.classList.add(t.CURSOR_BLINK_CLASS),o){case"bar":v.classList.add(t.CURSOR_STYLE_BAR_CLASS);break;case"underline":v.classList.add(t.CURSOR_STYLE_UNDERLINE_CLASS);break;default:v.classList.add(t.CURSOR_STYLE_BLOCK_CLASS)}this._workCell.isBold()&&v.classList.add(t.BOLD_CLASS),this._workCell.isItalic()&&v.classList.add(t.ITALIC_CLASS),this._workCell.isDim()&&v.classList.add(t.DIM_CLASS),this._workCell.isUnderline()&&v.classList.add(t.UNDERLINE_CLASS),this._workCell.isInvisible()?v.textContent=n.WHITESPACE_CELL_CHAR:v.textContent=this._workCell.getChars()||n.WHITESPACE_CELL_CHAR;var g=this._workCell.getFgColor(),y=this._workCell.getFgColorMode(),b=this._workCell.getBgColor(),S=this._workCell.getBgColorMode(),m=!!this._workCell.isInverse();if(m){var C=g;g=b,b=C;var w=y;y=S,S=w}switch(y){case 16777216:case 33554432:this._workCell.isBold()&&g<8&&this._optionsService.options.drawBoldTextInBrightColors&&(g+=8),this._applyMinimumContrast(v,this._colors.background,this._colors.ansi[g])||v.classList.add("xterm-fg-"+g);break;case 50331648:var E=s.rgba.toColor(g>>16&255,g>>8&255,255&g);this._applyMinimumContrast(v,this._colors.background,E)||this._addStyle(v,"color:#"+c(g.toString(16),"0",6));break;case 0:default:this._applyMinimumContrast(v,this._colors.background,this._colors.foreground)||m&&v.classList.add("xterm-fg-"+i.INVERTED_DEFAULT_COLOR)}switch(S){case 16777216:case 33554432:v.classList.add("xterm-bg-"+b);break;case 50331648:this._addStyle(v,"background-color:#"+c(b.toString(16),"0",6));break;case 0:default:m&&v.classList.add("xterm-bg-"+i.INVERTED_DEFAULT_COLOR)}f.appendChild(v)}}return f},e.prototype._applyMinimumContrast=function(e,t,r){if(1===this._optionsService.options.minimumContrastRatio)return!1;var i=this._colors.contrastCache.getColor(this._workCell.bg,this._workCell.fg);return void 0===i&&(i=s.color.ensureContrastRatio(t,r,this._optionsService.options.minimumContrastRatio),this._colors.contrastCache.setColor(this._workCell.bg,this._workCell.fg,null!=i?i:null)),!!i&&(this._addStyle(e,"color:"+i.css),!0)},e.prototype._addStyle=function(e,t){e.setAttribute("style",""+(e.getAttribute("style")||"")+t+";")},e}();function c(e,t,r){for(;e.length{Object.defineProperty(t,"__esModule",{value:!0}),t.SelectionModel=void 0;var r=function(){function e(e){this._bufferService=e,this.isSelectAllActive=!1,this.selectionStartLength=0}return e.prototype.clearSelection=function(){this.selectionStart=void 0,this.selectionEnd=void 0,this.isSelectAllActive=!1,this.selectionStartLength=0},Object.defineProperty(e.prototype,"finalSelectionStart",{get:function(){return this.isSelectAllActive?[0,0]:this.selectionEnd&&this.selectionStart&&this.areSelectionValuesReversed()?this.selectionEnd:this.selectionStart},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"finalSelectionEnd",{get:function(){if(this.isSelectAllActive)return[this._bufferService.cols,this._bufferService.buffer.ybase+this._bufferService.rows-1];if(this.selectionStart){if(!this.selectionEnd||this.areSelectionValuesReversed()){var e=this.selectionStart[0]+this.selectionStartLength;return e>this._bufferService.cols?[e%this._bufferService.cols,this.selectionStart[1]+Math.floor(e/this._bufferService.cols)]:[e,this.selectionStart[1]]}return this.selectionStartLength&&this.selectionEnd[1]===this.selectionStart[1]?[Math.max(this.selectionStart[0]+this.selectionStartLength,this.selectionEnd[0]),this.selectionEnd[1]]:this.selectionEnd}},enumerable:!1,configurable:!0}),e.prototype.areSelectionValuesReversed=function(){var e=this.selectionStart,t=this.selectionEnd;return!(!e||!t)&&(e[1]>t[1]||e[1]===t[1]&&e[0]>t[0])},e.prototype.onTrim=function(e){return this.selectionStart&&(this.selectionStart[1]-=e),this.selectionEnd&&(this.selectionEnd[1]-=e),this.selectionEnd&&this.selectionEnd[1]<0?(this.clearSelection(),!0):(this.selectionStart&&this.selectionStart[1]<0&&(this.selectionStart[1]=0),!1)},e}();t.SelectionModel=r},428:function(e,t,r){var i=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},n=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.CharSizeService=void 0;var o=r(2585),s=r(8460),a=function(){function e(e,t,r){this._optionsService=r,this.width=0,this.height=0,this._onCharSizeChange=new s.EventEmitter,this._measureStrategy=new c(e,t,this._optionsService)}return Object.defineProperty(e.prototype,"hasValidSize",{get:function(){return this.width>0&&this.height>0},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onCharSizeChange",{get:function(){return this._onCharSizeChange.event},enumerable:!1,configurable:!0}),e.prototype.measure=function(){var e=this._measureStrategy.measure();e.width===this.width&&e.height===this.height||(this.width=e.width,this.height=e.height,this._onCharSizeChange.fire())},i([n(2,o.IOptionsService)],e)}();t.CharSizeService=a;var c=function(){function e(e,t,r){this._document=e,this._parentElement=t,this._optionsService=r,this._result={width:0,height:0},this._measureElement=this._document.createElement("span"),this._measureElement.classList.add("xterm-char-measure-element"),this._measureElement.textContent="W",this._measureElement.setAttribute("aria-hidden","true"),this._parentElement.appendChild(this._measureElement)}return e.prototype.measure=function(){this._measureElement.style.fontFamily=this._optionsService.options.fontFamily,this._measureElement.style.fontSize=this._optionsService.options.fontSize+"px";var e=this._measureElement.getBoundingClientRect();return 0!==e.width&&0!==e.height&&(this._result.width=e.width,this._result.height=Math.ceil(e.height)),this._result},e}()},5114:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.CoreBrowserService=void 0;var r=function(){function e(e){this._textarea=e}return Object.defineProperty(e.prototype,"isFocused",{get:function(){return(this._textarea.getRootNode?this._textarea.getRootNode():document).activeElement===this._textarea&&document.hasFocus()},enumerable:!1,configurable:!0}),e}();t.CoreBrowserService=r},8934:function(e,t,r){var i=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},n=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.MouseService=void 0;var o=r(4725),s=r(9806),a=function(){function e(e,t){this._renderService=e,this._charSizeService=t}return e.prototype.getCoords=function(e,t,r,i,n){return s.getCoords(e,t,r,i,this._charSizeService.hasValidSize,this._renderService.dimensions.actualCellWidth,this._renderService.dimensions.actualCellHeight,n)},e.prototype.getRawByteCoords=function(e,t,r,i){var n=this.getCoords(e,t,r,i);return s.getRawByteCoords(n)},i([n(0,o.IRenderService),n(1,o.ICharSizeService)],e)}();t.MouseService=a},3230:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}),o=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},s=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.RenderService=void 0;var a=r(6193),c=r(8460),l=r(844),h=r(5596),u=r(3656),f=r(2585),_=r(4725),d=function(e){function t(t,r,i,n,o,s){var l=e.call(this)||this;if(l._renderer=t,l._rowCount=r,l._charSizeService=o,l._isPaused=!1,l._needsFullRefresh=!1,l._isNextRenderRedrawOnly=!0,l._needsSelectionRefresh=!1,l._canvasWidth=0,l._canvasHeight=0,l._selectionState={start:void 0,end:void 0,columnSelectMode:!1},l._onDimensionsChange=new c.EventEmitter,l._onRender=new c.EventEmitter,l._onRefreshRequest=new c.EventEmitter,l.register({dispose:function(){return l._renderer.dispose()}}),l._renderDebouncer=new a.RenderDebouncer((function(e,t){return l._renderRows(e,t)})),l.register(l._renderDebouncer),l._screenDprMonitor=new h.ScreenDprMonitor,l._screenDprMonitor.setListener((function(){return l.onDevicePixelRatioChange()})),l.register(l._screenDprMonitor),l.register(s.onResize((function(e){return l._fullRefresh()}))),l.register(n.onOptionChange((function(){return l._renderer.onOptionsChanged()}))),l.register(l._charSizeService.onCharSizeChange((function(){return l.onCharSizeChanged()}))),l._renderer.onRequestRedraw((function(e){return l.refreshRows(e.start,e.end,!0)})),l.register(u.addDisposableDomListener(window,"resize",(function(){return l.onDevicePixelRatioChange()}))),"IntersectionObserver"in window){var f=new IntersectionObserver((function(e){return l._onIntersectionChange(e[e.length-1])}),{threshold:0});f.observe(i),l.register({dispose:function(){return f.disconnect()}})}return l}return n(t,e),Object.defineProperty(t.prototype,"onDimensionsChange",{get:function(){return this._onDimensionsChange.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRenderedBufferChange",{get:function(){return this._onRender.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRefreshRequest",{get:function(){return this._onRefreshRequest.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"dimensions",{get:function(){return this._renderer.dimensions},enumerable:!1,configurable:!0}),t.prototype._onIntersectionChange=function(e){this._isPaused=void 0===e.isIntersecting?0===e.intersectionRatio:!e.isIntersecting,this._isPaused||this._charSizeService.hasValidSize||this._charSizeService.measure(),!this._isPaused&&this._needsFullRefresh&&(this.refreshRows(0,this._rowCount-1),this._needsFullRefresh=!1)},t.prototype.refreshRows=function(e,t,r){void 0===r&&(r=!1),this._isPaused?this._needsFullRefresh=!0:(r||(this._isNextRenderRedrawOnly=!1),this._renderDebouncer.refresh(e,t,this._rowCount))},t.prototype._renderRows=function(e,t){this._renderer.renderRows(e,t),this._needsSelectionRefresh&&(this._renderer.onSelectionChanged(this._selectionState.start,this._selectionState.end,this._selectionState.columnSelectMode),this._needsSelectionRefresh=!1),this._isNextRenderRedrawOnly||this._onRender.fire({start:e,end:t}),this._isNextRenderRedrawOnly=!0},t.prototype.resize=function(e,t){this._rowCount=t,this._fireOnCanvasResize()},t.prototype.changeOptions=function(){this._renderer.onOptionsChanged(),this.refreshRows(0,this._rowCount-1),this._fireOnCanvasResize()},t.prototype._fireOnCanvasResize=function(){this._renderer.dimensions.canvasWidth===this._canvasWidth&&this._renderer.dimensions.canvasHeight===this._canvasHeight||this._onDimensionsChange.fire(this._renderer.dimensions)},t.prototype.dispose=function(){e.prototype.dispose.call(this)},t.prototype.setRenderer=function(e){var t=this;this._renderer.dispose(),this._renderer=e,this._renderer.onRequestRedraw((function(e){return t.refreshRows(e.start,e.end,!0)})),this._needsSelectionRefresh=!0,this._fullRefresh()},t.prototype._fullRefresh=function(){this._isPaused?this._needsFullRefresh=!0:this.refreshRows(0,this._rowCount-1)},t.prototype.setColors=function(e){this._renderer.setColors(e),this._fullRefresh()},t.prototype.onDevicePixelRatioChange=function(){this._charSizeService.measure(),this._renderer.onDevicePixelRatioChange(),this.refreshRows(0,this._rowCount-1)},t.prototype.onResize=function(e,t){this._renderer.onResize(e,t),this._fullRefresh()},t.prototype.onCharSizeChanged=function(){this._renderer.onCharSizeChanged()},t.prototype.onBlur=function(){this._renderer.onBlur()},t.prototype.onFocus=function(){this._renderer.onFocus()},t.prototype.onSelectionChanged=function(e,t,r){this._selectionState.start=e,this._selectionState.end=t,this._selectionState.columnSelectMode=r,this._renderer.onSelectionChanged(e,t,r)},t.prototype.onCursorMove=function(){this._renderer.onCursorMove()},t.prototype.clear=function(){this._renderer.clear()},t.prototype.registerCharacterJoiner=function(e){return this._renderer.registerCharacterJoiner(e)},t.prototype.deregisterCharacterJoiner=function(e){return this._renderer.deregisterCharacterJoiner(e)},o([s(3,f.IOptionsService),s(4,_.ICharSizeService),s(5,f.IBufferService)],t)}(l.Disposable);t.RenderService=d},9312:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}),o=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},s=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.SelectionService=void 0;var a=r(6114),c=r(456),l=r(511),h=r(8460),u=r(4725),f=r(2585),_=r(9806),d=r(9504),p=r(844),v=String.fromCharCode(160),g=new RegExp(v,"g"),y=function(e){function t(t,r,i,n,o,s,a){var u=e.call(this)||this;return u._element=t,u._screenElement=r,u._bufferService=i,u._coreService=n,u._mouseService=o,u._optionsService=s,u._renderService=a,u._dragScrollAmount=0,u._enabled=!0,u._workCell=new l.CellData,u._mouseDownTimeStamp=0,u._oldHasSelection=!1,u._oldSelectionStart=void 0,u._oldSelectionEnd=void 0,u._onLinuxMouseSelection=u.register(new h.EventEmitter),u._onRedrawRequest=u.register(new h.EventEmitter),u._onSelectionChange=u.register(new h.EventEmitter),u._onRequestScrollLines=u.register(new h.EventEmitter),u._mouseMoveListener=function(e){return u._onMouseMove(e)},u._mouseUpListener=function(e){return u._onMouseUp(e)},u._coreService.onUserInput((function(){u.hasSelection&&u.clearSelection()})),u._trimListener=u._bufferService.buffer.lines.onTrim((function(e){return u._onTrim(e)})),u.register(u._bufferService.buffers.onBufferActivate((function(e){return u._onBufferActivate(e)}))),u.enable(),u._model=new c.SelectionModel(u._bufferService),u._activeSelectionMode=0,u}return n(t,e),Object.defineProperty(t.prototype,"onLinuxMouseSelection",{get:function(){return this._onLinuxMouseSelection.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRequestRedraw",{get:function(){return this._onRedrawRequest.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onSelectionChange",{get:function(){return this._onSelectionChange.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRequestScrollLines",{get:function(){return this._onRequestScrollLines.event},enumerable:!1,configurable:!0}),t.prototype.dispose=function(){this._removeMouseDownListeners()},t.prototype.reset=function(){this.clearSelection()},t.prototype.disable=function(){this.clearSelection(),this._enabled=!1},t.prototype.enable=function(){this._enabled=!0},Object.defineProperty(t.prototype,"selectionStart",{get:function(){return this._model.finalSelectionStart},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"selectionEnd",{get:function(){return this._model.finalSelectionEnd},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"hasSelection",{get:function(){var e=this._model.finalSelectionStart,t=this._model.finalSelectionEnd;return!(!e||!t||e[0]===t[0]&&e[1]===t[1])},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"selectionText",{get:function(){var e=this._model.finalSelectionStart,t=this._model.finalSelectionEnd;if(!e||!t)return"";var r=this._bufferService.buffer,i=[];if(3===this._activeSelectionMode){if(e[0]===t[0])return"";for(var n=e[1];n<=t[1];n++){var o=r.translateBufferLineToString(n,!0,e[0],t[0]);i.push(o)}}else{var s=e[1]===t[1]?t[0]:void 0;for(i.push(r.translateBufferLineToString(e[1],!0,e[0],s)),n=e[1]+1;n<=t[1]-1;n++){var c=r.lines.get(n);o=r.translateBufferLineToString(n,!0),c&&c.isWrapped?i[i.length-1]+=o:i.push(o)}e[1]!==t[1]&&(c=r.lines.get(t[1]),o=r.translateBufferLineToString(t[1],!0,0,t[0]),c&&c.isWrapped?i[i.length-1]+=o:i.push(o))}return i.map((function(e){return e.replace(g," ")})).join(a.isWindows?"\r\n":"\n")},enumerable:!1,configurable:!0}),t.prototype.clearSelection=function(){this._model.clearSelection(),this._removeMouseDownListeners(),this.refresh(),this._onSelectionChange.fire()},t.prototype.refresh=function(e){var t=this;this._refreshAnimationFrame||(this._refreshAnimationFrame=window.requestAnimationFrame((function(){return t._refresh()}))),a.isLinux&&e&&this.selectionText.length&&this._onLinuxMouseSelection.fire(this.selectionText)},t.prototype._refresh=function(){this._refreshAnimationFrame=void 0,this._onRedrawRequest.fire({start:this._model.finalSelectionStart,end:this._model.finalSelectionEnd,columnSelectMode:3===this._activeSelectionMode})},t.prototype._isClickInSelection=function(e){var t=this._getMouseBufferCoords(e),r=this._model.finalSelectionStart,i=this._model.finalSelectionEnd;return!!(r&&i&&t)&&this._areCoordsInSelection(t,r,i)},t.prototype._areCoordsInSelection=function(e,t,r){return e[1]>t[1]&&e[1]=t[0]&&e[0]=t[0]},t.prototype._selectWordAtCursor=function(e){var t=this._getMouseBufferCoords(e);t&&(this._selectWordAt(t,!1),this._model.selectionEnd=void 0,this.refresh(!0))},t.prototype.selectAll=function(){this._model.isSelectAllActive=!0,this.refresh(),this._onSelectionChange.fire()},t.prototype.selectLines=function(e,t){this._model.clearSelection(),e=Math.max(e,0),t=Math.min(t,this._bufferService.buffer.lines.length-1),this._model.selectionStart=[0,e],this._model.selectionEnd=[this._bufferService.cols,t],this.refresh(),this._onSelectionChange.fire()},t.prototype._onTrim=function(e){this._model.onTrim(e)&&this.refresh()},t.prototype._getMouseBufferCoords=function(e){var t=this._mouseService.getCoords(e,this._screenElement,this._bufferService.cols,this._bufferService.rows,!0);if(t)return t[0]--,t[1]--,t[1]+=this._bufferService.buffer.ydisp,t},t.prototype._getMouseEventScrollAmount=function(e){var t=_.getCoordsRelativeToElement(e,this._screenElement)[1],r=this._renderService.dimensions.canvasHeight;return t>=0&&t<=r?0:(t>r&&(t-=r),t=Math.min(Math.max(t,-50),50),(t/=50)/Math.abs(t)+Math.round(14*t))},t.prototype.shouldForceSelection=function(e){return a.isMac?e.altKey&&this._optionsService.options.macOptionClickForcesSelection:e.shiftKey},t.prototype.onMouseDown=function(e){if(this._mouseDownTimeStamp=e.timeStamp,(2!==e.button||!this.hasSelection)&&0===e.button){if(!this._enabled){if(!this.shouldForceSelection(e))return;e.stopPropagation()}e.preventDefault(),this._dragScrollAmount=0,this._enabled&&e.shiftKey?this._onIncrementalClick(e):1===e.detail?this._onSingleClick(e):2===e.detail?this._onDoubleClick(e):3===e.detail&&this._onTripleClick(e),this._addMouseDownListeners(),this.refresh(!0)}},t.prototype._addMouseDownListeners=function(){var e=this;this._screenElement.ownerDocument&&(this._screenElement.ownerDocument.addEventListener("mousemove",this._mouseMoveListener),this._screenElement.ownerDocument.addEventListener("mouseup",this._mouseUpListener)),this._dragScrollIntervalTimer=window.setInterval((function(){return e._dragScroll()}),50)},t.prototype._removeMouseDownListeners=function(){this._screenElement.ownerDocument&&(this._screenElement.ownerDocument.removeEventListener("mousemove",this._mouseMoveListener),this._screenElement.ownerDocument.removeEventListener("mouseup",this._mouseUpListener)),clearInterval(this._dragScrollIntervalTimer),this._dragScrollIntervalTimer=void 0},t.prototype._onIncrementalClick=function(e){this._model.selectionStart&&(this._model.selectionEnd=this._getMouseBufferCoords(e))},t.prototype._onSingleClick=function(e){if(this._model.selectionStartLength=0,this._model.isSelectAllActive=!1,this._activeSelectionMode=this.shouldColumnSelect(e)?3:0,this._model.selectionStart=this._getMouseBufferCoords(e),this._model.selectionStart){this._model.selectionEnd=void 0;var t=this._bufferService.buffer.lines.get(this._model.selectionStart[1]);t&&t.length!==this._model.selectionStart[0]&&0===t.hasWidth(this._model.selectionStart[0])&&this._model.selectionStart[0]++}},t.prototype._onDoubleClick=function(e){var t=this._getMouseBufferCoords(e);t&&(this._activeSelectionMode=1,this._selectWordAt(t,!0))},t.prototype._onTripleClick=function(e){var t=this._getMouseBufferCoords(e);t&&(this._activeSelectionMode=2,this._selectLineAt(t[1]))},t.prototype.shouldColumnSelect=function(e){return e.altKey&&!(a.isMac&&this._optionsService.options.macOptionClickForcesSelection)},t.prototype._onMouseMove=function(e){if(e.stopImmediatePropagation(),this._model.selectionStart){var t=this._model.selectionEnd?[this._model.selectionEnd[0],this._model.selectionEnd[1]]:null;if(this._model.selectionEnd=this._getMouseBufferCoords(e),this._model.selectionEnd){2===this._activeSelectionMode?this._model.selectionEnd[1]0?this._model.selectionEnd[0]=this._bufferService.cols:this._dragScrollAmount<0&&(this._model.selectionEnd[0]=0));var r=this._bufferService.buffer;if(this._model.selectionEnd[1]0?(3!==this._activeSelectionMode&&(this._model.selectionEnd[0]=this._bufferService.cols),this._model.selectionEnd[1]=Math.min(e.ydisp+this._bufferService.rows,e.lines.length-1)):(3!==this._activeSelectionMode&&(this._model.selectionEnd[0]=0),this._model.selectionEnd[1]=e.ydisp),this.refresh()}},t.prototype._onMouseUp=function(e){var t=e.timeStamp-this._mouseDownTimeStamp;if(this._removeMouseDownListeners(),this.selectionText.length<=1&&t<500&&e.altKey&&this._optionsService.getOption("altClickMovesCursor")){if(this._bufferService.buffer.ybase===this._bufferService.buffer.ydisp){var r=this._mouseService.getCoords(e,this._element,this._bufferService.cols,this._bufferService.rows,!1);if(r&&void 0!==r[0]&&void 0!==r[1]){var i=d.moveToCellSequence(r[0]-1,r[1]-1,this._bufferService,this._coreService.decPrivateModes.applicationCursorKeys);this._coreService.triggerDataEvent(i,!0)}}}else this._fireEventIfSelectionChanged()},t.prototype._fireEventIfSelectionChanged=function(){var e=this._model.finalSelectionStart,t=this._model.finalSelectionEnd,r=!(!e||!t||e[0]===t[0]&&e[1]===t[1]);r?e&&t&&(this._oldSelectionStart&&this._oldSelectionEnd&&e[0]===this._oldSelectionStart[0]&&e[1]===this._oldSelectionStart[1]&&t[0]===this._oldSelectionEnd[0]&&t[1]===this._oldSelectionEnd[1]||this._fireOnSelectionChange(e,t,r)):this._oldHasSelection&&this._fireOnSelectionChange(e,t,r)},t.prototype._fireOnSelectionChange=function(e,t,r){this._oldSelectionStart=e,this._oldSelectionEnd=t,this._oldHasSelection=r,this._onSelectionChange.fire()},t.prototype._onBufferActivate=function(e){var t=this;this.clearSelection(),this._trimListener.dispose(),this._trimListener=e.activeBuffer.lines.onTrim((function(e){return t._onTrim(e)}))},t.prototype._convertViewportColToCharacterIndex=function(e,t){for(var r=t[0],i=0;t[0]>=i;i++){var n=e.loadCell(i,this._workCell).getChars().length;0===this._workCell.getWidth()?r--:n>1&&t[0]!==i&&(r+=n-1)}return r},t.prototype.setSelection=function(e,t,r){this._model.clearSelection(),this._removeMouseDownListeners(),this._model.selectionStart=[e,t],this._model.selectionStartLength=r,this.refresh()},t.prototype.rightClickSelect=function(e){this._isClickInSelection(e)||(this._selectWordAtCursor(e),this._fireEventIfSelectionChanged())},t.prototype._getWordAt=function(e,t,r,i){if(void 0===r&&(r=!0),void 0===i&&(i=!0),!(e[0]>=this._bufferService.cols)){var n=this._bufferService.buffer,o=n.lines.get(e[1]);if(o){var s=n.translateBufferLineToString(e[1],!1),a=this._convertViewportColToCharacterIndex(o,e),c=a,l=e[0]-a,h=0,u=0,f=0,_=0;if(" "===s.charAt(a)){for(;a>0&&" "===s.charAt(a-1);)a--;for(;c1&&(_+=v-1,c+=v-1);d>0&&a>0&&!this._isCharWordSeparator(o.loadCell(d-1,this._workCell));){o.loadCell(d-1,this._workCell);var g=this._workCell.getChars().length;0===this._workCell.getWidth()?(h++,d--):g>1&&(f+=g-1,a-=g-1),a--,d--}for(;p1&&(_+=y-1,c+=y-1),c++,p++}}c++;var b=a+l-h+f,S=Math.min(this._bufferService.cols,c-a+h+u-f-_);if(t||""!==s.slice(a,c).trim()){if(r&&0===b&&32!==o.getCodePoint(0)){var m=n.lines.get(e[1]-1);if(m&&o.isWrapped&&32!==m.getCodePoint(this._bufferService.cols-1)){var C=this._getWordAt([this._bufferService.cols-1,e[1]-1],!1,!0,!1);if(C){var w=this._bufferService.cols-C.start;b-=w,S+=w}}}if(i&&b+S===this._bufferService.cols&&32!==o.getCodePoint(this._bufferService.cols-1)){var E=n.lines.get(e[1]+1);if(E&&E.isWrapped&&32!==E.getCodePoint(0)){var L=this._getWordAt([0,e[1]+1],!1,!1,!0);L&&(S+=L.length)}}return{start:b,length:S}}}}},t.prototype._selectWordAt=function(e,t){var r=this._getWordAt(e,t);if(r){for(;r.start<0;)r.start+=this._bufferService.cols,e[1]--;this._model.selectionStart=[r.start,e[1]],this._model.selectionStartLength=r.length}},t.prototype._selectToWordAt=function(e){var t=this._getWordAt(e,!0);if(t){for(var r=e[1];t.start<0;)t.start+=this._bufferService.cols,r--;if(!this._model.areSelectionValuesReversed())for(;t.start+t.length>this._bufferService.cols;)t.length-=this._bufferService.cols,r++;this._model.selectionEnd=[this._model.areSelectionValuesReversed()?t.start:t.start+t.length,r]}},t.prototype._isCharWordSeparator=function(e){return 0!==e.getWidth()&&this._optionsService.options.wordSeparator.indexOf(e.getChars())>=0},t.prototype._selectLineAt=function(e){var t=this._bufferService.buffer.getWrappedRangeForLine(e);this._model.selectionStart=[0,t.first],this._model.selectionEnd=[this._bufferService.cols,t.last],this._model.selectionStartLength=0},o([s(2,f.IBufferService),s(3,f.ICoreService),s(4,u.IMouseService),s(5,f.IOptionsService),s(6,u.IRenderService)],t)}(p.Disposable);t.SelectionService=y},4725:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.ISoundService=t.ISelectionService=t.IRenderService=t.IMouseService=t.ICoreBrowserService=t.ICharSizeService=void 0;var i=r(8343);t.ICharSizeService=i.createDecorator("CharSizeService"),t.ICoreBrowserService=i.createDecorator("CoreBrowserService"),t.IMouseService=i.createDecorator("MouseService"),t.IRenderService=i.createDecorator("RenderService"),t.ISelectionService=i.createDecorator("SelectionService"),t.ISoundService=i.createDecorator("SoundService")},357:function(e,t,r){var i=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},n=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.SoundService=void 0;var o=r(2585),s=function(){function e(e){this._optionsService=e}return Object.defineProperty(e,"audioContext",{get:function(){if(!e._audioContext){var t=window.AudioContext||window.webkitAudioContext;if(!t)return console.warn("Web Audio API is not supported by this browser. Consider upgrading to the latest version"),null;e._audioContext=new t}return e._audioContext},enumerable:!1,configurable:!0}),e.prototype.playBellSound=function(){var t=e.audioContext;if(t){var r=t.createBufferSource();t.decodeAudioData(this._base64ToArrayBuffer(this._removeMimeType(this._optionsService.options.bellSound)),(function(e){r.buffer=e,r.connect(t.destination),r.start(0)}))}},e.prototype._base64ToArrayBuffer=function(e){for(var t=window.atob(e),r=t.length,i=new Uint8Array(r),n=0;n{Object.defineProperty(t,"__esModule",{value:!0}),t.CircularList=void 0;var i=r(8460),n=function(){function e(e){this._maxLength=e,this.onDeleteEmitter=new i.EventEmitter,this.onInsertEmitter=new i.EventEmitter,this.onTrimEmitter=new i.EventEmitter,this._array=new Array(this._maxLength),this._startIndex=0,this._length=0}return Object.defineProperty(e.prototype,"onDelete",{get:function(){return this.onDeleteEmitter.event},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onInsert",{get:function(){return this.onInsertEmitter.event},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"onTrim",{get:function(){return this.onTrimEmitter.event},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"maxLength",{get:function(){return this._maxLength},set:function(e){if(this._maxLength!==e){for(var t=new Array(e),r=0;rthis._length)for(var t=this._length;t=e;n--)this._array[this._getCyclicIndex(n+r.length)]=this._array[this._getCyclicIndex(n)];for(n=0;nthis._maxLength){var o=this._length+r.length-this._maxLength;this._startIndex+=o,this._length=this._maxLength,this.onTrimEmitter.fire(o)}else this._length+=r.length},e.prototype.trimStart=function(e){e>this._length&&(e=this._length),this._startIndex+=e,this._length-=e,this.onTrimEmitter.fire(e)},e.prototype.shiftElements=function(e,t,r){if(!(t<=0)){if(e<0||e>=this._length)throw new Error("start argument out of range");if(e+r<0)throw new Error("Cannot shift elements in list beyond index 0");if(r>0){for(var i=t-1;i>=0;i--)this.set(e+i+r,this.get(e+i));var n=e+t+r-this._length;if(n>0)for(this._length+=n;this._length>this._maxLength;)this._length--,this._startIndex++,this.onTrimEmitter.fire(1)}else for(i=0;i{Object.defineProperty(t,"__esModule",{value:!0}),t.clone=void 0,t.clone=function e(t,r){if(void 0===r&&(r=5),"object"!=typeof t)return t;var i=Array.isArray(t)?[]:{};for(var n in t)i[n]=r<=1?t[n]:t[n]?e(t[n],r-1):t[n];return i}},8969:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.CoreTerminal=void 0;var o=r(844),s=r(2585),a=r(4348),c=r(7866),l=r(744),h=r(7302),u=r(6975),f=r(8460),_=r(1753),d=r(3730),p=r(1480),v=r(7994),g=r(9282),y=r(5435),b=r(5981),S=function(e){function t(t){var r=e.call(this)||this;return r._onBinary=new f.EventEmitter,r._onData=new f.EventEmitter,r._onLineFeed=new f.EventEmitter,r._onResize=new f.EventEmitter,r._onScroll=new f.EventEmitter,r._instantiationService=new a.InstantiationService,r.optionsService=new h.OptionsService(t),r._instantiationService.setService(s.IOptionsService,r.optionsService),r._bufferService=r.register(r._instantiationService.createInstance(l.BufferService)),r._instantiationService.setService(s.IBufferService,r._bufferService),r._logService=r._instantiationService.createInstance(c.LogService),r._instantiationService.setService(s.ILogService,r._logService),r._coreService=r.register(r._instantiationService.createInstance(u.CoreService,(function(){return r.scrollToBottom()}))),r._instantiationService.setService(s.ICoreService,r._coreService),r._coreMouseService=r._instantiationService.createInstance(_.CoreMouseService),r._instantiationService.setService(s.ICoreMouseService,r._coreMouseService),r._dirtyRowService=r._instantiationService.createInstance(d.DirtyRowService),r._instantiationService.setService(s.IDirtyRowService,r._dirtyRowService),r.unicodeService=r._instantiationService.createInstance(p.UnicodeService),r._instantiationService.setService(s.IUnicodeService,r.unicodeService),r._charsetService=r._instantiationService.createInstance(v.CharsetService),r._instantiationService.setService(s.ICharsetService,r._charsetService),r._inputHandler=new y.InputHandler(r._bufferService,r._charsetService,r._coreService,r._dirtyRowService,r._logService,r.optionsService,r._coreMouseService,r.unicodeService),r.register(f.forwardEvent(r._inputHandler.onLineFeed,r._onLineFeed)),r.register(r._inputHandler),r.register(f.forwardEvent(r._bufferService.onResize,r._onResize)),r.register(f.forwardEvent(r._coreService.onData,r._onData)),r.register(f.forwardEvent(r._coreService.onBinary,r._onBinary)),r.register(r.optionsService.onOptionChange((function(e){return r._updateOptions(e)}))),r._writeBuffer=new b.WriteBuffer((function(e){return r._inputHandler.parse(e)})),r}return n(t,e),Object.defineProperty(t.prototype,"onBinary",{get:function(){return this._onBinary.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onData",{get:function(){return this._onData.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onLineFeed",{get:function(){return this._onLineFeed.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onResize",{get:function(){return this._onResize.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onScroll",{get:function(){return this._onScroll.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"cols",{get:function(){return this._bufferService.cols},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"rows",{get:function(){return this._bufferService.rows},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"buffers",{get:function(){return this._bufferService.buffers},enumerable:!1,configurable:!0}),t.prototype.dispose=function(){var t;this._isDisposed||(e.prototype.dispose.call(this),null===(t=this._windowsMode)||void 0===t||t.dispose(),this._windowsMode=void 0)},t.prototype.write=function(e,t){this._writeBuffer.write(e,t)},t.prototype.writeSync=function(e){this._writeBuffer.writeSync(e)},t.prototype.resize=function(e,t){isNaN(e)||isNaN(t)||(e=Math.max(e,l.MINIMUM_COLS),t=Math.max(t,l.MINIMUM_ROWS),this._bufferService.resize(e,t))},t.prototype.scroll=function(e,t){void 0===t&&(t=!1);var r,i=this._bufferService.buffer;(r=this._cachedBlankLine)&&r.length===this.cols&&r.getFg(0)===e.fg&&r.getBg(0)===e.bg||(r=i.getBlankLine(e,t),this._cachedBlankLine=r),r.isWrapped=t;var n=i.ybase+i.scrollTop,o=i.ybase+i.scrollBottom;if(0===i.scrollTop){var s=i.lines.isFull;o===i.lines.length-1?s?i.lines.recycle().copyFrom(r):i.lines.push(r.clone()):i.lines.splice(o+1,0,r.clone()),s?this._bufferService.isUserScrolling&&(i.ydisp=Math.max(i.ydisp-1,0)):(i.ybase++,this._bufferService.isUserScrolling||i.ydisp++)}else{var a=o-n+1;i.lines.shiftElements(n+1,a-1,-1),i.lines.set(o,r.clone())}this._bufferService.isUserScrolling||(i.ydisp=i.ybase),this._dirtyRowService.markRangeDirty(i.scrollTop,i.scrollBottom),this._onScroll.fire(i.ydisp)},t.prototype.scrollLines=function(e,t){var r=this._bufferService.buffer;if(e<0){if(0===r.ydisp)return;this._bufferService.isUserScrolling=!0}else e+r.ydisp>=r.ybase&&(this._bufferService.isUserScrolling=!1);var i=r.ydisp;r.ydisp=Math.max(Math.min(r.ydisp+e,r.ybase),0),i!==r.ydisp&&(t||this._onScroll.fire(r.ydisp))},t.prototype.scrollPages=function(e){this.scrollLines(e*(this.rows-1))},t.prototype.scrollToTop=function(){this.scrollLines(-this._bufferService.buffer.ydisp)},t.prototype.scrollToBottom=function(){this.scrollLines(this._bufferService.buffer.ybase-this._bufferService.buffer.ydisp)},t.prototype.scrollToLine=function(e){var t=e-this._bufferService.buffer.ydisp;0!==t&&this.scrollLines(t)},t.prototype.addEscHandler=function(e,t){return this._inputHandler.addEscHandler(e,t)},t.prototype.addDcsHandler=function(e,t){return this._inputHandler.addDcsHandler(e,t)},t.prototype.addCsiHandler=function(e,t){return this._inputHandler.addCsiHandler(e,t)},t.prototype.addOscHandler=function(e,t){return this._inputHandler.addOscHandler(e,t)},t.prototype._setup=function(){this.optionsService.options.windowsMode&&this._enableWindowsMode()},t.prototype.reset=function(){this._inputHandler.reset(),this._bufferService.reset(),this._charsetService.reset(),this._coreService.reset(),this._coreMouseService.reset()},t.prototype._updateOptions=function(e){var t;switch(e){case"scrollback":this.buffers.resize(this.cols,this.rows);break;case"windowsMode":this.optionsService.options.windowsMode?this._enableWindowsMode():(null===(t=this._windowsMode)||void 0===t||t.dispose(),this._windowsMode=void 0)}},t.prototype._enableWindowsMode=function(){var e=this;if(!this._windowsMode){var t=[];t.push(this.onLineFeed(g.updateWindowsModeWrappedState.bind(null,this._bufferService))),t.push(this.addCsiHandler({final:"H"},(function(){return g.updateWindowsModeWrappedState(e._bufferService),!1}))),this._windowsMode={dispose:function(){for(var e=0,r=t;e{Object.defineProperty(t,"__esModule",{value:!0}),t.forwardEvent=t.EventEmitter=void 0;var r=function(){function e(){this._listeners=[],this._disposed=!1}return Object.defineProperty(e.prototype,"event",{get:function(){var e=this;return this._event||(this._event=function(t){return e._listeners.push(t),{dispose:function(){if(!e._disposed)for(var r=0;r24)return t.setWinLines||!1;switch(e){case 1:return!!t.restoreWin;case 2:return!!t.minimizeWin;case 3:return!!t.setWinPosition;case 4:return!!t.setWinSizePixels;case 5:return!!t.raiseWin;case 6:return!!t.lowerWin;case 7:return!!t.refreshWin;case 8:return!!t.setWinSizeChars;case 9:return!!t.maximizeWin;case 10:return!!t.fullscreenWin;case 11:return!!t.getWinState;case 13:return!!t.getWinPosition;case 14:return!!t.getWinSizePixels;case 15:return!!t.getScreenSizePixels;case 16:return!!t.getCellSizePixels;case 18:return!!t.getWinSizeChars;case 19:return!!t.getScreenSizeChars;case 20:return!!t.getIconTitle;case 21:return!!t.getWinTitle;case 22:return!!t.pushTitle;case 23:return!!t.popTitle;case 24:return!!t.setWinLines}return!1}!function(e){e[e.GET_WIN_SIZE_PIXELS=0]="GET_WIN_SIZE_PIXELS",e[e.GET_CELL_SIZE_PIXELS=1]="GET_CELL_SIZE_PIXELS"}(o=t.WindowsOptionsReportType||(t.WindowsOptionsReportType={}));var C=function(){function e(e,t,r,i){this._bufferService=e,this._coreService=t,this._logService=r,this._optionsService=i,this._data=new Uint32Array(0)}return e.prototype.hook=function(e){this._data=new Uint32Array(0)},e.prototype.put=function(e,t,r){this._data=h.concat(this._data,e.subarray(t,r))},e.prototype.unhook=function(e){if(!e)return this._data=new Uint32Array(0),!0;var t=u.utf32ToString(this._data);switch(this._data=new Uint32Array(0),t){case'"q':this._coreService.triggerDataEvent(s.C0.ESC+'P1$r0"q'+s.C0.ESC+"\\");break;case'"p':this._coreService.triggerDataEvent(s.C0.ESC+'P1$r61;1"p'+s.C0.ESC+"\\");break;case"r":var r=this._bufferService.buffer.scrollTop+1+";"+(this._bufferService.buffer.scrollBottom+1)+"r";this._coreService.triggerDataEvent(s.C0.ESC+"P1$r"+r+s.C0.ESC+"\\");break;case"m":this._coreService.triggerDataEvent(s.C0.ESC+"P1$r0m"+s.C0.ESC+"\\");break;case" q":var i={block:2,underline:4,bar:6}[this._optionsService.options.cursorStyle];i-=this._optionsService.options.cursorBlink?1:0,this._coreService.triggerDataEvent(s.C0.ESC+"P1$r"+i+" q"+s.C0.ESC+"\\");break;default:this._logService.debug("Unknown DCS $q %s",t),this._coreService.triggerDataEvent(s.C0.ESC+"P0$r"+s.C0.ESC+"\\")}return!0},e}(),w=function(e){function t(t,r,i,n,o,l,h,d,v){void 0===v&&(v=new c.EscapeSequenceParser);var y=e.call(this)||this;y._bufferService=t,y._charsetService=r,y._coreService=i,y._dirtyRowService=n,y._logService=o,y._optionsService=l,y._coreMouseService=h,y._unicodeService=d,y._parser=v,y._parseBuffer=new Uint32Array(4096),y._stringDecoder=new u.StringToUtf32,y._utf8Decoder=new u.Utf8ToUtf32,y._workCell=new p.CellData,y._windowTitle="",y._iconName="",y._windowTitleStack=[],y._iconNameStack=[],y._curAttrData=f.DEFAULT_ATTR_DATA.clone(),y._eraseAttrDataInternal=f.DEFAULT_ATTR_DATA.clone(),y._onRequestBell=new _.EventEmitter,y._onRequestRefreshRows=new _.EventEmitter,y._onRequestReset=new _.EventEmitter,y._onRequestScroll=new _.EventEmitter,y._onRequestSyncScrollBar=new _.EventEmitter,y._onRequestWindowsOptionsReport=new _.EventEmitter,y._onA11yChar=new _.EventEmitter,y._onA11yTab=new _.EventEmitter,y._onCursorMove=new _.EventEmitter,y._onLineFeed=new _.EventEmitter,y._onScroll=new _.EventEmitter,y._onTitleChange=new _.EventEmitter,y._onAnsiColorChange=new _.EventEmitter,y.register(y._parser),y._parser.setCsiHandlerFallback((function(e,t){y._logService.debug("Unknown CSI code: ",{identifier:y._parser.identToString(e),params:t.toArray()})})),y._parser.setEscHandlerFallback((function(e){y._logService.debug("Unknown ESC code: ",{identifier:y._parser.identToString(e)})})),y._parser.setExecuteHandlerFallback((function(e){y._logService.debug("Unknown EXECUTE code: ",{code:e})})),y._parser.setOscHandlerFallback((function(e,t,r){y._logService.debug("Unknown OSC code: ",{identifier:e,action:t,data:r})})),y._parser.setDcsHandlerFallback((function(e,t,r){"HOOK"===t&&(r=r.toArray()),y._logService.debug("Unknown DCS code: ",{identifier:y._parser.identToString(e),action:t,payload:r})})),y._parser.setPrintHandler((function(e,t,r){return y.print(e,t,r)})),y._parser.registerCsiHandler({final:"@"},(function(e){return y.insertChars(e)})),y._parser.registerCsiHandler({intermediates:" ",final:"@"},(function(e){return y.scrollLeft(e)})),y._parser.registerCsiHandler({final:"A"},(function(e){return y.cursorUp(e)})),y._parser.registerCsiHandler({intermediates:" ",final:"A"},(function(e){return y.scrollRight(e)})),y._parser.registerCsiHandler({final:"B"},(function(e){return y.cursorDown(e)})),y._parser.registerCsiHandler({final:"C"},(function(e){return y.cursorForward(e)})),y._parser.registerCsiHandler({final:"D"},(function(e){return y.cursorBackward(e)})),y._parser.registerCsiHandler({final:"E"},(function(e){return y.cursorNextLine(e)})),y._parser.registerCsiHandler({final:"F"},(function(e){return y.cursorPrecedingLine(e)})),y._parser.registerCsiHandler({final:"G"},(function(e){return y.cursorCharAbsolute(e)})),y._parser.registerCsiHandler({final:"H"},(function(e){return y.cursorPosition(e)})),y._parser.registerCsiHandler({final:"I"},(function(e){return y.cursorForwardTab(e)})),y._parser.registerCsiHandler({final:"J"},(function(e){return y.eraseInDisplay(e)})),y._parser.registerCsiHandler({prefix:"?",final:"J"},(function(e){return y.eraseInDisplay(e)})),y._parser.registerCsiHandler({final:"K"},(function(e){return y.eraseInLine(e)})),y._parser.registerCsiHandler({prefix:"?",final:"K"},(function(e){return y.eraseInLine(e)})),y._parser.registerCsiHandler({final:"L"},(function(e){return y.insertLines(e)})),y._parser.registerCsiHandler({final:"M"},(function(e){return y.deleteLines(e)})),y._parser.registerCsiHandler({final:"P"},(function(e){return y.deleteChars(e)})),y._parser.registerCsiHandler({final:"S"},(function(e){return y.scrollUp(e)})),y._parser.registerCsiHandler({final:"T"},(function(e){return y.scrollDown(e)})),y._parser.registerCsiHandler({final:"X"},(function(e){return y.eraseChars(e)})),y._parser.registerCsiHandler({final:"Z"},(function(e){return y.cursorBackwardTab(e)})),y._parser.registerCsiHandler({final:"`"},(function(e){return y.charPosAbsolute(e)})),y._parser.registerCsiHandler({final:"a"},(function(e){return y.hPositionRelative(e)})),y._parser.registerCsiHandler({final:"b"},(function(e){return y.repeatPrecedingCharacter(e)})),y._parser.registerCsiHandler({final:"c"},(function(e){return y.sendDeviceAttributesPrimary(e)})),y._parser.registerCsiHandler({prefix:">",final:"c"},(function(e){return y.sendDeviceAttributesSecondary(e)})),y._parser.registerCsiHandler({final:"d"},(function(e){return y.linePosAbsolute(e)})),y._parser.registerCsiHandler({final:"e"},(function(e){return y.vPositionRelative(e)})),y._parser.registerCsiHandler({final:"f"},(function(e){return y.hVPosition(e)})),y._parser.registerCsiHandler({final:"g"},(function(e){return y.tabClear(e)})),y._parser.registerCsiHandler({final:"h"},(function(e){return y.setMode(e)})),y._parser.registerCsiHandler({prefix:"?",final:"h"},(function(e){return y.setModePrivate(e)})),y._parser.registerCsiHandler({final:"l"},(function(e){return y.resetMode(e)})),y._parser.registerCsiHandler({prefix:"?",final:"l"},(function(e){return y.resetModePrivate(e)})),y._parser.registerCsiHandler({final:"m"},(function(e){return y.charAttributes(e)})),y._parser.registerCsiHandler({final:"n"},(function(e){return y.deviceStatus(e)})),y._parser.registerCsiHandler({prefix:"?",final:"n"},(function(e){return y.deviceStatusPrivate(e)})),y._parser.registerCsiHandler({intermediates:"!",final:"p"},(function(e){return y.softReset(e)})),y._parser.registerCsiHandler({intermediates:" ",final:"q"},(function(e){return y.setCursorStyle(e)})),y._parser.registerCsiHandler({final:"r"},(function(e){return y.setScrollRegion(e)})),y._parser.registerCsiHandler({final:"s"},(function(e){return y.saveCursor(e)})),y._parser.registerCsiHandler({final:"t"},(function(e){return y.windowOptions(e)})),y._parser.registerCsiHandler({final:"u"},(function(e){return y.restoreCursor(e)})),y._parser.registerCsiHandler({intermediates:"'",final:"}"},(function(e){return y.insertColumns(e)})),y._parser.registerCsiHandler({intermediates:"'",final:"~"},(function(e){return y.deleteColumns(e)})),y._parser.setExecuteHandler(s.C0.BEL,(function(){return y.bell()})),y._parser.setExecuteHandler(s.C0.LF,(function(){return y.lineFeed()})),y._parser.setExecuteHandler(s.C0.VT,(function(){return y.lineFeed()})),y._parser.setExecuteHandler(s.C0.FF,(function(){return y.lineFeed()})),y._parser.setExecuteHandler(s.C0.CR,(function(){return y.carriageReturn()})),y._parser.setExecuteHandler(s.C0.BS,(function(){return y.backspace()})),y._parser.setExecuteHandler(s.C0.HT,(function(){return y.tab()})),y._parser.setExecuteHandler(s.C0.SO,(function(){return y.shiftOut()})),y._parser.setExecuteHandler(s.C0.SI,(function(){return y.shiftIn()})),y._parser.setExecuteHandler(s.C1.IND,(function(){return y.index()})),y._parser.setExecuteHandler(s.C1.NEL,(function(){return y.nextLine()})),y._parser.setExecuteHandler(s.C1.HTS,(function(){return y.tabSet()})),y._parser.registerOscHandler(0,new g.OscHandler((function(e){return y.setTitle(e),y.setIconName(e),!0}))),y._parser.registerOscHandler(1,new g.OscHandler((function(e){return y.setIconName(e)}))),y._parser.registerOscHandler(2,new g.OscHandler((function(e){return y.setTitle(e)}))),y._parser.registerOscHandler(4,new g.OscHandler((function(e){return y.setAnsiColor(e)}))),y._parser.registerEscHandler({final:"7"},(function(){return y.saveCursor()})),y._parser.registerEscHandler({final:"8"},(function(){return y.restoreCursor()})),y._parser.registerEscHandler({final:"D"},(function(){return y.index()})),y._parser.registerEscHandler({final:"E"},(function(){return y.nextLine()})),y._parser.registerEscHandler({final:"H"},(function(){return y.tabSet()})),y._parser.registerEscHandler({final:"M"},(function(){return y.reverseIndex()})),y._parser.registerEscHandler({final:"="},(function(){return y.keypadApplicationMode()})),y._parser.registerEscHandler({final:">"},(function(){return y.keypadNumericMode()})),y._parser.registerEscHandler({final:"c"},(function(){return y.fullReset()})),y._parser.registerEscHandler({final:"n"},(function(){return y.setgLevel(2)})),y._parser.registerEscHandler({final:"o"},(function(){return y.setgLevel(3)})),y._parser.registerEscHandler({final:"|"},(function(){return y.setgLevel(3)})),y._parser.registerEscHandler({final:"}"},(function(){return y.setgLevel(2)})),y._parser.registerEscHandler({final:"~"},(function(){return y.setgLevel(1)})),y._parser.registerEscHandler({intermediates:"%",final:"@"},(function(){return y.selectDefaultCharset()})),y._parser.registerEscHandler({intermediates:"%",final:"G"},(function(){return y.selectDefaultCharset()}));var b=function(e){S._parser.registerEscHandler({intermediates:"(",final:e},(function(){return y.selectCharset("("+e)})),S._parser.registerEscHandler({intermediates:")",final:e},(function(){return y.selectCharset(")"+e)})),S._parser.registerEscHandler({intermediates:"*",final:e},(function(){return y.selectCharset("*"+e)})),S._parser.registerEscHandler({intermediates:"+",final:e},(function(){return y.selectCharset("+"+e)})),S._parser.registerEscHandler({intermediates:"-",final:e},(function(){return y.selectCharset("-"+e)})),S._parser.registerEscHandler({intermediates:".",final:e},(function(){return y.selectCharset("."+e)})),S._parser.registerEscHandler({intermediates:"/",final:e},(function(){return y.selectCharset("/"+e)}))},S=this;for(var m in a.CHARSETS)b(m);return y._parser.registerEscHandler({intermediates:"#",final:"8"},(function(){return y.screenAlignmentPattern()})),y._parser.setErrorHandler((function(e){return y._logService.error("Parsing error: ",e),e})),y._parser.registerDcsHandler({intermediates:"$",final:"q"},new C(y._bufferService,y._coreService,y._logService,y._optionsService)),y}return n(t,e),Object.defineProperty(t.prototype,"onRequestBell",{get:function(){return this._onRequestBell.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRequestRefreshRows",{get:function(){return this._onRequestRefreshRows.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRequestReset",{get:function(){return this._onRequestReset.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRequestScroll",{get:function(){return this._onRequestScroll.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRequestSyncScrollBar",{get:function(){return this._onRequestSyncScrollBar.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onRequestWindowsOptionsReport",{get:function(){return this._onRequestWindowsOptionsReport.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onA11yChar",{get:function(){return this._onA11yChar.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onA11yTab",{get:function(){return this._onA11yTab.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onCursorMove",{get:function(){return this._onCursorMove.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onLineFeed",{get:function(){return this._onLineFeed.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onScroll",{get:function(){return this._onScroll.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onTitleChange",{get:function(){return this._onTitleChange.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onAnsiColorChange",{get:function(){return this._onAnsiColorChange.event},enumerable:!1,configurable:!0}),t.prototype.dispose=function(){e.prototype.dispose.call(this)},t.prototype.parse=function(e){var t=this._bufferService.buffer,r=t.x,i=t.y;if(this._logService.debug("parsing data",e),this._parseBuffer.lengthS)for(var n=0;n0&&2===_.getWidth(o.x-1)&&_.setCellFromCodePoint(o.x-1,0,1,f.fg,f.bg,f.extended);for(var p=t;p=c)if(l){for(;o.x=this._bufferService.rows&&(o.y=this._bufferService.rows-1),o.lines.get(o.ybase+o.y).isWrapped=!0),_=o.lines.get(o.ybase+o.y)}else if(o.x=c-1,2===n)continue;if(h&&(_.insertCells(o.x,n,o.getNullCell(f),f),2===_.getWidth(c-1)&&_.setCellFromCodePoint(c-1,d.NULL_CELL_CODE,d.NULL_CELL_WIDTH,f.fg,f.bg,f.extended)),_.setCellFromCodePoint(o.x++,i,n,f.fg,f.bg,f.extended),n>0)for(;--n;)_.setCellFromCodePoint(o.x++,0,0,f.fg,f.bg,f.extended)}else _.getWidth(o.x-1)?_.addCodepointToCell(o.x-1,i):_.addCodepointToCell(o.x-2,i)}r-t>0&&(_.loadCell(o.x-1,this._workCell),2===this._workCell.getWidth()||this._workCell.getCode()>65535?this._parser.precedingCodepoint=0:this._workCell.isCombined()?this._parser.precedingCodepoint=this._workCell.getChars().charCodeAt(0):this._parser.precedingCodepoint=this._workCell.content),o.x0&&0===_.getWidth(o.x)&&!_.hasContent(o.x)&&_.setCellFromCodePoint(o.x,0,1,f.fg,f.bg,f.extended),this._dirtyRowService.markDirty(o.y)},t.prototype.addCsiHandler=function(e,t){var r=this;return"t"!==e.final||e.prefix||e.intermediates?this._parser.registerCsiHandler(e,t):this._parser.registerCsiHandler(e,(function(e){return!m(e.params[0],r._optionsService.options.windowOptions)||t(e)}))},t.prototype.addDcsHandler=function(e,t){return this._parser.registerDcsHandler(e,new y.DcsHandler(t))},t.prototype.addEscHandler=function(e,t){return this._parser.registerEscHandler(e,t)},t.prototype.addOscHandler=function(e,t){return this._parser.registerOscHandler(e,new g.OscHandler(t))},t.prototype.bell=function(){return this._onRequestBell.fire(),!0},t.prototype.lineFeed=function(){var e=this._bufferService.buffer;return this._dirtyRowService.markDirty(e.y),this._optionsService.options.convertEol&&(e.x=0),e.y++,e.y===e.scrollBottom+1?(e.y--,this._onRequestScroll.fire(this._eraseAttrData())):e.y>=this._bufferService.rows&&(e.y=this._bufferService.rows-1),e.x>=this._bufferService.cols&&e.x--,this._dirtyRowService.markDirty(e.y),this._onLineFeed.fire(),!0},t.prototype.carriageReturn=function(){return this._bufferService.buffer.x=0,!0},t.prototype.backspace=function(){var e,t=this._bufferService.buffer;if(!this._coreService.decPrivateModes.reverseWraparound)return this._restrictCursor(),t.x>0&&t.x--,!0;if(this._restrictCursor(this._bufferService.cols),t.x>0)t.x--;else if(0===t.x&&t.y>t.scrollTop&&t.y<=t.scrollBottom&&(null===(e=t.lines.get(t.ybase+t.y))||void 0===e?void 0:e.isWrapped)){t.lines.get(t.ybase+t.y).isWrapped=!1,t.y--,t.x=this._bufferService.cols-1;var r=t.lines.get(t.ybase+t.y);r.hasWidth(t.x)&&!r.hasContent(t.x)&&t.x--}return this._restrictCursor(),!0},t.prototype.tab=function(){if(this._bufferService.buffer.x>=this._bufferService.cols)return!0;var e=this._bufferService.buffer.x;return this._bufferService.buffer.x=this._bufferService.buffer.nextStop(),this._optionsService.options.screenReaderMode&&this._onA11yTab.fire(this._bufferService.buffer.x-e),!0},t.prototype.shiftOut=function(){return this._charsetService.setgLevel(1),!0},t.prototype.shiftIn=function(){return this._charsetService.setgLevel(0),!0},t.prototype._restrictCursor=function(e){void 0===e&&(e=this._bufferService.cols-1),this._bufferService.buffer.x=Math.min(e,Math.max(0,this._bufferService.buffer.x)),this._bufferService.buffer.y=this._coreService.decPrivateModes.origin?Math.min(this._bufferService.buffer.scrollBottom,Math.max(this._bufferService.buffer.scrollTop,this._bufferService.buffer.y)):Math.min(this._bufferService.rows-1,Math.max(0,this._bufferService.buffer.y)),this._dirtyRowService.markDirty(this._bufferService.buffer.y)},t.prototype._setCursor=function(e,t){this._dirtyRowService.markDirty(this._bufferService.buffer.y),this._coreService.decPrivateModes.origin?(this._bufferService.buffer.x=e,this._bufferService.buffer.y=this._bufferService.buffer.scrollTop+t):(this._bufferService.buffer.x=e,this._bufferService.buffer.y=t),this._restrictCursor(),this._dirtyRowService.markDirty(this._bufferService.buffer.y)},t.prototype._moveCursor=function(e,t){this._restrictCursor(),this._setCursor(this._bufferService.buffer.x+e,this._bufferService.buffer.y+t)},t.prototype.cursorUp=function(e){var t=this._bufferService.buffer.y-this._bufferService.buffer.scrollTop;return t>=0?this._moveCursor(0,-Math.min(t,e.params[0]||1)):this._moveCursor(0,-(e.params[0]||1)),!0},t.prototype.cursorDown=function(e){var t=this._bufferService.buffer.scrollBottom-this._bufferService.buffer.y;return t>=0?this._moveCursor(0,Math.min(t,e.params[0]||1)):this._moveCursor(0,e.params[0]||1),!0},t.prototype.cursorForward=function(e){return this._moveCursor(e.params[0]||1,0),!0},t.prototype.cursorBackward=function(e){return this._moveCursor(-(e.params[0]||1),0),!0},t.prototype.cursorNextLine=function(e){return this.cursorDown(e),this._bufferService.buffer.x=0,!0},t.prototype.cursorPrecedingLine=function(e){return this.cursorUp(e),this._bufferService.buffer.x=0,!0},t.prototype.cursorCharAbsolute=function(e){return this._setCursor((e.params[0]||1)-1,this._bufferService.buffer.y),!0},t.prototype.cursorPosition=function(e){return this._setCursor(e.length>=2?(e.params[1]||1)-1:0,(e.params[0]||1)-1),!0},t.prototype.charPosAbsolute=function(e){return this._setCursor((e.params[0]||1)-1,this._bufferService.buffer.y),!0},t.prototype.hPositionRelative=function(e){return this._moveCursor(e.params[0]||1,0),!0},t.prototype.linePosAbsolute=function(e){return this._setCursor(this._bufferService.buffer.x,(e.params[0]||1)-1),!0},t.prototype.vPositionRelative=function(e){return this._moveCursor(0,e.params[0]||1),!0},t.prototype.hVPosition=function(e){return this.cursorPosition(e),!0},t.prototype.tabClear=function(e){var t=e.params[0];return 0===t?delete this._bufferService.buffer.tabs[this._bufferService.buffer.x]:3===t&&(this._bufferService.buffer.tabs={}),!0},t.prototype.cursorForwardTab=function(e){if(this._bufferService.buffer.x>=this._bufferService.cols)return!0;for(var t=e.params[0]||1;t--;)this._bufferService.buffer.x=this._bufferService.buffer.nextStop();return!0},t.prototype.cursorBackwardTab=function(e){if(this._bufferService.buffer.x>=this._bufferService.cols)return!0;for(var t=e.params[0]||1,r=this._bufferService.buffer;t--;)r.x=r.prevStop();return!0},t.prototype._eraseInBufferLine=function(e,t,r,i){void 0===i&&(i=!1);var n=this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase+e);n.replaceCells(t,r,this._bufferService.buffer.getNullCell(this._eraseAttrData()),this._eraseAttrData()),i&&(n.isWrapped=!1)},t.prototype._resetBufferLine=function(e){var t=this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase+e);t.fill(this._bufferService.buffer.getNullCell(this._eraseAttrData())),t.isWrapped=!1},t.prototype.eraseInDisplay=function(e){var t;switch(this._restrictCursor(),e.params[0]){case 0:for(t=this._bufferService.buffer.y,this._dirtyRowService.markDirty(t),this._eraseInBufferLine(t++,this._bufferService.buffer.x,this._bufferService.cols,0===this._bufferService.buffer.x);t=this._bufferService.cols&&(this._bufferService.buffer.lines.get(t+1).isWrapped=!1);t--;)this._resetBufferLine(t);this._dirtyRowService.markDirty(0);break;case 2:for(t=this._bufferService.rows,this._dirtyRowService.markDirty(t-1);t--;)this._resetBufferLine(t);this._dirtyRowService.markDirty(0);break;case 3:var r=this._bufferService.buffer.lines.length-this._bufferService.rows;r>0&&(this._bufferService.buffer.lines.trimStart(r),this._bufferService.buffer.ybase=Math.max(this._bufferService.buffer.ybase-r,0),this._bufferService.buffer.ydisp=Math.max(this._bufferService.buffer.ydisp-r,0),this._onScroll.fire(0))}return!0},t.prototype.eraseInLine=function(e){switch(this._restrictCursor(),e.params[0]){case 0:this._eraseInBufferLine(this._bufferService.buffer.y,this._bufferService.buffer.x,this._bufferService.cols);break;case 1:this._eraseInBufferLine(this._bufferService.buffer.y,0,this._bufferService.buffer.x+1);break;case 2:this._eraseInBufferLine(this._bufferService.buffer.y,0,this._bufferService.cols)}return this._dirtyRowService.markDirty(this._bufferService.buffer.y),!0},t.prototype.insertLines=function(e){this._restrictCursor();var t=e.params[0]||1,r=this._bufferService.buffer;if(r.y>r.scrollBottom||r.yr.scrollBottom||r.yt.scrollBottom||t.yt.scrollBottom||t.yt.scrollBottom||t.yt.scrollBottom||t.y0||(this._is("xterm")||this._is("rxvt-unicode")||this._is("screen")?this._coreService.triggerDataEvent(s.C0.ESC+"[?1;2c"):this._is("linux")&&this._coreService.triggerDataEvent(s.C0.ESC+"[?6c")),!0},t.prototype.sendDeviceAttributesSecondary=function(e){return e.params[0]>0||(this._is("xterm")?this._coreService.triggerDataEvent(s.C0.ESC+"[>0;276;0c"):this._is("rxvt-unicode")?this._coreService.triggerDataEvent(s.C0.ESC+"[>85;95;0c"):this._is("linux")?this._coreService.triggerDataEvent(e.params[0]+"c"):this._is("screen")&&this._coreService.triggerDataEvent(s.C0.ESC+"[>83;40003;0c")),!0},t.prototype._is=function(e){return 0===(this._optionsService.options.termName+"").indexOf(e)},t.prototype.setMode=function(e){for(var t=0;t=2||2===i[1]&&o+n>=5)break;i[1]&&(n=1)}while(++o+t5)&&(e=1),t.extended.underlineStyle=e,t.fg|=268435456,0===e&&(t.fg&=-268435457),t.updateExtended()},t.prototype.charAttributes=function(e){if(1===e.length&&0===e.params[0])return this._curAttrData.fg=f.DEFAULT_ATTR_DATA.fg,this._curAttrData.bg=f.DEFAULT_ATTR_DATA.bg,!0;for(var t,r=e.length,i=this._curAttrData,n=0;n=30&&t<=37?(i.fg&=-50331904,i.fg|=16777216|t-30):t>=40&&t<=47?(i.bg&=-50331904,i.bg|=16777216|t-40):t>=90&&t<=97?(i.fg&=-50331904,i.fg|=16777224|t-90):t>=100&&t<=107?(i.bg&=-50331904,i.bg|=16777224|t-100):0===t?(i.fg=f.DEFAULT_ATTR_DATA.fg,i.bg=f.DEFAULT_ATTR_DATA.bg):1===t?i.fg|=134217728:3===t?i.bg|=67108864:4===t?(i.fg|=268435456,this._processUnderline(e.hasSubParams(n)?e.getSubParams(n)[0]:1,i)):5===t?i.fg|=536870912:7===t?i.fg|=67108864:8===t?i.fg|=1073741824:2===t?i.bg|=134217728:21===t?this._processUnderline(2,i):22===t?(i.fg&=-134217729,i.bg&=-134217729):23===t?i.bg&=-67108865:24===t?i.fg&=-268435457:25===t?i.fg&=-536870913:27===t?i.fg&=-67108865:28===t?i.fg&=-1073741825:39===t?(i.fg&=-67108864,i.fg|=16777215&f.DEFAULT_ATTR_DATA.fg):49===t?(i.bg&=-67108864,i.bg|=16777215&f.DEFAULT_ATTR_DATA.bg):38===t||48===t||58===t?n+=this._extractColor(e,n,i):59===t?(i.extended=i.extended.clone(),i.extended.underlineColor=-1,i.updateExtended()):100===t?(i.fg&=-67108864,i.fg|=16777215&f.DEFAULT_ATTR_DATA.fg,i.bg&=-67108864,i.bg|=16777215&f.DEFAULT_ATTR_DATA.bg):this._logService.debug("Unknown SGR attribute: %d.",t);return!0},t.prototype.deviceStatus=function(e){switch(e.params[0]){case 5:this._coreService.triggerDataEvent(s.C0.ESC+"[0n");break;case 6:var t=this._bufferService.buffer.y+1,r=this._bufferService.buffer.x+1;this._coreService.triggerDataEvent(s.C0.ESC+"["+t+";"+r+"R")}return!0},t.prototype.deviceStatusPrivate=function(e){switch(e.params[0]){case 6:var t=this._bufferService.buffer.y+1,r=this._bufferService.buffer.x+1;this._coreService.triggerDataEvent(s.C0.ESC+"[?"+t+";"+r+"R")}return!0},t.prototype.softReset=function(e){return this._coreService.isCursorHidden=!1,this._onRequestSyncScrollBar.fire(),this._bufferService.buffer.scrollTop=0,this._bufferService.buffer.scrollBottom=this._bufferService.rows-1,this._curAttrData=f.DEFAULT_ATTR_DATA.clone(),this._coreService.reset(),this._charsetService.reset(),this._bufferService.buffer.savedX=0,this._bufferService.buffer.savedY=this._bufferService.buffer.ybase,this._bufferService.buffer.savedCurAttrData.fg=this._curAttrData.fg,this._bufferService.buffer.savedCurAttrData.bg=this._curAttrData.bg,this._bufferService.buffer.savedCharset=this._charsetService.charset,this._coreService.decPrivateModes.origin=!1,!0},t.prototype.setCursorStyle=function(e){var t=e.params[0]||1;switch(t){case 1:case 2:this._optionsService.options.cursorStyle="block";break;case 3:case 4:this._optionsService.options.cursorStyle="underline";break;case 5:case 6:this._optionsService.options.cursorStyle="bar"}var r=t%2==1;return this._optionsService.options.cursorBlink=r,!0},t.prototype.setScrollRegion=function(e){var t,r=e.params[0]||1;return(e.length<2||(t=e.params[1])>this._bufferService.rows||0===t)&&(t=this._bufferService.rows),t>r&&(this._bufferService.buffer.scrollTop=r-1,this._bufferService.buffer.scrollBottom=t-1,this._setCursor(0,0)),!0},t.prototype.windowOptions=function(e){if(!m(e.params[0],this._optionsService.options.windowOptions))return!0;var t=e.length>1?e.params[1]:0;switch(e.params[0]){case 14:2!==t&&this._onRequestWindowsOptionsReport.fire(o.GET_WIN_SIZE_PIXELS);break;case 16:this._onRequestWindowsOptionsReport.fire(o.GET_CELL_SIZE_PIXELS);break;case 18:this._bufferService&&this._coreService.triggerDataEvent(s.C0.ESC+"[8;"+this._bufferService.rows+";"+this._bufferService.cols+"t");break;case 22:0!==t&&2!==t||(this._windowTitleStack.push(this._windowTitle),this._windowTitleStack.length>10&&this._windowTitleStack.shift()),0!==t&&1!==t||(this._iconNameStack.push(this._iconName),this._iconNameStack.length>10&&this._iconNameStack.shift());break;case 23:0!==t&&2!==t||this._windowTitleStack.length&&this.setTitle(this._windowTitleStack.pop()),0!==t&&1!==t||this._iconNameStack.length&&this.setIconName(this._iconNameStack.pop())}return!0},t.prototype.saveCursor=function(e){return this._bufferService.buffer.savedX=this._bufferService.buffer.x,this._bufferService.buffer.savedY=this._bufferService.buffer.ybase+this._bufferService.buffer.y,this._bufferService.buffer.savedCurAttrData.fg=this._curAttrData.fg,this._bufferService.buffer.savedCurAttrData.bg=this._curAttrData.bg,this._bufferService.buffer.savedCharset=this._charsetService.charset,!0},t.prototype.restoreCursor=function(e){return this._bufferService.buffer.x=this._bufferService.buffer.savedX||0,this._bufferService.buffer.y=Math.max(this._bufferService.buffer.savedY-this._bufferService.buffer.ybase,0),this._curAttrData.fg=this._bufferService.buffer.savedCurAttrData.fg,this._curAttrData.bg=this._bufferService.buffer.savedCurAttrData.bg,this._charsetService.charset=this._savedCharset,this._bufferService.buffer.savedCharset&&(this._charsetService.charset=this._bufferService.buffer.savedCharset),this._restrictCursor(),!0},t.prototype.setTitle=function(e){return this._windowTitle=e,this._onTitleChange.fire(e),!0},t.prototype.setIconName=function(e){return this._iconName=e,!0},t.prototype._parseAnsiColorChange=function(e){for(var t,r={colors:[]},i=/(\d+);rgb:([0-9a-f]{2})\/([0-9a-f]{2})\/([0-9a-f]{2})/gi;null!==(t=i.exec(e));)r.colors.push({colorIndex:parseInt(t[1]),red:parseInt(t[2],16),green:parseInt(t[3],16),blue:parseInt(t[4],16)});return 0===r.colors.length?null:r},t.prototype.setAnsiColor=function(e){var t=this._parseAnsiColorChange(e);return t?this._onAnsiColorChange.fire(t):this._logService.warn("Expected format ;rgb:// but got data: "+e),!0},t.prototype.nextLine=function(){return this._bufferService.buffer.x=0,this.index(),!0},t.prototype.keypadApplicationMode=function(){return this._logService.debug("Serial port requested application keypad."),this._coreService.decPrivateModes.applicationKeypad=!0,this._onRequestSyncScrollBar.fire(),!0},t.prototype.keypadNumericMode=function(){return this._logService.debug("Switching back to normal keypad."),this._coreService.decPrivateModes.applicationKeypad=!1,this._onRequestSyncScrollBar.fire(),!0},t.prototype.selectDefaultCharset=function(){return this._charsetService.setgLevel(0),this._charsetService.setgCharset(0,a.DEFAULT_CHARSET),!0},t.prototype.selectCharset=function(e){return 2!==e.length?(this.selectDefaultCharset(),!0):("/"===e[0]||this._charsetService.setgCharset(b[e[0]],a.CHARSETS[e[1]]||a.DEFAULT_CHARSET),!0)},t.prototype.index=function(){this._restrictCursor();var e=this._bufferService.buffer;return this._bufferService.buffer.y++,e.y===e.scrollBottom+1?(e.y--,this._onRequestScroll.fire(this._eraseAttrData())):e.y>=this._bufferService.rows&&(e.y=this._bufferService.rows-1),this._restrictCursor(),!0},t.prototype.tabSet=function(){return this._bufferService.buffer.tabs[this._bufferService.buffer.x]=!0,!0},t.prototype.reverseIndex=function(){this._restrictCursor();var e=this._bufferService.buffer;if(e.y===e.scrollTop){var t=e.scrollBottom-e.scrollTop;e.lines.shiftElements(e.ybase+e.y,t,1),e.lines.set(e.ybase+e.y,e.getBlankLine(this._eraseAttrData())),this._dirtyRowService.markRangeDirty(e.scrollTop,e.scrollBottom)}else e.y--,this._restrictCursor();return!0},t.prototype.fullReset=function(){return this._parser.reset(),this._onRequestReset.fire(),!0},t.prototype.reset=function(){this._curAttrData=f.DEFAULT_ATTR_DATA.clone(),this._eraseAttrDataInternal=f.DEFAULT_ATTR_DATA.clone()},t.prototype._eraseAttrData=function(){return this._eraseAttrDataInternal.bg&=-67108864,this._eraseAttrDataInternal.bg|=67108863&this._curAttrData.bg,this._eraseAttrDataInternal},t.prototype.setgLevel=function(e){return this._charsetService.setgLevel(e),!0},t.prototype.screenAlignmentPattern=function(){var e=new p.CellData;e.content=1<<22|"E".charCodeAt(0),e.fg=this._curAttrData.fg,e.bg=this._curAttrData.bg;var t=this._bufferService.buffer;this._setCursor(0,0);for(var r=0;r{Object.defineProperty(t,"__esModule",{value:!0}),t.getDisposeArrayDisposable=t.disposeArray=t.Disposable=void 0;var r=function(){function e(){this._disposables=[],this._isDisposed=!1}return e.prototype.dispose=function(){this._isDisposed=!0;for(var e=0,t=this._disposables;e{Object.defineProperty(t,"__esModule",{value:!0}),t.isLinux=t.isWindows=t.isIphone=t.isIpad=t.isMac=t.isSafari=t.isFirefox=void 0;var r="undefined"==typeof navigator,i=r?"node":navigator.userAgent,n=r?"node":navigator.platform;t.isFirefox=i.includes("Firefox"),t.isSafari=/^((?!chrome|android).)*safari/i.test(i),t.isMac=["Macintosh","MacIntel","MacPPC","Mac68K"].includes(n),t.isIpad="iPad"===n,t.isIphone="iPhone"===n,t.isWindows=["Windows","Win16","Win32","WinCE"].includes(n),t.isLinux=n.indexOf("Linux")>=0},8273:(e,t)=>{function r(e,t,r,i){if(void 0===r&&(r=0),void 0===i&&(i=e.length),r>=e.length)return e;r=(e.length+r)%e.length,i=i>=e.length?e.length:(e.length+i)%e.length;for(var n=r;n{Object.defineProperty(t,"__esModule",{value:!0}),t.updateWindowsModeWrappedState=void 0;var i=r(643);t.updateWindowsModeWrappedState=function(e){var t=e.buffer.lines.get(e.buffer.ybase+e.buffer.y-1),r=null==t?void 0:t.get(e.cols-1),n=e.buffer.lines.get(e.buffer.ybase+e.buffer.y);n&&r&&(n.isWrapped=r[i.CHAR_DATA_CODE_INDEX]!==i.NULL_CELL_CODE&&r[i.CHAR_DATA_CODE_INDEX]!==i.WHITESPACE_CELL_CODE)}},3734:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.ExtendedAttrs=t.AttributeData=void 0;var r=function(){function e(){this.fg=0,this.bg=0,this.extended=new i}return e.toColorRGB=function(e){return[e>>>16&255,e>>>8&255,255&e]},e.fromColorRGB=function(e){return(255&e[0])<<16|(255&e[1])<<8|255&e[2]},e.prototype.clone=function(){var t=new e;return t.fg=this.fg,t.bg=this.bg,t.extended=this.extended.clone(),t},e.prototype.isInverse=function(){return 67108864&this.fg},e.prototype.isBold=function(){return 134217728&this.fg},e.prototype.isUnderline=function(){return 268435456&this.fg},e.prototype.isBlink=function(){return 536870912&this.fg},e.prototype.isInvisible=function(){return 1073741824&this.fg},e.prototype.isItalic=function(){return 67108864&this.bg},e.prototype.isDim=function(){return 134217728&this.bg},e.prototype.getFgColorMode=function(){return 50331648&this.fg},e.prototype.getBgColorMode=function(){return 50331648&this.bg},e.prototype.isFgRGB=function(){return 50331648==(50331648&this.fg)},e.prototype.isBgRGB=function(){return 50331648==(50331648&this.bg)},e.prototype.isFgPalette=function(){return 16777216==(50331648&this.fg)||33554432==(50331648&this.fg)},e.prototype.isBgPalette=function(){return 16777216==(50331648&this.bg)||33554432==(50331648&this.bg)},e.prototype.isFgDefault=function(){return 0==(50331648&this.fg)},e.prototype.isBgDefault=function(){return 0==(50331648&this.bg)},e.prototype.isAttributeDefault=function(){return 0===this.fg&&0===this.bg},e.prototype.getFgColor=function(){switch(50331648&this.fg){case 16777216:case 33554432:return 255&this.fg;case 50331648:return 16777215&this.fg;default:return-1}},e.prototype.getBgColor=function(){switch(50331648&this.bg){case 16777216:case 33554432:return 255&this.bg;case 50331648:return 16777215&this.bg;default:return-1}},e.prototype.hasExtendedAttrs=function(){return 268435456&this.bg},e.prototype.updateExtended=function(){this.extended.isEmpty()?this.bg&=-268435457:this.bg|=268435456},e.prototype.getUnderlineColor=function(){if(268435456&this.bg&&~this.extended.underlineColor)switch(50331648&this.extended.underlineColor){case 16777216:case 33554432:return 255&this.extended.underlineColor;case 50331648:return 16777215&this.extended.underlineColor;default:return this.getFgColor()}return this.getFgColor()},e.prototype.getUnderlineColorMode=function(){return 268435456&this.bg&&~this.extended.underlineColor?50331648&this.extended.underlineColor:this.getFgColorMode()},e.prototype.isUnderlineColorRGB=function(){return 268435456&this.bg&&~this.extended.underlineColor?50331648==(50331648&this.extended.underlineColor):this.isFgRGB()},e.prototype.isUnderlineColorPalette=function(){return 268435456&this.bg&&~this.extended.underlineColor?16777216==(50331648&this.extended.underlineColor)||33554432==(50331648&this.extended.underlineColor):this.isFgPalette()},e.prototype.isUnderlineColorDefault=function(){return 268435456&this.bg&&~this.extended.underlineColor?0==(50331648&this.extended.underlineColor):this.isFgDefault()},e.prototype.getUnderlineStyle=function(){return 268435456&this.fg?268435456&this.bg?this.extended.underlineStyle:1:0},e}();t.AttributeData=r;var i=function(){function e(e,t){void 0===e&&(e=0),void 0===t&&(t=-1),this.underlineStyle=e,this.underlineColor=t}return e.prototype.clone=function(){return new e(this.underlineStyle,this.underlineColor)},e.prototype.isEmpty=function(){return 0===this.underlineStyle},e}();t.ExtendedAttrs=i},9092:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.BufferStringIterator=t.Buffer=t.MAX_BUFFER_SIZE=void 0;var i=r(6349),n=r(8437),o=r(511),s=r(643),a=r(4634),c=r(4863),l=r(7116),h=r(3734);t.MAX_BUFFER_SIZE=4294967295;var u=function(){function e(e,t,r){this._hasScrollback=e,this._optionsService=t,this._bufferService=r,this.ydisp=0,this.ybase=0,this.y=0,this.x=0,this.savedY=0,this.savedX=0,this.savedCurAttrData=n.DEFAULT_ATTR_DATA.clone(),this.savedCharset=l.DEFAULT_CHARSET,this.markers=[],this._nullCell=o.CellData.fromCharData([0,s.NULL_CELL_CHAR,s.NULL_CELL_WIDTH,s.NULL_CELL_CODE]),this._whitespaceCell=o.CellData.fromCharData([0,s.WHITESPACE_CELL_CHAR,s.WHITESPACE_CELL_WIDTH,s.WHITESPACE_CELL_CODE]),this._cols=this._bufferService.cols,this._rows=this._bufferService.rows,this.lines=new i.CircularList(this._getCorrectBufferLength(this._rows)),this.scrollTop=0,this.scrollBottom=this._rows-1,this.setupTabStops()}return e.prototype.getNullCell=function(e){return e?(this._nullCell.fg=e.fg,this._nullCell.bg=e.bg,this._nullCell.extended=e.extended):(this._nullCell.fg=0,this._nullCell.bg=0,this._nullCell.extended=new h.ExtendedAttrs),this._nullCell},e.prototype.getWhitespaceCell=function(e){return e?(this._whitespaceCell.fg=e.fg,this._whitespaceCell.bg=e.bg,this._whitespaceCell.extended=e.extended):(this._whitespaceCell.fg=0,this._whitespaceCell.bg=0,this._whitespaceCell.extended=new h.ExtendedAttrs),this._whitespaceCell},e.prototype.getBlankLine=function(e,t){return new n.BufferLine(this._bufferService.cols,this.getNullCell(e),t)},Object.defineProperty(e.prototype,"hasScrollback",{get:function(){return this._hasScrollback&&this.lines.maxLength>this._rows},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"isCursorInViewport",{get:function(){var e=this.ybase+this.y-this.ydisp;return e>=0&&et.MAX_BUFFER_SIZE?t.MAX_BUFFER_SIZE:r},e.prototype.fillViewportRows=function(e){if(0===this.lines.length){void 0===e&&(e=n.DEFAULT_ATTR_DATA);for(var t=this._rows;t--;)this.lines.push(this.getBlankLine(e))}},e.prototype.clear=function(){this.ydisp=0,this.ybase=0,this.y=0,this.x=0,this.lines=new i.CircularList(this._getCorrectBufferLength(this._rows)),this.scrollTop=0,this.scrollBottom=this._rows-1,this.setupTabStops()},e.prototype.resize=function(e,t){var r=this.getNullCell(n.DEFAULT_ATTR_DATA),i=this._getCorrectBufferLength(t);if(i>this.lines.maxLength&&(this.lines.maxLength=i),this.lines.length>0){if(this._cols0&&this.lines.length<=this.ybase+this.y+s+1?(this.ybase--,s++,this.ydisp>0&&this.ydisp--):this.lines.push(new n.BufferLine(e,r)));else for(a=this._rows;a>t;a--)this.lines.length>t+this.ybase&&(this.lines.length>this.ybase+this.y+1?this.lines.pop():(this.ybase++,this.ydisp++));if(i0&&(this.lines.trimStart(c),this.ybase=Math.max(this.ybase-c,0),this.ydisp=Math.max(this.ydisp-c,0),this.savedY=Math.max(this.savedY-c,0)),this.lines.maxLength=i}this.x=Math.min(this.x,e-1),this.y=Math.min(this.y,t-1),s&&(this.y+=s),this.savedX=Math.min(this.savedX,e-1),this.scrollTop=0}if(this.scrollBottom=t-1,this._isReflowEnabled&&(this._reflow(e,t),this._cols>e))for(o=0;othis._cols?this._reflowLarger(e,t):this._reflowSmaller(e,t))},e.prototype._reflowLarger=function(e,t){var r=a.reflowLargerGetLinesToRemove(this.lines,this._cols,e,this.ybase+this.y,this.getNullCell(n.DEFAULT_ATTR_DATA));if(r.length>0){var i=a.reflowLargerCreateNewLayout(this.lines,r);a.reflowLargerApplyNewLayout(this.lines,i.layout),this._reflowLargerAdjustViewport(e,t,i.countRemoved)}},e.prototype._reflowLargerAdjustViewport=function(e,t,r){for(var i=this.getNullCell(n.DEFAULT_ATTR_DATA),o=r;o-- >0;)0===this.ybase?(this.y>0&&this.y--,this.lines.length=0;s--){var c=this.lines.get(s);if(!(!c||!c.isWrapped&&c.getTrimmedLength()<=e)){for(var l=[c];c.isWrapped&&s>0;)c=this.lines.get(--s),l.unshift(c);var h=this.ybase+this.y;if(!(h>=s&&h0&&(i.push({start:s+l.length+o,newLines:p}),o+=p.length),l.push.apply(l,p);var y=_.length-1,b=_[y];0===b&&(b=_[--y]);for(var S=l.length-d-1,m=f;S>=0;){var C=Math.min(m,b);if(l[y].copyCellsFrom(l[S],m-C,b-C,C,!0),0==(b-=C)&&(b=_[--y]),0==(m-=C)){S--;var w=Math.max(S,0);m=a.getWrappedLineTrimmedLength(l,w,this._cols)}}for(v=0;v0;)0===this.ybase?this.y0){var L=[],A=[];for(v=0;v=0;v--)if(D&&D.start>k+T){for(var O=D.newLines.length-1;O>=0;O--)this.lines.set(v--,D.newLines[O]);v++,L.push({index:k+1,amount:D.newLines.length}),T+=D.newLines.length,D=i[++x]}else this.lines.set(v,A[k--]);var M=0;for(v=L.length-1;v>=0;v--)L[v].index+=M,this.lines.onInsertEmitter.fire(L[v]),M+=L[v].amount;var P=Math.max(0,R+o-this.lines.maxLength);P>0&&this.lines.onTrimEmitter.fire(P)}},e.prototype.stringIndexToBufferIndex=function(e,t,r){for(void 0===r&&(r=!1);t;){var i=this.lines.get(e);if(!i)return[-1,-1];for(var n=r?i.getTrimmedLength():i.length,o=0;o0&&this.lines.get(t).isWrapped;)t--;for(;r+10;);return e>=this._cols?this._cols-1:e<0?0:e},e.prototype.nextStop=function(e){for(null==e&&(e=this.x);!this.tabs[++e]&&e=this._cols?this._cols-1:e<0?0:e},e.prototype.addMarker=function(e){var t=this,r=new c.Marker(e);return this.markers.push(r),r.register(this.lines.onTrim((function(e){r.line-=e,r.line<0&&r.dispose()}))),r.register(this.lines.onInsert((function(e){r.line>=e.index&&(r.line+=e.amount)}))),r.register(this.lines.onDelete((function(e){r.line>=e.index&&r.linee.index&&(r.line-=e.amount)}))),r.register(r.onDispose((function(){return t._removeMarker(r)}))),r},e.prototype._removeMarker=function(e){this.markers.splice(this.markers.indexOf(e),1)},e.prototype.iterator=function(e,t,r,i,n){return new f(this,e,t,r,i,n)},e}();t.Buffer=u;var f=function(){function e(e,t,r,i,n,o){void 0===r&&(r=0),void 0===i&&(i=e.lines.length),void 0===n&&(n=0),void 0===o&&(o=0),this._buffer=e,this._trimRight=t,this._startIndex=r,this._endIndex=i,this._startOverscan=n,this._endOverscan=o,this._startIndex<0&&(this._startIndex=0),this._endIndex>this._buffer.lines.length&&(this._endIndex=this._buffer.lines.length),this._current=this._startIndex}return e.prototype.hasNext=function(){return this._currentthis._endIndex+this._endOverscan&&(e.last=this._endIndex+this._endOverscan),e.first=Math.max(e.first,0),e.last=Math.min(e.last,this._buffer.lines.length);for(var t="",r=e.first;r<=e.last;++r)t+=this._buffer.translateBufferLineToString(r,this._trimRight);return this._current=e.last+1,{range:e,content:t}},e}();t.BufferStringIterator=f},8437:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.BufferLine=t.DEFAULT_ATTR_DATA=void 0;var i=r(482),n=r(643),o=r(511),s=r(3734);t.DEFAULT_ATTR_DATA=Object.freeze(new s.AttributeData);var a=function(){function e(e,t,r){void 0===r&&(r=!1),this.isWrapped=r,this._combined={},this._extendedAttrs={},this._data=new Uint32Array(3*e);for(var i=t||o.CellData.fromCharData([0,n.NULL_CELL_CHAR,n.NULL_CELL_WIDTH,n.NULL_CELL_CODE]),s=0;s>22,2097152&t?this._combined[e].charCodeAt(this._combined[e].length-1):r]},e.prototype.set=function(e,t){this._data[3*e+1]=t[n.CHAR_DATA_ATTR_INDEX],t[n.CHAR_DATA_CHAR_INDEX].length>1?(this._combined[e]=t[1],this._data[3*e+0]=2097152|e|t[n.CHAR_DATA_WIDTH_INDEX]<<22):this._data[3*e+0]=t[n.CHAR_DATA_CHAR_INDEX].charCodeAt(0)|t[n.CHAR_DATA_WIDTH_INDEX]<<22},e.prototype.getWidth=function(e){return this._data[3*e+0]>>22},e.prototype.hasWidth=function(e){return 12582912&this._data[3*e+0]},e.prototype.getFg=function(e){return this._data[3*e+1]},e.prototype.getBg=function(e){return this._data[3*e+2]},e.prototype.hasContent=function(e){return 4194303&this._data[3*e+0]},e.prototype.getCodePoint=function(e){var t=this._data[3*e+0];return 2097152&t?this._combined[e].charCodeAt(this._combined[e].length-1):2097151&t},e.prototype.isCombined=function(e){return 2097152&this._data[3*e+0]},e.prototype.getString=function(e){var t=this._data[3*e+0];return 2097152&t?this._combined[e]:2097151&t?i.stringFromCodePoint(2097151&t):""},e.prototype.loadCell=function(e,t){var r=3*e;return t.content=this._data[r+0],t.fg=this._data[r+1],t.bg=this._data[r+2],2097152&t.content&&(t.combinedData=this._combined[e]),268435456&t.bg&&(t.extended=this._extendedAttrs[e]),t},e.prototype.setCell=function(e,t){2097152&t.content&&(this._combined[e]=t.combinedData),268435456&t.bg&&(this._extendedAttrs[e]=t.extended),this._data[3*e+0]=t.content,this._data[3*e+1]=t.fg,this._data[3*e+2]=t.bg},e.prototype.setCellFromCodePoint=function(e,t,r,i,n,o){268435456&n&&(this._extendedAttrs[e]=o),this._data[3*e+0]=t|r<<22,this._data[3*e+1]=i,this._data[3*e+2]=n},e.prototype.addCodepointToCell=function(e,t){var r=this._data[3*e+0];2097152&r?this._combined[e]+=i.stringFromCodePoint(t):(2097151&r?(this._combined[e]=i.stringFromCodePoint(2097151&r)+i.stringFromCodePoint(t),r&=-2097152,r|=2097152):r=t|1<<22,this._data[3*e+0]=r)},e.prototype.insertCells=function(e,t,r,i){if((e%=this.length)&&2===this.getWidth(e-1)&&this.setCellFromCodePoint(e-1,0,1,(null==i?void 0:i.fg)||0,(null==i?void 0:i.bg)||0,(null==i?void 0:i.extended)||new s.ExtendedAttrs),t=0;--a)this.setCell(e+t+a,this.loadCell(e+a,n));for(a=0;athis.length){var r=new Uint32Array(3*e);this.length&&(3*e=e&&delete this._combined[o]}}else this._data=new Uint32Array(0),this._combined={};this.length=e}},e.prototype.fill=function(e){this._combined={},this._extendedAttrs={};for(var t=0;t=0;--e)if(4194303&this._data[3*e+0])return e+(this._data[3*e+0]>>22);return 0},e.prototype.copyCellsFrom=function(e,t,r,i,n){var o=e._data;if(n)for(var s=i-1;s>=0;s--)for(var a=0;a<3;a++)this._data[3*(r+s)+a]=o[3*(t+s)+a];else for(s=0;s=t&&(this._combined[l-t+r]=e._combined[l])}},e.prototype.translateToString=function(e,t,r){void 0===e&&(e=!1),void 0===t&&(t=0),void 0===r&&(r=this.length),e&&(r=Math.min(r,this.getTrimmedLength()));for(var o="";t>22||1}return o},e}();t.BufferLine=a},4634:(e,t)=>{function r(e,t,r){if(t===e.length-1)return e[t].getTrimmedLength();var i=!e[t].hasContent(r-1)&&1===e[t].getWidth(r-1),n=2===e[t+1].getWidth(0);return i&&n?r-1:r}Object.defineProperty(t,"__esModule",{value:!0}),t.getWrappedLineTrimmedLength=t.reflowSmallerGetNewLineLengths=t.reflowLargerApplyNewLayout=t.reflowLargerCreateNewLayout=t.reflowLargerGetLinesToRemove=void 0,t.reflowLargerGetLinesToRemove=function(e,t,i,n,o){for(var s=[],a=0;a=a&&n0&&(S>u||0===h[S].getTrimmedLength());S--)b++;b>0&&(s.push(a+h.length-b),s.push(b)),a+=h.length-1}}}return s},t.reflowLargerCreateNewLayout=function(e,t){for(var r=[],i=0,n=t[i],o=0,s=0;sl&&(s-=l,a++);var h=2===e[a].getWidth(s-1);h&&s--;var u=h?i-1:i;n.push(u),c+=u}return n},t.getWrappedLineTrimmedLength=r},5295:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.BufferSet=void 0;var o=r(9092),s=r(8460),a=function(e){function t(t,r){var i=e.call(this)||this;return i._optionsService=t,i._bufferService=r,i._onBufferActivate=i.register(new s.EventEmitter),i.reset(),i}return n(t,e),Object.defineProperty(t.prototype,"onBufferActivate",{get:function(){return this._onBufferActivate.event},enumerable:!1,configurable:!0}),t.prototype.reset=function(){this._normal=new o.Buffer(!0,this._optionsService,this._bufferService),this._normal.fillViewportRows(),this._alt=new o.Buffer(!1,this._optionsService,this._bufferService),this._activeBuffer=this._normal,this.setupTabStops()},Object.defineProperty(t.prototype,"alt",{get:function(){return this._alt},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"active",{get:function(){return this._activeBuffer},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"normal",{get:function(){return this._normal},enumerable:!1,configurable:!0}),t.prototype.activateNormalBuffer=function(){this._activeBuffer!==this._normal&&(this._normal.x=this._alt.x,this._normal.y=this._alt.y,this._alt.clear(),this._activeBuffer=this._normal,this._onBufferActivate.fire({activeBuffer:this._normal,inactiveBuffer:this._alt}))},t.prototype.activateAltBuffer=function(e){this._activeBuffer!==this._alt&&(this._alt.fillViewportRows(e),this._alt.x=this._normal.x,this._alt.y=this._normal.y,this._activeBuffer=this._alt,this._onBufferActivate.fire({activeBuffer:this._alt,inactiveBuffer:this._normal}))},t.prototype.resize=function(e,t){this._normal.resize(e,t),this._alt.resize(e,t)},t.prototype.setupTabStops=function(e){this._normal.setupTabStops(e),this._alt.setupTabStops(e)},t}(r(844).Disposable);t.BufferSet=a},511:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.CellData=void 0;var o=r(482),s=r(643),a=r(3734),c=function(e){function t(){var t=null!==e&&e.apply(this,arguments)||this;return t.content=0,t.fg=0,t.bg=0,t.extended=new a.ExtendedAttrs,t.combinedData="",t}return n(t,e),t.fromCharData=function(e){var r=new t;return r.setFromCharData(e),r},t.prototype.isCombined=function(){return 2097152&this.content},t.prototype.getWidth=function(){return this.content>>22},t.prototype.getChars=function(){return 2097152&this.content?this.combinedData:2097151&this.content?o.stringFromCodePoint(2097151&this.content):""},t.prototype.getCode=function(){return this.isCombined()?this.combinedData.charCodeAt(this.combinedData.length-1):2097151&this.content},t.prototype.setFromCharData=function(e){this.fg=e[s.CHAR_DATA_ATTR_INDEX],this.bg=0;var t=!1;if(e[s.CHAR_DATA_CHAR_INDEX].length>2)t=!0;else if(2===e[s.CHAR_DATA_CHAR_INDEX].length){var r=e[s.CHAR_DATA_CHAR_INDEX].charCodeAt(0);if(55296<=r&&r<=56319){var i=e[s.CHAR_DATA_CHAR_INDEX].charCodeAt(1);56320<=i&&i<=57343?this.content=1024*(r-55296)+i-56320+65536|e[s.CHAR_DATA_WIDTH_INDEX]<<22:t=!0}else t=!0}else this.content=e[s.CHAR_DATA_CHAR_INDEX].charCodeAt(0)|e[s.CHAR_DATA_WIDTH_INDEX]<<22;t&&(this.combinedData=e[s.CHAR_DATA_CHAR_INDEX],this.content=2097152|e[s.CHAR_DATA_WIDTH_INDEX]<<22)},t.prototype.getAsCharData=function(){return[this.fg,this.getChars(),this.getWidth(),this.getCode()]},t}(a.AttributeData);t.CellData=c},643:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.WHITESPACE_CELL_CODE=t.WHITESPACE_CELL_WIDTH=t.WHITESPACE_CELL_CHAR=t.NULL_CELL_CODE=t.NULL_CELL_WIDTH=t.NULL_CELL_CHAR=t.CHAR_DATA_CODE_INDEX=t.CHAR_DATA_WIDTH_INDEX=t.CHAR_DATA_CHAR_INDEX=t.CHAR_DATA_ATTR_INDEX=t.DEFAULT_ATTR=t.DEFAULT_COLOR=void 0,t.DEFAULT_COLOR=256,t.DEFAULT_ATTR=256|t.DEFAULT_COLOR<<9,t.CHAR_DATA_ATTR_INDEX=0,t.CHAR_DATA_CHAR_INDEX=1,t.CHAR_DATA_WIDTH_INDEX=2,t.CHAR_DATA_CODE_INDEX=3,t.NULL_CELL_CHAR="",t.NULL_CELL_WIDTH=1,t.NULL_CELL_CODE=0,t.WHITESPACE_CELL_CHAR=" ",t.WHITESPACE_CELL_WIDTH=1,t.WHITESPACE_CELL_CODE=32},4863:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.Marker=void 0;var o=r(8460),s=function(e){function t(r){var i=e.call(this)||this;return i.line=r,i._id=t._nextId++,i.isDisposed=!1,i._onDispose=new o.EventEmitter,i}return n(t,e),Object.defineProperty(t.prototype,"id",{get:function(){return this._id},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onDispose",{get:function(){return this._onDispose.event},enumerable:!1,configurable:!0}),t.prototype.dispose=function(){this.isDisposed||(this.isDisposed=!0,this.line=-1,this._onDispose.fire(),e.prototype.dispose.call(this))},t._nextId=1,t}(r(844).Disposable);t.Marker=s},7116:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.DEFAULT_CHARSET=t.CHARSETS=void 0,t.CHARSETS={},t.DEFAULT_CHARSET=t.CHARSETS.B,t.CHARSETS[0]={"`":"◆",a:"▒",b:"␉",c:"␌",d:"␍",e:"␊",f:"°",g:"±",h:"␤",i:"␋",j:"┘",k:"┐",l:"┌",m:"└",n:"┼",o:"⎺",p:"⎻",q:"─",r:"⎼",s:"⎽",t:"├",u:"┤",v:"┴",w:"┬",x:"│",y:"≤",z:"≥","{":"π","|":"≠","}":"£","~":"·"},t.CHARSETS.A={"#":"£"},t.CHARSETS.B=void 0,t.CHARSETS[4]={"#":"£","@":"¾","[":"ij","\\":"½","]":"|","{":"¨","|":"f","}":"¼","~":"´"},t.CHARSETS.C=t.CHARSETS[5]={"[":"Ä","\\":"Ö","]":"Å","^":"Ü","`":"é","{":"ä","|":"ö","}":"å","~":"ü"},t.CHARSETS.R={"#":"£","@":"à","[":"°","\\":"ç","]":"§","{":"é","|":"ù","}":"è","~":"¨"},t.CHARSETS.Q={"@":"à","[":"â","\\":"ç","]":"ê","^":"î","`":"ô","{":"é","|":"ù","}":"è","~":"û"},t.CHARSETS.K={"@":"§","[":"Ä","\\":"Ö","]":"Ü","{":"ä","|":"ö","}":"ü","~":"ß"},t.CHARSETS.Y={"#":"£","@":"§","[":"°","\\":"ç","]":"é","`":"ù","{":"à","|":"ò","}":"è","~":"ì"},t.CHARSETS.E=t.CHARSETS[6]={"@":"Ä","[":"Æ","\\":"Ø","]":"Å","^":"Ü","`":"ä","{":"æ","|":"ø","}":"å","~":"ü"},t.CHARSETS.Z={"#":"£","@":"§","[":"¡","\\":"Ñ","]":"¿","{":"°","|":"ñ","}":"ç"},t.CHARSETS.H=t.CHARSETS[7]={"@":"É","[":"Ä","\\":"Ö","]":"Å","^":"Ü","`":"é","{":"ä","|":"ö","}":"å","~":"ü"},t.CHARSETS["="]={"#":"ù","@":"à","[":"é","\\":"ç","]":"ê","^":"î",_:"è","`":"ô","{":"ä","|":"ö","}":"ü","~":"û"}},2584:(e,t)=>{var r,i;Object.defineProperty(t,"__esModule",{value:!0}),t.C1=t.C0=void 0,(i=t.C0||(t.C0={})).NUL="\0",i.SOH="",i.STX="",i.ETX="",i.EOT="",i.ENQ="",i.ACK="",i.BEL="",i.BS="\b",i.HT="\t",i.LF="\n",i.VT="\v",i.FF="\f",i.CR="\r",i.SO="",i.SI="",i.DLE="",i.DC1="",i.DC2="",i.DC3="",i.DC4="",i.NAK="",i.SYN="",i.ETB="",i.CAN="",i.EM="",i.SUB="",i.ESC="",i.FS="",i.GS="",i.RS="",i.US="",i.SP=" ",i.DEL="",(r=t.C1||(t.C1={})).PAD="€",r.HOP="",r.BPH="‚",r.NBH="ƒ",r.IND="„",r.NEL="…",r.SSA="†",r.ESA="‡",r.HTS="ˆ",r.HTJ="‰",r.VTS="Š",r.PLD="‹",r.PLU="Œ",r.RI="",r.SS2="Ž",r.SS3="",r.DCS="",r.PU1="‘",r.PU2="’",r.STS="“",r.CCH="”",r.MW="•",r.SPA="–",r.EPA="—",r.SOS="˜",r.SGCI="™",r.SCI="š",r.CSI="›",r.ST="œ",r.OSC="",r.PM="ž",r.APC="Ÿ"},7399:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.evaluateKeyboardEvent=void 0;var i=r(2584),n={48:["0",")"],49:["1","!"],50:["2","@"],51:["3","#"],52:["4","$"],53:["5","%"],54:["6","^"],55:["7","&"],56:["8","*"],57:["9","("],186:[";",":"],187:["=","+"],188:[",","<"],189:["-","_"],190:[".",">"],191:["/","?"],192:["`","~"],219:["[","{"],220:["\\","|"],221:["]","}"],222:["'",'"']};t.evaluateKeyboardEvent=function(e,t,r,o){var s={type:0,cancel:!1,key:void 0},a=(e.shiftKey?1:0)|(e.altKey?2:0)|(e.ctrlKey?4:0)|(e.metaKey?8:0);switch(e.keyCode){case 0:"UIKeyInputUpArrow"===e.key?s.key=t?i.C0.ESC+"OA":i.C0.ESC+"[A":"UIKeyInputLeftArrow"===e.key?s.key=t?i.C0.ESC+"OD":i.C0.ESC+"[D":"UIKeyInputRightArrow"===e.key?s.key=t?i.C0.ESC+"OC":i.C0.ESC+"[C":"UIKeyInputDownArrow"===e.key&&(s.key=t?i.C0.ESC+"OB":i.C0.ESC+"[B");break;case 8:if(e.shiftKey){s.key=i.C0.BS;break}if(e.altKey){s.key=i.C0.ESC+i.C0.DEL;break}s.key=i.C0.DEL;break;case 9:if(e.shiftKey){s.key=i.C0.ESC+"[Z";break}s.key=i.C0.HT,s.cancel=!0;break;case 13:s.key=e.altKey?i.C0.ESC+i.C0.CR:i.C0.CR,s.cancel=!0;break;case 27:s.key=i.C0.ESC,e.altKey&&(s.key=i.C0.ESC+i.C0.ESC),s.cancel=!0;break;case 37:if(e.metaKey)break;a?(s.key=i.C0.ESC+"[1;"+(a+1)+"D",s.key===i.C0.ESC+"[1;3D"&&(s.key=i.C0.ESC+(r?"b":"[1;5D"))):s.key=t?i.C0.ESC+"OD":i.C0.ESC+"[D";break;case 39:if(e.metaKey)break;a?(s.key=i.C0.ESC+"[1;"+(a+1)+"C",s.key===i.C0.ESC+"[1;3C"&&(s.key=i.C0.ESC+(r?"f":"[1;5C"))):s.key=t?i.C0.ESC+"OC":i.C0.ESC+"[C";break;case 38:if(e.metaKey)break;a?(s.key=i.C0.ESC+"[1;"+(a+1)+"A",r||s.key!==i.C0.ESC+"[1;3A"||(s.key=i.C0.ESC+"[1;5A")):s.key=t?i.C0.ESC+"OA":i.C0.ESC+"[A";break;case 40:if(e.metaKey)break;a?(s.key=i.C0.ESC+"[1;"+(a+1)+"B",r||s.key!==i.C0.ESC+"[1;3B"||(s.key=i.C0.ESC+"[1;5B")):s.key=t?i.C0.ESC+"OB":i.C0.ESC+"[B";break;case 45:e.shiftKey||e.ctrlKey||(s.key=i.C0.ESC+"[2~");break;case 46:s.key=a?i.C0.ESC+"[3;"+(a+1)+"~":i.C0.ESC+"[3~";break;case 36:s.key=a?i.C0.ESC+"[1;"+(a+1)+"H":t?i.C0.ESC+"OH":i.C0.ESC+"[H";break;case 35:s.key=a?i.C0.ESC+"[1;"+(a+1)+"F":t?i.C0.ESC+"OF":i.C0.ESC+"[F";break;case 33:e.shiftKey?s.type=2:s.key=i.C0.ESC+"[5~";break;case 34:e.shiftKey?s.type=3:s.key=i.C0.ESC+"[6~";break;case 112:s.key=a?i.C0.ESC+"[1;"+(a+1)+"P":i.C0.ESC+"OP";break;case 113:s.key=a?i.C0.ESC+"[1;"+(a+1)+"Q":i.C0.ESC+"OQ";break;case 114:s.key=a?i.C0.ESC+"[1;"+(a+1)+"R":i.C0.ESC+"OR";break;case 115:s.key=a?i.C0.ESC+"[1;"+(a+1)+"S":i.C0.ESC+"OS";break;case 116:s.key=a?i.C0.ESC+"[15;"+(a+1)+"~":i.C0.ESC+"[15~";break;case 117:s.key=a?i.C0.ESC+"[17;"+(a+1)+"~":i.C0.ESC+"[17~";break;case 118:s.key=a?i.C0.ESC+"[18;"+(a+1)+"~":i.C0.ESC+"[18~";break;case 119:s.key=a?i.C0.ESC+"[19;"+(a+1)+"~":i.C0.ESC+"[19~";break;case 120:s.key=a?i.C0.ESC+"[20;"+(a+1)+"~":i.C0.ESC+"[20~";break;case 121:s.key=a?i.C0.ESC+"[21;"+(a+1)+"~":i.C0.ESC+"[21~";break;case 122:s.key=a?i.C0.ESC+"[23;"+(a+1)+"~":i.C0.ESC+"[23~";break;case 123:s.key=a?i.C0.ESC+"[24;"+(a+1)+"~":i.C0.ESC+"[24~";break;default:if(!e.ctrlKey||e.shiftKey||e.altKey||e.metaKey)if(r&&!o||!e.altKey||e.metaKey)!r||e.altKey||e.ctrlKey||e.shiftKey||!e.metaKey?e.key&&!e.ctrlKey&&!e.altKey&&!e.metaKey&&e.keyCode>=48&&1===e.key.length?s.key=e.key:e.key&&e.ctrlKey&&"_"===e.key&&(s.key=i.C0.US):65===e.keyCode&&(s.type=1);else{var c=n[e.keyCode],l=c&&c[e.shiftKey?1:0];if(l)s.key=i.C0.ESC+l;else if(e.keyCode>=65&&e.keyCode<=90){var h=e.ctrlKey?e.keyCode-64:e.keyCode+32;s.key=i.C0.ESC+String.fromCharCode(h)}}else e.keyCode>=65&&e.keyCode<=90?s.key=String.fromCharCode(e.keyCode-64):32===e.keyCode?s.key=i.C0.NUL:e.keyCode>=51&&e.keyCode<=55?s.key=String.fromCharCode(e.keyCode-51+27):56===e.keyCode?s.key=i.C0.DEL:219===e.keyCode?s.key=i.C0.ESC:220===e.keyCode?s.key=i.C0.FS:221===e.keyCode&&(s.key=i.C0.GS)}return s}},482:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.Utf8ToUtf32=t.StringToUtf32=t.utf32ToString=t.stringFromCodePoint=void 0,t.stringFromCodePoint=function(e){return e>65535?(e-=65536,String.fromCharCode(55296+(e>>10))+String.fromCharCode(e%1024+56320)):String.fromCharCode(e)},t.utf32ToString=function(e,t,r){void 0===t&&(t=0),void 0===r&&(r=e.length);for(var i="",n=t;n65535?(o-=65536,i+=String.fromCharCode(55296+(o>>10))+String.fromCharCode(o%1024+56320)):i+=String.fromCharCode(o)}return i};var r=function(){function e(){this._interim=0}return e.prototype.clear=function(){this._interim=0},e.prototype.decode=function(e,t){var r=e.length;if(!r)return 0;var i=0,n=0;this._interim&&(56320<=(a=e.charCodeAt(n++))&&a<=57343?t[i++]=1024*(this._interim-55296)+a-56320+65536:(t[i++]=this._interim,t[i++]=a),this._interim=0);for(var o=n;o=r)return this._interim=s,i;var a;56320<=(a=e.charCodeAt(o))&&a<=57343?t[i++]=1024*(s-55296)+a-56320+65536:(t[i++]=s,t[i++]=a)}else 65279!==s&&(t[i++]=s)}return i},e}();t.StringToUtf32=r;var i=function(){function e(){this.interim=new Uint8Array(3)}return e.prototype.clear=function(){this.interim.fill(0)},e.prototype.decode=function(e,t){var r=e.length;if(!r)return 0;var i,n,o,s,a=0,c=0,l=0;if(this.interim[0]){var h=!1,u=this.interim[0];u&=192==(224&u)?31:224==(240&u)?15:7;for(var f=0,_=void 0;(_=63&this.interim[++f])&&f<4;)u<<=6,u|=_;for(var d=192==(224&this.interim[0])?2:224==(240&this.interim[0])?3:4,p=d-f;l=r)return 0;if(128!=(192&(_=e[l++]))){l--,h=!0;break}this.interim[f++]=_,u<<=6,u|=63&_}h||(2===d?u<128?l--:t[a++]=u:3===d?u<2048||u>=55296&&u<=57343||65279===u||(t[a++]=u):u<65536||u>1114111||(t[a++]=u)),this.interim.fill(0)}for(var v=r-4,g=l;g=r)return this.interim[0]=i,a;if(128!=(192&(n=e[g++]))){g--;continue}if((c=(31&i)<<6|63&n)<128){g--;continue}t[a++]=c}else if(224==(240&i)){if(g>=r)return this.interim[0]=i,a;if(128!=(192&(n=e[g++]))){g--;continue}if(g>=r)return this.interim[0]=i,this.interim[1]=n,a;if(128!=(192&(o=e[g++]))){g--;continue}if((c=(15&i)<<12|(63&n)<<6|63&o)<2048||c>=55296&&c<=57343||65279===c)continue;t[a++]=c}else if(240==(248&i)){if(g>=r)return this.interim[0]=i,a;if(128!=(192&(n=e[g++]))){g--;continue}if(g>=r)return this.interim[0]=i,this.interim[1]=n,a;if(128!=(192&(o=e[g++]))){g--;continue}if(g>=r)return this.interim[0]=i,this.interim[1]=n,this.interim[2]=o,a;if(128!=(192&(s=e[g++]))){g--;continue}if((c=(7&i)<<18|(63&n)<<12|(63&o)<<6|63&s)<65536||c>1114111)continue;t[a++]=c}}return a},e}();t.Utf8ToUtf32=i},225:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.UnicodeV6=void 0;var i,n=r(8273),o=[[768,879],[1155,1158],[1160,1161],[1425,1469],[1471,1471],[1473,1474],[1476,1477],[1479,1479],[1536,1539],[1552,1557],[1611,1630],[1648,1648],[1750,1764],[1767,1768],[1770,1773],[1807,1807],[1809,1809],[1840,1866],[1958,1968],[2027,2035],[2305,2306],[2364,2364],[2369,2376],[2381,2381],[2385,2388],[2402,2403],[2433,2433],[2492,2492],[2497,2500],[2509,2509],[2530,2531],[2561,2562],[2620,2620],[2625,2626],[2631,2632],[2635,2637],[2672,2673],[2689,2690],[2748,2748],[2753,2757],[2759,2760],[2765,2765],[2786,2787],[2817,2817],[2876,2876],[2879,2879],[2881,2883],[2893,2893],[2902,2902],[2946,2946],[3008,3008],[3021,3021],[3134,3136],[3142,3144],[3146,3149],[3157,3158],[3260,3260],[3263,3263],[3270,3270],[3276,3277],[3298,3299],[3393,3395],[3405,3405],[3530,3530],[3538,3540],[3542,3542],[3633,3633],[3636,3642],[3655,3662],[3761,3761],[3764,3769],[3771,3772],[3784,3789],[3864,3865],[3893,3893],[3895,3895],[3897,3897],[3953,3966],[3968,3972],[3974,3975],[3984,3991],[3993,4028],[4038,4038],[4141,4144],[4146,4146],[4150,4151],[4153,4153],[4184,4185],[4448,4607],[4959,4959],[5906,5908],[5938,5940],[5970,5971],[6002,6003],[6068,6069],[6071,6077],[6086,6086],[6089,6099],[6109,6109],[6155,6157],[6313,6313],[6432,6434],[6439,6440],[6450,6450],[6457,6459],[6679,6680],[6912,6915],[6964,6964],[6966,6970],[6972,6972],[6978,6978],[7019,7027],[7616,7626],[7678,7679],[8203,8207],[8234,8238],[8288,8291],[8298,8303],[8400,8431],[12330,12335],[12441,12442],[43014,43014],[43019,43019],[43045,43046],[64286,64286],[65024,65039],[65056,65059],[65279,65279],[65529,65531]],s=[[68097,68099],[68101,68102],[68108,68111],[68152,68154],[68159,68159],[119143,119145],[119155,119170],[119173,119179],[119210,119213],[119362,119364],[917505,917505],[917536,917631],[917760,917999]],a=function(){function e(){if(this.version="6",!i){i=new Uint8Array(65536),n.fill(i,1),i[0]=0,n.fill(i,0,1,32),n.fill(i,0,127,160),n.fill(i,2,4352,4448),i[9001]=2,i[9002]=2,n.fill(i,2,11904,42192),i[12351]=1,n.fill(i,2,44032,55204),n.fill(i,2,63744,64256),n.fill(i,2,65040,65050),n.fill(i,2,65072,65136),n.fill(i,2,65280,65377),n.fill(i,2,65504,65511);for(var e=0;et[n][1])return!1;for(;n>=i;)if(e>t[r=i+n>>1][1])i=r+1;else{if(!(e=131072&&e<=196605||e>=196608&&e<=262141?2:1},e}();t.UnicodeV6=a},5981:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.WriteBuffer=void 0;var r=function(){function e(e){this._action=e,this._writeBuffer=[],this._callbacks=[],this._pendingData=0,this._bufferOffset=0}return e.prototype.writeSync=function(e){if(this._writeBuffer.length){for(var t=this._bufferOffset;t5e7)throw new Error("write data discarded, use flow control to avoid losing data");this._writeBuffer.length||(this._bufferOffset=0,setTimeout((function(){return r._innerWrite()}))),this._pendingData+=e.length,this._writeBuffer.push(e),this._callbacks.push(t)},e.prototype._innerWrite=function(){for(var e=this,t=Date.now();this._writeBuffer.length>this._bufferOffset;){var r=this._writeBuffer[this._bufferOffset],i=this._callbacks[this._bufferOffset];if(this._bufferOffset++,this._action(r),this._pendingData-=r.length,i&&i(),Date.now()-t>=12)break}this._writeBuffer.length>this._bufferOffset?(this._bufferOffset>50&&(this._writeBuffer=this._writeBuffer.slice(this._bufferOffset),this._callbacks=this._callbacks.slice(this._bufferOffset),this._bufferOffset=0),setTimeout((function(){return e._innerWrite()}),0)):(this._writeBuffer=[],this._callbacks=[],this._pendingData=0,this._bufferOffset=0)},e}();t.WriteBuffer=r},5770:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.PAYLOAD_LIMIT=void 0,t.PAYLOAD_LIMIT=1e7},6351:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.DcsHandler=t.DcsParser=void 0;var i=r(482),n=r(8742),o=r(5770),s=[],a=function(){function e(){this._handlers=Object.create(null),this._active=s,this._ident=0,this._handlerFb=function(){}}return e.prototype.dispose=function(){this._handlers=Object.create(null),this._handlerFb=function(){},this._active=s},e.prototype.registerHandler=function(e,t){void 0===this._handlers[e]&&(this._handlers[e]=[]);var r=this._handlers[e];return r.push(t),{dispose:function(){var e=r.indexOf(t);-1!==e&&r.splice(e,1)}}},e.prototype.clearHandler=function(e){this._handlers[e]&&delete this._handlers[e]},e.prototype.setHandlerFallback=function(e){this._handlerFb=e},e.prototype.reset=function(){this._active.length&&this.unhook(!1),this._active=s,this._ident=0},e.prototype.hook=function(e,t){if(this.reset(),this._ident=e,this._active=this._handlers[e]||s,this._active.length)for(var r=this._active.length-1;r>=0;r--)this._active[r].hook(t);else this._handlerFb(this._ident,"HOOK",t)},e.prototype.put=function(e,t,r){if(this._active.length)for(var n=this._active.length-1;n>=0;n--)this._active[n].put(e,t,r);else this._handlerFb(this._ident,"PUT",i.utf32ToString(e,t,r))},e.prototype.unhook=function(e){if(this._active.length){for(var t=this._active.length-1;t>=0&&!this._active[t].unhook(e);t--);for(t--;t>=0;t--)this._active[t].unhook(!1)}else this._handlerFb(this._ident,"UNHOOK",e);this._active=s,this._ident=0},e}();t.DcsParser=a;var c=new n.Params;c.addParam(0);var l=function(){function e(e){this._handler=e,this._data="",this._params=c,this._hitLimit=!1}return e.prototype.hook=function(e){this._params=e.length>1||e.params[0]?e.clone():c,this._data="",this._hitLimit=!1},e.prototype.put=function(e,t,r){this._hitLimit||(this._data+=i.utf32ToString(e,t,r),this._data.length>o.PAYLOAD_LIMIT&&(this._data="",this._hitLimit=!0))},e.prototype.unhook=function(e){var t=!1;return this._hitLimit?t=!1:e&&(t=this._handler(this._data,this._params)),this._params=c,this._data="",this._hitLimit=!1,t},e}();t.DcsHandler=l},2015:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)});Object.defineProperty(t,"__esModule",{value:!0}),t.EscapeSequenceParser=t.VT500_TRANSITION_TABLE=t.TransitionTable=void 0;var o=r(844),s=r(8273),a=r(8742),c=r(6242),l=r(6351),h=function(){function e(e){this.table=new Uint8Array(e)}return e.prototype.setDefault=function(e,t){s.fill(this.table,e<<4|t)},e.prototype.add=function(e,t,r,i){this.table[t<<8|e]=r<<4|i},e.prototype.addMany=function(e,t,r,i){for(var n=0;n1)throw new Error("only one byte as prefix supported");if((r=e.prefix.charCodeAt(0))&&60>r||r>63)throw new Error("prefix must be in range 0x3c .. 0x3f")}if(e.intermediates){if(e.intermediates.length>2)throw new Error("only two bytes as intermediates are supported");for(var i=0;in||n>47)throw new Error("intermediate must be in range 0x20 .. 0x2f");r<<=8,r|=n}}if(1!==e.final.length)throw new Error("final must be a single byte");var o=e.final.charCodeAt(0);if(t[0]>o||o>t[1])throw new Error("final must be in range "+t[0]+" .. "+t[1]);return(r<<=8)|o},r.prototype.identToString=function(e){for(var t=[];e;)t.push(String.fromCharCode(255&e)),e>>=8;return t.reverse().join("")},r.prototype.dispose=function(){this._csiHandlers=Object.create(null),this._executeHandlers=Object.create(null),this._escHandlers=Object.create(null),this._oscParser.dispose(),this._dcsParser.dispose()},r.prototype.setPrintHandler=function(e){this._printHandler=e},r.prototype.clearPrintHandler=function(){this._printHandler=this._printHandlerFb},r.prototype.registerEscHandler=function(e,t){var r=this._identifier(e,[48,126]);void 0===this._escHandlers[r]&&(this._escHandlers[r]=[]);var i=this._escHandlers[r];return i.push(t),{dispose:function(){var e=i.indexOf(t);-1!==e&&i.splice(e,1)}}},r.prototype.clearEscHandler=function(e){this._escHandlers[this._identifier(e,[48,126])]&&delete this._escHandlers[this._identifier(e,[48,126])]},r.prototype.setEscHandlerFallback=function(e){this._escHandlerFb=e},r.prototype.setExecuteHandler=function(e,t){this._executeHandlers[e.charCodeAt(0)]=t},r.prototype.clearExecuteHandler=function(e){this._executeHandlers[e.charCodeAt(0)]&&delete this._executeHandlers[e.charCodeAt(0)]},r.prototype.setExecuteHandlerFallback=function(e){this._executeHandlerFb=e},r.prototype.registerCsiHandler=function(e,t){var r=this._identifier(e);void 0===this._csiHandlers[r]&&(this._csiHandlers[r]=[]);var i=this._csiHandlers[r];return i.push(t),{dispose:function(){var e=i.indexOf(t);-1!==e&&i.splice(e,1)}}},r.prototype.clearCsiHandler=function(e){this._csiHandlers[this._identifier(e)]&&delete this._csiHandlers[this._identifier(e)]},r.prototype.setCsiHandlerFallback=function(e){this._csiHandlerFb=e},r.prototype.registerDcsHandler=function(e,t){return this._dcsParser.registerHandler(this._identifier(e),t)},r.prototype.clearDcsHandler=function(e){this._dcsParser.clearHandler(this._identifier(e))},r.prototype.setDcsHandlerFallback=function(e){this._dcsParser.setHandlerFallback(e)},r.prototype.registerOscHandler=function(e,t){return this._oscParser.registerHandler(e,t)},r.prototype.clearOscHandler=function(e){this._oscParser.clearHandler(e)},r.prototype.setOscHandlerFallback=function(e){this._oscParser.setHandlerFallback(e)},r.prototype.setErrorHandler=function(e){this._errorHandler=e},r.prototype.clearErrorHandler=function(){this._errorHandler=this._errorHandlerFb},r.prototype.reset=function(){this.currentState=this.initialState,this._oscParser.reset(),this._dcsParser.reset(),this._params.reset(),this._params.addParam(0),this._collect=0,this.precedingCodepoint=0},r.prototype.parse=function(e,t){for(var r=0,i=0,n=this.currentState,o=this._oscParser,s=this._dcsParser,a=this._collect,c=this._params,l=this._transitions.table,h=0;h>4){case 2:for(var f=h+1;;++f){if(f>=t||(r=e[f])<32||r>126&&r=t||(r=e[f])<32||r>126&&r=t||(r=e[f])<32||r>126&&r=t||(r=e[f])<32||r>126&&r=0&&!_[d](c);d--);d<0&&this._csiHandlerFb(a<<8|r,c),this.precedingCodepoint=0;break;case 8:do{switch(r){case 59:c.addParam(0);break;case 58:c.addSubParam(-1);break;default:c.addDigit(r-48)}}while(++h47&&r<60);h--;break;case 9:a<<=8,a|=r;break;case 10:for(var p=this._escHandlers[a<<8|r],v=p?p.length-1:-1;v>=0&&!p[v]();v--);v<0&&this._escHandlerFb(a<<8|r),this.precedingCodepoint=0;break;case 11:c.reset(),c.addParam(0),a=0;break;case 12:s.hook(a<<8|r,c);break;case 13:for(var g=h+1;;++g)if(g>=t||24===(r=e[g])||26===r||27===r||r>127&&r=t||(r=e[y])<32||r>127&&r{Object.defineProperty(t,"__esModule",{value:!0}),t.OscHandler=t.OscParser=void 0;var i=r(5770),n=r(482),o=[],s=function(){function e(){this._state=0,this._active=o,this._id=-1,this._handlers=Object.create(null),this._handlerFb=function(){}}return e.prototype.registerHandler=function(e,t){void 0===this._handlers[e]&&(this._handlers[e]=[]);var r=this._handlers[e];return r.push(t),{dispose:function(){var e=r.indexOf(t);-1!==e&&r.splice(e,1)}}},e.prototype.clearHandler=function(e){this._handlers[e]&&delete this._handlers[e]},e.prototype.setHandlerFallback=function(e){this._handlerFb=e},e.prototype.dispose=function(){this._handlers=Object.create(null),this._handlerFb=function(){},this._active=o},e.prototype.reset=function(){2===this._state&&this.end(!1),this._active=o,this._id=-1,this._state=0},e.prototype._start=function(){if(this._active=this._handlers[this._id]||o,this._active.length)for(var e=this._active.length-1;e>=0;e--)this._active[e].start();else this._handlerFb(this._id,"START")},e.prototype._put=function(e,t,r){if(this._active.length)for(var i=this._active.length-1;i>=0;i--)this._active[i].put(e,t,r);else this._handlerFb(this._id,"PUT",n.utf32ToString(e,t,r))},e.prototype._end=function(e){if(this._active.length){for(var t=this._active.length-1;t>=0&&!this._active[t].end(e);t--);for(t--;t>=0;t--)this._active[t].end(!1)}else this._handlerFb(this._id,"END",e)},e.prototype.start=function(){this.reset(),this._state=1},e.prototype.put=function(e,t,r){if(3!==this._state){if(1===this._state)for(;t0&&this._put(e,t,r)}},e.prototype.end=function(e){0!==this._state&&(3!==this._state&&(1===this._state&&this._start(),this._end(e)),this._active=o,this._id=-1,this._state=0)},e}();t.OscParser=s;var a=function(){function e(e){this._handler=e,this._data="",this._hitLimit=!1}return e.prototype.start=function(){this._data="",this._hitLimit=!1},e.prototype.put=function(e,t,r){this._hitLimit||(this._data+=n.utf32ToString(e,t,r),this._data.length>i.PAYLOAD_LIMIT&&(this._data="",this._hitLimit=!0))},e.prototype.end=function(e){var t=!1;return this._hitLimit?t=!1:e&&(t=this._handler(this._data)),this._data="",this._hitLimit=!1,t},e}();t.OscHandler=a},8742:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.Params=void 0;var r=2147483647,i=function(){function e(e,t){if(void 0===e&&(e=32),void 0===t&&(t=32),this.maxLength=e,this.maxSubParamsLength=t,t>256)throw new Error("maxSubParamsLength must not be greater than 256");this.params=new Int32Array(e),this.length=0,this._subParams=new Int32Array(t),this._subParamsLength=0,this._subParamsIdx=new Uint16Array(e),this._rejectDigits=!1,this._rejectSubDigits=!1,this._digitIsSub=!1}return e.fromArray=function(t){var r=new e;if(!t.length)return r;for(var i=t[0]instanceof Array?1:0;i>8,i=255&this._subParamsIdx[t];i-r>0&&e.push(Array.prototype.slice.call(this._subParams,r,i))}return e},e.prototype.reset=function(){this.length=0,this._subParamsLength=0,this._rejectDigits=!1,this._rejectSubDigits=!1,this._digitIsSub=!1},e.prototype.addParam=function(e){if(this._digitIsSub=!1,this.length>=this.maxLength)this._rejectDigits=!0;else{if(e<-1)throw new Error("values lesser than -1 are not allowed");this._subParamsIdx[this.length]=this._subParamsLength<<8|this._subParamsLength,this.params[this.length++]=e>r?r:e}},e.prototype.addSubParam=function(e){if(this._digitIsSub=!0,this.length)if(this._rejectDigits||this._subParamsLength>=this.maxSubParamsLength)this._rejectSubDigits=!0;else{if(e<-1)throw new Error("values lesser than -1 are not allowed");this._subParams[this._subParamsLength++]=e>r?r:e,this._subParamsIdx[this.length-1]++}},e.prototype.hasSubParams=function(e){return(255&this._subParamsIdx[e])-(this._subParamsIdx[e]>>8)>0},e.prototype.getSubParams=function(e){var t=this._subParamsIdx[e]>>8,r=255&this._subParamsIdx[e];return r-t>0?this._subParams.subarray(t,r):null},e.prototype.getSubParamsAll=function(){for(var e={},t=0;t>8,i=255&this._subParamsIdx[t];i-r>0&&(e[t]=this._subParams.slice(r,i))}return e},e.prototype.addDigit=function(e){var t;if(!(this._rejectDigits||!(t=this._digitIsSub?this._subParamsLength:this.length)||this._digitIsSub&&this._rejectSubDigits)){var i=this._digitIsSub?this._subParams:this.params,n=i[t-1];i[t-1]=~n?Math.min(10*n+e,r):e}},e}();t.Params=i},744:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}),o=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},s=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.BufferService=t.MINIMUM_ROWS=t.MINIMUM_COLS=void 0;var a=r(2585),c=r(5295),l=r(8460),h=r(844);t.MINIMUM_COLS=2,t.MINIMUM_ROWS=1;var u=function(e){function r(r){var i=e.call(this)||this;return i._optionsService=r,i.isUserScrolling=!1,i._onResize=new l.EventEmitter,i.cols=Math.max(r.options.cols,t.MINIMUM_COLS),i.rows=Math.max(r.options.rows,t.MINIMUM_ROWS),i.buffers=new c.BufferSet(r,i),i}return n(r,e),Object.defineProperty(r.prototype,"onResize",{get:function(){return this._onResize.event},enumerable:!1,configurable:!0}),Object.defineProperty(r.prototype,"buffer",{get:function(){return this.buffers.active},enumerable:!1,configurable:!0}),r.prototype.dispose=function(){e.prototype.dispose.call(this),this.buffers.dispose()},r.prototype.resize=function(e,t){this.cols=e,this.rows=t,this.buffers.resize(e,t),this.buffers.setupTabStops(this.cols),this._onResize.fire({cols:e,rows:t})},r.prototype.reset=function(){this.buffers.reset(),this.isUserScrolling=!1},o([s(0,a.IOptionsService)],r)}(h.Disposable);t.BufferService=u},7994:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.CharsetService=void 0;var r=function(){function e(){this.glevel=0,this._charsets=[]}return e.prototype.reset=function(){this.charset=void 0,this._charsets=[],this.glevel=0},e.prototype.setgLevel=function(e){this.glevel=e,this.charset=this._charsets[e]},e.prototype.setgCharset=function(e,t){this._charsets[e]=t,this.glevel===e&&(this.charset=t)},e}();t.CharsetService=r},1753:function(e,t,r){var i=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},n=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.CoreMouseService=void 0;var o=r(2585),s=r(8460),a={NONE:{events:0,restrict:function(){return!1}},X10:{events:1,restrict:function(e){return 4!==e.button&&1===e.action&&(e.ctrl=!1,e.alt=!1,e.shift=!1,!0)}},VT200:{events:19,restrict:function(e){return 32!==e.action}},DRAG:{events:23,restrict:function(e){return 32!==e.action||3!==e.button}},ANY:{events:31,restrict:function(e){return!0}}};function c(e,t){var r=(e.ctrl?16:0)|(e.shift?4:0)|(e.alt?8:0);return 4===e.button?(r|=64,r|=e.action):(r|=3&e.button,4&e.button&&(r|=64),8&e.button&&(r|=128),32===e.action?r|=32:0!==e.action||t||(r|=3)),r}var l=String.fromCharCode,h={DEFAULT:function(e){var t=[c(e,!1)+32,e.col+32,e.row+32];return t[0]>255||t[1]>255||t[2]>255?"":""+l(t[0])+l(t[1])+l(t[2])},SGR:function(e){var t=0===e.action&&4!==e.button?"m":"M";return"[<"+c(e,!0)+";"+e.col+";"+e.row+t}},u=function(){function e(e,t){this._bufferService=e,this._coreService=t,this._protocols={},this._encodings={},this._activeProtocol="",this._activeEncoding="",this._onProtocolChange=new s.EventEmitter,this._lastEvent=null;for(var r=0,i=Object.keys(a);r=this._bufferService.cols||e.row<0||e.row>=this._bufferService.rows)return!1;if(4===e.button&&32===e.action)return!1;if(3===e.button&&32!==e.action)return!1;if(4!==e.button&&(2===e.action||3===e.action))return!1;if(e.col++,e.row++,32===e.action&&this._lastEvent&&this._compareEvents(this._lastEvent,e))return!1;if(!this._protocols[this._activeProtocol].restrict(e))return!1;var t=this._encodings[this._activeEncoding](e);return t&&("DEFAULT"===this._activeEncoding?this._coreService.triggerBinaryEvent(t):this._coreService.triggerDataEvent(t,!0)),this._lastEvent=e,!0},e.prototype.explainEvents=function(e){return{down:!!(1&e),up:!!(2&e),drag:!!(4&e),move:!!(8&e),wheel:!!(16&e)}},e.prototype._compareEvents=function(e,t){return e.col===t.col&&e.row===t.row&&e.button===t.button&&e.action===t.action&&e.ctrl===t.ctrl&&e.alt===t.alt&&e.shift===t.shift},i([n(0,o.IBufferService),n(1,o.ICoreService)],e)}();t.CoreMouseService=u},6975:function(e,t,r){var i,n=this&&this.__extends||(i=function(e,t){return(i=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){function r(){this.constructor=e}i(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}),o=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},s=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.CoreService=void 0;var a=r(2585),c=r(8460),l=r(1439),h=r(844),u=Object.freeze({insertMode:!1}),f=Object.freeze({applicationCursorKeys:!1,applicationKeypad:!1,bracketedPasteMode:!1,origin:!1,reverseWraparound:!1,sendFocus:!1,wraparound:!0}),_=function(e){function t(t,r,i,n){var o=e.call(this)||this;return o._bufferService=r,o._logService=i,o._optionsService=n,o.isCursorInitialized=!1,o.isCursorHidden=!1,o._onData=o.register(new c.EventEmitter),o._onUserInput=o.register(new c.EventEmitter),o._onBinary=o.register(new c.EventEmitter),o._scrollToBottom=t,o.register({dispose:function(){return o._scrollToBottom=void 0}}),o.modes=l.clone(u),o.decPrivateModes=l.clone(f),o}return n(t,e),Object.defineProperty(t.prototype,"onData",{get:function(){return this._onData.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onUserInput",{get:function(){return this._onUserInput.event},enumerable:!1,configurable:!0}),Object.defineProperty(t.prototype,"onBinary",{get:function(){return this._onBinary.event},enumerable:!1,configurable:!0}),t.prototype.reset=function(){this.modes=l.clone(u),this.decPrivateModes=l.clone(f)},t.prototype.triggerDataEvent=function(e,t){if(void 0===t&&(t=!1),!this._optionsService.options.disableStdin){var r=this._bufferService.buffer;r.ybase!==r.ydisp&&this._scrollToBottom(),t&&this._onUserInput.fire(),this._logService.debug('sending data "'+e+'"',(function(){return e.split("").map((function(e){return e.charCodeAt(0)}))})),this._onData.fire(e)}},t.prototype.triggerBinaryEvent=function(e){this._optionsService.options.disableStdin||(this._logService.debug('sending binary "'+e+'"',(function(){return e.split("").map((function(e){return e.charCodeAt(0)}))})),this._onBinary.fire(e))},o([s(1,a.IBufferService),s(2,a.ILogService),s(3,a.IOptionsService)],t)}(h.Disposable);t.CoreService=_},3730:function(e,t,r){var i=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},n=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}};Object.defineProperty(t,"__esModule",{value:!0}),t.DirtyRowService=void 0;var o=r(2585),s=function(){function e(e){this._bufferService=e,this.clearRange()}return Object.defineProperty(e.prototype,"start",{get:function(){return this._start},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"end",{get:function(){return this._end},enumerable:!1,configurable:!0}),e.prototype.clearRange=function(){this._start=this._bufferService.buffer.y,this._end=this._bufferService.buffer.y},e.prototype.markDirty=function(e){ethis._end&&(this._end=e)},e.prototype.markRangeDirty=function(e,t){if(e>t){var r=e;e=t,t=r}ethis._end&&(this._end=t)},e.prototype.markAllDirty=function(){this.markRangeDirty(0,this._bufferService.rows-1)},i([n(0,o.IBufferService)],e)}();t.DirtyRowService=s},4348:function(e,t,r){var i=this&&this.__spreadArrays||function(){for(var e=0,t=0,r=arguments.length;t0?n[0].index:t.length;if(t.length!==u)throw new Error("[createInstance] First service dependency of "+e.name+" at position "+(u+1)+" conflicts with "+t.length+" static arguments");return new(e.bind.apply(e,i([void 0],i(t,s))))},e}();t.InstantiationService=a},7866:function(e,t,r){var i=this&&this.__decorate||function(e,t,r,i){var n,o=arguments.length,s=o<3?t:null===i?i=Object.getOwnPropertyDescriptor(t,r):i;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)s=Reflect.decorate(e,t,r,i);else for(var a=e.length-1;a>=0;a--)(n=e[a])&&(s=(o<3?n(s):o>3?n(t,r,s):n(t,r))||s);return o>3&&s&&Object.defineProperty(t,r,s),s},n=this&&this.__param||function(e,t){return function(r,i){t(r,i,e)}},o=this&&this.__spreadArrays||function(){for(var e=0,t=0,r=arguments.length;t{Object.defineProperty(t,"__esModule",{value:!0}),t.OptionsService=t.DEFAULT_OPTIONS=t.DEFAULT_BELL_SOUND=void 0;var i=r(8460),n=r(6114),o=r(1439);t.DEFAULT_BELL_SOUND="data:audio/mp3;base64,SUQzBAAAAAAAI1RTU0UAAAAPAAADTGF2ZjU4LjMyLjEwNAAAAAAAAAAAAAAA//tQxAADB8AhSmxhIIEVCSiJrDCQBTcu3UrAIwUdkRgQbFAZC1CQEwTJ9mjRvBA4UOLD8nKVOWfh+UlK3z/177OXrfOdKl7pyn3Xf//WreyTRUoAWgBgkOAGbZHBgG1OF6zM82DWbZaUmMBptgQhGjsyYqc9ae9XFz280948NMBWInljyzsNRFLPWdnZGWrddDsjK1unuSrVN9jJsK8KuQtQCtMBjCEtImISdNKJOopIpBFpNSMbIHCSRpRR5iakjTiyzLhchUUBwCgyKiweBv/7UsQbg8isVNoMPMjAAAA0gAAABEVFGmgqK////9bP/6XCykxBTUUzLjEwMKqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq",t.DEFAULT_OPTIONS=Object.freeze({cols:80,rows:24,cursorBlink:!1,cursorStyle:"block",cursorWidth:1,bellSound:t.DEFAULT_BELL_SOUND,bellStyle:"none",drawBoldTextInBrightColors:!0,fastScrollModifier:"alt",fastScrollSensitivity:5,fontFamily:"courier-new, courier, monospace",fontSize:15,fontWeight:"normal",fontWeightBold:"bold",lineHeight:1,linkTooltipHoverDuration:500,letterSpacing:0,logLevel:"info",scrollback:1e3,scrollSensitivity:1,screenReaderMode:!1,macOptionIsMeta:!1,macOptionClickForcesSelection:!1,minimumContrastRatio:1,disableStdin:!1,allowProposedApi:!0,allowTransparency:!1,tabStopWidth:8,theme:{},rightClickSelectsWord:n.isMac,rendererType:"canvas",windowOptions:{},windowsMode:!1,wordSeparator:" ()[]{}',\"`",altClickMovesCursor:!0,convertEol:!1,termName:"xterm",cancelEvents:!1});var s=["normal","bold","100","200","300","400","500","600","700","800","900"],a=["cols","rows"],c=function(){function e(e){this._onOptionChange=new i.EventEmitter,this.options=o.clone(t.DEFAULT_OPTIONS);for(var r=0,n=Object.keys(e);r{function r(e,t,r){t.di$target===t?t.di$dependencies.push({id:e,index:r}):(t.di$dependencies=[{id:e,index:r}],t.di$target=t)}Object.defineProperty(t,"__esModule",{value:!0}),t.createDecorator=t.getServiceDependencies=t.serviceRegistry=void 0,t.serviceRegistry=new Map,t.getServiceDependencies=function(e){return e.di$dependencies||[]},t.createDecorator=function(e){if(t.serviceRegistry.has(e))return t.serviceRegistry.get(e);var i=function(e,t,n){if(3!==arguments.length)throw new Error("@IServiceName-decorator can only be used to decorate a parameter");r(i,e,n)};return i.toString=function(){return e},t.serviceRegistry.set(e,i),i}},2585:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.IUnicodeService=t.IOptionsService=t.ILogService=t.IInstantiationService=t.IDirtyRowService=t.ICharsetService=t.ICoreService=t.ICoreMouseService=t.IBufferService=void 0;var i=r(8343);t.IBufferService=i.createDecorator("BufferService"),t.ICoreMouseService=i.createDecorator("CoreMouseService"),t.ICoreService=i.createDecorator("CoreService"),t.ICharsetService=i.createDecorator("CharsetService"),t.IDirtyRowService=i.createDecorator("DirtyRowService"),t.IInstantiationService=i.createDecorator("InstantiationService"),t.ILogService=i.createDecorator("LogService"),t.IOptionsService=i.createDecorator("OptionsService"),t.IUnicodeService=i.createDecorator("UnicodeService")},1480:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.UnicodeService=void 0;var i=r(8460),n=r(225),o=function(){function e(){this._providers=Object.create(null),this._active="",this._onChange=new i.EventEmitter;var e=new n.UnicodeV6;this.register(e),this._active=e.version,this._activeProvider=e}return Object.defineProperty(e.prototype,"onChange",{get:function(){return this._onChange.event},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"versions",{get:function(){return Object.keys(this._providers)},enumerable:!1,configurable:!0}),Object.defineProperty(e.prototype,"activeVersion",{get:function(){return this._active},set:function(e){if(!this._providers[e])throw new Error('unknown Unicode version "'+e+'"');this._active=e,this._activeProvider=this._providers[e],this._onChange.fire(e)},enumerable:!1,configurable:!0}),e.prototype.register=function(e){this._providers[e.version]=e},e.prototype.wcwidth=function(e){return this._activeProvider.wcwidth(e)},e.prototype.getStringCellWidth=function(e){for(var t=0,r=e.length,i=0;i=r)return t+this.wcwidth(n);var o=e.charCodeAt(i);56320<=o&&o<=57343?n=1024*(n-55296)+o-56320+65536:t+=this.wcwidth(o)}t+=this.wcwidth(n)}return t},e}();t.UnicodeService=o}},t={};return function r(i){if(t[i])return t[i].exports;var n=t[i]={exports:{}};return e[i].call(n.exports,n,n.exports,r),n.exports}(4389)})()})); -//# sourceMappingURL=xterm.js.map \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/lib/xterm.js.map b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/lib/xterm.js.map deleted file mode 100755 index 68cd2e2aa..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/lib/xterm.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"sources":["webpack://xterm/webpack/universalModuleDefinition","webpack://xterm/./src/browser/AccessibilityManager.ts","webpack://xterm/./src/browser/Clipboard.ts","webpack://xterm/./src/browser/Color.ts","webpack://xterm/./src/browser/ColorContrastCache.ts","webpack://xterm/./src/browser/ColorManager.ts","webpack://xterm/./src/browser/Dom.ts","webpack://xterm/./src/browser/Lifecycle.ts","webpack://xterm/./src/browser/Linkifier.ts","webpack://xterm/./src/browser/Linkifier2.ts","webpack://xterm/./src/browser/LocalizableStrings.ts","webpack://xterm/./src/browser/MouseZoneManager.ts","webpack://xterm/./src/browser/RenderDebouncer.ts","webpack://xterm/./src/browser/ScreenDprMonitor.ts","webpack://xterm/./src/browser/Terminal.ts","webpack://xterm/./src/browser/Viewport.ts","webpack://xterm/./src/browser/input/CompositionHelper.ts","webpack://xterm/./src/browser/input/Mouse.ts","webpack://xterm/./src/browser/input/MoveToCell.ts","webpack://xterm/./src/browser/public/AddonManager.ts","webpack://xterm/./src/browser/public/Terminal.ts","webpack://xterm/./src/browser/renderer/BaseRenderLayer.ts","webpack://xterm/./src/browser/renderer/CharacterJoinerRegistry.ts","webpack://xterm/./src/browser/renderer/CursorRenderLayer.ts","webpack://xterm/./src/browser/renderer/GridCache.ts","webpack://xterm/./src/browser/renderer/LinkRenderLayer.ts","webpack://xterm/./src/browser/renderer/Renderer.ts","webpack://xterm/./src/browser/renderer/RendererUtils.ts","webpack://xterm/./src/browser/renderer/SelectionRenderLayer.ts","webpack://xterm/./src/browser/renderer/TextRenderLayer.ts","webpack://xterm/./src/browser/renderer/atlas/BaseCharAtlas.ts","webpack://xterm/./src/browser/renderer/atlas/CharAtlasCache.ts","webpack://xterm/./src/browser/renderer/atlas/CharAtlasUtils.ts","webpack://xterm/./src/browser/renderer/atlas/Constants.ts","webpack://xterm/./src/browser/renderer/atlas/DynamicCharAtlas.ts","webpack://xterm/./src/browser/renderer/atlas/LRUMap.ts","webpack://xterm/./src/browser/renderer/dom/DomRenderer.ts","webpack://xterm/./src/browser/renderer/dom/DomRendererRowFactory.ts","webpack://xterm/./src/browser/selection/SelectionModel.ts","webpack://xterm/./src/browser/services/CharSizeService.ts","webpack://xterm/./src/browser/services/CoreBrowserService.ts","webpack://xterm/./src/browser/services/MouseService.ts","webpack://xterm/./src/browser/services/RenderService.ts","webpack://xterm/./src/browser/services/SelectionService.ts","webpack://xterm/./src/browser/services/Services.ts","webpack://xterm/./src/browser/services/SoundService.ts","webpack://xterm/./src/common/CircularList.ts","webpack://xterm/./src/common/Clone.ts","webpack://xterm/./src/common/CoreTerminal.ts","webpack://xterm/./src/common/EventEmitter.ts","webpack://xterm/./src/common/InputHandler.ts","webpack://xterm/./src/common/Lifecycle.ts","webpack://xterm/./src/common/Platform.ts","webpack://xterm/./src/common/TypedArrayUtils.ts","webpack://xterm/./src/common/WindowsMode.ts","webpack://xterm/./src/common/buffer/AttributeData.ts","webpack://xterm/./src/common/buffer/Buffer.ts","webpack://xterm/./src/common/buffer/BufferLine.ts","webpack://xterm/./src/common/buffer/BufferReflow.ts","webpack://xterm/./src/common/buffer/BufferSet.ts","webpack://xterm/./src/common/buffer/CellData.ts","webpack://xterm/./src/common/buffer/Constants.ts","webpack://xterm/./src/common/buffer/Marker.ts","webpack://xterm/./src/common/data/Charsets.ts","webpack://xterm/./src/common/data/EscapeSequences.ts","webpack://xterm/./src/common/input/Keyboard.ts","webpack://xterm/./src/common/input/TextDecoder.ts","webpack://xterm/./src/common/input/UnicodeV6.ts","webpack://xterm/./src/common/input/WriteBuffer.ts","webpack://xterm/./src/common/parser/Constants.ts","webpack://xterm/./src/common/parser/DcsParser.ts","webpack://xterm/./src/common/parser/EscapeSequenceParser.ts","webpack://xterm/./src/common/parser/OscParser.ts","webpack://xterm/./src/common/parser/Params.ts","webpack://xterm/./src/common/services/BufferService.ts","webpack://xterm/./src/common/services/CharsetService.ts","webpack://xterm/./src/common/services/CoreMouseService.ts","webpack://xterm/./src/common/services/CoreService.ts","webpack://xterm/./src/common/services/DirtyRowService.ts","webpack://xterm/./src/common/services/InstantiationService.ts","webpack://xterm/./src/common/services/LogService.ts","webpack://xterm/./src/common/services/OptionsService.ts","webpack://xterm/./src/common/services/ServiceRegistry.ts","webpack://xterm/./src/common/services/Services.ts","webpack://xterm/./src/common/services/UnicodeService.ts","webpack://xterm/webpack/bootstrap","webpack://xterm/webpack/startup"],"names":["root","factory","exports","module","define","amd","a","i","self","_terminal","_renderService","_liveRegionLineCount","_charsToConsume","_charsToAnnounce","_accessibilityTreeRoot","document","createElement","classList","add","_rowContainer","setAttribute","_rowElements","rows","_createAccessibilityTreeNode","appendChild","_topBoundaryFocusListener","e","_onBoundaryFocus","_bottomBoundaryFocusListener","addEventListener","length","_refreshRowsDimensions","_renderRowsDebouncer","RenderDebouncer","_renderRows","bind","_refreshRows","_liveRegion","element","Error","insertAdjacentElement","register","onResize","_onResize","onRender","start","end","onScroll","onA11yChar","char","_onChar","onLineFeed","onA11yTab","spaceCount","_onTab","onKey","_onKey","key","onBlur","_clearLiveRegion","onDimensionsChange","_screenDprMonitor","ScreenDprMonitor","setListener","addDisposableDomListener","window","dispose","removeElementFromParent","this","position","boundaryElement","target","beforeBoundaryElement","getAttribute","buffer","lines","relatedTarget","topBoundaryElement","bottomBoundaryElement","pop","removeChild","shift","removeEventListener","newElement","unshift","push","scrollLines","focus","preventDefault","stopImmediatePropagation","children","tabIndex","_refreshRowDimensions","MAX_ROWS_TO_READ","textContent","Strings","tooMuchOutput","isMac","parentNode","setTimeout","keyChar","refresh","setSize","toString","lineData","translateBufferLineToString","ydisp","posInSet","innerText","_announceCharacters","dimensions","actualCellHeight","style","height","Disposable","AccessibilityManager","prepareTextForTerminal","text","replace","bracketTextForPaste","bracketedPasteMode","paste","textarea","coreService","decPrivateModes","triggerDataEvent","value","moveTextAreaUnderMouseCursor","ev","screenElement","pos","getBoundingClientRect","left","clientX","top","clientY","width","zIndex","selectionService","clipboardData","setData","selectionText","stopPropagation","getData","shouldSelectWord","rightClickSelect","select","channels","rgb","rgba","toPaddedHex","c","s","contrastRatio","l1","l2","toCss","r","g","b","undefined","toRgba","color","blend","bg","fg","css","fgR","fgG","fgB","bgR","bgG","bgB","Math","round","isOpaque","ensureContrastRatio","ratio","result","toColor","opaque","rgbaColor","toChannels","opacity","parseInt","slice","relativeLuminance2","rs","gs","bs","pow","relativeLuminance","reduceLuminance","bgRgba","fgRgba","cr","max","ceil","increaseLuminance","min","bgL","fgL","_color","_rgba","clear","setCss","getCss","setColor","getColor","ColorContrastCache","DEFAULT_FOREGROUND","DEFAULT_BACKGROUND","DEFAULT_CURSOR","DEFAULT_CURSOR_ACCENT","DEFAULT_SELECTION","DEFAULT_ANSI_COLORS","Object","freeze","colors","v","allowTransparency","canvas","ctx","getContext","_ctx","globalCompositeOperation","_litmusColor","createLinearGradient","_contrastCache","foreground","background","cursor","cursorAccent","selectionTransparent","selectionOpaque","ansi","contrastCache","onOptionsChange","setTheme","theme","_parseColor","selection","black","red","green","yellow","blue","magenta","cyan","white","brightBlack","brightRed","brightGreen","brightYellow","brightBlue","brightMagenta","brightCyan","brightWhite","fallback","fillStyle","console","warn","fillRect","data","getImageData","substring","split","map","component","Number","alpha","ColorManager","elements","parentElement","node","type","handler","options","disposed","_bufferService","_logService","_unicodeService","_linkMatchers","_nextLinkMatcherId","_onShowLinkUnderline","EventEmitter","_onHideLinkUnderline","_onLinkTooltip","_rowsToLinkify","event","attachToDom","mouseZoneManager","_element","_mouseZoneManager","linkifyRows","clearAll","_rowsTimeoutId","clearTimeout","_linkifyRows","Linkifier","_timeBeforeLatency","absoluteRowIndexStart","absoluteRowIndexEnd","overscanLineLimit","cols","iterator","hasNext","next","_doLinkifyRow","range","first","content","debug","registerLinkMatcher","regex","matcher","id","matchIndex","validationCallback","hoverTooltipCallback","tooltipCallback","hoverLeaveCallback","leaveCallback","willLinkActivate","priority","_addLinkMatcherToList","splice","deregisterLinkMatcher","matcherId","rowIndex","match","rex","RegExp","source","flags","stringIndex","uri","indexOf","lastIndex","bufferIndex","stringIndexToBufferIndex","line","get","attr","getFg","isValid","_addLink","exec","x","y","getStringCellWidth","x1","y1","floor","x2","y2","MouseZone","newWindow","open","opener","location","href","fire","_createLinkHoverEvent","remove","IBufferService","ILogService","IUnicodeService","clickCallback","hoverCallback","_linkProviders","_linkCacheDisposables","_isMouseOut","_activeLine","getDisposeArrayDisposable","registerLinkProvider","linkProvider","providerIndex","mouseService","renderService","_mouseService","_clearCurrentLink","_onMouseMove","_onClick","_lastMouseEvent","_positionFromMouseEvent","composedPath","contains","_lastBufferCell","_onHover","_askForLink","_currentLink","_linkAtPosition","link","useLineCache","_activeProviderReplies","forEach","reply","linkWithState","Map","linkProvided","_checkLinkProviderResult","provideLinks","links","linksWithState","set","size","_removeIntersectingLinks","replies","occupiedCells","Set","providerReply","startX","endX","has","index","hasLinkBefore","j","linkAtPosition","find","_handleNewLink","currentLink","activate","startRow","endRow","_linkLeave","disposeArray","state","decorations","underline","pointerCursor","isHovered","_linkHover","defineProperties","toggle","_fireUnderlineEvent","onRenderedBufferChange","hover","showEvent","scrollOffset","_createLinkUnderlineEvent","leave","sameLine","wrappedFromLeft","wrappedToRight","coords","getCoords","Linkifier2","promptLabel","_screenElement","_selectionService","_optionsService","_zones","_areZonesActive","_lastHoverCoords","_initialSelectionLength","_onMouseDown","_mouseMoveListener","_mouseLeaveListener","_onMouseLeave","_clickListener","_deactivate","zone","_activate","_currentZone","pageX","pageY","_findZoneEventAt","_tooltipTimeout","_onTooltip","linkTooltipHoverDuration","_getSelectionLength","currentSelectionLength","IMouseService","ISelectionService","IOptionsService","MouseZoneManager","_renderCallback","_animationFrame","cancelAnimationFrame","rowStart","rowEnd","rowCount","_rowCount","_rowStart","_rowEnd","requestAnimationFrame","_innerRefresh","_currentDevicePixelRatio","devicePixelRatio","listener","_listener","clearListener","_outerListener","_updateDpr","_resolutionMediaMatchList","removeListener","matchMedia","addListener","browser","Browser","_keyDownHandled","_onCursorMove","_onRender","_onSelectionChange","_onTitleChange","_onFocus","_onBlur","_onA11yCharEmitter","_onA11yTabEmitter","_setup","linkifier","_instantiationService","createInstance","linkifier2","_inputHandler","onRequestBell","bell","onRequestRefreshRows","onRequestReset","reset","onRequestScroll","eraseAttr","isWrapped","scroll","onRequestWindowsOptionsReport","_reportWindowsOptions","onAnsiColorChange","_changeAnsiColor","forwardEvent","onCursorMove","onTitleChange","_afterResize","optionsService","_colorManager","ansiColor","colorIndex","setColors","viewport","onThemeChange","_isDisposed","_customKeyEventHandler","write","buffers","active","preventScroll","_updateOptions","_charSizeService","measure","setRenderer","_createRenderer","syncScrollArea","screenReaderMode","_accessibilityManager","setupTabStops","_setTheme","_onTextAreaFocus","_coreService","sendFocus","C0","ESC","updateCursorStyle","_showCursor","blur","_onTextAreaBlur","_syncTextArea","isCursorInViewport","_compositionHelper","isComposing","cellHeight","lineHeight","cursorTop","cursorLeft","_initGlobal","_bindKeys","hasSelection","copyHandler","pasteHandlerWrapper","handlePasteEvent","isFirefox","button","rightClickHandler","rightClickSelectsWord","isLinux","_keyUp","_keyDown","_keyPress","compositionstart","compositionupdate","compositionend","updateCompositionElements","_queueLinkification","parent","isConnected","_document","ownerDocument","dir","fragment","createDocumentFragment","_viewportElement","_viewportScrollArea","_helperContainer","coreBrowserService","CoreBrowserService","setService","ICoreBrowserService","CharSizeService","ICharSizeService","_compositionView","CompositionHelper","_theme","onOptionChange","renderer","RenderService","IRenderService","resize","_soundService","SoundService","ISoundService","MouseService","Viewport","amount","suppressEvent","onRequestSyncScrollBar","onFocus","SelectionService","onRequestScrollLines","suppressScrollEvent","onSelectionChange","onRequestRedraw","onSelectionChanged","columnSelectMode","onLinuxMouseSelection","onMouseDown","_coreMouseService","areMouseEventsActive","disable","enable","bindMouse","rendererType","Renderer","DomRenderer","el","sendEvent","but","action","getRawByteCoords","overrideType","buttons","deltaY","triggerMouseEvent","col","row","ctrl","ctrlKey","alt","altKey","shiftKey","requestedEvents","mouseup","wheel","mousedrag","mousemove","eventListeners","cancel","onProtocolChange","events","logLevel","explainEvents","passive","activeProtocol","shouldForceSelection","hasScrollback","getLinesScrolled","sequence","applicationCursorKeys","abs","onWheel","onTouchStart","onTouchMove","refreshRows","shouldColumnSelect","isCursorInitialized","disp","attachCustomKeyEventHandler","customKeyEventHandler","registerCharacterJoiner","joinerId","deregisterCharacterJoiner","markers","addMarker","cursorYOffset","normal","ybase","column","setSelection","getSelection","getSelectionPosition","startColumn","selectionStart","endColumn","selectionEnd","clearSelection","selectAll","selectLines","keydown","scrollToBottom","evaluateKeyboardEvent","macOptionIsMeta","scrollCount","_isThirdLevelShift","ETX","CR","domEvent","thirdLevelKey","metaKey","isWindows","keyCode","wasModifierKeyOnlyEvent","charCode","which","String","fromCharCode","_soundBell","playBellSound","hasValidSize","getBlankLine","DEFAULT_ATTR_DATA","_onScroll","WindowsOptionsReportType","GET_WIN_SIZE_PIXELS","canvasWidth","scaledCanvasWidth","toFixed","canvasHeight","scaledCanvasHeight","GET_CELL_SIZE_PIXELS","cellWidth","scaledCellWidth","scaledCellHeight","force","cancelEvents","_visualBell","bellStyle","CoreTerminal","Terminal","_scrollLines","_scrollArea","scrollBarWidth","_currentRowHeight","_lastRecordedBufferLength","_lastRecordedViewportHeight","_lastRecordedBufferHeight","_lastTouchY","_lastScrollTop","_wheelPartialScroll","_refreshAnimationFrame","_ignoreNextScrollEvent","offsetWidth","backgroundColor","_refresh","immediate","offsetHeight","newBufferHeight","scrollTop","newScrollTop","offsetParent","diff","_bubbleScroll","scrollPosFromTop","cancelable","_getPixelsScrolled","_applyScrollModifier","deltaMode","WheelEvent","DOM_DELTA_LINE","DOM_DELTA_PAGE","DOM_DELTA_PIXEL","modifier","fastScrollModifier","fastScrollSensitivity","scrollSensitivity","touches","_textarea","_isComposing","_isSendingComposition","_compositionPosition","_dataAlreadySent","_finalizeComposition","_handleAnyTextareaChanges","waitForPropagation","input","oldValue","dontRecurse","fontFamily","fontSize","compositionViewBounds","ICoreService","getCoordsRelativeToElement","rect","colCount","hasValidCharSize","actualCellWidth","isSelection","moveToRequestedRow","startY","targetY","bufferService","applicationCursor","wrappedRowsForRow","repeat","wrappedRows","direction","verticalDirection","wrappedRowsCount","currentRow","lineWraps","bufferLine","startCol","endCol","forward","currentCol","bufferStr","mod","count","str","rpt","targetX","resetStartingRow","horizontalDirection","moveToRequestedCol","rowDifference","currX","colsFromRowEnd","_addons","instance","loadAddon","terminal","loadedAddon","isDisposed","_wrappedAddonDispose","apply","AddonManager","_core","_addonManager","_checkProposedApi","allowProposedApi","onData","onBinary","_parser","ParserApi","UnicodeApi","_buffer","BufferNamespaceApi","columns","_verifyIntegers","registerMarker","scrollPages","pageCount","scrollToTop","scrollToLine","callback","writeUtf8","writeln","getOption","setOption","addon","values","Infinity","isNaN","init","getLine","BufferLineApiView","getNullCell","CellData","_onBufferChange","_normal","BufferApiView","_alternate","onBufferActivate","alternate","_line","getCell","cell","loadCell","translateToString","trimRight","registerCsiHandler","addCsiHandler","params","toArray","registerDcsHandler","addDcsHandler","registerEscHandler","addEscHandler","registerOscHandler","ident","addOscHandler","provider","unicodeService","versions","activeVersion","version","_container","_alpha","_colors","_rendererId","_scaledCharWidth","_scaledCharHeight","_scaledCellWidth","_scaledCellHeight","_scaledCharLeft","_scaledCharTop","_currentGlyphIdentifier","chars","code","bold","dim","italic","_canvas","_initCanvas","_charAtlas","throwIfFalsy","_clearAll","onOptionsChanged","onGridChanged","colorSet","_refreshCharAtlas","_setTransparency","oldCanvas","cloneNode","replaceChild","acquireCharAtlas","warmUp","scaledCharWidth","scaledCharHeight","scaledCharLeft","scaledCharTop","_fillCells","_fillBottomLineAtCells","_fillLeftLineAtCell","_strokeRectAtCell","lineWidth","strokeRect","clearRect","_clearCells","_fillCharTrueColor","font","_getFont","textBaseline","_clipRow","fillText","getChars","_drawChars","contrastColor","_getContrastColor","isFgRGB","isBgRGB","_drawUncachedChars","isInverse","isBgDefault","INVERTED_DEFAULT_COLOR","getBgColor","isFgDefault","getFgColor","DEFAULT_COLOR","drawBoldTextInBrightColors","isBold","WHITESPACE_CELL_CHAR","getCode","WHITESPACE_CELL_CODE","isDim","isItalic","draw","fgOverride","save","AttributeData","toColorRGB","join","globalAlpha","DIM_OPACITY","restore","beginPath","clip","fontWeightBold","fontWeight","minimumContrastRatio","adjustedColor","fgColor","fgColorMode","getFgColorMode","bgColor","bgColorMode","getBgColorMode","temp","temp2","_resolveBackgroundRgba","_resolveForegroundRgba","inverse","BaseRenderLayer","firstCell","combinedData","_width","isCombined","getWidth","setFromCharData","getAsCharData","JoinedCellData","_characterJoiners","_nextCharacterJoinerId","_workCell","joiner","getJoinedCharacters","ranges","lineStr","rangeStartColumn","currentStringIndex","rangeStartStringIndex","rangeAttrFG","rangeAttrBG","getBg","getTrimmedLength","joinedRanges","_getJoinedRanges","startIndex","endIndex","joinerRanges","CharacterJoinerRegistry","_mergeRanges","_stringRangesToCellRanges","currentRangeIndex","currentRangeStarted","currentRange","getString","newRange","inRange","BLINK_INTERVAL","container","rendererId","_onRequestRedraw","_coreBrowserService","_cell","_state","isFocused","_cursorRenderers","_renderBarCursor","_renderBlockCursor","_renderUnderlineCursor","_clearCursor","_cursorBlinkStateManager","pause","resume","cursorBlink","CursorBlinkStateManager","_render","restartBlinkAnimation","isPaused","triggeredByAnimationFrame","isCursorHidden","cursorY","viewportRelativeCursorY","cursorX","cursorStyle","_renderBlurCursor","isCursorVisible","cursorWidth","strokeStyle","CursorRenderLayer","_restartInterval","_blinkStartTimeout","_blinkInterval","clearInterval","_animationTimeRestarted","Date","now","timeToStart","time","setInterval","cache","GridCache","onShowLinkUnderline","onHideLinkUnderline","middleRowCount","is256Color","LinkRenderLayer","nextRendererId","_id","_characterJoinerRegistry","_renderLayers","TextRenderLayer","SelectionRenderLayer","_devicePixelRatio","_updateDimensions","removeTerminalFromCache","onDevicePixelRatioChange","l","onCharSizeChanged","_runOperation","operation","renderRows","letterSpacing","_clearState","_didStateChange","viewportStartRow","viewportEndRow","viewportCappedStartRow","viewportCappedEndRow","startRowEndCol","middleRowsCount","_areCoordinatesEqual","coord1","coord2","characterJoinerRegistry","_characterWidth","_characterFont","_characterOverlapCache","terminalFont","_forEachCell","firstRow","lastRow","joinerRegistry","isJoined","lastCharX","_isOverlapping","getCodePoint","NULL_CELL_CODE","_drawBackground","prevFillStyle","nextFillStyle","isBgPalette","_drawForeground","isInvisible","isUnderline","beginFrame","hasOwnProperty","overlaps","measureText","_didWarmUp","_doWarmUp","BaseCharAtlas","charAtlasCache","newConfig","generateConfig","ownedByIndex","entry","ownedBy","configEquals","config","atlas","newEntry","DynamicCharAtlas","clonedColors","colorCode","CHAR_ATLAS_CELL_SPACING","TRANSPARENT_COLOR","getGlyphCacheKey","glyph","_config","_drawToCacheCount","_glyphsWaitingOnBitmap","_bitmapCommitTimeout","_bitmap","_cacheCanvas","_cacheCtx","tmpCanvas","_tmpCtx","_height","capacity","_cacheMap","LRUMap","prealloc","_canCache","glyphKey","cacheValue","_drawFromCache","peek","_drawToCache","_toCoordinateX","_toCoordinateY","isEmpty","cacheX","cacheY","drawImage","inBitmap","_getColorFromAnsiIndex","idx","_getBackgroundColor","_getForegroundColor","fontStyle","imageData","offset","clearColor","putImageData","_addGlyphToBitmap","isSafari","_generateBitmap","glyphsMovingToBitmap","createImageBitmap","then","bitmap","NoneCharAtlas","_map","_head","_tail","_nodePool","_unlinkNode","prev","_appendNode","tail","nodePool","peekValue","head","TERMINAL_CLASS_PREFIX","FG_CLASS_PREFIX","BG_CLASS_PREFIX","FOCUS_CLASS","nextTerminalId","_linkifier","_linkifier2","_terminalClass","_refreshRowElements","_selectionContainer","_injectCss","_rowFactory","DomRendererRowFactory","_onLinkHover","_onLinkLeave","_themeStyleElement","_dimensionsStyleElement","overflow","styles","_terminalSelector","BOLD_CLASS","ITALIC_CLASS","CURSOR_CLASS","CURSOR_STYLE_BLOCK_CLASS","CURSOR_BLINK_CLASS","CURSOR_STYLE_BAR_CLASS","CURSOR_STYLE_UNDERLINE_CLASS","documentFragment","_createSelectionElement","colStart","colEnd","cursorAbsoluteY","rowElement","createRow","_setCellUnderline","enabled","span","textDecoration","DIM_CLASS","UNDERLINE_CLASS","isCursorRow","lineLength","charElement","_applyMinimumContrast","_addStyle","padStart","padChar","isSelectAllActive","selectionStartLength","areSelectionValuesReversed","startPlusLength","onTrim","SelectionModel","_onCharSizeChange","_measureStrategy","DomMeasureStrategy","_parentElement","_result","_measureElement","geometry","getRootNode","activeElement","hasFocus","_renderer","_isPaused","_needsFullRefresh","_isNextRenderRedrawOnly","_needsSelectionRefresh","_canvasWidth","_canvasHeight","_selectionState","_onDimensionsChange","_onRefreshRequest","_renderDebouncer","_fullRefresh","onCharSizeChange","IntersectionObserver","_onIntersectionChange","threshold","observe","disconnect","isIntersecting","intersectionRatio","isRedrawOnly","_fireOnCanvasResize","changeOptions","NON_BREAKING_SPACE_CHAR","ALL_NON_BREAKING_SPACE_REGEX","_dragScrollAmount","_enabled","_mouseDownTimeStamp","_oldHasSelection","_oldSelectionStart","_oldSelectionEnd","_onLinuxMouseSelection","_onRedrawRequest","_onRequestScrollLines","_mouseUpListener","_onMouseUp","onUserInput","_trimListener","_onTrim","_onBufferActivate","_model","_activeSelectionMode","_removeMouseDownListeners","finalSelectionStart","finalSelectionEnd","lineText","isLinuxMouseSelection","_isClickInSelection","_getMouseBufferCoords","_areCoordsInSelection","_selectWordAtCursor","_selectWordAt","_getMouseEventScrollAmount","terminalHeight","macOptionClickForcesSelection","timeStamp","_onIncrementalClick","detail","_onSingleClick","_onDoubleClick","_onTripleClick","_addMouseDownListeners","_dragScrollIntervalTimer","_dragScroll","hasWidth","_selectLineAt","previousSelectionEnd","_selectToWordAt","timeElapsed","coordinates","moveToCellSequence","_fireEventIfSelectionChanged","_fireOnSelectionChange","activeBuffer","_convertViewportColToCharacterIndex","charIndex","_getWordAt","allowWhitespaceOnlySelection","followWrappedLinesAbove","followWrappedLinesBelow","charOffset","leftWideCharCount","rightWideCharCount","leftLongCharOffset","rightLongCharOffset","charAt","_isCharWordSeparator","trim","previousBufferLine","previousLineWordPosition","nextBufferLine","nextLineWordPosition","wordPosition","wordSeparator","wrappedRange","getWrappedRangeForLine","last","createDecorator","_audioContext","audioContextCtor","AudioContext","webkitAudioContext","audioContext","bellAudioSource","createBufferSource","decodeAudioData","_base64ToArrayBuffer","_removeMimeType","bellSound","connect","destination","base64","binaryString","atob","len","bytes","Uint8Array","charCodeAt","dataURI","_maxLength","onDeleteEmitter","onInsertEmitter","onTrimEmitter","_array","Array","_startIndex","_length","newMaxLength","newArray","_getCyclicIndex","newLength","recycle","deleteCount","items","countToTrim","trimStart","shiftElements","expandListBy","CircularList","clone","val","depth","clonedObject","isArray","_onBinary","_onData","_onLineFeed","InstantiationService","OptionsService","BufferService","LogService","CoreService","CoreMouseService","ICoreMouseService","_dirtyRowService","DirtyRowService","IDirtyRowService","UnicodeService","_charsetService","CharsetService","ICharsetService","InputHandler","_writeBuffer","WriteBuffer","parse","_windowsMode","writeSync","MINIMUM_COLS","MINIMUM_ROWS","newLine","_cachedBlankLine","topRow","bottomRow","scrollBottom","willBufferBeTrimmed","isFull","copyFrom","isUserScrolling","scrollRegionHeight","markRangeDirty","oldYdisp","scrollAmount","windowsMode","_enableWindowsMode","updateWindowsModeWrappedState","final","_listeners","_disposed","_event","arg1","arg2","queue","call","from","to","GLEVEL","MAX_PARSEBUFFER_LENGTH","paramToWindowOption","n","opts","setWinLines","restoreWin","minimizeWin","setWinPosition","setWinSizePixels","raiseWin","lowerWin","refreshWin","setWinSizeChars","maximizeWin","fullscreenWin","getWinState","getWinPosition","getWinSizePixels","getScreenSizePixels","getCellSizePixels","getWinSizeChars","getScreenSizeChars","getIconTitle","getWinTitle","pushTitle","popTitle","_data","Uint32Array","hook","put","concat","subarray","unhook","success","utf32ToString","pt","EscapeSequenceParser","_parseBuffer","_stringDecoder","StringToUtf32","_utf8Decoder","Utf8ToUtf32","_windowTitle","_iconName","_windowTitleStack","_iconNameStack","_curAttrData","_eraseAttrDataInternal","_onRequestBell","_onRequestRefreshRows","_onRequestReset","_onRequestScroll","_onRequestSyncScrollBar","_onRequestWindowsOptionsReport","_onA11yChar","_onA11yTab","_onAnsiColorChange","setCsiHandlerFallback","identifier","identToString","setEscHandlerFallback","setExecuteHandlerFallback","setOscHandlerFallback","setDcsHandlerFallback","payload","setPrintHandler","print","insertChars","intermediates","scrollLeft","cursorUp","scrollRight","cursorDown","cursorForward","cursorBackward","cursorNextLine","cursorPrecedingLine","cursorCharAbsolute","cursorPosition","cursorForwardTab","eraseInDisplay","prefix","eraseInLine","insertLines","deleteLines","deleteChars","scrollUp","scrollDown","eraseChars","cursorBackwardTab","charPosAbsolute","hPositionRelative","repeatPrecedingCharacter","sendDeviceAttributesPrimary","sendDeviceAttributesSecondary","linePosAbsolute","vPositionRelative","hVPosition","tabClear","setMode","setModePrivate","resetMode","resetModePrivate","charAttributes","deviceStatus","deviceStatusPrivate","softReset","setCursorStyle","setScrollRegion","saveCursor","windowOptions","restoreCursor","insertColumns","deleteColumns","setExecuteHandler","BEL","LF","lineFeed","VT","FF","carriageReturn","BS","backspace","HT","tab","SO","shiftOut","SI","shiftIn","C1","IND","NEL","nextLine","HTS","tabSet","OscHandler","setTitle","setIconName","setAnsiColor","reverseIndex","keypadApplicationMode","keypadNumericMode","fullReset","setgLevel","selectDefaultCharset","flag","selectCharset","CHARSETS","screenAlignmentPattern","setErrorHandler","error","DECRQSS","cursorStartX","cursorStartY","clearRange","decode","chWidth","charset","wraparoundMode","wraparound","insertMode","modes","curAttr","bufferRow","markDirty","setCellFromCodePoint","extended","wcwidth","ch","stringFromCodePoint","_eraseAttrData","insertCells","NULL_CELL_WIDTH","addCodepointToCell","precedingCodepoint","hasContent","DcsHandler","convertEol","reverseWraparound","_restrictCursor","originalX","nextStop","maxCol","origin","_setCursor","_moveCursor","diffToTop","diffToBottom","param","tabs","prevStop","_eraseInBufferLine","clearWrap","replaceCells","_resetBufferLine","fill","scrollBackSize","scrollBottomRowsOffset","scrollBottomAbsolute","deleteCells","_is","term","termName","setgCharset","DEFAULT_CHARSET","applicationKeypad","activeEncoding","activateAltBuffer","activateNormalBuffer","_updateAttrColor","mode","c1","c2","c3","fromColorRGB","_extractColor","accu","cSpace","advance","hasSubParams","subparams","getSubParams","underlineColor","_processUnderline","underlineStyle","updateExtended","p","savedX","savedY","savedCurAttrData","savedCharset","isBlinking","bottom","second","_savedCharset","_parseAnsiColorChange","collectAndFlag","level","yOffset","markAllDirty","_disposables","d","unregister","disposables","array","isNode","navigator","userAgent","platform","includes","test","isIpad","isIphone","fillFallback","constructor","lastChar","CHAR_DATA_CODE_INDEX","ExtendedAttrs","newObj","isBlink","isFgPalette","isAttributeDefault","hasExtendedAttrs","getUnderlineColor","getUnderlineColorMode","isUnderlineColorRGB","isUnderlineColorPalette","isUnderlineColorDefault","getUnderlineStyle","MAX_BUFFER_SIZE","_hasScrollback","_nullCell","fromCharData","NULL_CELL_CHAR","_whitespaceCell","WHITESPACE_CELL_WIDTH","_cols","_rows","_getCorrectBufferLength","getWhitespaceCell","BufferLine","maxLength","relativeY","correctBufferLength","scrollback","fillViewportRows","fillAttr","newCols","newRows","nullCell","addToY","amountToTrim","_isReflowEnabled","_reflow","_reflowLarger","_reflowSmaller","toRemove","reflowLargerGetLinesToRemove","newLayoutResult","reflowLargerCreateNewLayout","reflowLargerApplyNewLayout","layout","_reflowLargerAdjustViewport","countRemoved","viewportAdjustments","toInsert","countToInsert","wrappedLines","absoluteY","trimmedLines","lastLineLength","destLineLengths","reflowSmallerGetNewLineLengths","linesToAdd","newLines","destLineIndex","destCol","srcLineIndex","srcCol","cellsToCopy","copyCellsFrom","wrappedLinesIndex","getWrappedLineTrimmedLength","setCell","insertEvents","originalLines","originalLinesLength","originalLineIndex","nextToInsertIndex","nextToInsert","countInsertedSoFar","nextI","insertCountEmitted","lineIndex","CHAR_DATA_WIDTH_INDEX","CHAR_DATA_CHAR_INDEX","tabStopWidth","marker","Marker","onInsert","onDelete","onDispose","_removeMarker","startOverscan","endOverscan","BufferStringIterator","Buffer","_trimRight","_endIndex","_startOverscan","_endOverscan","_current","fillCellData","_combined","_extendedAttrs","cp","CHAR_DATA_ATTR_INDEX","codePoint","eAttrs","keys","src","applyInReverse","srcData","srcCombinedKeys","endsInNull","followingLineStartsWithWide","oldCols","bufferAbsoluteY","srcTrimmedTineLength","srcRemainingCells","destRemainingCells","countToRemove","nextToRemoveIndex","nextToRemoveStart","countRemovedSoFar","newLayout","newLayoutLines","newLineLengths","cellsNeeded","reduce","srcLine","cellsAvailable","oldTrimmedLength","endsWithWide","_alt","_activeBuffer","inactiveBuffer","BufferSet","obj","combined","DEFAULT_ATTR","_nextId","_onDispose","C","NUL","SOH","STX","EOT","ENQ","ACK","DLE","DC1","DC2","DC3","DC4","NAK","SYN","ETB","CAN","EM","SUB","FS","GS","RS","US","SP","DEL","PAD","HOP","BPH","NBH","SSA","ESA","HTJ","VTS","PLD","PLU","RI","SS2","SS3","DCS","PU1","PU2","STS","CCH","MW","SPA","EPA","SOS","SGCI","SCI","CSI","ST","OSC","PM","APC","KEYCODE_KEY_MAPPINGS","48","49","50","51","52","53","54","55","56","57","186","187","188","189","190","191","192","219","220","221","222","applicationCursorMode","modifiers","keyMapping","codepoint","_interim","startPos","interim","byte1","byte2","byte3","byte4","discardInterim","tmp","missing","fourStop","table","BMP_COMBINING","HIGH_COMBINING","num","ucs","mid","bisearch","UnicodeV6","_action","_callbacks","_pendingData","_bufferOffset","cb","_innerWrite","startTime","PAYLOAD_LIMIT","EMPTY_HANDLERS","_handlers","create","_active","_ident","_handlerFb","registerHandler","handlerList","handlerIndex","clearHandler","setHandlerFallback","DcsParser","EMPTY_PARAMS","Params","addParam","_handler","_params","_hitLimit","ret","setDefault","addMany","codes","TransitionTable","NON_ASCII_PRINTABLE","VT500_TRANSITION_TABLE","blueprint","unused","PRINTABLES","EXECUTABLES","states","_transitions","initialState","currentState","_collect","_printHandlerFb","_executeHandlerFb","_csiHandlerFb","_escHandlerFb","_errorHandlerFb","_printHandler","_executeHandlers","_csiHandlers","_escHandlers","_oscParser","OscParser","_dcsParser","_errorHandler","_identifier","finalRange","res","intermediate","finalCode","reverse","clearPrintHandler","clearEscHandler","clearExecuteHandler","clearCsiHandler","clearDcsHandler","clearOscHandler","clearErrorHandler","transition","osc","dcs","collect","abort","handlers","addSubParam","addDigit","handlersEsc","jj","_start","_put","_end","MAX_VALUE","maxSubParamsLength","Int32Array","_subParams","_subParamsLength","_subParamsIdx","Uint16Array","_rejectDigits","_rejectSubDigits","_digitIsSub","fromArray","k","newParams","prototype","getSubParamsAll","store","cur","glevel","_charsets","DEFAULT_PROTOCOLS","NONE","restrict","X10","VT200","DRAG","ANY","eventCode","isSGR","S","DEFAULT_ENCODINGS","DEFAULT","SGR","_protocols","_encodings","_activeProtocol","_activeEncoding","_onProtocolChange","_lastEvent","addProtocol","addEncoding","name","protocol","encoding","_compareEvents","report","triggerBinaryEvent","down","up","drag","move","e1","e2","DEFAULT_MODES","DEFAULT_DEC_PRIVATE_MODES","_onUserInput","_scrollToBottom","wasUserInput","disableStdin","_entries","entries","service","ServiceCollection","_services","IInstantiationService","getService","ctor","serviceDependencies","getServiceDependencies","sort","serviceArgs","dependency","firstServiceArgPos","args","LogLevel","optionsKeyToLogLevel","DEBUG","info","INFO","WARN","ERROR","off","OFF","_updateLogLevel","_logLevel","_evalLazyOptionalParams","optionalParams","_log","message","log","DEFAULT_BELL_SOUND","DEFAULT_OPTIONS","altClickMovesCursor","FONT_WEIGHT_OPTIONS","CONSTRUCTOR_ONLY_OPTIONS","_onOptionChange","newValue","_sanitizeAndValidateOption","storeServiceDependency","serviceRegistry","decorator","arguments","_providers","_onChange","defaultProvider","_activeProvider","__webpack_module_cache__","__webpack_require__","moduleId","__webpack_modules__"],"mappings":"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","file":"xterm.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse {\n\t\tvar a = factory();\n\t\tfor(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];\n\t}\n})(self, function() {\nreturn ","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport * as Strings from 'browser/LocalizableStrings';\nimport { ITerminal } from 'browser/Types';\nimport { IBuffer } from 'common/buffer/Types';\nimport { isMac } from 'common/Platform';\nimport { RenderDebouncer } from 'browser/RenderDebouncer';\nimport { addDisposableDomListener } from 'browser/Lifecycle';\nimport { Disposable } from 'common/Lifecycle';\nimport { ScreenDprMonitor } from 'browser/ScreenDprMonitor';\nimport { IRenderService } from 'browser/services/Services';\nimport { removeElementFromParent } from 'browser/Dom';\n\nconst MAX_ROWS_TO_READ = 20;\n\nconst enum BoundaryPosition {\n TOP,\n BOTTOM\n}\n\nexport class AccessibilityManager extends Disposable {\n private _accessibilityTreeRoot: HTMLElement;\n private _rowContainer: HTMLElement;\n private _rowElements: HTMLElement[];\n private _liveRegion: HTMLElement;\n private _liveRegionLineCount: number = 0;\n\n private _renderRowsDebouncer: RenderDebouncer;\n private _screenDprMonitor: ScreenDprMonitor;\n\n private _topBoundaryFocusListener: (e: FocusEvent) => void;\n private _bottomBoundaryFocusListener: (e: FocusEvent) => void;\n\n /**\n * This queue has a character pushed to it for keys that are pressed, if the\n * next character added to the terminal is equal to the key char then it is\n * not announced (added to live region) because it has already been announced\n * by the textarea event (which cannot be canceled). There are some race\n * condition cases if there is typing while data is streaming, but this covers\n * the main case of typing into the prompt and inputting the answer to a\n * question (Y/N, etc.).\n */\n private _charsToConsume: string[] = [];\n\n private _charsToAnnounce: string = '';\n\n constructor(\n private readonly _terminal: ITerminal,\n private readonly _renderService: IRenderService\n ) {\n super();\n this._accessibilityTreeRoot = document.createElement('div');\n this._accessibilityTreeRoot.classList.add('xterm-accessibility');\n\n this._rowContainer = document.createElement('div');\n this._rowContainer.setAttribute('role', 'list');\n this._rowContainer.classList.add('xterm-accessibility-tree');\n this._rowElements = [];\n for (let i = 0; i < this._terminal.rows; i++) {\n this._rowElements[i] = this._createAccessibilityTreeNode();\n this._rowContainer.appendChild(this._rowElements[i]);\n }\n\n this._topBoundaryFocusListener = e => this._onBoundaryFocus(e, BoundaryPosition.TOP);\n this._bottomBoundaryFocusListener = e => this._onBoundaryFocus(e, BoundaryPosition.BOTTOM);\n this._rowElements[0].addEventListener('focus', this._topBoundaryFocusListener);\n this._rowElements[this._rowElements.length - 1].addEventListener('focus', this._bottomBoundaryFocusListener);\n\n this._refreshRowsDimensions();\n this._accessibilityTreeRoot.appendChild(this._rowContainer);\n\n this._renderRowsDebouncer = new RenderDebouncer(this._renderRows.bind(this));\n this._refreshRows();\n\n this._liveRegion = document.createElement('div');\n this._liveRegion.classList.add('live-region');\n this._liveRegion.setAttribute('aria-live', 'assertive');\n this._accessibilityTreeRoot.appendChild(this._liveRegion);\n\n if (!this._terminal.element) {\n throw new Error('Cannot enable accessibility before Terminal.open');\n }\n this._terminal.element.insertAdjacentElement('afterbegin', this._accessibilityTreeRoot);\n\n this.register(this._renderRowsDebouncer);\n this.register(this._terminal.onResize(e => this._onResize(e.rows)));\n this.register(this._terminal.onRender(e => this._refreshRows(e.start, e.end)));\n this.register(this._terminal.onScroll(() => this._refreshRows()));\n // Line feed is an issue as the prompt won't be read out after a command is run\n this.register(this._terminal.onA11yChar(char => this._onChar(char)));\n this.register(this._terminal.onLineFeed(() => this._onChar('\\n')));\n this.register(this._terminal.onA11yTab(spaceCount => this._onTab(spaceCount)));\n this.register(this._terminal.onKey(e => this._onKey(e.key)));\n this.register(this._terminal.onBlur(() => this._clearLiveRegion()));\n this.register(this._renderService.onDimensionsChange(() => this._refreshRowsDimensions()));\n\n this._screenDprMonitor = new ScreenDprMonitor();\n this.register(this._screenDprMonitor);\n this._screenDprMonitor.setListener(() => this._refreshRowsDimensions());\n // This shouldn't be needed on modern browsers but is present in case the\n // media query that drives the ScreenDprMonitor isn't supported\n this.register(addDisposableDomListener(window, 'resize', () => this._refreshRowsDimensions()));\n }\n\n public dispose(): void {\n super.dispose();\n removeElementFromParent(this._accessibilityTreeRoot);\n this._rowElements.length = 0;\n }\n\n private _onBoundaryFocus(e: FocusEvent, position: BoundaryPosition): void {\n const boundaryElement = e.target;\n const beforeBoundaryElement = this._rowElements[position === BoundaryPosition.TOP ? 1 : this._rowElements.length - 2];\n\n // Don't scroll if the buffer top has reached the end in that direction\n const posInSet = boundaryElement.getAttribute('aria-posinset');\n const lastRowPos = position === BoundaryPosition.TOP ? '1' : `${this._terminal.buffer.lines.length}`;\n if (posInSet === lastRowPos) {\n return;\n }\n\n // Don't scroll when the last focused item was not the second row (focus is going the other\n // direction)\n if (e.relatedTarget !== beforeBoundaryElement) {\n return;\n }\n\n // Remove old boundary element from array\n let topBoundaryElement: HTMLElement;\n let bottomBoundaryElement: HTMLElement;\n if (position === BoundaryPosition.TOP) {\n topBoundaryElement = boundaryElement;\n bottomBoundaryElement = this._rowElements.pop()!;\n this._rowContainer.removeChild(bottomBoundaryElement);\n } else {\n topBoundaryElement = this._rowElements.shift()!;\n bottomBoundaryElement = boundaryElement;\n this._rowContainer.removeChild(topBoundaryElement);\n }\n\n // Remove listeners from old boundary elements\n topBoundaryElement.removeEventListener('focus', this._topBoundaryFocusListener);\n bottomBoundaryElement.removeEventListener('focus', this._bottomBoundaryFocusListener);\n\n // Add new element to array/DOM\n if (position === BoundaryPosition.TOP) {\n const newElement = this._createAccessibilityTreeNode();\n this._rowElements.unshift(newElement);\n this._rowContainer.insertAdjacentElement('afterbegin', newElement);\n } else {\n const newElement = this._createAccessibilityTreeNode();\n this._rowElements.push(newElement);\n this._rowContainer.appendChild(newElement);\n }\n\n // Add listeners to new boundary elements\n this._rowElements[0].addEventListener('focus', this._topBoundaryFocusListener);\n this._rowElements[this._rowElements.length - 1].addEventListener('focus', this._bottomBoundaryFocusListener);\n\n // Scroll up\n this._terminal.scrollLines(position === BoundaryPosition.TOP ? -1 : 1);\n\n // Focus new boundary before element\n this._rowElements[position === BoundaryPosition.TOP ? 1 : this._rowElements.length - 2].focus();\n\n // Prevent the standard behavior\n e.preventDefault();\n e.stopImmediatePropagation();\n }\n\n private _onResize(rows: number): void {\n // Remove bottom boundary listener\n this._rowElements[this._rowElements.length - 1].removeEventListener('focus', this._bottomBoundaryFocusListener);\n\n // Grow rows as required\n for (let i = this._rowContainer.children.length; i < this._terminal.rows; i++) {\n this._rowElements[i] = this._createAccessibilityTreeNode();\n this._rowContainer.appendChild(this._rowElements[i]);\n }\n // Shrink rows as required\n while (this._rowElements.length > rows) {\n this._rowContainer.removeChild(this._rowElements.pop()!);\n }\n\n // Add bottom boundary listener\n this._rowElements[this._rowElements.length - 1].addEventListener('focus', this._bottomBoundaryFocusListener);\n\n this._refreshRowsDimensions();\n }\n\n private _createAccessibilityTreeNode(): HTMLElement {\n const element = document.createElement('div');\n element.setAttribute('role', 'listitem');\n element.tabIndex = -1;\n this._refreshRowDimensions(element);\n return element;\n }\n\n private _onTab(spaceCount: number): void {\n for (let i = 0; i < spaceCount; i++) {\n this._onChar(' ');\n }\n }\n\n private _onChar(char: string): void {\n if (this._liveRegionLineCount < MAX_ROWS_TO_READ + 1) {\n if (this._charsToConsume.length > 0) {\n // Have the screen reader ignore the char if it was just input\n const shiftedChar = this._charsToConsume.shift();\n if (shiftedChar !== char) {\n this._charsToAnnounce += char;\n }\n } else {\n this._charsToAnnounce += char;\n }\n\n if (char === '\\n') {\n this._liveRegionLineCount++;\n if (this._liveRegionLineCount === MAX_ROWS_TO_READ + 1) {\n this._liveRegion.textContent += Strings.tooMuchOutput;\n }\n }\n\n // Only detach/attach on mac as otherwise messages can go unaccounced\n if (isMac) {\n if (this._liveRegion.textContent && this._liveRegion.textContent.length > 0 && !this._liveRegion.parentNode) {\n setTimeout(() => {\n this._accessibilityTreeRoot.appendChild(this._liveRegion);\n }, 0);\n }\n }\n }\n }\n\n private _clearLiveRegion(): void {\n this._liveRegion.textContent = '';\n this._liveRegionLineCount = 0;\n\n // Only detach/attach on mac as otherwise messages can go unaccounced\n if (isMac) {\n removeElementFromParent(this._liveRegion);\n }\n }\n\n private _onKey(keyChar: string): void {\n this._clearLiveRegion();\n this._charsToConsume.push(keyChar);\n }\n\n private _refreshRows(start?: number, end?: number): void {\n this._renderRowsDebouncer.refresh(start, end, this._terminal.rows);\n }\n\n private _renderRows(start: number, end: number): void {\n const buffer: IBuffer = this._terminal.buffer;\n const setSize = buffer.lines.length.toString();\n for (let i = start; i <= end; i++) {\n const lineData = buffer.translateBufferLineToString(buffer.ydisp + i, true);\n const posInSet = (buffer.ydisp + i + 1).toString();\n const element = this._rowElements[i];\n if (element) {\n if (lineData.length === 0) {\n element.innerText = '\\u00a0';\n } else {\n element.textContent = lineData;\n }\n element.setAttribute('aria-posinset', posInSet);\n element.setAttribute('aria-setsize', setSize);\n }\n }\n this._announceCharacters();\n }\n\n private _refreshRowsDimensions(): void {\n if (!this._renderService.dimensions.actualCellHeight) {\n return;\n }\n if (this._rowElements.length !== this._terminal.rows) {\n this._onResize(this._terminal.rows);\n }\n for (let i = 0; i < this._terminal.rows; i++) {\n this._refreshRowDimensions(this._rowElements[i]);\n }\n }\n\n private _refreshRowDimensions(element: HTMLElement): void {\n element.style.height = `${this._renderService.dimensions.actualCellHeight}px`;\n }\n\n private _announceCharacters(): void {\n if (this._charsToAnnounce.length === 0) {\n return;\n }\n this._liveRegion.textContent += this._charsToAnnounce;\n this._charsToAnnounce = '';\n }\n}\n","/**\n * Copyright (c) 2016 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ISelectionService } from 'browser/services/Services';\nimport { ICoreService } from 'common/services/Services';\n\n/**\n * Prepares text to be pasted into the terminal by normalizing the line endings\n * @param text The pasted text that needs processing before inserting into the terminal\n */\nexport function prepareTextForTerminal(text: string): string {\n return text.replace(/\\r?\\n/g, '\\r');\n}\n\n/**\n * Bracket text for paste, if necessary, as per https://cirw.in/blog/bracketed-paste\n * @param text The pasted text to bracket\n */\nexport function bracketTextForPaste(text: string, bracketedPasteMode: boolean): string {\n if (bracketedPasteMode) {\n return '\\x1b[200~' + text + '\\x1b[201~';\n }\n return text;\n}\n\n/**\n * Binds copy functionality to the given terminal.\n * @param ev The original copy event to be handled\n */\nexport function copyHandler(ev: ClipboardEvent, selectionService: ISelectionService): void {\n if (ev.clipboardData) {\n ev.clipboardData.setData('text/plain', selectionService.selectionText);\n }\n // Prevent or the original text will be copied.\n ev.preventDefault();\n}\n\n/**\n * Redirect the clipboard's data to the terminal's input handler.\n * @param ev The original paste event to be handled\n * @param term The terminal on which to apply the handled paste event\n */\nexport function handlePasteEvent(ev: ClipboardEvent, textarea: HTMLTextAreaElement, coreService: ICoreService): void {\n ev.stopPropagation();\n if (ev.clipboardData) {\n const text = ev.clipboardData.getData('text/plain');\n paste(text, textarea, coreService);\n }\n}\n\nexport function paste(text: string, textarea: HTMLTextAreaElement, coreService: ICoreService): void {\n text = prepareTextForTerminal(text);\n text = bracketTextForPaste(text, coreService.decPrivateModes.bracketedPasteMode);\n coreService.triggerDataEvent(text, true);\n textarea.value = '';\n}\n\n/**\n * Moves the textarea under the mouse cursor and focuses it.\n * @param ev The original right click event to be handled.\n * @param textarea The terminal's textarea.\n */\nexport function moveTextAreaUnderMouseCursor(ev: MouseEvent, textarea: HTMLTextAreaElement, screenElement: HTMLElement): void {\n\n // Calculate textarea position relative to the screen element\n const pos = screenElement.getBoundingClientRect();\n const left = ev.clientX - pos.left - 10;\n const top = ev.clientY - pos.top - 10;\n\n // Bring textarea at the cursor position\n textarea.style.width = '20px';\n textarea.style.height = '20px';\n textarea.style.left = `${left}px`;\n textarea.style.top = `${top}px`;\n textarea.style.zIndex = '1000';\n\n textarea.focus();\n}\n\n/**\n * Bind to right-click event and allow right-click copy and paste.\n * @param ev The original right click event to be handled.\n * @param textarea The terminal's textarea.\n * @param selectionService The terminal's selection manager.\n * @param shouldSelectWord If true and there is no selection the current word will be selected\n */\nexport function rightClickHandler(ev: MouseEvent, textarea: HTMLTextAreaElement, screenElement: HTMLElement, selectionService: ISelectionService, shouldSelectWord: boolean): void {\n moveTextAreaUnderMouseCursor(ev, textarea, screenElement);\n\n if (shouldSelectWord) {\n selectionService.rightClickSelect(ev);\n }\n\n // Get textarea ready to copy from the context menu\n textarea.value = selectionService.selectionText;\n textarea.select();\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IColor } from 'browser/Types';\n\n/**\n * Helper functions where the source type is \"channels\" (individual color channels as numbers).\n */\nexport namespace channels {\n export function toCss(r: number, g: number, b: number, a?: number): string {\n if (a !== undefined) {\n return `#${toPaddedHex(r)}${toPaddedHex(g)}${toPaddedHex(b)}${toPaddedHex(a)}`;\n }\n return `#${toPaddedHex(r)}${toPaddedHex(g)}${toPaddedHex(b)}`;\n }\n\n export function toRgba(r: number, g: number, b: number, a: number = 0xFF): number {\n // >>> 0 forces an unsigned int\n return (r << 24 | g << 16 | b << 8 | a) >>> 0;\n }\n}\n\n/**\n * Helper functions where the source type is `IColor`.\n */\nexport namespace color {\n export function blend(bg: IColor, fg: IColor): IColor {\n const a = (fg.rgba & 0xFF) / 255;\n if (a === 1) {\n return {\n css: fg.css,\n rgba: fg.rgba\n };\n }\n const fgR = (fg.rgba >> 24) & 0xFF;\n const fgG = (fg.rgba >> 16) & 0xFF;\n const fgB = (fg.rgba >> 8) & 0xFF;\n const bgR = (bg.rgba >> 24) & 0xFF;\n const bgG = (bg.rgba >> 16) & 0xFF;\n const bgB = (bg.rgba >> 8) & 0xFF;\n const r = bgR + Math.round((fgR - bgR) * a);\n const g = bgG + Math.round((fgG - bgG) * a);\n const b = bgB + Math.round((fgB - bgB) * a);\n const css = channels.toCss(r, g, b);\n const rgba = channels.toRgba(r, g, b);\n return { css, rgba };\n }\n\n export function isOpaque(color: IColor): boolean {\n return (color.rgba & 0xFF) === 0xFF;\n }\n\n export function ensureContrastRatio(bg: IColor, fg: IColor, ratio: number): IColor | undefined {\n const result = rgba.ensureContrastRatio(bg.rgba, fg.rgba, ratio);\n if (!result) {\n return undefined;\n }\n return rgba.toColor(\n (result >> 24 & 0xFF),\n (result >> 16 & 0xFF),\n (result >> 8 & 0xFF)\n );\n }\n\n export function opaque(color: IColor): IColor {\n const rgbaColor = (color.rgba | 0xFF) >>> 0;\n const [r, g, b] = rgba.toChannels(rgbaColor);\n return {\n css: channels.toCss(r, g, b),\n rgba: rgbaColor\n };\n }\n\n export function opacity(color: IColor, opacity: number): IColor {\n const a = Math.round(opacity * 0xFF);\n const [r, g, b] = rgba.toChannels(color.rgba);\n return {\n css: channels.toCss(r, g, b, a),\n rgba: channels.toRgba(r, g, b, a)\n };\n }\n}\n\n/**\n * Helper functions where the source type is \"css\" (string: '#rgb', '#rgba', '#rrggbb', '#rrggbbaa').\n */\nexport namespace css {\n export function toColor(css: string): IColor {\n switch (css.length) {\n case 7: // #rrggbb\n return {\n css,\n rgba: (parseInt(css.slice(1), 16) << 8 | 0xFF) >>> 0\n };\n case 9: // #rrggbbaa\n return {\n css,\n rgba: parseInt(css.slice(1), 16) >>> 0\n };\n }\n throw new Error('css.toColor: Unsupported css format');\n }\n}\n\n/**\n * Helper functions where the source type is \"rgb\" (number: 0xrrggbb).\n */\nexport namespace rgb {\n /**\n * Gets the relative luminance of an RGB color, this is useful in determining the contrast ratio\n * between two colors.\n * @param rgb The color to use.\n * @see https://www.w3.org/TR/WCAG20/#relativeluminancedef\n */\n export function relativeLuminance(rgb: number): number {\n return relativeLuminance2(\n (rgb >> 16) & 0xFF,\n (rgb >> 8 ) & 0xFF,\n (rgb ) & 0xFF);\n }\n\n /**\n * Gets the relative luminance of an RGB color, this is useful in determining the contrast ratio\n * between two colors.\n * @param r The red channel (0x00 to 0xFF).\n * @param g The green channel (0x00 to 0xFF).\n * @param b The blue channel (0x00 to 0xFF).\n * @see https://www.w3.org/TR/WCAG20/#relativeluminancedef\n */\n export function relativeLuminance2(r: number, g: number, b: number): number {\n const rs = r / 255;\n const gs = g / 255;\n const bs = b / 255;\n const rr = rs <= 0.03928 ? rs / 12.92 : Math.pow((rs + 0.055) / 1.055, 2.4);\n const rg = gs <= 0.03928 ? gs / 12.92 : Math.pow((gs + 0.055) / 1.055, 2.4);\n const rb = bs <= 0.03928 ? bs / 12.92 : Math.pow((bs + 0.055) / 1.055, 2.4);\n return rr * 0.2126 + rg * 0.7152 + rb * 0.0722;\n }\n}\n\n/**\n * Helper functions where the source type is \"rgba\" (number: 0xrrggbbaa).\n */\nexport namespace rgba {\n export function ensureContrastRatio(bgRgba: number, fgRgba: number, ratio: number): number | undefined {\n const bgL = rgb.relativeLuminance(bgRgba >> 8);\n const fgL = rgb.relativeLuminance(fgRgba >> 8);\n const cr = contrastRatio(bgL, fgL);\n if (cr < ratio) {\n if (fgL < bgL) {\n return reduceLuminance(bgRgba, fgRgba, ratio);\n }\n return increaseLuminance(bgRgba, fgRgba, ratio);\n }\n return undefined;\n }\n\n export function reduceLuminance(bgRgba: number, fgRgba: number, ratio: number): number {\n // This is a naive but fast approach to reducing luminance as converting to\n // HSL and back is expensive\n const bgR = (bgRgba >> 24) & 0xFF;\n const bgG = (bgRgba >> 16) & 0xFF;\n const bgB = (bgRgba >> 8) & 0xFF;\n let fgR = (fgRgba >> 24) & 0xFF;\n let fgG = (fgRgba >> 16) & 0xFF;\n let fgB = (fgRgba >> 8) & 0xFF;\n let cr = contrastRatio(rgb.relativeLuminance2(fgR, fgB, fgG), rgb.relativeLuminance2(bgR, bgG, bgB));\n while (cr < ratio && (fgR > 0 || fgG > 0 || fgB > 0)) {\n // Reduce by 10% until the ratio is hit\n fgR -= Math.max(0, Math.ceil(fgR * 0.1));\n fgG -= Math.max(0, Math.ceil(fgG * 0.1));\n fgB -= Math.max(0, Math.ceil(fgB * 0.1));\n cr = contrastRatio(rgb.relativeLuminance2(fgR, fgB, fgG), rgb.relativeLuminance2(bgR, bgG, bgB));\n }\n return (fgR << 24 | fgG << 16 | fgB << 8 | 0xFF) >>> 0;\n }\n\n export function increaseLuminance(bgRgba: number, fgRgba: number, ratio: number): number {\n // This is a naive but fast approach to increasing luminance as converting to\n // HSL and back is expensive\n const bgR = (bgRgba >> 24) & 0xFF;\n const bgG = (bgRgba >> 16) & 0xFF;\n const bgB = (bgRgba >> 8) & 0xFF;\n let fgR = (fgRgba >> 24) & 0xFF;\n let fgG = (fgRgba >> 16) & 0xFF;\n let fgB = (fgRgba >> 8) & 0xFF;\n let cr = contrastRatio(rgb.relativeLuminance2(fgR, fgB, fgG), rgb.relativeLuminance2(bgR, bgG, bgB));\n while (cr < ratio && (fgR < 0xFF || fgG < 0xFF || fgB < 0xFF)) {\n // Increase by 10% until the ratio is hit\n fgR = Math.min(0xFF, fgR + Math.ceil((255 - fgR) * 0.1));\n fgG = Math.min(0xFF, fgG + Math.ceil((255 - fgG) * 0.1));\n fgB = Math.min(0xFF, fgB + Math.ceil((255 - fgB) * 0.1));\n cr = contrastRatio(rgb.relativeLuminance2(fgR, fgB, fgG), rgb.relativeLuminance2(bgR, bgG, bgB));\n }\n return (fgR << 24 | fgG << 16 | fgB << 8 | 0xFF) >>> 0;\n }\n\n export function toChannels(value: number): [number, number, number, number] {\n return [(value >> 24) & 0xFF, (value >> 16) & 0xFF, (value >> 8) & 0xFF, value & 0xFF];\n }\n\n export function toColor(r: number, g: number, b: number): IColor {\n return {\n css: channels.toCss(r, g, b),\n rgba: channels.toRgba(r, g, b)\n };\n }\n}\n\nexport function toPaddedHex(c: number): string {\n const s = c.toString(16);\n return s.length < 2 ? '0' + s : s;\n}\n\n/**\n * Gets the contrast ratio between two relative luminance values.\n * @param l1 The first relative luminance.\n * @param l2 The first relative luminance.\n * @see https://www.w3.org/TR/WCAG20/#contrast-ratiodef\n */\nexport function contrastRatio(l1: number, l2: number): number {\n if (l1 < l2) {\n return (l2 + 0.05) / (l1 + 0.05);\n }\n return (l1 + 0.05) / (l2 + 0.05);\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IColor, IColorContrastCache } from 'browser/Types';\n\nexport class ColorContrastCache implements IColorContrastCache {\n private _color: { [bg: number]: { [fg: number]: IColor | null | undefined } | undefined } = {};\n private _rgba: { [bg: number]: { [fg: number]: string | null | undefined } | undefined } = {};\n\n public clear(): void {\n this._color = {};\n this._rgba = {};\n }\n\n public setCss(bg: number, fg: number, value: string | null): void {\n if (!this._rgba[bg]) {\n this._rgba[bg] = {};\n }\n this._rgba[bg]![fg] = value;\n }\n\n public getCss(bg: number, fg: number): string | null | undefined {\n return this._rgba[bg] ? this._rgba[bg]![fg] : undefined;\n }\n\n public setColor(bg: number, fg: number, value: IColor | null): void {\n if (!this._color[bg]) {\n this._color[bg] = {};\n }\n this._color[bg]![fg] = value;\n }\n\n public getColor(bg: number, fg: number): IColor | null | undefined {\n return this._color[bg] ? this._color[bg]![fg] : undefined;\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IColorManager, IColor, IColorSet, IColorContrastCache } from 'browser/Types';\nimport { ITheme } from 'common/services/Services';\nimport { channels, color, css } from 'browser/Color';\nimport { ColorContrastCache } from 'browser/ColorContrastCache';\n\nconst DEFAULT_FOREGROUND = css.toColor('#ffffff');\nconst DEFAULT_BACKGROUND = css.toColor('#000000');\nconst DEFAULT_CURSOR = css.toColor('#ffffff');\nconst DEFAULT_CURSOR_ACCENT = css.toColor('#000000');\nconst DEFAULT_SELECTION = {\n css: 'rgba(255, 255, 255, 0.3)',\n rgba: 0xFFFFFF4D\n};\n\n// An IIFE to generate DEFAULT_ANSI_COLORS.\nexport const DEFAULT_ANSI_COLORS = Object.freeze((() => {\n const colors = [\n // dark:\n css.toColor('#2e3436'),\n css.toColor('#cc0000'),\n css.toColor('#4e9a06'),\n css.toColor('#c4a000'),\n css.toColor('#3465a4'),\n css.toColor('#75507b'),\n css.toColor('#06989a'),\n css.toColor('#d3d7cf'),\n // bright:\n css.toColor('#555753'),\n css.toColor('#ef2929'),\n css.toColor('#8ae234'),\n css.toColor('#fce94f'),\n css.toColor('#729fcf'),\n css.toColor('#ad7fa8'),\n css.toColor('#34e2e2'),\n css.toColor('#eeeeec')\n ];\n\n // Fill in the remaining 240 ANSI colors.\n // Generate colors (16-231)\n const v = [0x00, 0x5f, 0x87, 0xaf, 0xd7, 0xff];\n for (let i = 0; i < 216; i++) {\n const r = v[(i / 36) % 6 | 0];\n const g = v[(i / 6) % 6 | 0];\n const b = v[i % 6];\n colors.push({\n css: channels.toCss(r, g, b),\n rgba: channels.toRgba(r, g, b)\n });\n }\n\n // Generate greys (232-255)\n for (let i = 0; i < 24; i++) {\n const c = 8 + i * 10;\n colors.push({\n css: channels.toCss(c, c, c),\n rgba: channels.toRgba(c, c, c)\n });\n }\n\n return colors;\n})());\n\n/**\n * Manages the source of truth for a terminal's colors.\n */\nexport class ColorManager implements IColorManager {\n public colors: IColorSet;\n private _ctx: CanvasRenderingContext2D;\n private _litmusColor: CanvasGradient;\n private _contrastCache: IColorContrastCache;\n\n constructor(document: Document, public allowTransparency: boolean) {\n const canvas = document.createElement('canvas');\n canvas.width = 1;\n canvas.height = 1;\n const ctx = canvas.getContext('2d');\n if (!ctx) {\n throw new Error('Could not get rendering context');\n }\n this._ctx = ctx;\n this._ctx.globalCompositeOperation = 'copy';\n this._litmusColor = this._ctx.createLinearGradient(0, 0, 1, 1);\n this._contrastCache = new ColorContrastCache();\n this.colors = {\n foreground: DEFAULT_FOREGROUND,\n background: DEFAULT_BACKGROUND,\n cursor: DEFAULT_CURSOR,\n cursorAccent: DEFAULT_CURSOR_ACCENT,\n selectionTransparent: DEFAULT_SELECTION,\n selectionOpaque: color.blend(DEFAULT_BACKGROUND, DEFAULT_SELECTION),\n ansi: DEFAULT_ANSI_COLORS.slice(),\n contrastCache: this._contrastCache\n };\n }\n\n public onOptionsChange(key: string): void {\n if (key === 'minimumContrastRatio') {\n this._contrastCache.clear();\n }\n }\n\n /**\n * Sets the terminal's theme.\n * @param theme The theme to use. If a partial theme is provided then default\n * colors will be used where colors are not defined.\n */\n public setTheme(theme: ITheme = {}): void {\n this.colors.foreground = this._parseColor(theme.foreground, DEFAULT_FOREGROUND);\n this.colors.background = this._parseColor(theme.background, DEFAULT_BACKGROUND);\n this.colors.cursor = this._parseColor(theme.cursor, DEFAULT_CURSOR, true);\n this.colors.cursorAccent = this._parseColor(theme.cursorAccent, DEFAULT_CURSOR_ACCENT, true);\n this.colors.selectionTransparent = this._parseColor(theme.selection, DEFAULT_SELECTION, true);\n this.colors.selectionOpaque = color.blend(this.colors.background, this.colors.selectionTransparent);\n /**\n * If selection color is opaque, blend it with background with 0.3 opacity\n * Issue #2737\n */\n if (color.isOpaque(this.colors.selectionTransparent)) {\n const opacity = 0.3;\n this.colors.selectionTransparent = color.opacity(this.colors.selectionTransparent, opacity);\n }\n this.colors.ansi[0] = this._parseColor(theme.black, DEFAULT_ANSI_COLORS[0]);\n this.colors.ansi[1] = this._parseColor(theme.red, DEFAULT_ANSI_COLORS[1]);\n this.colors.ansi[2] = this._parseColor(theme.green, DEFAULT_ANSI_COLORS[2]);\n this.colors.ansi[3] = this._parseColor(theme.yellow, DEFAULT_ANSI_COLORS[3]);\n this.colors.ansi[4] = this._parseColor(theme.blue, DEFAULT_ANSI_COLORS[4]);\n this.colors.ansi[5] = this._parseColor(theme.magenta, DEFAULT_ANSI_COLORS[5]);\n this.colors.ansi[6] = this._parseColor(theme.cyan, DEFAULT_ANSI_COLORS[6]);\n this.colors.ansi[7] = this._parseColor(theme.white, DEFAULT_ANSI_COLORS[7]);\n this.colors.ansi[8] = this._parseColor(theme.brightBlack, DEFAULT_ANSI_COLORS[8]);\n this.colors.ansi[9] = this._parseColor(theme.brightRed, DEFAULT_ANSI_COLORS[9]);\n this.colors.ansi[10] = this._parseColor(theme.brightGreen, DEFAULT_ANSI_COLORS[10]);\n this.colors.ansi[11] = this._parseColor(theme.brightYellow, DEFAULT_ANSI_COLORS[11]);\n this.colors.ansi[12] = this._parseColor(theme.brightBlue, DEFAULT_ANSI_COLORS[12]);\n this.colors.ansi[13] = this._parseColor(theme.brightMagenta, DEFAULT_ANSI_COLORS[13]);\n this.colors.ansi[14] = this._parseColor(theme.brightCyan, DEFAULT_ANSI_COLORS[14]);\n this.colors.ansi[15] = this._parseColor(theme.brightWhite, DEFAULT_ANSI_COLORS[15]);\n // Clear our the cache\n this._contrastCache.clear();\n }\n\n private _parseColor(\n css: string | undefined,\n fallback: IColor,\n allowTransparency: boolean = this.allowTransparency\n ): IColor {\n if (css === undefined) {\n return fallback;\n }\n\n // If parsing the value results in failure, then it must be ignored, and the attribute must\n // retain its previous value.\n // -- https://html.spec.whatwg.org/multipage/canvas.html#fill-and-stroke-styles\n this._ctx.fillStyle = this._litmusColor;\n this._ctx.fillStyle = css;\n if (typeof this._ctx.fillStyle !== 'string') {\n console.warn(`Color: ${css} is invalid using fallback ${fallback.css}`);\n return fallback;\n }\n\n this._ctx.fillRect(0, 0, 1, 1);\n const data = this._ctx.getImageData(0, 0, 1, 1).data;\n\n // Check if the printed color was transparent\n if (data[3] !== 0xFF) {\n if (!allowTransparency) {\n // Ideally we'd just ignore the alpha channel, but...\n //\n // Browsers may not give back exactly the same RGB values we put in, because most/all\n // convert the color to a pre-multiplied representation. getImageData converts that back to\n // a un-premultipled representation, but the precision loss may make the RGB channels unuable\n // on their own.\n //\n // E.g. In Chrome #12345610 turns into #10305010, and in the extreme case, 0xFFFFFF00 turns\n // into 0x00000000.\n //\n // \"Note: Due to the lossy nature of converting to and from premultiplied alpha color values,\n // pixels that have just been set using putImageData() might be returned to an equivalent\n // getImageData() as different values.\"\n // -- https://html.spec.whatwg.org/multipage/canvas.html#pixel-manipulation\n //\n // So let's just use the fallback color in this case instead.\n console.warn(\n `Color: ${css} is using transparency, but allowTransparency is false. ` +\n `Using fallback ${fallback.css}.`\n );\n return fallback;\n }\n\n // https://html.spec.whatwg.org/multipage/canvas.html#serialisation-of-a-color\n // the color value has alpha less than 1.0, and the string is the color value in the CSS rgba()\n const [r, g, b, a] = this._ctx.fillStyle.substring(5, this._ctx.fillStyle.length - 1).split(',').map(component => Number(component));\n const alpha = Math.round(a * 255);\n const rgba: number = channels.toRgba(r, g, b, alpha);\n return {\n rgba,\n css\n };\n }\n\n return {\n // https://html.spec.whatwg.org/multipage/canvas.html#serialisation-of-a-color\n // if it has alpha equal to 1.0, then the string is a lowercase six-digit hex value, prefixed with a \"#\" character\n css: this._ctx.fillStyle,\n rgba: channels.toRgba(data[0], data[1], data[2], data[3])\n };\n }\n}\n","/**\n * Copyright (c) 2020 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nexport function removeElementFromParent(...elements: (HTMLElement | undefined)[]): void {\n for (const e of elements) {\n e?.parentElement?.removeChild(e);\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IDisposable } from 'common/Types';\n\n/**\n * Adds a disposable listener to a node in the DOM, returning the disposable.\n * @param type The event type.\n * @param handler The handler for the listener.\n */\nexport function addDisposableDomListener(\n node: Element | Window | Document,\n type: string,\n handler: (e: any) => void,\n options?: boolean | AddEventListenerOptions\n): IDisposable {\n node.addEventListener(type, handler, options);\n let disposed = false;\n return {\n dispose: () => {\n if (disposed) {\n return;\n }\n disposed = true;\n node.removeEventListener(type, handler, options);\n }\n };\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ILinkifierEvent, ILinkMatcher, LinkMatcherHandler, ILinkMatcherOptions, ILinkifier, IMouseZoneManager, IMouseZone, IRegisteredLinkMatcher } from 'browser/Types';\nimport { IBufferStringIteratorResult } from 'common/buffer/Types';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { ILogService, IBufferService, IOptionsService, IUnicodeService } from 'common/services/Services';\n\n/**\n * Limit of the unwrapping line expansion (overscan) at the top and bottom\n * of the actual viewport in ASCII characters.\n * A limit of 2000 should match most sane urls.\n */\nconst OVERSCAN_CHAR_LIMIT = 2000;\n\n/**\n * The Linkifier applies links to rows shortly after they have been refreshed.\n */\nexport class Linkifier implements ILinkifier {\n /**\n * The time to wait after a row is changed before it is linkified. This prevents\n * the costly operation of searching every row multiple times, potentially a\n * huge amount of times.\n */\n protected static _timeBeforeLatency = 200;\n\n protected _linkMatchers: IRegisteredLinkMatcher[] = [];\n\n private _mouseZoneManager: IMouseZoneManager | undefined;\n private _element: HTMLElement | undefined;\n\n private _rowsTimeoutId: number | undefined;\n private _nextLinkMatcherId = 0;\n private _rowsToLinkify: { start: number | undefined, end: number | undefined };\n\n private _onShowLinkUnderline = new EventEmitter();\n public get onShowLinkUnderline(): IEvent { return this._onShowLinkUnderline.event; }\n private _onHideLinkUnderline = new EventEmitter();\n public get onHideLinkUnderline(): IEvent { return this._onHideLinkUnderline.event; }\n private _onLinkTooltip = new EventEmitter();\n public get onLinkTooltip(): IEvent { return this._onLinkTooltip.event; }\n\n constructor(\n @IBufferService protected readonly _bufferService: IBufferService,\n @ILogService private readonly _logService: ILogService,\n @IUnicodeService private readonly _unicodeService: IUnicodeService\n ) {\n this._rowsToLinkify = {\n start: undefined,\n end: undefined\n };\n }\n\n /**\n * Attaches the linkifier to the DOM, enabling linkification.\n * @param mouseZoneManager The mouse zone manager to register link zones with.\n */\n public attachToDom(element: HTMLElement, mouseZoneManager: IMouseZoneManager): void {\n this._element = element;\n this._mouseZoneManager = mouseZoneManager;\n }\n\n /**\n * Queue linkification on a set of rows.\n * @param start The row to linkify from (inclusive).\n * @param end The row to linkify to (inclusive).\n */\n public linkifyRows(start: number, end: number): void {\n // Don't attempt linkify if not yet attached to DOM\n if (!this._mouseZoneManager) {\n return;\n }\n\n // Increase range to linkify\n if (this._rowsToLinkify.start === undefined || this._rowsToLinkify.end === undefined) {\n this._rowsToLinkify.start = start;\n this._rowsToLinkify.end = end;\n } else {\n this._rowsToLinkify.start = Math.min(this._rowsToLinkify.start, start);\n this._rowsToLinkify.end = Math.max(this._rowsToLinkify.end, end);\n }\n\n // Clear out any existing links on this row range\n this._mouseZoneManager.clearAll(start, end);\n\n // Restart timer\n if (this._rowsTimeoutId) {\n clearTimeout(this._rowsTimeoutId);\n }\n this._rowsTimeoutId = setTimeout(() => this._linkifyRows(), Linkifier._timeBeforeLatency);\n }\n\n /**\n * Linkifies the rows requested.\n */\n private _linkifyRows(): void {\n this._rowsTimeoutId = undefined;\n const buffer = this._bufferService.buffer;\n\n if (this._rowsToLinkify.start === undefined || this._rowsToLinkify.end === undefined) {\n this._logService.debug('_rowToLinkify was unset before _linkifyRows was called');\n return;\n }\n\n // Ensure the start row exists\n const absoluteRowIndexStart = buffer.ydisp + this._rowsToLinkify.start;\n if (absoluteRowIndexStart >= buffer.lines.length) {\n return;\n }\n\n // Invalidate bad end row values (if a resize happened)\n const absoluteRowIndexEnd = buffer.ydisp + Math.min(this._rowsToLinkify.end, this._bufferService.rows) + 1;\n\n // Iterate over the range of unwrapped content strings within start..end\n // (excluding).\n // _doLinkifyRow gets full unwrapped lines with the start row as buffer offset\n // for every matcher.\n // The unwrapping is needed to also match content that got wrapped across\n // several buffer lines. To avoid a worst case scenario where the whole buffer\n // contains just a single unwrapped string we limit this line expansion beyond\n // the viewport to +OVERSCAN_CHAR_LIMIT chars (overscan) at top and bottom.\n // This comes with the tradeoff that matches longer than OVERSCAN_CHAR_LIMIT\n // chars will not match anymore at the viewport borders.\n const overscanLineLimit = Math.ceil(OVERSCAN_CHAR_LIMIT / this._bufferService.cols);\n const iterator = this._bufferService.buffer.iterator(\n false, absoluteRowIndexStart, absoluteRowIndexEnd, overscanLineLimit, overscanLineLimit);\n while (iterator.hasNext()) {\n const lineData: IBufferStringIteratorResult = iterator.next();\n for (let i = 0; i < this._linkMatchers.length; i++) {\n this._doLinkifyRow(lineData.range.first, lineData.content, this._linkMatchers[i]);\n }\n }\n\n this._rowsToLinkify.start = undefined;\n this._rowsToLinkify.end = undefined;\n }\n\n /**\n * Registers a link matcher, allowing custom link patterns to be matched and\n * handled.\n * @param regex The regular expression to search for. Specifically, this\n * searches the textContent of the rows. You will want to use \\s to match a\n * space ' ' character for example.\n * @param handler The callback when the link is called.\n * @param options Options for the link matcher.\n * @return The ID of the new matcher, this can be used to deregister.\n */\n public registerLinkMatcher(regex: RegExp, handler: LinkMatcherHandler, options: ILinkMatcherOptions = {}): number {\n if (!handler) {\n throw new Error('handler must be defined');\n }\n const matcher: IRegisteredLinkMatcher = {\n id: this._nextLinkMatcherId++,\n regex,\n handler,\n matchIndex: options.matchIndex,\n validationCallback: options.validationCallback,\n hoverTooltipCallback: options.tooltipCallback,\n hoverLeaveCallback: options.leaveCallback,\n willLinkActivate: options.willLinkActivate,\n priority: options.priority || 0\n };\n this._addLinkMatcherToList(matcher);\n return matcher.id;\n }\n\n /**\n * Inserts a link matcher to the list in the correct position based on the\n * priority of each link matcher. New link matchers of equal priority are\n * considered after older link matchers.\n * @param matcher The link matcher to be added.\n */\n private _addLinkMatcherToList(matcher: IRegisteredLinkMatcher): void {\n if (this._linkMatchers.length === 0) {\n this._linkMatchers.push(matcher);\n return;\n }\n\n for (let i = this._linkMatchers.length - 1; i >= 0; i--) {\n if (matcher.priority <= this._linkMatchers[i].priority) {\n this._linkMatchers.splice(i + 1, 0, matcher);\n return;\n }\n }\n\n this._linkMatchers.splice(0, 0, matcher);\n }\n\n /**\n * Deregisters a link matcher if it has been registered.\n * @param matcherId The link matcher's ID (returned after register)\n * @return Whether a link matcher was found and deregistered.\n */\n public deregisterLinkMatcher(matcherId: number): boolean {\n for (let i = 0; i < this._linkMatchers.length; i++) {\n if (this._linkMatchers[i].id === matcherId) {\n this._linkMatchers.splice(i, 1);\n return true;\n }\n }\n return false;\n }\n\n /**\n * Linkifies a row given a specific handler.\n * @param rowIndex The row index to linkify (absolute index).\n * @param text string content of the unwrapped row.\n * @param matcher The link matcher for this line.\n */\n private _doLinkifyRow(rowIndex: number, text: string, matcher: ILinkMatcher): void {\n // clone regex to do a global search on text\n const rex = new RegExp(matcher.regex.source, (matcher.regex.flags || '') + 'g');\n let match;\n let stringIndex = -1;\n while ((match = rex.exec(text)) !== null) {\n const uri = match[typeof matcher.matchIndex !== 'number' ? 0 : matcher.matchIndex];\n if (!uri) {\n // something matched but does not comply with the given matchIndex\n // since this is most likely a bug the regex itself we simply do nothing here\n this._logService.debug('match found without corresponding matchIndex', match, matcher);\n break;\n }\n\n // Get index, match.index is for the outer match which includes negated chars\n // therefore we cannot use match.index directly, instead we search the position\n // of the match group in text again\n // also correct regex and string search offsets for the next loop run\n stringIndex = text.indexOf(uri, stringIndex + 1);\n rex.lastIndex = stringIndex + uri.length;\n if (stringIndex < 0) {\n // invalid stringIndex (should not have happened)\n break;\n }\n\n // get the buffer index as [absolute row, col] for the match\n const bufferIndex = this._bufferService.buffer.stringIndexToBufferIndex(rowIndex, stringIndex);\n if (bufferIndex[0] < 0) {\n // invalid bufferIndex (should not have happened)\n break;\n }\n\n const line = this._bufferService.buffer.lines.get(bufferIndex[0]);\n if (!line) {\n break;\n }\n\n const attr = line.getFg(bufferIndex[1]);\n const fg = attr ? (attr >> 9) & 0x1ff : undefined;\n\n if (matcher.validationCallback) {\n matcher.validationCallback(uri, isValid => {\n // Discard link if the line has already changed\n if (this._rowsTimeoutId) {\n return;\n }\n if (isValid) {\n this._addLink(bufferIndex[1], bufferIndex[0] - this._bufferService.buffer.ydisp, uri, matcher, fg);\n }\n });\n } else {\n this._addLink(bufferIndex[1], bufferIndex[0] - this._bufferService.buffer.ydisp, uri, matcher, fg);\n }\n }\n }\n\n /**\n * Registers a link to the mouse zone manager.\n * @param x The column the link starts.\n * @param y The row the link is on.\n * @param uri The URI of the link.\n * @param matcher The link matcher for the link.\n * @param fg The link color for hover event.\n */\n private _addLink(x: number, y: number, uri: string, matcher: ILinkMatcher, fg: number | undefined): void {\n if (!this._mouseZoneManager || !this._element) {\n return;\n }\n // FIXME: get cell length from buffer to avoid mismatch after Unicode version change\n const width = this._unicodeService.getStringCellWidth(uri);\n const x1 = x % this._bufferService.cols;\n const y1 = y + Math.floor(x / this._bufferService.cols);\n let x2 = (x1 + width) % this._bufferService.cols;\n let y2 = y1 + Math.floor((x1 + width) / this._bufferService.cols);\n if (x2 === 0) {\n x2 = this._bufferService.cols;\n y2--;\n }\n\n this._mouseZoneManager.add(new MouseZone(\n x1 + 1,\n y1 + 1,\n x2 + 1,\n y2 + 1,\n e => {\n if (matcher.handler) {\n return matcher.handler(e, uri);\n }\n const newWindow = window.open();\n if (newWindow) {\n newWindow.opener = null;\n newWindow.location.href = uri;\n } else {\n console.warn('Opening link blocked as opener could not be cleared');\n }\n },\n () => {\n this._onShowLinkUnderline.fire(this._createLinkHoverEvent(x1, y1, x2, y2, fg));\n this._element!.classList.add('xterm-cursor-pointer');\n },\n e => {\n this._onLinkTooltip.fire(this._createLinkHoverEvent(x1, y1, x2, y2, fg));\n if (matcher.hoverTooltipCallback) {\n // Note that IViewportRange use 1-based coordinates to align with escape sequences such\n // as CUP which use 1,1 as the default for row/col\n matcher.hoverTooltipCallback(e, uri, { start: { x: x1, y: y1 }, end: { x: x2, y: y2 } });\n }\n },\n () => {\n this._onHideLinkUnderline.fire(this._createLinkHoverEvent(x1, y1, x2, y2, fg));\n this._element!.classList.remove('xterm-cursor-pointer');\n if (matcher.hoverLeaveCallback) {\n matcher.hoverLeaveCallback();\n }\n },\n e => {\n if (matcher.willLinkActivate) {\n return matcher.willLinkActivate(e, uri);\n }\n return true;\n }\n ));\n }\n\n private _createLinkHoverEvent(x1: number, y1: number, x2: number, y2: number, fg: number | undefined): ILinkifierEvent {\n return { x1, y1, x2, y2, cols: this._bufferService.cols, fg };\n }\n}\n\nexport class MouseZone implements IMouseZone {\n constructor(\n public x1: number,\n public y1: number,\n public x2: number,\n public y2: number,\n public clickCallback: (e: MouseEvent) => any,\n public hoverCallback: (e: MouseEvent) => any,\n public tooltipCallback: (e: MouseEvent) => any,\n public leaveCallback: () => void,\n public willLinkActivate: (e: MouseEvent) => boolean\n ) {\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ILinkifier2, ILinkProvider, IBufferCellPosition, ILink, ILinkifierEvent, ILinkDecorations } from 'browser/Types';\nimport { IDisposable } from 'common/Types';\nimport { IMouseService, IRenderService } from './services/Services';\nimport { IBufferService } from 'common/services/Services';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { Disposable, getDisposeArrayDisposable, disposeArray } from 'common/Lifecycle';\nimport { addDisposableDomListener } from 'browser/Lifecycle';\n\ninterface ILinkState {\n decorations: ILinkDecorations;\n isHovered: boolean;\n}\n\ninterface ILinkWithState {\n link: ILink;\n state?: ILinkState;\n}\n\nexport class Linkifier2 extends Disposable implements ILinkifier2 {\n private _element: HTMLElement | undefined;\n private _mouseService: IMouseService | undefined;\n private _renderService: IRenderService | undefined;\n private _linkProviders: ILinkProvider[] = [];\n protected _currentLink: ILinkWithState | undefined;\n private _lastMouseEvent: MouseEvent | undefined;\n private _linkCacheDisposables: IDisposable[] = [];\n private _lastBufferCell: IBufferCellPosition | undefined;\n private _isMouseOut: boolean = true;\n private _activeProviderReplies: Map | undefined;\n private _activeLine: number = -1;\n\n private _onShowLinkUnderline = this.register(new EventEmitter());\n public get onShowLinkUnderline(): IEvent { return this._onShowLinkUnderline.event; }\n private _onHideLinkUnderline = this.register(new EventEmitter());\n public get onHideLinkUnderline(): IEvent { return this._onHideLinkUnderline.event; }\n\n constructor(\n @IBufferService private readonly _bufferService: IBufferService\n ) {\n super();\n this.register(getDisposeArrayDisposable(this._linkCacheDisposables));\n }\n\n public registerLinkProvider(linkProvider: ILinkProvider): IDisposable {\n this._linkProviders.push(linkProvider);\n return {\n dispose: () => {\n // Remove the link provider from the list\n const providerIndex = this._linkProviders.indexOf(linkProvider);\n\n if (providerIndex !== -1) {\n this._linkProviders.splice(providerIndex, 1);\n }\n }\n };\n }\n\n public attachToDom(element: HTMLElement, mouseService: IMouseService, renderService: IRenderService): void {\n this._element = element;\n this._mouseService = mouseService;\n this._renderService = renderService;\n\n this.register(addDisposableDomListener(this._element, 'mouseleave', () => {\n this._isMouseOut = true;\n this._clearCurrentLink();\n }));\n this.register(addDisposableDomListener(this._element, 'mousemove', this._onMouseMove.bind(this)));\n this.register(addDisposableDomListener(this._element, 'click', this._onClick.bind(this)));\n }\n\n private _onMouseMove(event: MouseEvent): void {\n this._lastMouseEvent = event;\n\n if (!this._element || !this._mouseService) {\n return;\n }\n\n const position = this._positionFromMouseEvent(event, this._element, this._mouseService);\n if (!position) {\n return;\n }\n this._isMouseOut = false;\n\n // Ignore the event if it's an embedder created hover widget\n const composedPath = event.composedPath() as HTMLElement[];\n for (let i = 0; i < composedPath.length; i++) {\n const target = composedPath[i];\n // Hit Terminal.element, break and continue\n if (target.classList.contains('xterm')) {\n break;\n }\n // It's a hover, don't respect hover event\n if (target.classList.contains('xterm-hover')) {\n return;\n }\n }\n\n if (!this._lastBufferCell || (position.x !== this._lastBufferCell.x || position.y !== this._lastBufferCell.y)) {\n this._onHover(position);\n this._lastBufferCell = position;\n }\n }\n\n private _onHover(position: IBufferCellPosition): void {\n // TODO: This currently does not cache link provider results across wrapped lines, activeLine should be something like `activeRange: {startY, endY}`\n // Check if we need to clear the link\n if (this._activeLine !== position.y) {\n this._clearCurrentLink();\n this._askForLink(position, false);\n return;\n }\n\n // Check the if the link is in the mouse position\n const isCurrentLinkInPosition = this._currentLink && this._linkAtPosition(this._currentLink.link, position);\n if (!isCurrentLinkInPosition) {\n this._clearCurrentLink();\n this._askForLink(position, true);\n }\n }\n\n private _askForLink(position: IBufferCellPosition, useLineCache: boolean): void {\n if (!this._activeProviderReplies || !useLineCache) {\n this._activeProviderReplies?.forEach(reply => {\n reply?.forEach(linkWithState => {\n if (linkWithState.link.dispose) {\n linkWithState.link.dispose();\n }\n });\n });\n this._activeProviderReplies = new Map();\n this._activeLine = position.y;\n }\n let linkProvided = false;\n\n // There is no link cached, so ask for one\n this._linkProviders.forEach((linkProvider, i) => {\n if (useLineCache) {\n const existingReply = this._activeProviderReplies?.get(i);\n // If there isn't a reply, the provider hasn't responded yet.\n\n // TODO: If there isn't a reply yet it means that the provider is still resolving. Ensuring\n // provideLinks isn't triggered again saves ILink.hover firing twice though. This probably\n // needs promises to get fixed\n if (existingReply) {\n linkProvided = this._checkLinkProviderResult(i, position, linkProvided);\n }\n } else {\n linkProvider.provideLinks(position.y, (links: ILink[] | undefined) => {\n if (this._isMouseOut) {\n return;\n }\n const linksWithState: ILinkWithState[] | undefined = links?.map(link => ({ link }));\n this._activeProviderReplies?.set(i, linksWithState);\n linkProvided = this._checkLinkProviderResult(i, position, linkProvided);\n\n // If all providers have responded, remove lower priority links that intersect ranges of\n // higher priority links\n if (this._activeProviderReplies?.size === this._linkProviders.length) {\n this._removeIntersectingLinks(position.y, this._activeProviderReplies);\n }\n });\n }\n });\n }\n\n private _removeIntersectingLinks(y: number, replies: Map): void {\n const occupiedCells = new Set();\n for (let i = 0; i < replies.size; i++) {\n const providerReply = replies.get(i);\n if (!providerReply) {\n continue;\n }\n for (let i = 0; i < providerReply.length; i++) {\n const linkWithState = providerReply[i];\n const startX = linkWithState.link.range.start.y < y ? 0 : linkWithState.link.range.start.x;\n const endX = linkWithState.link.range.end.y > y ? this._bufferService.cols : linkWithState.link.range.end.x;\n for (let x = startX; x <= endX; x++) {\n if (occupiedCells.has(x)) {\n providerReply.splice(i--, 1);\n break;\n }\n occupiedCells.add(x);\n }\n }\n }\n }\n\n private _checkLinkProviderResult(index: number, position: IBufferCellPosition, linkProvided: boolean): boolean {\n if (!this._activeProviderReplies) {\n return linkProvided;\n }\n\n const links = this._activeProviderReplies.get(index);\n\n // Check if every provider before this one has come back undefined\n let hasLinkBefore = false;\n for (let j = 0; j < index; j++) {\n if (!this._activeProviderReplies.has(j) || this._activeProviderReplies.get(j)) {\n hasLinkBefore = true;\n }\n }\n\n // If all providers with higher priority came back undefined, then this provider's link for\n // the position should be used\n if (!hasLinkBefore && links) {\n const linkAtPosition = links.find(link => this._linkAtPosition(link.link, position));\n if (linkAtPosition) {\n linkProvided = true;\n this._handleNewLink(linkAtPosition);\n }\n }\n\n // Check if all the providers have responded\n if (this._activeProviderReplies.size === this._linkProviders.length && !linkProvided) {\n // Respect the order of the link providers\n for (let j = 0; j < this._activeProviderReplies.size; j++) {\n const currentLink = this._activeProviderReplies.get(j)?.find(link => this._linkAtPosition(link.link, position));\n if (currentLink) {\n linkProvided = true;\n this._handleNewLink(currentLink);\n break;\n }\n }\n }\n\n return linkProvided;\n }\n\n private _onClick(event: MouseEvent): void {\n if (!this._element || !this._mouseService || !this._currentLink) {\n return;\n }\n\n const position = this._positionFromMouseEvent(event, this._element, this._mouseService);\n\n if (!position) {\n return;\n }\n\n if (this._linkAtPosition(this._currentLink.link, position)) {\n this._currentLink.link.activate(event, this._currentLink.link.text);\n }\n }\n\n private _clearCurrentLink(startRow?: number, endRow?: number): void {\n if (!this._element || !this._currentLink || !this._lastMouseEvent) {\n return;\n }\n\n // If we have a start and end row, check that the link is within it\n if (!startRow || !endRow || (this._currentLink.link.range.start.y >= startRow && this._currentLink.link.range.end.y <= endRow)) {\n this._linkLeave(this._element, this._currentLink.link, this._lastMouseEvent);\n this._currentLink = undefined;\n disposeArray(this._linkCacheDisposables);\n }\n }\n\n private _handleNewLink(linkWithState: ILinkWithState): void {\n if (!this._element || !this._lastMouseEvent || !this._mouseService) {\n return;\n }\n\n const position = this._positionFromMouseEvent(this._lastMouseEvent, this._element, this._mouseService);\n\n if (!position) {\n return;\n }\n\n // Trigger hover if the we have a link at the position\n if (this._linkAtPosition(linkWithState.link, position)) {\n this._currentLink = linkWithState;\n this._currentLink.state = {\n decorations: {\n underline: linkWithState.link.decorations === undefined ? true : linkWithState.link.decorations.underline,\n pointerCursor: linkWithState.link.decorations === undefined ? true : linkWithState.link.decorations.pointerCursor\n },\n isHovered: true\n };\n this._linkHover(this._element, linkWithState.link, this._lastMouseEvent);\n\n // Add listener for tracking decorations changes\n linkWithState.link.decorations = {} as ILinkDecorations;\n Object.defineProperties(linkWithState.link.decorations, {\n pointerCursor: {\n get: () => this._currentLink?.state?.decorations.pointerCursor,\n set: v => {\n if (this._currentLink?.state && this._currentLink.state.decorations.pointerCursor !== v) {\n this._currentLink.state.decorations.pointerCursor = v;\n if (this._currentLink.state.isHovered) {\n this._element?.classList.toggle('xterm-cursor-pointer', v);\n }\n }\n }\n },\n underline: {\n get: () => this._currentLink?.state?.decorations.underline,\n set: v => {\n if (this._currentLink?.state && this._currentLink?.state?.decorations.underline !== v) {\n this._currentLink.state.decorations.underline = v;\n if (this._currentLink.state.isHovered) {\n this._fireUnderlineEvent(linkWithState.link, v);\n }\n }\n }\n }\n });\n\n // Add listener for rerendering\n if (this._renderService) {\n this._linkCacheDisposables.push(this._renderService.onRenderedBufferChange(e => {\n // When start is 0 a scroll most likely occurred, make sure links above the fold also get\n // cleared.\n const start = e.start === 0 ? 0 : e.start + 1 + this._bufferService.buffer.ydisp;\n this._clearCurrentLink(start, e.end + 1 + this._bufferService.buffer.ydisp);\n }));\n }\n }\n }\n\n protected _linkHover(element: HTMLElement, link: ILink, event: MouseEvent): void {\n if (this._currentLink?.state) {\n this._currentLink.state.isHovered = true;\n if (this._currentLink.state.decorations.underline) {\n this._fireUnderlineEvent(link, true);\n }\n if (this._currentLink.state.decorations.pointerCursor) {\n element.classList.add('xterm-cursor-pointer');\n }\n }\n\n if (link.hover) {\n link.hover(event, link.text);\n }\n }\n\n private _fireUnderlineEvent(link: ILink, showEvent: boolean): void {\n const range = link.range;\n const scrollOffset = this._bufferService.buffer.ydisp;\n const event = this._createLinkUnderlineEvent(range.start.x - 1, range.start.y - scrollOffset - 1, range.end.x, range.end.y - scrollOffset - 1, undefined);\n const emitter = showEvent ? this._onShowLinkUnderline : this._onHideLinkUnderline;\n emitter.fire(event);\n }\n\n protected _linkLeave(element: HTMLElement, link: ILink, event: MouseEvent): void {\n if (this._currentLink?.state) {\n this._currentLink.state.isHovered = false;\n if (this._currentLink.state.decorations.underline) {\n this._fireUnderlineEvent(link, false);\n }\n if (this._currentLink.state.decorations.pointerCursor) {\n element.classList.remove('xterm-cursor-pointer');\n }\n }\n\n if (link.leave) {\n link.leave(event, link.text);\n }\n }\n\n /**\n * Check if the buffer position is within the link\n * @param link\n * @param position\n */\n private _linkAtPosition(link: ILink, position: IBufferCellPosition): boolean {\n const sameLine = link.range.start.y === link.range.end.y;\n const wrappedFromLeft = link.range.start.y < position.y;\n const wrappedToRight = link.range.end.y > position.y;\n\n // If the start and end have the same y, then the position must be between start and end x\n // If not, then handle each case seperately, depending on which way it wraps\n return ((sameLine && link.range.start.x <= position.x && link.range.end.x >= position.x) ||\n (wrappedFromLeft && link.range.end.x >= position.x) ||\n (wrappedToRight && link.range.start.x <= position.x) ||\n (wrappedFromLeft && wrappedToRight)) &&\n link.range.start.y <= position.y &&\n link.range.end.y >= position.y;\n }\n\n /**\n * Get the buffer position from a mouse event\n * @param event\n */\n private _positionFromMouseEvent(event: MouseEvent, element: HTMLElement, mouseService: IMouseService): IBufferCellPosition | undefined {\n const coords = mouseService.getCoords(event, element, this._bufferService.cols, this._bufferService.rows);\n if (!coords) {\n return;\n }\n\n return { x: coords[0], y: coords[1] + this._bufferService.buffer.ydisp };\n }\n\n private _createLinkUnderlineEvent(x1: number, y1: number, x2: number, y2: number, fg: number | undefined): ILinkifierEvent {\n return { x1, y1, x2, y2, cols: this._bufferService.cols, fg };\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\n// eslint-disable-next-line prefer-const\nexport let promptLabel = 'Terminal input';\n\n// eslint-disable-next-line prefer-const\nexport let tooMuchOutput = 'Too much output to announce, navigate to rows manually to read';\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Disposable } from 'common/Lifecycle';\nimport { addDisposableDomListener } from 'browser/Lifecycle';\nimport { IMouseService, ISelectionService } from 'browser/services/Services';\nimport { IMouseZoneManager, IMouseZone } from 'browser/Types';\nimport { IBufferService, IOptionsService } from 'common/services/Services';\n\n/**\n * The MouseZoneManager allows components to register zones within the terminal\n * that trigger hover and click callbacks.\n *\n * This class was intentionally made not so robust initially as the only case it\n * needed to support was single-line links which never overlap. Improvements can\n * be made in the future.\n */\nexport class MouseZoneManager extends Disposable implements IMouseZoneManager {\n private _zones: IMouseZone[] = [];\n\n private _areZonesActive: boolean = false;\n private _mouseMoveListener: (e: MouseEvent) => any;\n private _mouseLeaveListener: (e: MouseEvent) => any;\n private _clickListener: (e: MouseEvent) => any;\n\n private _tooltipTimeout: number | undefined;\n private _currentZone: IMouseZone | undefined;\n private _lastHoverCoords: [number | undefined, number | undefined] = [undefined, undefined];\n private _initialSelectionLength: number = 0;\n\n constructor(\n private readonly _element: HTMLElement,\n private readonly _screenElement: HTMLElement,\n @IBufferService private readonly _bufferService: IBufferService,\n @IMouseService private readonly _mouseService: IMouseService,\n @ISelectionService private readonly _selectionService: ISelectionService,\n @IOptionsService private readonly _optionsService: IOptionsService\n ) {\n super();\n\n this.register(addDisposableDomListener(this._element, 'mousedown', e => this._onMouseDown(e)));\n\n // These events are expensive, only listen to it when mouse zones are active\n this._mouseMoveListener = e => this._onMouseMove(e);\n this._mouseLeaveListener = e => this._onMouseLeave(e);\n this._clickListener = e => this._onClick(e);\n }\n\n public dispose(): void {\n super.dispose();\n this._deactivate();\n }\n\n public add(zone: IMouseZone): void {\n this._zones.push(zone);\n if (this._zones.length === 1) {\n this._activate();\n }\n }\n\n public clearAll(start?: number, end?: number): void {\n // Exit if there's nothing to clear\n if (this._zones.length === 0) {\n return;\n }\n\n // Clear all if start/end weren't set\n if (!start || !end) {\n start = 0;\n end = this._bufferService.rows - 1;\n }\n\n // Iterate through zones and clear them out if they're within the range\n for (let i = 0; i < this._zones.length; i++) {\n const zone = this._zones[i];\n if ((zone.y1 > start && zone.y1 <= end + 1) ||\n (zone.y2 > start && zone.y2 <= end + 1) ||\n (zone.y1 < start && zone.y2 > end + 1)) {\n if (this._currentZone && this._currentZone === zone) {\n this._currentZone.leaveCallback();\n this._currentZone = undefined;\n }\n this._zones.splice(i--, 1);\n }\n }\n\n // Deactivate the mouse zone manager if all the zones have been removed\n if (this._zones.length === 0) {\n this._deactivate();\n }\n }\n\n private _activate(): void {\n if (!this._areZonesActive) {\n this._areZonesActive = true;\n this._element.addEventListener('mousemove', this._mouseMoveListener);\n this._element.addEventListener('mouseleave', this._mouseLeaveListener);\n this._element.addEventListener('click', this._clickListener);\n }\n }\n\n private _deactivate(): void {\n if (this._areZonesActive) {\n this._areZonesActive = false;\n this._element.removeEventListener('mousemove', this._mouseMoveListener);\n this._element.removeEventListener('mouseleave', this._mouseLeaveListener);\n this._element.removeEventListener('click', this._clickListener);\n }\n }\n\n private _onMouseMove(e: MouseEvent): void {\n // TODO: Ideally this would only clear the hover state when the mouse moves\n // outside of the mouse zone\n if (this._lastHoverCoords[0] !== e.pageX || this._lastHoverCoords[1] !== e.pageY) {\n this._onHover(e);\n // Record the current coordinates\n this._lastHoverCoords = [e.pageX, e.pageY];\n }\n }\n\n private _onHover(e: MouseEvent): void {\n const zone = this._findZoneEventAt(e);\n\n // Do nothing if the zone is the same\n if (zone === this._currentZone) {\n return;\n }\n\n // Fire the hover end callback and cancel any existing timer if a new zone\n // is being hovered\n if (this._currentZone) {\n this._currentZone.leaveCallback();\n this._currentZone = undefined;\n if (this._tooltipTimeout) {\n clearTimeout(this._tooltipTimeout);\n }\n }\n\n // Exit if there is not zone\n if (!zone) {\n return;\n }\n this._currentZone = zone;\n\n // Trigger the hover callback\n if (zone.hoverCallback) {\n zone.hoverCallback(e);\n }\n\n // Restart the tooltip timeout\n this._tooltipTimeout = window.setTimeout(() => this._onTooltip(e), this._optionsService.options.linkTooltipHoverDuration);\n }\n\n private _onTooltip(e: MouseEvent): void {\n this._tooltipTimeout = undefined;\n const zone = this._findZoneEventAt(e);\n if (zone && zone.tooltipCallback) {\n zone.tooltipCallback(e);\n }\n }\n\n private _onMouseDown(e: MouseEvent): void {\n // Store current terminal selection length, to check if we're performing\n // a selection operation\n this._initialSelectionLength = this._getSelectionLength();\n\n // Ignore the event if there are no zones active\n if (!this._areZonesActive) {\n return;\n }\n\n // Find the active zone, prevent event propagation if found to prevent other\n // components from handling the mouse event.\n const zone = this._findZoneEventAt(e);\n if (zone?.willLinkActivate(e)) {\n e.preventDefault();\n e.stopImmediatePropagation();\n }\n }\n\n private _onMouseLeave(e: MouseEvent): void {\n // Fire the hover end callback and cancel any existing timer if the mouse\n // leaves the terminal element\n if (this._currentZone) {\n this._currentZone.leaveCallback();\n this._currentZone = undefined;\n if (this._tooltipTimeout) {\n clearTimeout(this._tooltipTimeout);\n }\n }\n }\n\n private _onClick(e: MouseEvent): void {\n // Find the active zone and click it if found and no selection was\n // being performed\n const zone = this._findZoneEventAt(e);\n const currentSelectionLength = this._getSelectionLength();\n\n if (zone && currentSelectionLength === this._initialSelectionLength) {\n zone.clickCallback(e);\n e.preventDefault();\n e.stopImmediatePropagation();\n }\n }\n\n private _getSelectionLength(): number {\n const selectionText = this._selectionService.selectionText;\n return selectionText ? selectionText.length : 0;\n }\n\n private _findZoneEventAt(e: MouseEvent): IMouseZone | undefined {\n const coords = this._mouseService.getCoords(e, this._screenElement, this._bufferService.cols, this._bufferService.rows);\n if (!coords) {\n return undefined;\n }\n const x = coords[0];\n const y = coords[1];\n for (let i = 0; i < this._zones.length; i++) {\n const zone = this._zones[i];\n if (zone.y1 === zone.y2) {\n // Single line link\n if (y === zone.y1 && x >= zone.x1 && x < zone.x2) {\n return zone;\n }\n } else {\n // Multi-line link\n if ((y === zone.y1 && x >= zone.x1) ||\n (y === zone.y2 && x < zone.x2) ||\n (y > zone.y1 && y < zone.y2)) {\n return zone;\n }\n }\n }\n return undefined;\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IDisposable } from 'common/Types';\n\n/**\n * Debounces calls to render terminal rows using animation frames.\n */\nexport class RenderDebouncer implements IDisposable {\n private _rowStart: number | undefined;\n private _rowEnd: number | undefined;\n private _rowCount: number | undefined;\n private _animationFrame: number | undefined;\n\n constructor(\n private _renderCallback: (start: number, end: number) => void\n ) {\n }\n\n public dispose(): void {\n if (this._animationFrame) {\n window.cancelAnimationFrame(this._animationFrame);\n this._animationFrame = undefined;\n }\n }\n\n public refresh(rowStart: number | undefined, rowEnd: number | undefined, rowCount: number): void {\n this._rowCount = rowCount;\n // Get the min/max row start/end for the arg values\n rowStart = rowStart !== undefined ? rowStart : 0;\n rowEnd = rowEnd !== undefined ? rowEnd : this._rowCount - 1;\n // Set the properties to the updated values\n this._rowStart = this._rowStart !== undefined ? Math.min(this._rowStart, rowStart) : rowStart;\n this._rowEnd = this._rowEnd !== undefined ? Math.max(this._rowEnd, rowEnd) : rowEnd;\n\n if (this._animationFrame) {\n return;\n }\n\n this._animationFrame = window.requestAnimationFrame(() => this._innerRefresh());\n }\n\n private _innerRefresh(): void {\n // Make sure values are set\n if (this._rowStart === undefined || this._rowEnd === undefined || this._rowCount === undefined) {\n return;\n }\n\n // Clamp values\n const start = Math.max(this._rowStart, 0);\n const end = Math.min(this._rowEnd, this._rowCount - 1);\n\n // Reset debouncer (this happens before render callback as the render could trigger it again)\n this._rowStart = undefined;\n this._rowEnd = undefined;\n this._animationFrame = undefined;\n\n // Run render callback\n this._renderCallback(start, end);\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Disposable } from 'common/Lifecycle';\n\nexport type ScreenDprListener = (newDevicePixelRatio?: number, oldDevicePixelRatio?: number) => void;\n\n/**\n * The screen device pixel ratio monitor allows listening for when the\n * window.devicePixelRatio value changes. This is done not with polling but with\n * the use of window.matchMedia to watch media queries. When the event fires,\n * the listener will be reattached using a different media query to ensure that\n * any further changes will register.\n *\n * The listener should fire on both window zoom changes and switching to a\n * monitor with a different DPI.\n */\nexport class ScreenDprMonitor extends Disposable {\n private _currentDevicePixelRatio: number = window.devicePixelRatio;\n private _outerListener: ((this: MediaQueryList, ev: MediaQueryListEvent) => any) | undefined;\n private _listener: ScreenDprListener | undefined;\n private _resolutionMediaMatchList: MediaQueryList | undefined;\n\n public setListener(listener: ScreenDprListener): void {\n if (this._listener) {\n this.clearListener();\n }\n this._listener = listener;\n this._outerListener = () => {\n if (!this._listener) {\n return;\n }\n this._listener(window.devicePixelRatio, this._currentDevicePixelRatio);\n this._updateDpr();\n };\n this._updateDpr();\n }\n\n public dispose(): void {\n super.dispose();\n this.clearListener();\n }\n\n private _updateDpr(): void {\n if (!this._outerListener) {\n return;\n }\n\n // Clear listeners for old DPR\n this._resolutionMediaMatchList?.removeListener(this._outerListener);\n\n // Add listeners for new DPR\n this._currentDevicePixelRatio = window.devicePixelRatio;\n this._resolutionMediaMatchList = window.matchMedia(`screen and (resolution: ${window.devicePixelRatio}dppx)`);\n this._resolutionMediaMatchList.addListener(this._outerListener);\n }\n\n public clearListener(): void {\n if (!this._resolutionMediaMatchList || !this._listener || !this._outerListener) {\n return;\n }\n this._resolutionMediaMatchList.removeListener(this._outerListener);\n this._resolutionMediaMatchList = undefined;\n this._listener = undefined;\n this._outerListener = undefined;\n }\n}\n","/**\n * Copyright (c) 2014 The xterm.js authors. All rights reserved.\n * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)\n * @license MIT\n *\n * Originally forked from (with the author's permission):\n * Fabrice Bellard's javascript vt100 for jslinux:\n * http://bellard.org/jslinux/\n * Copyright (c) 2011 Fabrice Bellard\n * The original design remains. The terminal itself\n * has been extended to include xterm CSI codes, among\n * other features.\n *\n * Terminal Emulation References:\n * http://vt100.net/\n * http://invisible-island.net/xterm/ctlseqs/ctlseqs.txt\n * http://invisible-island.net/xterm/ctlseqs/ctlseqs.html\n * http://invisible-island.net/vttest/\n * http://www.inwap.com/pdp10/ansicode.txt\n * http://linux.die.net/man/4/console_codes\n * http://linux.die.net/man/7/urxvt\n */\n\nimport { ICompositionHelper, ITerminal, IBrowser, CustomKeyEventHandler, ILinkifier, IMouseZoneManager, LinkMatcherHandler, ILinkMatcherOptions, IViewport, ILinkifier2 } from 'browser/Types';\nimport { IRenderer, CharacterJoinerHandler } from 'browser/renderer/Types';\nimport { CompositionHelper } from 'browser/input/CompositionHelper';\nimport { Viewport } from 'browser/Viewport';\nimport { rightClickHandler, moveTextAreaUnderMouseCursor, handlePasteEvent, copyHandler, paste } from 'browser/Clipboard';\nimport { C0 } from 'common/data/EscapeSequences';\nimport { WindowsOptionsReportType } from '../common/InputHandler';\nimport { Renderer } from 'browser/renderer/Renderer';\nimport { Linkifier } from 'browser/Linkifier';\nimport { SelectionService } from 'browser/services/SelectionService';\nimport * as Browser from 'common/Platform';\nimport { addDisposableDomListener } from 'browser/Lifecycle';\nimport * as Strings from 'browser/LocalizableStrings';\nimport { SoundService } from 'browser/services/SoundService';\nimport { MouseZoneManager } from 'browser/MouseZoneManager';\nimport { AccessibilityManager } from './AccessibilityManager';\nimport { ITheme, IMarker, IDisposable, ISelectionPosition, ILinkProvider } from 'xterm';\nimport { DomRenderer } from 'browser/renderer/dom/DomRenderer';\nimport { IKeyboardEvent, KeyboardResultType, CoreMouseEventType, CoreMouseButton, CoreMouseAction, ITerminalOptions, IAnsiColorChangeEvent } from 'common/Types';\nimport { evaluateKeyboardEvent } from 'common/input/Keyboard';\nimport { EventEmitter, IEvent, forwardEvent } from 'common/EventEmitter';\nimport { DEFAULT_ATTR_DATA } from 'common/buffer/BufferLine';\nimport { ColorManager } from 'browser/ColorManager';\nimport { RenderService } from 'browser/services/RenderService';\nimport { ICharSizeService, IRenderService, IMouseService, ISelectionService, ISoundService, ICoreBrowserService } from 'browser/services/Services';\nimport { CharSizeService } from 'browser/services/CharSizeService';\nimport { IBuffer } from 'common/buffer/Types';\nimport { MouseService } from 'browser/services/MouseService';\nimport { Linkifier2 } from 'browser/Linkifier2';\nimport { CoreBrowserService } from 'browser/services/CoreBrowserService';\nimport { CoreTerminal } from 'common/CoreTerminal';\nimport { ITerminalOptions as IInitializedTerminalOptions } from 'common/services/Services';\nimport { rgba } from 'browser/Color';\n\n// Let it work inside Node.js for automated testing purposes.\nconst document: Document = (typeof window !== 'undefined') ? window.document : null as any;\n\nexport class Terminal extends CoreTerminal implements ITerminal {\n public textarea: HTMLTextAreaElement | undefined;\n public element: HTMLElement | undefined;\n public screenElement: HTMLElement | undefined;\n\n private _document: Document | undefined;\n private _viewportScrollArea: HTMLElement | undefined;\n private _viewportElement: HTMLElement | undefined;\n private _helperContainer: HTMLElement | undefined;\n private _compositionView: HTMLElement | undefined;\n\n // private _visualBellTimer: number;\n\n public browser: IBrowser = Browser;\n\n // TODO: We should remove options once components adopt optionsService\n public get options(): IInitializedTerminalOptions { return this.optionsService.options; }\n\n private _customKeyEventHandler: CustomKeyEventHandler | undefined;\n\n // browser services\n private _charSizeService: ICharSizeService | undefined;\n private _mouseService: IMouseService | undefined;\n private _renderService: IRenderService | undefined;\n private _selectionService: ISelectionService | undefined;\n private _soundService: ISoundService | undefined;\n\n /**\n * Records whether the keydown event has already been handled and triggered a data event, if so\n * the keypress event should not trigger a data event but should still print to the textarea so\n * screen readers will announce it.\n */\n private _keyDownHandled: boolean = false;\n\n public linkifier: ILinkifier;\n public linkifier2: ILinkifier2;\n public viewport: IViewport | undefined;\n private _compositionHelper: ICompositionHelper | undefined;\n private _mouseZoneManager: IMouseZoneManager | undefined;\n private _accessibilityManager: AccessibilityManager | undefined;\n private _colorManager: ColorManager | undefined;\n private _theme: ITheme | undefined;\n\n private _onCursorMove = new EventEmitter();\n public get onCursorMove(): IEvent { return this._onCursorMove.event; }\n private _onKey = new EventEmitter<{ key: string, domEvent: KeyboardEvent }>();\n public get onKey(): IEvent<{ key: string, domEvent: KeyboardEvent }> { return this._onKey.event; }\n private _onRender = new EventEmitter<{ start: number, end: number }>();\n public get onRender(): IEvent<{ start: number, end: number }> { return this._onRender.event; }\n private _onSelectionChange = new EventEmitter();\n public get onSelectionChange(): IEvent { return this._onSelectionChange.event; }\n private _onTitleChange = new EventEmitter();\n public get onTitleChange(): IEvent { return this._onTitleChange.event; }\n\n private _onFocus = new EventEmitter();\n public get onFocus(): IEvent { return this._onFocus.event; }\n private _onBlur = new EventEmitter();\n public get onBlur(): IEvent { return this._onBlur.event; }\n private _onA11yCharEmitter = new EventEmitter();\n public get onA11yChar(): IEvent { return this._onA11yCharEmitter.event; }\n private _onA11yTabEmitter = new EventEmitter();\n public get onA11yTab(): IEvent { return this._onA11yTabEmitter.event; }\n\n /**\n * Creates a new `Terminal` object.\n *\n * @param options An object containing a set of options, the available options are:\n * - `cursorBlink` (boolean): Whether the terminal cursor blinks\n * - `cols` (number): The number of columns of the terminal (horizontal size)\n * - `rows` (number): The number of rows of the terminal (vertical size)\n *\n * @public\n * @class Xterm Xterm\n * @alias module:xterm/src/xterm\n */\n constructor(\n options: ITerminalOptions = {}\n ) {\n super(options);\n\n this._setup();\n\n this.linkifier = this._instantiationService.createInstance(Linkifier);\n this.linkifier2 = this.register(this._instantiationService.createInstance(Linkifier2));\n\n // Setup InputHandler listeners\n this.register(this._inputHandler.onRequestBell(() => this.bell()));\n this.register(this._inputHandler.onRequestRefreshRows((start, end) => this.refresh(start, end)));\n this.register(this._inputHandler.onRequestReset(() => this.reset()));\n this.register(this._inputHandler.onRequestScroll((eraseAttr, isWrapped) => this.scroll(eraseAttr, isWrapped || undefined)));\n this.register(this._inputHandler.onRequestWindowsOptionsReport(type => this._reportWindowsOptions(type)));\n this.register(this._inputHandler.onAnsiColorChange((event) => this._changeAnsiColor(event)));\n this.register(forwardEvent(this._inputHandler.onCursorMove, this._onCursorMove));\n this.register(forwardEvent(this._inputHandler.onTitleChange, this._onTitleChange));\n this.register(forwardEvent(this._inputHandler.onA11yChar, this._onA11yCharEmitter));\n this.register(forwardEvent(this._inputHandler.onA11yTab, this._onA11yTabEmitter));\n\n // Setup listeners\n this.register(this._bufferService.onResize(e => this._afterResize(e.cols, e.rows)));\n }\n\n private _changeAnsiColor(event: IAnsiColorChangeEvent): void {\n if (!this._colorManager) { return; }\n\n event.colors.forEach(ansiColor => {\n const color = rgba.toColor(ansiColor.red, ansiColor.green, ansiColor.blue);\n\n this._colorManager!.colors.ansi[ansiColor.colorIndex] = color;\n });\n\n this._renderService?.setColors(this._colorManager!.colors);\n this.viewport?.onThemeChange(this._colorManager!.colors);\n }\n\n public dispose(): void {\n if (this._isDisposed) {\n return;\n }\n super.dispose();\n this._renderService?.dispose();\n this._customKeyEventHandler = undefined;\n this.write = () => { };\n this.element?.parentNode?.removeChild(this.element);\n }\n\n protected _setup(): void {\n super._setup();\n\n this._customKeyEventHandler = undefined;\n }\n\n /**\n * Convenience property to active buffer.\n */\n public get buffer(): IBuffer {\n return this.buffers.active;\n }\n\n /**\n * Focus the terminal. Delegates focus handling to the terminal's DOM element.\n */\n public focus(): void {\n if (this.textarea) {\n this.textarea.focus({ preventScroll: true });\n }\n }\n\n protected _updateOptions(key: string): void {\n super._updateOptions(key);\n\n // TODO: These listeners should be owned by individual components\n switch (key) {\n case 'fontFamily':\n case 'fontSize':\n // When the font changes the size of the cells may change which requires a renderer clear\n this._renderService?.clear();\n this._charSizeService?.measure();\n break;\n case 'cursorBlink':\n case 'cursorStyle':\n // The DOM renderer needs a row refresh to update the cursor styles\n this.refresh(this.buffer.y, this.buffer.y);\n break;\n case 'drawBoldTextInBrightColors':\n case 'letterSpacing':\n case 'lineHeight':\n case 'fontWeight':\n case 'fontWeightBold':\n case 'minimumContrastRatio':\n // When the font changes the size of the cells may change which requires a renderer clear\n if (this._renderService) {\n this._renderService.clear();\n this._renderService.onResize(this.cols, this.rows);\n this.refresh(0, this.rows - 1);\n }\n break;\n case 'rendererType':\n if (this._renderService) {\n this._renderService.setRenderer(this._createRenderer());\n this._renderService.onResize(this.cols, this.rows);\n }\n break;\n case 'scrollback':\n this.viewport?.syncScrollArea();\n break;\n case 'screenReaderMode':\n if (this.optionsService.options.screenReaderMode) {\n if (!this._accessibilityManager && this._renderService) {\n this._accessibilityManager = new AccessibilityManager(this, this._renderService);\n }\n } else {\n this._accessibilityManager?.dispose();\n this._accessibilityManager = undefined;\n }\n break;\n case 'tabStopWidth': this.buffers.setupTabStops(); break;\n case 'theme':\n this._setTheme(this.optionsService.options.theme);\n break;\n }\n }\n\n /**\n * Binds the desired focus behavior on a given terminal object.\n */\n private _onTextAreaFocus(ev: KeyboardEvent): void {\n if (this._coreService.decPrivateModes.sendFocus) {\n this._coreService.triggerDataEvent(C0.ESC + '[I');\n }\n this.updateCursorStyle(ev);\n this.element!.classList.add('focus');\n this._showCursor();\n this._onFocus.fire();\n }\n\n /**\n * Blur the terminal, calling the blur function on the terminal's underlying\n * textarea.\n */\n public blur(): void {\n return this.textarea?.blur();\n }\n\n /**\n * Binds the desired blur behavior on a given terminal object.\n */\n private _onTextAreaBlur(): void {\n // Text can safely be removed on blur. Doing it earlier could interfere with\n // screen readers reading it out.\n this.textarea!.value = '';\n this.refresh(this.buffer.y, this.buffer.y);\n if (this._coreService.decPrivateModes.sendFocus) {\n this._coreService.triggerDataEvent(C0.ESC + '[O');\n }\n this.element!.classList.remove('focus');\n this._onBlur.fire();\n }\n\n private _syncTextArea(): void {\n if (!this.textarea || !this.buffer.isCursorInViewport || this._compositionHelper!.isComposing) {\n return;\n }\n\n const cellHeight = Math.ceil(this._charSizeService!.height * this.optionsService.options.lineHeight);\n const cursorTop = this._bufferService.buffer.y * cellHeight;\n const cursorLeft = this._bufferService.buffer.x * this._charSizeService!.width;\n\n // Sync the textarea to the exact position of the composition view so the IME knows where the\n // text is.\n this.textarea.style.left = cursorLeft + 'px';\n this.textarea.style.top = cursorTop + 'px';\n this.textarea.style.width = this._charSizeService!.width + 'px';\n this.textarea.style.height = cellHeight + 'px';\n this.textarea.style.lineHeight = cellHeight + 'px';\n this.textarea.style.zIndex = '-5';\n }\n\n /**\n * Initialize default behavior\n */\n private _initGlobal(): void {\n this._bindKeys();\n\n // Bind clipboard functionality\n this.register(addDisposableDomListener(this.element!, 'copy', (event: ClipboardEvent) => {\n // If mouse events are active it means the selection manager is disabled and\n // copy should be handled by the host program.\n if (!this.hasSelection()) {\n return;\n }\n copyHandler(event, this._selectionService!);\n }));\n const pasteHandlerWrapper = (event: ClipboardEvent): void => handlePasteEvent(event, this.textarea!, this._coreService);\n this.register(addDisposableDomListener(this.textarea!, 'paste', pasteHandlerWrapper));\n this.register(addDisposableDomListener(this.element!, 'paste', pasteHandlerWrapper));\n\n // Handle right click context menus\n if (Browser.isFirefox) {\n // Firefox doesn't appear to fire the contextmenu event on right click\n this.register(addDisposableDomListener(this.element!, 'mousedown', (event: MouseEvent) => {\n if (event.button === 2) {\n rightClickHandler(event, this.textarea!, this.screenElement!, this._selectionService!, this.options.rightClickSelectsWord);\n }\n }));\n } else {\n this.register(addDisposableDomListener(this.element!, 'contextmenu', (event: MouseEvent) => {\n rightClickHandler(event, this.textarea!, this.screenElement!, this._selectionService!, this.options.rightClickSelectsWord);\n }));\n }\n\n // Move the textarea under the cursor when middle clicking on Linux to ensure\n // middle click to paste selection works. This only appears to work in Chrome\n // at the time is writing.\n if (Browser.isLinux) {\n // Use auxclick event over mousedown the latter doesn't seem to work. Note\n // that the regular click event doesn't fire for the middle mouse button.\n this.register(addDisposableDomListener(this.element!, 'auxclick', (event: MouseEvent) => {\n if (event.button === 1) {\n moveTextAreaUnderMouseCursor(event, this.textarea!, this.screenElement!);\n }\n }));\n }\n }\n\n /**\n * Apply key handling to the terminal\n */\n private _bindKeys(): void {\n this.register(addDisposableDomListener(this.textarea!, 'keyup', (ev: KeyboardEvent) => this._keyUp(ev), true));\n this.register(addDisposableDomListener(this.textarea!, 'keydown', (ev: KeyboardEvent) => this._keyDown(ev), true));\n this.register(addDisposableDomListener(this.textarea!, 'keypress', (ev: KeyboardEvent) => this._keyPress(ev), true));\n this.register(addDisposableDomListener(this.textarea!, 'compositionstart', () => this._compositionHelper!.compositionstart()));\n this.register(addDisposableDomListener(this.textarea!, 'compositionupdate', (e: CompositionEvent) => this._compositionHelper!.compositionupdate(e)));\n this.register(addDisposableDomListener(this.textarea!, 'compositionend', () => this._compositionHelper!.compositionend()));\n this.register(this.onRender(() => this._compositionHelper!.updateCompositionElements()));\n this.register(this.onRender(e => this._queueLinkification(e.start, e.end)));\n }\n\n /**\n * Opens the terminal within an element.\n *\n * @param parent The element to create the terminal within.\n */\n public open(parent: HTMLElement): void {\n if (!parent) {\n throw new Error('Terminal requires a parent element.');\n }\n\n if (!parent.isConnected) {\n this._logService.debug('Terminal.open was called on an element that was not attached to the DOM');\n }\n\n this._document = parent.ownerDocument!;\n\n // Create main element container\n this.element = this._document.createElement('div');\n this.element.dir = 'ltr'; // xterm.css assumes LTR\n this.element.classList.add('terminal');\n this.element.classList.add('xterm');\n this.element.setAttribute('tabindex', '0');\n this.element.setAttribute('role', 'document');\n parent.appendChild(this.element);\n\n // Performance: Use a document fragment to build the terminal\n // viewport and helper elements detached from the DOM\n const fragment = document.createDocumentFragment();\n this._viewportElement = document.createElement('div');\n this._viewportElement.classList.add('xterm-viewport');\n fragment.appendChild(this._viewportElement);\n this._viewportScrollArea = document.createElement('div');\n this._viewportScrollArea.classList.add('xterm-scroll-area');\n this._viewportElement.appendChild(this._viewportScrollArea);\n\n this.screenElement = document.createElement('div');\n this.screenElement.classList.add('xterm-screen');\n // Create the container that will hold helpers like the textarea for\n // capturing DOM Events. Then produce the helpers.\n this._helperContainer = document.createElement('div');\n this._helperContainer.classList.add('xterm-helpers');\n this.screenElement.appendChild(this._helperContainer);\n fragment.appendChild(this.screenElement);\n\n this.textarea = document.createElement('textarea');\n this.textarea.classList.add('xterm-helper-textarea');\n this.textarea.setAttribute('aria-label', Strings.promptLabel);\n this.textarea.setAttribute('aria-multiline', 'false');\n this.textarea.setAttribute('autocorrect', 'off');\n this.textarea.setAttribute('autocapitalize', 'off');\n this.textarea.setAttribute('spellcheck', 'false');\n this.textarea.tabIndex = 0;\n this.register(addDisposableDomListener(this.textarea, 'focus', (ev: KeyboardEvent) => this._onTextAreaFocus(ev)));\n this.register(addDisposableDomListener(this.textarea, 'blur', () => this._onTextAreaBlur()));\n this._helperContainer.appendChild(this.textarea);\n\n const coreBrowserService = this._instantiationService.createInstance(CoreBrowserService, this.textarea);\n this._instantiationService.setService(ICoreBrowserService, coreBrowserService);\n\n this._charSizeService = this._instantiationService.createInstance(CharSizeService, this._document, this._helperContainer);\n this._instantiationService.setService(ICharSizeService, this._charSizeService);\n\n this._compositionView = document.createElement('div');\n this._compositionView.classList.add('composition-view');\n this._compositionHelper = this._instantiationService.createInstance(CompositionHelper, this.textarea, this._compositionView);\n this._helperContainer.appendChild(this._compositionView);\n\n // Performance: Add viewport and helper elements from the fragment\n this.element.appendChild(fragment);\n\n this._theme = this.options.theme || this._theme;\n this._colorManager = new ColorManager(document, this.options.allowTransparency);\n this.register(this.optionsService.onOptionChange(e => this._colorManager!.onOptionsChange(e)));\n this._colorManager.setTheme(this._theme);\n\n const renderer = this._createRenderer();\n this._renderService = this.register(this._instantiationService.createInstance(RenderService, renderer, this.rows, this.screenElement));\n this._instantiationService.setService(IRenderService, this._renderService);\n this.register(this._renderService.onRenderedBufferChange(e => this._onRender.fire(e)));\n this.onResize(e => this._renderService!.resize(e.cols, e.rows));\n\n this._soundService = this._instantiationService.createInstance(SoundService);\n this._instantiationService.setService(ISoundService, this._soundService);\n this._mouseService = this._instantiationService.createInstance(MouseService);\n this._instantiationService.setService(IMouseService, this._mouseService);\n\n this.viewport = this._instantiationService.createInstance(Viewport,\n (amount: number, suppressEvent: boolean) => this.scrollLines(amount, suppressEvent),\n this._viewportElement,\n this._viewportScrollArea\n );\n this.viewport.onThemeChange(this._colorManager.colors);\n this.register(this._inputHandler.onRequestSyncScrollBar(() => this.viewport!.syncScrollArea()));\n this.register(this.viewport);\n\n this.register(this.onCursorMove(() => {\n this._renderService!.onCursorMove();\n this._syncTextArea();\n }));\n this.register(this.onResize(() => this._renderService!.onResize(this.cols, this.rows)));\n this.register(this.onBlur(() => this._renderService!.onBlur()));\n this.register(this.onFocus(() => this._renderService!.onFocus()));\n this.register(this._renderService.onDimensionsChange(() => this.viewport!.syncScrollArea()));\n\n this._selectionService = this.register(this._instantiationService.createInstance(SelectionService,\n this.element,\n this.screenElement));\n this._instantiationService.setService(ISelectionService, this._selectionService);\n this.register(this._selectionService.onRequestScrollLines(e => this.scrollLines(e.amount, e.suppressScrollEvent)));\n this.register(this._selectionService.onSelectionChange(() => this._onSelectionChange.fire()));\n this.register(this._selectionService.onRequestRedraw(e => this._renderService!.onSelectionChanged(e.start, e.end, e.columnSelectMode)));\n this.register(this._selectionService.onLinuxMouseSelection(text => {\n // If there's a new selection, put it into the textarea, focus and select it\n // in order to register it as a selection on the OS. This event is fired\n // only on Linux to enable middle click to paste selection.\n this.textarea!.value = text;\n this.textarea!.focus();\n this.textarea!.select();\n }));\n this.register(this.onScroll(() => {\n this.viewport!.syncScrollArea();\n this._selectionService!.refresh();\n }));\n this.register(addDisposableDomListener(this._viewportElement, 'scroll', () => this._selectionService!.refresh()));\n\n this._mouseZoneManager = this._instantiationService.createInstance(MouseZoneManager, this.element, this.screenElement);\n this.register(this._mouseZoneManager);\n this.register(this.onScroll(() => this._mouseZoneManager!.clearAll()));\n this.linkifier.attachToDom(this.element, this._mouseZoneManager);\n this.linkifier2.attachToDom(this.element, this._mouseService, this._renderService);\n\n // This event listener must be registered aftre MouseZoneManager is created\n this.register(addDisposableDomListener(this.element, 'mousedown', (e: MouseEvent) => this._selectionService!.onMouseDown(e)));\n\n // apply mouse event classes set by escape codes before terminal was attached\n if (this._coreMouseService.areMouseEventsActive) {\n this._selectionService.disable();\n this.element.classList.add('enable-mouse-events');\n } else {\n this._selectionService.enable();\n }\n\n if (this.options.screenReaderMode) {\n // Note that this must be done *after* the renderer is created in order to\n // ensure the correct order of the dprchange event\n this._accessibilityManager = new AccessibilityManager(this, this._renderService);\n }\n\n // Measure the character size\n this._charSizeService.measure();\n\n // Setup loop that draws to screen\n this.refresh(0, this.rows - 1);\n\n // Initialize global actions that need to be taken on the document.\n this._initGlobal();\n\n // Listen for mouse events and translate\n // them into terminal mouse protocols.\n this.bindMouse();\n }\n\n private _createRenderer(): IRenderer {\n switch (this.options.rendererType) {\n case 'canvas': return this._instantiationService.createInstance(Renderer, this._colorManager!.colors, this.screenElement!, this.linkifier, this.linkifier2);\n case 'dom': return this._instantiationService.createInstance(DomRenderer, this._colorManager!.colors, this.element!, this.screenElement!, this._viewportElement!, this.linkifier, this.linkifier2);\n default: throw new Error(`Unrecognized rendererType \"${this.options.rendererType}\"`);\n }\n }\n\n /**\n * Sets the theme on the renderer. The renderer must have been initialized.\n * @param theme The theme to set.\n */\n private _setTheme(theme: ITheme): void {\n this._theme = theme;\n this._colorManager?.setTheme(theme);\n this._renderService?.setColors(this._colorManager!.colors);\n this.viewport?.onThemeChange(this._colorManager!.colors);\n }\n\n /**\n * Bind certain mouse events to the terminal.\n * By default only 3 button + wheel up/down is ativated. For higher buttons\n * no mouse report will be created. Typically the standard actions will be active.\n *\n * There are several reasons not to enable support for higher buttons/wheel:\n * - Button 4 and 5 are typically used for history back and forward navigation,\n * there is no straight forward way to supress/intercept those standard actions.\n * - Support for higher buttons does not work in some platform/browser combinations.\n * - Left/right wheel was not tested.\n * - Emulators vary in mouse button support, typically only 3 buttons and\n * wheel up/down work reliable.\n *\n * TODO: Move mouse event code into its own file.\n */\n public bindMouse(): void {\n const self = this;\n const el = this.element!;\n\n // send event to CoreMouseService\n function sendEvent(ev: MouseEvent | WheelEvent): boolean {\n // get mouse coordinates\n const pos = self._mouseService!.getRawByteCoords(ev, self.screenElement!, self.cols, self.rows);\n if (!pos) {\n return false;\n }\n\n let but: CoreMouseButton;\n let action: CoreMouseAction | undefined;\n switch ((ev).overrideType || ev.type) {\n case 'mousemove':\n action = CoreMouseAction.MOVE;\n if (ev.buttons === undefined) {\n // buttons is not supported on macOS, try to get a value from button instead\n but = CoreMouseButton.NONE;\n if (ev.button !== undefined) {\n but = ev.button < 3 ? ev.button : CoreMouseButton.NONE;\n }\n } else {\n // according to MDN buttons only reports up to button 5 (AUX2)\n but = ev.buttons & 1 ? CoreMouseButton.LEFT :\n ev.buttons & 4 ? CoreMouseButton.MIDDLE :\n ev.buttons & 2 ? CoreMouseButton.RIGHT :\n CoreMouseButton.NONE; // fallback to NONE\n }\n break;\n case 'mouseup':\n action = CoreMouseAction.UP;\n but = ev.button < 3 ? ev.button : CoreMouseButton.NONE;\n break;\n case 'mousedown':\n action = CoreMouseAction.DOWN;\n but = ev.button < 3 ? ev.button : CoreMouseButton.NONE;\n break;\n case 'wheel':\n // only UP/DOWN wheel events are respected\n if ((ev as WheelEvent).deltaY !== 0) {\n action = (ev as WheelEvent).deltaY < 0 ? CoreMouseAction.UP : CoreMouseAction.DOWN;\n }\n but = CoreMouseButton.WHEEL;\n break;\n default:\n // dont handle other event types by accident\n return false;\n }\n\n // exit if we cannot determine valid button/action values\n // do nothing for higher buttons than wheel\n if (action === undefined || but === undefined || but > CoreMouseButton.WHEEL) {\n return false;\n }\n\n return self._coreMouseService.triggerMouseEvent({\n col: pos.x - 33, // FIXME: why -33 here?\n row: pos.y - 33,\n button: but,\n action,\n ctrl: ev.ctrlKey,\n alt: ev.altKey,\n shift: ev.shiftKey\n });\n }\n\n /**\n * Event listener state handling.\n * We listen to the onProtocolChange event of CoreMouseService and put\n * requested listeners in `requestedEvents`. With this the listeners\n * have all bits to do the event listener juggling.\n * Note: 'mousedown' currently is \"always on\" and not managed\n * by onProtocolChange.\n */\n const requestedEvents: { [key: string]: ((ev: Event) => void) | null } = {\n mouseup: null,\n wheel: null,\n mousedrag: null,\n mousemove: null\n };\n const eventListeners: { [key: string]: (ev: any) => void | boolean } = {\n mouseup: (ev: MouseEvent) => {\n sendEvent(ev);\n if (!ev.buttons) {\n // if no other button is held remove global handlers\n this._document!.removeEventListener('mouseup', requestedEvents.mouseup!);\n if (requestedEvents.mousedrag) {\n this._document!.removeEventListener('mousemove', requestedEvents.mousedrag);\n }\n }\n return this.cancel(ev);\n },\n wheel: (ev: WheelEvent) => {\n sendEvent(ev);\n ev.preventDefault();\n return this.cancel(ev);\n },\n mousedrag: (ev: MouseEvent) => {\n // deal only with move while a button is held\n if (ev.buttons) {\n sendEvent(ev);\n }\n },\n mousemove: (ev: MouseEvent) => {\n // deal only with move without any button\n if (!ev.buttons) {\n sendEvent(ev);\n }\n }\n };\n this.register(this._coreMouseService.onProtocolChange(events => {\n // apply global changes on events\n if (events) {\n if (this.optionsService.options.logLevel === 'debug') {\n this._logService.debug('Binding to mouse events:', this._coreMouseService.explainEvents(events));\n }\n this.element!.classList.add('enable-mouse-events');\n this._selectionService!.disable();\n } else {\n this._logService.debug('Unbinding from mouse events.');\n this.element!.classList.remove('enable-mouse-events');\n this._selectionService!.enable();\n }\n\n // add/remove handlers from requestedEvents\n\n if (!(events & CoreMouseEventType.MOVE)) {\n el.removeEventListener('mousemove', requestedEvents.mousemove!);\n requestedEvents.mousemove = null;\n } else if (!requestedEvents.mousemove) {\n el.addEventListener('mousemove', eventListeners.mousemove);\n requestedEvents.mousemove = eventListeners.mousemove;\n }\n\n if (!(events & CoreMouseEventType.WHEEL)) {\n el.removeEventListener('wheel', requestedEvents.wheel!);\n requestedEvents.wheel = null;\n } else if (!requestedEvents.wheel) {\n el.addEventListener('wheel', eventListeners.wheel, { passive: false });\n requestedEvents.wheel = eventListeners.wheel;\n }\n\n if (!(events & CoreMouseEventType.UP)) {\n this._document!.removeEventListener('mouseup', requestedEvents.mouseup!);\n requestedEvents.mouseup = null;\n } else if (!requestedEvents.mouseup) {\n requestedEvents.mouseup = eventListeners.mouseup;\n }\n\n if (!(events & CoreMouseEventType.DRAG)) {\n this._document!.removeEventListener('mousemove', requestedEvents.mousedrag!);\n requestedEvents.mousedrag = null;\n } else if (!requestedEvents.mousedrag) {\n requestedEvents.mousedrag = eventListeners.mousedrag;\n }\n }));\n // force initial onProtocolChange so we dont miss early mouse requests\n this._coreMouseService.activeProtocol = this._coreMouseService.activeProtocol;\n\n /**\n * \"Always on\" event listeners.\n */\n this.register(addDisposableDomListener(el, 'mousedown', (ev: MouseEvent) => {\n ev.preventDefault();\n this.focus();\n\n // Don't send the mouse button to the pty if mouse events are disabled or\n // if the selection manager is having selection forced (ie. a modifier is\n // held).\n if (!this._coreMouseService.areMouseEventsActive || this._selectionService!.shouldForceSelection(ev)) {\n return;\n }\n\n sendEvent(ev);\n\n // Register additional global handlers which should keep reporting outside\n // of the terminal element.\n // Note: Other emulators also do this for 'mousedown' while a button\n // is held, we currently limit 'mousedown' to the terminal only.\n if (requestedEvents.mouseup) {\n this._document!.addEventListener('mouseup', requestedEvents.mouseup);\n }\n if (requestedEvents.mousedrag) {\n this._document!.addEventListener('mousemove', requestedEvents.mousedrag);\n }\n\n return this.cancel(ev);\n }));\n\n this.register(addDisposableDomListener(el, 'wheel', (ev: WheelEvent) => {\n if (!requestedEvents.wheel) {\n // Convert wheel events into up/down events when the buffer does not have scrollback, this\n // enables scrolling in apps hosted in the alt buffer such as vim or tmux.\n if (!this.buffer.hasScrollback) {\n const amount = this.viewport!.getLinesScrolled(ev);\n\n // Do nothing if there's no vertical scroll\n if (amount === 0) {\n return;\n }\n\n // Construct and send sequences\n const sequence = C0.ESC + (this._coreService.decPrivateModes.applicationCursorKeys ? 'O' : '[') + (ev.deltaY < 0 ? 'A' : 'B');\n let data = '';\n for (let i = 0; i < Math.abs(amount); i++) {\n data += sequence;\n }\n this._coreService.triggerDataEvent(data, true);\n }\n return;\n }\n }, { passive: true }));\n\n // allow wheel scrolling in\n // the shell for example\n this.register(addDisposableDomListener(el, 'wheel', (ev: WheelEvent) => {\n if (requestedEvents.wheel) return;\n if (!this.viewport!.onWheel(ev)) {\n return this.cancel(ev);\n }\n }, { passive: false }));\n\n this.register(addDisposableDomListener(el, 'touchstart', (ev: TouchEvent) => {\n if (this._coreMouseService.areMouseEventsActive) return;\n this.viewport!.onTouchStart(ev);\n return this.cancel(ev);\n }, { passive: true }));\n\n this.register(addDisposableDomListener(el, 'touchmove', (ev: TouchEvent) => {\n if (this._coreMouseService.areMouseEventsActive) return;\n if (!this.viewport!.onTouchMove(ev)) {\n return this.cancel(ev);\n }\n }, { passive: false }));\n }\n\n\n /**\n * Tells the renderer to refresh terminal content between two rows (inclusive) at the next\n * opportunity.\n * @param start The row to start from (between 0 and this.rows - 1).\n * @param end The row to end at (between start and this.rows - 1).\n */\n public refresh(start: number, end: number): void {\n this._renderService?.refreshRows(start, end);\n }\n\n /**\n * Queues linkification for the specified rows.\n * @param start The row to start from (between 0 and this.rows - 1).\n * @param end The row to end at (between start and this.rows - 1).\n */\n private _queueLinkification(start: number, end: number): void {\n this.linkifier?.linkifyRows(start, end);\n }\n\n /**\n * Change the cursor style for different selection modes\n */\n public updateCursorStyle(ev: KeyboardEvent): void {\n if (this._selectionService && this._selectionService.shouldColumnSelect(ev)) {\n this.element!.classList.add('column-select');\n } else {\n this.element!.classList.remove('column-select');\n }\n }\n\n /**\n * Display the cursor element\n */\n private _showCursor(): void {\n if (!this._coreService.isCursorInitialized) {\n this._coreService.isCursorInitialized = true;\n this.refresh(this.buffer.y, this.buffer.y);\n }\n }\n\n public scrollLines(disp: number, suppressScrollEvent?: boolean): void {\n super.scrollLines(disp, suppressScrollEvent);\n this.refresh(0, this.rows - 1);\n }\n\n public paste(data: string): void {\n paste(data, this.textarea!, this._coreService);\n }\n\n /**\n * Attaches a custom key event handler which is run before keys are processed,\n * giving consumers of xterm.js ultimate control as to what keys should be\n * processed by the terminal and what keys should not.\n * @param customKeyEventHandler The custom KeyboardEvent handler to attach.\n * This is a function that takes a KeyboardEvent, allowing consumers to stop\n * propagation and/or prevent the default action. The function returns whether\n * the event should be processed by xterm.js.\n */\n public attachCustomKeyEventHandler(customKeyEventHandler: CustomKeyEventHandler): void {\n this._customKeyEventHandler = customKeyEventHandler;\n }\n\n /**\n * Registers a link matcher, allowing custom link patterns to be matched and\n * handled.\n * @param regex The regular expression to search for, specifically\n * this searches the textContent of the rows. You will want to use \\s to match\n * a space ' ' character for example.\n * @param handler The callback when the link is called.\n * @param options Options for the link matcher.\n * @return The ID of the new matcher, this can be used to deregister.\n */\n public registerLinkMatcher(regex: RegExp, handler: LinkMatcherHandler, options?: ILinkMatcherOptions): number {\n const matcherId = this.linkifier.registerLinkMatcher(regex, handler, options);\n this.refresh(0, this.rows - 1);\n return matcherId;\n }\n\n /**\n * Deregisters a link matcher if it has been registered.\n * @param matcherId The link matcher's ID (returned after register)\n */\n public deregisterLinkMatcher(matcherId: number): void {\n if (this.linkifier.deregisterLinkMatcher(matcherId)) {\n this.refresh(0, this.rows - 1);\n }\n }\n\n public registerLinkProvider(linkProvider: ILinkProvider): IDisposable {\n return this.linkifier2.registerLinkProvider(linkProvider);\n }\n\n public registerCharacterJoiner(handler: CharacterJoinerHandler): number {\n const joinerId = this._renderService!.registerCharacterJoiner(handler);\n this.refresh(0, this.rows - 1);\n return joinerId;\n }\n\n public deregisterCharacterJoiner(joinerId: number): void {\n if (this._renderService!.deregisterCharacterJoiner(joinerId)) {\n this.refresh(0, this.rows - 1);\n }\n }\n\n public get markers(): IMarker[] {\n return this.buffer.markers;\n }\n\n public addMarker(cursorYOffset: number): IMarker | undefined {\n // Disallow markers on the alt buffer\n if (this.buffer !== this.buffers.normal) {\n return;\n }\n\n return this.buffer.addMarker(this.buffer.ybase + this.buffer.y + cursorYOffset);\n }\n\n /**\n * Gets whether the terminal has an active selection.\n */\n public hasSelection(): boolean {\n return this._selectionService ? this._selectionService.hasSelection : false;\n }\n\n /**\n * Selects text within the terminal.\n * @param column The column the selection starts at..\n * @param row The row the selection starts at.\n * @param length The length of the selection.\n */\n public select(column: number, row: number, length: number): void {\n this._selectionService!.setSelection(column, row, length);\n }\n\n /**\n * Gets the terminal's current selection, this is useful for implementing copy\n * behavior outside of xterm.js.\n */\n public getSelection(): string {\n return this._selectionService ? this._selectionService.selectionText : '';\n }\n\n public getSelectionPosition(): ISelectionPosition | undefined {\n if (!this._selectionService || !this._selectionService.hasSelection) {\n return undefined;\n }\n\n return {\n startColumn: this._selectionService.selectionStart![0],\n startRow: this._selectionService.selectionStart![1],\n endColumn: this._selectionService.selectionEnd![0],\n endRow: this._selectionService.selectionEnd![1]\n };\n }\n\n /**\n * Clears the current terminal selection.\n */\n public clearSelection(): void {\n this._selectionService?.clearSelection();\n }\n\n /**\n * Selects all text within the terminal.\n */\n public selectAll(): void {\n this._selectionService?.selectAll();\n }\n\n public selectLines(start: number, end: number): void {\n this._selectionService?.selectLines(start, end);\n }\n\n /**\n * Handle a keydown event\n * Key Resources:\n * - https://developer.mozilla.org/en-US/docs/DOM/KeyboardEvent\n * @param ev The keydown event to be handled.\n */\n protected _keyDown(event: KeyboardEvent): boolean | undefined {\n this._keyDownHandled = false;\n\n if (this._customKeyEventHandler && this._customKeyEventHandler(event) === false) {\n return false;\n }\n\n if (!this._compositionHelper!.keydown(event)) {\n if (this.buffer.ybase !== this.buffer.ydisp) {\n this.scrollToBottom();\n }\n return false;\n }\n\n const result = evaluateKeyboardEvent(event, this._coreService.decPrivateModes.applicationCursorKeys, this.browser.isMac, this.options.macOptionIsMeta);\n\n this.updateCursorStyle(event);\n\n if (result.type === KeyboardResultType.PAGE_DOWN || result.type === KeyboardResultType.PAGE_UP) {\n const scrollCount = this.rows - 1;\n this.scrollLines(result.type === KeyboardResultType.PAGE_UP ? -scrollCount : scrollCount);\n return this.cancel(event, true);\n }\n\n if (result.type === KeyboardResultType.SELECT_ALL) {\n this.selectAll();\n }\n\n if (this._isThirdLevelShift(this.browser, event)) {\n return true;\n }\n\n if (result.cancel) {\n // The event is canceled at the end already, is this necessary?\n this.cancel(event, true);\n }\n\n if (!result.key) {\n return true;\n }\n\n // If ctrl+c or enter is being sent, clear out the textarea. This is done so that screen readers\n // will announce deleted characters. This will not work 100% of the time but it should cover\n // most scenarios.\n if (result.key === C0.ETX || result.key === C0.CR) {\n this.textarea!.value = '';\n }\n\n this._onKey.fire({ key: result.key, domEvent: event });\n this._showCursor();\n this._coreService.triggerDataEvent(result.key, true);\n\n // Cancel events when not in screen reader mode so events don't get bubbled up and handled by\n // other listeners. When screen reader mode is enabled, this could cause issues if the event\n // is handled at a higher level, this is a compromise in order to echo keys to the screen\n // reader.\n if (!this.optionsService.options.screenReaderMode) {\n return this.cancel(event, true);\n }\n\n this._keyDownHandled = true;\n }\n\n private _isThirdLevelShift(browser: IBrowser, ev: IKeyboardEvent): boolean {\n const thirdLevelKey =\n (browser.isMac && !this.options.macOptionIsMeta && ev.altKey && !ev.ctrlKey && !ev.metaKey) ||\n (browser.isWindows && ev.altKey && ev.ctrlKey && !ev.metaKey);\n\n if (ev.type === 'keypress') {\n return thirdLevelKey;\n }\n\n // Don't invoke for arrows, pageDown, home, backspace, etc. (on non-keypress events)\n return thirdLevelKey && (!ev.keyCode || ev.keyCode > 47);\n }\n\n protected _keyUp(ev: KeyboardEvent): void {\n if (this._customKeyEventHandler && this._customKeyEventHandler(ev) === false) {\n return;\n }\n\n if (!wasModifierKeyOnlyEvent(ev)) {\n this.focus();\n }\n\n this.updateCursorStyle(ev);\n }\n\n /**\n * Handle a keypress event.\n * Key Resources:\n * - https://developer.mozilla.org/en-US/docs/DOM/KeyboardEvent\n * @param ev The keypress event to be handled.\n */\n protected _keyPress(ev: KeyboardEvent): boolean {\n let key;\n\n if (this._keyDownHandled) {\n return false;\n }\n\n if (this._customKeyEventHandler && this._customKeyEventHandler(ev) === false) {\n return false;\n }\n\n this.cancel(ev);\n\n if (ev.charCode) {\n key = ev.charCode;\n } else if (ev.which === null || ev.which === undefined) {\n key = ev.keyCode;\n } else if (ev.which !== 0 && ev.charCode !== 0) {\n key = ev.which;\n } else {\n return false;\n }\n\n if (!key || (\n (ev.altKey || ev.ctrlKey || ev.metaKey) && !this._isThirdLevelShift(this.browser, ev)\n )) {\n return false;\n }\n\n key = String.fromCharCode(key);\n\n this._onKey.fire({ key, domEvent: ev });\n this._showCursor();\n this._coreService.triggerDataEvent(key, true);\n\n return true;\n }\n\n /**\n * Ring the bell.\n * Note: We could do sweet things with webaudio here\n */\n public bell(): void {\n if (this._soundBell()) {\n this._soundService!.playBellSound();\n }\n\n // if (this._visualBell()) {\n // this.element.classList.add('visual-bell-active');\n // clearTimeout(this._visualBellTimer);\n // this._visualBellTimer = window.setTimeout(() => {\n // this.element.classList.remove('visual-bell-active');\n // }, 200);\n // }\n }\n\n /**\n * Resizes the terminal.\n *\n * @param x The number of columns to resize to.\n * @param y The number of rows to resize to.\n */\n public resize(x: number, y: number): void {\n if (x === this.cols && y === this.rows) {\n // Check if we still need to measure the char size (fixes #785).\n if (this._charSizeService && !this._charSizeService.hasValidSize) {\n this._charSizeService.measure();\n }\n return;\n }\n\n super.resize(x, y);\n }\n\n private _afterResize(x: number, y: number): void {\n this._charSizeService?.measure();\n\n // Sync the scroll area to make sure scroll events don't fire and scroll the viewport to an\n // invalid location\n this.viewport?.syncScrollArea(true);\n }\n\n /**\n * Clear the entire buffer, making the prompt line the new first line.\n */\n public clear(): void {\n if (this.buffer.ybase === 0 && this.buffer.y === 0) {\n // Don't clear if it's already clear\n return;\n }\n this.buffer.lines.set(0, this.buffer.lines.get(this.buffer.ybase + this.buffer.y)!);\n this.buffer.lines.length = 1;\n this.buffer.ydisp = 0;\n this.buffer.ybase = 0;\n this.buffer.y = 0;\n for (let i = 1; i < this.rows; i++) {\n this.buffer.lines.push(this.buffer.getBlankLine(DEFAULT_ATTR_DATA));\n }\n this.refresh(0, this.rows - 1);\n this._onScroll.fire(this.buffer.ydisp);\n }\n\n /**\n * Reset terminal.\n * Note: Calling this directly from JS is synchronous but does not clear\n * input buffers and does not reset the parser, thus the terminal will\n * continue to apply pending input data.\n * If you need in band reset (synchronous with input data) consider\n * using DECSTR (soft reset, CSI ! p) or RIS instead (hard reset, ESC c).\n */\n public reset(): void {\n /**\n * Since _setup handles a full terminal creation, we have to carry forward\n * a few things that should not reset.\n */\n this.options.rows = this.rows;\n this.options.cols = this.cols;\n const customKeyEventHandler = this._customKeyEventHandler;\n\n this._setup();\n super.reset();\n this._selectionService?.reset();\n\n // reattach\n this._customKeyEventHandler = customKeyEventHandler;\n\n // do a full screen refresh\n this.refresh(0, this.rows - 1);\n this.viewport?.syncScrollArea();\n }\n\n private _reportWindowsOptions(type: WindowsOptionsReportType): void {\n if (!this._renderService) {\n return;\n }\n\n switch (type) {\n case WindowsOptionsReportType.GET_WIN_SIZE_PIXELS:\n const canvasWidth = this._renderService.dimensions.scaledCanvasWidth.toFixed(0);\n const canvasHeight = this._renderService.dimensions.scaledCanvasHeight.toFixed(0);\n this._coreService.triggerDataEvent(`${C0.ESC}[4;${canvasHeight};${canvasWidth}t`);\n break;\n case WindowsOptionsReportType.GET_CELL_SIZE_PIXELS:\n const cellWidth = this._renderService.dimensions.scaledCellWidth.toFixed(0);\n const cellHeight = this._renderService.dimensions.scaledCellHeight.toFixed(0);\n this._coreService.triggerDataEvent(`${C0.ESC}[6;${cellHeight};${cellWidth}t`);\n break;\n }\n }\n\n // TODO: Remove cancel function and cancelEvents option\n public cancel(ev: Event, force?: boolean): boolean | undefined {\n if (!this.options.cancelEvents && !force) {\n return;\n }\n ev.preventDefault();\n ev.stopPropagation();\n return false;\n }\n\n private _visualBell(): boolean {\n return false;\n // return this.options.bellStyle === 'visual' ||\n // this.options.bellStyle === 'both';\n }\n\n private _soundBell(): boolean {\n return this.options.bellStyle === 'sound';\n // return this.options.bellStyle === 'sound' ||\n // this.options.bellStyle === 'both';\n }\n}\n\n/**\n * Helpers\n */\n\nfunction wasModifierKeyOnlyEvent(ev: KeyboardEvent): boolean {\n return ev.keyCode === 16 || // Shift\n ev.keyCode === 17 || // Ctrl\n ev.keyCode === 18; // Alt\n}\n","/**\n * Copyright (c) 2016 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Disposable } from 'common/Lifecycle';\nimport { addDisposableDomListener } from 'browser/Lifecycle';\nimport { IColorSet, IViewport } from 'browser/Types';\nimport { ICharSizeService, IRenderService } from 'browser/services/Services';\nimport { IBufferService, IOptionsService } from 'common/services/Services';\n\nconst FALLBACK_SCROLL_BAR_WIDTH = 15;\n\n/**\n * Represents the viewport of a terminal, the visible area within the larger buffer of output.\n * Logic for the virtual scroll bar is included in this object.\n */\nexport class Viewport extends Disposable implements IViewport {\n public scrollBarWidth: number = 0;\n private _currentRowHeight: number = 0;\n private _lastRecordedBufferLength: number = 0;\n private _lastRecordedViewportHeight: number = 0;\n private _lastRecordedBufferHeight: number = 0;\n private _lastTouchY: number = 0;\n private _lastScrollTop: number = 0;\n\n // Stores a partial line amount when scrolling, this is used to keep track of how much of a line\n // is scrolled so we can \"scroll\" over partial lines and feel natural on touchpads. This is a\n // quick fix and could have a more robust solution in place that reset the value when needed.\n private _wheelPartialScroll: number = 0;\n\n private _refreshAnimationFrame: number | null = null;\n private _ignoreNextScrollEvent: boolean = false;\n\n constructor(\n private readonly _scrollLines: (amount: number, suppressEvent: boolean) => void,\n private readonly _viewportElement: HTMLElement,\n private readonly _scrollArea: HTMLElement,\n @IBufferService private readonly _bufferService: IBufferService,\n @IOptionsService private readonly _optionsService: IOptionsService,\n @ICharSizeService private readonly _charSizeService: ICharSizeService,\n @IRenderService private readonly _renderService: IRenderService\n ) {\n super();\n\n // Measure the width of the scrollbar. If it is 0 we can assume it's an OSX overlay scrollbar.\n // Unfortunately the overlay scrollbar would be hidden underneath the screen element in that case,\n // therefore we account for a standard amount to make it visible\n this.scrollBarWidth = (this._viewportElement.offsetWidth - this._scrollArea.offsetWidth) || FALLBACK_SCROLL_BAR_WIDTH;\n this.register(addDisposableDomListener(this._viewportElement, 'scroll', this._onScroll.bind(this)));\n\n // Perform this async to ensure the ICharSizeService is ready.\n setTimeout(() => this.syncScrollArea(), 0);\n }\n\n public onThemeChange(colors: IColorSet): void {\n this._viewportElement.style.backgroundColor = colors.background.css;\n }\n\n /**\n * Refreshes row height, setting line-height, viewport height and scroll area height if\n * necessary.\n */\n private _refresh(immediate: boolean): void {\n if (immediate) {\n this._innerRefresh();\n if (this._refreshAnimationFrame !== null) {\n cancelAnimationFrame(this._refreshAnimationFrame);\n }\n return;\n }\n if (this._refreshAnimationFrame === null) {\n this._refreshAnimationFrame = requestAnimationFrame(() => this._innerRefresh());\n }\n }\n\n private _innerRefresh(): void {\n if (this._charSizeService.height > 0) {\n this._currentRowHeight = this._renderService.dimensions.scaledCellHeight / window.devicePixelRatio;\n this._lastRecordedViewportHeight = this._viewportElement.offsetHeight;\n const newBufferHeight = Math.round(this._currentRowHeight * this._lastRecordedBufferLength) + (this._lastRecordedViewportHeight - this._renderService.dimensions.canvasHeight);\n if (this._lastRecordedBufferHeight !== newBufferHeight) {\n this._lastRecordedBufferHeight = newBufferHeight;\n this._scrollArea.style.height = this._lastRecordedBufferHeight + 'px';\n }\n }\n\n // Sync scrollTop\n const scrollTop = this._bufferService.buffer.ydisp * this._currentRowHeight;\n if (this._viewportElement.scrollTop !== scrollTop) {\n // Ignore the next scroll event which will be triggered by setting the scrollTop as we do not\n // want this event to scroll the terminal\n this._ignoreNextScrollEvent = true;\n this._viewportElement.scrollTop = scrollTop;\n }\n\n this._refreshAnimationFrame = null;\n }\n /**\n * Updates dimensions and synchronizes the scroll area if necessary.\n */\n public syncScrollArea(immediate: boolean = false): void {\n // If buffer height changed\n if (this._lastRecordedBufferLength !== this._bufferService.buffer.lines.length) {\n this._lastRecordedBufferLength = this._bufferService.buffer.lines.length;\n this._refresh(immediate);\n return;\n }\n\n // If viewport height changed\n if (this._lastRecordedViewportHeight !== this._renderService.dimensions.canvasHeight) {\n this._refresh(immediate);\n return;\n }\n\n // If the buffer position doesn't match last scroll top\n const newScrollTop = this._bufferService.buffer.ydisp * this._currentRowHeight;\n if (this._lastScrollTop !== newScrollTop) {\n this._refresh(immediate);\n return;\n }\n\n // If element's scroll top changed, this can happen when hiding the element\n if (this._lastScrollTop !== this._viewportElement.scrollTop) {\n this._refresh(immediate);\n return;\n }\n\n // If row height changed\n if (this._renderService.dimensions.scaledCellHeight / window.devicePixelRatio !== this._currentRowHeight) {\n this._refresh(immediate);\n return;\n }\n }\n\n /**\n * Handles scroll events on the viewport, calculating the new viewport and requesting the\n * terminal to scroll to it.\n * @param ev The scroll event.\n */\n private _onScroll(ev: Event): void {\n // Record current scroll top position\n this._lastScrollTop = this._viewportElement.scrollTop;\n\n // Don't attempt to scroll if the element is not visible, otherwise scrollTop will be corrupt\n // which causes the terminal to scroll the buffer to the top\n if (!this._viewportElement.offsetParent) {\n return;\n }\n\n // Ignore the event if it was flagged to ignore (when the source of the event is from Viewport)\n if (this._ignoreNextScrollEvent) {\n this._ignoreNextScrollEvent = false;\n return;\n }\n\n const newRow = Math.round(this._lastScrollTop / this._currentRowHeight);\n const diff = newRow - this._bufferService.buffer.ydisp;\n this._scrollLines(diff, true);\n }\n\n /**\n * Handles bubbling of scroll event in case the viewport has reached top or bottom\n * @param ev The scroll event.\n * @param amount The amount scrolled\n */\n private _bubbleScroll(ev: Event, amount: number): boolean {\n const scrollPosFromTop = this._viewportElement.scrollTop + this._lastRecordedViewportHeight;\n if ((amount < 0 && this._viewportElement.scrollTop !== 0) ||\n (amount > 0 && scrollPosFromTop < this._lastRecordedBufferHeight)) {\n if (ev.cancelable) {\n ev.preventDefault();\n }\n return false;\n }\n return true;\n }\n\n /**\n * Handles mouse wheel events by adjusting the viewport's scrollTop and delegating the actual\n * scrolling to `onScroll`, this event needs to be attached manually by the consumer of\n * `Viewport`.\n * @param ev The mouse wheel event.\n */\n public onWheel(ev: WheelEvent): boolean {\n const amount = this._getPixelsScrolled(ev);\n if (amount === 0) {\n return false;\n }\n this._viewportElement.scrollTop += amount;\n return this._bubbleScroll(ev, amount);\n }\n\n private _getPixelsScrolled(ev: WheelEvent): number {\n // Do nothing if it's not a vertical scroll event\n if (ev.deltaY === 0) {\n return 0;\n }\n\n // Fallback to WheelEvent.DOM_DELTA_PIXEL\n let amount = this._applyScrollModifier(ev.deltaY, ev);\n if (ev.deltaMode === WheelEvent.DOM_DELTA_LINE) {\n amount *= this._currentRowHeight;\n } else if (ev.deltaMode === WheelEvent.DOM_DELTA_PAGE) {\n amount *= this._currentRowHeight * this._bufferService.rows;\n }\n return amount;\n }\n\n /**\n * Gets the number of pixels scrolled by the mouse event taking into account what type of delta\n * is being used.\n * @param ev The mouse wheel event.\n */\n public getLinesScrolled(ev: WheelEvent): number {\n // Do nothing if it's not a vertical scroll event\n if (ev.deltaY === 0) {\n return 0;\n }\n\n // Fallback to WheelEvent.DOM_DELTA_LINE\n let amount = this._applyScrollModifier(ev.deltaY, ev);\n if (ev.deltaMode === WheelEvent.DOM_DELTA_PIXEL) {\n amount /= this._currentRowHeight + 0.0; // Prevent integer division\n this._wheelPartialScroll += amount;\n amount = Math.floor(Math.abs(this._wheelPartialScroll)) * (this._wheelPartialScroll > 0 ? 1 : -1);\n this._wheelPartialScroll %= 1;\n } else if (ev.deltaMode === WheelEvent.DOM_DELTA_PAGE) {\n amount *= this._bufferService.rows;\n }\n return amount;\n }\n\n private _applyScrollModifier(amount: number, ev: WheelEvent): number {\n const modifier = this._optionsService.options.fastScrollModifier;\n // Multiply the scroll speed when the modifier is down\n if ((modifier === 'alt' && ev.altKey) ||\n (modifier === 'ctrl' && ev.ctrlKey) ||\n (modifier === 'shift' && ev.shiftKey)) {\n return amount * this._optionsService.options.fastScrollSensitivity * this._optionsService.options.scrollSensitivity;\n }\n\n return amount * this._optionsService.options.scrollSensitivity;\n }\n\n /**\n * Handles the touchstart event, recording the touch occurred.\n * @param ev The touch event.\n */\n public onTouchStart(ev: TouchEvent): void {\n this._lastTouchY = ev.touches[0].pageY;\n }\n\n /**\n * Handles the touchmove event, scrolling the viewport if the position shifted.\n * @param ev The touch event.\n */\n public onTouchMove(ev: TouchEvent): boolean {\n const deltaY = this._lastTouchY - ev.touches[0].pageY;\n this._lastTouchY = ev.touches[0].pageY;\n if (deltaY === 0) {\n return false;\n }\n this._viewportElement.scrollTop += deltaY;\n return this._bubbleScroll(ev, deltaY);\n }\n}\n","/**\n * Copyright (c) 2016 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ICharSizeService } from 'browser/services/Services';\nimport { IBufferService, ICoreService, IOptionsService } from 'common/services/Services';\n\ninterface IPosition {\n start: number;\n end: number;\n}\n\n/**\n * Encapsulates the logic for handling compositionstart, compositionupdate and compositionend\n * events, displaying the in-progress composition to the UI and forwarding the final composition\n * to the handler.\n */\nexport class CompositionHelper {\n /**\n * Whether input composition is currently happening, eg. via a mobile keyboard, speech input or\n * IME. This variable determines whether the compositionText should be displayed on the UI.\n */\n private _isComposing: boolean;\n public get isComposing(): boolean { return this._isComposing; }\n\n /**\n * The position within the input textarea's value of the current composition.\n */\n private _compositionPosition: IPosition;\n\n /**\n * Whether a composition is in the process of being sent, setting this to false will cancel any\n * in-progress composition.\n */\n private _isSendingComposition: boolean;\n\n /**\n * Data already sent due to keydown event.\n */\n private _dataAlreadySent: string;\n\n constructor(\n private readonly _textarea: HTMLTextAreaElement,\n private readonly _compositionView: HTMLElement,\n @IBufferService private readonly _bufferService: IBufferService,\n @IOptionsService private readonly _optionsService: IOptionsService,\n @ICharSizeService private readonly _charSizeService: ICharSizeService,\n @ICoreService private readonly _coreService: ICoreService\n ) {\n this._isComposing = false;\n this._isSendingComposition = false;\n this._compositionPosition = { start: 0, end: 0 };\n this._dataAlreadySent = '';\n }\n\n /**\n * Handles the compositionstart event, activating the composition view.\n */\n public compositionstart(): void {\n this._isComposing = true;\n this._compositionPosition.start = this._textarea.value.length;\n this._compositionView.textContent = '';\n this._dataAlreadySent = '';\n this._compositionView.classList.add('active');\n }\n\n /**\n * Handles the compositionupdate event, updating the composition view.\n * @param ev The event.\n */\n public compositionupdate(ev: CompositionEvent): void {\n this._compositionView.textContent = ev.data;\n this.updateCompositionElements();\n setTimeout(() => {\n this._compositionPosition.end = this._textarea.value.length;\n }, 0);\n }\n\n /**\n * Handles the compositionend event, hiding the composition view and sending the composition to\n * the handler.\n */\n public compositionend(): void {\n this._finalizeComposition(true);\n }\n\n /**\n * Handles the keydown event, routing any necessary events to the CompositionHelper functions.\n * @param ev The keydown event.\n * @return Whether the Terminal should continue processing the keydown event.\n */\n public keydown(ev: KeyboardEvent): boolean {\n if (this._isComposing || this._isSendingComposition) {\n if (ev.keyCode === 229) {\n // Continue composing if the keyCode is the \"composition character\"\n return false;\n }\n if (ev.keyCode === 16 || ev.keyCode === 17 || ev.keyCode === 18) {\n // Continue composing if the keyCode is a modifier key\n return false;\n }\n // Finish composition immediately. This is mainly here for the case where enter is\n // pressed and the handler needs to be triggered before the command is executed.\n this._finalizeComposition(false);\n }\n\n if (ev.keyCode === 229) {\n // If the \"composition character\" is used but gets to this point it means a non-composition\n // character (eg. numbers and punctuation) was pressed when the IME was active.\n this._handleAnyTextareaChanges();\n return false;\n }\n\n return true;\n }\n\n /**\n * Finalizes the composition, resuming regular input actions. This is called when a composition\n * is ending.\n * @param waitForPropagation Whether to wait for events to propagate before sending\n * the input. This should be false if a non-composition keystroke is entered before the\n * compositionend event is triggered, such as enter, so that the composition is sent before\n * the command is executed.\n */\n private _finalizeComposition(waitForPropagation: boolean): void {\n this._compositionView.classList.remove('active');\n this._isComposing = false;\n\n if (!waitForPropagation) {\n // Cancel any delayed composition send requests and send the input immediately.\n this._isSendingComposition = false;\n const input = this._textarea.value.substring(this._compositionPosition.start, this._compositionPosition.end);\n this._coreService.triggerDataEvent(input, true);\n } else {\n // Make a deep copy of the composition position here as a new compositionstart event may\n // fire before the setTimeout executes.\n const currentCompositionPosition = {\n start: this._compositionPosition.start,\n end: this._compositionPosition.end\n };\n\n // Since composition* events happen before the changes take place in the textarea on most\n // browsers, use a setTimeout with 0ms time to allow the native compositionend event to\n // complete. This ensures the correct character is retrieved.\n // This solution was used because:\n // - The compositionend event's data property is unreliable, at least on Chromium\n // - The last compositionupdate event's data property does not always accurately describe\n // the character, a counter example being Korean where an ending consonsant can move to\n // the following character if the following input is a vowel.\n this._isSendingComposition = true;\n setTimeout(() => {\n // Ensure that the input has not already been sent\n if (this._isSendingComposition) {\n this._isSendingComposition = false;\n let input;\n // Add length of data already sent due to keydown event,\n // otherwise input characters can be duplicated. (Issue #3191)\n currentCompositionPosition.start += this._dataAlreadySent.length;\n if (this._isComposing) {\n // Use the end position to get the string if a new composition has started.\n input = this._textarea.value.substring(currentCompositionPosition.start, currentCompositionPosition.end);\n } else {\n // Don't use the end position here in order to pick up any characters after the\n // composition has finished, for example when typing a non-composition character\n // (eg. 2) after a composition character.\n input = this._textarea.value.substring(currentCompositionPosition.start);\n }\n if (input.length > 0) {\n this._coreService.triggerDataEvent(input, true);\n }\n }\n }, 0);\n }\n }\n\n /**\n * Apply any changes made to the textarea after the current event chain is allowed to complete.\n * This should be called when not currently composing but a keydown event with the \"composition\n * character\" (229) is triggered, in order to allow non-composition text to be entered when an\n * IME is active.\n */\n private _handleAnyTextareaChanges(): void {\n const oldValue = this._textarea.value;\n setTimeout(() => {\n // Ignore if a composition has started since the timeout\n if (!this._isComposing) {\n const newValue = this._textarea.value;\n const diff = newValue.replace(oldValue, '');\n if (diff.length > 0) {\n this._dataAlreadySent = diff;\n this._coreService.triggerDataEvent(diff, true);\n }\n }\n }, 0);\n }\n\n /**\n * Positions the composition view on top of the cursor and the textarea just below it (so the\n * IME helper dialog is positioned correctly).\n * @param dontRecurse Whether to use setTimeout to recursively trigger another update, this is\n * necessary as the IME events across browsers are not consistently triggered.\n */\n public updateCompositionElements(dontRecurse?: boolean): void {\n if (!this._isComposing) {\n return;\n }\n\n if (this._bufferService.buffer.isCursorInViewport) {\n const cellHeight = Math.ceil(this._charSizeService.height * this._optionsService.options.lineHeight);\n const cursorTop = this._bufferService.buffer.y * cellHeight;\n const cursorLeft = this._bufferService.buffer.x * this._charSizeService.width;\n\n this._compositionView.style.left = cursorLeft + 'px';\n this._compositionView.style.top = cursorTop + 'px';\n this._compositionView.style.height = cellHeight + 'px';\n this._compositionView.style.lineHeight = cellHeight + 'px';\n this._compositionView.style.fontFamily = this._optionsService.options.fontFamily;\n this._compositionView.style.fontSize = this._optionsService.options.fontSize + 'px';\n // Sync the textarea to the exact position of the composition view so the IME knows where the\n // text is.\n const compositionViewBounds = this._compositionView.getBoundingClientRect();\n this._textarea.style.left = cursorLeft + 'px';\n this._textarea.style.top = cursorTop + 'px';\n this._textarea.style.width = compositionViewBounds.width + 'px';\n this._textarea.style.height = compositionViewBounds.height + 'px';\n this._textarea.style.lineHeight = compositionViewBounds.height + 'px';\n }\n\n if (!dontRecurse) {\n setTimeout(() => this.updateCompositionElements(true), 0);\n }\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nexport function getCoordsRelativeToElement(event: {clientX: number, clientY: number}, element: HTMLElement): [number, number] {\n const rect = element.getBoundingClientRect();\n return [event.clientX - rect.left, event.clientY - rect.top];\n}\n\n/**\n * Gets coordinates within the terminal for a particular mouse event. The result\n * is returned as an array in the form [x, y] instead of an object as it's a\n * little faster and this function is used in some low level code.\n * @param event The mouse event.\n * @param element The terminal's container element.\n * @param colCount The number of columns in the terminal.\n * @param rowCount The number of rows n the terminal.\n * @param isSelection Whether the request is for the selection or not. This will\n * apply an offset to the x value such that the left half of the cell will\n * select that cell and the right half will select the next cell.\n */\nexport function getCoords(event: {clientX: number, clientY: number}, element: HTMLElement, colCount: number, rowCount: number, hasValidCharSize: boolean, actualCellWidth: number, actualCellHeight: number, isSelection?: boolean): [number, number] | undefined {\n // Coordinates cannot be measured if there are no valid\n if (!hasValidCharSize) {\n return undefined;\n }\n\n const coords = getCoordsRelativeToElement(event, element);\n if (!coords) {\n return undefined;\n }\n\n coords[0] = Math.ceil((coords[0] + (isSelection ? actualCellWidth / 2 : 0)) / actualCellWidth);\n coords[1] = Math.ceil(coords[1] / actualCellHeight);\n\n // Ensure coordinates are within the terminal viewport. Note that selections\n // need an addition point of precision to cover the end point (as characters\n // cover half of one char and half of the next).\n coords[0] = Math.min(Math.max(coords[0], 1), colCount + (isSelection ? 1 : 0));\n coords[1] = Math.min(Math.max(coords[1], 1), rowCount);\n\n return coords;\n}\n\n/**\n * Gets coordinates within the terminal for a particular mouse event, wrapping\n * them to the bounds of the terminal and adding 32 to both the x and y values\n * as expected by xterm.\n */\nexport function getRawByteCoords(coords: [number, number] | undefined): { x: number, y: number } | undefined {\n if (!coords) {\n return undefined;\n }\n\n // xterm sends raw bytes and starts at 32 (SP) for each.\n return { x: coords[0] + 32, y: coords[1] + 32 };\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { C0 } from 'common/data/EscapeSequences';\nimport { IBufferService } from 'common/services/Services';\n\nconst enum Direction {\n UP = 'A',\n DOWN = 'B',\n RIGHT = 'C',\n LEFT = 'D'\n}\n\n/**\n * Concatenates all the arrow sequences together.\n * Resets the starting row to an unwrapped row, moves to the requested row,\n * then moves to requested col.\n */\nexport function moveToCellSequence(targetX: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): string {\n const startX = bufferService.buffer.x;\n const startY = bufferService.buffer.y;\n\n // The alt buffer should try to navigate between rows\n if (!bufferService.buffer.hasScrollback) {\n return resetStartingRow(startX, startY, targetX, targetY, bufferService, applicationCursor) +\n moveToRequestedRow(startY, targetY, bufferService, applicationCursor) +\n moveToRequestedCol(startX, startY, targetX, targetY, bufferService, applicationCursor);\n }\n\n // Only move horizontally for the normal buffer\n let direction;\n if (startY === targetY) {\n direction = startX > targetX ? Direction.LEFT : Direction.RIGHT;\n return repeat(Math.abs(startX - targetX), sequence(direction, applicationCursor));\n }\n direction = startY > targetY ? Direction.LEFT : Direction.RIGHT;\n const rowDifference = Math.abs(startY - targetY);\n const cellsToMove = colsFromRowEnd(startY > targetY ? targetX : startX, bufferService) +\n (rowDifference - 1) * bufferService.cols + 1 /* wrap around 1 row */ +\n colsFromRowBeginning(startY > targetY ? startX : targetX, bufferService);\n return repeat(cellsToMove, sequence(direction, applicationCursor));\n}\n\n/**\n * Find the number of cols from a row beginning to a col.\n */\nfunction colsFromRowBeginning(currX: number, bufferService: IBufferService): number {\n return currX - 1;\n}\n\n/**\n * Find the number of cols from a col to row end.\n */\nfunction colsFromRowEnd(currX: number, bufferService: IBufferService): number {\n return bufferService.cols - currX;\n}\n\n/**\n * If the initial position of the cursor is on a row that is wrapped, move the\n * cursor up to the first row that is not wrapped to have accurate vertical\n * positioning.\n */\nfunction resetStartingRow(startX: number, startY: number, targetX: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): string {\n if (moveToRequestedRow(startY, targetY, bufferService, applicationCursor).length === 0) {\n return '';\n }\n return repeat(bufferLine(\n startX, startY, startX,\n startY - wrappedRowsForRow(bufferService, startY), false, bufferService\n ).length, sequence(Direction.LEFT, applicationCursor));\n}\n\n/**\n * Using the reset starting and ending row, move to the requested row,\n * ignoring wrapped rows\n */\nfunction moveToRequestedRow(startY: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): string {\n const startRow = startY - wrappedRowsForRow(bufferService, startY);\n const endRow = targetY - wrappedRowsForRow(bufferService, targetY);\n\n const rowsToMove = Math.abs(startRow - endRow) - wrappedRowsCount(startY, targetY, bufferService);\n\n return repeat(rowsToMove, sequence(verticalDirection(startY, targetY), applicationCursor));\n}\n\n/**\n * Move to the requested col on the ending row\n */\nfunction moveToRequestedCol(startX: number, startY: number, targetX: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): string {\n let startRow;\n if (moveToRequestedRow(startY, targetY, bufferService, applicationCursor).length > 0) {\n startRow = targetY - wrappedRowsForRow(bufferService, targetY);\n } else {\n startRow = startY;\n }\n\n const endRow = targetY;\n const direction = horizontalDirection(startX, startY, targetX, targetY, bufferService, applicationCursor);\n\n return repeat(bufferLine(\n startX, startRow, targetX, endRow,\n direction === Direction.RIGHT, bufferService\n ).length, sequence(direction, applicationCursor));\n}\n\n/**\n * Utility functions\n */\n\n/**\n * Calculates the number of wrapped rows between the unwrapped starting and\n * ending rows. These rows need to ignored since the cursor skips over them.\n */\nfunction wrappedRowsCount(startY: number, targetY: number, bufferService: IBufferService): number {\n let wrappedRows = 0;\n const startRow = startY - wrappedRowsForRow(bufferService, startY);\n const endRow = targetY - wrappedRowsForRow(bufferService, targetY);\n\n for (let i = 0; i < Math.abs(startRow - endRow); i++) {\n const direction = verticalDirection(startY, targetY) === Direction.UP ? -1 : 1;\n const line = bufferService.buffer.lines.get(startRow + (direction * i));\n if (line && line.isWrapped) {\n wrappedRows++;\n }\n }\n\n return wrappedRows;\n}\n\n/**\n * Calculates the number of wrapped rows that make up a given row.\n * @param currentRow The row to determine how many wrapped rows make it up\n */\nfunction wrappedRowsForRow(bufferService: IBufferService, currentRow: number): number {\n let rowCount = 0;\n let line = bufferService.buffer.lines.get(currentRow);\n let lineWraps = line && line.isWrapped;\n\n while (lineWraps && currentRow >= 0 && currentRow < bufferService.rows) {\n rowCount++;\n line = bufferService.buffer.lines.get(--currentRow);\n lineWraps = line && line.isWrapped;\n }\n\n return rowCount;\n}\n\n/**\n * Direction determiners\n */\n\n/**\n * Determines if the right or left arrow is needed\n */\nfunction horizontalDirection(startX: number, startY: number, targetX: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): Direction {\n let startRow;\n if (moveToRequestedRow(targetX, targetY, bufferService, applicationCursor).length > 0) {\n startRow = targetY - wrappedRowsForRow(bufferService, targetY);\n } else {\n startRow = startY;\n }\n\n if ((startX < targetX &&\n startRow <= targetY) || // down/right or same y/right\n (startX >= targetX &&\n startRow < targetY)) { // down/left or same y/left\n return Direction.RIGHT;\n }\n return Direction.LEFT;\n}\n\n/**\n * Determines if the up or down arrow is needed\n */\nfunction verticalDirection(startY: number, targetY: number): Direction {\n return startY > targetY ? Direction.UP : Direction.DOWN;\n}\n\n/**\n * Constructs the string of chars in the buffer from a starting row and col\n * to an ending row and col\n * @param startCol The starting column position\n * @param startRow The starting row position\n * @param endCol The ending column position\n * @param endRow The ending row position\n * @param forward Direction to move\n */\nfunction bufferLine(\n startCol: number,\n startRow: number,\n endCol: number,\n endRow: number,\n forward: boolean,\n bufferService: IBufferService\n): string {\n let currentCol = startCol;\n let currentRow = startRow;\n let bufferStr = '';\n\n while (currentCol !== endCol || currentRow !== endRow) {\n currentCol += forward ? 1 : -1;\n\n if (forward && currentCol > bufferService.cols - 1) {\n bufferStr += bufferService.buffer.translateBufferLineToString(\n currentRow, false, startCol, currentCol\n );\n currentCol = 0;\n startCol = 0;\n currentRow++;\n } else if (!forward && currentCol < 0) {\n bufferStr += bufferService.buffer.translateBufferLineToString(\n currentRow, false, 0, startCol + 1\n );\n currentCol = bufferService.cols - 1;\n startCol = currentCol;\n currentRow--;\n }\n }\n\n return bufferStr + bufferService.buffer.translateBufferLineToString(\n currentRow, false, startCol, currentCol\n );\n}\n\n/**\n * Constructs the escape sequence for clicking an arrow\n * @param direction The direction to move\n */\nfunction sequence(direction: Direction, applicationCursor: boolean): string {\n const mod = applicationCursor ? 'O' : '[';\n return C0.ESC + mod + direction;\n}\n\n/**\n * Returns a string repeated a given number of times\n * Polyfill from https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/repeat\n * @param count The number of times to repeat the string\n * @param string The string that is to be repeated\n */\nfunction repeat(count: number, str: string): string {\n count = Math.floor(count);\n let rpt = '';\n for (let i = 0; i < count; i++) {\n rpt += str;\n }\n return rpt;\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ITerminalAddon, IDisposable, Terminal } from 'xterm';\n\nexport interface ILoadedAddon {\n instance: ITerminalAddon;\n dispose: () => void;\n isDisposed: boolean;\n}\n\nexport class AddonManager implements IDisposable {\n protected _addons: ILoadedAddon[] = [];\n\n constructor() {\n }\n\n public dispose(): void {\n for (let i = this._addons.length - 1; i >= 0; i--) {\n this._addons[i].instance.dispose();\n }\n }\n\n public loadAddon(terminal: Terminal, instance: ITerminalAddon): void {\n const loadedAddon: ILoadedAddon = {\n instance,\n dispose: instance.dispose,\n isDisposed: false\n };\n this._addons.push(loadedAddon);\n instance.dispose = () => this._wrappedAddonDispose(loadedAddon);\n instance.activate(terminal);\n }\n\n private _wrappedAddonDispose(loadedAddon: ILoadedAddon): void {\n if (loadedAddon.isDisposed) {\n // Do nothing if already disposed\n return;\n }\n let index = -1;\n for (let i = 0; i < this._addons.length; i++) {\n if (this._addons[i] === loadedAddon) {\n index = i;\n break;\n }\n }\n if (index === -1) {\n throw new Error('Could not dispose an addon that has not been loaded');\n }\n loadedAddon.isDisposed = true;\n loadedAddon.dispose.apply(loadedAddon.instance);\n this._addons.splice(index, 1);\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Terminal as ITerminalApi, ITerminalOptions, IMarker, IDisposable, ILinkMatcherOptions, ITheme, ILocalizableStrings, ITerminalAddon, ISelectionPosition, IBuffer as IBufferApi, IBufferNamespace as IBufferNamespaceApi, IBufferLine as IBufferLineApi, IBufferCell as IBufferCellApi, IParser, IFunctionIdentifier, ILinkProvider, IUnicodeHandling, IUnicodeVersionProvider, FontWeight } from 'xterm';\nimport { ITerminal } from 'browser/Types';\nimport { IBufferLine, ICellData } from 'common/Types';\nimport { IBuffer, IBufferSet } from 'common/buffer/Types';\nimport { CellData } from 'common/buffer/CellData';\nimport { Terminal as TerminalCore } from '../Terminal';\nimport * as Strings from '../LocalizableStrings';\nimport { IEvent, EventEmitter } from 'common/EventEmitter';\nimport { AddonManager } from './AddonManager';\nimport { IParams } from 'common/parser/Types';\nimport { BufferSet } from 'common/buffer/BufferSet';\n\nexport class Terminal implements ITerminalApi {\n private _core: ITerminal;\n private _addonManager: AddonManager;\n private _parser: IParser | undefined;\n private _buffer: BufferNamespaceApi | undefined;\n\n constructor(options?: ITerminalOptions) {\n this._core = new TerminalCore(options);\n this._addonManager = new AddonManager();\n }\n\n private _checkProposedApi(): void {\n if (!this._core.optionsService.options.allowProposedApi) {\n throw new Error('You must set the allowProposedApi option to true to use proposed API');\n }\n }\n\n public get onCursorMove(): IEvent { return this._core.onCursorMove; }\n public get onLineFeed(): IEvent { return this._core.onLineFeed; }\n public get onSelectionChange(): IEvent { return this._core.onSelectionChange; }\n public get onData(): IEvent { return this._core.onData; }\n public get onBinary(): IEvent { return this._core.onBinary; }\n public get onTitleChange(): IEvent { return this._core.onTitleChange; }\n public get onScroll(): IEvent { return this._core.onScroll; }\n public get onKey(): IEvent<{ key: string, domEvent: KeyboardEvent }> { return this._core.onKey; }\n public get onRender(): IEvent<{ start: number, end: number }> { return this._core.onRender; }\n public get onResize(): IEvent<{ cols: number, rows: number }> { return this._core.onResize; }\n\n public get element(): HTMLElement | undefined { return this._core.element; }\n public get parser(): IParser {\n this._checkProposedApi();\n if (!this._parser) {\n this._parser = new ParserApi(this._core);\n }\n return this._parser;\n }\n public get unicode(): IUnicodeHandling {\n this._checkProposedApi();\n return new UnicodeApi(this._core);\n }\n public get textarea(): HTMLTextAreaElement | undefined { return this._core.textarea; }\n public get rows(): number { return this._core.rows; }\n public get cols(): number { return this._core.cols; }\n public get buffer(): IBufferNamespaceApi {\n this._checkProposedApi();\n if (!this._buffer) {\n this._buffer = new BufferNamespaceApi(this._core);\n }\n return this._buffer;\n }\n public get markers(): ReadonlyArray {\n this._checkProposedApi();\n return this._core.markers;\n }\n public blur(): void {\n this._core.blur();\n }\n public focus(): void {\n this._core.focus();\n }\n public resize(columns: number, rows: number): void {\n this._verifyIntegers(columns, rows);\n this._core.resize(columns, rows);\n }\n public open(parent: HTMLElement): void {\n this._core.open(parent);\n }\n public attachCustomKeyEventHandler(customKeyEventHandler: (event: KeyboardEvent) => boolean): void {\n this._core.attachCustomKeyEventHandler(customKeyEventHandler);\n }\n public registerLinkMatcher(regex: RegExp, handler: (event: MouseEvent, uri: string) => void, options?: ILinkMatcherOptions): number {\n this._checkProposedApi();\n return this._core.registerLinkMatcher(regex, handler, options);\n }\n public deregisterLinkMatcher(matcherId: number): void {\n this._checkProposedApi();\n this._core.deregisterLinkMatcher(matcherId);\n }\n public registerLinkProvider(linkProvider: ILinkProvider): IDisposable {\n this._checkProposedApi();\n return this._core.registerLinkProvider(linkProvider);\n }\n public registerCharacterJoiner(handler: (text: string) => [number, number][]): number {\n this._checkProposedApi();\n return this._core.registerCharacterJoiner(handler);\n }\n public deregisterCharacterJoiner(joinerId: number): void {\n this._checkProposedApi();\n this._core.deregisterCharacterJoiner(joinerId);\n }\n public registerMarker(cursorYOffset: number): IMarker | undefined {\n this._checkProposedApi();\n this._verifyIntegers(cursorYOffset);\n return this._core.addMarker(cursorYOffset);\n }\n public addMarker(cursorYOffset: number): IMarker | undefined {\n return this.registerMarker(cursorYOffset);\n }\n public hasSelection(): boolean {\n return this._core.hasSelection();\n }\n public select(column: number, row: number, length: number): void {\n this._verifyIntegers(column, row, length);\n this._core.select(column, row, length);\n }\n public getSelection(): string {\n return this._core.getSelection();\n }\n public getSelectionPosition(): ISelectionPosition | undefined {\n return this._core.getSelectionPosition();\n }\n public clearSelection(): void {\n this._core.clearSelection();\n }\n public selectAll(): void {\n this._core.selectAll();\n }\n public selectLines(start: number, end: number): void {\n this._verifyIntegers(start, end);\n this._core.selectLines(start, end);\n }\n public dispose(): void {\n this._addonManager.dispose();\n this._core.dispose();\n }\n public scrollLines(amount: number): void {\n this._verifyIntegers(amount);\n this._core.scrollLines(amount);\n }\n public scrollPages(pageCount: number): void {\n this._verifyIntegers(pageCount);\n this._core.scrollPages(pageCount);\n }\n public scrollToTop(): void {\n this._core.scrollToTop();\n }\n public scrollToBottom(): void {\n this._core.scrollToBottom();\n }\n public scrollToLine(line: number): void {\n this._verifyIntegers(line);\n this._core.scrollToLine(line);\n }\n public clear(): void {\n this._core.clear();\n }\n public write(data: string | Uint8Array, callback?: () => void): void {\n this._core.write(data, callback);\n }\n public writeUtf8(data: Uint8Array, callback?: () => void): void {\n this._core.write(data, callback);\n }\n public writeln(data: string | Uint8Array, callback?: () => void): void {\n this._core.write(data);\n this._core.write('\\r\\n', callback);\n }\n public paste(data: string): void {\n this._core.paste(data);\n }\n public getOption(key: 'bellSound' | 'bellStyle' | 'cursorStyle' | 'fontFamily' | 'logLevel' | 'rendererType' | 'termName' | 'wordSeparator'): string;\n public getOption(key: 'allowTransparency' | 'altClickMovesCursor' | 'cancelEvents' | 'convertEol' | 'cursorBlink' | 'disableStdin' | 'macOptionIsMeta' | 'rightClickSelectsWord' | 'popOnBell' | 'visualBell'): boolean;\n public getOption(key: 'cols' | 'fontSize' | 'letterSpacing' | 'lineHeight' | 'rows' | 'tabStopWidth' | 'scrollback'): number;\n public getOption(key: 'fontWeight' | 'fontWeightBold'): FontWeight;\n public getOption(key: string): any;\n public getOption(key: any): any {\n return this._core.optionsService.getOption(key);\n }\n public setOption(key: 'bellSound' | 'fontFamily' | 'termName' | 'wordSeparator', value: string): void;\n public setOption(key: 'fontWeight' | 'fontWeightBold', value: 'normal' | 'bold' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900' | number): void;\n public setOption(key: 'logLevel', value: 'debug' | 'info' | 'warn' | 'error' | 'off'): void;\n public setOption(key: 'bellStyle', value: 'none' | 'visual' | 'sound' | 'both'): void;\n public setOption(key: 'cursorStyle', value: 'block' | 'underline' | 'bar'): void;\n public setOption(key: 'allowTransparency' | 'altClickMovesCursor' | 'cancelEvents' | 'convertEol' | 'cursorBlink' | 'disableStdin' | 'macOptionIsMeta' | 'rightClickSelectsWord' | 'popOnBell' | 'visualBell', value: boolean): void;\n public setOption(key: 'fontSize' | 'letterSpacing' | 'lineHeight' | 'tabStopWidth' | 'scrollback', value: number): void;\n public setOption(key: 'theme', value: ITheme): void;\n public setOption(key: 'cols' | 'rows', value: number): void;\n public setOption(key: string, value: any): void;\n public setOption(key: any, value: any): void {\n this._core.optionsService.setOption(key, value);\n }\n public refresh(start: number, end: number): void {\n this._verifyIntegers(start, end);\n this._core.refresh(start, end);\n }\n public reset(): void {\n this._core.reset();\n }\n public loadAddon(addon: ITerminalAddon): void {\n return this._addonManager.loadAddon(this, addon);\n }\n public static get strings(): ILocalizableStrings {\n return Strings;\n }\n\n private _verifyIntegers(...values: number[]): void {\n for (const value of values) {\n if (value === Infinity || isNaN(value) || value % 1 !== 0) {\n throw new Error('This API only accepts integers');\n }\n }\n }\n}\n\nclass BufferApiView implements IBufferApi {\n constructor(\n private _buffer: IBuffer,\n public readonly type: 'normal' | 'alternate'\n ) { }\n\n public init(buffer: IBuffer): BufferApiView {\n this._buffer = buffer;\n return this;\n }\n\n public get cursorY(): number { return this._buffer.y; }\n public get cursorX(): number { return this._buffer.x; }\n public get viewportY(): number { return this._buffer.ydisp; }\n public get baseY(): number { return this._buffer.ybase; }\n public get length(): number { return this._buffer.lines.length; }\n public getLine(y: number): IBufferLineApi | undefined {\n const line = this._buffer.lines.get(y);\n if (!line) {\n return undefined;\n }\n return new BufferLineApiView(line);\n }\n public getNullCell(): IBufferCellApi { return new CellData(); }\n}\n\nclass BufferNamespaceApi implements IBufferNamespaceApi {\n private _normal: BufferApiView;\n private _alternate: BufferApiView;\n private _onBufferChange = new EventEmitter();\n public get onBufferChange(): IEvent { return this._onBufferChange.event; }\n\n constructor(private _core: ITerminal) {\n this._normal = new BufferApiView(this._core.buffers.normal, 'normal');\n this._alternate = new BufferApiView(this._core.buffers.alt, 'alternate');\n this._core.buffers.onBufferActivate(() => this._onBufferChange.fire(this.active));\n }\n public get active(): IBufferApi {\n if (this._core.buffers.active === this._core.buffers.normal) { return this.normal; }\n if (this._core.buffers.active === this._core.buffers.alt) { return this.alternate; }\n throw new Error('Active buffer is neither normal nor alternate');\n }\n public get normal(): IBufferApi {\n return this._normal.init(this._core.buffers.normal);\n }\n public get alternate(): IBufferApi {\n return this._alternate.init(this._core.buffers.alt);\n }\n}\n\nclass BufferLineApiView implements IBufferLineApi {\n constructor(private _line: IBufferLine) { }\n\n public get isWrapped(): boolean { return this._line.isWrapped; }\n public get length(): number { return this._line.length; }\n public getCell(x: number, cell?: IBufferCellApi): IBufferCellApi | undefined {\n if (x < 0 || x >= this._line.length) {\n return undefined;\n }\n\n if (cell) {\n this._line.loadCell(x, cell);\n return cell;\n }\n return this._line.loadCell(x, new CellData());\n }\n public translateToString(trimRight?: boolean, startColumn?: number, endColumn?: number): string {\n return this._line.translateToString(trimRight, startColumn, endColumn);\n }\n}\n\nclass ParserApi implements IParser {\n constructor(private _core: ITerminal) { }\n\n public registerCsiHandler(id: IFunctionIdentifier, callback: (params: (number | number[])[]) => boolean): IDisposable {\n return this._core.addCsiHandler(id, (params: IParams) => callback(params.toArray()));\n }\n public addCsiHandler(id: IFunctionIdentifier, callback: (params: (number | number[])[]) => boolean): IDisposable {\n return this.registerCsiHandler(id, callback);\n }\n public registerDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: (number | number[])[]) => boolean): IDisposable {\n return this._core.addDcsHandler(id, (data: string, params: IParams) => callback(data, params.toArray()));\n }\n public addDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: (number | number[])[]) => boolean): IDisposable {\n return this.registerDcsHandler(id, callback);\n }\n public registerEscHandler(id: IFunctionIdentifier, handler: () => boolean): IDisposable {\n return this._core.addEscHandler(id, handler);\n }\n public addEscHandler(id: IFunctionIdentifier, handler: () => boolean): IDisposable {\n return this.registerEscHandler(id, handler);\n }\n public registerOscHandler(ident: number, callback: (data: string) => boolean): IDisposable {\n return this._core.addOscHandler(ident, callback);\n }\n public addOscHandler(ident: number, callback: (data: string) => boolean): IDisposable {\n return this.registerOscHandler(ident, callback);\n }\n}\n\nclass UnicodeApi implements IUnicodeHandling {\n constructor(private _core: ITerminal) { }\n\n public register(provider: IUnicodeVersionProvider): void {\n this._core.unicodeService.register(provider);\n }\n\n public get versions(): string[] {\n return this._core.unicodeService.versions;\n }\n\n public get activeVersion(): string {\n return this._core.unicodeService.activeVersion;\n }\n\n public set activeVersion(version: string) {\n this._core.unicodeService.activeVersion = version;\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IRenderDimensions, IRenderLayer } from 'browser/renderer/Types';\nimport { ICellData } from 'common/Types';\nimport { DEFAULT_COLOR, WHITESPACE_CELL_CHAR, WHITESPACE_CELL_CODE, Attributes } from 'common/buffer/Constants';\nimport { IGlyphIdentifier } from 'browser/renderer/atlas/Types';\nimport { DIM_OPACITY, INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants';\nimport { BaseCharAtlas } from 'browser/renderer/atlas/BaseCharAtlas';\nimport { acquireCharAtlas } from 'browser/renderer/atlas/CharAtlasCache';\nimport { AttributeData } from 'common/buffer/AttributeData';\nimport { IColorSet, IColor } from 'browser/Types';\nimport { CellData } from 'common/buffer/CellData';\nimport { IBufferService, IOptionsService } from 'common/services/Services';\nimport { throwIfFalsy } from 'browser/renderer/RendererUtils';\nimport { channels, color, rgba } from 'browser/Color';\nimport { removeElementFromParent } from 'browser/Dom';\n\nexport abstract class BaseRenderLayer implements IRenderLayer {\n private _canvas: HTMLCanvasElement;\n protected _ctx!: CanvasRenderingContext2D;\n private _scaledCharWidth: number = 0;\n private _scaledCharHeight: number = 0;\n private _scaledCellWidth: number = 0;\n private _scaledCellHeight: number = 0;\n private _scaledCharLeft: number = 0;\n private _scaledCharTop: number = 0;\n\n protected _charAtlas: BaseCharAtlas | undefined;\n\n /**\n * An object that's reused when drawing glyphs in order to reduce GC.\n */\n private _currentGlyphIdentifier: IGlyphIdentifier = {\n chars: '',\n code: 0,\n bg: 0,\n fg: 0,\n bold: false,\n dim: false,\n italic: false\n };\n\n constructor(\n private _container: HTMLElement,\n id: string,\n zIndex: number,\n private _alpha: boolean,\n protected _colors: IColorSet,\n private _rendererId: number,\n protected readonly _bufferService: IBufferService,\n protected readonly _optionsService: IOptionsService\n ) {\n this._canvas = document.createElement('canvas');\n this._canvas.classList.add(`xterm-${id}-layer`);\n this._canvas.style.zIndex = zIndex.toString();\n this._initCanvas();\n this._container.appendChild(this._canvas);\n }\n\n public dispose(): void {\n removeElementFromParent(this._canvas);\n this._charAtlas?.dispose();\n }\n\n private _initCanvas(): void {\n this._ctx = throwIfFalsy(this._canvas.getContext('2d', {alpha: this._alpha}));\n // Draw the background if this is an opaque layer\n if (!this._alpha) {\n this._clearAll();\n }\n }\n\n public onOptionsChanged(): void {}\n public onBlur(): void {}\n public onFocus(): void {}\n public onCursorMove(): void {}\n public onGridChanged(startRow: number, endRow: number): void {}\n public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean = false): void {}\n\n public setColors(colorSet: IColorSet): void {\n this._refreshCharAtlas(colorSet);\n }\n\n protected _setTransparency(alpha: boolean): void {\n // Do nothing when alpha doesn't change\n if (alpha === this._alpha) {\n return;\n }\n\n // Create new canvas and replace old one\n const oldCanvas = this._canvas;\n this._alpha = alpha;\n // Cloning preserves properties\n this._canvas = this._canvas.cloneNode() as HTMLCanvasElement;\n this._initCanvas();\n this._container.replaceChild(this._canvas, oldCanvas);\n\n // Regenerate char atlas and force a full redraw\n this._refreshCharAtlas(this._colors);\n this.onGridChanged(0, this._bufferService.rows - 1);\n }\n\n /**\n * Refreshes the char atlas, aquiring a new one if necessary.\n * @param colorSet The color set to use for the char atlas.\n */\n private _refreshCharAtlas(colorSet: IColorSet): void {\n if (this._scaledCharWidth <= 0 && this._scaledCharHeight <= 0) {\n return;\n }\n this._charAtlas = acquireCharAtlas(this._optionsService.options, this._rendererId, colorSet, this._scaledCharWidth, this._scaledCharHeight);\n this._charAtlas.warmUp();\n }\n\n public resize(dim: IRenderDimensions): void {\n this._scaledCellWidth = dim.scaledCellWidth;\n this._scaledCellHeight = dim.scaledCellHeight;\n this._scaledCharWidth = dim.scaledCharWidth;\n this._scaledCharHeight = dim.scaledCharHeight;\n this._scaledCharLeft = dim.scaledCharLeft;\n this._scaledCharTop = dim.scaledCharTop;\n this._canvas.width = dim.scaledCanvasWidth;\n this._canvas.height = dim.scaledCanvasHeight;\n this._canvas.style.width = `${dim.canvasWidth}px`;\n this._canvas.style.height = `${dim.canvasHeight}px`;\n\n // Draw the background if this is an opaque layer\n if (!this._alpha) {\n this._clearAll();\n }\n\n this._refreshCharAtlas(this._colors);\n }\n\n public abstract reset(): void;\n\n /**\n * Fills 1+ cells completely. This uses the existing fillStyle on the context.\n * @param x The column to start at.\n * @param y The row to start at\n * @param width The number of columns to fill.\n * @param height The number of rows to fill.\n */\n protected _fillCells(x: number, y: number, width: number, height: number): void {\n this._ctx.fillRect(\n x * this._scaledCellWidth,\n y * this._scaledCellHeight,\n width * this._scaledCellWidth,\n height * this._scaledCellHeight);\n }\n\n /**\n * Fills a 1px line (2px on HDPI) at the bottom of the cell. This uses the\n * existing fillStyle on the context.\n * @param x The column to fill.\n * @param y The row to fill.\n */\n protected _fillBottomLineAtCells(x: number, y: number, width: number = 1): void {\n this._ctx.fillRect(\n x * this._scaledCellWidth,\n (y + 1) * this._scaledCellHeight - window.devicePixelRatio - 1 /* Ensure it's drawn within the cell */,\n width * this._scaledCellWidth,\n window.devicePixelRatio);\n }\n\n /**\n * Fills a 1px line (2px on HDPI) at the left of the cell. This uses the\n * existing fillStyle on the context.\n * @param x The column to fill.\n * @param y The row to fill.\n */\n protected _fillLeftLineAtCell(x: number, y: number, width: number): void {\n this._ctx.fillRect(\n x * this._scaledCellWidth,\n y * this._scaledCellHeight,\n window.devicePixelRatio * width,\n this._scaledCellHeight);\n }\n\n /**\n * Strokes a 1px rectangle (2px on HDPI) around a cell. This uses the existing\n * strokeStyle on the context.\n * @param x The column to fill.\n * @param y The row to fill.\n */\n protected _strokeRectAtCell(x: number, y: number, width: number, height: number): void {\n this._ctx.lineWidth = window.devicePixelRatio;\n this._ctx.strokeRect(\n x * this._scaledCellWidth + window.devicePixelRatio / 2,\n y * this._scaledCellHeight + (window.devicePixelRatio / 2),\n width * this._scaledCellWidth - window.devicePixelRatio,\n (height * this._scaledCellHeight) - window.devicePixelRatio);\n }\n\n /**\n * Clears the entire canvas.\n */\n protected _clearAll(): void {\n if (this._alpha) {\n this._ctx.clearRect(0, 0, this._canvas.width, this._canvas.height);\n } else {\n this._ctx.fillStyle = this._colors.background.css;\n this._ctx.fillRect(0, 0, this._canvas.width, this._canvas.height);\n }\n }\n\n /**\n * Clears 1+ cells completely.\n * @param x The column to start at.\n * @param y The row to start at.\n * @param width The number of columns to clear.\n * @param height The number of rows to clear.\n */\n protected _clearCells(x: number, y: number, width: number, height: number): void {\n if (this._alpha) {\n this._ctx.clearRect(\n x * this._scaledCellWidth,\n y * this._scaledCellHeight,\n width * this._scaledCellWidth,\n height * this._scaledCellHeight);\n } else {\n this._ctx.fillStyle = this._colors.background.css;\n this._ctx.fillRect(\n x * this._scaledCellWidth,\n y * this._scaledCellHeight,\n width * this._scaledCellWidth,\n height * this._scaledCellHeight);\n }\n }\n\n /**\n * Draws a truecolor character at the cell. The character will be clipped to\n * ensure that it fits with the cell, including the cell to the right if it's\n * a wide character. This uses the existing fillStyle on the context.\n * @param cell The cell data for the character to draw.\n * @param x The column to draw at.\n * @param y The row to draw at.\n * @param color The color of the character.\n */\n protected _fillCharTrueColor(cell: CellData, x: number, y: number): void {\n this._ctx.font = this._getFont(false, false);\n this._ctx.textBaseline = 'middle';\n this._clipRow(y);\n this._ctx.fillText(\n cell.getChars(),\n x * this._scaledCellWidth + this._scaledCharLeft,\n y * this._scaledCellHeight + this._scaledCharTop + this._scaledCharHeight / 2);\n }\n\n /**\n * Draws one or more characters at a cell. If possible this will draw using\n * the character atlas to reduce draw time.\n * @param chars The character or characters.\n * @param code The character code.\n * @param width The width of the characters.\n * @param x The column to draw at.\n * @param y The row to draw at.\n * @param fg The foreground color, in the format stored within the attributes.\n * @param bg The background color, in the format stored within the attributes.\n * This is used to validate whether a cached image can be used.\n * @param bold Whether the text is bold.\n */\n protected _drawChars(cell: ICellData, x: number, y: number): void {\n const contrastColor = this._getContrastColor(cell);\n\n // skip cache right away if we draw in RGB\n // Note: to avoid bad runtime JoinedCellData will be skipped\n // in the cache handler itself (atlasDidDraw == false) and\n // fall through to uncached later down below\n if (contrastColor || cell.isFgRGB() || cell.isBgRGB()) {\n this._drawUncachedChars(cell, x, y, contrastColor);\n return;\n }\n\n let fg;\n let bg;\n if (cell.isInverse()) {\n fg = (cell.isBgDefault()) ? INVERTED_DEFAULT_COLOR : cell.getBgColor();\n bg = (cell.isFgDefault()) ? INVERTED_DEFAULT_COLOR : cell.getFgColor();\n } else {\n bg = (cell.isBgDefault()) ? DEFAULT_COLOR : cell.getBgColor();\n fg = (cell.isFgDefault()) ? DEFAULT_COLOR : cell.getFgColor();\n }\n\n const drawInBrightColor = this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && fg < 8;\n\n fg += drawInBrightColor ? 8 : 0;\n this._currentGlyphIdentifier.chars = cell.getChars() || WHITESPACE_CELL_CHAR;\n this._currentGlyphIdentifier.code = cell.getCode() || WHITESPACE_CELL_CODE;\n this._currentGlyphIdentifier.bg = bg;\n this._currentGlyphIdentifier.fg = fg;\n this._currentGlyphIdentifier.bold = !!cell.isBold();\n this._currentGlyphIdentifier.dim = !!cell.isDim();\n this._currentGlyphIdentifier.italic = !!cell.isItalic();\n const atlasDidDraw = this._charAtlas && this._charAtlas.draw(\n this._ctx,\n this._currentGlyphIdentifier,\n x * this._scaledCellWidth + this._scaledCharLeft,\n y * this._scaledCellHeight + this._scaledCharTop\n );\n\n if (!atlasDidDraw) {\n this._drawUncachedChars(cell, x, y);\n }\n }\n\n /**\n * Draws one or more characters at one or more cells. The character(s) will be\n * clipped to ensure that they fit with the cell(s), including the cell to the\n * right if the last character is a wide character.\n * @param chars The character.\n * @param width The width of the character.\n * @param fg The foreground color, in the format stored within the attributes.\n * @param x The column to draw at.\n * @param y The row to draw at.\n */\n private _drawUncachedChars(cell: ICellData, x: number, y: number, fgOverride?: IColor): void {\n this._ctx.save();\n this._ctx.font = this._getFont(!!cell.isBold(), !!cell.isItalic());\n this._ctx.textBaseline = 'middle';\n\n if (cell.isInverse()) {\n if (fgOverride) {\n this._ctx.fillStyle = fgOverride.css;\n } else if (cell.isBgDefault()) {\n this._ctx.fillStyle = color.opaque(this._colors.background).css;\n } else if (cell.isBgRGB()) {\n this._ctx.fillStyle = `rgb(${AttributeData.toColorRGB(cell.getBgColor()).join(',')})`;\n } else {\n let bg = cell.getBgColor();\n if (this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && bg < 8) {\n bg += 8;\n }\n this._ctx.fillStyle = this._colors.ansi[bg].css;\n }\n } else {\n if (fgOverride) {\n this._ctx.fillStyle = fgOverride.css;\n } else if (cell.isFgDefault()) {\n this._ctx.fillStyle = this._colors.foreground.css;\n } else if (cell.isFgRGB()) {\n this._ctx.fillStyle = `rgb(${AttributeData.toColorRGB(cell.getFgColor()).join(',')})`;\n } else {\n let fg = cell.getFgColor();\n if (this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && fg < 8) {\n fg += 8;\n }\n this._ctx.fillStyle = this._colors.ansi[fg].css;\n }\n }\n\n this._clipRow(y);\n\n // Apply alpha to dim the character\n if (cell.isDim()) {\n this._ctx.globalAlpha = DIM_OPACITY;\n }\n // Draw the character\n this._ctx.fillText(\n cell.getChars(),\n x * this._scaledCellWidth + this._scaledCharLeft,\n y * this._scaledCellHeight + this._scaledCharTop + this._scaledCharHeight / 2);\n this._ctx.restore();\n }\n\n /**\n * Clips a row to ensure no pixels will be drawn outside the cells in the row.\n * @param y The row to clip.\n */\n private _clipRow(y: number): void {\n this._ctx.beginPath();\n this._ctx.rect(\n 0,\n y * this._scaledCellHeight,\n this._bufferService.cols * this._scaledCellWidth,\n this._scaledCellHeight);\n this._ctx.clip();\n }\n\n /**\n * Gets the current font.\n * @param isBold If we should use the bold fontWeight.\n */\n protected _getFont(isBold: boolean, isItalic: boolean): string {\n const fontWeight = isBold ? this._optionsService.options.fontWeightBold : this._optionsService.options.fontWeight;\n const fontStyle = isItalic ? 'italic' : '';\n\n return `${fontStyle} ${fontWeight} ${this._optionsService.options.fontSize * window.devicePixelRatio}px ${this._optionsService.options.fontFamily}`;\n }\n\n private _getContrastColor(cell: CellData): IColor | undefined {\n if (this._optionsService.options.minimumContrastRatio === 1) {\n return undefined;\n }\n\n // Try get from cache first\n const adjustedColor = this._colors.contrastCache.getColor(cell.bg, cell.fg);\n if (adjustedColor !== undefined) {\n return adjustedColor || undefined;\n }\n\n let fgColor = cell.getFgColor();\n let fgColorMode = cell.getFgColorMode();\n let bgColor = cell.getBgColor();\n let bgColorMode = cell.getBgColorMode();\n const isInverse = !!cell.isInverse();\n const isBold = !!cell.isInverse();\n if (isInverse) {\n const temp = fgColor;\n fgColor = bgColor;\n bgColor = temp;\n const temp2 = fgColorMode;\n fgColorMode = bgColorMode;\n bgColorMode = temp2;\n }\n\n const bgRgba = this._resolveBackgroundRgba(bgColorMode, bgColor, isInverse);\n const fgRgba = this._resolveForegroundRgba(fgColorMode, fgColor, isInverse, isBold);\n const result = rgba.ensureContrastRatio(bgRgba, fgRgba, this._optionsService.options.minimumContrastRatio);\n\n if (!result) {\n this._colors.contrastCache.setColor(cell.bg, cell.fg, null);\n return undefined;\n }\n\n const color: IColor = {\n css: channels.toCss(\n (result >> 24) & 0xFF,\n (result >> 16) & 0xFF,\n (result >> 8) & 0xFF\n ),\n rgba: result\n };\n this._colors.contrastCache.setColor(cell.bg, cell.fg, color);\n\n return color;\n }\n\n private _resolveBackgroundRgba(bgColorMode: number, bgColor: number, inverse: boolean): number {\n switch (bgColorMode) {\n case Attributes.CM_P16:\n case Attributes.CM_P256:\n return this._colors.ansi[bgColor].rgba;\n case Attributes.CM_RGB:\n return bgColor << 8;\n case Attributes.CM_DEFAULT:\n default:\n if (inverse) {\n return this._colors.foreground.rgba;\n }\n return this._colors.background.rgba;\n }\n }\n\n private _resolveForegroundRgba(fgColorMode: number, fgColor: number, inverse: boolean, bold: boolean): number {\n switch (fgColorMode) {\n case Attributes.CM_P16:\n case Attributes.CM_P256:\n if (this._optionsService.options.drawBoldTextInBrightColors && bold && fgColor < 8) {\n fgColor += 8;\n }\n return this._colors.ansi[fgColor].rgba;\n case Attributes.CM_RGB:\n return fgColor << 8;\n case Attributes.CM_DEFAULT:\n default:\n if (inverse) {\n return this._colors.background.rgba;\n }\n return this._colors.foreground.rgba;\n }\n }\n}\n\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IBufferLine, ICellData, CharData } from 'common/Types';\nimport { ICharacterJoinerRegistry, ICharacterJoiner } from 'browser/renderer/Types';\nimport { AttributeData } from 'common/buffer/AttributeData';\nimport { WHITESPACE_CELL_CHAR, Content } from 'common/buffer/Constants';\nimport { CellData } from 'common/buffer/CellData';\nimport { IBufferService } from 'common/services/Services';\n\nexport class JoinedCellData extends AttributeData implements ICellData {\n private _width: number;\n // .content carries no meaning for joined CellData, simply nullify it\n // thus we have to overload all other .content accessors\n public content: number = 0;\n public fg: number;\n public bg: number;\n public combinedData: string = '';\n\n constructor(firstCell: ICellData, chars: string, width: number) {\n super();\n this.fg = firstCell.fg;\n this.bg = firstCell.bg;\n this.combinedData = chars;\n this._width = width;\n }\n\n public isCombined(): number {\n // always mark joined cell data as combined\n return Content.IS_COMBINED_MASK;\n }\n\n public getWidth(): number {\n return this._width;\n }\n\n public getChars(): string {\n return this.combinedData;\n }\n\n public getCode(): number {\n // code always gets the highest possible fake codepoint (read as -1)\n // this is needed as code is used by caches as identifier\n return 0x1FFFFF;\n }\n\n public setFromCharData(value: CharData): void {\n throw new Error('not implemented');\n }\n\n public getAsCharData(): CharData {\n return [this.fg, this.getChars(), this.getWidth(), this.getCode()];\n }\n}\n\nexport class CharacterJoinerRegistry implements ICharacterJoinerRegistry {\n\n private _characterJoiners: ICharacterJoiner[] = [];\n private _nextCharacterJoinerId: number = 0;\n private _workCell: CellData = new CellData();\n\n constructor(private _bufferService: IBufferService) { }\n\n public registerCharacterJoiner(handler: (text: string) => [number, number][]): number {\n const joiner: ICharacterJoiner = {\n id: this._nextCharacterJoinerId++,\n handler\n };\n\n this._characterJoiners.push(joiner);\n return joiner.id;\n }\n\n public deregisterCharacterJoiner(joinerId: number): boolean {\n for (let i = 0; i < this._characterJoiners.length; i++) {\n if (this._characterJoiners[i].id === joinerId) {\n this._characterJoiners.splice(i, 1);\n return true;\n }\n }\n\n return false;\n }\n\n public getJoinedCharacters(row: number): [number, number][] {\n if (this._characterJoiners.length === 0) {\n return [];\n }\n\n const line = this._bufferService.buffer.lines.get(row);\n if (!line || line.length === 0) {\n return [];\n }\n\n const ranges: [number, number][] = [];\n const lineStr = line.translateToString(true);\n\n // Because some cells can be represented by multiple javascript characters,\n // we track the cell and the string indexes separately. This allows us to\n // translate the string ranges we get from the joiners back into cell ranges\n // for use when rendering\n let rangeStartColumn = 0;\n let currentStringIndex = 0;\n let rangeStartStringIndex = 0;\n let rangeAttrFG = line.getFg(0);\n let rangeAttrBG = line.getBg(0);\n\n for (let x = 0; x < line.getTrimmedLength(); x++) {\n line.loadCell(x, this._workCell);\n\n if (this._workCell.getWidth() === 0) {\n // If this character is of width 0, skip it.\n continue;\n }\n\n // End of range\n if (this._workCell.fg !== rangeAttrFG || this._workCell.bg !== rangeAttrBG) {\n // If we ended up with a sequence of more than one character,\n // look for ranges to join.\n if (x - rangeStartColumn > 1) {\n const joinedRanges = this._getJoinedRanges(\n lineStr,\n rangeStartStringIndex,\n currentStringIndex,\n line,\n rangeStartColumn\n );\n for (let i = 0; i < joinedRanges.length; i++) {\n ranges.push(joinedRanges[i]);\n }\n }\n\n // Reset our markers for a new range.\n rangeStartColumn = x;\n rangeStartStringIndex = currentStringIndex;\n rangeAttrFG = this._workCell.fg;\n rangeAttrBG = this._workCell.bg;\n }\n\n currentStringIndex += this._workCell.getChars().length || WHITESPACE_CELL_CHAR.length;\n }\n\n // Process any trailing ranges.\n if (this._bufferService.cols - rangeStartColumn > 1) {\n const joinedRanges = this._getJoinedRanges(\n lineStr,\n rangeStartStringIndex,\n currentStringIndex,\n line,\n rangeStartColumn\n );\n for (let i = 0; i < joinedRanges.length; i++) {\n ranges.push(joinedRanges[i]);\n }\n }\n\n return ranges;\n }\n\n /**\n * Given a segment of a line of text, find all ranges of text that should be\n * joined in a single rendering unit. Ranges are internally converted to\n * column ranges, rather than string ranges.\n * @param line String representation of the full line of text\n * @param startIndex Start position of the range to search in the string (inclusive)\n * @param endIndex End position of the range to search in the string (exclusive)\n */\n private _getJoinedRanges(line: string, startIndex: number, endIndex: number, lineData: IBufferLine, startCol: number): [number, number][] {\n const text = line.substring(startIndex, endIndex);\n // At this point we already know that there is at least one joiner so\n // we can just pull its value and assign it directly rather than\n // merging it into an empty array, which incurs unnecessary writes.\n const joinedRanges: [number, number][] = this._characterJoiners[0].handler(text);\n for (let i = 1; i < this._characterJoiners.length; i++) {\n // We merge any overlapping ranges across the different joiners\n const joinerRanges = this._characterJoiners[i].handler(text);\n for (let j = 0; j < joinerRanges.length; j++) {\n CharacterJoinerRegistry._mergeRanges(joinedRanges, joinerRanges[j]);\n }\n }\n this._stringRangesToCellRanges(joinedRanges, lineData, startCol);\n return joinedRanges;\n }\n\n /**\n * Modifies the provided ranges in-place to adjust for variations between\n * string length and cell width so that the range represents a cell range,\n * rather than the string range the joiner provides.\n * @param ranges String ranges containing start (inclusive) and end (exclusive) index\n * @param line Cell data for the relevant line in the terminal\n * @param startCol Offset within the line to start from\n */\n private _stringRangesToCellRanges(ranges: [number, number][], line: IBufferLine, startCol: number): void {\n let currentRangeIndex = 0;\n let currentRangeStarted = false;\n let currentStringIndex = 0;\n let currentRange = ranges[currentRangeIndex];\n\n // If we got through all of the ranges, stop searching\n if (!currentRange) {\n return;\n }\n\n for (let x = startCol; x < this._bufferService.cols; x++) {\n const width = line.getWidth(x);\n const length = line.getString(x).length || WHITESPACE_CELL_CHAR.length;\n\n // We skip zero-width characters when creating the string to join the text\n // so we do the same here\n if (width === 0) {\n continue;\n }\n\n // Adjust the start of the range\n if (!currentRangeStarted && currentRange[0] <= currentStringIndex) {\n currentRange[0] = x;\n currentRangeStarted = true;\n }\n\n // Adjust the end of the range\n if (currentRange[1] <= currentStringIndex) {\n currentRange[1] = x;\n\n // We're finished with this range, so we move to the next one\n currentRange = ranges[++currentRangeIndex];\n\n // If there are no more ranges left, stop searching\n if (!currentRange) {\n break;\n }\n\n // Ranges can be on adjacent characters. Because the end index of the\n // ranges are exclusive, this means that the index for the start of a\n // range can be the same as the end index of the previous range. To\n // account for the start of the next range, we check here just in case.\n if (currentRange[0] <= currentStringIndex) {\n currentRange[0] = x;\n currentRangeStarted = true;\n } else {\n currentRangeStarted = false;\n }\n }\n\n // Adjust the string index based on the character length to line up with\n // the column adjustment\n currentStringIndex += length;\n }\n\n // If there is still a range left at the end, it must extend all the way to\n // the end of the line.\n if (currentRange) {\n currentRange[1] = this._bufferService.cols;\n }\n }\n\n /**\n * Merges the range defined by the provided start and end into the list of\n * existing ranges. The merge is done in place on the existing range for\n * performance and is also returned.\n * @param ranges Existing range list\n * @param newRange Tuple of two numbers representing the new range to merge in.\n * @returns The ranges input with the new range merged in place\n */\n private static _mergeRanges(ranges: [number, number][], newRange: [number, number]): [number, number][] {\n let inRange = false;\n for (let i = 0; i < ranges.length; i++) {\n const range = ranges[i];\n if (!inRange) {\n if (newRange[1] <= range[0]) {\n // Case 1: New range is before the search range\n ranges.splice(i, 0, newRange);\n return ranges;\n }\n\n if (newRange[1] <= range[1]) {\n // Case 2: New range is either wholly contained within the\n // search range or overlaps with the front of it\n range[0] = Math.min(newRange[0], range[0]);\n return ranges;\n }\n\n if (newRange[0] < range[1]) {\n // Case 3: New range either wholly contains the search range\n // or overlaps with the end of it\n range[0] = Math.min(newRange[0], range[0]);\n inRange = true;\n }\n\n // Case 4: New range starts after the search range\n continue;\n } else {\n if (newRange[1] <= range[0]) {\n // Case 5: New range extends from previous range but doesn't\n // reach the current one\n ranges[i - 1][1] = newRange[1];\n return ranges;\n }\n\n if (newRange[1] <= range[1]) {\n // Case 6: New range extends from prvious range into the\n // current range\n ranges[i - 1][1] = Math.max(newRange[1], range[1]);\n ranges.splice(i, 1);\n return ranges;\n }\n\n // Case 7: New range extends from previous range past the\n // end of the current range\n ranges.splice(i, 1);\n i--;\n }\n }\n\n if (inRange) {\n // Case 8: New range extends past the last existing range\n ranges[ranges.length - 1][1] = newRange[1];\n } else {\n // Case 9: New range starts after the last existing range\n ranges.push(newRange);\n }\n\n return ranges;\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IRenderDimensions, IRequestRedrawEvent } from 'browser/renderer/Types';\nimport { BaseRenderLayer } from 'browser/renderer/BaseRenderLayer';\nimport { ICellData } from 'common/Types';\nimport { CellData } from 'common/buffer/CellData';\nimport { IColorSet } from 'browser/Types';\nimport { IBufferService, IOptionsService, ICoreService } from 'common/services/Services';\nimport { IEventEmitter } from 'common/EventEmitter';\nimport { ICoreBrowserService } from 'browser/services/Services';\n\ninterface ICursorState {\n x: number;\n y: number;\n isFocused: boolean;\n style: string;\n width: number;\n}\n\n/**\n * The time between cursor blinks.\n */\nconst BLINK_INTERVAL = 600;\n\nexport class CursorRenderLayer extends BaseRenderLayer {\n private _state: ICursorState;\n private _cursorRenderers: {[key: string]: (x: number, y: number, cell: ICellData) => void};\n private _cursorBlinkStateManager: CursorBlinkStateManager | undefined;\n private _cell: ICellData = new CellData();\n\n constructor(\n container: HTMLElement,\n zIndex: number,\n colors: IColorSet,\n rendererId: number,\n private _onRequestRedraw: IEventEmitter,\n bufferService: IBufferService,\n optionsService: IOptionsService,\n private readonly _coreService: ICoreService,\n private readonly _coreBrowserService: ICoreBrowserService\n ) {\n super(container, 'cursor', zIndex, true, colors, rendererId, bufferService, optionsService);\n this._state = {\n x: 0,\n y: 0,\n isFocused: false,\n style: '',\n width: 0\n };\n this._cursorRenderers = {\n 'bar': this._renderBarCursor.bind(this),\n 'block': this._renderBlockCursor.bind(this),\n 'underline': this._renderUnderlineCursor.bind(this)\n };\n // TODO: Consider initial options? Maybe onOptionsChanged should be called at the end of open?\n }\n\n public resize(dim: IRenderDimensions): void {\n super.resize(dim);\n // Resizing the canvas discards the contents of the canvas so clear state\n this._state = {\n x: 0,\n y: 0,\n isFocused: false,\n style: '',\n width: 0\n };\n }\n\n public reset(): void {\n this._clearCursor();\n if (this._cursorBlinkStateManager) {\n this._cursorBlinkStateManager.dispose();\n this._cursorBlinkStateManager = undefined;\n this.onOptionsChanged();\n }\n }\n\n public onBlur(): void {\n if (this._cursorBlinkStateManager) {\n this._cursorBlinkStateManager.pause();\n }\n this._onRequestRedraw.fire({ start: this._bufferService.buffer.y, end: this._bufferService.buffer.y });\n }\n\n public onFocus(): void {\n if (this._cursorBlinkStateManager) {\n this._cursorBlinkStateManager.resume();\n } else {\n this._onRequestRedraw.fire({ start: this._bufferService.buffer.y, end: this._bufferService.buffer.y });\n }\n }\n\n public onOptionsChanged(): void {\n if (this._optionsService.options.cursorBlink) {\n if (!this._cursorBlinkStateManager) {\n this._cursorBlinkStateManager = new CursorBlinkStateManager(this._coreBrowserService.isFocused, () => {\n this._render(true);\n });\n }\n } else {\n this._cursorBlinkStateManager?.dispose();\n this._cursorBlinkStateManager = undefined;\n }\n // Request a refresh from the terminal as management of rendering is being\n // moved back to the terminal\n this._onRequestRedraw.fire({ start: this._bufferService.buffer.y, end: this._bufferService.buffer.y });\n }\n\n public onCursorMove(): void {\n if (this._cursorBlinkStateManager) {\n this._cursorBlinkStateManager.restartBlinkAnimation();\n }\n }\n\n public onGridChanged(startRow: number, endRow: number): void {\n if (!this._cursorBlinkStateManager || this._cursorBlinkStateManager.isPaused) {\n this._render(false);\n } else {\n this._cursorBlinkStateManager.restartBlinkAnimation();\n }\n }\n\n private _render(triggeredByAnimationFrame: boolean): void {\n // Don't draw the cursor if it's hidden\n if (!this._coreService.isCursorInitialized || this._coreService.isCursorHidden) {\n this._clearCursor();\n return;\n }\n\n const cursorY = this._bufferService.buffer.ybase + this._bufferService.buffer.y;\n const viewportRelativeCursorY = cursorY - this._bufferService.buffer.ydisp;\n\n // Don't draw the cursor if it's off-screen\n if (viewportRelativeCursorY < 0 || viewportRelativeCursorY >= this._bufferService.rows) {\n this._clearCursor();\n return;\n }\n\n // in case cursor.x == cols adjust visual cursor to cols - 1\n const cursorX = Math.min(this._bufferService.buffer.x, this._bufferService.cols - 1);\n this._bufferService.buffer.lines.get(cursorY)!.loadCell(cursorX, this._cell);\n if (this._cell.content === undefined) {\n return;\n }\n\n if (!this._coreBrowserService.isFocused) {\n this._clearCursor();\n this._ctx.save();\n this._ctx.fillStyle = this._colors.cursor.css;\n const cursorStyle = this._optionsService.options.cursorStyle;\n if (cursorStyle && cursorStyle !== 'block') {\n this._cursorRenderers[cursorStyle](cursorX, viewportRelativeCursorY, this._cell);\n } else {\n this._renderBlurCursor(cursorX, viewportRelativeCursorY, this._cell);\n }\n this._ctx.restore();\n this._state.x = cursorX;\n this._state.y = viewportRelativeCursorY;\n this._state.isFocused = false;\n this._state.style = cursorStyle;\n this._state.width = this._cell.getWidth();\n return;\n }\n\n // Don't draw the cursor if it's blinking\n if (this._cursorBlinkStateManager && !this._cursorBlinkStateManager.isCursorVisible) {\n this._clearCursor();\n return;\n }\n\n if (this._state) {\n // The cursor is already in the correct spot, don't redraw\n if (this._state.x === cursorX &&\n this._state.y === viewportRelativeCursorY &&\n this._state.isFocused === this._coreBrowserService.isFocused &&\n this._state.style === this._optionsService.options.cursorStyle &&\n this._state.width === this._cell.getWidth()) {\n return;\n }\n this._clearCursor();\n }\n\n this._ctx.save();\n this._cursorRenderers[this._optionsService.options.cursorStyle || 'block'](cursorX, viewportRelativeCursorY, this._cell);\n this._ctx.restore();\n\n this._state.x = cursorX;\n this._state.y = viewportRelativeCursorY;\n this._state.isFocused = false;\n this._state.style = this._optionsService.options.cursorStyle;\n this._state.width = this._cell.getWidth();\n }\n\n private _clearCursor(): void {\n if (this._state) {\n this._clearCells(this._state.x, this._state.y, this._state.width, 1);\n this._state = {\n x: 0,\n y: 0,\n isFocused: false,\n style: '',\n width: 0\n };\n }\n }\n\n private _renderBarCursor(x: number, y: number, cell: ICellData): void {\n this._ctx.save();\n this._ctx.fillStyle = this._colors.cursor.css;\n this._fillLeftLineAtCell(x, y, this._optionsService.options.cursorWidth);\n this._ctx.restore();\n }\n\n private _renderBlockCursor(x: number, y: number, cell: ICellData): void {\n this._ctx.save();\n this._ctx.fillStyle = this._colors.cursor.css;\n this._fillCells(x, y, cell.getWidth(), 1);\n this._ctx.fillStyle = this._colors.cursorAccent.css;\n this._fillCharTrueColor(cell, x, y);\n this._ctx.restore();\n }\n\n private _renderUnderlineCursor(x: number, y: number, cell: ICellData): void {\n this._ctx.save();\n this._ctx.fillStyle = this._colors.cursor.css;\n this._fillBottomLineAtCells(x, y);\n this._ctx.restore();\n }\n\n private _renderBlurCursor(x: number, y: number, cell: ICellData): void {\n this._ctx.save();\n this._ctx.strokeStyle = this._colors.cursor.css;\n this._strokeRectAtCell(x, y, cell.getWidth(), 1);\n this._ctx.restore();\n }\n}\n\nclass CursorBlinkStateManager {\n public isCursorVisible: boolean;\n\n private _animationFrame: number | undefined;\n private _blinkStartTimeout: number | undefined;\n private _blinkInterval: number | undefined;\n\n /**\n * The time at which the animation frame was restarted, this is used on the\n * next render to restart the timers so they don't need to restart the timers\n * multiple times over a short period.\n */\n private _animationTimeRestarted: number | undefined;\n\n constructor(\n isFocused: boolean,\n private _renderCallback: () => void\n ) {\n this.isCursorVisible = true;\n if (isFocused) {\n this._restartInterval();\n }\n }\n\n public get isPaused(): boolean { return !(this._blinkStartTimeout || this._blinkInterval); }\n\n public dispose(): void {\n if (this._blinkInterval) {\n window.clearInterval(this._blinkInterval);\n this._blinkInterval = undefined;\n }\n if (this._blinkStartTimeout) {\n window.clearTimeout(this._blinkStartTimeout);\n this._blinkStartTimeout = undefined;\n }\n if (this._animationFrame) {\n window.cancelAnimationFrame(this._animationFrame);\n this._animationFrame = undefined;\n }\n }\n\n public restartBlinkAnimation(): void {\n if (this.isPaused) {\n return;\n }\n // Save a timestamp so that the restart can be done on the next interval\n this._animationTimeRestarted = Date.now();\n // Force a cursor render to ensure it's visible and in the correct position\n this.isCursorVisible = true;\n if (!this._animationFrame) {\n this._animationFrame = window.requestAnimationFrame(() => {\n this._renderCallback();\n this._animationFrame = undefined;\n });\n }\n }\n\n private _restartInterval(timeToStart: number = BLINK_INTERVAL): void {\n // Clear any existing interval\n if (this._blinkInterval) {\n window.clearInterval(this._blinkInterval);\n }\n\n // Setup the initial timeout which will hide the cursor, this is done before\n // the regular interval is setup in order to support restarting the blink\n // animation in a lightweight way (without thrashing clearInterval and\n // setInterval).\n this._blinkStartTimeout = window.setTimeout(() => {\n // Check if another animation restart was requested while this was being\n // started\n if (this._animationTimeRestarted) {\n const time = BLINK_INTERVAL - (Date.now() - this._animationTimeRestarted);\n this._animationTimeRestarted = undefined;\n if (time > 0) {\n this._restartInterval(time);\n return;\n }\n }\n\n // Hide the cursor\n this.isCursorVisible = false;\n this._animationFrame = window.requestAnimationFrame(() => {\n this._renderCallback();\n this._animationFrame = undefined;\n });\n\n // Setup the blink interval\n this._blinkInterval = window.setInterval(() => {\n // Adjust the animation time if it was restarted\n if (this._animationTimeRestarted) {\n // calc time diff\n // Make restart interval do a setTimeout initially?\n const time = BLINK_INTERVAL - (Date.now() - this._animationTimeRestarted);\n this._animationTimeRestarted = undefined;\n this._restartInterval(time);\n return;\n }\n\n // Invert visibility and render\n this.isCursorVisible = !this.isCursorVisible;\n this._animationFrame = window.requestAnimationFrame(() => {\n this._renderCallback();\n this._animationFrame = undefined;\n });\n }, BLINK_INTERVAL);\n }, timeToStart);\n }\n\n public pause(): void {\n this.isCursorVisible = true;\n if (this._blinkInterval) {\n window.clearInterval(this._blinkInterval);\n this._blinkInterval = undefined;\n }\n if (this._blinkStartTimeout) {\n window.clearTimeout(this._blinkStartTimeout);\n this._blinkStartTimeout = undefined;\n }\n if (this._animationFrame) {\n window.cancelAnimationFrame(this._animationFrame);\n this._animationFrame = undefined;\n }\n }\n\n public resume(): void {\n // Clear out any existing timers just in case\n this.pause();\n\n this._animationTimeRestarted = undefined;\n this._restartInterval();\n this.restartBlinkAnimation();\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nexport class GridCache {\n public cache: (T | undefined)[][];\n\n public constructor() {\n this.cache = [];\n }\n\n public resize(width: number, height: number): void {\n for (let x = 0; x < width; x++) {\n if (this.cache.length <= x) {\n this.cache.push([]);\n }\n for (let y = this.cache[x].length; y < height; y++) {\n this.cache[x].push(undefined);\n }\n this.cache[x].length = height;\n }\n this.cache.length = width;\n }\n\n public clear(): void {\n for (let x = 0; x < this.cache.length; x++) {\n for (let y = 0; y < this.cache[x].length; y++) {\n this.cache[x][y] = undefined;\n }\n }\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IRenderDimensions } from 'browser/renderer/Types';\nimport { BaseRenderLayer } from './BaseRenderLayer';\nimport { INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants';\nimport { is256Color } from 'browser/renderer/atlas/CharAtlasUtils';\nimport { IColorSet, ILinkifierEvent, ILinkifier, ILinkifier2 } from 'browser/Types';\nimport { IBufferService, IOptionsService } from 'common/services/Services';\n\nexport class LinkRenderLayer extends BaseRenderLayer {\n private _state: ILinkifierEvent | undefined;\n\n constructor(\n container: HTMLElement,\n zIndex: number,\n colors: IColorSet,\n rendererId: number,\n linkifier: ILinkifier,\n linkifier2: ILinkifier2,\n bufferService: IBufferService,\n optionsService: IOptionsService\n ) {\n super(container, 'link', zIndex, true, colors, rendererId, bufferService, optionsService);\n linkifier.onShowLinkUnderline(e => this._onShowLinkUnderline(e));\n linkifier.onHideLinkUnderline(e => this._onHideLinkUnderline(e));\n\n linkifier2.onShowLinkUnderline(e => this._onShowLinkUnderline(e));\n linkifier2.onHideLinkUnderline(e => this._onHideLinkUnderline(e));\n }\n\n public resize(dim: IRenderDimensions): void {\n super.resize(dim);\n // Resizing the canvas discards the contents of the canvas so clear state\n this._state = undefined;\n }\n\n public reset(): void {\n this._clearCurrentLink();\n }\n\n private _clearCurrentLink(): void {\n if (this._state) {\n this._clearCells(this._state.x1, this._state.y1, this._state.cols - this._state.x1, 1);\n const middleRowCount = this._state.y2 - this._state.y1 - 1;\n if (middleRowCount > 0) {\n this._clearCells(0, this._state.y1 + 1, this._state.cols, middleRowCount);\n }\n this._clearCells(0, this._state.y2, this._state.x2, 1);\n this._state = undefined;\n }\n }\n\n private _onShowLinkUnderline(e: ILinkifierEvent): void {\n if (e.fg === INVERTED_DEFAULT_COLOR) {\n this._ctx.fillStyle = this._colors.background.css;\n } else if (e.fg && is256Color(e.fg)) {\n // 256 color support\n this._ctx.fillStyle = this._colors.ansi[e.fg].css;\n } else {\n this._ctx.fillStyle = this._colors.foreground.css;\n }\n\n if (e.y1 === e.y2) {\n // Single line link\n this._fillBottomLineAtCells(e.x1, e.y1, e.x2 - e.x1);\n } else {\n // Multi-line link\n this._fillBottomLineAtCells(e.x1, e.y1, e.cols - e.x1);\n for (let y = e.y1 + 1; y < e.y2; y++) {\n this._fillBottomLineAtCells(0, y, e.cols);\n }\n this._fillBottomLineAtCells(0, e.y2, e.x2);\n }\n this._state = e;\n }\n\n private _onHideLinkUnderline(e: ILinkifierEvent): void {\n this._clearCurrentLink();\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { TextRenderLayer } from 'browser/renderer/TextRenderLayer';\nimport { SelectionRenderLayer } from 'browser/renderer/SelectionRenderLayer';\nimport { CursorRenderLayer } from 'browser/renderer/CursorRenderLayer';\nimport { IRenderLayer, IRenderer, IRenderDimensions, CharacterJoinerHandler, ICharacterJoinerRegistry, IRequestRedrawEvent } from 'browser/renderer/Types';\nimport { LinkRenderLayer } from 'browser/renderer/LinkRenderLayer';\nimport { CharacterJoinerRegistry } from 'browser/renderer/CharacterJoinerRegistry';\nimport { Disposable } from 'common/Lifecycle';\nimport { IColorSet, ILinkifier, ILinkifier2 } from 'browser/Types';\nimport { ICharSizeService, ICoreBrowserService } from 'browser/services/Services';\nimport { IBufferService, IOptionsService, ICoreService } from 'common/services/Services';\nimport { removeTerminalFromCache } from 'browser/renderer/atlas/CharAtlasCache';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\n\nlet nextRendererId = 1;\n\nexport class Renderer extends Disposable implements IRenderer {\n private _id = nextRendererId++;\n\n private _renderLayers: IRenderLayer[];\n private _devicePixelRatio: number;\n private _characterJoinerRegistry: ICharacterJoinerRegistry;\n\n public dimensions: IRenderDimensions;\n\n private _onRequestRedraw = new EventEmitter();\n public get onRequestRedraw(): IEvent { return this._onRequestRedraw.event; }\n\n constructor(\n private _colors: IColorSet,\n private readonly _screenElement: HTMLElement,\n linkifier: ILinkifier,\n linkifier2: ILinkifier2,\n @IBufferService private readonly _bufferService: IBufferService,\n @ICharSizeService private readonly _charSizeService: ICharSizeService,\n @IOptionsService private readonly _optionsService: IOptionsService,\n @ICoreService coreService: ICoreService,\n @ICoreBrowserService coreBrowserService: ICoreBrowserService\n ) {\n super();\n const allowTransparency = this._optionsService.options.allowTransparency;\n this._characterJoinerRegistry = new CharacterJoinerRegistry(this._bufferService);\n this._renderLayers = [\n new TextRenderLayer(this._screenElement, 0, this._colors, this._characterJoinerRegistry, allowTransparency, this._id, this._bufferService, _optionsService),\n new SelectionRenderLayer(this._screenElement, 1, this._colors, this._id, this._bufferService, _optionsService),\n new LinkRenderLayer(this._screenElement, 2, this._colors, this._id, linkifier, linkifier2, this._bufferService, _optionsService),\n new CursorRenderLayer(this._screenElement, 3, this._colors, this._id, this._onRequestRedraw, this._bufferService, _optionsService, coreService, coreBrowserService)\n ];\n this.dimensions = {\n scaledCharWidth: 0,\n scaledCharHeight: 0,\n scaledCellWidth: 0,\n scaledCellHeight: 0,\n scaledCharLeft: 0,\n scaledCharTop: 0,\n scaledCanvasWidth: 0,\n scaledCanvasHeight: 0,\n canvasWidth: 0,\n canvasHeight: 0,\n actualCellWidth: 0,\n actualCellHeight: 0\n };\n this._devicePixelRatio = window.devicePixelRatio;\n this._updateDimensions();\n this.onOptionsChanged();\n }\n\n public dispose(): void {\n for (const l of this._renderLayers) {\n l.dispose();\n }\n super.dispose();\n removeTerminalFromCache(this._id);\n }\n\n public onDevicePixelRatioChange(): void {\n // If the device pixel ratio changed, the char atlas needs to be regenerated\n // and the terminal needs to refreshed\n if (this._devicePixelRatio !== window.devicePixelRatio) {\n this._devicePixelRatio = window.devicePixelRatio;\n this.onResize(this._bufferService.cols, this._bufferService.rows);\n }\n }\n\n public setColors(colors: IColorSet): void {\n this._colors = colors;\n // Clear layers and force a full render\n for (const l of this._renderLayers) {\n l.setColors(this._colors);\n l.reset();\n }\n }\n\n public onResize(cols: number, rows: number): void {\n // Update character and canvas dimensions\n this._updateDimensions();\n\n // Resize all render layers\n for (const l of this._renderLayers) {\n l.resize(this.dimensions);\n }\n\n // Resize the screen\n this._screenElement.style.width = `${this.dimensions.canvasWidth}px`;\n this._screenElement.style.height = `${this.dimensions.canvasHeight}px`;\n }\n\n public onCharSizeChanged(): void {\n this.onResize(this._bufferService.cols, this._bufferService.rows);\n }\n\n public onBlur(): void {\n this._runOperation(l => l.onBlur());\n }\n\n public onFocus(): void {\n this._runOperation(l => l.onFocus());\n }\n\n public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean = false): void {\n this._runOperation(l => l.onSelectionChanged(start, end, columnSelectMode));\n }\n\n public onCursorMove(): void {\n this._runOperation(l => l.onCursorMove());\n }\n\n public onOptionsChanged(): void {\n this._runOperation(l => l.onOptionsChanged());\n }\n\n public clear(): void {\n this._runOperation(l => l.reset());\n }\n\n private _runOperation(operation: (layer: IRenderLayer) => void): void {\n for (const l of this._renderLayers) {\n operation(l);\n }\n }\n\n /**\n * Performs the refresh loop callback, calling refresh only if a refresh is\n * necessary before queueing up the next one.\n */\n public renderRows(start: number, end: number): void {\n for (const l of this._renderLayers) {\n l.onGridChanged(start, end);\n }\n }\n\n /**\n * Recalculates the character and canvas dimensions.\n */\n private _updateDimensions(): void {\n if (!this._charSizeService.hasValidSize) {\n return;\n }\n\n // Calculate the scaled character width. Width is floored as it must be\n // drawn to an integer grid in order for the CharAtlas \"stamps\" to not be\n // blurry. When text is drawn to the grid not using the CharAtlas, it is\n // clipped to ensure there is no overlap with the next cell.\n this.dimensions.scaledCharWidth = Math.floor(this._charSizeService.width * window.devicePixelRatio);\n\n // Calculate the scaled character height. Height is ceiled in case\n // devicePixelRatio is a floating point number in order to ensure there is\n // enough space to draw the character to the cell.\n this.dimensions.scaledCharHeight = Math.ceil(this._charSizeService.height * window.devicePixelRatio);\n\n // Calculate the scaled cell height, if lineHeight is not 1 then the value\n // will be floored because since lineHeight can never be lower then 1, there\n // is a guarentee that the scaled line height will always be larger than\n // scaled char height.\n this.dimensions.scaledCellHeight = Math.floor(this.dimensions.scaledCharHeight * this._optionsService.options.lineHeight);\n\n // Calculate the y coordinate within a cell that text should draw from in\n // order to draw in the center of a cell.\n this.dimensions.scaledCharTop = this._optionsService.options.lineHeight === 1 ? 0 : Math.round((this.dimensions.scaledCellHeight - this.dimensions.scaledCharHeight) / 2);\n\n // Calculate the scaled cell width, taking the letterSpacing into account.\n this.dimensions.scaledCellWidth = this.dimensions.scaledCharWidth + Math.round(this._optionsService.options.letterSpacing);\n\n // Calculate the x coordinate with a cell that text should draw from in\n // order to draw in the center of a cell.\n this.dimensions.scaledCharLeft = Math.floor(this._optionsService.options.letterSpacing / 2);\n\n // Recalculate the canvas dimensions; scaled* define the actual number of\n // pixel in the canvas\n this.dimensions.scaledCanvasHeight = this._bufferService.rows * this.dimensions.scaledCellHeight;\n this.dimensions.scaledCanvasWidth = this._bufferService.cols * this.dimensions.scaledCellWidth;\n\n // The the size of the canvas on the page. It's very important that this\n // rounds to nearest integer and not ceils as browsers often set\n // window.devicePixelRatio as something like 1.100000023841858, when it's\n // actually 1.1. Ceiling causes blurriness as the backing canvas image is 1\n // pixel too large for the canvas element size.\n this.dimensions.canvasHeight = Math.round(this.dimensions.scaledCanvasHeight / window.devicePixelRatio);\n this.dimensions.canvasWidth = Math.round(this.dimensions.scaledCanvasWidth / window.devicePixelRatio);\n\n // Get the _actual_ dimensions of an individual cell. This needs to be\n // derived from the canvasWidth/Height calculated above which takes into\n // account window.devicePixelRatio. ICharSizeService.width/height by itself\n // is insufficient when the page is not at 100% zoom level as it's measured\n // in CSS pixels, but the actual char size on the canvas can differ.\n this.dimensions.actualCellHeight = this.dimensions.canvasHeight / this._bufferService.rows;\n this.dimensions.actualCellWidth = this.dimensions.canvasWidth / this._bufferService.cols;\n }\n\n public registerCharacterJoiner(handler: CharacterJoinerHandler): number {\n return this._characterJoinerRegistry.registerCharacterJoiner(handler);\n }\n\n public deregisterCharacterJoiner(joinerId: number): boolean {\n return this._characterJoinerRegistry.deregisterCharacterJoiner(joinerId);\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nexport function throwIfFalsy(value: T | undefined | null): T {\n if (!value) {\n throw new Error('value must not be falsy');\n }\n return value;\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IRenderDimensions } from 'browser/renderer/Types';\nimport { BaseRenderLayer } from 'browser/renderer/BaseRenderLayer';\nimport { IColorSet } from 'browser/Types';\nimport { IBufferService, IOptionsService } from 'common/services/Services';\n\ninterface ISelectionState {\n start?: [number, number];\n end?: [number, number];\n columnSelectMode?: boolean;\n ydisp?: number;\n}\n\nexport class SelectionRenderLayer extends BaseRenderLayer {\n private _state!: ISelectionState;\n\n constructor(\n container: HTMLElement,\n zIndex: number,\n colors: IColorSet,\n rendererId: number,\n bufferService: IBufferService,\n optionsService: IOptionsService\n ) {\n super(container, 'selection', zIndex, true, colors, rendererId, bufferService, optionsService);\n this._clearState();\n }\n\n private _clearState(): void {\n this._state = {\n start: undefined,\n end: undefined,\n columnSelectMode: undefined,\n ydisp: undefined\n };\n }\n\n public resize(dim: IRenderDimensions): void {\n super.resize(dim);\n // Resizing the canvas discards the contents of the canvas so clear state\n this._clearState();\n }\n\n public reset(): void {\n if (this._state.start && this._state.end) {\n this._clearState();\n this._clearAll();\n }\n }\n\n public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void {\n // Selection has not changed\n if (!this._didStateChange(start, end, columnSelectMode, this._bufferService.buffer.ydisp)) {\n return;\n }\n\n // Remove all selections\n this._clearAll();\n\n // Selection does not exist\n if (!start || !end) {\n this._clearState();\n return;\n }\n\n // Translate from buffer position to viewport position\n const viewportStartRow = start[1] - this._bufferService.buffer.ydisp;\n const viewportEndRow = end[1] - this._bufferService.buffer.ydisp;\n const viewportCappedStartRow = Math.max(viewportStartRow, 0);\n const viewportCappedEndRow = Math.min(viewportEndRow, this._bufferService.rows - 1);\n\n // No need to draw the selection\n if (viewportCappedStartRow >= this._bufferService.rows || viewportCappedEndRow < 0) {\n this._state.ydisp = this._bufferService.buffer.ydisp;\n return;\n }\n\n this._ctx.fillStyle = this._colors.selectionTransparent.css;\n\n if (columnSelectMode) {\n const startCol = start[0];\n const width = end[0] - startCol;\n const height = viewportCappedEndRow - viewportCappedStartRow + 1;\n this._fillCells(startCol, viewportCappedStartRow, width, height);\n } else {\n // Draw first row\n const startCol = viewportStartRow === viewportCappedStartRow ? start[0] : 0;\n const startRowEndCol = viewportCappedStartRow === viewportEndRow ? end[0] : this._bufferService.cols;\n this._fillCells(startCol, viewportCappedStartRow, startRowEndCol - startCol, 1);\n\n // Draw middle rows\n const middleRowsCount = Math.max(viewportCappedEndRow - viewportCappedStartRow - 1, 0);\n this._fillCells(0, viewportCappedStartRow + 1, this._bufferService.cols, middleRowsCount);\n\n // Draw final row\n if (viewportCappedStartRow !== viewportCappedEndRow) {\n // Only draw viewportEndRow if it's not the same as viewportStartRow\n const endCol = viewportEndRow === viewportCappedEndRow ? end[0] : this._bufferService.cols;\n this._fillCells(0, viewportCappedEndRow, endCol, 1);\n }\n }\n\n // Save state for next render\n this._state.start = [start[0], start[1]];\n this._state.end = [end[0], end[1]];\n this._state.columnSelectMode = columnSelectMode;\n this._state.ydisp = this._bufferService.buffer.ydisp;\n }\n\n private _didStateChange(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean, ydisp: number): boolean {\n return !this._areCoordinatesEqual(start, this._state.start) ||\n !this._areCoordinatesEqual(end, this._state.end) ||\n columnSelectMode !== this._state.columnSelectMode ||\n ydisp !== this._state.ydisp;\n }\n\n private _areCoordinatesEqual(coord1: [number, number] | undefined, coord2: [number, number] | undefined): boolean {\n if (!coord1 || !coord2) {\n return false;\n }\n\n return coord1[0] === coord2[0] && coord1[1] === coord2[1];\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ICharacterJoinerRegistry, IRenderDimensions } from 'browser/renderer/Types';\nimport { CharData, ICellData } from 'common/Types';\nimport { GridCache } from 'browser/renderer/GridCache';\nimport { BaseRenderLayer } from 'browser/renderer/BaseRenderLayer';\nimport { AttributeData } from 'common/buffer/AttributeData';\nimport { NULL_CELL_CODE, Content } from 'common/buffer/Constants';\nimport { JoinedCellData } from 'browser/renderer/CharacterJoinerRegistry';\nimport { IColorSet } from 'browser/Types';\nimport { CellData } from 'common/buffer/CellData';\nimport { IOptionsService, IBufferService } from 'common/services/Services';\n\n/**\n * This CharData looks like a null character, which will forc a clear and render\n * when the character changes (a regular space ' ' character may not as it's\n * drawn state is a cleared cell).\n */\n// const OVERLAP_OWNED_CHAR_DATA: CharData = [null, '', 0, -1];\n\nexport class TextRenderLayer extends BaseRenderLayer {\n private _state: GridCache;\n private _characterWidth: number = 0;\n private _characterFont: string = '';\n private _characterOverlapCache: { [key: string]: boolean } = {};\n private _characterJoinerRegistry: ICharacterJoinerRegistry;\n private _workCell = new CellData();\n\n constructor(\n container: HTMLElement,\n zIndex: number,\n colors: IColorSet,\n characterJoinerRegistry: ICharacterJoinerRegistry,\n alpha: boolean,\n rendererId: number,\n bufferService: IBufferService,\n optionsService: IOptionsService\n ) {\n super(container, 'text', zIndex, alpha, colors, rendererId, bufferService, optionsService);\n this._state = new GridCache();\n this._characterJoinerRegistry = characterJoinerRegistry;\n }\n\n public resize(dim: IRenderDimensions): void {\n super.resize(dim);\n\n // Clear the character width cache if the font or width has changed\n const terminalFont = this._getFont(false, false);\n if (this._characterWidth !== dim.scaledCharWidth || this._characterFont !== terminalFont) {\n this._characterWidth = dim.scaledCharWidth;\n this._characterFont = terminalFont;\n this._characterOverlapCache = {};\n }\n // Resizing the canvas discards the contents of the canvas so clear state\n this._state.clear();\n this._state.resize(this._bufferService.cols, this._bufferService.rows);\n }\n\n public reset(): void {\n this._state.clear();\n this._clearAll();\n }\n\n private _forEachCell(\n firstRow: number,\n lastRow: number,\n joinerRegistry: ICharacterJoinerRegistry | null,\n callback: (\n cell: ICellData,\n x: number,\n y: number\n ) => void\n ): void {\n for (let y = firstRow; y <= lastRow; y++) {\n const row = y + this._bufferService.buffer.ydisp;\n const line = this._bufferService.buffer.lines.get(row);\n const joinedRanges = joinerRegistry ? joinerRegistry.getJoinedCharacters(row) : [];\n for (let x = 0; x < this._bufferService.cols; x++) {\n line!.loadCell(x, this._workCell);\n let cell = this._workCell;\n\n // If true, indicates that the current character(s) to draw were joined.\n let isJoined = false;\n let lastCharX = x;\n\n // The character to the left is a wide character, drawing is owned by\n // the char at x-1\n if (cell.getWidth() === 0) {\n continue;\n }\n\n // Process any joined character ranges as needed. Because of how the\n // ranges are produced, we know that they are valid for the characters\n // and attributes of our input.\n if (joinedRanges.length > 0 && x === joinedRanges[0][0]) {\n isJoined = true;\n const range = joinedRanges.shift()!;\n\n // We already know the exact start and end column of the joined range,\n // so we get the string and width representing it directly\n\n cell = new JoinedCellData(\n this._workCell,\n line!.translateToString(true, range[0], range[1]),\n range[1] - range[0]\n );\n\n // Skip over the cells occupied by this range in the loop\n lastCharX = range[1] - 1;\n }\n\n // If the character is an overlapping char and the character to the\n // right is a space, take ownership of the cell to the right. We skip\n // this check for joined characters because their rendering likely won't\n // yield the same result as rendering the last character individually.\n if (!isJoined && this._isOverlapping(cell)) {\n // If the character is overlapping, we want to force a re-render on every\n // frame. This is specifically to work around the case where two\n // overlaping chars `a` and `b` are adjacent, the cursor is moved to b and a\n // space is added. Without this, the first half of `b` would never\n // get removed, and `a` would not re-render because it thinks it's\n // already in the correct state.\n // this._state.cache[x][y] = OVERLAP_OWNED_CHAR_DATA;\n if (lastCharX < line!.length - 1 && line!.getCodePoint(lastCharX + 1) === NULL_CELL_CODE) {\n // patch width to 2\n cell.content &= ~Content.WIDTH_MASK;\n cell.content |= 2 << Content.WIDTH_SHIFT;\n // this._clearChar(x + 1, y);\n // The overlapping char's char data will force a clear and render when the\n // overlapping char is no longer to the left of the character and also when\n // the space changes to another character.\n // this._state.cache[x + 1][y] = OVERLAP_OWNED_CHAR_DATA;\n }\n }\n\n callback(\n cell,\n x,\n y\n );\n\n x = lastCharX;\n }\n }\n }\n\n /**\n * Draws the background for a specified range of columns. Tries to batch adjacent cells of the\n * same color together to reduce draw calls.\n */\n private _drawBackground(firstRow: number, lastRow: number): void {\n const ctx = this._ctx;\n const cols = this._bufferService.cols;\n let startX: number = 0;\n let startY: number = 0;\n let prevFillStyle: string | null = null;\n\n ctx.save();\n\n this._forEachCell(firstRow, lastRow, null, (cell, x, y) => {\n // libvte and xterm both draw the background (but not foreground) of invisible characters,\n // so we should too.\n let nextFillStyle = null; // null represents default background color\n\n if (cell.isInverse()) {\n if (cell.isFgDefault()) {\n nextFillStyle = this._colors.foreground.css;\n } else if (cell.isFgRGB()) {\n nextFillStyle = `rgb(${AttributeData.toColorRGB(cell.getFgColor()).join(',')})`;\n } else {\n nextFillStyle = this._colors.ansi[cell.getFgColor()].css;\n }\n } else if (cell.isBgRGB()) {\n nextFillStyle = `rgb(${AttributeData.toColorRGB(cell.getBgColor()).join(',')})`;\n } else if (cell.isBgPalette()) {\n nextFillStyle = this._colors.ansi[cell.getBgColor()].css;\n }\n\n if (prevFillStyle === null) {\n // This is either the first iteration, or the default background was set. Either way, we\n // don't need to draw anything.\n startX = x;\n startY = y;\n }\n\n if (y !== startY) {\n // our row changed, draw the previous row\n ctx.fillStyle = prevFillStyle || '';\n this._fillCells(startX, startY, cols - startX, 1);\n startX = x;\n startY = y;\n } else if (prevFillStyle !== nextFillStyle) {\n // our color changed, draw the previous characters in this row\n ctx.fillStyle = prevFillStyle || '';\n this._fillCells(startX, startY, x - startX, 1);\n startX = x;\n startY = y;\n }\n\n prevFillStyle = nextFillStyle;\n });\n\n // flush the last color we encountered\n if (prevFillStyle !== null) {\n ctx.fillStyle = prevFillStyle;\n this._fillCells(startX, startY, cols - startX, 1);\n }\n\n ctx.restore();\n }\n\n private _drawForeground(firstRow: number, lastRow: number): void {\n this._forEachCell(firstRow, lastRow, this._characterJoinerRegistry, (cell, x, y) => {\n if (cell.isInvisible()) {\n return;\n }\n this._drawChars(cell, x, y);\n if (cell.isUnderline()) {\n this._ctx.save();\n\n if (cell.isInverse()) {\n if (cell.isBgDefault()) {\n this._ctx.fillStyle = this._colors.background.css;\n } else if (cell.isBgRGB()) {\n this._ctx.fillStyle = `rgb(${AttributeData.toColorRGB(cell.getBgColor()).join(',')})`;\n } else {\n let bg = cell.getBgColor();\n if (this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && bg < 8) {\n bg += 8;\n }\n this._ctx.fillStyle = this._colors.ansi[bg].css;\n }\n } else {\n if (cell.isFgDefault()) {\n this._ctx.fillStyle = this._colors.foreground.css;\n } else if (cell.isFgRGB()) {\n this._ctx.fillStyle = `rgb(${AttributeData.toColorRGB(cell.getFgColor()).join(',')})`;\n } else {\n let fg = cell.getFgColor();\n if (this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && fg < 8) {\n fg += 8;\n }\n this._ctx.fillStyle = this._colors.ansi[fg].css;\n }\n }\n\n this._fillBottomLineAtCells(x, y, cell.getWidth());\n this._ctx.restore();\n }\n });\n }\n\n public onGridChanged(firstRow: number, lastRow: number): void {\n // Resize has not been called yet\n if (this._state.cache.length === 0) {\n return;\n }\n\n if (this._charAtlas) {\n this._charAtlas.beginFrame();\n }\n\n this._clearCells(0, firstRow, this._bufferService.cols, lastRow - firstRow + 1);\n this._drawBackground(firstRow, lastRow);\n this._drawForeground(firstRow, lastRow);\n }\n\n public onOptionsChanged(): void {\n this._setTransparency(this._optionsService.options.allowTransparency);\n }\n\n /**\n * Whether a character is overlapping to the next cell.\n */\n private _isOverlapping(cell: ICellData): boolean {\n // Only single cell characters can be overlapping, rendering issues can\n // occur without this check\n if (cell.getWidth() !== 1) {\n return false;\n }\n\n // We assume that any ascii character will not overlap\n if (cell.getCode() < 256) {\n return false;\n }\n\n const chars = cell.getChars();\n\n // Deliver from cache if available\n if (this._characterOverlapCache.hasOwnProperty(chars)) {\n return this._characterOverlapCache[chars];\n }\n\n // Setup the font\n this._ctx.save();\n this._ctx.font = this._characterFont;\n\n // Measure the width of the character, but Math.floor it\n // because that is what the renderer does when it calculates\n // the character dimensions we are comparing against\n const overlaps = Math.floor(this._ctx.measureText(chars).width) > this._characterWidth;\n\n // Restore the original context\n this._ctx.restore();\n\n // Cache and return\n this._characterOverlapCache[chars] = overlaps;\n return overlaps;\n }\n\n /**\n * Clear the charcater at the cell specified.\n * @param x The column of the char.\n * @param y The row of the char.\n */\n // private _clearChar(x: number, y: number): void {\n // let colsToClear = 1;\n // // Clear the adjacent character if it was wide\n // const state = this._state.cache[x][y];\n // if (state && state[CHAR_DATA_WIDTH_INDEX] === 2) {\n // colsToClear = 2;\n // }\n // this.clearCells(x, y, colsToClear, 1);\n // }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IGlyphIdentifier } from 'browser/renderer/atlas/Types';\nimport { IDisposable } from 'common/Types';\n\nexport abstract class BaseCharAtlas implements IDisposable {\n private _didWarmUp: boolean = false;\n\n public dispose(): void { }\n\n /**\n * Perform any work needed to warm the cache before it can be used. May be called multiple times.\n * Implement _doWarmUp instead if you only want to get called once.\n */\n public warmUp(): void {\n if (!this._didWarmUp) {\n this._doWarmUp();\n this._didWarmUp = true;\n }\n }\n\n /**\n * Perform any work needed to warm the cache before it can be used. Used by the default\n * implementation of warmUp(), and will only be called once.\n */\n private _doWarmUp(): void { }\n\n /**\n * Called when we start drawing a new frame.\n *\n * TODO: We rely on this getting called by TextRenderLayer. This should really be called by\n * Renderer instead, but we need to make Renderer the source-of-truth for the char atlas, instead\n * of BaseRenderLayer.\n */\n public beginFrame(): void { }\n\n /**\n * May be called before warmUp finishes, however it is okay for the implementation to\n * do nothing and return false in that case.\n *\n * @param ctx Where to draw the character onto.\n * @param glyph Information about what to draw\n * @param x The position on the context to start drawing at\n * @param y The position on the context to start drawing at\n * @returns The success state. True if we drew the character.\n */\n public abstract draw(\n ctx: CanvasRenderingContext2D,\n glyph: IGlyphIdentifier,\n x: number,\n y: number\n ): boolean;\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { generateConfig, configEquals } from 'browser/renderer/atlas/CharAtlasUtils';\nimport { BaseCharAtlas } from 'browser/renderer/atlas/BaseCharAtlas';\nimport { DynamicCharAtlas } from 'browser/renderer/atlas/DynamicCharAtlas';\nimport { ICharAtlasConfig } from 'browser/renderer/atlas/Types';\nimport { IColorSet } from 'browser/Types';\nimport { ITerminalOptions } from 'common/services/Services';\n\ninterface ICharAtlasCacheEntry {\n atlas: BaseCharAtlas;\n config: ICharAtlasConfig;\n // N.B. This implementation potentially holds onto copies of the terminal forever, so\n // this may cause memory leaks.\n ownedBy: number[];\n}\n\nconst charAtlasCache: ICharAtlasCacheEntry[] = [];\n\n/**\n * Acquires a char atlas, either generating a new one or returning an existing\n * one that is in use by another terminal.\n */\nexport function acquireCharAtlas(\n options: ITerminalOptions,\n rendererId: number,\n colors: IColorSet,\n scaledCharWidth: number,\n scaledCharHeight: number\n): BaseCharAtlas {\n const newConfig = generateConfig(scaledCharWidth, scaledCharHeight, options, colors);\n\n // Check to see if the renderer already owns this config\n for (let i = 0; i < charAtlasCache.length; i++) {\n const entry = charAtlasCache[i];\n const ownedByIndex = entry.ownedBy.indexOf(rendererId);\n if (ownedByIndex >= 0) {\n if (configEquals(entry.config, newConfig)) {\n return entry.atlas;\n }\n // The configs differ, release the renderer from the entry\n if (entry.ownedBy.length === 1) {\n entry.atlas.dispose();\n charAtlasCache.splice(i, 1);\n } else {\n entry.ownedBy.splice(ownedByIndex, 1);\n }\n break;\n }\n }\n\n // Try match a char atlas from the cache\n for (let i = 0; i < charAtlasCache.length; i++) {\n const entry = charAtlasCache[i];\n if (configEquals(entry.config, newConfig)) {\n // Add the renderer to the cache entry and return\n entry.ownedBy.push(rendererId);\n return entry.atlas;\n }\n }\n\n const newEntry: ICharAtlasCacheEntry = {\n atlas: new DynamicCharAtlas(\n document,\n newConfig\n ),\n config: newConfig,\n ownedBy: [rendererId]\n };\n charAtlasCache.push(newEntry);\n return newEntry.atlas;\n}\n\n/**\n * Removes a terminal reference from the cache, allowing its memory to be freed.\n */\nexport function removeTerminalFromCache(rendererId: number): void {\n for (let i = 0; i < charAtlasCache.length; i++) {\n const index = charAtlasCache[i].ownedBy.indexOf(rendererId);\n if (index !== -1) {\n if (charAtlasCache[i].ownedBy.length === 1) {\n // Remove the cache entry if it's the only renderer\n charAtlasCache[i].atlas.dispose();\n charAtlasCache.splice(i, 1);\n } else {\n // Remove the reference from the cache entry\n charAtlasCache[i].ownedBy.splice(index, 1);\n }\n break;\n }\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ICharAtlasConfig } from 'browser/renderer/atlas/Types';\nimport { DEFAULT_COLOR } from 'common/buffer/Constants';\nimport { IColorSet, IPartialColorSet } from 'browser/Types';\nimport { ITerminalOptions } from 'common/services/Services';\n\nexport function generateConfig(scaledCharWidth: number, scaledCharHeight: number, options: ITerminalOptions, colors: IColorSet): ICharAtlasConfig {\n // null out some fields that don't matter\n const clonedColors = {\n foreground: colors.foreground,\n background: colors.background,\n cursor: undefined,\n cursorAccent: undefined,\n selection: undefined,\n ansi: colors.ansi\n };\n return {\n devicePixelRatio: window.devicePixelRatio,\n scaledCharWidth,\n scaledCharHeight,\n fontFamily: options.fontFamily,\n fontSize: options.fontSize,\n fontWeight: options.fontWeight,\n fontWeightBold: options.fontWeightBold,\n allowTransparency: options.allowTransparency,\n colors: clonedColors\n };\n}\n\nexport function configEquals(a: ICharAtlasConfig, b: ICharAtlasConfig): boolean {\n for (let i = 0; i < a.colors.ansi.length; i++) {\n if (a.colors.ansi[i].rgba !== b.colors.ansi[i].rgba) {\n return false;\n }\n }\n return a.devicePixelRatio === b.devicePixelRatio &&\n a.fontFamily === b.fontFamily &&\n a.fontSize === b.fontSize &&\n a.fontWeight === b.fontWeight &&\n a.fontWeightBold === b.fontWeightBold &&\n a.allowTransparency === b.allowTransparency &&\n a.scaledCharWidth === b.scaledCharWidth &&\n a.scaledCharHeight === b.scaledCharHeight &&\n a.colors.foreground === b.colors.foreground &&\n a.colors.background === b.colors.background;\n}\n\nexport function is256Color(colorCode: number): boolean {\n return colorCode < DEFAULT_COLOR;\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nexport const INVERTED_DEFAULT_COLOR = 257;\nexport const DIM_OPACITY = 0.5;\n\nexport const CHAR_ATLAS_CELL_SPACING = 1;\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { DIM_OPACITY, INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants';\nimport { IGlyphIdentifier, ICharAtlasConfig } from 'browser/renderer/atlas/Types';\nimport { BaseCharAtlas } from 'browser/renderer/atlas/BaseCharAtlas';\nimport { DEFAULT_ANSI_COLORS } from 'browser/ColorManager';\nimport { LRUMap } from 'browser/renderer/atlas/LRUMap';\nimport { isFirefox, isSafari } from 'common/Platform';\nimport { IColor } from 'browser/Types';\nimport { throwIfFalsy } from 'browser/renderer/RendererUtils';\nimport { color } from 'browser/Color';\n\n// In practice we're probably never going to exhaust a texture this large. For debugging purposes,\n// however, it can be useful to set this to a really tiny value, to verify that LRU eviction works.\nconst TEXTURE_WIDTH = 1024;\nconst TEXTURE_HEIGHT = 1024;\n\nconst TRANSPARENT_COLOR = {\n css: 'rgba(0, 0, 0, 0)',\n rgba: 0\n};\n\n// Drawing to the cache is expensive: If we have to draw more than this number of glyphs to the\n// cache in a single frame, give up on trying to cache anything else, and try to finish the current\n// frame ASAP.\n//\n// This helps to limit the amount of damage a program can do when it would otherwise thrash the\n// cache.\nconst FRAME_CACHE_DRAW_LIMIT = 100;\n\n/**\n * The number of milliseconds to wait before generating the ImageBitmap, this is to debounce/batch\n * the operation as window.createImageBitmap is asynchronous.\n */\nconst GLYPH_BITMAP_COMMIT_DELAY = 100;\n\ninterface IGlyphCacheValue {\n index: number;\n isEmpty: boolean;\n inBitmap: boolean;\n}\n\nexport function getGlyphCacheKey(glyph: IGlyphIdentifier): number {\n // Note that this only returns a valid key when code < 256\n // Layout:\n // 0b00000000000000000000000000000001: italic (1)\n // 0b00000000000000000000000000000010: dim (1)\n // 0b00000000000000000000000000000100: bold (1)\n // 0b00000000000000000000111111111000: fg (9)\n // 0b00000000000111111111000000000000: bg (9)\n // 0b00011111111000000000000000000000: code (8)\n // 0b11100000000000000000000000000000: unused (3)\n return glyph.code << 21 | glyph.bg << 12 | glyph.fg << 3 | (glyph.bold ? 0 : 4) + (glyph.dim ? 0 : 2) + (glyph.italic ? 0 : 1);\n}\n\nexport class DynamicCharAtlas extends BaseCharAtlas {\n // An ordered map that we're using to keep track of where each glyph is in the atlas texture.\n // It's ordered so that we can determine when to remove the old entries.\n private _cacheMap: LRUMap;\n\n // The texture that the atlas is drawn to\n private _cacheCanvas: HTMLCanvasElement;\n private _cacheCtx: CanvasRenderingContext2D;\n\n // A temporary context that glyphs are drawn to before being transfered to the atlas.\n private _tmpCtx: CanvasRenderingContext2D;\n\n // The number of characters stored in the atlas by width/height\n private _width: number;\n private _height: number;\n\n private _drawToCacheCount: number = 0;\n\n // An array of glyph keys that are waiting on the bitmap to be generated.\n private _glyphsWaitingOnBitmap: IGlyphCacheValue[] = [];\n\n // The timeout that is used to batch bitmap generation so it's not requested for every new glyph.\n private _bitmapCommitTimeout: number | null = null;\n\n // The bitmap to draw from, this is much faster on other browsers than others.\n private _bitmap: ImageBitmap | null = null;\n\n constructor(document: Document, private _config: ICharAtlasConfig) {\n super();\n this._cacheCanvas = document.createElement('canvas');\n this._cacheCanvas.width = TEXTURE_WIDTH;\n this._cacheCanvas.height = TEXTURE_HEIGHT;\n // The canvas needs alpha because we use clearColor to convert the background color to alpha.\n // It might also contain some characters with transparent backgrounds if allowTransparency is\n // set.\n this._cacheCtx = throwIfFalsy(this._cacheCanvas.getContext('2d', {alpha: true}));\n\n const tmpCanvas = document.createElement('canvas');\n tmpCanvas.width = this._config.scaledCharWidth;\n tmpCanvas.height = this._config.scaledCharHeight;\n this._tmpCtx = throwIfFalsy(tmpCanvas.getContext('2d', {alpha: this._config.allowTransparency}));\n\n this._width = Math.floor(TEXTURE_WIDTH / this._config.scaledCharWidth);\n this._height = Math.floor(TEXTURE_HEIGHT / this._config.scaledCharHeight);\n const capacity = this._width * this._height;\n this._cacheMap = new LRUMap(capacity);\n this._cacheMap.prealloc(capacity);\n\n // This is useful for debugging\n // document.body.appendChild(this._cacheCanvas);\n }\n\n public dispose(): void {\n if (this._bitmapCommitTimeout !== null) {\n window.clearTimeout(this._bitmapCommitTimeout);\n this._bitmapCommitTimeout = null;\n }\n }\n\n public beginFrame(): void {\n this._drawToCacheCount = 0;\n }\n\n public draw(\n ctx: CanvasRenderingContext2D,\n glyph: IGlyphIdentifier,\n x: number,\n y: number\n ): boolean {\n // Space is always an empty cell, special case this as it's so common\n if (glyph.code === 32) {\n return true;\n }\n\n // Exit early for uncachable glyphs\n if (!this._canCache(glyph)) {\n return false;\n }\n\n const glyphKey = getGlyphCacheKey(glyph);\n const cacheValue = this._cacheMap.get(glyphKey);\n if (cacheValue !== null && cacheValue !== undefined) {\n this._drawFromCache(ctx, cacheValue, x, y);\n return true;\n }\n if (this._drawToCacheCount < FRAME_CACHE_DRAW_LIMIT) {\n let index;\n if (this._cacheMap.size < this._cacheMap.capacity) {\n index = this._cacheMap.size;\n } else {\n // we're out of space, so our call to set will delete this item\n index = this._cacheMap.peek()!.index;\n }\n const cacheValue = this._drawToCache(glyph, index);\n this._cacheMap.set(glyphKey, cacheValue);\n this._drawFromCache(ctx, cacheValue, x, y);\n return true;\n }\n return false;\n }\n\n private _canCache(glyph: IGlyphIdentifier): boolean {\n // Only cache ascii and extended characters for now, to be safe. In the future, we could do\n // something more complicated to determine the expected width of a character.\n //\n // If we switch the renderer over to webgl at some point, we may be able to use blending modes\n // to draw overlapping glyphs from the atlas:\n // https://github.com/servo/webrender/issues/464#issuecomment-255632875\n // https://webglfundamentals.org/webgl/lessons/webgl-text-texture.html\n return glyph.code < 256;\n }\n\n private _toCoordinateX(index: number): number {\n return (index % this._width) * this._config.scaledCharWidth;\n }\n\n private _toCoordinateY(index: number): number {\n return Math.floor(index / this._width) * this._config.scaledCharHeight;\n }\n\n private _drawFromCache(\n ctx: CanvasRenderingContext2D,\n cacheValue: IGlyphCacheValue,\n x: number,\n y: number\n ): void {\n // We don't actually need to do anything if this is whitespace.\n if (cacheValue.isEmpty) {\n return;\n }\n const cacheX = this._toCoordinateX(cacheValue.index);\n const cacheY = this._toCoordinateY(cacheValue.index);\n ctx.drawImage(\n cacheValue.inBitmap ? this._bitmap! : this._cacheCanvas,\n cacheX,\n cacheY,\n this._config.scaledCharWidth,\n this._config.scaledCharHeight,\n x,\n y,\n this._config.scaledCharWidth,\n this._config.scaledCharHeight\n );\n }\n\n private _getColorFromAnsiIndex(idx: number): IColor {\n if (idx < this._config.colors.ansi.length) {\n return this._config.colors.ansi[idx];\n }\n return DEFAULT_ANSI_COLORS[idx];\n }\n\n private _getBackgroundColor(glyph: IGlyphIdentifier): IColor {\n if (this._config.allowTransparency) {\n // The background color might have some transparency, so we need to render it as fully\n // transparent in the atlas. Otherwise we'd end up drawing the transparent background twice\n // around the anti-aliased edges of the glyph, and it would look too dark.\n return TRANSPARENT_COLOR;\n }\n if (glyph.bg === INVERTED_DEFAULT_COLOR) {\n return this._config.colors.foreground;\n }\n if (glyph.bg < 256) {\n return this._getColorFromAnsiIndex(glyph.bg);\n }\n return this._config.colors.background;\n }\n\n private _getForegroundColor(glyph: IGlyphIdentifier): IColor {\n if (glyph.fg === INVERTED_DEFAULT_COLOR) {\n return color.opaque(this._config.colors.background);\n }\n if (glyph.fg < 256) {\n // 256 color support\n return this._getColorFromAnsiIndex(glyph.fg);\n }\n return this._config.colors.foreground;\n }\n\n // TODO: We do this (or something similar) in multiple places. We should split this off\n // into a shared function.\n private _drawToCache(glyph: IGlyphIdentifier, index: number): IGlyphCacheValue {\n this._drawToCacheCount++;\n\n this._tmpCtx.save();\n\n // draw the background\n const backgroundColor = this._getBackgroundColor(glyph);\n // Use a 'copy' composite operation to clear any existing glyph out of _tmpCtxWithAlpha, regardless of\n // transparency in backgroundColor\n this._tmpCtx.globalCompositeOperation = 'copy';\n this._tmpCtx.fillStyle = backgroundColor.css;\n this._tmpCtx.fillRect(0, 0, this._config.scaledCharWidth, this._config.scaledCharHeight);\n this._tmpCtx.globalCompositeOperation = 'source-over';\n\n // draw the foreground/glyph\n const fontWeight = glyph.bold ? this._config.fontWeightBold : this._config.fontWeight;\n const fontStyle = glyph.italic ? 'italic' : '';\n this._tmpCtx.font =\n `${fontStyle} ${fontWeight} ${this._config.fontSize * this._config.devicePixelRatio}px ${this._config.fontFamily}`;\n this._tmpCtx.textBaseline = 'middle';\n\n this._tmpCtx.fillStyle = this._getForegroundColor(glyph).css;\n\n // Apply alpha to dim the character\n if (glyph.dim) {\n this._tmpCtx.globalAlpha = DIM_OPACITY;\n }\n // Draw the character\n this._tmpCtx.fillText(glyph.chars, 0, this._config.scaledCharHeight / 2);\n this._tmpCtx.restore();\n\n // clear the background from the character to avoid issues with drawing over the previous\n // character if it extends past it's bounds\n const imageData = this._tmpCtx.getImageData(\n 0, 0, this._config.scaledCharWidth, this._config.scaledCharHeight\n );\n let isEmpty = false;\n if (!this._config.allowTransparency) {\n isEmpty = clearColor(imageData, backgroundColor);\n }\n\n // copy the data from imageData to _cacheCanvas\n const x = this._toCoordinateX(index);\n const y = this._toCoordinateY(index);\n // putImageData doesn't do any blending, so it will overwrite any existing cache entry for us\n this._cacheCtx.putImageData(imageData, x, y);\n\n // Add the glyph and queue it to the bitmap (if the browser supports it)\n const cacheValue = {\n index,\n isEmpty,\n inBitmap: false\n };\n this._addGlyphToBitmap(cacheValue);\n\n return cacheValue;\n }\n\n private _addGlyphToBitmap(cacheValue: IGlyphCacheValue): void {\n // Support is patchy for createImageBitmap at the moment, pass a canvas back\n // if support is lacking as drawImage works there too. Firefox is also\n // included here as ImageBitmap appears both buggy and has horrible\n // performance (tested on v55).\n if (!('createImageBitmap' in window) || isFirefox || isSafari) {\n return;\n }\n\n // Add the glyph to the queue\n this._glyphsWaitingOnBitmap.push(cacheValue);\n\n // Check if bitmap generation timeout already exists\n if (this._bitmapCommitTimeout !== null) {\n return;\n }\n\n this._bitmapCommitTimeout = window.setTimeout(() => this._generateBitmap(), GLYPH_BITMAP_COMMIT_DELAY);\n }\n\n private _generateBitmap(): void {\n const glyphsMovingToBitmap = this._glyphsWaitingOnBitmap;\n this._glyphsWaitingOnBitmap = [];\n window.createImageBitmap(this._cacheCanvas).then(bitmap => {\n // Set bitmap\n this._bitmap = bitmap;\n\n // Mark all new glyphs as in bitmap, excluding glyphs that came in after\n // the bitmap was requested\n for (let i = 0; i < glyphsMovingToBitmap.length; i++) {\n const value = glyphsMovingToBitmap[i];\n // It doesn't matter if the value was already evicted, it will be\n // released from memory after this block if so.\n value.inBitmap = true;\n }\n });\n this._bitmapCommitTimeout = null;\n }\n}\n\n// This is used for debugging the renderer, just swap out `new DynamicCharAtlas` with\n// `new NoneCharAtlas`.\nexport class NoneCharAtlas extends BaseCharAtlas {\n constructor(document: Document, config: ICharAtlasConfig) {\n super();\n }\n\n public draw(\n ctx: CanvasRenderingContext2D,\n glyph: IGlyphIdentifier,\n x: number,\n y: number\n ): boolean {\n return false;\n }\n}\n\n/**\n * Makes a partiicular rgb color in an ImageData completely transparent.\n * @returns True if the result is \"empty\", meaning all pixels are fully transparent.\n */\nfunction clearColor(imageData: ImageData, color: IColor): boolean {\n let isEmpty = true;\n const r = color.rgba >>> 24;\n const g = color.rgba >>> 16 & 0xFF;\n const b = color.rgba >>> 8 & 0xFF;\n for (let offset = 0; offset < imageData.data.length; offset += 4) {\n if (imageData.data[offset] === r &&\n imageData.data[offset + 1] === g &&\n imageData.data[offset + 2] === b) {\n imageData.data[offset + 3] = 0;\n } else {\n isEmpty = false;\n }\n }\n return isEmpty;\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\ninterface ILinkedListNode {\n prev: ILinkedListNode | null;\n next: ILinkedListNode | null;\n key: number | null;\n value: T | null;\n}\n\nexport class LRUMap {\n private _map: { [key: number]: ILinkedListNode } = {};\n private _head: ILinkedListNode | null = null;\n private _tail: ILinkedListNode | null = null;\n private _nodePool: ILinkedListNode[] = [];\n public size: number = 0;\n\n constructor(public capacity: number) { }\n\n private _unlinkNode(node: ILinkedListNode): void {\n const prev = node.prev;\n const next = node.next;\n if (node === this._head) {\n this._head = next;\n }\n if (node === this._tail) {\n this._tail = prev;\n }\n if (prev !== null) {\n prev.next = next;\n }\n if (next !== null) {\n next.prev = prev;\n }\n }\n\n private _appendNode(node: ILinkedListNode): void {\n const tail = this._tail;\n if (tail !== null) {\n tail.next = node;\n }\n node.prev = tail;\n node.next = null;\n this._tail = node;\n if (this._head === null) {\n this._head = node;\n }\n }\n\n /**\n * Preallocate a bunch of linked-list nodes. Allocating these nodes ahead of time means that\n * they're more likely to live next to each other in memory, which seems to improve performance.\n *\n * Each empty object only consumes about 60 bytes of memory, so this is pretty cheap, even for\n * large maps.\n */\n public prealloc(count: number): void {\n const nodePool = this._nodePool;\n for (let i = 0; i < count; i++) {\n nodePool.push({\n prev: null,\n next: null,\n key: null,\n value: null\n });\n }\n }\n\n public get(key: number): T | null {\n // This is unsafe: We're assuming our keyspace doesn't overlap with Object.prototype. However,\n // it's faster than calling hasOwnProperty, and in our case, it would never overlap.\n const node = this._map[key];\n if (node !== undefined) {\n this._unlinkNode(node);\n this._appendNode(node);\n return node.value;\n }\n return null;\n }\n\n /**\n * Gets a value from a key without marking it as the most recently used item.\n */\n public peekValue(key: number): T | null {\n const node = this._map[key];\n if (node !== undefined) {\n return node.value;\n }\n return null;\n }\n\n public peek(): T | null {\n const head = this._head;\n return head === null ? null : head.value;\n }\n\n public set(key: number, value: T): void {\n // This is unsafe: See note above.\n let node = this._map[key];\n if (node !== undefined) {\n // already exists, we just need to mutate it and move it to the end of the list\n node = this._map[key];\n this._unlinkNode(node);\n node.value = value;\n } else if (this.size >= this.capacity) {\n // we're out of space: recycle the head node, move it to the tail\n node = this._head!;\n this._unlinkNode(node);\n delete this._map[node.key!];\n node.key = key;\n node.value = value;\n this._map[key] = node;\n } else {\n // make a new element\n const nodePool = this._nodePool;\n if (nodePool.length > 0) {\n // use a preallocated node if we can\n node = nodePool.pop()!;\n node.key = key;\n node.value = value;\n } else {\n node = {\n prev: null,\n next: null,\n key,\n value\n };\n }\n this._map[key] = node;\n this.size++;\n }\n this._appendNode(node);\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IRenderer, IRenderDimensions, CharacterJoinerHandler, IRequestRedrawEvent } from 'browser/renderer/Types';\nimport { BOLD_CLASS, ITALIC_CLASS, CURSOR_CLASS, CURSOR_STYLE_BLOCK_CLASS, CURSOR_BLINK_CLASS, CURSOR_STYLE_BAR_CLASS, CURSOR_STYLE_UNDERLINE_CLASS, DomRendererRowFactory } from 'browser/renderer/dom/DomRendererRowFactory';\nimport { INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants';\nimport { Disposable } from 'common/Lifecycle';\nimport { IColorSet, ILinkifierEvent, ILinkifier, ILinkifier2 } from 'browser/Types';\nimport { ICharSizeService } from 'browser/services/Services';\nimport { IOptionsService, IBufferService } from 'common/services/Services';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { color } from 'browser/Color';\nimport { removeElementFromParent } from 'browser/Dom';\n\nconst TERMINAL_CLASS_PREFIX = 'xterm-dom-renderer-owner-';\nconst ROW_CONTAINER_CLASS = 'xterm-rows';\nconst FG_CLASS_PREFIX = 'xterm-fg-';\nconst BG_CLASS_PREFIX = 'xterm-bg-';\nconst FOCUS_CLASS = 'xterm-focus';\nconst SELECTION_CLASS = 'xterm-selection';\n\nlet nextTerminalId = 1;\n\n/**\n * A fallback renderer for when canvas is slow. This is not meant to be\n * particularly fast or feature complete, more just stable and usable for when\n * canvas is not an option.\n */\nexport class DomRenderer extends Disposable implements IRenderer {\n private _rowFactory: DomRendererRowFactory;\n private _terminalClass: number = nextTerminalId++;\n\n private _themeStyleElement!: HTMLStyleElement;\n private _dimensionsStyleElement!: HTMLStyleElement;\n private _rowContainer: HTMLElement;\n private _rowElements: HTMLElement[] = [];\n private _selectionContainer: HTMLElement;\n\n public dimensions: IRenderDimensions;\n\n public get onRequestRedraw(): IEvent { return new EventEmitter().event; }\n\n constructor(\n private _colors: IColorSet,\n private readonly _element: HTMLElement,\n private readonly _screenElement: HTMLElement,\n private readonly _viewportElement: HTMLElement,\n private readonly _linkifier: ILinkifier,\n private readonly _linkifier2: ILinkifier2,\n @ICharSizeService private readonly _charSizeService: ICharSizeService,\n @IOptionsService private readonly _optionsService: IOptionsService,\n @IBufferService private readonly _bufferService: IBufferService\n ) {\n super();\n this._rowContainer = document.createElement('div');\n this._rowContainer.classList.add(ROW_CONTAINER_CLASS);\n this._rowContainer.style.lineHeight = 'normal';\n this._rowContainer.setAttribute('aria-hidden', 'true');\n this._refreshRowElements(this._bufferService.cols, this._bufferService.rows);\n this._selectionContainer = document.createElement('div');\n this._selectionContainer.classList.add(SELECTION_CLASS);\n this._selectionContainer.setAttribute('aria-hidden', 'true');\n\n this.dimensions = {\n scaledCharWidth: 0,\n scaledCharHeight: 0,\n scaledCellWidth: 0,\n scaledCellHeight: 0,\n scaledCharLeft: 0,\n scaledCharTop: 0,\n scaledCanvasWidth: 0,\n scaledCanvasHeight: 0,\n canvasWidth: 0,\n canvasHeight: 0,\n actualCellWidth: 0,\n actualCellHeight: 0\n };\n this._updateDimensions();\n this._injectCss();\n\n this._rowFactory = new DomRendererRowFactory(document, this._optionsService, this._colors);\n\n this._element.classList.add(TERMINAL_CLASS_PREFIX + this._terminalClass);\n this._screenElement.appendChild(this._rowContainer);\n this._screenElement.appendChild(this._selectionContainer);\n\n this._linkifier.onShowLinkUnderline(e => this._onLinkHover(e));\n this._linkifier.onHideLinkUnderline(e => this._onLinkLeave(e));\n\n this._linkifier2.onShowLinkUnderline(e => this._onLinkHover(e));\n this._linkifier2.onHideLinkUnderline(e => this._onLinkLeave(e));\n }\n\n public dispose(): void {\n this._element.classList.remove(TERMINAL_CLASS_PREFIX + this._terminalClass);\n\n // Outside influences such as React unmounts may manipulate the DOM before our disposal.\n // https://github.com/xtermjs/xterm.js/issues/2960\n removeElementFromParent(this._rowContainer, this._selectionContainer, this._themeStyleElement, this._dimensionsStyleElement);\n\n super.dispose();\n }\n\n private _updateDimensions(): void {\n this.dimensions.scaledCharWidth = this._charSizeService.width * window.devicePixelRatio;\n this.dimensions.scaledCharHeight = Math.ceil(this._charSizeService.height * window.devicePixelRatio);\n this.dimensions.scaledCellWidth = this.dimensions.scaledCharWidth + Math.round(this._optionsService.options.letterSpacing);\n this.dimensions.scaledCellHeight = Math.floor(this.dimensions.scaledCharHeight * this._optionsService.options.lineHeight);\n this.dimensions.scaledCharLeft = 0;\n this.dimensions.scaledCharTop = 0;\n this.dimensions.scaledCanvasWidth = this.dimensions.scaledCellWidth * this._bufferService.cols;\n this.dimensions.scaledCanvasHeight = this.dimensions.scaledCellHeight * this._bufferService.rows;\n this.dimensions.canvasWidth = Math.round(this.dimensions.scaledCanvasWidth / window.devicePixelRatio);\n this.dimensions.canvasHeight = Math.round(this.dimensions.scaledCanvasHeight / window.devicePixelRatio);\n this.dimensions.actualCellWidth = this.dimensions.canvasWidth / this._bufferService.cols;\n this.dimensions.actualCellHeight = this.dimensions.canvasHeight / this._bufferService.rows;\n\n for (const element of this._rowElements) {\n element.style.width = `${this.dimensions.canvasWidth}px`;\n element.style.height = `${this.dimensions.actualCellHeight}px`;\n element.style.lineHeight = `${this.dimensions.actualCellHeight}px`;\n // Make sure rows don't overflow onto following row\n element.style.overflow = 'hidden';\n }\n\n if (!this._dimensionsStyleElement) {\n this._dimensionsStyleElement = document.createElement('style');\n this._screenElement.appendChild(this._dimensionsStyleElement);\n }\n\n const styles =\n `${this._terminalSelector} .${ROW_CONTAINER_CLASS} span {` +\n ` display: inline-block;` +\n ` height: 100%;` +\n ` vertical-align: top;` +\n ` width: ${this.dimensions.actualCellWidth}px` +\n `}`;\n\n this._dimensionsStyleElement.textContent = styles;\n\n this._selectionContainer.style.height = this._viewportElement.style.height;\n this._screenElement.style.width = `${this.dimensions.canvasWidth}px`;\n this._screenElement.style.height = `${this.dimensions.canvasHeight}px`;\n }\n\n public setColors(colors: IColorSet): void {\n this._colors = colors;\n this._injectCss();\n }\n\n private _injectCss(): void {\n if (!this._themeStyleElement) {\n this._themeStyleElement = document.createElement('style');\n this._screenElement.appendChild(this._themeStyleElement);\n }\n\n // Base CSS\n let styles =\n `${this._terminalSelector} .${ROW_CONTAINER_CLASS} {` +\n ` color: ${this._colors.foreground.css};` +\n ` font-family: ${this._optionsService.options.fontFamily};` +\n ` font-size: ${this._optionsService.options.fontSize}px;` +\n `}`;\n // Text styles\n styles +=\n `${this._terminalSelector} span:not(.${BOLD_CLASS}) {` +\n ` font-weight: ${this._optionsService.options.fontWeight};` +\n `}` +\n `${this._terminalSelector} span.${BOLD_CLASS} {` +\n ` font-weight: ${this._optionsService.options.fontWeightBold};` +\n `}` +\n `${this._terminalSelector} span.${ITALIC_CLASS} {` +\n ` font-style: italic;` +\n `}`;\n // Blink animation\n styles +=\n `@keyframes blink_box_shadow` + `_` + this._terminalClass + ` {` +\n ` 50% {` +\n ` box-shadow: none;` +\n ` }` +\n `}`;\n styles +=\n `@keyframes blink_block` + `_` + this._terminalClass + ` {` +\n ` 0% {` +\n ` background-color: ${this._colors.cursor.css};` +\n ` color: ${this._colors.cursorAccent.css};` +\n ` }` +\n ` 50% {` +\n ` background-color: ${this._colors.cursorAccent.css};` +\n ` color: ${this._colors.cursor.css};` +\n ` }` +\n `}`;\n // Cursor\n styles +=\n `${this._terminalSelector} .${ROW_CONTAINER_CLASS}:not(.${FOCUS_CLASS}) .${CURSOR_CLASS}.${CURSOR_STYLE_BLOCK_CLASS} {` +\n ` outline: 1px solid ${this._colors.cursor.css};` +\n ` outline-offset: -1px;` +\n `}` +\n `${this._terminalSelector} .${ROW_CONTAINER_CLASS}.${FOCUS_CLASS} .${CURSOR_CLASS}.${CURSOR_BLINK_CLASS}:not(.${CURSOR_STYLE_BLOCK_CLASS}) {` +\n ` animation: blink_box_shadow` + `_` + this._terminalClass + ` 1s step-end infinite;` +\n `}` +\n `${this._terminalSelector} .${ROW_CONTAINER_CLASS}.${FOCUS_CLASS} .${CURSOR_CLASS}.${CURSOR_BLINK_CLASS}.${CURSOR_STYLE_BLOCK_CLASS} {` +\n ` animation: blink_block` + `_` + this._terminalClass + ` 1s step-end infinite;` +\n `}` +\n `${this._terminalSelector} .${ROW_CONTAINER_CLASS}.${FOCUS_CLASS} .${CURSOR_CLASS}.${CURSOR_STYLE_BLOCK_CLASS} {` +\n ` background-color: ${this._colors.cursor.css};` +\n ` color: ${this._colors.cursorAccent.css};` +\n `}` +\n `${this._terminalSelector} .${ROW_CONTAINER_CLASS} .${CURSOR_CLASS}.${CURSOR_STYLE_BAR_CLASS} {` +\n ` box-shadow: ${this._optionsService.options.cursorWidth}px 0 0 ${this._colors.cursor.css} inset;` +\n `}` +\n `${this._terminalSelector} .${ROW_CONTAINER_CLASS} .${CURSOR_CLASS}.${CURSOR_STYLE_UNDERLINE_CLASS} {` +\n ` box-shadow: 0 -1px 0 ${this._colors.cursor.css} inset;` +\n `}`;\n // Selection\n styles +=\n `${this._terminalSelector} .${SELECTION_CLASS} {` +\n ` position: absolute;` +\n ` top: 0;` +\n ` left: 0;` +\n ` z-index: 1;` +\n ` pointer-events: none;` +\n `}` +\n `${this._terminalSelector} .${SELECTION_CLASS} div {` +\n ` position: absolute;` +\n ` background-color: ${this._colors.selectionTransparent.css};` +\n `}`;\n // Colors\n this._colors.ansi.forEach((c, i) => {\n styles +=\n `${this._terminalSelector} .${FG_CLASS_PREFIX}${i} { color: ${c.css}; }` +\n `${this._terminalSelector} .${BG_CLASS_PREFIX}${i} { background-color: ${c.css}; }`;\n });\n styles +=\n `${this._terminalSelector} .${FG_CLASS_PREFIX}${INVERTED_DEFAULT_COLOR} { color: ${color.opaque(this._colors.background).css}; }` +\n `${this._terminalSelector} .${BG_CLASS_PREFIX}${INVERTED_DEFAULT_COLOR} { background-color: ${this._colors.foreground.css}; }`;\n\n this._themeStyleElement.textContent = styles;\n }\n\n public onDevicePixelRatioChange(): void {\n this._updateDimensions();\n }\n\n private _refreshRowElements(cols: number, rows: number): void {\n // Add missing elements\n for (let i = this._rowElements.length; i <= rows; i++) {\n const row = document.createElement('div');\n this._rowContainer.appendChild(row);\n this._rowElements.push(row);\n }\n // Remove excess elements\n while (this._rowElements.length > rows) {\n this._rowContainer.removeChild(this._rowElements.pop()!);\n }\n }\n\n public onResize(cols: number, rows: number): void {\n this._refreshRowElements(cols, rows);\n this._updateDimensions();\n }\n\n public onCharSizeChanged(): void {\n this._updateDimensions();\n }\n\n public onBlur(): void {\n this._rowContainer.classList.remove(FOCUS_CLASS);\n }\n\n public onFocus(): void {\n this._rowContainer.classList.add(FOCUS_CLASS);\n }\n\n public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void {\n // Remove all selections\n while (this._selectionContainer.children.length) {\n this._selectionContainer.removeChild(this._selectionContainer.children[0]);\n }\n\n // Selection does not exist\n if (!start || !end) {\n return;\n }\n\n // Translate from buffer position to viewport position\n const viewportStartRow = start[1] - this._bufferService.buffer.ydisp;\n const viewportEndRow = end[1] - this._bufferService.buffer.ydisp;\n const viewportCappedStartRow = Math.max(viewportStartRow, 0);\n const viewportCappedEndRow = Math.min(viewportEndRow, this._bufferService.rows - 1);\n\n // No need to draw the selection\n if (viewportCappedStartRow >= this._bufferService.rows || viewportCappedEndRow < 0) {\n return;\n }\n\n // Create the selections\n const documentFragment = document.createDocumentFragment();\n\n if (columnSelectMode) {\n documentFragment.appendChild(\n this._createSelectionElement(viewportCappedStartRow, start[0], end[0], viewportCappedEndRow - viewportCappedStartRow + 1)\n );\n } else {\n // Draw first row\n const startCol = viewportStartRow === viewportCappedStartRow ? start[0] : 0;\n const endCol = viewportCappedStartRow === viewportEndRow ? end[0] : this._bufferService.cols;\n documentFragment.appendChild(this._createSelectionElement(viewportCappedStartRow, startCol, endCol));\n // Draw middle rows\n const middleRowsCount = viewportCappedEndRow - viewportCappedStartRow - 1;\n documentFragment.appendChild(this._createSelectionElement(viewportCappedStartRow + 1, 0, this._bufferService.cols, middleRowsCount));\n // Draw final row\n if (viewportCappedStartRow !== viewportCappedEndRow) {\n // Only draw viewportEndRow if it's not the same as viewporttartRow\n const endCol = viewportEndRow === viewportCappedEndRow ? end[0] : this._bufferService.cols;\n documentFragment.appendChild(this._createSelectionElement(viewportCappedEndRow, 0, endCol));\n }\n }\n this._selectionContainer.appendChild(documentFragment);\n }\n\n /**\n * Creates a selection element at the specified position.\n * @param row The row of the selection.\n * @param colStart The start column.\n * @param colEnd The end columns.\n */\n private _createSelectionElement(row: number, colStart: number, colEnd: number, rowCount: number = 1): HTMLElement {\n const element = document.createElement('div');\n element.style.height = `${rowCount * this.dimensions.actualCellHeight}px`;\n element.style.top = `${row * this.dimensions.actualCellHeight}px`;\n element.style.left = `${colStart * this.dimensions.actualCellWidth}px`;\n element.style.width = `${this.dimensions.actualCellWidth * (colEnd - colStart)}px`;\n return element;\n }\n\n public onCursorMove(): void {\n // No-op, the cursor is drawn when rows are drawn\n }\n\n public onOptionsChanged(): void {\n // Force a refresh\n this._updateDimensions();\n this._injectCss();\n }\n\n public clear(): void {\n for (const e of this._rowElements) {\n e.innerText = '';\n }\n }\n\n public renderRows(start: number, end: number): void {\n const cursorAbsoluteY = this._bufferService.buffer.ybase + this._bufferService.buffer.y;\n const cursorX = Math.min(this._bufferService.buffer.x, this._bufferService.cols - 1);\n const cursorBlink = this._optionsService.options.cursorBlink;\n\n for (let y = start; y <= end; y++) {\n const rowElement = this._rowElements[y];\n rowElement.innerText = '';\n\n const row = y + this._bufferService.buffer.ydisp;\n const lineData = this._bufferService.buffer.lines.get(row);\n const cursorStyle = this._optionsService.options.cursorStyle;\n rowElement.appendChild(this._rowFactory.createRow(lineData!, row === cursorAbsoluteY, cursorStyle, cursorX, cursorBlink, this.dimensions.actualCellWidth, this._bufferService.cols));\n }\n }\n\n private get _terminalSelector(): string {\n return `.${TERMINAL_CLASS_PREFIX}${this._terminalClass}`;\n }\n\n public registerCharacterJoiner(handler: CharacterJoinerHandler): number { return -1; }\n public deregisterCharacterJoiner(joinerId: number): boolean { return false; }\n\n private _onLinkHover(e: ILinkifierEvent): void {\n this._setCellUnderline(e.x1, e.x2, e.y1, e.y2, e.cols, true);\n }\n\n private _onLinkLeave(e: ILinkifierEvent): void {\n this._setCellUnderline(e.x1, e.x2, e.y1, e.y2, e.cols, false);\n }\n\n private _setCellUnderline(x: number, x2: number, y: number, y2: number, cols: number, enabled: boolean): void {\n while (x !== x2 || y !== y2) {\n const row = this._rowElements[y];\n if (!row) {\n return;\n }\n const span = row.children[x];\n if (span) {\n span.style.textDecoration = enabled ? 'underline' : 'none';\n }\n if (++x >= cols) {\n x = 0;\n y++;\n }\n }\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IBufferLine } from 'common/Types';\nimport { INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants';\nimport { NULL_CELL_CODE, WHITESPACE_CELL_CHAR, Attributes } from 'common/buffer/Constants';\nimport { CellData } from 'common/buffer/CellData';\nimport { IOptionsService } from 'common/services/Services';\nimport { color, rgba } from 'browser/Color';\nimport { IColorSet, IColor } from 'browser/Types';\n\nexport const BOLD_CLASS = 'xterm-bold';\nexport const DIM_CLASS = 'xterm-dim';\nexport const ITALIC_CLASS = 'xterm-italic';\nexport const UNDERLINE_CLASS = 'xterm-underline';\nexport const CURSOR_CLASS = 'xterm-cursor';\nexport const CURSOR_BLINK_CLASS = 'xterm-cursor-blink';\nexport const CURSOR_STYLE_BLOCK_CLASS = 'xterm-cursor-block';\nexport const CURSOR_STYLE_BAR_CLASS = 'xterm-cursor-bar';\nexport const CURSOR_STYLE_UNDERLINE_CLASS = 'xterm-cursor-underline';\n\nexport class DomRendererRowFactory {\n private _workCell: CellData = new CellData();\n\n constructor(\n private readonly _document: Document,\n private readonly _optionsService: IOptionsService,\n private _colors: IColorSet\n ) {\n }\n\n public setColors(colors: IColorSet): void {\n this._colors = colors;\n }\n\n public createRow(lineData: IBufferLine, isCursorRow: boolean, cursorStyle: string | undefined, cursorX: number, cursorBlink: boolean, cellWidth: number, cols: number): DocumentFragment {\n const fragment = this._document.createDocumentFragment();\n\n // Find the line length first, this prevents the need to output a bunch of\n // empty cells at the end. This cannot easily be integrated into the main\n // loop below because of the colCount feature (which can be removed after we\n // properly support reflow and disallow data to go beyond the right-side of\n // the viewport).\n let lineLength = 0;\n for (let x = Math.min(lineData.length, cols) - 1; x >= 0; x--) {\n if (lineData.loadCell(x, this._workCell).getCode() !== NULL_CELL_CODE || (isCursorRow && x === cursorX)) {\n lineLength = x + 1;\n break;\n }\n }\n\n for (let x = 0; x < lineLength; x++) {\n lineData.loadCell(x, this._workCell);\n const width = this._workCell.getWidth();\n\n // The character to the left is a wide character, drawing is owned by the char at x-1\n if (width === 0) {\n continue;\n }\n\n const charElement = this._document.createElement('span');\n if (width > 1) {\n charElement.style.width = `${cellWidth * width}px`;\n }\n\n if (isCursorRow && x === cursorX) {\n charElement.classList.add(CURSOR_CLASS);\n\n if (cursorBlink) {\n charElement.classList.add(CURSOR_BLINK_CLASS);\n }\n\n switch (cursorStyle) {\n case 'bar':\n charElement.classList.add(CURSOR_STYLE_BAR_CLASS);\n break;\n case 'underline':\n charElement.classList.add(CURSOR_STYLE_UNDERLINE_CLASS);\n break;\n default:\n charElement.classList.add(CURSOR_STYLE_BLOCK_CLASS);\n break;\n }\n }\n\n if (this._workCell.isBold()) {\n charElement.classList.add(BOLD_CLASS);\n }\n\n if (this._workCell.isItalic()) {\n charElement.classList.add(ITALIC_CLASS);\n }\n\n if (this._workCell.isDim()) {\n charElement.classList.add(DIM_CLASS);\n }\n\n if (this._workCell.isUnderline()) {\n charElement.classList.add(UNDERLINE_CLASS);\n }\n\n if (this._workCell.isInvisible()) {\n charElement.textContent = WHITESPACE_CELL_CHAR;\n } else {\n charElement.textContent = this._workCell.getChars() || WHITESPACE_CELL_CHAR;\n }\n\n let fg = this._workCell.getFgColor();\n let fgColorMode = this._workCell.getFgColorMode();\n let bg = this._workCell.getBgColor();\n let bgColorMode = this._workCell.getBgColorMode();\n const isInverse = !!this._workCell.isInverse();\n if (isInverse) {\n const temp = fg;\n fg = bg;\n bg = temp;\n const temp2 = fgColorMode;\n fgColorMode = bgColorMode;\n bgColorMode = temp2;\n }\n\n // Foreground\n switch (fgColorMode) {\n case Attributes.CM_P16:\n case Attributes.CM_P256:\n if (this._workCell.isBold() && fg < 8 && this._optionsService.options.drawBoldTextInBrightColors) {\n fg += 8;\n }\n if (!this._applyMinimumContrast(charElement, this._colors.background, this._colors.ansi[fg])) {\n charElement.classList.add(`xterm-fg-${fg}`);\n }\n break;\n case Attributes.CM_RGB:\n const color = rgba.toColor(\n (fg >> 16) & 0xFF,\n (fg >> 8) & 0xFF,\n (fg ) & 0xFF\n );\n if (!this._applyMinimumContrast(charElement, this._colors.background, color)) {\n this._addStyle(charElement, `color:#${padStart(fg.toString(16), '0', 6)}`);\n }\n break;\n case Attributes.CM_DEFAULT:\n default:\n if (!this._applyMinimumContrast(charElement, this._colors.background, this._colors.foreground)) {\n if (isInverse) {\n charElement.classList.add(`xterm-fg-${INVERTED_DEFAULT_COLOR}`);\n }\n }\n }\n\n // Background\n switch (bgColorMode) {\n case Attributes.CM_P16:\n case Attributes.CM_P256:\n charElement.classList.add(`xterm-bg-${bg}`);\n break;\n case Attributes.CM_RGB:\n this._addStyle(charElement, `background-color:#${padStart(bg.toString(16), '0', 6)}`);\n break;\n case Attributes.CM_DEFAULT:\n default:\n if (isInverse) {\n charElement.classList.add(`xterm-bg-${INVERTED_DEFAULT_COLOR}`);\n }\n }\n\n fragment.appendChild(charElement);\n }\n return fragment;\n }\n\n private _applyMinimumContrast(element: HTMLElement, bg: IColor, fg: IColor): boolean {\n if (this._optionsService.options.minimumContrastRatio === 1) {\n return false;\n }\n\n // Try get from cache first\n let adjustedColor = this._colors.contrastCache.getColor(this._workCell.bg, this._workCell.fg);\n\n // Calculate and store in cache\n if (adjustedColor === undefined) {\n adjustedColor = color.ensureContrastRatio(bg, fg, this._optionsService.options.minimumContrastRatio);\n this._colors.contrastCache.setColor(this._workCell.bg, this._workCell.fg, adjustedColor ?? null);\n }\n\n if (adjustedColor) {\n this._addStyle(element, `color:${adjustedColor.css}`);\n return true;\n }\n\n return false;\n }\n\n private _addStyle(element: HTMLElement, style: string): void {\n element.setAttribute('style', `${element.getAttribute('style') || ''}${style};`);\n }\n}\n\nfunction padStart(text: string, padChar: string, length: number): string {\n while (text.length < length) {\n text = padChar + text;\n }\n return text;\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IBufferService } from 'common/services/Services';\n\n/**\n * Represents a selection within the buffer. This model only cares about column\n * and row coordinates, not wide characters.\n */\nexport class SelectionModel {\n /**\n * Whether select all is currently active.\n */\n public isSelectAllActive: boolean = false;\n\n /**\n * The minimal length of the selection from the start position. When double\n * clicking on a word, the word will be selected which makes the selection\n * start at the start of the word and makes this variable the length.\n */\n public selectionStartLength: number = 0;\n\n /**\n * The [x, y] position the selection starts at.\n */\n public selectionStart: [number, number] | undefined;\n\n /**\n * The [x, y] position the selection ends at.\n */\n public selectionEnd: [number, number] | undefined;\n\n constructor(\n private _bufferService: IBufferService\n ) {\n }\n\n /**\n * Clears the current selection.\n */\n public clearSelection(): void {\n this.selectionStart = undefined;\n this.selectionEnd = undefined;\n this.isSelectAllActive = false;\n this.selectionStartLength = 0;\n }\n\n /**\n * The final selection start, taking into consideration select all.\n */\n public get finalSelectionStart(): [number, number] | undefined {\n if (this.isSelectAllActive) {\n return [0, 0];\n }\n\n if (!this.selectionEnd || !this.selectionStart) {\n return this.selectionStart;\n }\n\n return this.areSelectionValuesReversed() ? this.selectionEnd : this.selectionStart;\n }\n\n /**\n * The final selection end, taking into consideration select all, double click\n * word selection and triple click line selection.\n */\n public get finalSelectionEnd(): [number, number] | undefined {\n if (this.isSelectAllActive) {\n return [this._bufferService.cols, this._bufferService.buffer.ybase + this._bufferService.rows - 1];\n }\n\n if (!this.selectionStart) {\n return undefined;\n }\n\n // Use the selection start + length if the end doesn't exist or they're reversed\n if (!this.selectionEnd || this.areSelectionValuesReversed()) {\n const startPlusLength = this.selectionStart[0] + this.selectionStartLength;\n if (startPlusLength > this._bufferService.cols) {\n return [startPlusLength % this._bufferService.cols, this.selectionStart[1] + Math.floor(startPlusLength / this._bufferService.cols)];\n }\n return [startPlusLength, this.selectionStart[1]];\n }\n\n // Ensure the the word/line is selected after a double/triple click\n if (this.selectionStartLength) {\n // Select the larger of the two when start and end are on the same line\n if (this.selectionEnd[1] === this.selectionStart[1]) {\n return [Math.max(this.selectionStart[0] + this.selectionStartLength, this.selectionEnd[0]), this.selectionEnd[1]];\n }\n }\n return this.selectionEnd;\n }\n\n /**\n * Returns whether the selection start and end are reversed.\n */\n public areSelectionValuesReversed(): boolean {\n const start = this.selectionStart;\n const end = this.selectionEnd;\n if (!start || !end) {\n return false;\n }\n return start[1] > end[1] || (start[1] === end[1] && start[0] > end[0]);\n }\n\n /**\n * Handle the buffer being trimmed, adjust the selection position.\n * @param amount The amount the buffer is being trimmed.\n * @return Whether a refresh is necessary.\n */\n public onTrim(amount: number): boolean {\n // Adjust the selection position based on the trimmed amount.\n if (this.selectionStart) {\n this.selectionStart[1] -= amount;\n }\n if (this.selectionEnd) {\n this.selectionEnd[1] -= amount;\n }\n\n // The selection has moved off the buffer, clear it.\n if (this.selectionEnd && this.selectionEnd[1] < 0) {\n this.clearSelection();\n return true;\n }\n\n // If the selection start is trimmed, ensure the start column is 0.\n if (this.selectionStart && this.selectionStart[1] < 0) {\n this.selectionStart[1] = 0;\n }\n return false;\n }\n}\n","/**\n * Copyright (c) 2016 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IOptionsService } from 'common/services/Services';\nimport { IEvent, EventEmitter } from 'common/EventEmitter';\nimport { ICharSizeService } from 'browser/services/Services';\n\nexport class CharSizeService implements ICharSizeService {\n public serviceBrand: undefined;\n\n public width: number = 0;\n public height: number = 0;\n private _measureStrategy: IMeasureStrategy;\n\n public get hasValidSize(): boolean { return this.width > 0 && this.height > 0; }\n\n private _onCharSizeChange = new EventEmitter();\n public get onCharSizeChange(): IEvent { return this._onCharSizeChange.event; }\n\n constructor(\n document: Document,\n parentElement: HTMLElement,\n @IOptionsService private readonly _optionsService: IOptionsService\n ) {\n this._measureStrategy = new DomMeasureStrategy(document, parentElement, this._optionsService);\n }\n\n public measure(): void {\n const result = this._measureStrategy.measure();\n if (result.width !== this.width || result.height !== this.height) {\n this.width = result.width;\n this.height = result.height;\n this._onCharSizeChange.fire();\n }\n }\n}\n\ninterface IMeasureStrategy {\n measure(): IReadonlyMeasureResult;\n}\n\ninterface IReadonlyMeasureResult {\n readonly width: number;\n readonly height: number;\n}\n\ninterface IMeasureResult {\n width: number;\n height: number;\n}\n\n// TODO: For supporting browsers we should also provide a CanvasCharDimensionsProvider that uses ctx.measureText\nclass DomMeasureStrategy implements IMeasureStrategy {\n private _result: IMeasureResult = { width: 0, height: 0 };\n private _measureElement: HTMLElement;\n\n constructor(\n private _document: Document,\n private _parentElement: HTMLElement,\n private _optionsService: IOptionsService\n ) {\n this._measureElement = this._document.createElement('span');\n this._measureElement.classList.add('xterm-char-measure-element');\n this._measureElement.textContent = 'W';\n this._measureElement.setAttribute('aria-hidden', 'true');\n this._parentElement.appendChild(this._measureElement);\n }\n\n public measure(): IReadonlyMeasureResult {\n this._measureElement.style.fontFamily = this._optionsService.options.fontFamily;\n this._measureElement.style.fontSize = `${this._optionsService.options.fontSize}px`;\n\n // Note that this triggers a synchronous layout\n const geometry = this._measureElement.getBoundingClientRect();\n\n // If values are 0 then the element is likely currently display:none, in which case we should\n // retain the previous value.\n if (geometry.width !== 0 && geometry.height !== 0) {\n this._result.width = geometry.width;\n this._result.height = Math.ceil(geometry.height);\n }\n\n return this._result;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ICoreBrowserService } from './Services';\n\nexport class CoreBrowserService implements ICoreBrowserService {\n public serviceBrand: undefined;\n\n constructor(\n private _textarea: HTMLTextAreaElement\n ) {\n }\n\n public get isFocused(): boolean {\n const docOrShadowRoot = this._textarea.getRootNode ? this._textarea.getRootNode() as Document | ShadowRoot : document;\n return docOrShadowRoot.activeElement === this._textarea && document.hasFocus();\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ICharSizeService, IRenderService, IMouseService } from './Services';\nimport { getCoords, getRawByteCoords } from 'browser/input/Mouse';\n\nexport class MouseService implements IMouseService {\n public serviceBrand: undefined;\n\n constructor(\n @IRenderService private readonly _renderService: IRenderService,\n @ICharSizeService private readonly _charSizeService: ICharSizeService\n ) {\n }\n\n public getCoords(event: {clientX: number, clientY: number}, element: HTMLElement, colCount: number, rowCount: number, isSelection?: boolean): [number, number] | undefined {\n return getCoords(\n event,\n element,\n colCount,\n rowCount,\n this._charSizeService.hasValidSize,\n this._renderService.dimensions.actualCellWidth,\n this._renderService.dimensions.actualCellHeight,\n isSelection\n );\n }\n\n public getRawByteCoords(event: MouseEvent, element: HTMLElement, colCount: number, rowCount: number): { x: number, y: number } | undefined {\n const coords = this.getCoords(event, element, colCount, rowCount);\n return getRawByteCoords(coords);\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IRenderer, IRenderDimensions, CharacterJoinerHandler } from 'browser/renderer/Types';\nimport { RenderDebouncer } from 'browser/RenderDebouncer';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { Disposable } from 'common/Lifecycle';\nimport { ScreenDprMonitor } from 'browser/ScreenDprMonitor';\nimport { addDisposableDomListener } from 'browser/Lifecycle';\nimport { IColorSet } from 'browser/Types';\nimport { IOptionsService, IBufferService } from 'common/services/Services';\nimport { ICharSizeService, IRenderService } from 'browser/services/Services';\n\ninterface ISelectionState {\n start: [number, number] | undefined;\n end: [number, number] | undefined;\n columnSelectMode: boolean;\n}\n\nexport class RenderService extends Disposable implements IRenderService {\n public serviceBrand: undefined;\n\n private _renderDebouncer: RenderDebouncer;\n private _screenDprMonitor: ScreenDprMonitor;\n\n private _isPaused: boolean = false;\n private _needsFullRefresh: boolean = false;\n private _isNextRenderRedrawOnly: boolean = true;\n private _needsSelectionRefresh: boolean = false;\n private _canvasWidth: number = 0;\n private _canvasHeight: number = 0;\n private _selectionState: ISelectionState = {\n start: undefined,\n end: undefined,\n columnSelectMode: false\n };\n\n private _onDimensionsChange = new EventEmitter();\n public get onDimensionsChange(): IEvent { return this._onDimensionsChange.event; }\n private _onRender = new EventEmitter<{ start: number, end: number }>();\n public get onRenderedBufferChange(): IEvent<{ start: number, end: number }> { return this._onRender.event; }\n private _onRefreshRequest = new EventEmitter<{ start: number, end: number }>();\n public get onRefreshRequest(): IEvent<{ start: number, end: number }> { return this._onRefreshRequest.event; }\n\n public get dimensions(): IRenderDimensions { return this._renderer.dimensions; }\n\n constructor(\n private _renderer: IRenderer,\n private _rowCount: number,\n screenElement: HTMLElement,\n @IOptionsService optionsService: IOptionsService,\n @ICharSizeService private readonly _charSizeService: ICharSizeService,\n @IBufferService bufferService: IBufferService\n ) {\n super();\n\n this.register({ dispose: () => this._renderer.dispose() });\n\n this._renderDebouncer = new RenderDebouncer((start, end) => this._renderRows(start, end));\n this.register(this._renderDebouncer);\n\n this._screenDprMonitor = new ScreenDprMonitor();\n this._screenDprMonitor.setListener(() => this.onDevicePixelRatioChange());\n this.register(this._screenDprMonitor);\n\n this.register(bufferService.onResize(e => this._fullRefresh()));\n this.register(optionsService.onOptionChange(() => this._renderer.onOptionsChanged()));\n this.register(this._charSizeService.onCharSizeChange(() => this.onCharSizeChanged()));\n\n // No need to register this as renderer is explicitly disposed in RenderService.dispose\n this._renderer.onRequestRedraw(e => this.refreshRows(e.start, e.end, true));\n\n // dprchange should handle this case, we need this as well for browsers that don't support the\n // matchMedia query.\n this.register(addDisposableDomListener(window, 'resize', () => this.onDevicePixelRatioChange()));\n\n // Detect whether IntersectionObserver is detected and enable renderer pause\n // and resume based on terminal visibility if so\n if ('IntersectionObserver' in window) {\n const observer = new IntersectionObserver(e => this._onIntersectionChange(e[e.length - 1]), { threshold: 0 });\n observer.observe(screenElement);\n this.register({ dispose: () => observer.disconnect() });\n }\n }\n\n private _onIntersectionChange(entry: IntersectionObserverEntry): void {\n this._isPaused = entry.isIntersecting === undefined ? (entry.intersectionRatio === 0) : !entry.isIntersecting;\n\n // Terminal was hidden on open\n if (!this._isPaused && !this._charSizeService.hasValidSize) {\n this._charSizeService.measure();\n }\n\n if (!this._isPaused && this._needsFullRefresh) {\n this.refreshRows(0, this._rowCount - 1);\n this._needsFullRefresh = false;\n }\n }\n\n public refreshRows(start: number, end: number, isRedrawOnly: boolean = false): void {\n if (this._isPaused) {\n this._needsFullRefresh = true;\n return;\n }\n if (!isRedrawOnly) {\n this._isNextRenderRedrawOnly = false;\n }\n this._renderDebouncer.refresh(start, end, this._rowCount);\n }\n\n private _renderRows(start: number, end: number): void {\n this._renderer.renderRows(start, end);\n\n // Update selection if needed\n if (this._needsSelectionRefresh) {\n this._renderer.onSelectionChanged(this._selectionState.start, this._selectionState.end, this._selectionState.columnSelectMode);\n this._needsSelectionRefresh = false;\n }\n\n // Fire render event only if it was not a redraw\n if (!this._isNextRenderRedrawOnly) {\n this._onRender.fire({ start, end });\n }\n this._isNextRenderRedrawOnly = true;\n }\n\n public resize(cols: number, rows: number): void {\n this._rowCount = rows;\n this._fireOnCanvasResize();\n }\n\n public changeOptions(): void {\n this._renderer.onOptionsChanged();\n this.refreshRows(0, this._rowCount - 1);\n this._fireOnCanvasResize();\n }\n\n private _fireOnCanvasResize(): void {\n // Don't fire the event if the dimensions haven't changed\n if (this._renderer.dimensions.canvasWidth === this._canvasWidth && this._renderer.dimensions.canvasHeight === this._canvasHeight) {\n return;\n }\n this._onDimensionsChange.fire(this._renderer.dimensions);\n }\n\n public dispose(): void {\n super.dispose();\n }\n\n public setRenderer(renderer: IRenderer): void {\n // TODO: RenderService should be the only one to dispose the renderer\n this._renderer.dispose();\n this._renderer = renderer;\n this._renderer.onRequestRedraw(e => this.refreshRows(e.start, e.end, true));\n\n // Force a refresh\n this._needsSelectionRefresh = true;\n this._fullRefresh();\n }\n\n private _fullRefresh(): void {\n if (this._isPaused) {\n this._needsFullRefresh = true;\n } else {\n this.refreshRows(0, this._rowCount - 1);\n }\n }\n\n public setColors(colors: IColorSet): void {\n this._renderer.setColors(colors);\n this._fullRefresh();\n }\n\n public onDevicePixelRatioChange(): void {\n // Force char size measurement as DomMeasureStrategy(getBoundingClientRect) is not stable\n // when devicePixelRatio changes\n this._charSizeService.measure();\n\n this._renderer.onDevicePixelRatioChange();\n this.refreshRows(0, this._rowCount - 1);\n }\n\n public onResize(cols: number, rows: number): void {\n this._renderer.onResize(cols, rows);\n this._fullRefresh();\n }\n\n // TODO: Is this useful when we have onResize?\n public onCharSizeChanged(): void {\n this._renderer.onCharSizeChanged();\n }\n\n public onBlur(): void {\n this._renderer.onBlur();\n }\n\n public onFocus(): void {\n this._renderer.onFocus();\n }\n\n public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void {\n this._selectionState.start = start;\n this._selectionState.end = end;\n this._selectionState.columnSelectMode = columnSelectMode;\n this._renderer.onSelectionChanged(start, end, columnSelectMode);\n }\n\n public onCursorMove(): void {\n this._renderer.onCursorMove();\n }\n\n public clear(): void {\n this._renderer.clear();\n }\n\n public registerCharacterJoiner(handler: CharacterJoinerHandler): number {\n return this._renderer.registerCharacterJoiner(handler);\n }\n\n public deregisterCharacterJoiner(joinerId: number): boolean {\n return this._renderer.deregisterCharacterJoiner(joinerId);\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ISelectionRedrawRequestEvent, ISelectionRequestScrollLinesEvent } from 'browser/selection/Types';\nimport { IBuffer } from 'common/buffer/Types';\nimport { IBufferLine, IDisposable } from 'common/Types';\nimport * as Browser from 'common/Platform';\nimport { SelectionModel } from 'browser/selection/SelectionModel';\nimport { CellData } from 'common/buffer/CellData';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { ICharSizeService, IMouseService, ISelectionService, IRenderService } from 'browser/services/Services';\nimport { IBufferService, IOptionsService, ICoreService } from 'common/services/Services';\nimport { getCoordsRelativeToElement } from 'browser/input/Mouse';\nimport { moveToCellSequence } from 'browser/input/MoveToCell';\nimport { Disposable } from 'common/Lifecycle';\n\n/**\n * The number of pixels the mouse needs to be above or below the viewport in\n * order to scroll at the maximum speed.\n */\nconst DRAG_SCROLL_MAX_THRESHOLD = 50;\n\n/**\n * The maximum scrolling speed\n */\nconst DRAG_SCROLL_MAX_SPEED = 15;\n\n/**\n * The number of milliseconds between drag scroll updates.\n */\nconst DRAG_SCROLL_INTERVAL = 50;\n\n/**\n * The maximum amount of time that can have elapsed for an alt click to move the\n * cursor.\n */\nconst ALT_CLICK_MOVE_CURSOR_TIME = 500;\n\nconst NON_BREAKING_SPACE_CHAR = String.fromCharCode(160);\nconst ALL_NON_BREAKING_SPACE_REGEX = new RegExp(NON_BREAKING_SPACE_CHAR, 'g');\n\n/**\n * Represents a position of a word on a line.\n */\ninterface IWordPosition {\n start: number;\n length: number;\n}\n\n/**\n * A selection mode, this drives how the selection behaves on mouse move.\n */\nexport const enum SelectionMode {\n NORMAL,\n WORD,\n LINE,\n COLUMN\n}\n\n/**\n * A class that manages the selection of the terminal. With help from\n * SelectionModel, SelectionService handles with all logic associated with\n * dealing with the selection, including handling mouse interaction, wide\n * characters and fetching the actual text within the selection. Rendering is\n * not handled by the SelectionService but the onRedrawRequest event is fired\n * when the selection is ready to be redrawn (on an animation frame).\n */\nexport class SelectionService extends Disposable implements ISelectionService {\n public serviceBrand: undefined;\n\n protected _model: SelectionModel;\n\n /**\n * The amount to scroll every drag scroll update (depends on how far the mouse\n * drag is above or below the terminal).\n */\n private _dragScrollAmount: number = 0;\n\n /**\n * The current selection mode.\n */\n protected _activeSelectionMode: SelectionMode;\n\n /**\n * A setInterval timer that is active while the mouse is down whose callback\n * scrolls the viewport when necessary.\n */\n private _dragScrollIntervalTimer: number | undefined;\n\n /**\n * The animation frame ID used for refreshing the selection.\n */\n private _refreshAnimationFrame: number | undefined;\n\n /**\n * Whether selection is enabled.\n */\n private _enabled = true;\n\n private _mouseMoveListener: EventListener;\n private _mouseUpListener: EventListener;\n private _trimListener: IDisposable;\n private _workCell: CellData = new CellData();\n\n private _mouseDownTimeStamp: number = 0;\n private _oldHasSelection: boolean = false;\n private _oldSelectionStart: [number, number] | undefined = undefined;\n private _oldSelectionEnd: [number, number] | undefined = undefined;\n\n private _onLinuxMouseSelection = this.register(new EventEmitter());\n public get onLinuxMouseSelection(): IEvent { return this._onLinuxMouseSelection.event; }\n private _onRedrawRequest = this.register(new EventEmitter());\n public get onRequestRedraw(): IEvent { return this._onRedrawRequest.event; }\n private _onSelectionChange = this.register(new EventEmitter());\n public get onSelectionChange(): IEvent { return this._onSelectionChange.event; }\n private _onRequestScrollLines = this.register(new EventEmitter());\n public get onRequestScrollLines(): IEvent { return this._onRequestScrollLines.event; }\n\n constructor(\n private readonly _element: HTMLElement,\n private readonly _screenElement: HTMLElement,\n @IBufferService private readonly _bufferService: IBufferService,\n @ICoreService private readonly _coreService: ICoreService,\n @IMouseService private readonly _mouseService: IMouseService,\n @IOptionsService private readonly _optionsService: IOptionsService,\n @IRenderService private readonly _renderService: IRenderService\n ) {\n super();\n\n // Init listeners\n this._mouseMoveListener = event => this._onMouseMove(event);\n this._mouseUpListener = event => this._onMouseUp(event);\n this._coreService.onUserInput(() => {\n if (this.hasSelection) {\n this.clearSelection();\n }\n });\n this._trimListener = this._bufferService.buffer.lines.onTrim(amount => this._onTrim(amount));\n this.register(this._bufferService.buffers.onBufferActivate(e => this._onBufferActivate(e)));\n\n this.enable();\n\n this._model = new SelectionModel(this._bufferService);\n this._activeSelectionMode = SelectionMode.NORMAL;\n }\n\n public dispose(): void {\n this._removeMouseDownListeners();\n }\n\n public reset(): void {\n this.clearSelection();\n }\n\n /**\n * Disables the selection manager. This is useful for when terminal mouse\n * are enabled.\n */\n public disable(): void {\n this.clearSelection();\n this._enabled = false;\n }\n\n /**\n * Enable the selection manager.\n */\n public enable(): void {\n this._enabled = true;\n }\n\n public get selectionStart(): [number, number] | undefined { return this._model.finalSelectionStart; }\n public get selectionEnd(): [number, number] | undefined { return this._model.finalSelectionEnd; }\n\n /**\n * Gets whether there is an active text selection.\n */\n public get hasSelection(): boolean {\n const start = this._model.finalSelectionStart;\n const end = this._model.finalSelectionEnd;\n if (!start || !end) {\n return false;\n }\n return start[0] !== end[0] || start[1] !== end[1];\n }\n\n /**\n * Gets the text currently selected.\n */\n public get selectionText(): string {\n const start = this._model.finalSelectionStart;\n const end = this._model.finalSelectionEnd;\n if (!start || !end) {\n return '';\n }\n\n const buffer = this._bufferService.buffer;\n const result: string[] = [];\n\n if (this._activeSelectionMode === SelectionMode.COLUMN) {\n // Ignore zero width selections\n if (start[0] === end[0]) {\n return '';\n }\n\n for (let i = start[1]; i <= end[1]; i++) {\n const lineText = buffer.translateBufferLineToString(i, true, start[0], end[0]);\n result.push(lineText);\n }\n } else {\n // Get first row\n const startRowEndCol = start[1] === end[1] ? end[0] : undefined;\n result.push(buffer.translateBufferLineToString(start[1], true, start[0], startRowEndCol));\n\n // Get middle rows\n for (let i = start[1] + 1; i <= end[1] - 1; i++) {\n const bufferLine = buffer.lines.get(i);\n const lineText = buffer.translateBufferLineToString(i, true);\n if (bufferLine && bufferLine.isWrapped) {\n result[result.length - 1] += lineText;\n } else {\n result.push(lineText);\n }\n }\n\n // Get final row\n if (start[1] !== end[1]) {\n const bufferLine = buffer.lines.get(end[1]);\n const lineText = buffer.translateBufferLineToString(end[1], true, 0, end[0]);\n if (bufferLine && bufferLine!.isWrapped) {\n result[result.length - 1] += lineText;\n } else {\n result.push(lineText);\n }\n }\n }\n\n // Format string by replacing non-breaking space chars with regular spaces\n // and joining the array into a multi-line string.\n const formattedResult = result.map(line => {\n return line.replace(ALL_NON_BREAKING_SPACE_REGEX, ' ');\n }).join(Browser.isWindows ? '\\r\\n' : '\\n');\n\n return formattedResult;\n }\n\n /**\n * Clears the current terminal selection.\n */\n public clearSelection(): void {\n this._model.clearSelection();\n this._removeMouseDownListeners();\n this.refresh();\n this._onSelectionChange.fire();\n }\n\n /**\n * Queues a refresh, redrawing the selection on the next opportunity.\n * @param isLinuxMouseSelection Whether the selection should be registered as a new\n * selection on Linux.\n */\n public refresh(isLinuxMouseSelection?: boolean): void {\n // Queue the refresh for the renderer\n if (!this._refreshAnimationFrame) {\n this._refreshAnimationFrame = window.requestAnimationFrame(() => this._refresh());\n }\n\n // If the platform is Linux and the refresh call comes from a mouse event,\n // we need to update the selection for middle click to paste selection.\n if (Browser.isLinux && isLinuxMouseSelection) {\n const selectionText = this.selectionText;\n if (selectionText.length) {\n this._onLinuxMouseSelection.fire(this.selectionText);\n }\n }\n }\n\n /**\n * Fires the refresh event, causing consumers to pick it up and redraw the\n * selection state.\n */\n private _refresh(): void {\n this._refreshAnimationFrame = undefined;\n this._onRedrawRequest.fire({\n start: this._model.finalSelectionStart,\n end: this._model.finalSelectionEnd,\n columnSelectMode: this._activeSelectionMode === SelectionMode.COLUMN\n });\n }\n\n /**\n * Checks if the current click was inside the current selection\n * @param event The mouse event\n */\n private _isClickInSelection(event: MouseEvent): boolean {\n const coords = this._getMouseBufferCoords(event);\n const start = this._model.finalSelectionStart;\n const end = this._model.finalSelectionEnd;\n\n if (!start || !end || !coords) {\n return false;\n }\n\n return this._areCoordsInSelection(coords, start, end);\n }\n\n protected _areCoordsInSelection(coords: [number, number], start: [number, number], end: [number, number]): boolean {\n return (coords[1] > start[1] && coords[1] < end[1]) ||\n (start[1] === end[1] && coords[1] === start[1] && coords[0] >= start[0] && coords[0] < end[0]) ||\n (start[1] < end[1] && coords[1] === end[1] && coords[0] < end[0]) ||\n (start[1] < end[1] && coords[1] === start[1] && coords[0] >= start[0]);\n }\n\n /**\n * Selects word at the current mouse event coordinates.\n * @param event The mouse event.\n */\n private _selectWordAtCursor(event: MouseEvent): void {\n const coords = this._getMouseBufferCoords(event);\n if (coords) {\n this._selectWordAt(coords, false);\n this._model.selectionEnd = undefined;\n this.refresh(true);\n }\n }\n\n /**\n * Selects all text within the terminal.\n */\n public selectAll(): void {\n this._model.isSelectAllActive = true;\n this.refresh();\n this._onSelectionChange.fire();\n }\n\n public selectLines(start: number, end: number): void {\n this._model.clearSelection();\n start = Math.max(start, 0);\n end = Math.min(end, this._bufferService.buffer.lines.length - 1);\n this._model.selectionStart = [0, start];\n this._model.selectionEnd = [this._bufferService.cols, end];\n this.refresh();\n this._onSelectionChange.fire();\n }\n\n /**\n * Handle the buffer being trimmed, adjust the selection position.\n * @param amount The amount the buffer is being trimmed.\n */\n private _onTrim(amount: number): void {\n const needsRefresh = this._model.onTrim(amount);\n if (needsRefresh) {\n this.refresh();\n }\n }\n\n /**\n * Gets the 0-based [x, y] buffer coordinates of the current mouse event.\n * @param event The mouse event.\n */\n private _getMouseBufferCoords(event: MouseEvent): [number, number] | undefined {\n const coords = this._mouseService.getCoords(event, this._screenElement, this._bufferService.cols, this._bufferService.rows, true);\n if (!coords) {\n return undefined;\n }\n\n // Convert to 0-based\n coords[0]--;\n coords[1]--;\n\n // Convert viewport coords to buffer coords\n coords[1] += this._bufferService.buffer.ydisp;\n return coords;\n }\n\n /**\n * Gets the amount the viewport should be scrolled based on how far out of the\n * terminal the mouse is.\n * @param event The mouse event.\n */\n private _getMouseEventScrollAmount(event: MouseEvent): number {\n let offset = getCoordsRelativeToElement(event, this._screenElement)[1];\n const terminalHeight = this._renderService.dimensions.canvasHeight;\n if (offset >= 0 && offset <= terminalHeight) {\n return 0;\n }\n if (offset > terminalHeight) {\n offset -= terminalHeight;\n }\n\n offset = Math.min(Math.max(offset, -DRAG_SCROLL_MAX_THRESHOLD), DRAG_SCROLL_MAX_THRESHOLD);\n offset /= DRAG_SCROLL_MAX_THRESHOLD;\n return (offset / Math.abs(offset)) + Math.round(offset * (DRAG_SCROLL_MAX_SPEED - 1));\n }\n\n /**\n * Returns whether the selection manager should force selection, regardless of\n * whether the terminal is in mouse events mode.\n * @param event The mouse event.\n */\n public shouldForceSelection(event: MouseEvent): boolean {\n if (Browser.isMac) {\n return event.altKey && this._optionsService.options.macOptionClickForcesSelection;\n }\n\n return event.shiftKey;\n }\n\n /**\n * Handles te mousedown event, setting up for a new selection.\n * @param event The mousedown event.\n */\n public onMouseDown(event: MouseEvent): void {\n this._mouseDownTimeStamp = event.timeStamp;\n // If we have selection, we want the context menu on right click even if the\n // terminal is in mouse mode.\n if (event.button === 2 && this.hasSelection) {\n return;\n }\n\n // Only action the primary button\n if (event.button !== 0) {\n return;\n }\n\n // Allow selection when using a specific modifier key, even when disabled\n if (!this._enabled) {\n if (!this.shouldForceSelection(event)) {\n return;\n }\n\n // Don't send the mouse down event to the current process, we want to select\n event.stopPropagation();\n }\n\n // Tell the browser not to start a regular selection\n event.preventDefault();\n\n // Reset drag scroll state\n this._dragScrollAmount = 0;\n\n if (this._enabled && event.shiftKey) {\n this._onIncrementalClick(event);\n } else {\n if (event.detail === 1) {\n this._onSingleClick(event);\n } else if (event.detail === 2) {\n this._onDoubleClick(event);\n } else if (event.detail === 3) {\n this._onTripleClick(event);\n }\n }\n\n this._addMouseDownListeners();\n this.refresh(true);\n }\n\n /**\n * Adds listeners when mousedown is triggered.\n */\n private _addMouseDownListeners(): void {\n // Listen on the document so that dragging outside of viewport works\n if (this._screenElement.ownerDocument) {\n this._screenElement.ownerDocument.addEventListener('mousemove', this._mouseMoveListener);\n this._screenElement.ownerDocument.addEventListener('mouseup', this._mouseUpListener);\n }\n this._dragScrollIntervalTimer = window.setInterval(() => this._dragScroll(), DRAG_SCROLL_INTERVAL);\n }\n\n /**\n * Removes the listeners that are registered when mousedown is triggered.\n */\n private _removeMouseDownListeners(): void {\n if (this._screenElement.ownerDocument) {\n this._screenElement.ownerDocument.removeEventListener('mousemove', this._mouseMoveListener);\n this._screenElement.ownerDocument.removeEventListener('mouseup', this._mouseUpListener);\n }\n clearInterval(this._dragScrollIntervalTimer);\n this._dragScrollIntervalTimer = undefined;\n }\n\n /**\n * Performs an incremental click, setting the selection end position to the mouse\n * position.\n * @param event The mouse event.\n */\n private _onIncrementalClick(event: MouseEvent): void {\n if (this._model.selectionStart) {\n this._model.selectionEnd = this._getMouseBufferCoords(event);\n }\n }\n\n /**\n * Performs a single click, resetting relevant state and setting the selection\n * start position.\n * @param event The mouse event.\n */\n private _onSingleClick(event: MouseEvent): void {\n this._model.selectionStartLength = 0;\n this._model.isSelectAllActive = false;\n this._activeSelectionMode = this.shouldColumnSelect(event) ? SelectionMode.COLUMN : SelectionMode.NORMAL;\n\n // Initialize the new selection\n this._model.selectionStart = this._getMouseBufferCoords(event);\n if (!this._model.selectionStart) {\n return;\n }\n this._model.selectionEnd = undefined;\n\n // Ensure the line exists\n const line = this._bufferService.buffer.lines.get(this._model.selectionStart[1]);\n if (!line) {\n return;\n }\n\n // Return early if the click event is not in the buffer (eg. in scroll bar)\n if (line.length === this._model.selectionStart[0]) {\n return;\n }\n\n // If the mouse is over the second half of a wide character, adjust the\n // selection to cover the whole character\n if (line.hasWidth(this._model.selectionStart[0]) === 0) {\n this._model.selectionStart[0]++;\n }\n }\n\n /**\n * Performs a double click, selecting the current work.\n * @param event The mouse event.\n */\n private _onDoubleClick(event: MouseEvent): void {\n const coords = this._getMouseBufferCoords(event);\n if (coords) {\n this._activeSelectionMode = SelectionMode.WORD;\n this._selectWordAt(coords, true);\n }\n }\n\n /**\n * Performs a triple click, selecting the current line and activating line\n * select mode.\n * @param event The mouse event.\n */\n private _onTripleClick(event: MouseEvent): void {\n const coords = this._getMouseBufferCoords(event);\n if (coords) {\n this._activeSelectionMode = SelectionMode.LINE;\n this._selectLineAt(coords[1]);\n }\n }\n\n /**\n * Returns whether the selection manager should operate in column select mode\n * @param event the mouse or keyboard event\n */\n public shouldColumnSelect(event: KeyboardEvent | MouseEvent): boolean {\n return event.altKey && !(Browser.isMac && this._optionsService.options.macOptionClickForcesSelection);\n }\n\n /**\n * Handles the mousemove event when the mouse button is down, recording the\n * end of the selection and refreshing the selection.\n * @param event The mousemove event.\n */\n private _onMouseMove(event: MouseEvent): void {\n // If the mousemove listener is active it means that a selection is\n // currently being made, we should stop propagation to prevent mouse events\n // to be sent to the pty.\n event.stopImmediatePropagation();\n\n // Do nothing if there is no selection start, this can happen if the first\n // click in the terminal is an incremental click\n if (!this._model.selectionStart) {\n return;\n }\n\n // Record the previous position so we know whether to redraw the selection\n // at the end.\n const previousSelectionEnd = this._model.selectionEnd ? [this._model.selectionEnd[0], this._model.selectionEnd[1]] : null;\n\n // Set the initial selection end based on the mouse coordinates\n this._model.selectionEnd = this._getMouseBufferCoords(event);\n if (!this._model.selectionEnd) {\n this.refresh(true);\n return;\n }\n\n // Select the entire line if line select mode is active.\n if (this._activeSelectionMode === SelectionMode.LINE) {\n if (this._model.selectionEnd[1] < this._model.selectionStart[1]) {\n this._model.selectionEnd[0] = 0;\n } else {\n this._model.selectionEnd[0] = this._bufferService.cols;\n }\n } else if (this._activeSelectionMode === SelectionMode.WORD) {\n this._selectToWordAt(this._model.selectionEnd);\n }\n\n // Determine the amount of scrolling that will happen.\n this._dragScrollAmount = this._getMouseEventScrollAmount(event);\n\n // If the cursor was above or below the viewport, make sure it's at the\n // start or end of the viewport respectively. This should only happen when\n // NOT in column select mode.\n if (this._activeSelectionMode !== SelectionMode.COLUMN) {\n if (this._dragScrollAmount > 0) {\n this._model.selectionEnd[0] = this._bufferService.cols;\n } else if (this._dragScrollAmount < 0) {\n this._model.selectionEnd[0] = 0;\n }\n }\n\n // If the character is a wide character include the cell to the right in the\n // selection. Note that selections at the very end of the line will never\n // have a character.\n const buffer = this._bufferService.buffer;\n if (this._model.selectionEnd[1] < buffer.lines.length) {\n const line = buffer.lines.get(this._model.selectionEnd[1]);\n if (line && line.hasWidth(this._model.selectionEnd[0]) === 0) {\n this._model.selectionEnd[0]++;\n }\n }\n\n // Only draw here if the selection changes.\n if (!previousSelectionEnd ||\n previousSelectionEnd[0] !== this._model.selectionEnd[0] ||\n previousSelectionEnd[1] !== this._model.selectionEnd[1]) {\n this.refresh(true);\n }\n }\n\n /**\n * The callback that occurs every DRAG_SCROLL_INTERVAL ms that does the\n * scrolling of the viewport.\n */\n private _dragScroll(): void {\n if (!this._model.selectionEnd || !this._model.selectionStart) {\n return;\n }\n if (this._dragScrollAmount) {\n this._onRequestScrollLines.fire({ amount: this._dragScrollAmount, suppressScrollEvent: false });\n // Re-evaluate selection\n // If the cursor was above or below the viewport, make sure it's at the\n // start or end of the viewport respectively. This should only happen when\n // NOT in column select mode.\n const buffer = this._bufferService.buffer;\n if (this._dragScrollAmount > 0) {\n if (this._activeSelectionMode !== SelectionMode.COLUMN) {\n this._model.selectionEnd[0] = this._bufferService.cols;\n }\n this._model.selectionEnd[1] = Math.min(buffer.ydisp + this._bufferService.rows, buffer.lines.length - 1);\n } else {\n if (this._activeSelectionMode !== SelectionMode.COLUMN) {\n this._model.selectionEnd[0] = 0;\n }\n this._model.selectionEnd[1] = buffer.ydisp;\n }\n this.refresh();\n }\n }\n\n /**\n * Handles the mouseup event, removing the mousedown listeners.\n * @param event The mouseup event.\n */\n private _onMouseUp(event: MouseEvent): void {\n const timeElapsed = event.timeStamp - this._mouseDownTimeStamp;\n\n this._removeMouseDownListeners();\n\n if (this.selectionText.length <= 1 && timeElapsed < ALT_CLICK_MOVE_CURSOR_TIME && event.altKey && this._optionsService.getOption('altClickMovesCursor')) {\n if (this._bufferService.buffer.ybase === this._bufferService.buffer.ydisp) {\n const coordinates = this._mouseService.getCoords(\n event,\n this._element,\n this._bufferService.cols,\n this._bufferService.rows,\n false\n );\n if (coordinates && coordinates[0] !== undefined && coordinates[1] !== undefined) {\n const sequence = moveToCellSequence(coordinates[0] - 1, coordinates[1] - 1, this._bufferService, this._coreService.decPrivateModes.applicationCursorKeys);\n this._coreService.triggerDataEvent(sequence, true);\n }\n }\n } else {\n this._fireEventIfSelectionChanged();\n }\n }\n\n private _fireEventIfSelectionChanged(): void {\n const start = this._model.finalSelectionStart;\n const end = this._model.finalSelectionEnd;\n const hasSelection = !!start && !!end && (start[0] !== end[0] || start[1] !== end[1]);\n\n if (!hasSelection) {\n if (this._oldHasSelection) {\n this._fireOnSelectionChange(start, end, hasSelection);\n }\n return;\n }\n\n // Sanity check, these should not be undefined as there is a selection\n if (!start || !end) {\n return;\n }\n\n if (!this._oldSelectionStart || !this._oldSelectionEnd || (\n start[0] !== this._oldSelectionStart[0] || start[1] !== this._oldSelectionStart[1] ||\n end[0] !== this._oldSelectionEnd[0] || end[1] !== this._oldSelectionEnd[1])) {\n\n this._fireOnSelectionChange(start, end, hasSelection);\n }\n }\n\n private _fireOnSelectionChange(start: [number, number] | undefined, end: [number, number] | undefined, hasSelection: boolean): void {\n this._oldSelectionStart = start;\n this._oldSelectionEnd = end;\n this._oldHasSelection = hasSelection;\n this._onSelectionChange.fire();\n }\n\n private _onBufferActivate(e: {activeBuffer: IBuffer, inactiveBuffer: IBuffer}): void {\n this.clearSelection();\n // Only adjust the selection on trim, shiftElements is rarely used (only in\n // reverseIndex) and delete in a splice is only ever used when the same\n // number of elements was just added. Given this is could actually be\n // beneficial to leave the selection as is for these cases.\n this._trimListener.dispose();\n this._trimListener = e.activeBuffer.lines.onTrim(amount => this._onTrim(amount));\n }\n\n /**\n * Converts a viewport column to the character index on the buffer line, the\n * latter takes into account wide characters.\n * @param coords The coordinates to find the 2 index for.\n */\n private _convertViewportColToCharacterIndex(bufferLine: IBufferLine, coords: [number, number]): number {\n let charIndex = coords[0];\n for (let i = 0; coords[0] >= i; i++) {\n const length = bufferLine.loadCell(i, this._workCell).getChars().length;\n if (this._workCell.getWidth() === 0) {\n // Wide characters aren't included in the line string so decrement the\n // index so the index is back on the wide character.\n charIndex--;\n } else if (length > 1 && coords[0] !== i) {\n // Emojis take up multiple characters, so adjust accordingly. For these\n // we don't want ot include the character at the column as we're\n // returning the start index in the string, not the end index.\n charIndex += length - 1;\n }\n }\n return charIndex;\n }\n\n public setSelection(col: number, row: number, length: number): void {\n this._model.clearSelection();\n this._removeMouseDownListeners();\n this._model.selectionStart = [col, row];\n this._model.selectionStartLength = length;\n this.refresh();\n }\n\n public rightClickSelect(ev: MouseEvent): void {\n if (!this._isClickInSelection(ev)) {\n this._selectWordAtCursor(ev);\n this._fireEventIfSelectionChanged();\n }\n }\n\n /**\n * Gets positional information for the word at the coordinated specified.\n * @param coords The coordinates to get the word at.\n */\n private _getWordAt(coords: [number, number], allowWhitespaceOnlySelection: boolean, followWrappedLinesAbove: boolean = true, followWrappedLinesBelow: boolean = true): IWordPosition | undefined {\n // Ensure coords are within viewport (eg. not within scroll bar)\n if (coords[0] >= this._bufferService.cols) {\n return undefined;\n }\n\n const buffer = this._bufferService.buffer;\n const bufferLine = buffer.lines.get(coords[1]);\n if (!bufferLine) {\n return undefined;\n }\n\n const line = buffer.translateBufferLineToString(coords[1], false);\n\n // Get actual index, taking into consideration wide characters\n let startIndex = this._convertViewportColToCharacterIndex(bufferLine, coords);\n let endIndex = startIndex;\n\n // Record offset to be used later\n const charOffset = coords[0] - startIndex;\n let leftWideCharCount = 0;\n let rightWideCharCount = 0;\n let leftLongCharOffset = 0;\n let rightLongCharOffset = 0;\n\n if (line.charAt(startIndex) === ' ') {\n // Expand until non-whitespace is hit\n while (startIndex > 0 && line.charAt(startIndex - 1) === ' ') {\n startIndex--;\n }\n while (endIndex < line.length && line.charAt(endIndex + 1) === ' ') {\n endIndex++;\n }\n } else {\n // Expand until whitespace is hit. This algorithm works by scanning left\n // and right from the starting position, keeping both the index format\n // (line) and the column format (bufferLine) in sync. When a wide\n // character is hit, it is recorded and the column index is adjusted.\n let startCol = coords[0];\n let endCol = coords[0];\n\n // Consider the initial position, skip it and increment the wide char\n // variable\n if (bufferLine.getWidth(startCol) === 0) {\n leftWideCharCount++;\n startCol--;\n }\n if (bufferLine.getWidth(endCol) === 2) {\n rightWideCharCount++;\n endCol++;\n }\n\n // Adjust the end index for characters whose length are > 1 (emojis)\n const length = bufferLine.getString(endCol).length;\n if (length > 1) {\n rightLongCharOffset += length - 1;\n endIndex += length - 1;\n }\n\n // Expand the string in both directions until a space is hit\n while (startCol > 0 && startIndex > 0 && !this._isCharWordSeparator(bufferLine.loadCell(startCol - 1, this._workCell))) {\n bufferLine.loadCell(startCol - 1, this._workCell);\n const length = this._workCell.getChars().length;\n if (this._workCell.getWidth() === 0) {\n // If the next character is a wide char, record it and skip the column\n leftWideCharCount++;\n startCol--;\n } else if (length > 1) {\n // If the next character's string is longer than 1 char (eg. emoji),\n // adjust the index\n leftLongCharOffset += length - 1;\n startIndex -= length - 1;\n }\n startIndex--;\n startCol--;\n }\n while (endCol < bufferLine.length && endIndex + 1 < line.length && !this._isCharWordSeparator(bufferLine.loadCell(endCol + 1, this._workCell))) {\n bufferLine.loadCell(endCol + 1, this._workCell);\n const length = this._workCell.getChars().length;\n if (this._workCell.getWidth() === 2) {\n // If the next character is a wide char, record it and skip the column\n rightWideCharCount++;\n endCol++;\n } else if (length > 1) {\n // If the next character's string is longer than 1 char (eg. emoji),\n // adjust the index\n rightLongCharOffset += length - 1;\n endIndex += length - 1;\n }\n endIndex++;\n endCol++;\n }\n }\n\n // Incremenet the end index so it is at the start of the next character\n endIndex++;\n\n // Calculate the start _column_, converting the the string indexes back to\n // column coordinates.\n let start =\n startIndex // The index of the selection's start char in the line string\n + charOffset // The difference between the initial char's column and index\n - leftWideCharCount // The number of wide chars left of the initial char\n + leftLongCharOffset; // The number of additional chars left of the initial char added by columns with strings longer than 1 (emojis)\n\n // Calculate the length in _columns_, converting the the string indexes back\n // to column coordinates.\n let length = Math.min(this._bufferService.cols, // Disallow lengths larger than the terminal cols\n endIndex // The index of the selection's end char in the line string\n - startIndex // The index of the selection's start char in the line string\n + leftWideCharCount // The number of wide chars left of the initial char\n + rightWideCharCount // The number of wide chars right of the initial char (inclusive)\n - leftLongCharOffset // The number of additional chars left of the initial char added by columns with strings longer than 1 (emojis)\n - rightLongCharOffset); // The number of additional chars right of the initial char (inclusive) added by columns with strings longer than 1 (emojis)\n\n if (!allowWhitespaceOnlySelection && line.slice(startIndex, endIndex).trim() === '') {\n return undefined;\n }\n\n // Recurse upwards if the line is wrapped and the word wraps to the above line\n if (followWrappedLinesAbove) {\n if (start === 0 && bufferLine.getCodePoint(0) !== 32 /* ' ' */) {\n const previousBufferLine = buffer.lines.get(coords[1] - 1);\n if (previousBufferLine && bufferLine.isWrapped && previousBufferLine.getCodePoint(this._bufferService.cols - 1) !== 32 /* ' ' */) {\n const previousLineWordPosition = this._getWordAt([this._bufferService.cols - 1, coords[1] - 1], false, true, false);\n if (previousLineWordPosition) {\n const offset = this._bufferService.cols - previousLineWordPosition.start;\n start -= offset;\n length += offset;\n }\n }\n }\n }\n\n // Recurse downwards if the line is wrapped and the word wraps to the next line\n if (followWrappedLinesBelow) {\n if (start + length === this._bufferService.cols && bufferLine.getCodePoint(this._bufferService.cols - 1) !== 32 /* ' ' */) {\n const nextBufferLine = buffer.lines.get(coords[1] + 1);\n if (nextBufferLine && nextBufferLine.isWrapped && nextBufferLine.getCodePoint(0) !== 32 /* ' ' */) {\n const nextLineWordPosition = this._getWordAt([0, coords[1] + 1], false, false, true);\n if (nextLineWordPosition) {\n length += nextLineWordPosition.length;\n }\n }\n }\n }\n\n return { start, length };\n }\n\n /**\n * Selects the word at the coordinates specified.\n * @param coords The coordinates to get the word at.\n * @param allowWhitespaceOnlySelection If whitespace should be selected\n */\n protected _selectWordAt(coords: [number, number], allowWhitespaceOnlySelection: boolean): void {\n const wordPosition = this._getWordAt(coords, allowWhitespaceOnlySelection);\n if (wordPosition) {\n // Adjust negative start value\n while (wordPosition.start < 0) {\n wordPosition.start += this._bufferService.cols;\n coords[1]--;\n }\n this._model.selectionStart = [wordPosition.start, coords[1]];\n this._model.selectionStartLength = wordPosition.length;\n }\n }\n\n /**\n * Sets the selection end to the word at the coordinated specified.\n * @param coords The coordinates to get the word at.\n */\n private _selectToWordAt(coords: [number, number]): void {\n const wordPosition = this._getWordAt(coords, true);\n if (wordPosition) {\n let endRow = coords[1];\n\n // Adjust negative start value\n while (wordPosition.start < 0) {\n wordPosition.start += this._bufferService.cols;\n endRow--;\n }\n\n // Adjust wrapped length value, this only needs to happen when values are reversed as in that\n // case we're interested in the start of the word, not the end\n if (!this._model.areSelectionValuesReversed()) {\n while (wordPosition.start + wordPosition.length > this._bufferService.cols) {\n wordPosition.length -= this._bufferService.cols;\n endRow++;\n }\n }\n\n this._model.selectionEnd = [this._model.areSelectionValuesReversed() ? wordPosition.start : wordPosition.start + wordPosition.length, endRow];\n }\n }\n\n /**\n * Gets whether the character is considered a word separator by the select\n * word logic.\n * @param char The character to check.\n */\n private _isCharWordSeparator(cell: CellData): boolean {\n // Zero width characters are never separators as they are always to the\n // right of wide characters\n if (cell.getWidth() === 0) {\n return false;\n }\n return this._optionsService.options.wordSeparator.indexOf(cell.getChars()) >= 0;\n }\n\n /**\n * Selects the line specified.\n * @param line The line index.\n */\n protected _selectLineAt(line: number): void {\n const wrappedRange = this._bufferService.buffer.getWrappedRangeForLine(line);\n this._model.selectionStart = [0, wrappedRange.first];\n this._model.selectionEnd = [this._bufferService.cols, wrappedRange.last];\n this._model.selectionStartLength = 0;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IEvent } from 'common/EventEmitter';\nimport { IRenderDimensions, IRenderer, CharacterJoinerHandler } from 'browser/renderer/Types';\nimport { IColorSet } from 'browser/Types';\nimport { ISelectionRedrawRequestEvent as ISelectionRequestRedrawEvent, ISelectionRequestScrollLinesEvent } from 'browser/selection/Types';\nimport { createDecorator } from 'common/services/ServiceRegistry';\nimport { IDisposable } from 'common/Types';\n\nexport const ICharSizeService = createDecorator('CharSizeService');\nexport interface ICharSizeService {\n serviceBrand: undefined;\n\n readonly width: number;\n readonly height: number;\n readonly hasValidSize: boolean;\n\n readonly onCharSizeChange: IEvent;\n\n measure(): void;\n}\n\nexport const ICoreBrowserService = createDecorator('CoreBrowserService');\nexport interface ICoreBrowserService {\n serviceBrand: undefined;\n\n readonly isFocused: boolean;\n}\n\nexport const IMouseService = createDecorator('MouseService');\nexport interface IMouseService {\n serviceBrand: undefined;\n\n getCoords(event: {clientX: number, clientY: number}, element: HTMLElement, colCount: number, rowCount: number, isSelection?: boolean): [number, number] | undefined;\n getRawByteCoords(event: MouseEvent, element: HTMLElement, colCount: number, rowCount: number): { x: number, y: number } | undefined;\n}\n\nexport const IRenderService = createDecorator('RenderService');\nexport interface IRenderService extends IDisposable {\n serviceBrand: undefined;\n\n onDimensionsChange: IEvent;\n /**\n * Fires when buffer changes are rendered. This does not fire when only cursor\n * or selections are rendered.\n */\n onRenderedBufferChange: IEvent<{ start: number, end: number }>;\n onRefreshRequest: IEvent<{ start: number, end: number }>;\n\n dimensions: IRenderDimensions;\n\n refreshRows(start: number, end: number): void;\n resize(cols: number, rows: number): void;\n changeOptions(): void;\n setRenderer(renderer: IRenderer): void;\n setColors(colors: IColorSet): void;\n onDevicePixelRatioChange(): void;\n onResize(cols: number, rows: number): void;\n // TODO: Is this useful when we have onResize?\n onCharSizeChanged(): void;\n onBlur(): void;\n onFocus(): void;\n onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void;\n onCursorMove(): void;\n clear(): void;\n registerCharacterJoiner(handler: CharacterJoinerHandler): number;\n deregisterCharacterJoiner(joinerId: number): boolean;\n}\n\nexport const ISelectionService = createDecorator('SelectionService');\nexport interface ISelectionService {\n serviceBrand: undefined;\n\n readonly selectionText: string;\n readonly hasSelection: boolean;\n readonly selectionStart: [number, number] | undefined;\n readonly selectionEnd: [number, number] | undefined;\n\n readonly onLinuxMouseSelection: IEvent;\n readonly onRequestRedraw: IEvent;\n readonly onRequestScrollLines: IEvent;\n readonly onSelectionChange: IEvent;\n\n disable(): void;\n enable(): void;\n reset(): void;\n setSelection(row: number, col: number, length: number): void;\n selectAll(): void;\n selectLines(start: number, end: number): void;\n clearSelection(): void;\n rightClickSelect(event: MouseEvent): void;\n shouldColumnSelect(event: KeyboardEvent | MouseEvent): boolean;\n shouldForceSelection(event: MouseEvent): boolean;\n refresh(isLinuxMouseSelection?: boolean): void;\n onMouseDown(event: MouseEvent): void;\n}\n\nexport const ISoundService = createDecorator('SoundService');\nexport interface ISoundService {\n serviceBrand: undefined;\n\n playBellSound(): void;\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IOptionsService } from 'common/services/Services';\nimport { ISoundService } from 'browser/services/Services';\n\nexport class SoundService implements ISoundService {\n public serviceBrand: undefined;\n\n private static _audioContext: AudioContext;\n\n public static get audioContext(): AudioContext | null {\n if (!SoundService._audioContext) {\n const audioContextCtor: typeof AudioContext = (window).AudioContext || (window).webkitAudioContext;\n if (!audioContextCtor) {\n console.warn('Web Audio API is not supported by this browser. Consider upgrading to the latest version');\n return null;\n }\n SoundService._audioContext = new audioContextCtor();\n }\n return SoundService._audioContext;\n }\n\n constructor(\n @IOptionsService private _optionsService: IOptionsService\n ) {\n }\n\n public playBellSound(): void {\n const ctx = SoundService.audioContext;\n if (!ctx) {\n return;\n }\n const bellAudioSource = ctx.createBufferSource();\n ctx.decodeAudioData(this._base64ToArrayBuffer(this._removeMimeType(this._optionsService.options.bellSound)), (buffer) => {\n bellAudioSource.buffer = buffer;\n bellAudioSource.connect(ctx.destination);\n bellAudioSource.start(0);\n });\n }\n\n private _base64ToArrayBuffer(base64: string): ArrayBuffer {\n const binaryString = window.atob(base64);\n const len = binaryString.length;\n const bytes = new Uint8Array(len);\n\n for (let i = 0; i < len; i++) {\n bytes[i] = binaryString.charCodeAt(i);\n }\n\n return bytes.buffer;\n }\n\n private _removeMimeType(dataURI: string): string {\n // Split the input to get the mime-type and the data itself\n const splitUri = dataURI.split(',');\n\n // Return only the data\n return splitUri[1];\n }\n}\n","/**\n * Copyright (c) 2016 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ICircularList } from 'common/Types';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\n\nexport interface IInsertEvent {\n index: number;\n amount: number;\n}\n\nexport interface IDeleteEvent {\n index: number;\n amount: number;\n}\n\n/**\n * Represents a circular list; a list with a maximum size that wraps around when push is called,\n * overriding values at the start of the list.\n */\nexport class CircularList implements ICircularList {\n protected _array: (T | undefined)[];\n private _startIndex: number;\n private _length: number;\n\n public onDeleteEmitter = new EventEmitter();\n public get onDelete(): IEvent { return this.onDeleteEmitter.event; }\n public onInsertEmitter = new EventEmitter();\n public get onInsert(): IEvent { return this.onInsertEmitter.event; }\n public onTrimEmitter = new EventEmitter();\n public get onTrim(): IEvent { return this.onTrimEmitter.event; }\n\n constructor(\n private _maxLength: number\n ) {\n this._array = new Array(this._maxLength);\n this._startIndex = 0;\n this._length = 0;\n }\n\n public get maxLength(): number {\n return this._maxLength;\n }\n\n public set maxLength(newMaxLength: number) {\n // There was no change in maxLength, return early.\n if (this._maxLength === newMaxLength) {\n return;\n }\n\n // Reconstruct array, starting at index 0. Only transfer values from the\n // indexes 0 to length.\n const newArray = new Array(newMaxLength);\n for (let i = 0; i < Math.min(newMaxLength, this.length); i++) {\n newArray[i] = this._array[this._getCyclicIndex(i)];\n }\n this._array = newArray;\n this._maxLength = newMaxLength;\n this._startIndex = 0;\n }\n\n public get length(): number {\n return this._length;\n }\n\n public set length(newLength: number) {\n if (newLength > this._length) {\n for (let i = this._length; i < newLength; i++) {\n this._array[i] = undefined;\n }\n }\n this._length = newLength;\n }\n\n /**\n * Gets the value at an index.\n *\n * Note that for performance reasons there is no bounds checking here, the index reference is\n * circular so this should always return a value and never throw.\n * @param index The index of the value to get.\n * @return The value corresponding to the index.\n */\n public get(index: number): T | undefined {\n return this._array[this._getCyclicIndex(index)];\n }\n\n /**\n * Sets the value at an index.\n *\n * Note that for performance reasons there is no bounds checking here, the index reference is\n * circular so this should always return a value and never throw.\n * @param index The index to set.\n * @param value The value to set.\n */\n public set(index: number, value: T | undefined): void {\n this._array[this._getCyclicIndex(index)] = value;\n }\n\n /**\n * Pushes a new value onto the list, wrapping around to the start of the array, overriding index 0\n * if the maximum length is reached.\n * @param value The value to push onto the list.\n */\n public push(value: T): void {\n this._array[this._getCyclicIndex(this._length)] = value;\n if (this._length === this._maxLength) {\n this._startIndex = ++this._startIndex % this._maxLength;\n this.onTrimEmitter.fire(1);\n } else {\n this._length++;\n }\n }\n\n /**\n * Advance ringbuffer index and return current element for recycling.\n * Note: The buffer must be full for this method to work.\n * @throws When the buffer is not full.\n */\n public recycle(): T {\n if (this._length !== this._maxLength) {\n throw new Error('Can only recycle when the buffer is full');\n }\n this._startIndex = ++this._startIndex % this._maxLength;\n this.onTrimEmitter.fire(1);\n return this._array[this._getCyclicIndex(this._length - 1)]!;\n }\n\n /**\n * Ringbuffer is at max length.\n */\n public get isFull(): boolean {\n return this._length === this._maxLength;\n }\n\n /**\n * Removes and returns the last value on the list.\n * @return The popped value.\n */\n public pop(): T | undefined {\n return this._array[this._getCyclicIndex(this._length-- - 1)];\n }\n\n /**\n * Deletes and/or inserts items at a particular index (in that order). Unlike\n * Array.prototype.splice, this operation does not return the deleted items as a new array in\n * order to save creating a new array. Note that this operation may shift all values in the list\n * in the worst case.\n * @param start The index to delete and/or insert.\n * @param deleteCount The number of elements to delete.\n * @param items The items to insert.\n */\n public splice(start: number, deleteCount: number, ...items: T[]): void {\n // Delete items\n if (deleteCount) {\n for (let i = start; i < this._length - deleteCount; i++) {\n this._array[this._getCyclicIndex(i)] = this._array[this._getCyclicIndex(i + deleteCount)];\n }\n this._length -= deleteCount;\n this.onDeleteEmitter.fire({index: start, amount: deleteCount});\n }\n\n // Add items\n for (let i = this._length - 1; i >= start; i--) {\n this._array[this._getCyclicIndex(i + items.length)] = this._array[this._getCyclicIndex(i)];\n }\n for (let i = 0; i < items.length; i++) {\n this._array[this._getCyclicIndex(start + i)] = items[i];\n }\n if (items.length) {\n this.onInsertEmitter.fire({index: start, amount: items.length});\n }\n\n // Adjust length as needed\n if (this._length + items.length > this._maxLength) {\n const countToTrim = (this._length + items.length) - this._maxLength;\n this._startIndex += countToTrim;\n this._length = this._maxLength;\n this.onTrimEmitter.fire(countToTrim);\n } else {\n this._length += items.length;\n }\n }\n\n /**\n * Trims a number of items from the start of the list.\n * @param count The number of items to remove.\n */\n public trimStart(count: number): void {\n if (count > this._length) {\n count = this._length;\n }\n this._startIndex += count;\n this._length -= count;\n this.onTrimEmitter.fire(count);\n }\n\n public shiftElements(start: number, count: number, offset: number): void {\n if (count <= 0) {\n return;\n }\n if (start < 0 || start >= this._length) {\n throw new Error('start argument out of range');\n }\n if (start + offset < 0) {\n throw new Error('Cannot shift elements in list beyond index 0');\n }\n\n if (offset > 0) {\n for (let i = count - 1; i >= 0; i--) {\n this.set(start + i + offset, this.get(start + i));\n }\n const expandListBy = (start + count + offset) - this._length;\n if (expandListBy > 0) {\n this._length += expandListBy;\n while (this._length > this._maxLength) {\n this._length--;\n this._startIndex++;\n this.onTrimEmitter.fire(1);\n }\n }\n } else {\n for (let i = 0; i < count; i++) {\n this.set(start + i + offset, this.get(start + i));\n }\n }\n }\n\n /**\n * Gets the cyclic index for the specified regular index. The cyclic index can then be used on the\n * backing array to get the element associated with the regular index.\n * @param index The regular index.\n * @returns The cyclic index.\n */\n private _getCyclicIndex(index: number): number {\n return (this._startIndex + index) % this._maxLength;\n }\n}\n","/**\n * Copyright (c) 2016 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\n/*\n * A simple utility for cloning values\n */\nexport function clone(val: T, depth: number = 5): T {\n if (typeof val !== 'object') {\n return val;\n }\n\n // If we're cloning an array, use an array as the base, otherwise use an object\n const clonedObject: any = Array.isArray(val) ? [] : {};\n\n for (const key in val) {\n // Recursively clone eack item unless we're at the maximum depth\n clonedObject[key] = depth <= 1 ? val[key] : (val[key] ? clone(val[key], depth - 1) : val[key]);\n }\n\n return clonedObject as T;\n}\n","/**\n * Copyright (c) 2014-2020 The xterm.js authors. All rights reserved.\n * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)\n * @license MIT\n *\n * Originally forked from (with the author's permission):\n * Fabrice Bellard's javascript vt100 for jslinux:\n * http://bellard.org/jslinux/\n * Copyright (c) 2011 Fabrice Bellard\n * The original design remains. The terminal itself\n * has been extended to include xterm CSI codes, among\n * other features.\n *\n * Terminal Emulation References:\n * http://vt100.net/\n * http://invisible-island.net/xterm/ctlseqs/ctlseqs.txt\n * http://invisible-island.net/xterm/ctlseqs/ctlseqs.html\n * http://invisible-island.net/vttest/\n * http://www.inwap.com/pdp10/ansicode.txt\n * http://linux.die.net/man/4/console_codes\n * http://linux.die.net/man/7/urxvt\n */\n\nimport { Disposable } from 'common/Lifecycle';\nimport { IInstantiationService, IOptionsService, IBufferService, ILogService, ICharsetService, ICoreService, ICoreMouseService, IUnicodeService, IDirtyRowService } from 'common/services/Services';\nimport { InstantiationService } from 'common/services/InstantiationService';\nimport { LogService } from 'common/services/LogService';\nimport { BufferService, MINIMUM_COLS, MINIMUM_ROWS } from 'common/services/BufferService';\nimport { OptionsService } from 'common/services/OptionsService';\nimport { ITerminalOptions, IDisposable, IBufferLine, IAttributeData, ICoreTerminal } from 'common/Types';\nimport { CoreService } from 'common/services/CoreService';\nimport { EventEmitter, IEvent, forwardEvent } from 'common/EventEmitter';\nimport { CoreMouseService } from 'common/services/CoreMouseService';\nimport { DirtyRowService } from 'common/services/DirtyRowService';\nimport { UnicodeService } from 'common/services/UnicodeService';\nimport { CharsetService } from 'common/services/CharsetService';\nimport { updateWindowsModeWrappedState } from 'common/WindowsMode';\nimport { IFunctionIdentifier, IParams } from 'common/parser/Types';\nimport { IBufferSet } from 'common/buffer/Types';\nimport { InputHandler } from 'common/InputHandler';\nimport { WriteBuffer } from 'common/input/WriteBuffer';\n\nexport abstract class CoreTerminal extends Disposable implements ICoreTerminal {\n protected readonly _instantiationService: IInstantiationService;\n protected readonly _bufferService: IBufferService;\n protected readonly _logService: ILogService;\n protected readonly _coreService: ICoreService;\n protected readonly _charsetService: ICharsetService;\n protected readonly _coreMouseService: ICoreMouseService;\n protected readonly _dirtyRowService: IDirtyRowService;\n\n public readonly unicodeService: IUnicodeService;\n public readonly optionsService: IOptionsService;\n\n protected _inputHandler: InputHandler;\n private _writeBuffer: WriteBuffer;\n private _windowsMode: IDisposable | undefined;\n /** An IBufferline to clone/copy from for new blank lines */\n private _cachedBlankLine: IBufferLine | undefined;\n\n private _onBinary = new EventEmitter();\n public get onBinary(): IEvent { return this._onBinary.event; }\n private _onData = new EventEmitter();\n public get onData(): IEvent { return this._onData.event; }\n protected _onLineFeed = new EventEmitter();\n public get onLineFeed(): IEvent { return this._onLineFeed.event; }\n private _onResize = new EventEmitter<{ cols: number, rows: number }>();\n public get onResize(): IEvent<{ cols: number, rows: number }> { return this._onResize.event; }\n protected _onScroll = new EventEmitter();\n public get onScroll(): IEvent { return this._onScroll.event; }\n\n public get cols(): number { return this._bufferService.cols; }\n public get rows(): number { return this._bufferService.rows; }\n public get buffers(): IBufferSet { return this._bufferService.buffers; }\n\n constructor(\n options: ITerminalOptions\n ) {\n super();\n\n // Setup and initialize services\n this._instantiationService = new InstantiationService();\n this.optionsService = new OptionsService(options);\n this._instantiationService.setService(IOptionsService, this.optionsService);\n this._bufferService = this.register(this._instantiationService.createInstance(BufferService));\n this._instantiationService.setService(IBufferService, this._bufferService);\n this._logService = this._instantiationService.createInstance(LogService);\n this._instantiationService.setService(ILogService, this._logService);\n this._coreService = this.register(this._instantiationService.createInstance(CoreService, () => this.scrollToBottom()));\n this._instantiationService.setService(ICoreService, this._coreService);\n this._coreMouseService = this._instantiationService.createInstance(CoreMouseService);\n this._instantiationService.setService(ICoreMouseService, this._coreMouseService);\n this._dirtyRowService = this._instantiationService.createInstance(DirtyRowService);\n this._instantiationService.setService(IDirtyRowService, this._dirtyRowService);\n this.unicodeService = this._instantiationService.createInstance(UnicodeService);\n this._instantiationService.setService(IUnicodeService, this.unicodeService);\n this._charsetService = this._instantiationService.createInstance(CharsetService);\n this._instantiationService.setService(ICharsetService, this._charsetService);\n\n // Register input handler and handle/forward events\n this._inputHandler = new InputHandler(this._bufferService, this._charsetService, this._coreService, this._dirtyRowService, this._logService, this.optionsService, this._coreMouseService, this.unicodeService);\n this.register(forwardEvent(this._inputHandler.onLineFeed, this._onLineFeed));\n this.register(this._inputHandler);\n\n // Setup listeners\n this.register(forwardEvent(this._bufferService.onResize, this._onResize));\n this.register(forwardEvent(this._coreService.onData, this._onData));\n this.register(forwardEvent(this._coreService.onBinary, this._onBinary));\n this.register(this.optionsService.onOptionChange(key => this._updateOptions(key)));\n\n // Setup WriteBuffer\n this._writeBuffer = new WriteBuffer(data => this._inputHandler.parse(data));\n }\n\n public dispose(): void {\n if (this._isDisposed) {\n return;\n }\n super.dispose();\n this._windowsMode?.dispose();\n this._windowsMode = undefined;\n }\n\n public write(data: string | Uint8Array, callback?: () => void): void {\n this._writeBuffer.write(data, callback);\n }\n\n public writeSync(data: string | Uint8Array): void {\n this._writeBuffer.writeSync(data);\n }\n\n public resize(x: number, y: number): void {\n if (isNaN(x) || isNaN(y)) {\n return;\n }\n\n x = Math.max(x, MINIMUM_COLS);\n y = Math.max(y, MINIMUM_ROWS);\n\n this._bufferService.resize(x, y);\n }\n\n /**\n * Scroll the terminal down 1 row, creating a blank line.\n * @param isWrapped Whether the new line is wrapped from the previous line.\n */\n public scroll(eraseAttr: IAttributeData, isWrapped: boolean = false): void {\n const buffer = this._bufferService.buffer;\n\n let newLine: IBufferLine | undefined;\n newLine = this._cachedBlankLine;\n if (!newLine || newLine.length !== this.cols || newLine.getFg(0) !== eraseAttr.fg || newLine.getBg(0) !== eraseAttr.bg) {\n newLine = buffer.getBlankLine(eraseAttr, isWrapped);\n this._cachedBlankLine = newLine;\n }\n newLine.isWrapped = isWrapped;\n\n const topRow = buffer.ybase + buffer.scrollTop;\n const bottomRow = buffer.ybase + buffer.scrollBottom;\n\n if (buffer.scrollTop === 0) {\n // Determine whether the buffer is going to be trimmed after insertion.\n const willBufferBeTrimmed = buffer.lines.isFull;\n\n // Insert the line using the fastest method\n if (bottomRow === buffer.lines.length - 1) {\n if (willBufferBeTrimmed) {\n buffer.lines.recycle().copyFrom(newLine);\n } else {\n buffer.lines.push(newLine.clone());\n }\n } else {\n buffer.lines.splice(bottomRow + 1, 0, newLine.clone());\n }\n\n // Only adjust ybase and ydisp when the buffer is not trimmed\n if (!willBufferBeTrimmed) {\n buffer.ybase++;\n // Only scroll the ydisp with ybase if the user has not scrolled up\n if (!this._bufferService.isUserScrolling) {\n buffer.ydisp++;\n }\n } else {\n // When the buffer is full and the user has scrolled up, keep the text\n // stable unless ydisp is right at the top\n if (this._bufferService.isUserScrolling) {\n buffer.ydisp = Math.max(buffer.ydisp - 1, 0);\n }\n }\n } else {\n // scrollTop is non-zero which means no line will be going to the\n // scrollback, instead we can just shift them in-place.\n const scrollRegionHeight = bottomRow - topRow + 1 /* as it's zero-based */;\n buffer.lines.shiftElements(topRow + 1, scrollRegionHeight - 1, -1);\n buffer.lines.set(bottomRow, newLine.clone());\n }\n\n // Move the viewport to the bottom of the buffer unless the user is\n // scrolling.\n if (!this._bufferService.isUserScrolling) {\n buffer.ydisp = buffer.ybase;\n }\n\n // Flag rows that need updating\n this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom);\n\n this._onScroll.fire(buffer.ydisp);\n }\n\n /**\n * Scroll the display of the terminal\n * @param disp The number of lines to scroll down (negative scroll up).\n * @param suppressScrollEvent Don't emit the scroll event as scrollLines. This is used\n * to avoid unwanted events being handled by the viewport when the event was triggered from the\n * viewport originally.\n */\n public scrollLines(disp: number, suppressScrollEvent?: boolean): void {\n const buffer = this._bufferService.buffer;\n if (disp < 0) {\n if (buffer.ydisp === 0) {\n return;\n }\n this._bufferService.isUserScrolling = true;\n } else if (disp + buffer.ydisp >= buffer.ybase) {\n this._bufferService.isUserScrolling = false;\n }\n\n const oldYdisp = buffer.ydisp;\n buffer.ydisp = Math.max(Math.min(buffer.ydisp + disp, buffer.ybase), 0);\n\n // No change occurred, don't trigger scroll/refresh\n if (oldYdisp === buffer.ydisp) {\n return;\n }\n\n if (!suppressScrollEvent) {\n this._onScroll.fire(buffer.ydisp);\n }\n }\n\n /**\n * Scroll the display of the terminal by a number of pages.\n * @param pageCount The number of pages to scroll (negative scrolls up).\n */\n public scrollPages(pageCount: number): void {\n this.scrollLines(pageCount * (this.rows - 1));\n }\n\n /**\n * Scrolls the display of the terminal to the top.\n */\n public scrollToTop(): void {\n this.scrollLines(-this._bufferService.buffer.ydisp);\n }\n\n /**\n * Scrolls the display of the terminal to the bottom.\n */\n public scrollToBottom(): void {\n this.scrollLines(this._bufferService.buffer.ybase - this._bufferService.buffer.ydisp);\n }\n\n public scrollToLine(line: number): void {\n const scrollAmount = line - this._bufferService.buffer.ydisp;\n if (scrollAmount !== 0) {\n this.scrollLines(scrollAmount);\n }\n }\n\n /** Add handler for ESC escape sequence. See xterm.d.ts for details. */\n public addEscHandler(id: IFunctionIdentifier, callback: () => boolean): IDisposable {\n return this._inputHandler.addEscHandler(id, callback);\n }\n\n /** Add handler for DCS escape sequence. See xterm.d.ts for details. */\n public addDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: IParams) => boolean): IDisposable {\n return this._inputHandler.addDcsHandler(id, callback);\n }\n\n /** Add handler for CSI escape sequence. See xterm.d.ts for details. */\n public addCsiHandler(id: IFunctionIdentifier, callback: (params: IParams) => boolean): IDisposable {\n return this._inputHandler.addCsiHandler(id, callback);\n }\n\n /** Add handler for OSC escape sequence. See xterm.d.ts for details. */\n public addOscHandler(ident: number, callback: (data: string) => boolean): IDisposable {\n return this._inputHandler.addOscHandler(ident, callback);\n }\n\n protected _setup(): void {\n if (this.optionsService.options.windowsMode) {\n this._enableWindowsMode();\n }\n }\n\n public reset(): void {\n this._inputHandler.reset();\n this._bufferService.reset();\n this._charsetService.reset();\n this._coreService.reset();\n this._coreMouseService.reset();\n }\n\n protected _updateOptions(key: string): void {\n // TODO: These listeners should be owned by individual components\n switch (key) {\n case 'scrollback':\n this.buffers.resize(this.cols, this.rows);\n break;\n case 'windowsMode':\n if (this.optionsService.options.windowsMode) {\n this._enableWindowsMode();\n } else {\n this._windowsMode?.dispose();\n this._windowsMode = undefined;\n }\n break;\n }\n }\n\n protected _enableWindowsMode(): void {\n if (!this._windowsMode) {\n const disposables: IDisposable[] = [];\n disposables.push(this.onLineFeed(updateWindowsModeWrappedState.bind(null, this._bufferService)));\n disposables.push(this.addCsiHandler({ final: 'H' }, () => {\n updateWindowsModeWrappedState(this._bufferService);\n return false;\n }));\n this._windowsMode = {\n dispose: () => {\n for (const d of disposables) {\n d.dispose();\n }\n }\n };\n }\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IDisposable } from 'common/Types';\n\ninterface IListener {\n (arg1: T, arg2: U): void;\n}\n\nexport interface IEvent {\n (listener: (arg1: T, arg2: U) => any): IDisposable;\n}\n\nexport interface IEventEmitter {\n event: IEvent;\n fire(arg1: T, arg2: U): void;\n dispose(): void;\n}\n\nexport class EventEmitter implements IEventEmitter {\n private _listeners: IListener[] = [];\n private _event?: IEvent;\n private _disposed: boolean = false;\n\n public get event(): IEvent {\n if (!this._event) {\n this._event = (listener: (arg1: T, arg2: U) => any) => {\n this._listeners.push(listener);\n const disposable = {\n dispose: () => {\n if (!this._disposed) {\n for (let i = 0; i < this._listeners.length; i++) {\n if (this._listeners[i] === listener) {\n this._listeners.splice(i, 1);\n return;\n }\n }\n }\n }\n };\n return disposable;\n };\n }\n return this._event;\n }\n\n public fire(arg1: T, arg2: U): void {\n const queue: IListener[] = [];\n for (let i = 0; i < this._listeners.length; i++) {\n queue.push(this._listeners[i]);\n }\n for (let i = 0; i < queue.length; i++) {\n queue[i].call(undefined, arg1, arg2);\n }\n }\n\n public dispose(): void {\n if (this._listeners) {\n this._listeners.length = 0;\n }\n this._disposed = true;\n }\n}\n\nexport function forwardEvent(from: IEvent, to: IEventEmitter): IDisposable {\n return from(e => to.fire(e));\n}\n","/**\n * Copyright (c) 2014 The xterm.js authors. All rights reserved.\n * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)\n * @license MIT\n */\n\nimport { IInputHandler, IAttributeData, IDisposable, IWindowOptions, IAnsiColorChangeEvent } from 'common/Types';\nimport { C0, C1 } from 'common/data/EscapeSequences';\nimport { CHARSETS, DEFAULT_CHARSET } from 'common/data/Charsets';\nimport { EscapeSequenceParser } from 'common/parser/EscapeSequenceParser';\nimport { Disposable } from 'common/Lifecycle';\nimport { concat } from 'common/TypedArrayUtils';\nimport { StringToUtf32, stringFromCodePoint, utf32ToString, Utf8ToUtf32 } from 'common/input/TextDecoder';\nimport { DEFAULT_ATTR_DATA } from 'common/buffer/BufferLine';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { IParsingState, IDcsHandler, IEscapeSequenceParser, IParams, IFunctionIdentifier } from 'common/parser/Types';\nimport { NULL_CELL_CODE, NULL_CELL_WIDTH, Attributes, FgFlags, BgFlags, Content, UnderlineStyle } from 'common/buffer/Constants';\nimport { CellData } from 'common/buffer/CellData';\nimport { AttributeData } from 'common/buffer/AttributeData';\nimport { ICoreService, IBufferService, IOptionsService, ILogService, IDirtyRowService, ICoreMouseService, ICharsetService, IUnicodeService } from 'common/services/Services';\nimport { OscHandler } from 'common/parser/OscParser';\nimport { DcsHandler } from 'common/parser/DcsParser';\n\n/**\n * Map collect to glevel. Used in `selectCharset`.\n */\nconst GLEVEL: {[key: string]: number} = {'(': 0, ')': 1, '*': 2, '+': 3, '-': 1, '.': 2};\n\n/**\n * VT commands done by the parser - FIXME: move this to the parser?\n */\n// @vt: #Y ESC CSI \"Control Sequence Introducer\" \"ESC [\" \"Start of a CSI sequence.\"\n// @vt: #Y ESC OSC \"Operating System Command\" \"ESC ]\" \"Start of an OSC sequence.\"\n// @vt: #Y ESC DCS \"Device Control String\" \"ESC P\" \"Start of a DCS sequence.\"\n// @vt: #Y ESC ST \"String Terminator\" \"ESC \\\" \"Terminator used for string type sequences.\"\n// @vt: #Y ESC PM \"Privacy Message\" \"ESC ^\" \"Start of a privacy message.\"\n// @vt: #Y ESC APC \"Application Program Command\" \"ESC _\" \"Start of an APC sequence.\"\n// @vt: #Y C1 CSI \"Control Sequence Introducer\" \"\\x9B\" \"Start of a CSI sequence.\"\n// @vt: #Y C1 OSC \"Operating System Command\" \"\\x9D\" \"Start of an OSC sequence.\"\n// @vt: #Y C1 DCS \"Device Control String\" \"\\x90\" \"Start of a DCS sequence.\"\n// @vt: #Y C1 ST \"String Terminator\" \"\\x9C\" \"Terminator used for string type sequences.\"\n// @vt: #Y C1 PM \"Privacy Message\" \"\\x9E\" \"Start of a privacy message.\"\n// @vt: #Y C1 APC \"Application Program Command\" \"\\x9F\" \"Start of an APC sequence.\"\n// @vt: #Y C0 NUL \"Null\" \"\\0, \\x00\" \"NUL is ignored.\"\n// @vt: #Y C0 ESC \"Escape\" \"\\e, \\x1B\" \"Start of a sequence. Cancels any other sequence.\"\n\n/**\n * Document common VT features here that are currently unsupported\n */\n// @vt: #N DCS SIXEL \"SIXEL Graphics\" \"DCS Ps ; Ps ; Ps ; q \tPt ST\" \"Draw SIXEL image starting at cursor position.\"\n// @vt: #N OSC 1 \"Set Icon Name\" \"OSC 1 ; Pt BEL\" \"Set icon name.\"\n\n/**\n * Max length of the UTF32 input buffer. Real memory consumption is 4 times higher.\n */\nconst MAX_PARSEBUFFER_LENGTH = 131072;\n\n/**\n * Limit length of title and icon name stacks.\n */\nconst STACK_LIMIT = 10;\n\n// map params to window option\nfunction paramToWindowOption(n: number, opts: IWindowOptions): boolean {\n if (n > 24) {\n return opts.setWinLines || false;\n }\n switch (n) {\n case 1: return !!opts.restoreWin;\n case 2: return !!opts.minimizeWin;\n case 3: return !!opts.setWinPosition;\n case 4: return !!opts.setWinSizePixels;\n case 5: return !!opts.raiseWin;\n case 6: return !!opts.lowerWin;\n case 7: return !!opts.refreshWin;\n case 8: return !!opts.setWinSizeChars;\n case 9: return !!opts.maximizeWin;\n case 10: return !!opts.fullscreenWin;\n case 11: return !!opts.getWinState;\n case 13: return !!opts.getWinPosition;\n case 14: return !!opts.getWinSizePixels;\n case 15: return !!opts.getScreenSizePixels;\n case 16: return !!opts.getCellSizePixels;\n case 18: return !!opts.getWinSizeChars;\n case 19: return !!opts.getScreenSizeChars;\n case 20: return !!opts.getIconTitle;\n case 21: return !!opts.getWinTitle;\n case 22: return !!opts.pushTitle;\n case 23: return !!opts.popTitle;\n case 24: return !!opts.setWinLines;\n }\n return false;\n}\n\nexport enum WindowsOptionsReportType {\n GET_WIN_SIZE_PIXELS = 0,\n GET_CELL_SIZE_PIXELS = 1\n}\n\n/**\n * DCS subparser implementations\n */\n\n/**\n * DCS $ q Pt ST\n * DECRQSS (https://vt100.net/docs/vt510-rm/DECRQSS.html)\n * Request Status String (DECRQSS), VT420 and up.\n * Response: DECRPSS (https://vt100.net/docs/vt510-rm/DECRPSS.html)\n *\n * @vt: #P[See limited support below.] DCS DECRQSS \"Request Selection or Setting\" \"DCS $ q Pt ST\" \"Request several terminal settings.\"\n * Response is in the form `ESC P 1 $ r Pt ST` for valid requests, where `Pt` contains the corresponding CSI string,\n * `ESC P 0 ST` for invalid requests.\n *\n * Supported requests and responses:\n *\n * | Type | Request | Response (`Pt`) |\n * | -------------------------------- | ----------------- | ----------------------------------------------------- |\n * | Graphic Rendition (SGR) | `DCS $ q m ST` | always reporting `0m` (currently broken) |\n * | Top and Bottom Margins (DECSTBM) | `DCS $ q r ST` | `Ps ; Ps r` |\n * | Cursor Style (DECSCUSR) | `DCS $ q SP q ST` | `Ps SP q` |\n * | Protection Attribute (DECSCA) | `DCS $ q \" q ST` | always reporting `0 \" q` (DECSCA is unsupported) |\n * | Conformance Level (DECSCL) | `DCS $ q \" p ST` | always reporting `61 ; 1 \" p` (DECSCL is unsupported) |\n *\n *\n * TODO:\n * - fix SGR report\n * - either implement DECSCA or remove the report\n * - either check which conformance is better suited or remove the report completely\n * --> we are currently a mixture of all up to VT400 but dont follow anyone strictly\n */\nclass DECRQSS implements IDcsHandler {\n private _data: Uint32Array = new Uint32Array(0);\n\n constructor(\n private _bufferService: IBufferService,\n private _coreService: ICoreService,\n private _logService: ILogService,\n private _optionsService: IOptionsService\n ) { }\n\n public hook(params: IParams): void {\n this._data = new Uint32Array(0);\n }\n\n public put(data: Uint32Array, start: number, end: number): void {\n this._data = concat(this._data, data.subarray(start, end));\n }\n\n public unhook(success: boolean): boolean {\n if (!success) {\n this._data = new Uint32Array(0);\n return true;\n }\n const data = utf32ToString(this._data);\n this._data = new Uint32Array(0);\n switch (data) {\n // valid: DCS 1 $ r Pt ST (xterm)\n case '\"q': // DECSCA\n this._coreService.triggerDataEvent(`${C0.ESC}P1$r0\"q${C0.ESC}\\\\`);\n break;\n case '\"p': // DECSCL\n this._coreService.triggerDataEvent(`${C0.ESC}P1$r61;1\"p${C0.ESC}\\\\`);\n break;\n case 'r': // DECSTBM\n const pt = '' + (this._bufferService.buffer.scrollTop + 1) +\n ';' + (this._bufferService.buffer.scrollBottom + 1) + 'r';\n this._coreService.triggerDataEvent(`${C0.ESC}P1$r${pt}${C0.ESC}\\\\`);\n break;\n case 'm': // SGR\n // TODO: report real settings instead of 0m\n this._coreService.triggerDataEvent(`${C0.ESC}P1$r0m${C0.ESC}\\\\`);\n break;\n case ' q': // DECSCUSR\n const STYLES: {[key: string]: number} = {'block': 2, 'underline': 4, 'bar': 6};\n let style = STYLES[this._optionsService.options.cursorStyle];\n style -= this._optionsService.options.cursorBlink ? 1 : 0;\n this._coreService.triggerDataEvent(`${C0.ESC}P1$r${style} q${C0.ESC}\\\\`);\n break;\n default:\n // invalid: DCS 0 $ r Pt ST (xterm)\n this._logService.debug('Unknown DCS $q %s', data);\n this._coreService.triggerDataEvent(`${C0.ESC}P0$r${C0.ESC}\\\\`);\n }\n return true;\n }\n}\n\n/**\n * DCS Ps; Ps| Pt ST\n * DECUDK (https://vt100.net/docs/vt510-rm/DECUDK.html)\n * not supported\n *\n * @vt: #N DCS DECUDK \"User Defined Keys\" \"DCS Ps ; Ps | Pt ST\" \"Definitions for user-defined keys.\"\n */\n\n/**\n * DCS + q Pt ST (xterm)\n * Request Terminfo String\n * not implemented\n *\n * @vt: #N DCS XTGETTCAP \"Request Terminfo String\" \"DCS + q Pt ST\" \"Request Terminfo String.\"\n */\n\n/**\n * DCS + p Pt ST (xterm)\n * Set Terminfo Data\n * not supported\n *\n * @vt: #N DCS XTSETTCAP \"Set Terminfo Data\" \"DCS + p Pt ST\" \"Set Terminfo Data.\"\n */\n\n\n\n/**\n * The terminal's standard implementation of IInputHandler, this handles all\n * input from the Parser.\n *\n * Refer to http://invisible-island.net/xterm/ctlseqs/ctlseqs.html to understand\n * each function's header comment.\n */\nexport class InputHandler extends Disposable implements IInputHandler {\n private _parseBuffer: Uint32Array = new Uint32Array(4096);\n private _stringDecoder: StringToUtf32 = new StringToUtf32();\n private _utf8Decoder: Utf8ToUtf32 = new Utf8ToUtf32();\n private _workCell: CellData = new CellData();\n private _windowTitle = '';\n private _iconName = '';\n protected _windowTitleStack: string[] = [];\n protected _iconNameStack: string[] = [];\n\n private _curAttrData: IAttributeData = DEFAULT_ATTR_DATA.clone();\n private _eraseAttrDataInternal: IAttributeData = DEFAULT_ATTR_DATA.clone();\n\n private _onRequestBell = new EventEmitter();\n public get onRequestBell(): IEvent { return this._onRequestBell.event; }\n private _onRequestRefreshRows = new EventEmitter();\n public get onRequestRefreshRows(): IEvent { return this._onRequestRefreshRows.event; }\n private _onRequestReset = new EventEmitter();\n public get onRequestReset(): IEvent { return this._onRequestReset.event; }\n private _onRequestScroll = new EventEmitter();\n public get onRequestScroll(): IEvent { return this._onRequestScroll.event; }\n private _onRequestSyncScrollBar = new EventEmitter();\n public get onRequestSyncScrollBar(): IEvent { return this._onRequestSyncScrollBar.event; }\n private _onRequestWindowsOptionsReport = new EventEmitter();\n public get onRequestWindowsOptionsReport(): IEvent { return this._onRequestWindowsOptionsReport.event; }\n\n private _onA11yChar = new EventEmitter();\n public get onA11yChar(): IEvent { return this._onA11yChar.event; }\n private _onA11yTab = new EventEmitter();\n public get onA11yTab(): IEvent { return this._onA11yTab.event; }\n private _onCursorMove = new EventEmitter();\n public get onCursorMove(): IEvent { return this._onCursorMove.event; }\n private _onLineFeed = new EventEmitter();\n public get onLineFeed(): IEvent { return this._onLineFeed.event; }\n private _onScroll = new EventEmitter();\n public get onScroll(): IEvent { return this._onScroll.event; }\n private _onTitleChange = new EventEmitter();\n public get onTitleChange(): IEvent { return this._onTitleChange.event; }\n private _onAnsiColorChange = new EventEmitter();\n public get onAnsiColorChange(): IEvent { return this._onAnsiColorChange.event; }\n\n constructor(\n private readonly _bufferService: IBufferService,\n private readonly _charsetService: ICharsetService,\n private readonly _coreService: ICoreService,\n private readonly _dirtyRowService: IDirtyRowService,\n private readonly _logService: ILogService,\n private readonly _optionsService: IOptionsService,\n private readonly _coreMouseService: ICoreMouseService,\n private readonly _unicodeService: IUnicodeService,\n private readonly _parser: IEscapeSequenceParser = new EscapeSequenceParser()\n ) {\n super();\n this.register(this._parser);\n\n /**\n * custom fallback handlers\n */\n this._parser.setCsiHandlerFallback((ident, params) => {\n this._logService.debug('Unknown CSI code: ', { identifier: this._parser.identToString(ident), params: params.toArray() });\n });\n this._parser.setEscHandlerFallback(ident => {\n this._logService.debug('Unknown ESC code: ', { identifier: this._parser.identToString(ident) });\n });\n this._parser.setExecuteHandlerFallback(code => {\n this._logService.debug('Unknown EXECUTE code: ', { code });\n });\n this._parser.setOscHandlerFallback((identifier, action, data) => {\n this._logService.debug('Unknown OSC code: ', { identifier, action, data });\n });\n this._parser.setDcsHandlerFallback((ident, action, payload) => {\n if (action === 'HOOK') {\n payload = payload.toArray();\n }\n this._logService.debug('Unknown DCS code: ', { identifier: this._parser.identToString(ident), action, payload });\n });\n\n /**\n * print handler\n */\n this._parser.setPrintHandler((data, start, end) => this.print(data, start, end));\n\n /**\n * CSI handler\n */\n this._parser.registerCsiHandler({final: '@'}, params => this.insertChars(params));\n this._parser.registerCsiHandler({intermediates: ' ', final: '@'}, params => this.scrollLeft(params));\n this._parser.registerCsiHandler({final: 'A'}, params => this.cursorUp(params));\n this._parser.registerCsiHandler({intermediates: ' ', final: 'A'}, params => this.scrollRight(params));\n this._parser.registerCsiHandler({final: 'B'}, params => this.cursorDown(params));\n this._parser.registerCsiHandler({final: 'C'}, params => this.cursorForward(params));\n this._parser.registerCsiHandler({final: 'D'}, params => this.cursorBackward(params));\n this._parser.registerCsiHandler({final: 'E'}, params => this.cursorNextLine(params));\n this._parser.registerCsiHandler({final: 'F'}, params => this.cursorPrecedingLine(params));\n this._parser.registerCsiHandler({final: 'G'}, params => this.cursorCharAbsolute(params));\n this._parser.registerCsiHandler({final: 'H'}, params => this.cursorPosition(params));\n this._parser.registerCsiHandler({final: 'I'}, params => this.cursorForwardTab(params));\n this._parser.registerCsiHandler({final: 'J'}, params => this.eraseInDisplay(params));\n this._parser.registerCsiHandler({prefix: '?', final: 'J'}, params => this.eraseInDisplay(params));\n this._parser.registerCsiHandler({final: 'K'}, params => this.eraseInLine(params));\n this._parser.registerCsiHandler({prefix: '?', final: 'K'}, params => this.eraseInLine(params));\n this._parser.registerCsiHandler({final: 'L'}, params => this.insertLines(params));\n this._parser.registerCsiHandler({final: 'M'}, params => this.deleteLines(params));\n this._parser.registerCsiHandler({final: 'P'}, params => this.deleteChars(params));\n this._parser.registerCsiHandler({final: 'S'}, params => this.scrollUp(params));\n this._parser.registerCsiHandler({final: 'T'}, params => this.scrollDown(params));\n this._parser.registerCsiHandler({final: 'X'}, params => this.eraseChars(params));\n this._parser.registerCsiHandler({final: 'Z'}, params => this.cursorBackwardTab(params));\n this._parser.registerCsiHandler({final: '`'}, params => this.charPosAbsolute(params));\n this._parser.registerCsiHandler({final: 'a'}, params => this.hPositionRelative(params));\n this._parser.registerCsiHandler({final: 'b'}, params => this.repeatPrecedingCharacter(params));\n this._parser.registerCsiHandler({final: 'c'}, params => this.sendDeviceAttributesPrimary(params));\n this._parser.registerCsiHandler({prefix: '>', final: 'c'}, params => this.sendDeviceAttributesSecondary(params));\n this._parser.registerCsiHandler({final: 'd'}, params => this.linePosAbsolute(params));\n this._parser.registerCsiHandler({final: 'e'}, params => this.vPositionRelative(params));\n this._parser.registerCsiHandler({final: 'f'}, params => this.hVPosition(params));\n this._parser.registerCsiHandler({final: 'g'}, params => this.tabClear(params));\n this._parser.registerCsiHandler({final: 'h'}, params => this.setMode(params));\n this._parser.registerCsiHandler({prefix: '?', final: 'h'}, params => this.setModePrivate(params));\n this._parser.registerCsiHandler({final: 'l'}, params => this.resetMode(params));\n this._parser.registerCsiHandler({prefix: '?', final: 'l'}, params => this.resetModePrivate(params));\n this._parser.registerCsiHandler({final: 'm'}, params => this.charAttributes(params));\n this._parser.registerCsiHandler({final: 'n'}, params => this.deviceStatus(params));\n this._parser.registerCsiHandler({prefix: '?', final: 'n'}, params => this.deviceStatusPrivate(params));\n this._parser.registerCsiHandler({intermediates: '!', final: 'p'}, params => this.softReset(params));\n this._parser.registerCsiHandler({intermediates: ' ', final: 'q'}, params => this.setCursorStyle(params));\n this._parser.registerCsiHandler({final: 'r'}, params => this.setScrollRegion(params));\n this._parser.registerCsiHandler({final: 's'}, params => this.saveCursor(params));\n this._parser.registerCsiHandler({final: 't'}, params => this.windowOptions(params));\n this._parser.registerCsiHandler({final: 'u'}, params => this.restoreCursor(params));\n this._parser.registerCsiHandler({intermediates: '\\'', final: '}'}, params => this.insertColumns(params));\n this._parser.registerCsiHandler({intermediates: '\\'', final: '~'}, params => this.deleteColumns(params));\n\n /**\n * execute handler\n */\n this._parser.setExecuteHandler(C0.BEL, () => this.bell());\n this._parser.setExecuteHandler(C0.LF, () => this.lineFeed());\n this._parser.setExecuteHandler(C0.VT, () => this.lineFeed());\n this._parser.setExecuteHandler(C0.FF, () => this.lineFeed());\n this._parser.setExecuteHandler(C0.CR, () => this.carriageReturn());\n this._parser.setExecuteHandler(C0.BS, () => this.backspace());\n this._parser.setExecuteHandler(C0.HT, () => this.tab());\n this._parser.setExecuteHandler(C0.SO, () => this.shiftOut());\n this._parser.setExecuteHandler(C0.SI, () => this.shiftIn());\n // FIXME: What do to with missing? Old code just added those to print.\n\n this._parser.setExecuteHandler(C1.IND, () => this.index());\n this._parser.setExecuteHandler(C1.NEL, () => this.nextLine());\n this._parser.setExecuteHandler(C1.HTS, () => this.tabSet());\n\n /**\n * OSC handler\n */\n // 0 - icon name + title\n this._parser.registerOscHandler(0, new OscHandler(data => { this.setTitle(data); this.setIconName(data); return true; }));\n // 1 - icon name\n this._parser.registerOscHandler(1, new OscHandler(data => this.setIconName(data)));\n // 2 - title\n this._parser.registerOscHandler(2, new OscHandler(data => this.setTitle(data)));\n // 3 - set property X in the form \"prop=value\"\n // 4 - Change Color Number\n this._parser.registerOscHandler(4, new OscHandler(data => this.setAnsiColor(data)));\n // 5 - Change Special Color Number\n // 6 - Enable/disable Special Color Number c\n // 7 - current directory? (not in xterm spec, see https://gitlab.com/gnachman/iterm2/issues/3939)\n // 10 - Change VT100 text foreground color to Pt.\n // 11 - Change VT100 text background color to Pt.\n // 12 - Change text cursor color to Pt.\n // 13 - Change mouse foreground color to Pt.\n // 14 - Change mouse background color to Pt.\n // 15 - Change Tektronix foreground color to Pt.\n // 16 - Change Tektronix background color to Pt.\n // 17 - Change highlight background color to Pt.\n // 18 - Change Tektronix cursor color to Pt.\n // 19 - Change highlight foreground color to Pt.\n // 46 - Change Log File to Pt.\n // 50 - Set Font to Pt.\n // 51 - reserved for Emacs shell.\n // 52 - Manipulate Selection Data.\n // 104 ; c - Reset Color Number c.\n // 105 ; c - Reset Special Color Number c.\n // 106 ; c; f - Enable/disable Special Color Number c.\n // 110 - Reset VT100 text foreground color.\n // 111 - Reset VT100 text background color.\n // 112 - Reset text cursor color.\n // 113 - Reset mouse foreground color.\n // 114 - Reset mouse background color.\n // 115 - Reset Tektronix foreground color.\n // 116 - Reset Tektronix background color.\n // 117 - Reset highlight color.\n // 118 - Reset Tektronix cursor color.\n // 119 - Reset highlight foreground color.\n\n /**\n * ESC handlers\n */\n this._parser.registerEscHandler({final: '7'}, () => this.saveCursor());\n this._parser.registerEscHandler({final: '8'}, () => this.restoreCursor());\n this._parser.registerEscHandler({final: 'D'}, () => this.index());\n this._parser.registerEscHandler({final: 'E'}, () => this.nextLine());\n this._parser.registerEscHandler({final: 'H'}, () => this.tabSet());\n this._parser.registerEscHandler({final: 'M'}, () => this.reverseIndex());\n this._parser.registerEscHandler({final: '='}, () => this.keypadApplicationMode());\n this._parser.registerEscHandler({final: '>'}, () => this.keypadNumericMode());\n this._parser.registerEscHandler({final: 'c'}, () => this.fullReset());\n this._parser.registerEscHandler({final: 'n'}, () => this.setgLevel(2));\n this._parser.registerEscHandler({final: 'o'}, () => this.setgLevel(3));\n this._parser.registerEscHandler({final: '|'}, () => this.setgLevel(3));\n this._parser.registerEscHandler({final: '}'}, () => this.setgLevel(2));\n this._parser.registerEscHandler({final: '~'}, () => this.setgLevel(1));\n this._parser.registerEscHandler({intermediates: '%', final: '@'}, () => this.selectDefaultCharset());\n this._parser.registerEscHandler({intermediates: '%', final: 'G'}, () => this.selectDefaultCharset());\n for (const flag in CHARSETS) {\n this._parser.registerEscHandler({intermediates: '(', final: flag}, () => this.selectCharset('(' + flag));\n this._parser.registerEscHandler({intermediates: ')', final: flag}, () => this.selectCharset(')' + flag));\n this._parser.registerEscHandler({intermediates: '*', final: flag}, () => this.selectCharset('*' + flag));\n this._parser.registerEscHandler({intermediates: '+', final: flag}, () => this.selectCharset('+' + flag));\n this._parser.registerEscHandler({intermediates: '-', final: flag}, () => this.selectCharset('-' + flag));\n this._parser.registerEscHandler({intermediates: '.', final: flag}, () => this.selectCharset('.' + flag));\n this._parser.registerEscHandler({intermediates: '/', final: flag}, () => this.selectCharset('/' + flag)); // TODO: supported?\n }\n this._parser.registerEscHandler({intermediates: '#', final: '8'}, () => this.screenAlignmentPattern());\n\n /**\n * error handler\n */\n this._parser.setErrorHandler((state: IParsingState) => {\n this._logService.error('Parsing error: ', state);\n return state;\n });\n\n /**\n * DCS handler\n */\n this._parser.registerDcsHandler({intermediates: '$', final: 'q'}, new DECRQSS(this._bufferService, this._coreService, this._logService, this._optionsService));\n }\n\n public dispose(): void {\n super.dispose();\n }\n\n public parse(data: string | Uint8Array): void {\n let buffer = this._bufferService.buffer;\n const cursorStartX = buffer.x;\n const cursorStartY = buffer.y;\n\n this._logService.debug('parsing data', data);\n\n // resize input buffer if needed\n if (this._parseBuffer.length < data.length) {\n if (this._parseBuffer.length < MAX_PARSEBUFFER_LENGTH) {\n this._parseBuffer = new Uint32Array(Math.min(data.length, MAX_PARSEBUFFER_LENGTH));\n }\n }\n\n // Clear the dirty row service so we know which lines changed as a result of parsing\n this._dirtyRowService.clearRange();\n\n // process big data in smaller chunks\n if (data.length > MAX_PARSEBUFFER_LENGTH) {\n for (let i = 0; i < data.length; i += MAX_PARSEBUFFER_LENGTH) {\n const end = i + MAX_PARSEBUFFER_LENGTH < data.length ? i + MAX_PARSEBUFFER_LENGTH : data.length;\n const len = (typeof data === 'string')\n ? this._stringDecoder.decode(data.substring(i, end), this._parseBuffer)\n : this._utf8Decoder.decode(data.subarray(i, end), this._parseBuffer);\n this._parser.parse(this._parseBuffer, len);\n }\n } else {\n const len = (typeof data === 'string')\n ? this._stringDecoder.decode(data, this._parseBuffer)\n : this._utf8Decoder.decode(data, this._parseBuffer);\n this._parser.parse(this._parseBuffer, len);\n }\n\n buffer = this._bufferService.buffer;\n if (buffer.x !== cursorStartX || buffer.y !== cursorStartY) {\n this._onCursorMove.fire();\n }\n\n // Refresh any dirty rows accumulated as part of parsing\n this._onRequestRefreshRows.fire(this._dirtyRowService.start, this._dirtyRowService.end);\n }\n\n public print(data: Uint32Array, start: number, end: number): void {\n let code: number;\n let chWidth: number;\n const buffer = this._bufferService.buffer;\n const charset = this._charsetService.charset;\n const screenReaderMode = this._optionsService.options.screenReaderMode;\n const cols = this._bufferService.cols;\n const wraparoundMode = this._coreService.decPrivateModes.wraparound;\n const insertMode = this._coreService.modes.insertMode;\n const curAttr = this._curAttrData;\n let bufferRow = buffer.lines.get(buffer.ybase + buffer.y)!;\n\n this._dirtyRowService.markDirty(buffer.y);\n\n // handle wide chars: reset start_cell-1 if we would overwrite the second cell of a wide char\n if (buffer.x && end - start > 0 && bufferRow.getWidth(buffer.x - 1) === 2) {\n bufferRow.setCellFromCodePoint(buffer.x - 1, 0, 1, curAttr.fg, curAttr.bg, curAttr.extended);\n }\n\n for (let pos = start; pos < end; ++pos) {\n code = data[pos];\n\n // calculate print space\n // expensive call, therefore we save width in line buffer\n chWidth = this._unicodeService.wcwidth(code);\n\n // get charset replacement character\n // charset is only defined for ASCII, therefore we only\n // search for an replacement char if code < 127\n if (code < 127 && charset) {\n const ch = charset[String.fromCharCode(code)];\n if (ch) {\n code = ch.charCodeAt(0);\n }\n }\n\n if (screenReaderMode) {\n this._onA11yChar.fire(stringFromCodePoint(code));\n }\n\n // insert combining char at last cursor position\n // buffer.x should never be 0 for a combining char\n // since they always follow a cell consuming char\n // therefore we can test for buffer.x to avoid overflow left\n if (!chWidth && buffer.x) {\n if (!bufferRow.getWidth(buffer.x - 1)) {\n // found empty cell after fullwidth, need to go 2 cells back\n // it is save to step 2 cells back here\n // since an empty cell is only set by fullwidth chars\n bufferRow.addCodepointToCell(buffer.x - 2, code);\n } else {\n bufferRow.addCodepointToCell(buffer.x - 1, code);\n }\n continue;\n }\n\n // goto next line if ch would overflow\n // NOTE: To avoid costly width checks here,\n // the terminal does not allow a cols < 2.\n if (buffer.x + chWidth - 1 >= cols) {\n // autowrap - DECAWM\n // automatically wraps to the beginning of the next line\n if (wraparoundMode) {\n // clear left over cells to the right\n while (buffer.x < cols) {\n bufferRow.setCellFromCodePoint(buffer.x++, 0, 1, curAttr.fg, curAttr.bg, curAttr.extended);\n }\n buffer.x = 0;\n buffer.y++;\n if (buffer.y === buffer.scrollBottom + 1) {\n buffer.y--;\n this._onRequestScroll.fire(this._eraseAttrData(), true);\n } else {\n if (buffer.y >= this._bufferService.rows) {\n buffer.y = this._bufferService.rows - 1;\n }\n // The line already exists (eg. the initial viewport), mark it as a\n // wrapped line\n buffer.lines.get(buffer.ybase + buffer.y)!.isWrapped = true;\n }\n // row changed, get it again\n bufferRow = buffer.lines.get(buffer.ybase + buffer.y)!;\n } else {\n buffer.x = cols - 1;\n if (chWidth === 2) {\n // FIXME: check for xterm behavior\n // What to do here? We got a wide char that does not fit into last cell\n continue;\n }\n }\n }\n\n // insert mode: move characters to right\n if (insertMode) {\n // right shift cells according to the width\n bufferRow.insertCells(buffer.x, chWidth, buffer.getNullCell(curAttr), curAttr);\n // test last cell - since the last cell has only room for\n // a halfwidth char any fullwidth shifted there is lost\n // and will be set to empty cell\n if (bufferRow.getWidth(cols - 1) === 2) {\n bufferRow.setCellFromCodePoint(cols - 1, NULL_CELL_CODE, NULL_CELL_WIDTH, curAttr.fg, curAttr.bg, curAttr.extended);\n }\n }\n\n // write current char to buffer and advance cursor\n bufferRow.setCellFromCodePoint(buffer.x++, code, chWidth, curAttr.fg, curAttr.bg, curAttr.extended);\n\n // fullwidth char - also set next cell to placeholder stub and advance cursor\n // for graphemes bigger than fullwidth we can simply loop to zero\n // we already made sure above, that buffer.x + chWidth will not overflow right\n if (chWidth > 0) {\n while (--chWidth) {\n // other than a regular empty cell a cell following a wide char has no width\n bufferRow.setCellFromCodePoint(buffer.x++, 0, 0, curAttr.fg, curAttr.bg, curAttr.extended);\n }\n }\n }\n // store last char in Parser.precedingCodepoint for REP to work correctly\n // This needs to check whether:\n // - fullwidth + surrogates: reset\n // - combining: only base char gets carried on (bug in xterm?)\n if (end - start > 0) {\n bufferRow.loadCell(buffer.x - 1, this._workCell);\n if (this._workCell.getWidth() === 2 || this._workCell.getCode() > 0xFFFF) {\n this._parser.precedingCodepoint = 0;\n } else if (this._workCell.isCombined()) {\n this._parser.precedingCodepoint = this._workCell.getChars().charCodeAt(0);\n } else {\n this._parser.precedingCodepoint = this._workCell.content;\n }\n }\n\n // handle wide chars: reset cell to the right if it is second cell of a wide char\n if (buffer.x < cols && end - start > 0 && bufferRow.getWidth(buffer.x) === 0 && !bufferRow.hasContent(buffer.x)) {\n bufferRow.setCellFromCodePoint(buffer.x, 0, 1, curAttr.fg, curAttr.bg, curAttr.extended);\n }\n\n this._dirtyRowService.markDirty(buffer.y);\n }\n\n /**\n * Forward addCsiHandler from parser.\n */\n public addCsiHandler(id: IFunctionIdentifier, callback: (params: IParams) => boolean): IDisposable {\n if (id.final === 't' && !id.prefix && !id.intermediates) {\n // security: always check whether window option is allowed\n return this._parser.registerCsiHandler(id, params => {\n if (!paramToWindowOption(params.params[0], this._optionsService.options.windowOptions)) {\n return true;\n }\n return callback(params);\n });\n }\n return this._parser.registerCsiHandler(id, callback);\n }\n\n /**\n * Forward addDcsHandler from parser.\n */\n public addDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: IParams) => boolean): IDisposable {\n return this._parser.registerDcsHandler(id, new DcsHandler(callback));\n }\n\n /**\n * Forward addEscHandler from parser.\n */\n public addEscHandler(id: IFunctionIdentifier, callback: () => boolean): IDisposable {\n return this._parser.registerEscHandler(id, callback);\n }\n\n /**\n * Forward addOscHandler from parser.\n */\n public addOscHandler(ident: number, callback: (data: string) => boolean): IDisposable {\n return this._parser.registerOscHandler(ident, new OscHandler(callback));\n }\n\n /**\n * BEL\n * Bell (Ctrl-G).\n *\n * @vt: #Y C0 BEL \"Bell\" \"\\a, \\x07\" \"Ring the bell.\"\n * The behavior of the bell is further customizable with `ITerminalOptions.bellStyle`\n * and `ITerminalOptions.bellSound`.\n */\n public bell(): boolean {\n this._onRequestBell.fire();\n return true;\n }\n\n /**\n * LF\n * Line Feed or New Line (NL). (LF is Ctrl-J).\n *\n * @vt: #Y C0 LF \"Line Feed\" \"\\n, \\x0A\" \"Move the cursor one row down, scrolling if needed.\"\n * Scrolling is restricted to scroll margins and will only happen on the bottom line.\n *\n * @vt: #Y C0 VT \"Vertical Tabulation\" \"\\v, \\x0B\" \"Treated as LF.\"\n * @vt: #Y C0 FF \"Form Feed\" \"\\f, \\x0C\" \"Treated as LF.\"\n */\n public lineFeed(): boolean {\n // make buffer local for faster access\n const buffer = this._bufferService.buffer;\n\n this._dirtyRowService.markDirty(buffer.y);\n if (this._optionsService.options.convertEol) {\n buffer.x = 0;\n }\n buffer.y++;\n if (buffer.y === buffer.scrollBottom + 1) {\n buffer.y--;\n this._onRequestScroll.fire(this._eraseAttrData());\n } else if (buffer.y >= this._bufferService.rows) {\n buffer.y = this._bufferService.rows - 1;\n }\n // If the end of the line is hit, prevent this action from wrapping around to the next line.\n if (buffer.x >= this._bufferService.cols) {\n buffer.x--;\n }\n this._dirtyRowService.markDirty(buffer.y);\n\n this._onLineFeed.fire();\n return true;\n }\n\n /**\n * CR\n * Carriage Return (Ctrl-M).\n *\n * @vt: #Y C0 CR \"Carriage Return\" \"\\r, \\x0D\" \"Move the cursor to the beginning of the row.\"\n */\n public carriageReturn(): boolean {\n this._bufferService.buffer.x = 0;\n return true;\n }\n\n /**\n * BS\n * Backspace (Ctrl-H).\n *\n * @vt: #Y C0 BS \"Backspace\" \"\\b, \\x08\" \"Move the cursor one position to the left.\"\n * By default it is not possible to move the cursor past the leftmost position.\n * If `reverse wrap-around` (`CSI ? 45 h`) is set, a previous soft line wrap (DECAWM)\n * can be undone with BS within the scroll margins. In that case the cursor will wrap back\n * to the end of the previous row. Note that it is not possible to peek back into the scrollbuffer\n * with the cursor, thus at the home position (top-leftmost cell) this has no effect.\n */\n public backspace(): boolean {\n const buffer = this._bufferService.buffer;\n\n // reverse wrap-around is disabled\n if (!this._coreService.decPrivateModes.reverseWraparound) {\n this._restrictCursor();\n if (buffer.x > 0) {\n buffer.x--;\n }\n return true;\n }\n\n // reverse wrap-around is enabled\n // other than for normal operation mode, reverse wrap-around allows the cursor\n // to be at x=cols to be able to address the last cell of a row by BS\n this._restrictCursor(this._bufferService.cols);\n\n if (buffer.x > 0) {\n buffer.x--;\n } else {\n /**\n * reverse wrap-around handling:\n * Our implementation deviates from xterm on purpose. Details:\n * - only previous soft NLs can be reversed (isWrapped=true)\n * - only works within scrollborders (top/bottom, left/right not yet supported)\n * - cannot peek into scrollbuffer\n * - any cursor movement sequence keeps working as expected\n */\n if (buffer.x === 0\n && buffer.y > buffer.scrollTop\n && buffer.y <= buffer.scrollBottom\n && buffer.lines.get(buffer.ybase + buffer.y)?.isWrapped)\n {\n buffer.lines.get(buffer.ybase + buffer.y)!.isWrapped = false;\n buffer.y--;\n buffer.x = this._bufferService.cols - 1;\n // find last taken cell - last cell can have 3 different states:\n // - hasContent(true) + hasWidth(1): narrow char - we are done\n // - hasWidth(0): second part of wide char - we are done\n // - hasContent(false) + hasWidth(1): empty cell due to early wrapping wide char, go one cell further back\n const line = buffer.lines.get(buffer.ybase + buffer.y)!;\n if (line.hasWidth(buffer.x) && !line.hasContent(buffer.x)) {\n buffer.x--;\n // We do this only once, since width=1 + hasContent=false currently happens only once before\n // early wrapping of a wide char.\n // This needs to be fixed once we support graphemes taking more than 2 cells.\n }\n }\n }\n this._restrictCursor();\n return true;\n }\n\n /**\n * TAB\n * Horizontal Tab (HT) (Ctrl-I).\n *\n * @vt: #Y C0 HT \"Horizontal Tabulation\" \"\\t, \\x09\" \"Move the cursor to the next character tab stop.\"\n */\n public tab(): boolean {\n if (this._bufferService.buffer.x >= this._bufferService.cols) {\n return true;\n }\n const originalX = this._bufferService.buffer.x;\n this._bufferService.buffer.x = this._bufferService.buffer.nextStop();\n if (this._optionsService.options.screenReaderMode) {\n this._onA11yTab.fire(this._bufferService.buffer.x - originalX);\n }\n return true;\n }\n\n /**\n * SO\n * Shift Out (Ctrl-N) -> Switch to Alternate Character Set. This invokes the\n * G1 character set.\n *\n * @vt: #P[Only limited ISO-2022 charset support.] C0 SO \"Shift Out\" \"\\x0E\" \"Switch to an alternative character set.\"\n */\n public shiftOut(): boolean {\n this._charsetService.setgLevel(1);\n return true;\n }\n\n /**\n * SI\n * Shift In (Ctrl-O) -> Switch to Standard Character Set. This invokes the G0\n * character set (the default).\n *\n * @vt: #Y C0 SI \"Shift In\" \"\\x0F\" \"Return to regular character set after Shift Out.\"\n */\n public shiftIn(): boolean {\n this._charsetService.setgLevel(0);\n return true;\n }\n\n /**\n * Restrict cursor to viewport size / scroll margin (origin mode).\n */\n private _restrictCursor(maxCol: number = this._bufferService.cols - 1): void {\n this._bufferService.buffer.x = Math.min(maxCol, Math.max(0, this._bufferService.buffer.x));\n this._bufferService.buffer.y = this._coreService.decPrivateModes.origin\n ? Math.min(this._bufferService.buffer.scrollBottom, Math.max(this._bufferService.buffer.scrollTop, this._bufferService.buffer.y))\n : Math.min(this._bufferService.rows - 1, Math.max(0, this._bufferService.buffer.y));\n this._dirtyRowService.markDirty(this._bufferService.buffer.y);\n }\n\n /**\n * Set absolute cursor position.\n */\n private _setCursor(x: number, y: number): void {\n this._dirtyRowService.markDirty(this._bufferService.buffer.y);\n if (this._coreService.decPrivateModes.origin) {\n this._bufferService.buffer.x = x;\n this._bufferService.buffer.y = this._bufferService.buffer.scrollTop + y;\n } else {\n this._bufferService.buffer.x = x;\n this._bufferService.buffer.y = y;\n }\n this._restrictCursor();\n this._dirtyRowService.markDirty(this._bufferService.buffer.y);\n }\n\n /**\n * Set relative cursor position.\n */\n private _moveCursor(x: number, y: number): void {\n // for relative changes we have to make sure we are within 0 .. cols/rows - 1\n // before calculating the new position\n this._restrictCursor();\n this._setCursor(this._bufferService.buffer.x + x, this._bufferService.buffer.y + y);\n }\n\n /**\n * CSI Ps A\n * Cursor Up Ps Times (default = 1) (CUU).\n *\n * @vt: #Y CSI CUU \"Cursor Up\" \"CSI Ps A\" \"Move cursor `Ps` times up (default=1).\"\n * If the cursor would pass the top scroll margin, it will stop there.\n */\n public cursorUp(params: IParams): boolean {\n // stop at scrollTop\n const diffToTop = this._bufferService.buffer.y - this._bufferService.buffer.scrollTop;\n if (diffToTop >= 0) {\n this._moveCursor(0, -Math.min(diffToTop, params.params[0] || 1));\n } else {\n this._moveCursor(0, -(params.params[0] || 1));\n }\n return true;\n }\n\n /**\n * CSI Ps B\n * Cursor Down Ps Times (default = 1) (CUD).\n *\n * @vt: #Y CSI CUD \"Cursor Down\" \"CSI Ps B\" \"Move cursor `Ps` times down (default=1).\"\n * If the cursor would pass the bottom scroll margin, it will stop there.\n */\n public cursorDown(params: IParams): boolean {\n // stop at scrollBottom\n const diffToBottom = this._bufferService.buffer.scrollBottom - this._bufferService.buffer.y;\n if (diffToBottom >= 0) {\n this._moveCursor(0, Math.min(diffToBottom, params.params[0] || 1));\n } else {\n this._moveCursor(0, params.params[0] || 1);\n }\n return true;\n }\n\n /**\n * CSI Ps C\n * Cursor Forward Ps Times (default = 1) (CUF).\n *\n * @vt: #Y CSI CUF \"Cursor Forward\" \"CSI Ps C\" \"Move cursor `Ps` times forward (default=1).\"\n */\n public cursorForward(params: IParams): boolean {\n this._moveCursor(params.params[0] || 1, 0);\n return true;\n }\n\n /**\n * CSI Ps D\n * Cursor Backward Ps Times (default = 1) (CUB).\n *\n * @vt: #Y CSI CUB \"Cursor Backward\" \"CSI Ps D\" \"Move cursor `Ps` times backward (default=1).\"\n */\n public cursorBackward(params: IParams): boolean {\n this._moveCursor(-(params.params[0] || 1), 0);\n return true;\n }\n\n /**\n * CSI Ps E\n * Cursor Next Line Ps Times (default = 1) (CNL).\n * Other than cursorDown (CUD) also set the cursor to first column.\n *\n * @vt: #Y CSI CNL \"Cursor Next Line\" \"CSI Ps E\" \"Move cursor `Ps` times down (default=1) and to the first column.\"\n * Same as CUD, additionally places the cursor at the first column.\n */\n public cursorNextLine(params: IParams): boolean {\n this.cursorDown(params);\n this._bufferService.buffer.x = 0;\n return true;\n }\n\n /**\n * CSI Ps F\n * Cursor Previous Line Ps Times (default = 1) (CPL).\n * Other than cursorUp (CUU) also set the cursor to first column.\n *\n * @vt: #Y CSI CPL \"Cursor Backward\" \"CSI Ps F\" \"Move cursor `Ps` times up (default=1) and to the first column.\"\n * Same as CUU, additionally places the cursor at the first column.\n */\n public cursorPrecedingLine(params: IParams): boolean {\n this.cursorUp(params);\n this._bufferService.buffer.x = 0;\n return true;\n }\n\n /**\n * CSI Ps G\n * Cursor Character Absolute [column] (default = [row,1]) (CHA).\n *\n * @vt: #Y CSI CHA \"Cursor Horizontal Absolute\" \"CSI Ps G\" \"Move cursor to `Ps`-th column of the active row (default=1).\"\n */\n public cursorCharAbsolute(params: IParams): boolean {\n this._setCursor((params.params[0] || 1) - 1, this._bufferService.buffer.y);\n return true;\n }\n\n /**\n * CSI Ps ; Ps H\n * Cursor Position [row;column] (default = [1,1]) (CUP).\n *\n * @vt: #Y CSI CUP \"Cursor Position\" \"CSI Ps ; Ps H\" \"Set cursor to position [`Ps`, `Ps`] (default = [1, 1]).\"\n * If ORIGIN mode is set, places the cursor to the absolute position within the scroll margins.\n * If ORIGIN mode is not set, places the cursor to the absolute position within the viewport.\n * Note that the coordinates are 1-based, thus the top left position starts at `1 ; 1`.\n */\n public cursorPosition(params: IParams): boolean {\n this._setCursor(\n // col\n (params.length >= 2) ? (params.params[1] || 1) - 1 : 0,\n // row\n (params.params[0] || 1) - 1\n );\n return true;\n }\n\n /**\n * CSI Pm ` Character Position Absolute\n * [column] (default = [row,1]) (HPA).\n * Currently same functionality as CHA.\n *\n * @vt: #Y CSI HPA \"Horizontal Position Absolute\" \"CSI Ps ` \" \"Same as CHA.\"\n */\n public charPosAbsolute(params: IParams): boolean {\n this._setCursor((params.params[0] || 1) - 1, this._bufferService.buffer.y);\n return true;\n }\n\n /**\n * CSI Pm a Character Position Relative\n * [columns] (default = [row,col+1]) (HPR)\n *\n * @vt: #Y CSI HPR \"Horizontal Position Relative\" \"CSI Ps a\" \"Same as CUF.\"\n */\n public hPositionRelative(params: IParams): boolean {\n this._moveCursor(params.params[0] || 1, 0);\n return true;\n }\n\n /**\n * CSI Pm d Vertical Position Absolute (VPA)\n * [row] (default = [1,column])\n *\n * @vt: #Y CSI VPA \"Vertical Position Absolute\" \"CSI Ps d\" \"Move cursor to `Ps`-th row (default=1).\"\n */\n public linePosAbsolute(params: IParams): boolean {\n this._setCursor(this._bufferService.buffer.x, (params.params[0] || 1) - 1);\n return true;\n }\n\n /**\n * CSI Pm e Vertical Position Relative (VPR)\n * [rows] (default = [row+1,column])\n * reuse CSI Ps B ?\n *\n * @vt: #Y CSI VPR \"Vertical Position Relative\" \"CSI Ps e\" \"Move cursor `Ps` times down (default=1).\"\n */\n public vPositionRelative(params: IParams): boolean {\n this._moveCursor(0, params.params[0] || 1);\n return true;\n }\n\n /**\n * CSI Ps ; Ps f\n * Horizontal and Vertical Position [row;column] (default =\n * [1,1]) (HVP).\n * Same as CUP.\n *\n * @vt: #Y CSI HVP \"Horizontal and Vertical Position\" \"CSI Ps ; Ps f\" \"Same as CUP.\"\n */\n public hVPosition(params: IParams): boolean {\n this.cursorPosition(params);\n return true;\n }\n\n /**\n * CSI Ps g Tab Clear (TBC).\n * Ps = 0 -> Clear Current Column (default).\n * Ps = 3 -> Clear All.\n * Potentially:\n * Ps = 2 -> Clear Stops on Line.\n * http://vt100.net/annarbor/aaa-ug/section6.html\n *\n * @vt: #Y CSI TBC \"Tab Clear\" \"CSI Ps g\" \"Clear tab stops at current position (0) or all (3) (default=0).\"\n * Clearing tabstops off the active row (Ps = 2, VT100) is currently not supported.\n */\n public tabClear(params: IParams): boolean {\n const param = params.params[0];\n if (param === 0) {\n delete this._bufferService.buffer.tabs[this._bufferService.buffer.x];\n } else if (param === 3) {\n this._bufferService.buffer.tabs = {};\n }\n return true;\n }\n\n /**\n * CSI Ps I\n * Cursor Forward Tabulation Ps tab stops (default = 1) (CHT).\n *\n * @vt: #Y CSI CHT \"Cursor Horizontal Tabulation\" \"CSI Ps I\" \"Move cursor `Ps` times tabs forward (default=1).\"\n */\n public cursorForwardTab(params: IParams): boolean {\n if (this._bufferService.buffer.x >= this._bufferService.cols) {\n return true;\n }\n let param = params.params[0] || 1;\n while (param--) {\n this._bufferService.buffer.x = this._bufferService.buffer.nextStop();\n }\n return true;\n }\n\n /**\n * CSI Ps Z Cursor Backward Tabulation Ps tab stops (default = 1) (CBT).\n *\n * @vt: #Y CSI CBT \"Cursor Backward Tabulation\" \"CSI Ps Z\" \"Move cursor `Ps` tabs backward (default=1).\"\n */\n public cursorBackwardTab(params: IParams): boolean {\n if (this._bufferService.buffer.x >= this._bufferService.cols) {\n return true;\n }\n let param = params.params[0] || 1;\n\n // make buffer local for faster access\n const buffer = this._bufferService.buffer;\n\n while (param--) {\n buffer.x = buffer.prevStop();\n }\n return true;\n }\n\n\n /**\n * Helper method to erase cells in a terminal row.\n * The cell gets replaced with the eraseChar of the terminal.\n * @param y row index\n * @param start first cell index to be erased\n * @param end end - 1 is last erased cell\n */\n private _eraseInBufferLine(y: number, start: number, end: number, clearWrap: boolean = false): void {\n const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + y)!;\n line.replaceCells(\n start,\n end,\n this._bufferService.buffer.getNullCell(this._eraseAttrData()),\n this._eraseAttrData()\n );\n if (clearWrap) {\n line.isWrapped = false;\n }\n }\n\n /**\n * Helper method to reset cells in a terminal row.\n * The cell gets replaced with the eraseChar of the terminal and the isWrapped property is set to false.\n * @param y row index\n */\n private _resetBufferLine(y: number): void {\n const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + y)!;\n line.fill(this._bufferService.buffer.getNullCell(this._eraseAttrData()));\n line.isWrapped = false;\n }\n\n /**\n * CSI Ps J Erase in Display (ED).\n * Ps = 0 -> Erase Below (default).\n * Ps = 1 -> Erase Above.\n * Ps = 2 -> Erase All.\n * Ps = 3 -> Erase Saved Lines (xterm).\n * CSI ? Ps J\n * Erase in Display (DECSED).\n * Ps = 0 -> Selective Erase Below (default).\n * Ps = 1 -> Selective Erase Above.\n * Ps = 2 -> Selective Erase All.\n *\n * @vt: #Y CSI ED \"Erase In Display\" \"CSI Ps J\" \"Erase various parts of the viewport.\"\n * Supported param values:\n *\n * | Ps | Effect |\n * | -- | ------------------------------------------------------------ |\n * | 0 | Erase from the cursor through the end of the viewport. |\n * | 1 | Erase from the beginning of the viewport through the cursor. |\n * | 2 | Erase complete viewport. |\n * | 3 | Erase scrollback. |\n *\n * @vt: #P[Protection attributes are not supported.] CSI DECSED \"Selective Erase In Display\" \"CSI ? Ps J\" \"Currently the same as ED.\"\n */\n public eraseInDisplay(params: IParams): boolean {\n this._restrictCursor();\n let j;\n switch (params.params[0]) {\n case 0:\n j = this._bufferService.buffer.y;\n this._dirtyRowService.markDirty(j);\n this._eraseInBufferLine(j++, this._bufferService.buffer.x, this._bufferService.cols, this._bufferService.buffer.x === 0);\n for (; j < this._bufferService.rows; j++) {\n this._resetBufferLine(j);\n }\n this._dirtyRowService.markDirty(j);\n break;\n case 1:\n j = this._bufferService.buffer.y;\n this._dirtyRowService.markDirty(j);\n // Deleted front part of line and everything before. This line will no longer be wrapped.\n this._eraseInBufferLine(j, 0, this._bufferService.buffer.x + 1, true);\n if (this._bufferService.buffer.x + 1 >= this._bufferService.cols) {\n // Deleted entire previous line. This next line can no longer be wrapped.\n this._bufferService.buffer.lines.get(j + 1)!.isWrapped = false;\n }\n while (j--) {\n this._resetBufferLine(j);\n }\n this._dirtyRowService.markDirty(0);\n break;\n case 2:\n j = this._bufferService.rows;\n this._dirtyRowService.markDirty(j - 1);\n while (j--) {\n this._resetBufferLine(j);\n }\n this._dirtyRowService.markDirty(0);\n break;\n case 3:\n // Clear scrollback (everything not in viewport)\n const scrollBackSize = this._bufferService.buffer.lines.length - this._bufferService.rows;\n if (scrollBackSize > 0) {\n this._bufferService.buffer.lines.trimStart(scrollBackSize);\n this._bufferService.buffer.ybase = Math.max(this._bufferService.buffer.ybase - scrollBackSize, 0);\n this._bufferService.buffer.ydisp = Math.max(this._bufferService.buffer.ydisp - scrollBackSize, 0);\n // Force a scroll event to refresh viewport\n this._onScroll.fire(0);\n }\n break;\n }\n return true;\n }\n\n /**\n * CSI Ps K Erase in Line (EL).\n * Ps = 0 -> Erase to Right (default).\n * Ps = 1 -> Erase to Left.\n * Ps = 2 -> Erase All.\n * CSI ? Ps K\n * Erase in Line (DECSEL).\n * Ps = 0 -> Selective Erase to Right (default).\n * Ps = 1 -> Selective Erase to Left.\n * Ps = 2 -> Selective Erase All.\n *\n * @vt: #Y CSI EL \"Erase In Line\" \"CSI Ps K\" \"Erase various parts of the active row.\"\n * Supported param values:\n *\n * | Ps | Effect |\n * | -- | -------------------------------------------------------- |\n * | 0 | Erase from the cursor through the end of the row. |\n * | 1 | Erase from the beginning of the line through the cursor. |\n * | 2 | Erase complete line. |\n *\n * @vt: #P[Protection attributes are not supported.] CSI DECSEL \"Selective Erase In Line\" \"CSI ? Ps K\" \"Currently the same as EL.\"\n */\n public eraseInLine(params: IParams): boolean {\n this._restrictCursor();\n switch (params.params[0]) {\n case 0:\n this._eraseInBufferLine(this._bufferService.buffer.y, this._bufferService.buffer.x, this._bufferService.cols);\n break;\n case 1:\n this._eraseInBufferLine(this._bufferService.buffer.y, 0, this._bufferService.buffer.x + 1);\n break;\n case 2:\n this._eraseInBufferLine(this._bufferService.buffer.y, 0, this._bufferService.cols);\n break;\n }\n this._dirtyRowService.markDirty(this._bufferService.buffer.y);\n return true;\n }\n\n /**\n * CSI Ps L\n * Insert Ps Line(s) (default = 1) (IL).\n *\n * @vt: #Y CSI IL \"Insert Line\" \"CSI Ps L\" \"Insert `Ps` blank lines at active row (default=1).\"\n * For every inserted line at the scroll top one line at the scroll bottom gets removed.\n * The cursor is set to the first column.\n * IL has no effect if the cursor is outside the scroll margins.\n */\n public insertLines(params: IParams): boolean {\n this._restrictCursor();\n let param = params.params[0] || 1;\n\n // make buffer local for faster access\n const buffer = this._bufferService.buffer;\n\n if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) {\n return true;\n }\n\n const row: number = buffer.ybase + buffer.y;\n\n const scrollBottomRowsOffset = this._bufferService.rows - 1 - buffer.scrollBottom;\n const scrollBottomAbsolute = this._bufferService.rows - 1 + buffer.ybase - scrollBottomRowsOffset + 1;\n while (param--) {\n // test: echo -e '\\e[44m\\e[1L\\e[0m'\n // blankLine(true) - xterm/linux behavior\n buffer.lines.splice(scrollBottomAbsolute - 1, 1);\n buffer.lines.splice(row, 0, buffer.getBlankLine(this._eraseAttrData()));\n }\n\n this._dirtyRowService.markRangeDirty(buffer.y, buffer.scrollBottom);\n buffer.x = 0; // see https://vt100.net/docs/vt220-rm/chapter4.html - vt220 only?\n return true;\n }\n\n /**\n * CSI Ps M\n * Delete Ps Line(s) (default = 1) (DL).\n *\n * @vt: #Y CSI DL \"Delete Line\" \"CSI Ps M\" \"Delete `Ps` lines at active row (default=1).\"\n * For every deleted line at the scroll top one blank line at the scroll bottom gets appended.\n * The cursor is set to the first column.\n * DL has no effect if the cursor is outside the scroll margins.\n */\n public deleteLines(params: IParams): boolean {\n this._restrictCursor();\n let param = params.params[0] || 1;\n\n // make buffer local for faster access\n const buffer = this._bufferService.buffer;\n\n if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) {\n return true;\n }\n\n const row: number = buffer.ybase + buffer.y;\n\n let j: number;\n j = this._bufferService.rows - 1 - buffer.scrollBottom;\n j = this._bufferService.rows - 1 + buffer.ybase - j;\n while (param--) {\n // test: echo -e '\\e[44m\\e[1M\\e[0m'\n // blankLine(true) - xterm/linux behavior\n buffer.lines.splice(row, 1);\n buffer.lines.splice(j, 0, buffer.getBlankLine(this._eraseAttrData()));\n }\n\n this._dirtyRowService.markRangeDirty(buffer.y, buffer.scrollBottom);\n buffer.x = 0; // see https://vt100.net/docs/vt220-rm/chapter4.html - vt220 only?\n return true;\n }\n\n /**\n * CSI Ps @\n * Insert Ps (Blank) Character(s) (default = 1) (ICH).\n *\n * @vt: #Y CSI ICH \"Insert Characters\" \"CSI Ps @\" \"Insert `Ps` (blank) characters (default = 1).\"\n * The ICH sequence inserts `Ps` blank characters. The cursor remains at the beginning of the blank characters.\n * Text between the cursor and right margin moves to the right. Characters moved past the right margin are lost.\n *\n *\n * FIXME: check against xterm - should not work outside of scroll margins (see VT520 manual)\n */\n public insertChars(params: IParams): boolean {\n this._restrictCursor();\n const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + this._bufferService.buffer.y);\n if (line) {\n line.insertCells(\n this._bufferService.buffer.x,\n params.params[0] || 1,\n this._bufferService.buffer.getNullCell(this._eraseAttrData()),\n this._eraseAttrData()\n );\n this._dirtyRowService.markDirty(this._bufferService.buffer.y);\n }\n return true;\n }\n\n /**\n * CSI Ps P\n * Delete Ps Character(s) (default = 1) (DCH).\n *\n * @vt: #Y CSI DCH \"Delete Character\" \"CSI Ps P\" \"Delete `Ps` characters (default=1).\"\n * As characters are deleted, the remaining characters between the cursor and right margin move to the left.\n * Character attributes move with the characters. The terminal adds blank characters at the right margin.\n *\n *\n * FIXME: check against xterm - should not work outside of scroll margins (see VT520 manual)\n */\n public deleteChars(params: IParams): boolean {\n this._restrictCursor();\n const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + this._bufferService.buffer.y);\n if (line) {\n line.deleteCells(\n this._bufferService.buffer.x,\n params.params[0] || 1,\n this._bufferService.buffer.getNullCell(this._eraseAttrData()),\n this._eraseAttrData()\n );\n this._dirtyRowService.markDirty(this._bufferService.buffer.y);\n }\n return true;\n }\n\n /**\n * CSI Ps S Scroll up Ps lines (default = 1) (SU).\n *\n * @vt: #Y CSI SU \"Scroll Up\" \"CSI Ps S\" \"Scroll `Ps` lines up (default=1).\"\n *\n *\n * FIXME: scrolled out lines at top = 1 should add to scrollback (xterm)\n */\n public scrollUp(params: IParams): boolean {\n let param = params.params[0] || 1;\n\n // make buffer local for faster access\n const buffer = this._bufferService.buffer;\n\n while (param--) {\n buffer.lines.splice(buffer.ybase + buffer.scrollTop, 1);\n buffer.lines.splice(buffer.ybase + buffer.scrollBottom, 0, buffer.getBlankLine(this._eraseAttrData()));\n }\n this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom);\n return true;\n }\n\n /**\n * CSI Ps T Scroll down Ps lines (default = 1) (SD).\n *\n * @vt: #Y CSI SD \"Scroll Down\" \"CSI Ps T\" \"Scroll `Ps` lines down (default=1).\"\n */\n public scrollDown(params: IParams): boolean {\n let param = params.params[0] || 1;\n\n // make buffer local for faster access\n const buffer = this._bufferService.buffer;\n\n while (param--) {\n buffer.lines.splice(buffer.ybase + buffer.scrollBottom, 1);\n buffer.lines.splice(buffer.ybase + buffer.scrollTop, 0, buffer.getBlankLine(DEFAULT_ATTR_DATA));\n }\n this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom);\n return true;\n }\n\n /**\n * CSI Ps SP @ Scroll left Ps columns (default = 1) (SL) ECMA-48\n *\n * Notation: (Pn)\n * Representation: CSI Pn 02/00 04/00\n * Parameter default value: Pn = 1\n * SL causes the data in the presentation component to be moved by n character positions\n * if the line orientation is horizontal, or by n line positions if the line orientation\n * is vertical, such that the data appear to move to the left; where n equals the value of Pn.\n * The active presentation position is not affected by this control function.\n *\n * Supported:\n * - always left shift (no line orientation setting respected)\n *\n * @vt: #Y CSI SL \"Scroll Left\" \"CSI Ps SP @\" \"Scroll viewport `Ps` times to the left.\"\n * SL moves the content of all lines within the scroll margins `Ps` times to the left.\n * SL has no effect outside of the scroll margins.\n */\n public scrollLeft(params: IParams): boolean {\n const buffer = this._bufferService.buffer;\n if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) {\n return true;\n }\n const param = params.params[0] || 1;\n for (let y = buffer.scrollTop; y <= buffer.scrollBottom; ++y) {\n const line = buffer.lines.get(buffer.ybase + y)!;\n line.deleteCells(0, param, buffer.getNullCell(this._eraseAttrData()), this._eraseAttrData());\n line.isWrapped = false;\n }\n this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom);\n return true;\n }\n\n /**\n * CSI Ps SP A Scroll right Ps columns (default = 1) (SR) ECMA-48\n *\n * Notation: (Pn)\n * Representation: CSI Pn 02/00 04/01\n * Parameter default value: Pn = 1\n * SR causes the data in the presentation component to be moved by n character positions\n * if the line orientation is horizontal, or by n line positions if the line orientation\n * is vertical, such that the data appear to move to the right; where n equals the value of Pn.\n * The active presentation position is not affected by this control function.\n *\n * Supported:\n * - always right shift (no line orientation setting respected)\n *\n * @vt: #Y CSI SR \"Scroll Right\" \"CSI Ps SP A\" \"Scroll viewport `Ps` times to the right.\"\n * SL moves the content of all lines within the scroll margins `Ps` times to the right.\n * Content at the right margin is lost.\n * SL has no effect outside of the scroll margins.\n */\n public scrollRight(params: IParams): boolean {\n const buffer = this._bufferService.buffer;\n if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) {\n return true;\n }\n const param = params.params[0] || 1;\n for (let y = buffer.scrollTop; y <= buffer.scrollBottom; ++y) {\n const line = buffer.lines.get(buffer.ybase + y)!;\n line.insertCells(0, param, buffer.getNullCell(this._eraseAttrData()), this._eraseAttrData());\n line.isWrapped = false;\n }\n this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom);\n return true;\n }\n\n /**\n * CSI Pm ' }\n * Insert Ps Column(s) (default = 1) (DECIC), VT420 and up.\n *\n * @vt: #Y CSI DECIC \"Insert Columns\" \"CSI Ps ' }\" \"Insert `Ps` columns at cursor position.\"\n * DECIC inserts `Ps` times blank columns at the cursor position for all lines with the scroll margins,\n * moving content to the right. Content at the right margin is lost.\n * DECIC has no effect outside the scrolling margins.\n */\n public insertColumns(params: IParams): boolean {\n const buffer = this._bufferService.buffer;\n if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) {\n return true;\n }\n const param = params.params[0] || 1;\n for (let y = buffer.scrollTop; y <= buffer.scrollBottom; ++y) {\n const line = this._bufferService.buffer.lines.get(buffer.ybase + y)!;\n line.insertCells(buffer.x, param, buffer.getNullCell(this._eraseAttrData()), this._eraseAttrData());\n line.isWrapped = false;\n }\n this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom);\n return true;\n }\n\n /**\n * CSI Pm ' ~\n * Delete Ps Column(s) (default = 1) (DECDC), VT420 and up.\n *\n * @vt: #Y CSI DECDC \"Delete Columns\" \"CSI Ps ' ~\" \"Delete `Ps` columns at cursor position.\"\n * DECDC deletes `Ps` times columns at the cursor position for all lines with the scroll margins,\n * moving content to the left. Blank columns are added at the right margin.\n * DECDC has no effect outside the scrolling margins.\n */\n public deleteColumns(params: IParams): boolean {\n const buffer = this._bufferService.buffer;\n if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) {\n return true;\n }\n const param = params.params[0] || 1;\n for (let y = buffer.scrollTop; y <= buffer.scrollBottom; ++y) {\n const line = buffer.lines.get(buffer.ybase + y)!;\n line.deleteCells(buffer.x, param, buffer.getNullCell(this._eraseAttrData()), this._eraseAttrData());\n line.isWrapped = false;\n }\n this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom);\n return true;\n }\n\n /**\n * CSI Ps X\n * Erase Ps Character(s) (default = 1) (ECH).\n *\n * @vt: #Y CSI ECH \"Erase Character\" \"CSI Ps X\" \"Erase `Ps` characters from current cursor position to the right (default=1).\"\n * ED erases `Ps` characters from current cursor position to the right.\n * ED works inside or outside the scrolling margins.\n */\n public eraseChars(params: IParams): boolean {\n this._restrictCursor();\n const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + this._bufferService.buffer.y);\n if (line) {\n line.replaceCells(\n this._bufferService.buffer.x,\n this._bufferService.buffer.x + (params.params[0] || 1),\n this._bufferService.buffer.getNullCell(this._eraseAttrData()),\n this._eraseAttrData()\n );\n this._dirtyRowService.markDirty(this._bufferService.buffer.y);\n }\n return true;\n }\n\n /**\n * CSI Ps b Repeat the preceding graphic character Ps times (REP).\n * From ECMA 48 (@see http://www.ecma-international.org/publications/files/ECMA-ST/Ecma-048.pdf)\n * Notation: (Pn)\n * Representation: CSI Pn 06/02\n * Parameter default value: Pn = 1\n * REP is used to indicate that the preceding character in the data stream,\n * if it is a graphic character (represented by one or more bit combinations) including SPACE,\n * is to be repeated n times, where n equals the value of Pn.\n * If the character preceding REP is a control function or part of a control function,\n * the effect of REP is not defined by this Standard.\n *\n * Since we propagate the terminal as xterm-256color we have to follow xterm's behavior:\n * - fullwidth + surrogate chars are ignored\n * - for combining chars only the base char gets repeated\n * - text attrs are applied normally\n * - wrap around is respected\n * - any valid sequence resets the carried forward char\n *\n * Note: To get reset on a valid sequence working correctly without much runtime penalty,\n * the preceding codepoint is stored on the parser in `this.print` and reset during `parser.parse`.\n *\n * @vt: #Y CSI REP \"Repeat Preceding Character\" \"CSI Ps b\" \"Repeat preceding character `Ps` times (default=1).\"\n * REP repeats the previous character `Ps` times advancing the cursor, also wrapping if DECAWM is set.\n * REP has no effect if the sequence does not follow a printable ASCII character\n * (NOOP for any other sequence in between or NON ASCII characters).\n */\n public repeatPrecedingCharacter(params: IParams): boolean {\n if (!this._parser.precedingCodepoint) {\n return true;\n }\n // call print to insert the chars and handle correct wrapping\n const length = params.params[0] || 1;\n const data = new Uint32Array(length);\n for (let i = 0; i < length; ++i) {\n data[i] = this._parser.precedingCodepoint;\n }\n this.print(data, 0, data.length);\n return true;\n }\n\n /**\n * CSI Ps c Send Device Attributes (Primary DA).\n * Ps = 0 or omitted -> request attributes from terminal. The\n * response depends on the decTerminalID resource setting.\n * -> CSI ? 1 ; 2 c (``VT100 with Advanced Video Option'')\n * -> CSI ? 1 ; 0 c (``VT101 with No Options'')\n * -> CSI ? 6 c (``VT102'')\n * -> CSI ? 6 0 ; 1 ; 2 ; 6 ; 8 ; 9 ; 1 5 ; c (``VT220'')\n * The VT100-style response parameters do not mean anything by\n * themselves. VT220 parameters do, telling the host what fea-\n * tures the terminal supports:\n * Ps = 1 -> 132-columns.\n * Ps = 2 -> Printer.\n * Ps = 6 -> Selective erase.\n * Ps = 8 -> User-defined keys.\n * Ps = 9 -> National replacement character sets.\n * Ps = 1 5 -> Technical characters.\n * Ps = 2 2 -> ANSI color, e.g., VT525.\n * Ps = 2 9 -> ANSI text locator (i.e., DEC Locator mode).\n *\n * @vt: #Y CSI DA1 \"Primary Device Attributes\" \"CSI c\" \"Send primary device attributes.\"\n *\n *\n * TODO: fix and cleanup response\n */\n public sendDeviceAttributesPrimary(params: IParams): boolean {\n if (params.params[0] > 0) {\n return true;\n }\n if (this._is('xterm') || this._is('rxvt-unicode') || this._is('screen')) {\n this._coreService.triggerDataEvent(C0.ESC + '[?1;2c');\n } else if (this._is('linux')) {\n this._coreService.triggerDataEvent(C0.ESC + '[?6c');\n }\n return true;\n }\n\n /**\n * CSI > Ps c\n * Send Device Attributes (Secondary DA).\n * Ps = 0 or omitted -> request the terminal's identification\n * code. The response depends on the decTerminalID resource set-\n * ting. It should apply only to VT220 and up, but xterm extends\n * this to VT100.\n * -> CSI > Pp ; Pv ; Pc c\n * where Pp denotes the terminal type\n * Pp = 0 -> ``VT100''.\n * Pp = 1 -> ``VT220''.\n * and Pv is the firmware version (for xterm, this was originally\n * the XFree86 patch number, starting with 95). In a DEC termi-\n * nal, Pc indicates the ROM cartridge registration number and is\n * always zero.\n * More information:\n * xterm/charproc.c - line 2012, for more information.\n * vim responds with ^[[?0c or ^[[?1c after the terminal's response (?)\n *\n * @vt: #Y CSI DA2 \"Secondary Device Attributes\" \"CSI > c\" \"Send primary device attributes.\"\n *\n *\n * TODO: fix and cleanup response\n */\n public sendDeviceAttributesSecondary(params: IParams): boolean {\n if (params.params[0] > 0) {\n return true;\n }\n // xterm and urxvt\n // seem to spit this\n // out around ~370 times (?).\n if (this._is('xterm')) {\n this._coreService.triggerDataEvent(C0.ESC + '[>0;276;0c');\n } else if (this._is('rxvt-unicode')) {\n this._coreService.triggerDataEvent(C0.ESC + '[>85;95;0c');\n } else if (this._is('linux')) {\n // not supported by linux console.\n // linux console echoes parameters.\n this._coreService.triggerDataEvent(params.params[0] + 'c');\n } else if (this._is('screen')) {\n this._coreService.triggerDataEvent(C0.ESC + '[>83;40003;0c');\n }\n return true;\n }\n\n /**\n * Evaluate if the current terminal is the given argument.\n * @param term The terminal name to evaluate\n */\n private _is(term: string): boolean {\n return (this._optionsService.options.termName + '').indexOf(term) === 0;\n }\n\n /**\n * CSI Pm h Set Mode (SM).\n * Ps = 2 -> Keyboard Action Mode (AM).\n * Ps = 4 -> Insert Mode (IRM).\n * Ps = 1 2 -> Send/receive (SRM).\n * Ps = 2 0 -> Automatic Newline (LNM).\n *\n * @vt: #P[Only IRM is supported.] CSI SM \"Set Mode\" \"CSI Pm h\" \"Set various terminal modes.\"\n * Supported param values by SM:\n *\n * | Param | Action | Support |\n * | ----- | -------------------------------------- | ------- |\n * | 2 | Keyboard Action Mode (KAM). Always on. | #N |\n * | 4 | Insert Mode (IRM). | #Y |\n * | 12 | Send/receive (SRM). Always off. | #N |\n * | 20 | Automatic Newline (LNM). Always off. | #N |\n */\n public setMode(params: IParams): boolean {\n for (let i = 0; i < params.length; i++) {\n switch (params.params[i]) {\n case 4:\n this._coreService.modes.insertMode = true;\n break;\n case 20:\n // this._t.convertEol = true;\n break;\n }\n }\n return true;\n }\n\n /**\n * CSI ? Pm h\n * DEC Private Mode Set (DECSET).\n * Ps = 1 -> Application Cursor Keys (DECCKM).\n * Ps = 2 -> Designate USASCII for character sets G0-G3\n * (DECANM), and set VT100 mode.\n * Ps = 3 -> 132 Column Mode (DECCOLM).\n * Ps = 4 -> Smooth (Slow) Scroll (DECSCLM).\n * Ps = 5 -> Reverse Video (DECSCNM).\n * Ps = 6 -> Origin Mode (DECOM).\n * Ps = 7 -> Wraparound Mode (DECAWM).\n * Ps = 8 -> Auto-repeat Keys (DECARM).\n * Ps = 9 -> Send Mouse X & Y on button press. See the sec-\n * tion Mouse Tracking.\n * Ps = 1 0 -> Show toolbar (rxvt).\n * Ps = 1 2 -> Start Blinking Cursor (att610).\n * Ps = 1 8 -> Print form feed (DECPFF).\n * Ps = 1 9 -> Set print extent to full screen (DECPEX).\n * Ps = 2 5 -> Show Cursor (DECTCEM).\n * Ps = 3 0 -> Show scrollbar (rxvt).\n * Ps = 3 5 -> Enable font-shifting functions (rxvt).\n * Ps = 3 8 -> Enter Tektronix Mode (DECTEK).\n * Ps = 4 0 -> Allow 80 -> 132 Mode.\n * Ps = 4 1 -> more(1) fix (see curses resource).\n * Ps = 4 2 -> Enable Nation Replacement Character sets (DECN-\n * RCM).\n * Ps = 4 4 -> Turn On Margin Bell.\n * Ps = 4 5 -> Reverse-wraparound Mode.\n * Ps = 4 6 -> Start Logging. This is normally disabled by a\n * compile-time option.\n * Ps = 4 7 -> Use Alternate Screen Buffer. (This may be dis-\n * abled by the titeInhibit resource).\n * Ps = 6 6 -> Application keypad (DECNKM).\n * Ps = 6 7 -> Backarrow key sends backspace (DECBKM).\n * Ps = 1 0 0 0 -> Send Mouse X & Y on button press and\n * release. See the section Mouse Tracking.\n * Ps = 1 0 0 1 -> Use Hilite Mouse Tracking.\n * Ps = 1 0 0 2 -> Use Cell Motion Mouse Tracking.\n * Ps = 1 0 0 3 -> Use All Motion Mouse Tracking.\n * Ps = 1 0 0 4 -> Send FocusIn/FocusOut events.\n * Ps = 1 0 0 5 -> Enable Extended Mouse Mode.\n * Ps = 1 0 1 0 -> Scroll to bottom on tty output (rxvt).\n * Ps = 1 0 1 1 -> Scroll to bottom on key press (rxvt).\n * Ps = 1 0 3 4 -> Interpret \"meta\" key, sets eighth bit.\n * (enables the eightBitInput resource).\n * Ps = 1 0 3 5 -> Enable special modifiers for Alt and Num-\n * Lock keys. (This enables the numLock resource).\n * Ps = 1 0 3 6 -> Send ESC when Meta modifies a key. (This\n * enables the metaSendsEscape resource).\n * Ps = 1 0 3 7 -> Send DEL from the editing-keypad Delete\n * key.\n * Ps = 1 0 3 9 -> Send ESC when Alt modifies a key. (This\n * enables the altSendsEscape resource).\n * Ps = 1 0 4 0 -> Keep selection even if not highlighted.\n * (This enables the keepSelection resource).\n * Ps = 1 0 4 1 -> Use the CLIPBOARD selection. (This enables\n * the selectToClipboard resource).\n * Ps = 1 0 4 2 -> Enable Urgency window manager hint when\n * Control-G is received. (This enables the bellIsUrgent\n * resource).\n * Ps = 1 0 4 3 -> Enable raising of the window when Control-G\n * is received. (enables the popOnBell resource).\n * Ps = 1 0 4 7 -> Use Alternate Screen Buffer. (This may be\n * disabled by the titeInhibit resource).\n * Ps = 1 0 4 8 -> Save cursor as in DECSC. (This may be dis-\n * abled by the titeInhibit resource).\n * Ps = 1 0 4 9 -> Save cursor as in DECSC and use Alternate\n * Screen Buffer, clearing it first. (This may be disabled by\n * the titeInhibit resource). This combines the effects of the 1\n * 0 4 7 and 1 0 4 8 modes. Use this with terminfo-based\n * applications rather than the 4 7 mode.\n * Ps = 1 0 5 0 -> Set terminfo/termcap function-key mode.\n * Ps = 1 0 5 1 -> Set Sun function-key mode.\n * Ps = 1 0 5 2 -> Set HP function-key mode.\n * Ps = 1 0 5 3 -> Set SCO function-key mode.\n * Ps = 1 0 6 0 -> Set legacy keyboard emulation (X11R6).\n * Ps = 1 0 6 1 -> Set VT220 keyboard emulation.\n * Ps = 2 0 0 4 -> Set bracketed paste mode.\n * Modes:\n * http: *vt100.net/docs/vt220-rm/chapter4.html\n *\n * @vt: #P[See below for supported modes.] CSI DECSET \"DEC Private Set Mode\" \"CSI ? Pm h\" \"Set various terminal attributes.\"\n * Supported param values by DECSET:\n *\n * | param | Action | Support |\n * | ----- | ------------------------------------------------------- | --------|\n * | 1 | Application Cursor Keys (DECCKM). | #Y |\n * | 2 | Designate US-ASCII for character sets G0-G3 (DECANM). | #Y |\n * | 3 | 132 Column Mode (DECCOLM). | #Y |\n * | 6 | Origin Mode (DECOM). | #Y |\n * | 7 | Auto-wrap Mode (DECAWM). | #Y |\n * | 8 | Auto-repeat Keys (DECARM). Always on. | #N |\n * | 9 | X10 xterm mouse protocol. | #Y |\n * | 12 | Start Blinking Cursor. | #Y |\n * | 25 | Show Cursor (DECTCEM). | #Y |\n * | 45 | Reverse wrap-around. | #Y |\n * | 47 | Use Alternate Screen Buffer. | #Y |\n * | 66 | Application keypad (DECNKM). | #Y |\n * | 1000 | X11 xterm mouse protocol. | #Y |\n * | 1002 | Use Cell Motion Mouse Tracking. | #Y |\n * | 1003 | Use All Motion Mouse Tracking. | #Y |\n * | 1004 | Send FocusIn/FocusOut events | #Y |\n * | 1005 | Enable UTF-8 Mouse Mode. | #N |\n * | 1006 | Enable SGR Mouse Mode. | #Y |\n * | 1015 | Enable urxvt Mouse Mode. | #N |\n * | 1047 | Use Alternate Screen Buffer. | #Y |\n * | 1048 | Save cursor as in DECSC. | #Y |\n * | 1049 | Save cursor and switch to alternate buffer clearing it. | #P[Does not clear the alternate buffer.] |\n * | 2004 | Set bracketed paste mode. | #Y |\n *\n *\n * FIXME: implement DECSCNM, 1049 should clear altbuffer\n */\n public setModePrivate(params: IParams): boolean {\n for (let i = 0; i < params.length; i++) {\n switch (params.params[i]) {\n case 1:\n this._coreService.decPrivateModes.applicationCursorKeys = true;\n break;\n case 2:\n this._charsetService.setgCharset(0, DEFAULT_CHARSET);\n this._charsetService.setgCharset(1, DEFAULT_CHARSET);\n this._charsetService.setgCharset(2, DEFAULT_CHARSET);\n this._charsetService.setgCharset(3, DEFAULT_CHARSET);\n // set VT100 mode here\n break;\n case 3:\n /**\n * DECCOLM - 132 column mode.\n * This is only active if 'SetWinLines' (24) is enabled\n * through `options.windowsOptions`.\n */\n if (this._optionsService.options.windowOptions.setWinLines) {\n this._bufferService.resize(132, this._bufferService.rows);\n this._onRequestReset.fire();\n }\n break;\n case 6:\n this._coreService.decPrivateModes.origin = true;\n this._setCursor(0, 0);\n break;\n case 7:\n this._coreService.decPrivateModes.wraparound = true;\n break;\n case 12:\n // this.cursorBlink = true;\n break;\n case 45:\n this._coreService.decPrivateModes.reverseWraparound = true;\n break;\n case 66:\n this._logService.debug('Serial port requested application keypad.');\n this._coreService.decPrivateModes.applicationKeypad = true;\n this._onRequestSyncScrollBar.fire();\n break;\n case 9: // X10 Mouse\n // no release, no motion, no wheel, no modifiers.\n this._coreMouseService.activeProtocol = 'X10';\n break;\n case 1000: // vt200 mouse\n // no motion.\n this._coreMouseService.activeProtocol = 'VT200';\n break;\n case 1002: // button event mouse\n this._coreMouseService.activeProtocol = 'DRAG';\n break;\n case 1003: // any event mouse\n // any event - sends motion events,\n // even if there is no button held down.\n this._coreMouseService.activeProtocol = 'ANY';\n break;\n case 1004: // send focusin/focusout events\n // focusin: ^[[I\n // focusout: ^[[O\n this._coreService.decPrivateModes.sendFocus = true;\n break;\n case 1005: // utf8 ext mode mouse - removed in #2507\n this._logService.debug('DECSET 1005 not supported (see #2507)');\n break;\n case 1006: // sgr ext mode mouse\n this._coreMouseService.activeEncoding = 'SGR';\n break;\n case 1015: // urxvt ext mode mouse - removed in #2507\n this._logService.debug('DECSET 1015 not supported (see #2507)');\n break;\n case 25: // show cursor\n this._coreService.isCursorHidden = false;\n break;\n case 1048: // alt screen cursor\n this.saveCursor();\n break;\n case 1049: // alt screen buffer cursor\n this.saveCursor();\n // FALL-THROUGH\n case 47: // alt screen buffer\n case 1047: // alt screen buffer\n this._bufferService.buffers.activateAltBuffer(this._eraseAttrData());\n this._coreService.isCursorInitialized = true;\n this._onRequestRefreshRows.fire(0, this._bufferService.rows - 1);\n this._onRequestSyncScrollBar.fire();\n break;\n case 2004: // bracketed paste mode (https://cirw.in/blog/bracketed-paste)\n this._coreService.decPrivateModes.bracketedPasteMode = true;\n break;\n }\n }\n return true;\n }\n\n\n /**\n * CSI Pm l Reset Mode (RM).\n * Ps = 2 -> Keyboard Action Mode (AM).\n * Ps = 4 -> Replace Mode (IRM).\n * Ps = 1 2 -> Send/receive (SRM).\n * Ps = 2 0 -> Normal Linefeed (LNM).\n *\n * @vt: #P[Only IRM is supported.] CSI RM \"Reset Mode\" \"CSI Pm l\" \"Set various terminal attributes.\"\n * Supported param values by RM:\n *\n * | Param | Action | Support |\n * | ----- | -------------------------------------- | ------- |\n * | 2 | Keyboard Action Mode (KAM). Always on. | #N |\n * | 4 | Replace Mode (IRM). (default) | #Y |\n * | 12 | Send/receive (SRM). Always off. | #N |\n * | 20 | Normal Linefeed (LNM). Always off. | #N |\n *\n *\n * FIXME: why is LNM commented out?\n */\n public resetMode(params: IParams): boolean {\n for (let i = 0; i < params.length; i++) {\n switch (params.params[i]) {\n case 4:\n this._coreService.modes.insertMode = false;\n break;\n case 20:\n // this._t.convertEol = false;\n break;\n }\n }\n return true;\n }\n\n /**\n * CSI ? Pm l\n * DEC Private Mode Reset (DECRST).\n * Ps = 1 -> Normal Cursor Keys (DECCKM).\n * Ps = 2 -> Designate VT52 mode (DECANM).\n * Ps = 3 -> 80 Column Mode (DECCOLM).\n * Ps = 4 -> Jump (Fast) Scroll (DECSCLM).\n * Ps = 5 -> Normal Video (DECSCNM).\n * Ps = 6 -> Normal Cursor Mode (DECOM).\n * Ps = 7 -> No Wraparound Mode (DECAWM).\n * Ps = 8 -> No Auto-repeat Keys (DECARM).\n * Ps = 9 -> Don't send Mouse X & Y on button press.\n * Ps = 1 0 -> Hide toolbar (rxvt).\n * Ps = 1 2 -> Stop Blinking Cursor (att610).\n * Ps = 1 8 -> Don't print form feed (DECPFF).\n * Ps = 1 9 -> Limit print to scrolling region (DECPEX).\n * Ps = 2 5 -> Hide Cursor (DECTCEM).\n * Ps = 3 0 -> Don't show scrollbar (rxvt).\n * Ps = 3 5 -> Disable font-shifting functions (rxvt).\n * Ps = 4 0 -> Disallow 80 -> 132 Mode.\n * Ps = 4 1 -> No more(1) fix (see curses resource).\n * Ps = 4 2 -> Disable Nation Replacement Character sets (DEC-\n * NRCM).\n * Ps = 4 4 -> Turn Off Margin Bell.\n * Ps = 4 5 -> No Reverse-wraparound Mode.\n * Ps = 4 6 -> Stop Logging. (This is normally disabled by a\n * compile-time option).\n * Ps = 4 7 -> Use Normal Screen Buffer.\n * Ps = 6 6 -> Numeric keypad (DECNKM).\n * Ps = 6 7 -> Backarrow key sends delete (DECBKM).\n * Ps = 1 0 0 0 -> Don't send Mouse X & Y on button press and\n * release. See the section Mouse Tracking.\n * Ps = 1 0 0 1 -> Don't use Hilite Mouse Tracking.\n * Ps = 1 0 0 2 -> Don't use Cell Motion Mouse Tracking.\n * Ps = 1 0 0 3 -> Don't use All Motion Mouse Tracking.\n * Ps = 1 0 0 4 -> Don't send FocusIn/FocusOut events.\n * Ps = 1 0 0 5 -> Disable Extended Mouse Mode.\n * Ps = 1 0 1 0 -> Don't scroll to bottom on tty output\n * (rxvt).\n * Ps = 1 0 1 1 -> Don't scroll to bottom on key press (rxvt).\n * Ps = 1 0 3 4 -> Don't interpret \"meta\" key. (This disables\n * the eightBitInput resource).\n * Ps = 1 0 3 5 -> Disable special modifiers for Alt and Num-\n * Lock keys. (This disables the numLock resource).\n * Ps = 1 0 3 6 -> Don't send ESC when Meta modifies a key.\n * (This disables the metaSendsEscape resource).\n * Ps = 1 0 3 7 -> Send VT220 Remove from the editing-keypad\n * Delete key.\n * Ps = 1 0 3 9 -> Don't send ESC when Alt modifies a key.\n * (This disables the altSendsEscape resource).\n * Ps = 1 0 4 0 -> Do not keep selection when not highlighted.\n * (This disables the keepSelection resource).\n * Ps = 1 0 4 1 -> Use the PRIMARY selection. (This disables\n * the selectToClipboard resource).\n * Ps = 1 0 4 2 -> Disable Urgency window manager hint when\n * Control-G is received. (This disables the bellIsUrgent\n * resource).\n * Ps = 1 0 4 3 -> Disable raising of the window when Control-\n * G is received. (This disables the popOnBell resource).\n * Ps = 1 0 4 7 -> Use Normal Screen Buffer, clearing screen\n * first if in the Alternate Screen. (This may be disabled by\n * the titeInhibit resource).\n * Ps = 1 0 4 8 -> Restore cursor as in DECRC. (This may be\n * disabled by the titeInhibit resource).\n * Ps = 1 0 4 9 -> Use Normal Screen Buffer and restore cursor\n * as in DECRC. (This may be disabled by the titeInhibit\n * resource). This combines the effects of the 1 0 4 7 and 1 0\n * 4 8 modes. Use this with terminfo-based applications rather\n * than the 4 7 mode.\n * Ps = 1 0 5 0 -> Reset terminfo/termcap function-key mode.\n * Ps = 1 0 5 1 -> Reset Sun function-key mode.\n * Ps = 1 0 5 2 -> Reset HP function-key mode.\n * Ps = 1 0 5 3 -> Reset SCO function-key mode.\n * Ps = 1 0 6 0 -> Reset legacy keyboard emulation (X11R6).\n * Ps = 1 0 6 1 -> Reset keyboard emulation to Sun/PC style.\n * Ps = 2 0 0 4 -> Reset bracketed paste mode.\n *\n * @vt: #P[See below for supported modes.] CSI DECRST \"DEC Private Reset Mode\" \"CSI ? Pm l\" \"Reset various terminal attributes.\"\n * Supported param values by DECRST:\n *\n * | param | Action | Support |\n * | ----- | ------------------------------------------------------- | ------- |\n * | 1 | Normal Cursor Keys (DECCKM). | #Y |\n * | 2 | Designate VT52 mode (DECANM). | #N |\n * | 3 | 80 Column Mode (DECCOLM). | #B[Switches to old column width instead of 80.] |\n * | 6 | Normal Cursor Mode (DECOM). | #Y |\n * | 7 | No Wraparound Mode (DECAWM). | #Y |\n * | 8 | No Auto-repeat Keys (DECARM). | #N |\n * | 9 | Don't send Mouse X & Y on button press. | #Y |\n * | 12 | Stop Blinking Cursor. | #Y |\n * | 25 | Hide Cursor (DECTCEM). | #Y |\n * | 45 | No reverse wrap-around. | #Y |\n * | 47 | Use Normal Screen Buffer. | #Y |\n * | 66 | Numeric keypad (DECNKM). | #Y |\n * | 1000 | Don't send Mouse reports. | #Y |\n * | 1002 | Don't use Cell Motion Mouse Tracking. | #Y |\n * | 1003 | Don't use All Motion Mouse Tracking. | #Y |\n * | 1004 | Don't send FocusIn/FocusOut events. | #Y |\n * | 1005 | Disable UTF-8 Mouse Mode. | #N |\n * | 1006 | Disable SGR Mouse Mode. | #Y |\n * | 1015 | Disable urxvt Mouse Mode. | #N |\n * | 1047 | Use Normal Screen Buffer (clearing screen if in alt). | #Y |\n * | 1048 | Restore cursor as in DECRC. | #Y |\n * | 1049 | Use Normal Screen Buffer and restore cursor. | #Y |\n * | 2004 | Reset bracketed paste mode. | #Y |\n *\n *\n * FIXME: DECCOLM is currently broken (already fixed in window options PR)\n */\n public resetModePrivate(params: IParams): boolean {\n for (let i = 0; i < params.length; i++) {\n switch (params.params[i]) {\n case 1:\n this._coreService.decPrivateModes.applicationCursorKeys = false;\n break;\n case 3:\n /**\n * DECCOLM - 80 column mode.\n * This is only active if 'SetWinLines' (24) is enabled\n * through `options.windowsOptions`.\n */\n if (this._optionsService.options.windowOptions.setWinLines) {\n this._bufferService.resize(80, this._bufferService.rows);\n this._onRequestReset.fire();\n }\n break;\n case 6:\n this._coreService.decPrivateModes.origin = false;\n this._setCursor(0, 0);\n break;\n case 7:\n this._coreService.decPrivateModes.wraparound = false;\n break;\n case 12:\n // this.cursorBlink = false;\n break;\n case 45:\n this._coreService.decPrivateModes.reverseWraparound = false;\n break;\n case 66:\n this._logService.debug('Switching back to normal keypad.');\n this._coreService.decPrivateModes.applicationKeypad = false;\n this._onRequestSyncScrollBar.fire();\n break;\n case 9: // X10 Mouse\n case 1000: // vt200 mouse\n case 1002: // button event mouse\n case 1003: // any event mouse\n this._coreMouseService.activeProtocol = 'NONE';\n break;\n case 1004: // send focusin/focusout events\n this._coreService.decPrivateModes.sendFocus = false;\n break;\n case 1005: // utf8 ext mode mouse - removed in #2507\n this._logService.debug('DECRST 1005 not supported (see #2507)');\n break;\n case 1006: // sgr ext mode mouse\n this._coreMouseService.activeEncoding = 'DEFAULT';\n break;\n case 1015: // urxvt ext mode mouse - removed in #2507\n this._logService.debug('DECRST 1015 not supported (see #2507)');\n break;\n case 25: // hide cursor\n this._coreService.isCursorHidden = true;\n break;\n case 1048: // alt screen cursor\n this.restoreCursor();\n break;\n case 1049: // alt screen buffer cursor\n // FALL-THROUGH\n case 47: // normal screen buffer\n case 1047: // normal screen buffer - clearing it first\n // Ensure the selection manager has the correct buffer\n this._bufferService.buffers.activateNormalBuffer();\n if (params.params[i] === 1049) {\n this.restoreCursor();\n }\n this._coreService.isCursorInitialized = true;\n this._onRequestRefreshRows.fire(0, this._bufferService.rows - 1);\n this._onRequestSyncScrollBar.fire();\n break;\n case 2004: // bracketed paste mode (https://cirw.in/blog/bracketed-paste)\n this._coreService.decPrivateModes.bracketedPasteMode = false;\n break;\n }\n }\n return true;\n }\n\n /**\n * Helper to write color information packed with color mode.\n */\n private _updateAttrColor(color: number, mode: number, c1: number, c2: number, c3: number): number {\n if (mode === 2) {\n color |= Attributes.CM_RGB;\n color &= ~Attributes.RGB_MASK;\n color |= AttributeData.fromColorRGB([c1, c2, c3]);\n } else if (mode === 5) {\n color &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK);\n color |= Attributes.CM_P256 | (c1 & 0xff);\n }\n return color;\n }\n\n /**\n * Helper to extract and apply color params/subparams.\n * Returns advance for params index.\n */\n private _extractColor(params: IParams, pos: number, attr: IAttributeData): number {\n // normalize params\n // meaning: [target, CM, ign, val, val, val]\n // RGB : [ 38/48, 2, ign, r, g, b]\n // P256 : [ 38/48, 5, ign, v, ign, ign]\n const accu = [0, 0, -1, 0, 0, 0];\n\n // alignment placeholder for non color space sequences\n let cSpace = 0;\n\n // return advance we took in params\n let advance = 0;\n\n do {\n accu[advance + cSpace] = params.params[pos + advance];\n if (params.hasSubParams(pos + advance)) {\n const subparams = params.getSubParams(pos + advance)!;\n let i = 0;\n do {\n if (accu[1] === 5) {\n cSpace = 1;\n }\n accu[advance + i + 1 + cSpace] = subparams[i];\n } while (++i < subparams.length && i + advance + 1 + cSpace < accu.length);\n break;\n }\n // exit early if can decide color mode with semicolons\n if ((accu[1] === 5 && advance + cSpace >= 2)\n || (accu[1] === 2 && advance + cSpace >= 5)) {\n break;\n }\n // offset colorSpace slot for semicolon mode\n if (accu[1]) {\n cSpace = 1;\n }\n } while (++advance + pos < params.length && advance + cSpace < accu.length);\n\n // set default values to 0\n for (let i = 2; i < accu.length; ++i) {\n if (accu[i] === -1) {\n accu[i] = 0;\n }\n }\n\n // apply colors\n switch (accu[0]) {\n case 38:\n attr.fg = this._updateAttrColor(attr.fg, accu[1], accu[3], accu[4], accu[5]);\n break;\n case 48:\n attr.bg = this._updateAttrColor(attr.bg, accu[1], accu[3], accu[4], accu[5]);\n break;\n case 58:\n attr.extended = attr.extended.clone();\n attr.extended.underlineColor = this._updateAttrColor(attr.extended.underlineColor, accu[1], accu[3], accu[4], accu[5]);\n }\n\n return advance;\n }\n\n /**\n * SGR 4 subparams:\n * 4:0 - equal to SGR 24 (turn off all underline)\n * 4:1 - equal to SGR 4 (single underline)\n * 4:2 - equal to SGR 21 (double underline)\n * 4:3 - curly underline\n * 4:4 - dotted underline\n * 4:5 - dashed underline\n */\n private _processUnderline(style: number, attr: IAttributeData): void {\n // treat extended attrs as immutable, thus always clone from old one\n // this is needed since the buffer only holds references to it\n attr.extended = attr.extended.clone();\n\n // default to 1 == single underline\n if (!~style || style > 5) {\n style = 1;\n }\n attr.extended.underlineStyle = style;\n attr.fg |= FgFlags.UNDERLINE;\n\n // 0 deactivates underline\n if (style === 0) {\n attr.fg &= ~FgFlags.UNDERLINE;\n }\n\n // update HAS_EXTENDED in BG\n attr.updateExtended();\n }\n\n /**\n * CSI Pm m Character Attributes (SGR).\n *\n * @vt: #P[See below for supported attributes.] CSI SGR \"Select Graphic Rendition\" \"CSI Pm m\" \"Set/Reset various text attributes.\"\n * SGR selects one or more character attributes at the same time. Multiple params (up to 32)\n * are applied in order from left to right. The changed attributes are applied to all new\n * characters received. If you move characters in the viewport by scrolling or any other means,\n * then the attributes move with the characters.\n *\n * Supported param values by SGR:\n *\n * | Param | Meaning | Support |\n * | --------- | -------------------------------------------------------- | ------- |\n * | 0 | Normal (default). Resets any other preceding SGR. | #Y |\n * | 1 | Bold. (also see `options.drawBoldTextInBrightColors`) | #Y |\n * | 2 | Faint, decreased intensity. | #Y |\n * | 3 | Italic. | #Y |\n * | 4 | Underlined (see below for style support). | #Y |\n * | 5 | Slowly blinking. | #N |\n * | 6 | Rapidly blinking. | #N |\n * | 7 | Inverse. Flips foreground and background color. | #Y |\n * | 8 | Invisible (hidden). | #Y |\n * | 9 | Crossed-out characters. | #N |\n * | 21 | Doubly underlined. | #P[Currently outputs a single underline.] |\n * | 22 | Normal (neither bold nor faint). | #Y |\n * | 23 | No italic. | #Y |\n * | 24 | Not underlined. | #Y |\n * | 25 | Steady (not blinking). | #Y |\n * | 27 | Positive (not inverse). | #Y |\n * | 28 | Visible (not hidden). | #Y |\n * | 29 | Not Crossed-out. | #N |\n * | 30 | Foreground color: Black. | #Y |\n * | 31 | Foreground color: Red. | #Y |\n * | 32 | Foreground color: Green. | #Y |\n * | 33 | Foreground color: Yellow. | #Y |\n * | 34 | Foreground color: Blue. | #Y |\n * | 35 | Foreground color: Magenta. | #Y |\n * | 36 | Foreground color: Cyan. | #Y |\n * | 37 | Foreground color: White. | #Y |\n * | 38 | Foreground color: Extended color. | #P[Support for RGB and indexed colors, see below.] |\n * | 39 | Foreground color: Default (original). | #Y |\n * | 40 | Background color: Black. | #Y |\n * | 41 | Background color: Red. | #Y |\n * | 42 | Background color: Green. | #Y |\n * | 43 | Background color: Yellow. | #Y |\n * | 44 | Background color: Blue. | #Y |\n * | 45 | Background color: Magenta. | #Y |\n * | 46 | Background color: Cyan. | #Y |\n * | 47 | Background color: White. | #Y |\n * | 48 | Background color: Extended color. | #P[Support for RGB and indexed colors, see below.] |\n * | 49 | Background color: Default (original). | #Y |\n * | 90 - 97 | Bright foreground color (analogous to 30 - 37). | #Y |\n * | 100 - 107 | Bright background color (analogous to 40 - 47). | #Y |\n *\n * Underline supports subparams to denote the style in the form `4 : x`:\n *\n * | x | Meaning | Support |\n * | ------ | ------------------------------------------------------------- | ------- |\n * | 0 | No underline. Same as `SGR 24 m`. | #Y |\n * | 1 | Single underline. Same as `SGR 4 m`. | #Y |\n * | 2 | Double underline. | #P[Currently outputs a single underline.] |\n * | 3 | Curly underline. | #P[Currently outputs a single underline.] |\n * | 4 | Dotted underline. | #P[Currently outputs a single underline.] |\n * | 5 | Dashed underline. | #P[Currently outputs a single underline.] |\n * | other | Single underline. Same as `SGR 4 m`. | #Y |\n *\n * Extended colors are supported for foreground (Ps=38) and background (Ps=48) as follows:\n *\n * | Ps + 1 | Meaning | Support |\n * | ------ | ------------------------------------------------------------- | ------- |\n * | 0 | Implementation defined. | #N |\n * | 1 | Transparent. | #N |\n * | 2 | RGB color as `Ps ; 2 ; R ; G ; B` or `Ps : 2 : : R : G : B`. | #Y |\n * | 3 | CMY color. | #N |\n * | 4 | CMYK color. | #N |\n * | 5 | Indexed (256 colors) as `Ps ; 5 ; INDEX` or `Ps : 5 : INDEX`. | #Y |\n *\n *\n * FIXME: blinking is implemented in attrs, but not working in renderers?\n * FIXME: remove dead branch for p=100\n */\n public charAttributes(params: IParams): boolean {\n // Optimize a single SGR0.\n if (params.length === 1 && params.params[0] === 0) {\n this._curAttrData.fg = DEFAULT_ATTR_DATA.fg;\n this._curAttrData.bg = DEFAULT_ATTR_DATA.bg;\n return true;\n }\n\n const l = params.length;\n let p;\n const attr = this._curAttrData;\n\n for (let i = 0; i < l; i++) {\n p = params.params[i];\n if (p >= 30 && p <= 37) {\n // fg color 8\n attr.fg &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK);\n attr.fg |= Attributes.CM_P16 | (p - 30);\n } else if (p >= 40 && p <= 47) {\n // bg color 8\n attr.bg &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK);\n attr.bg |= Attributes.CM_P16 | (p - 40);\n } else if (p >= 90 && p <= 97) {\n // fg color 16\n attr.fg &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK);\n attr.fg |= Attributes.CM_P16 | (p - 90) | 8;\n } else if (p >= 100 && p <= 107) {\n // bg color 16\n attr.bg &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK);\n attr.bg |= Attributes.CM_P16 | (p - 100) | 8;\n } else if (p === 0) {\n // default\n attr.fg = DEFAULT_ATTR_DATA.fg;\n attr.bg = DEFAULT_ATTR_DATA.bg;\n } else if (p === 1) {\n // bold text\n attr.fg |= FgFlags.BOLD;\n } else if (p === 3) {\n // italic text\n attr.bg |= BgFlags.ITALIC;\n } else if (p === 4) {\n // underlined text\n attr.fg |= FgFlags.UNDERLINE;\n this._processUnderline(params.hasSubParams(i) ? params.getSubParams(i)![0] : UnderlineStyle.SINGLE, attr);\n } else if (p === 5) {\n // blink\n attr.fg |= FgFlags.BLINK;\n } else if (p === 7) {\n // inverse and positive\n // test with: echo -e '\\e[31m\\e[42mhello\\e[7mworld\\e[27mhi\\e[m'\n attr.fg |= FgFlags.INVERSE;\n } else if (p === 8) {\n // invisible\n attr.fg |= FgFlags.INVISIBLE;\n } else if (p === 2) {\n // dimmed text\n attr.bg |= BgFlags.DIM;\n } else if (p === 21) {\n // double underline\n this._processUnderline(UnderlineStyle.DOUBLE, attr);\n } else if (p === 22) {\n // not bold nor faint\n attr.fg &= ~FgFlags.BOLD;\n attr.bg &= ~BgFlags.DIM;\n } else if (p === 23) {\n // not italic\n attr.bg &= ~BgFlags.ITALIC;\n } else if (p === 24) {\n // not underlined\n attr.fg &= ~FgFlags.UNDERLINE;\n } else if (p === 25) {\n // not blink\n attr.fg &= ~FgFlags.BLINK;\n } else if (p === 27) {\n // not inverse\n attr.fg &= ~FgFlags.INVERSE;\n } else if (p === 28) {\n // not invisible\n attr.fg &= ~FgFlags.INVISIBLE;\n } else if (p === 39) {\n // reset fg\n attr.fg &= ~(Attributes.CM_MASK | Attributes.RGB_MASK);\n attr.fg |= DEFAULT_ATTR_DATA.fg & (Attributes.PCOLOR_MASK | Attributes.RGB_MASK);\n } else if (p === 49) {\n // reset bg\n attr.bg &= ~(Attributes.CM_MASK | Attributes.RGB_MASK);\n attr.bg |= DEFAULT_ATTR_DATA.bg & (Attributes.PCOLOR_MASK | Attributes.RGB_MASK);\n } else if (p === 38 || p === 48 || p === 58) {\n // fg color 256 and RGB\n i += this._extractColor(params, i, attr);\n } else if (p === 59) {\n attr.extended = attr.extended.clone();\n attr.extended.underlineColor = -1;\n attr.updateExtended();\n } else if (p === 100) { // FIXME: dead branch, p=100 already handled above!\n // reset fg/bg\n attr.fg &= ~(Attributes.CM_MASK | Attributes.RGB_MASK);\n attr.fg |= DEFAULT_ATTR_DATA.fg & (Attributes.PCOLOR_MASK | Attributes.RGB_MASK);\n attr.bg &= ~(Attributes.CM_MASK | Attributes.RGB_MASK);\n attr.bg |= DEFAULT_ATTR_DATA.bg & (Attributes.PCOLOR_MASK | Attributes.RGB_MASK);\n } else {\n this._logService.debug('Unknown SGR attribute: %d.', p);\n }\n }\n return true;\n }\n\n /**\n * CSI Ps n Device Status Report (DSR).\n * Ps = 5 -> Status Report. Result (``OK'') is\n * CSI 0 n\n * Ps = 6 -> Report Cursor Position (CPR) [row;column].\n * Result is\n * CSI r ; c R\n * CSI ? Ps n\n * Device Status Report (DSR, DEC-specific).\n * Ps = 6 -> Report Cursor Position (CPR) [row;column] as CSI\n * ? r ; c R (assumes page is zero).\n * Ps = 1 5 -> Report Printer status as CSI ? 1 0 n (ready).\n * or CSI ? 1 1 n (not ready).\n * Ps = 2 5 -> Report UDK status as CSI ? 2 0 n (unlocked)\n * or CSI ? 2 1 n (locked).\n * Ps = 2 6 -> Report Keyboard status as\n * CSI ? 2 7 ; 1 ; 0 ; 0 n (North American).\n * The last two parameters apply to VT400 & up, and denote key-\n * board ready and LK01 respectively.\n * Ps = 5 3 -> Report Locator status as\n * CSI ? 5 3 n Locator available, if compiled-in, or\n * CSI ? 5 0 n No Locator, if not.\n *\n * @vt: #Y CSI DSR \"Device Status Report\" \"CSI Ps n\" \"Request cursor position (CPR) with `Ps` = 6.\"\n */\n public deviceStatus(params: IParams): boolean {\n switch (params.params[0]) {\n case 5:\n // status report\n this._coreService.triggerDataEvent(`${C0.ESC}[0n`);\n break;\n case 6:\n // cursor position\n const y = this._bufferService.buffer.y + 1;\n const x = this._bufferService.buffer.x + 1;\n this._coreService.triggerDataEvent(`${C0.ESC}[${y};${x}R`);\n break;\n }\n return true;\n }\n\n // @vt: #P[Only CPR is supported.] CSI DECDSR \"DEC Device Status Report\" \"CSI ? Ps n\" \"Only CPR is supported (same as DSR).\"\n public deviceStatusPrivate(params: IParams): boolean {\n // modern xterm doesnt seem to\n // respond to any of these except ?6, 6, and 5\n switch (params.params[0]) {\n case 6:\n // cursor position\n const y = this._bufferService.buffer.y + 1;\n const x = this._bufferService.buffer.x + 1;\n this._coreService.triggerDataEvent(`${C0.ESC}[?${y};${x}R`);\n break;\n case 15:\n // no printer\n // this.handler(C0.ESC + '[?11n');\n break;\n case 25:\n // dont support user defined keys\n // this.handler(C0.ESC + '[?21n');\n break;\n case 26:\n // north american keyboard\n // this.handler(C0.ESC + '[?27;1;0;0n');\n break;\n case 53:\n // no dec locator/mouse\n // this.handler(C0.ESC + '[?50n');\n break;\n }\n return true;\n }\n\n /**\n * CSI ! p Soft terminal reset (DECSTR).\n * http://vt100.net/docs/vt220-rm/table4-10.html\n *\n * @vt: #Y CSI DECSTR \"Soft Terminal Reset\" \"CSI ! p\" \"Reset several terminal attributes to initial state.\"\n * There are two terminal reset sequences - RIS and DECSTR. While RIS performs almost a full terminal bootstrap,\n * DECSTR only resets certain attributes. For most needs DECSTR should be sufficient.\n *\n * The following terminal attributes are reset to default values:\n * - IRM is reset (dafault = false)\n * - scroll margins are reset (default = viewport size)\n * - erase attributes are reset to default\n * - charsets are reset\n * - DECSC data is reset to initial values\n * - DECOM is reset to absolute mode\n *\n *\n * FIXME: there are several more attributes missing (see VT520 manual)\n */\n public softReset(params: IParams): boolean {\n this._coreService.isCursorHidden = false;\n this._onRequestSyncScrollBar.fire();\n this._bufferService.buffer.scrollTop = 0;\n this._bufferService.buffer.scrollBottom = this._bufferService.rows - 1;\n this._curAttrData = DEFAULT_ATTR_DATA.clone();\n this._coreService.reset();\n this._charsetService.reset();\n\n // reset DECSC data\n this._bufferService.buffer.savedX = 0;\n this._bufferService.buffer.savedY = this._bufferService.buffer.ybase;\n this._bufferService.buffer.savedCurAttrData.fg = this._curAttrData.fg;\n this._bufferService.buffer.savedCurAttrData.bg = this._curAttrData.bg;\n this._bufferService.buffer.savedCharset = this._charsetService.charset;\n\n // reset DECOM\n this._coreService.decPrivateModes.origin = false;\n return true;\n }\n\n /**\n * CSI Ps SP q Set cursor style (DECSCUSR, VT520).\n * Ps = 0 -> blinking block.\n * Ps = 1 -> blinking block (default).\n * Ps = 2 -> steady block.\n * Ps = 3 -> blinking underline.\n * Ps = 4 -> steady underline.\n * Ps = 5 -> blinking bar (xterm).\n * Ps = 6 -> steady bar (xterm).\n *\n * @vt: #Y CSI DECSCUSR \"Set Cursor Style\" \"CSI Ps SP q\" \"Set cursor style.\"\n * Supported cursor styles:\n * - empty, 0 or 1: steady block\n * - 2: blink block\n * - 3: steady underline\n * - 4: blink underline\n * - 5: steady bar\n * - 6: blink bar\n */\n public setCursorStyle(params: IParams): boolean {\n const param = params.params[0] || 1;\n switch (param) {\n case 1:\n case 2:\n this._optionsService.options.cursorStyle = 'block';\n break;\n case 3:\n case 4:\n this._optionsService.options.cursorStyle = 'underline';\n break;\n case 5:\n case 6:\n this._optionsService.options.cursorStyle = 'bar';\n break;\n }\n const isBlinking = param % 2 === 1;\n this._optionsService.options.cursorBlink = isBlinking;\n return true;\n }\n\n /**\n * CSI Ps ; Ps r\n * Set Scrolling Region [top;bottom] (default = full size of win-\n * dow) (DECSTBM).\n *\n * @vt: #Y CSI DECSTBM \"Set Top and Bottom Margin\" \"CSI Ps ; Ps r\" \"Set top and bottom margins of the viewport [top;bottom] (default = viewport size).\"\n */\n public setScrollRegion(params: IParams): boolean {\n const top = params.params[0] || 1;\n let bottom: number;\n\n if (params.length < 2 || (bottom = params.params[1]) > this._bufferService.rows || bottom === 0) {\n bottom = this._bufferService.rows;\n }\n\n if (bottom > top) {\n this._bufferService.buffer.scrollTop = top - 1;\n this._bufferService.buffer.scrollBottom = bottom - 1;\n this._setCursor(0, 0);\n }\n return true;\n }\n\n /**\n * CSI Ps ; Ps ; Ps t - Various window manipulations and reports (xterm)\n *\n * Note: Only those listed below are supported. All others are left to integrators and\n * need special treatment based on the embedding environment.\n *\n * Ps = 1 4 supported\n * Report xterm text area size in pixels.\n * Result is CSI 4 ; height ; width t\n * Ps = 14 ; 2 not implemented\n * Ps = 16 supported\n * Report xterm character cell size in pixels.\n * Result is CSI 6 ; height ; width t\n * Ps = 18 supported\n * Report the size of the text area in characters.\n * Result is CSI 8 ; height ; width t\n * Ps = 20 supported\n * Report xterm window's icon label.\n * Result is OSC L label ST\n * Ps = 21 supported\n * Report xterm window's title.\n * Result is OSC l label ST\n * Ps = 22 ; 0 -> Save xterm icon and window title on stack. supported\n * Ps = 22 ; 1 -> Save xterm icon title on stack. supported\n * Ps = 22 ; 2 -> Save xterm window title on stack. supported\n * Ps = 23 ; 0 -> Restore xterm icon and window title from stack. supported\n * Ps = 23 ; 1 -> Restore xterm icon title from stack. supported\n * Ps = 23 ; 2 -> Restore xterm window title from stack. supported\n * Ps >= 24 not implemented\n */\n public windowOptions(params: IParams): boolean {\n if (!paramToWindowOption(params.params[0], this._optionsService.options.windowOptions)) {\n return true;\n }\n const second = (params.length > 1) ? params.params[1] : 0;\n switch (params.params[0]) {\n case 14: // GetWinSizePixels, returns CSI 4 ; height ; width t\n if (second !== 2) {\n this._onRequestWindowsOptionsReport.fire(WindowsOptionsReportType.GET_WIN_SIZE_PIXELS);\n }\n break;\n case 16: // GetCellSizePixels, returns CSI 6 ; height ; width t\n this._onRequestWindowsOptionsReport.fire(WindowsOptionsReportType.GET_CELL_SIZE_PIXELS);\n break;\n case 18: // GetWinSizeChars, returns CSI 8 ; height ; width t\n if (this._bufferService) {\n this._coreService.triggerDataEvent(`${C0.ESC}[8;${this._bufferService.rows};${this._bufferService.cols}t`);\n }\n break;\n case 22: // PushTitle\n if (second === 0 || second === 2) {\n this._windowTitleStack.push(this._windowTitle);\n if (this._windowTitleStack.length > STACK_LIMIT) {\n this._windowTitleStack.shift();\n }\n }\n if (second === 0 || second === 1) {\n this._iconNameStack.push(this._iconName);\n if (this._iconNameStack.length > STACK_LIMIT) {\n this._iconNameStack.shift();\n }\n }\n break;\n case 23: // PopTitle\n if (second === 0 || second === 2) {\n if (this._windowTitleStack.length) {\n this.setTitle(this._windowTitleStack.pop()!);\n }\n }\n if (second === 0 || second === 1) {\n if (this._iconNameStack.length) {\n this.setIconName(this._iconNameStack.pop()!);\n }\n }\n break;\n }\n return true;\n }\n\n\n /**\n * CSI s\n * ESC 7\n * Save cursor (ANSI.SYS).\n *\n * @vt: #P[TODO...] CSI SCOSC \"Save Cursor\" \"CSI s\" \"Save cursor position, charmap and text attributes.\"\n * @vt: #Y ESC SC \"Save Cursor\" \"ESC 7\" \"Save cursor position, charmap and text attributes.\"\n */\n public saveCursor(params?: IParams): boolean {\n this._bufferService.buffer.savedX = this._bufferService.buffer.x;\n this._bufferService.buffer.savedY = this._bufferService.buffer.ybase + this._bufferService.buffer.y;\n this._bufferService.buffer.savedCurAttrData.fg = this._curAttrData.fg;\n this._bufferService.buffer.savedCurAttrData.bg = this._curAttrData.bg;\n this._bufferService.buffer.savedCharset = this._charsetService.charset;\n return true;\n }\n\n\n /**\n * CSI u\n * ESC 8\n * Restore cursor (ANSI.SYS).\n *\n * @vt: #P[TODO...] CSI SCORC \"Restore Cursor\" \"CSI u\" \"Restore cursor position, charmap and text attributes.\"\n * @vt: #Y ESC RC \"Restore Cursor\" \"ESC 8\" \"Restore cursor position, charmap and text attributes.\"\n */\n public restoreCursor(params?: IParams): boolean {\n this._bufferService.buffer.x = this._bufferService.buffer.savedX || 0;\n this._bufferService.buffer.y = Math.max(this._bufferService.buffer.savedY - this._bufferService.buffer.ybase, 0);\n this._curAttrData.fg = this._bufferService.buffer.savedCurAttrData.fg;\n this._curAttrData.bg = this._bufferService.buffer.savedCurAttrData.bg;\n this._charsetService.charset = (this as any)._savedCharset;\n if (this._bufferService.buffer.savedCharset) {\n this._charsetService.charset = this._bufferService.buffer.savedCharset;\n }\n this._restrictCursor();\n return true;\n }\n\n\n /**\n * OSC 2; ST (set window title)\n * Proxy to set window title.\n *\n * @vt: #P[Icon name is not exposed.] OSC 0 \"Set Windows Title and Icon Name\" \"OSC 0 ; Pt BEL\" \"Set window title and icon name.\"\n * Icon name is not supported. For Window Title see below.\n *\n * @vt: #Y OSC 2 \"Set Windows Title\" \"OSC 2 ; Pt BEL\" \"Set window title.\"\n * xterm.js does not manipulate the title directly, instead exposes changes via the event `Terminal.onTitleChange`.\n */\n public setTitle(data: string): boolean {\n this._windowTitle = data;\n this._onTitleChange.fire(data);\n return true;\n }\n\n /**\n * OSC 1; ST\n * Note: Icon name is not exposed.\n */\n public setIconName(data: string): boolean {\n this._iconName = data;\n return true;\n }\n\n protected _parseAnsiColorChange(data: string): IAnsiColorChangeEvent | null {\n const result: IAnsiColorChangeEvent = { colors: [] };\n // example data: 5;rgb:aa/bb/cc\n const regex = /(\\d+);rgb:([0-9a-f]{2})\\/([0-9a-f]{2})\\/([0-9a-f]{2})/gi;\n let match;\n\n while ((match = regex.exec(data)) !== null) {\n result.colors.push({\n colorIndex: parseInt(match[1]),\n red: parseInt(match[2], 16),\n green: parseInt(match[3], 16),\n blue: parseInt(match[4], 16)\n });\n }\n\n if (result.colors.length === 0) {\n return null;\n }\n\n return result;\n }\n\n /**\n * OSC 4; ; ST (set ANSI color to )\n *\n * @vt: #Y OSC 4 \"Set ANSI color\" \"OSC 4 ; c ; spec BEL\" \"Change color number `c` to the color specified by `spec`.\"\n * `c` is the color index between 0 and 255. `spec` color format is 'rgb:hh/hh/hh' where `h` are hexadecimal digits.\n * There may be multipe c ; spec elements present in the same instruction, e.g. 1;rgb:10/20/30;2;rgb:a0/b0/c0.\n */\n public setAnsiColor(data: string): boolean {\n const event = this._parseAnsiColorChange(data);\n if (event) {\n this._onAnsiColorChange.fire(event);\n }\n else {\n this._logService.warn(`Expected format ;rgb:// but got data: ${data}`);\n }\n return true;\n }\n\n /**\n * ESC E\n * C1.NEL\n * DEC mnemonic: NEL (https://vt100.net/docs/vt510-rm/NEL)\n * Moves cursor to first position on next line.\n *\n * @vt: #Y C1 NEL \"Next Line\" \"\\x85\" \"Move the cursor to the beginning of the next row.\"\n * @vt: #Y ESC NEL \"Next Line\" \"ESC E\" \"Move the cursor to the beginning of the next row.\"\n */\n public nextLine(): boolean {\n this._bufferService.buffer.x = 0;\n this.index();\n return true;\n }\n\n /**\n * ESC =\n * DEC mnemonic: DECKPAM (https://vt100.net/docs/vt510-rm/DECKPAM.html)\n * Enables the numeric keypad to send application sequences to the host.\n */\n public keypadApplicationMode(): boolean {\n this._logService.debug('Serial port requested application keypad.');\n this._coreService.decPrivateModes.applicationKeypad = true;\n this._onRequestSyncScrollBar.fire();\n return true;\n }\n\n /**\n * ESC >\n * DEC mnemonic: DECKPNM (https://vt100.net/docs/vt510-rm/DECKPNM.html)\n * Enables the keypad to send numeric characters to the host.\n */\n public keypadNumericMode(): boolean {\n this._logService.debug('Switching back to normal keypad.');\n this._coreService.decPrivateModes.applicationKeypad = false;\n this._onRequestSyncScrollBar.fire();\n return true;\n }\n\n /**\n * ESC % @\n * ESC % G\n * Select default character set. UTF-8 is not supported (string are unicode anyways)\n * therefore ESC % G does the same.\n */\n public selectDefaultCharset(): boolean {\n this._charsetService.setgLevel(0);\n this._charsetService.setgCharset(0, DEFAULT_CHARSET); // US (default)\n return true;\n }\n\n /**\n * ESC ( C\n * Designate G0 Character Set, VT100, ISO 2022.\n * ESC ) C\n * Designate G1 Character Set (ISO 2022, VT100).\n * ESC * C\n * Designate G2 Character Set (ISO 2022, VT220).\n * ESC + C\n * Designate G3 Character Set (ISO 2022, VT220).\n * ESC - C\n * Designate G1 Character Set (VT300).\n * ESC . C\n * Designate G2 Character Set (VT300).\n * ESC / C\n * Designate G3 Character Set (VT300). C = A -> ISO Latin-1 Supplemental. - Supported?\n */\n public selectCharset(collectAndFlag: string): boolean {\n if (collectAndFlag.length !== 2) {\n this.selectDefaultCharset();\n return true;\n }\n if (collectAndFlag[0] === '/') {\n return true; // TODO: Is this supported?\n }\n this._charsetService.setgCharset(GLEVEL[collectAndFlag[0]], CHARSETS[collectAndFlag[1]] || DEFAULT_CHARSET);\n return true;\n }\n\n /**\n * ESC D\n * C1.IND\n * DEC mnemonic: IND (https://vt100.net/docs/vt510-rm/IND.html)\n * Moves the cursor down one line in the same column.\n *\n * @vt: #Y C1 IND \"Index\" \"\\x84\" \"Move the cursor one line down scrolling if needed.\"\n * @vt: #Y ESC IND \"Index\" \"ESC D\" \"Move the cursor one line down scrolling if needed.\"\n */\n public index(): boolean {\n this._restrictCursor();\n const buffer = this._bufferService.buffer;\n this._bufferService.buffer.y++;\n if (buffer.y === buffer.scrollBottom + 1) {\n buffer.y--;\n this._onRequestScroll.fire(this._eraseAttrData());\n } else if (buffer.y >= this._bufferService.rows) {\n buffer.y = this._bufferService.rows - 1;\n }\n this._restrictCursor();\n return true;\n }\n\n /**\n * ESC H\n * C1.HTS\n * DEC mnemonic: HTS (https://vt100.net/docs/vt510-rm/HTS.html)\n * Sets a horizontal tab stop at the column position indicated by\n * the value of the active column when the terminal receives an HTS.\n *\n * @vt: #Y C1 HTS \"Horizontal Tabulation Set\" \"\\x88\" \"Places a tab stop at the current cursor position.\"\n * @vt: #Y ESC HTS \"Horizontal Tabulation Set\" \"ESC H\" \"Places a tab stop at the current cursor position.\"\n */\n public tabSet(): boolean {\n this._bufferService.buffer.tabs[this._bufferService.buffer.x] = true;\n return true;\n }\n\n /**\n * ESC M\n * C1.RI\n * DEC mnemonic: HTS\n * Moves the cursor up one line in the same column. If the cursor is at the top margin,\n * the page scrolls down.\n *\n * @vt: #Y ESC IR \"Reverse Index\" \"ESC M\" \"Move the cursor one line up scrolling if needed.\"\n */\n public reverseIndex(): boolean {\n this._restrictCursor();\n const buffer = this._bufferService.buffer;\n if (buffer.y === buffer.scrollTop) {\n // possibly move the code below to term.reverseScroll();\n // test: echo -ne '\\e[1;1H\\e[44m\\eM\\e[0m'\n // blankLine(true) is xterm/linux behavior\n const scrollRegionHeight = buffer.scrollBottom - buffer.scrollTop;\n buffer.lines.shiftElements(buffer.ybase + buffer.y, scrollRegionHeight, 1);\n buffer.lines.set(buffer.ybase + buffer.y, buffer.getBlankLine(this._eraseAttrData()));\n this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom);\n } else {\n buffer.y--;\n this._restrictCursor(); // quickfix to not run out of bounds\n }\n return true;\n }\n\n /**\n * ESC c\n * DEC mnemonic: RIS (https://vt100.net/docs/vt510-rm/RIS.html)\n * Reset to initial state.\n */\n public fullReset(): boolean {\n this._parser.reset();\n this._onRequestReset.fire();\n return true;\n }\n\n public reset(): void {\n this._curAttrData = DEFAULT_ATTR_DATA.clone();\n this._eraseAttrDataInternal = DEFAULT_ATTR_DATA.clone();\n }\n\n /**\n * back_color_erase feature for xterm.\n */\n private _eraseAttrData(): IAttributeData {\n this._eraseAttrDataInternal.bg &= ~(Attributes.CM_MASK | 0xFFFFFF);\n this._eraseAttrDataInternal.bg |= this._curAttrData.bg & ~0xFC000000;\n return this._eraseAttrDataInternal;\n }\n\n /**\n * ESC n\n * ESC o\n * ESC |\n * ESC }\n * ESC ~\n * DEC mnemonic: LS (https://vt100.net/docs/vt510-rm/LS.html)\n * When you use a locking shift, the character set remains in GL or GR until\n * you use another locking shift. (partly supported)\n */\n public setgLevel(level: number): boolean {\n this._charsetService.setgLevel(level);\n return true;\n }\n\n /**\n * ESC # 8\n * DEC mnemonic: DECALN (https://vt100.net/docs/vt510-rm/DECALN.html)\n * This control function fills the complete screen area with\n * a test pattern (E) used for adjusting screen alignment.\n *\n * @vt: #Y ESC DECALN \"Screen Alignment Pattern\" \"ESC # 8\" \"Fill viewport with a test pattern (E).\"\n */\n public screenAlignmentPattern(): boolean {\n // prepare cell data\n const cell = new CellData();\n cell.content = 1 << Content.WIDTH_SHIFT | 'E'.charCodeAt(0);\n cell.fg = this._curAttrData.fg;\n cell.bg = this._curAttrData.bg;\n\n const buffer = this._bufferService.buffer;\n\n this._setCursor(0, 0);\n for (let yOffset = 0; yOffset < this._bufferService.rows; ++yOffset) {\n const row = buffer.ybase + buffer.y + yOffset;\n const line = buffer.lines.get(row);\n if (line) {\n line.fill(cell);\n line.isWrapped = false;\n }\n }\n this._dirtyRowService.markAllDirty();\n this._setCursor(0, 0);\n return true;\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IDisposable } from 'common/Types';\n\n/**\n * A base class that can be extended to provide convenience methods for managing the lifecycle of an\n * object and its components.\n */\nexport abstract class Disposable implements IDisposable {\n protected _disposables: IDisposable[] = [];\n protected _isDisposed: boolean = false;\n\n constructor() {\n }\n\n /**\n * Disposes the object, triggering the `dispose` method on all registered IDisposables.\n */\n public dispose(): void {\n this._isDisposed = true;\n for (const d of this._disposables) {\n d.dispose();\n }\n this._disposables.length = 0;\n }\n\n /**\n * Registers a disposable object.\n * @param d The disposable to register.\n * @returns The disposable.\n */\n public register(d: T): T {\n this._disposables.push(d);\n return d;\n }\n\n /**\n * Unregisters a disposable object if it has been registered, if not do\n * nothing.\n * @param d The disposable to unregister.\n */\n public unregister(d: T): void {\n const index = this._disposables.indexOf(d);\n if (index !== -1) {\n this._disposables.splice(index, 1);\n }\n }\n}\n\n/**\n * Dispose of all disposables in an array and set its length to 0.\n */\nexport function disposeArray(disposables: IDisposable[]): void {\n for (const d of disposables) {\n d.dispose();\n }\n disposables.length = 0;\n}\n\n/**\n * Creates a disposable that will dispose of an array of disposables when disposed.\n */\nexport function getDisposeArrayDisposable(array: IDisposable[]): IDisposable {\n return { dispose: () => disposeArray(array) };\n}\n","/**\n * Copyright (c) 2016 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\ninterface INavigator {\n userAgent: string;\n language: string;\n platform: string;\n}\n\n// We're declaring a navigator global here as we expect it in all runtimes (node and browser), but\n// we want this module to live in common.\ndeclare const navigator: INavigator;\n\nconst isNode = (typeof navigator === 'undefined') ? true : false;\nconst userAgent = (isNode) ? 'node' : navigator.userAgent;\nconst platform = (isNode) ? 'node' : navigator.platform;\n\nexport const isFirefox = userAgent.includes('Firefox');\nexport const isSafari = /^((?!chrome|android).)*safari/i.test(userAgent);\n\n// Find the users platform. We use this to interpret the meta key\n// and ISO third level shifts.\n// http://stackoverflow.com/q/19877924/577598\nexport const isMac = ['Macintosh', 'MacIntel', 'MacPPC', 'Mac68K'].includes(platform);\nexport const isIpad = platform === 'iPad';\nexport const isIphone = platform === 'iPhone';\nexport const isWindows = ['Windows', 'Win16', 'Win32', 'WinCE'].includes(platform);\nexport const isLinux = platform.indexOf('Linux') >= 0;\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nexport type TypedArray = Uint8Array | Uint16Array | Uint32Array | Uint8ClampedArray | Int8Array | Int16Array | Int32Array | Float32Array | Float64Array;\n\n\n/**\n * polyfill for TypedArray.fill\n * This is needed to support .fill in all safari versions and IE 11.\n */\nexport function fill(array: T, value: number, start?: number, end?: number): T {\n // all modern engines that support .fill\n if (array.fill) {\n return array.fill(value, start, end) as T;\n }\n return fillFallback(array, value, start, end);\n}\n\nexport function fillFallback(array: T, value: number, start: number = 0, end: number = array.length): T {\n // safari and IE 11\n // since IE 11 does not support Array.prototype.fill either\n // we cannot use the suggested polyfill from MDN\n // instead we simply fall back to looping\n if (start >= array.length) {\n return array;\n }\n start = (array.length + start) % array.length;\n if (end >= array.length) {\n end = array.length;\n } else {\n end = (array.length + end) % array.length;\n }\n for (let i = start; i < end; ++i) {\n array[i] = value;\n }\n return array;\n}\n\n/**\n * Concat two typed arrays `a` and `b`.\n * Returns a new typed array.\n */\nexport function concat(a: T, b: T): T {\n const result = new (a.constructor as any)(a.length + b.length);\n result.set(a);\n result.set(b, a.length);\n return result;\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { CHAR_DATA_CODE_INDEX, NULL_CELL_CODE, WHITESPACE_CELL_CODE } from 'common/buffer/Constants';\nimport { IBufferService } from 'common/services/Services';\n\nexport function updateWindowsModeWrappedState(bufferService: IBufferService): void {\n // Winpty does not support wraparound mode which means that lines will never\n // be marked as wrapped. This causes issues for things like copying a line\n // retaining the wrapped new line characters or if consumers are listening\n // in on the data stream.\n //\n // The workaround for this is to listen to every incoming line feed and mark\n // the line as wrapped if the last character in the previous line is not a\n // space. This is certainly not without its problems, but generally on\n // Windows when text reaches the end of the terminal it's likely going to be\n // wrapped.\n const line = bufferService.buffer.lines.get(bufferService.buffer.ybase + bufferService.buffer.y - 1);\n const lastChar = line?.get(bufferService.cols - 1);\n\n const nextLine = bufferService.buffer.lines.get(bufferService.buffer.ybase + bufferService.buffer.y);\n if (nextLine && lastChar) {\n nextLine.isWrapped = (lastChar[CHAR_DATA_CODE_INDEX] !== NULL_CELL_CODE && lastChar[CHAR_DATA_CODE_INDEX] !== WHITESPACE_CELL_CODE);\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IAttributeData, IColorRGB, IExtendedAttrs } from 'common/Types';\nimport { Attributes, FgFlags, BgFlags, UnderlineStyle } from 'common/buffer/Constants';\n\nexport class AttributeData implements IAttributeData {\n public static toColorRGB(value: number): IColorRGB {\n return [\n value >>> Attributes.RED_SHIFT & 255,\n value >>> Attributes.GREEN_SHIFT & 255,\n value & 255\n ];\n }\n\n public static fromColorRGB(value: IColorRGB): number {\n return (value[0] & 255) << Attributes.RED_SHIFT | (value[1] & 255) << Attributes.GREEN_SHIFT | value[2] & 255;\n }\n\n public clone(): IAttributeData {\n const newObj = new AttributeData();\n newObj.fg = this.fg;\n newObj.bg = this.bg;\n newObj.extended = this.extended.clone();\n return newObj;\n }\n\n // data\n public fg = 0;\n public bg = 0;\n public extended = new ExtendedAttrs();\n\n // flags\n public isInverse(): number { return this.fg & FgFlags.INVERSE; }\n public isBold(): number { return this.fg & FgFlags.BOLD; }\n public isUnderline(): number { return this.fg & FgFlags.UNDERLINE; }\n public isBlink(): number { return this.fg & FgFlags.BLINK; }\n public isInvisible(): number { return this.fg & FgFlags.INVISIBLE; }\n public isItalic(): number { return this.bg & BgFlags.ITALIC; }\n public isDim(): number { return this.bg & BgFlags.DIM; }\n\n // color modes\n public getFgColorMode(): number { return this.fg & Attributes.CM_MASK; }\n public getBgColorMode(): number { return this.bg & Attributes.CM_MASK; }\n public isFgRGB(): boolean { return (this.fg & Attributes.CM_MASK) === Attributes.CM_RGB; }\n public isBgRGB(): boolean { return (this.bg & Attributes.CM_MASK) === Attributes.CM_RGB; }\n public isFgPalette(): boolean { return (this.fg & Attributes.CM_MASK) === Attributes.CM_P16 || (this.fg & Attributes.CM_MASK) === Attributes.CM_P256; }\n public isBgPalette(): boolean { return (this.bg & Attributes.CM_MASK) === Attributes.CM_P16 || (this.bg & Attributes.CM_MASK) === Attributes.CM_P256; }\n public isFgDefault(): boolean { return (this.fg & Attributes.CM_MASK) === 0; }\n public isBgDefault(): boolean { return (this.bg & Attributes.CM_MASK) === 0; }\n public isAttributeDefault(): boolean { return this.fg === 0 && this.bg === 0; }\n\n // colors\n public getFgColor(): number {\n switch (this.fg & Attributes.CM_MASK) {\n case Attributes.CM_P16:\n case Attributes.CM_P256: return this.fg & Attributes.PCOLOR_MASK;\n case Attributes.CM_RGB: return this.fg & Attributes.RGB_MASK;\n default: return -1; // CM_DEFAULT defaults to -1\n }\n }\n public getBgColor(): number {\n switch (this.bg & Attributes.CM_MASK) {\n case Attributes.CM_P16:\n case Attributes.CM_P256: return this.bg & Attributes.PCOLOR_MASK;\n case Attributes.CM_RGB: return this.bg & Attributes.RGB_MASK;\n default: return -1; // CM_DEFAULT defaults to -1\n }\n }\n\n // extended attrs\n public hasExtendedAttrs(): number {\n return this.bg & BgFlags.HAS_EXTENDED;\n }\n public updateExtended(): void {\n if (this.extended.isEmpty()) {\n this.bg &= ~BgFlags.HAS_EXTENDED;\n } else {\n this.bg |= BgFlags.HAS_EXTENDED;\n }\n }\n public getUnderlineColor(): number {\n if ((this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor) {\n switch (this.extended.underlineColor & Attributes.CM_MASK) {\n case Attributes.CM_P16:\n case Attributes.CM_P256: return this.extended.underlineColor & Attributes.PCOLOR_MASK;\n case Attributes.CM_RGB: return this.extended.underlineColor & Attributes.RGB_MASK;\n default: return this.getFgColor();\n }\n }\n return this.getFgColor();\n }\n public getUnderlineColorMode(): number {\n return (this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor\n ? this.extended.underlineColor & Attributes.CM_MASK\n : this.getFgColorMode();\n }\n public isUnderlineColorRGB(): boolean {\n return (this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor\n ? (this.extended.underlineColor & Attributes.CM_MASK) === Attributes.CM_RGB\n : this.isFgRGB();\n }\n public isUnderlineColorPalette(): boolean {\n return (this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor\n ? (this.extended.underlineColor & Attributes.CM_MASK) === Attributes.CM_P16\n || (this.extended.underlineColor & Attributes.CM_MASK) === Attributes.CM_P256\n : this.isFgPalette();\n }\n public isUnderlineColorDefault(): boolean {\n return (this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor\n ? (this.extended.underlineColor & Attributes.CM_MASK) === 0\n : this.isFgDefault();\n }\n public getUnderlineStyle(): UnderlineStyle {\n return this.fg & FgFlags.UNDERLINE\n ? (this.bg & BgFlags.HAS_EXTENDED ? this.extended.underlineStyle : UnderlineStyle.SINGLE)\n : UnderlineStyle.NONE;\n }\n}\n\n\n/**\n * Extended attributes for a cell.\n * Holds information about different underline styles and color.\n */\nexport class ExtendedAttrs implements IExtendedAttrs {\n constructor(\n // underline style, NONE is empty\n public underlineStyle: UnderlineStyle = UnderlineStyle.NONE,\n // underline color, -1 is empty (same as FG)\n public underlineColor: number = -1\n ) {}\n\n public clone(): IExtendedAttrs {\n return new ExtendedAttrs(this.underlineStyle, this.underlineColor);\n }\n\n /**\n * Convenient method to indicate whether the object holds no additional information,\n * that needs to be persistant in the buffer.\n */\n public isEmpty(): boolean {\n return this.underlineStyle === UnderlineStyle.NONE;\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { CircularList, IInsertEvent } from 'common/CircularList';\nimport { IBuffer, BufferIndex, IBufferStringIterator, IBufferStringIteratorResult } from 'common/buffer/Types';\nimport { IBufferLine, ICellData, IAttributeData, ICharset } from 'common/Types';\nimport { BufferLine, DEFAULT_ATTR_DATA } from 'common/buffer/BufferLine';\nimport { CellData } from 'common/buffer/CellData';\nimport { NULL_CELL_CHAR, NULL_CELL_WIDTH, NULL_CELL_CODE, WHITESPACE_CELL_CHAR, WHITESPACE_CELL_WIDTH, WHITESPACE_CELL_CODE, CHAR_DATA_WIDTH_INDEX, CHAR_DATA_CHAR_INDEX } from 'common/buffer/Constants';\nimport { reflowLargerApplyNewLayout, reflowLargerCreateNewLayout, reflowLargerGetLinesToRemove, reflowSmallerGetNewLineLengths, getWrappedLineTrimmedLength } from 'common/buffer/BufferReflow';\nimport { Marker } from 'common/buffer/Marker';\nimport { IOptionsService, IBufferService } from 'common/services/Services';\nimport { DEFAULT_CHARSET } from 'common/data/Charsets';\nimport { ExtendedAttrs } from 'common/buffer/AttributeData';\n\nexport const MAX_BUFFER_SIZE = 4294967295; // 2^32 - 1\n\n/**\n * This class represents a terminal buffer (an internal state of the terminal), where the\n * following information is stored (in high-level):\n * - text content of this particular buffer\n * - cursor position\n * - scroll position\n */\nexport class Buffer implements IBuffer {\n public lines: CircularList;\n public ydisp: number = 0;\n public ybase: number = 0;\n public y: number = 0;\n public x: number = 0;\n public scrollBottom: number;\n public scrollTop: number;\n // TODO: Type me\n public tabs: any;\n public savedY: number = 0;\n public savedX: number = 0;\n public savedCurAttrData = DEFAULT_ATTR_DATA.clone();\n public savedCharset: ICharset | undefined = DEFAULT_CHARSET;\n public markers: Marker[] = [];\n private _nullCell: ICellData = CellData.fromCharData([0, NULL_CELL_CHAR, NULL_CELL_WIDTH, NULL_CELL_CODE]);\n private _whitespaceCell: ICellData = CellData.fromCharData([0, WHITESPACE_CELL_CHAR, WHITESPACE_CELL_WIDTH, WHITESPACE_CELL_CODE]);\n private _cols: number;\n private _rows: number;\n\n constructor(\n private _hasScrollback: boolean,\n private _optionsService: IOptionsService,\n private _bufferService: IBufferService\n ) {\n this._cols = this._bufferService.cols;\n this._rows = this._bufferService.rows;\n this.lines = new CircularList(this._getCorrectBufferLength(this._rows));\n this.scrollTop = 0;\n this.scrollBottom = this._rows - 1;\n this.setupTabStops();\n }\n\n public getNullCell(attr?: IAttributeData): ICellData {\n if (attr) {\n this._nullCell.fg = attr.fg;\n this._nullCell.bg = attr.bg;\n this._nullCell.extended = attr.extended;\n } else {\n this._nullCell.fg = 0;\n this._nullCell.bg = 0;\n this._nullCell.extended = new ExtendedAttrs();\n }\n return this._nullCell;\n }\n\n public getWhitespaceCell(attr?: IAttributeData): ICellData {\n if (attr) {\n this._whitespaceCell.fg = attr.fg;\n this._whitespaceCell.bg = attr.bg;\n this._whitespaceCell.extended = attr.extended;\n } else {\n this._whitespaceCell.fg = 0;\n this._whitespaceCell.bg = 0;\n this._whitespaceCell.extended = new ExtendedAttrs();\n }\n return this._whitespaceCell;\n }\n\n public getBlankLine(attr: IAttributeData, isWrapped?: boolean): IBufferLine {\n return new BufferLine(this._bufferService.cols, this.getNullCell(attr), isWrapped);\n }\n\n public get hasScrollback(): boolean {\n return this._hasScrollback && this.lines.maxLength > this._rows;\n }\n\n public get isCursorInViewport(): boolean {\n const absoluteY = this.ybase + this.y;\n const relativeY = absoluteY - this.ydisp;\n return (relativeY >= 0 && relativeY < this._rows);\n }\n\n /**\n * Gets the correct buffer length based on the rows provided, the terminal's\n * scrollback and whether this buffer is flagged to have scrollback or not.\n * @param rows The terminal rows to use in the calculation.\n */\n private _getCorrectBufferLength(rows: number): number {\n if (!this._hasScrollback) {\n return rows;\n }\n\n const correctBufferLength = rows + this._optionsService.options.scrollback;\n\n return correctBufferLength > MAX_BUFFER_SIZE ? MAX_BUFFER_SIZE : correctBufferLength;\n }\n\n /**\n * Fills the buffer's viewport with blank lines.\n */\n public fillViewportRows(fillAttr?: IAttributeData): void {\n if (this.lines.length === 0) {\n if (fillAttr === undefined) {\n fillAttr = DEFAULT_ATTR_DATA;\n }\n let i = this._rows;\n while (i--) {\n this.lines.push(this.getBlankLine(fillAttr));\n }\n }\n }\n\n /**\n * Clears the buffer to it's initial state, discarding all previous data.\n */\n public clear(): void {\n this.ydisp = 0;\n this.ybase = 0;\n this.y = 0;\n this.x = 0;\n this.lines = new CircularList(this._getCorrectBufferLength(this._rows));\n this.scrollTop = 0;\n this.scrollBottom = this._rows - 1;\n this.setupTabStops();\n }\n\n /**\n * Resizes the buffer, adjusting its data accordingly.\n * @param newCols The new number of columns.\n * @param newRows The new number of rows.\n */\n public resize(newCols: number, newRows: number): void {\n // store reference to null cell with default attrs\n const nullCell = this.getNullCell(DEFAULT_ATTR_DATA);\n\n // Increase max length if needed before adjustments to allow space to fill\n // as required.\n const newMaxLength = this._getCorrectBufferLength(newRows);\n if (newMaxLength > this.lines.maxLength) {\n this.lines.maxLength = newMaxLength;\n }\n\n // The following adjustments should only happen if the buffer has been\n // initialized/filled.\n if (this.lines.length > 0) {\n // Deal with columns increasing (reducing needs to happen after reflow)\n if (this._cols < newCols) {\n for (let i = 0; i < this.lines.length; i++) {\n this.lines.get(i)!.resize(newCols, nullCell);\n }\n }\n\n // Resize rows in both directions as needed\n let addToY = 0;\n if (this._rows < newRows) {\n for (let y = this._rows; y < newRows; y++) {\n if (this.lines.length < newRows + this.ybase) {\n if (this._optionsService.options.windowsMode) {\n // Just add the new missing rows on Windows as conpty reprints the screen with it's\n // view of the world. Once a line enters scrollback for conpty it remains there\n this.lines.push(new BufferLine(newCols, nullCell));\n } else {\n if (this.ybase > 0 && this.lines.length <= this.ybase + this.y + addToY + 1) {\n // There is room above the buffer and there are no empty elements below the line,\n // scroll up\n this.ybase--;\n addToY++;\n if (this.ydisp > 0) {\n // Viewport is at the top of the buffer, must increase downwards\n this.ydisp--;\n }\n } else {\n // Add a blank line if there is no buffer left at the top to scroll to, or if there\n // are blank lines after the cursor\n this.lines.push(new BufferLine(newCols, nullCell));\n }\n }\n }\n }\n } else { // (this._rows >= newRows)\n for (let y = this._rows; y > newRows; y--) {\n if (this.lines.length > newRows + this.ybase) {\n if (this.lines.length > this.ybase + this.y + 1) {\n // The line is a blank line below the cursor, remove it\n this.lines.pop();\n } else {\n // The line is the cursor, scroll down\n this.ybase++;\n this.ydisp++;\n }\n }\n }\n }\n\n // Reduce max length if needed after adjustments, this is done after as it\n // would otherwise cut data from the bottom of the buffer.\n if (newMaxLength < this.lines.maxLength) {\n // Trim from the top of the buffer and adjust ybase and ydisp.\n const amountToTrim = this.lines.length - newMaxLength;\n if (amountToTrim > 0) {\n this.lines.trimStart(amountToTrim);\n this.ybase = Math.max(this.ybase - amountToTrim, 0);\n this.ydisp = Math.max(this.ydisp - amountToTrim, 0);\n this.savedY = Math.max(this.savedY - amountToTrim, 0);\n }\n this.lines.maxLength = newMaxLength;\n }\n\n // Make sure that the cursor stays on screen\n this.x = Math.min(this.x, newCols - 1);\n this.y = Math.min(this.y, newRows - 1);\n if (addToY) {\n this.y += addToY;\n }\n this.savedX = Math.min(this.savedX, newCols - 1);\n\n this.scrollTop = 0;\n }\n\n this.scrollBottom = newRows - 1;\n\n if (this._isReflowEnabled) {\n this._reflow(newCols, newRows);\n\n // Trim the end of the line off if cols shrunk\n if (this._cols > newCols) {\n for (let i = 0; i < this.lines.length; i++) {\n this.lines.get(i)!.resize(newCols, nullCell);\n }\n }\n }\n\n this._cols = newCols;\n this._rows = newRows;\n }\n\n private get _isReflowEnabled(): boolean {\n return this._hasScrollback && !this._optionsService.options.windowsMode;\n }\n\n private _reflow(newCols: number, newRows: number): void {\n if (this._cols === newCols) {\n return;\n }\n\n // Iterate through rows, ignore the last one as it cannot be wrapped\n if (newCols > this._cols) {\n this._reflowLarger(newCols, newRows);\n } else {\n this._reflowSmaller(newCols, newRows);\n }\n }\n\n private _reflowLarger(newCols: number, newRows: number): void {\n const toRemove: number[] = reflowLargerGetLinesToRemove(this.lines, this._cols, newCols, this.ybase + this.y, this.getNullCell(DEFAULT_ATTR_DATA));\n if (toRemove.length > 0) {\n const newLayoutResult = reflowLargerCreateNewLayout(this.lines, toRemove);\n reflowLargerApplyNewLayout(this.lines, newLayoutResult.layout);\n this._reflowLargerAdjustViewport(newCols, newRows, newLayoutResult.countRemoved);\n }\n }\n\n private _reflowLargerAdjustViewport(newCols: number, newRows: number, countRemoved: number): void {\n const nullCell = this.getNullCell(DEFAULT_ATTR_DATA);\n // Adjust viewport based on number of items removed\n let viewportAdjustments = countRemoved;\n while (viewportAdjustments-- > 0) {\n if (this.ybase === 0) {\n if (this.y > 0) {\n this.y--;\n }\n if (this.lines.length < newRows) {\n // Add an extra row at the bottom of the viewport\n this.lines.push(new BufferLine(newCols, nullCell));\n }\n } else {\n if (this.ydisp === this.ybase) {\n this.ydisp--;\n }\n this.ybase--;\n }\n }\n this.savedY = Math.max(this.savedY - countRemoved, 0);\n }\n\n private _reflowSmaller(newCols: number, newRows: number): void {\n const nullCell = this.getNullCell(DEFAULT_ATTR_DATA);\n // Gather all BufferLines that need to be inserted into the Buffer here so that they can be\n // batched up and only committed once\n const toInsert = [];\n let countToInsert = 0;\n // Go backwards as many lines may be trimmed and this will avoid considering them\n for (let y = this.lines.length - 1; y >= 0; y--) {\n // Check whether this line is a problem\n let nextLine = this.lines.get(y) as BufferLine;\n if (!nextLine || !nextLine.isWrapped && nextLine.getTrimmedLength() <= newCols) {\n continue;\n }\n\n // Gather wrapped lines and adjust y to be the starting line\n const wrappedLines: BufferLine[] = [nextLine];\n while (nextLine.isWrapped && y > 0) {\n nextLine = this.lines.get(--y) as BufferLine;\n wrappedLines.unshift(nextLine);\n }\n\n // If these lines contain the cursor don't touch them, the program will handle fixing up\n // wrapped lines with the cursor\n const absoluteY = this.ybase + this.y;\n if (absoluteY >= y && absoluteY < y + wrappedLines.length) {\n continue;\n }\n\n const lastLineLength = wrappedLines[wrappedLines.length - 1].getTrimmedLength();\n const destLineLengths = reflowSmallerGetNewLineLengths(wrappedLines, this._cols, newCols);\n const linesToAdd = destLineLengths.length - wrappedLines.length;\n let trimmedLines: number;\n if (this.ybase === 0 && this.y !== this.lines.length - 1) {\n // If the top section of the buffer is not yet filled\n trimmedLines = Math.max(0, this.y - this.lines.maxLength + linesToAdd);\n } else {\n trimmedLines = Math.max(0, this.lines.length - this.lines.maxLength + linesToAdd);\n }\n\n // Add the new lines\n const newLines: BufferLine[] = [];\n for (let i = 0; i < linesToAdd; i++) {\n const newLine = this.getBlankLine(DEFAULT_ATTR_DATA, true) as BufferLine;\n newLines.push(newLine);\n }\n if (newLines.length > 0) {\n toInsert.push({\n // countToInsert here gets the actual index, taking into account other inserted items.\n // using this we can iterate through the list forwards\n start: y + wrappedLines.length + countToInsert,\n newLines\n });\n countToInsert += newLines.length;\n }\n wrappedLines.push(...newLines);\n\n // Copy buffer data to new locations, this needs to happen backwards to do in-place\n let destLineIndex = destLineLengths.length - 1; // Math.floor(cellsNeeded / newCols);\n let destCol = destLineLengths[destLineIndex]; // cellsNeeded % newCols;\n if (destCol === 0) {\n destLineIndex--;\n destCol = destLineLengths[destLineIndex];\n }\n let srcLineIndex = wrappedLines.length - linesToAdd - 1;\n let srcCol = lastLineLength;\n while (srcLineIndex >= 0) {\n const cellsToCopy = Math.min(srcCol, destCol);\n wrappedLines[destLineIndex].copyCellsFrom(wrappedLines[srcLineIndex], srcCol - cellsToCopy, destCol - cellsToCopy, cellsToCopy, true);\n destCol -= cellsToCopy;\n if (destCol === 0) {\n destLineIndex--;\n destCol = destLineLengths[destLineIndex];\n }\n srcCol -= cellsToCopy;\n if (srcCol === 0) {\n srcLineIndex--;\n const wrappedLinesIndex = Math.max(srcLineIndex, 0);\n srcCol = getWrappedLineTrimmedLength(wrappedLines, wrappedLinesIndex, this._cols);\n }\n }\n\n // Null out the end of the line ends if a wide character wrapped to the following line\n for (let i = 0; i < wrappedLines.length; i++) {\n if (destLineLengths[i] < newCols) {\n wrappedLines[i].setCell(destLineLengths[i], nullCell);\n }\n }\n\n // Adjust viewport as needed\n let viewportAdjustments = linesToAdd - trimmedLines;\n while (viewportAdjustments-- > 0) {\n if (this.ybase === 0) {\n if (this.y < newRows - 1) {\n this.y++;\n this.lines.pop();\n } else {\n this.ybase++;\n this.ydisp++;\n }\n } else {\n // Ensure ybase does not exceed its maximum value\n if (this.ybase < Math.min(this.lines.maxLength, this.lines.length + countToInsert) - newRows) {\n if (this.ybase === this.ydisp) {\n this.ydisp++;\n }\n this.ybase++;\n }\n }\n }\n this.savedY = Math.min(this.savedY + linesToAdd, this.ybase + newRows - 1);\n }\n\n // Rearrange lines in the buffer if there are any insertions, this is done at the end rather\n // than earlier so that it's a single O(n) pass through the buffer, instead of O(n^2) from many\n // costly calls to CircularList.splice.\n if (toInsert.length > 0) {\n // Record buffer insert events and then play them back backwards so that the indexes are\n // correct\n const insertEvents: IInsertEvent[] = [];\n\n // Record original lines so they don't get overridden when we rearrange the list\n const originalLines: BufferLine[] = [];\n for (let i = 0; i < this.lines.length; i++) {\n originalLines.push(this.lines.get(i) as BufferLine);\n }\n const originalLinesLength = this.lines.length;\n\n let originalLineIndex = originalLinesLength - 1;\n let nextToInsertIndex = 0;\n let nextToInsert = toInsert[nextToInsertIndex];\n this.lines.length = Math.min(this.lines.maxLength, this.lines.length + countToInsert);\n let countInsertedSoFar = 0;\n for (let i = Math.min(this.lines.maxLength - 1, originalLinesLength + countToInsert - 1); i >= 0; i--) {\n if (nextToInsert && nextToInsert.start > originalLineIndex + countInsertedSoFar) {\n // Insert extra lines here, adjusting i as needed\n for (let nextI = nextToInsert.newLines.length - 1; nextI >= 0; nextI--) {\n this.lines.set(i--, nextToInsert.newLines[nextI]);\n }\n i++;\n\n // Create insert events for later\n insertEvents.push({\n index: originalLineIndex + 1,\n amount: nextToInsert.newLines.length\n });\n\n countInsertedSoFar += nextToInsert.newLines.length;\n nextToInsert = toInsert[++nextToInsertIndex];\n } else {\n this.lines.set(i, originalLines[originalLineIndex--]);\n }\n }\n\n // Update markers\n let insertCountEmitted = 0;\n for (let i = insertEvents.length - 1; i >= 0; i--) {\n insertEvents[i].index += insertCountEmitted;\n this.lines.onInsertEmitter.fire(insertEvents[i]);\n insertCountEmitted += insertEvents[i].amount;\n }\n const amountToTrim = Math.max(0, originalLinesLength + countToInsert - this.lines.maxLength);\n if (amountToTrim > 0) {\n this.lines.onTrimEmitter.fire(amountToTrim);\n }\n }\n }\n\n // private _reflowSmallerGetLinesNeeded()\n\n /**\n * Translates a string index back to a BufferIndex.\n * To get the correct buffer position the string must start at `startCol` 0\n * (default in translateBufferLineToString).\n * The method also works on wrapped line strings given rows were not trimmed.\n * The method operates on the CharData string length, there are no\n * additional content or boundary checks. Therefore the string and the buffer\n * should not be altered in between.\n * TODO: respect trim flag after fixing #1685\n * @param lineIndex line index the string was retrieved from\n * @param stringIndex index within the string\n * @param startCol column offset the string was retrieved from\n */\n public stringIndexToBufferIndex(lineIndex: number, stringIndex: number, trimRight: boolean = false): BufferIndex {\n while (stringIndex) {\n const line = this.lines.get(lineIndex);\n if (!line) {\n return [-1, -1];\n }\n const length = (trimRight) ? line.getTrimmedLength() : line.length;\n for (let i = 0; i < length; ++i) {\n if (line.get(i)[CHAR_DATA_WIDTH_INDEX]) {\n // empty cells report a string length of 0, but get replaced\n // with a whitespace in translateToString, thus replace with 1\n stringIndex -= line.get(i)[CHAR_DATA_CHAR_INDEX].length || 1;\n }\n if (stringIndex < 0) {\n return [lineIndex, i];\n }\n }\n lineIndex++;\n }\n return [lineIndex, 0];\n }\n\n /**\n * Translates a buffer line to a string, with optional start and end columns.\n * Wide characters will count as two columns in the resulting string. This\n * function is useful for getting the actual text underneath the raw selection\n * position.\n * @param line The line being translated.\n * @param trimRight Whether to trim whitespace to the right.\n * @param startCol The column to start at.\n * @param endCol The column to end at.\n */\n public translateBufferLineToString(lineIndex: number, trimRight: boolean, startCol: number = 0, endCol?: number): string {\n const line = this.lines.get(lineIndex);\n if (!line) {\n return '';\n }\n return line.translateToString(trimRight, startCol, endCol);\n }\n\n public getWrappedRangeForLine(y: number): { first: number, last: number } {\n let first = y;\n let last = y;\n // Scan upwards for wrapped lines\n while (first > 0 && this.lines.get(first)!.isWrapped) {\n first--;\n }\n // Scan downwards for wrapped lines\n while (last + 1 < this.lines.length && this.lines.get(last + 1)!.isWrapped) {\n last++;\n }\n return { first, last };\n }\n\n /**\n * Setup the tab stops.\n * @param i The index to start setting up tab stops from.\n */\n public setupTabStops(i?: number): void {\n if (i !== null && i !== undefined) {\n if (!this.tabs[i]) {\n i = this.prevStop(i);\n }\n } else {\n this.tabs = {};\n i = 0;\n }\n\n for (; i < this._cols; i += this._optionsService.options.tabStopWidth) {\n this.tabs[i] = true;\n }\n }\n\n /**\n * Move the cursor to the previous tab stop from the given position (default is current).\n * @param x The position to move the cursor to the previous tab stop.\n */\n public prevStop(x?: number): number {\n if (x === null || x === undefined) {\n x = this.x;\n }\n while (!this.tabs[--x] && x > 0);\n return x >= this._cols ? this._cols - 1 : x < 0 ? 0 : x;\n }\n\n /**\n * Move the cursor one tab stop forward from the given position (default is current).\n * @param x The position to move the cursor one tab stop forward.\n */\n public nextStop(x?: number): number {\n if (x === null || x === undefined) {\n x = this.x;\n }\n while (!this.tabs[++x] && x < this._cols);\n return x >= this._cols ? this._cols - 1 : x < 0 ? 0 : x;\n }\n\n public addMarker(y: number): Marker {\n const marker = new Marker(y);\n this.markers.push(marker);\n marker.register(this.lines.onTrim(amount => {\n marker.line -= amount;\n // The marker should be disposed when the line is trimmed from the buffer\n if (marker.line < 0) {\n marker.dispose();\n }\n }));\n marker.register(this.lines.onInsert(event => {\n if (marker.line >= event.index) {\n marker.line += event.amount;\n }\n }));\n marker.register(this.lines.onDelete(event => {\n // Delete the marker if it's within the range\n if (marker.line >= event.index && marker.line < event.index + event.amount) {\n marker.dispose();\n }\n\n // Shift the marker if it's after the deleted range\n if (marker.line > event.index) {\n marker.line -= event.amount;\n }\n }));\n marker.register(marker.onDispose(() => this._removeMarker(marker)));\n return marker;\n }\n\n private _removeMarker(marker: Marker): void {\n this.markers.splice(this.markers.indexOf(marker), 1);\n }\n\n public iterator(trimRight: boolean, startIndex?: number, endIndex?: number, startOverscan?: number, endOverscan?: number): IBufferStringIterator {\n return new BufferStringIterator(this, trimRight, startIndex, endIndex, startOverscan, endOverscan);\n }\n}\n\n/**\n * Iterator to get unwrapped content strings from the buffer.\n * The iterator returns at least the string data between the borders\n * `startIndex` and `endIndex` (exclusive) and will expand the lines\n * by `startOverscan` to the top and by `endOverscan` to the bottom,\n * if no new line was found in between.\n * It will never read/return string data beyond `startIndex - startOverscan`\n * or `endIndex + endOverscan`. Therefore the first and last line might be truncated.\n * It is possible to always get the full string for the first and last line as well\n * by setting the overscan values to the actual buffer length. This not recommended\n * since it might return the whole buffer within a single string in a worst case scenario.\n */\nexport class BufferStringIterator implements IBufferStringIterator {\n private _current: number;\n\n constructor (\n private _buffer: IBuffer,\n private _trimRight: boolean,\n private _startIndex: number = 0,\n private _endIndex: number = _buffer.lines.length,\n private _startOverscan: number = 0,\n private _endOverscan: number = 0\n ) {\n if (this._startIndex < 0) {\n this._startIndex = 0;\n }\n if (this._endIndex > this._buffer.lines.length) {\n this._endIndex = this._buffer.lines.length;\n }\n this._current = this._startIndex;\n }\n\n public hasNext(): boolean {\n return this._current < this._endIndex;\n }\n\n public next(): IBufferStringIteratorResult {\n const range = this._buffer.getWrappedRangeForLine(this._current);\n // limit search window to overscan value at both borders\n if (range.first < this._startIndex - this._startOverscan) {\n range.first = this._startIndex - this._startOverscan;\n }\n if (range.last > this._endIndex + this._endOverscan) {\n range.last = this._endIndex + this._endOverscan;\n }\n // limit to current buffer length\n range.first = Math.max(range.first, 0);\n range.last = Math.min(range.last, this._buffer.lines.length);\n let content = '';\n for (let i = range.first; i <= range.last; ++i) {\n content += this._buffer.translateBufferLineToString(i, this._trimRight);\n }\n this._current = range.last + 1;\n return {range, content};\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { CharData, IBufferLine, ICellData, IAttributeData, IExtendedAttrs } from 'common/Types';\nimport { stringFromCodePoint } from 'common/input/TextDecoder';\nimport { CHAR_DATA_CHAR_INDEX, CHAR_DATA_WIDTH_INDEX, CHAR_DATA_ATTR_INDEX, NULL_CELL_CHAR, NULL_CELL_WIDTH, NULL_CELL_CODE, WHITESPACE_CELL_CHAR, Content, BgFlags } from 'common/buffer/Constants';\nimport { CellData } from 'common/buffer/CellData';\nimport { AttributeData, ExtendedAttrs } from 'common/buffer/AttributeData';\n\n/**\n * buffer memory layout:\n *\n * | uint32_t | uint32_t | uint32_t |\n * | `content` | `FG` | `BG` |\n * | wcwidth(2) comb(1) codepoint(21) | flags(8) R(8) G(8) B(8) | flags(8) R(8) G(8) B(8) |\n */\n\n\n/** typed array slots taken by one cell */\nconst CELL_SIZE = 3;\n\n/**\n * Cell member indices.\n *\n * Direct access:\n * `content = data[column * CELL_SIZE + Cell.CONTENT];`\n * `fg = data[column * CELL_SIZE + Cell.FG];`\n * `bg = data[column * CELL_SIZE + Cell.BG];`\n */\nconst enum Cell {\n CONTENT = 0,\n FG = 1, // currently simply holds all known attrs\n BG = 2 // currently unused\n}\n\nexport const DEFAULT_ATTR_DATA = Object.freeze(new AttributeData());\n\n/**\n * Typed array based bufferline implementation.\n *\n * There are 2 ways to insert data into the cell buffer:\n * - `setCellFromCodepoint` + `addCodepointToCell`\n * Use these for data that is already UTF32.\n * Used during normal input in `InputHandler` for faster buffer access.\n * - `setCell`\n * This method takes a CellData object and stores the data in the buffer.\n * Use `CellData.fromCharData` to create the CellData object (e.g. from JS string).\n *\n * To retrieve data from the buffer use either one of the primitive methods\n * (if only one particular value is needed) or `loadCell`. For `loadCell` in a loop\n * memory allocs / GC pressure can be greatly reduced by reusing the CellData object.\n */\nexport class BufferLine implements IBufferLine {\n protected _data: Uint32Array;\n protected _combined: {[index: number]: string} = {};\n protected _extendedAttrs: {[index: number]: ExtendedAttrs} = {};\n public length: number;\n\n constructor(cols: number, fillCellData?: ICellData, public isWrapped: boolean = false) {\n this._data = new Uint32Array(cols * CELL_SIZE);\n const cell = fillCellData || CellData.fromCharData([0, NULL_CELL_CHAR, NULL_CELL_WIDTH, NULL_CELL_CODE]);\n for (let i = 0; i < cols; ++i) {\n this.setCell(i, cell);\n }\n this.length = cols;\n }\n\n /**\n * Get cell data CharData.\n * @deprecated\n */\n public get(index: number): CharData {\n const content = this._data[index * CELL_SIZE + Cell.CONTENT];\n const cp = content & Content.CODEPOINT_MASK;\n return [\n this._data[index * CELL_SIZE + Cell.FG],\n (content & Content.IS_COMBINED_MASK)\n ? this._combined[index]\n : (cp) ? stringFromCodePoint(cp) : '',\n content >> Content.WIDTH_SHIFT,\n (content & Content.IS_COMBINED_MASK)\n ? this._combined[index].charCodeAt(this._combined[index].length - 1)\n : cp\n ];\n }\n\n /**\n * Set cell data from CharData.\n * @deprecated\n */\n public set(index: number, value: CharData): void {\n this._data[index * CELL_SIZE + Cell.FG] = value[CHAR_DATA_ATTR_INDEX];\n if (value[CHAR_DATA_CHAR_INDEX].length > 1) {\n this._combined[index] = value[1];\n this._data[index * CELL_SIZE + Cell.CONTENT] = index | Content.IS_COMBINED_MASK | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT);\n } else {\n this._data[index * CELL_SIZE + Cell.CONTENT] = value[CHAR_DATA_CHAR_INDEX].charCodeAt(0) | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT);\n }\n }\n\n /**\n * primitive getters\n * use these when only one value is needed, otherwise use `loadCell`\n */\n public getWidth(index: number): number {\n return this._data[index * CELL_SIZE + Cell.CONTENT] >> Content.WIDTH_SHIFT;\n }\n\n /** Test whether content has width. */\n public hasWidth(index: number): number {\n return this._data[index * CELL_SIZE + Cell.CONTENT] & Content.WIDTH_MASK;\n }\n\n /** Get FG cell component. */\n public getFg(index: number): number {\n return this._data[index * CELL_SIZE + Cell.FG];\n }\n\n /** Get BG cell component. */\n public getBg(index: number): number {\n return this._data[index * CELL_SIZE + Cell.BG];\n }\n\n /**\n * Test whether contains any chars.\n * Basically an empty has no content, but other cells might differ in FG/BG\n * from real empty cells.\n * */\n public hasContent(index: number): number {\n return this._data[index * CELL_SIZE + Cell.CONTENT] & Content.HAS_CONTENT_MASK;\n }\n\n /**\n * Get codepoint of the cell.\n * To be in line with `code` in CharData this either returns\n * a single UTF32 codepoint or the last codepoint of a combined string.\n */\n public getCodePoint(index: number): number {\n const content = this._data[index * CELL_SIZE + Cell.CONTENT];\n if (content & Content.IS_COMBINED_MASK) {\n return this._combined[index].charCodeAt(this._combined[index].length - 1);\n }\n return content & Content.CODEPOINT_MASK;\n }\n\n /** Test whether the cell contains a combined string. */\n public isCombined(index: number): number {\n return this._data[index * CELL_SIZE + Cell.CONTENT] & Content.IS_COMBINED_MASK;\n }\n\n /** Returns the string content of the cell. */\n public getString(index: number): string {\n const content = this._data[index * CELL_SIZE + Cell.CONTENT];\n if (content & Content.IS_COMBINED_MASK) {\n return this._combined[index];\n }\n if (content & Content.CODEPOINT_MASK) {\n return stringFromCodePoint(content & Content.CODEPOINT_MASK);\n }\n // return empty string for empty cells\n return '';\n }\n\n /**\n * Load data at `index` into `cell`. This is used to access cells in a way that's more friendly\n * to GC as it significantly reduced the amount of new objects/references needed.\n */\n public loadCell(index: number, cell: ICellData): ICellData {\n const startIndex = index * CELL_SIZE;\n cell.content = this._data[startIndex + Cell.CONTENT];\n cell.fg = this._data[startIndex + Cell.FG];\n cell.bg = this._data[startIndex + Cell.BG];\n if (cell.content & Content.IS_COMBINED_MASK) {\n cell.combinedData = this._combined[index];\n }\n if (cell.bg & BgFlags.HAS_EXTENDED) {\n cell.extended = this._extendedAttrs[index];\n }\n return cell;\n }\n\n /**\n * Set data at `index` to `cell`.\n */\n public setCell(index: number, cell: ICellData): void {\n if (cell.content & Content.IS_COMBINED_MASK) {\n this._combined[index] = cell.combinedData;\n }\n if (cell.bg & BgFlags.HAS_EXTENDED) {\n this._extendedAttrs[index] = cell.extended;\n }\n this._data[index * CELL_SIZE + Cell.CONTENT] = cell.content;\n this._data[index * CELL_SIZE + Cell.FG] = cell.fg;\n this._data[index * CELL_SIZE + Cell.BG] = cell.bg;\n }\n\n /**\n * Set cell data from input handler.\n * Since the input handler see the incoming chars as UTF32 codepoints,\n * it gets an optimized access method.\n */\n public setCellFromCodePoint(index: number, codePoint: number, width: number, fg: number, bg: number, eAttrs: IExtendedAttrs): void {\n if (bg & BgFlags.HAS_EXTENDED) {\n this._extendedAttrs[index] = eAttrs;\n }\n this._data[index * CELL_SIZE + Cell.CONTENT] = codePoint | (width << Content.WIDTH_SHIFT);\n this._data[index * CELL_SIZE + Cell.FG] = fg;\n this._data[index * CELL_SIZE + Cell.BG] = bg;\n }\n\n /**\n * Add a codepoint to a cell from input handler.\n * During input stage combining chars with a width of 0 follow and stack\n * onto a leading char. Since we already set the attrs\n * by the previous `setDataFromCodePoint` call, we can omit it here.\n */\n public addCodepointToCell(index: number, codePoint: number): void {\n let content = this._data[index * CELL_SIZE + Cell.CONTENT];\n if (content & Content.IS_COMBINED_MASK) {\n // we already have a combined string, simply add\n this._combined[index] += stringFromCodePoint(codePoint);\n } else {\n if (content & Content.CODEPOINT_MASK) {\n // normal case for combining chars:\n // - move current leading char + new one into combined string\n // - set combined flag\n this._combined[index] = stringFromCodePoint(content & Content.CODEPOINT_MASK) + stringFromCodePoint(codePoint);\n content &= ~Content.CODEPOINT_MASK; // set codepoint in buffer to 0\n content |= Content.IS_COMBINED_MASK;\n } else {\n // should not happen - we actually have no data in the cell yet\n // simply set the data in the cell buffer with a width of 1\n content = codePoint | (1 << Content.WIDTH_SHIFT);\n }\n this._data[index * CELL_SIZE + Cell.CONTENT] = content;\n }\n }\n\n public insertCells(pos: number, n: number, fillCellData: ICellData, eraseAttr?: IAttributeData): void {\n pos %= this.length;\n\n // handle fullwidth at pos: reset cell one to the left if pos is second cell of a wide char\n if (pos && this.getWidth(pos - 1) === 2) {\n this.setCellFromCodePoint(pos - 1, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs());\n }\n\n if (n < this.length - pos) {\n const cell = new CellData();\n for (let i = this.length - pos - n - 1; i >= 0; --i) {\n this.setCell(pos + n + i, this.loadCell(pos + i, cell));\n }\n for (let i = 0; i < n; ++i) {\n this.setCell(pos + i, fillCellData);\n }\n } else {\n for (let i = pos; i < this.length; ++i) {\n this.setCell(i, fillCellData);\n }\n }\n\n // handle fullwidth at line end: reset last cell if it is first cell of a wide char\n if (this.getWidth(this.length - 1) === 2) {\n this.setCellFromCodePoint(this.length - 1, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs());\n }\n }\n\n public deleteCells(pos: number, n: number, fillCellData: ICellData, eraseAttr?: IAttributeData): void {\n pos %= this.length;\n if (n < this.length - pos) {\n const cell = new CellData();\n for (let i = 0; i < this.length - pos - n; ++i) {\n this.setCell(pos + i, this.loadCell(pos + n + i, cell));\n }\n for (let i = this.length - n; i < this.length; ++i) {\n this.setCell(i, fillCellData);\n }\n } else {\n for (let i = pos; i < this.length; ++i) {\n this.setCell(i, fillCellData);\n }\n }\n\n // handle fullwidth at pos:\n // - reset pos-1 if wide char\n // - reset pos if width==0 (previous second cell of a wide char)\n if (pos && this.getWidth(pos - 1) === 2) {\n this.setCellFromCodePoint(pos - 1, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs());\n }\n if (this.getWidth(pos) === 0 && !this.hasContent(pos)) {\n this.setCellFromCodePoint(pos, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs());\n }\n }\n\n public replaceCells(start: number, end: number, fillCellData: ICellData, eraseAttr?: IAttributeData): void {\n // handle fullwidth at start: reset cell one to the left if start is second cell of a wide char\n if (start && this.getWidth(start - 1) === 2) {\n this.setCellFromCodePoint(start - 1, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs());\n }\n // handle fullwidth at last cell + 1: reset to empty cell if it is second part of a wide char\n if (end < this.length && this.getWidth(end - 1) === 2) {\n this.setCellFromCodePoint(end, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs());\n }\n\n while (start < end && start < this.length) {\n this.setCell(start++, fillCellData);\n }\n }\n\n public resize(cols: number, fillCellData: ICellData): void {\n if (cols === this.length) {\n return;\n }\n if (cols > this.length) {\n const data = new Uint32Array(cols * CELL_SIZE);\n if (this.length) {\n if (cols * CELL_SIZE < this._data.length) {\n data.set(this._data.subarray(0, cols * CELL_SIZE));\n } else {\n data.set(this._data);\n }\n }\n this._data = data;\n for (let i = this.length; i < cols; ++i) {\n this.setCell(i, fillCellData);\n }\n } else {\n if (cols) {\n const data = new Uint32Array(cols * CELL_SIZE);\n data.set(this._data.subarray(0, cols * CELL_SIZE));\n this._data = data;\n // Remove any cut off combined data, FIXME: repeat this for extended attrs\n const keys = Object.keys(this._combined);\n for (let i = 0; i < keys.length; i++) {\n const key = parseInt(keys[i], 10);\n if (key >= cols) {\n delete this._combined[key];\n }\n }\n } else {\n this._data = new Uint32Array(0);\n this._combined = {};\n }\n }\n this.length = cols;\n }\n\n /** fill a line with fillCharData */\n public fill(fillCellData: ICellData): void {\n this._combined = {};\n this._extendedAttrs = {};\n for (let i = 0; i < this.length; ++i) {\n this.setCell(i, fillCellData);\n }\n }\n\n /** alter to a full copy of line */\n public copyFrom(line: BufferLine): void {\n if (this.length !== line.length) {\n this._data = new Uint32Array(line._data);\n } else {\n // use high speed copy if lengths are equal\n this._data.set(line._data);\n }\n this.length = line.length;\n this._combined = {};\n for (const el in line._combined) {\n this._combined[el] = line._combined[el];\n }\n this._extendedAttrs = {};\n for (const el in line._extendedAttrs) {\n this._extendedAttrs[el] = line._extendedAttrs[el];\n }\n this.isWrapped = line.isWrapped;\n }\n\n /** create a new clone */\n public clone(): IBufferLine {\n const newLine = new BufferLine(0);\n newLine._data = new Uint32Array(this._data);\n newLine.length = this.length;\n for (const el in this._combined) {\n newLine._combined[el] = this._combined[el];\n }\n for (const el in this._extendedAttrs) {\n newLine._extendedAttrs[el] = this._extendedAttrs[el];\n }\n newLine.isWrapped = this.isWrapped;\n return newLine;\n }\n\n public getTrimmedLength(): number {\n for (let i = this.length - 1; i >= 0; --i) {\n if ((this._data[i * CELL_SIZE + Cell.CONTENT] & Content.HAS_CONTENT_MASK)) {\n return i + (this._data[i * CELL_SIZE + Cell.CONTENT] >> Content.WIDTH_SHIFT);\n }\n }\n return 0;\n }\n\n public copyCellsFrom(src: BufferLine, srcCol: number, destCol: number, length: number, applyInReverse: boolean): void {\n const srcData = src._data;\n if (applyInReverse) {\n for (let cell = length - 1; cell >= 0; cell--) {\n for (let i = 0; i < CELL_SIZE; i++) {\n this._data[(destCol + cell) * CELL_SIZE + i] = srcData[(srcCol + cell) * CELL_SIZE + i];\n }\n }\n } else {\n for (let cell = 0; cell < length; cell++) {\n for (let i = 0; i < CELL_SIZE; i++) {\n this._data[(destCol + cell) * CELL_SIZE + i] = srcData[(srcCol + cell) * CELL_SIZE + i];\n }\n }\n }\n\n // Move any combined data over as needed, FIXME: repeat for extended attrs\n const srcCombinedKeys = Object.keys(src._combined);\n for (let i = 0; i < srcCombinedKeys.length; i++) {\n const key = parseInt(srcCombinedKeys[i], 10);\n if (key >= srcCol) {\n this._combined[key - srcCol + destCol] = src._combined[key];\n }\n }\n }\n\n public translateToString(trimRight: boolean = false, startCol: number = 0, endCol: number = this.length): string {\n if (trimRight) {\n endCol = Math.min(endCol, this.getTrimmedLength());\n }\n let result = '';\n while (startCol < endCol) {\n const content = this._data[startCol * CELL_SIZE + Cell.CONTENT];\n const cp = content & Content.CODEPOINT_MASK;\n result += (content & Content.IS_COMBINED_MASK) ? this._combined[startCol] : (cp) ? stringFromCodePoint(cp) : WHITESPACE_CELL_CHAR;\n startCol += (content >> Content.WIDTH_SHIFT) || 1; // always advance by 1\n }\n return result;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { BufferLine } from 'common/buffer/BufferLine';\nimport { CircularList } from 'common/CircularList';\nimport { IBufferLine, ICellData } from 'common/Types';\n\nexport interface INewLayoutResult {\n layout: number[];\n countRemoved: number;\n}\n\n/**\n * Evaluates and returns indexes to be removed after a reflow larger occurs. Lines will be removed\n * when a wrapped line unwraps.\n * @param lines The buffer lines.\n * @param newCols The columns after resize.\n */\nexport function reflowLargerGetLinesToRemove(lines: CircularList, oldCols: number, newCols: number, bufferAbsoluteY: number, nullCell: ICellData): number[] {\n // Gather all BufferLines that need to be removed from the Buffer here so that they can be\n // batched up and only committed once\n const toRemove: number[] = [];\n\n for (let y = 0; y < lines.length - 1; y++) {\n // Check if this row is wrapped\n let i = y;\n let nextLine = lines.get(++i) as BufferLine;\n if (!nextLine.isWrapped) {\n continue;\n }\n\n // Check how many lines it's wrapped for\n const wrappedLines: BufferLine[] = [lines.get(y) as BufferLine];\n while (i < lines.length && nextLine.isWrapped) {\n wrappedLines.push(nextLine);\n nextLine = lines.get(++i) as BufferLine;\n }\n\n // If these lines contain the cursor don't touch them, the program will handle fixing up wrapped\n // lines with the cursor\n if (bufferAbsoluteY >= y && bufferAbsoluteY < i) {\n y += wrappedLines.length - 1;\n continue;\n }\n\n // Copy buffer data to new locations\n let destLineIndex = 0;\n let destCol = getWrappedLineTrimmedLength(wrappedLines, destLineIndex, oldCols);\n let srcLineIndex = 1;\n let srcCol = 0;\n while (srcLineIndex < wrappedLines.length) {\n const srcTrimmedTineLength = getWrappedLineTrimmedLength(wrappedLines, srcLineIndex, oldCols);\n const srcRemainingCells = srcTrimmedTineLength - srcCol;\n const destRemainingCells = newCols - destCol;\n const cellsToCopy = Math.min(srcRemainingCells, destRemainingCells);\n\n wrappedLines[destLineIndex].copyCellsFrom(wrappedLines[srcLineIndex], srcCol, destCol, cellsToCopy, false);\n\n destCol += cellsToCopy;\n if (destCol === newCols) {\n destLineIndex++;\n destCol = 0;\n }\n srcCol += cellsToCopy;\n if (srcCol === srcTrimmedTineLength) {\n srcLineIndex++;\n srcCol = 0;\n }\n\n // Make sure the last cell isn't wide, if it is copy it to the current dest\n if (destCol === 0 && destLineIndex !== 0) {\n if (wrappedLines[destLineIndex - 1].getWidth(newCols - 1) === 2) {\n wrappedLines[destLineIndex].copyCellsFrom(wrappedLines[destLineIndex - 1], newCols - 1, destCol++, 1, false);\n // Null out the end of the last row\n wrappedLines[destLineIndex - 1].setCell(newCols - 1, nullCell);\n }\n }\n }\n\n // Clear out remaining cells or fragments could remain;\n wrappedLines[destLineIndex].replaceCells(destCol, newCols, nullCell);\n\n // Work backwards and remove any rows at the end that only contain null cells\n let countToRemove = 0;\n for (let i = wrappedLines.length - 1; i > 0; i--) {\n if (i > destLineIndex || wrappedLines[i].getTrimmedLength() === 0) {\n countToRemove++;\n } else {\n break;\n }\n }\n\n if (countToRemove > 0) {\n toRemove.push(y + wrappedLines.length - countToRemove); // index\n toRemove.push(countToRemove);\n }\n\n y += wrappedLines.length - 1;\n }\n return toRemove;\n}\n\n/**\n * Creates and return the new layout for lines given an array of indexes to be removed.\n * @param lines The buffer lines.\n * @param toRemove The indexes to remove.\n */\nexport function reflowLargerCreateNewLayout(lines: CircularList, toRemove: number[]): INewLayoutResult {\n const layout: number[] = [];\n // First iterate through the list and get the actual indexes to use for rows\n let nextToRemoveIndex = 0;\n let nextToRemoveStart = toRemove[nextToRemoveIndex];\n let countRemovedSoFar = 0;\n for (let i = 0; i < lines.length; i++) {\n if (nextToRemoveStart === i) {\n const countToRemove = toRemove[++nextToRemoveIndex];\n\n // Tell markers that there was a deletion\n lines.onDeleteEmitter.fire({\n index: i - countRemovedSoFar,\n amount: countToRemove\n });\n\n i += countToRemove - 1;\n countRemovedSoFar += countToRemove;\n nextToRemoveStart = toRemove[++nextToRemoveIndex];\n } else {\n layout.push(i);\n }\n }\n return {\n layout,\n countRemoved: countRemovedSoFar\n };\n}\n\n/**\n * Applies a new layout to the buffer. This essentially does the same as many splice calls but it's\n * done all at once in a single iteration through the list since splice is very expensive.\n * @param lines The buffer lines.\n * @param newLayout The new layout to apply.\n */\nexport function reflowLargerApplyNewLayout(lines: CircularList, newLayout: number[]): void {\n // Record original lines so they don't get overridden when we rearrange the list\n const newLayoutLines: BufferLine[] = [];\n for (let i = 0; i < newLayout.length; i++) {\n newLayoutLines.push(lines.get(newLayout[i]) as BufferLine);\n }\n\n // Rearrange the list\n for (let i = 0; i < newLayoutLines.length; i++) {\n lines.set(i, newLayoutLines[i]);\n }\n lines.length = newLayout.length;\n}\n\n/**\n * Gets the new line lengths for a given wrapped line. The purpose of this function it to pre-\n * compute the wrapping points since wide characters may need to be wrapped onto the following line.\n * This function will return an array of numbers of where each line wraps to, the resulting array\n * will only contain the values `newCols` (when the line does not end with a wide character) and\n * `newCols - 1` (when the line does end with a wide character), except for the last value which\n * will contain the remaining items to fill the line.\n *\n * Calling this with a `newCols` value of `1` will lock up.\n *\n * @param wrappedLines The wrapped lines to evaluate.\n * @param oldCols The columns before resize.\n * @param newCols The columns after resize.\n */\nexport function reflowSmallerGetNewLineLengths(wrappedLines: BufferLine[], oldCols: number, newCols: number): number[] {\n const newLineLengths: number[] = [];\n const cellsNeeded = wrappedLines.map((l, i) => getWrappedLineTrimmedLength(wrappedLines, i, oldCols)).reduce((p, c) => p + c);\n\n // Use srcCol and srcLine to find the new wrapping point, use that to get the cellsAvailable and\n // linesNeeded\n let srcCol = 0;\n let srcLine = 0;\n let cellsAvailable = 0;\n while (cellsAvailable < cellsNeeded) {\n if (cellsNeeded - cellsAvailable < newCols) {\n // Add the final line and exit the loop\n newLineLengths.push(cellsNeeded - cellsAvailable);\n break;\n }\n srcCol += newCols;\n const oldTrimmedLength = getWrappedLineTrimmedLength(wrappedLines, srcLine, oldCols);\n if (srcCol > oldTrimmedLength) {\n srcCol -= oldTrimmedLength;\n srcLine++;\n }\n const endsWithWide = wrappedLines[srcLine].getWidth(srcCol - 1) === 2;\n if (endsWithWide) {\n srcCol--;\n }\n const lineLength = endsWithWide ? newCols - 1 : newCols;\n newLineLengths.push(lineLength);\n cellsAvailable += lineLength;\n }\n\n return newLineLengths;\n}\n\nexport function getWrappedLineTrimmedLength(lines: BufferLine[], i: number, cols: number): number {\n // If this is the last row in the wrapped line, get the actual trimmed length\n if (i === lines.length - 1) {\n return lines[i].getTrimmedLength();\n }\n // Detect whether the following line starts with a wide character and the end of the current line\n // is null, if so then we can be pretty sure the null character should be excluded from the line\n // length]\n const endsInNull = !(lines[i].hasContent(cols - 1)) && lines[i].getWidth(cols - 1) === 1;\n const followingLineStartsWithWide = lines[i + 1].getWidth(0) === 2;\n if (endsInNull && followingLineStartsWithWide) {\n return cols - 1;\n }\n return cols;\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IBuffer, IBufferSet } from 'common/buffer/Types';\nimport { IAttributeData } from 'common/Types';\nimport { Buffer } from 'common/buffer/Buffer';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { IOptionsService, IBufferService } from 'common/services/Services';\nimport { Disposable } from 'common/Lifecycle';\n\n/**\n * The BufferSet represents the set of two buffers used by xterm terminals (normal and alt) and\n * provides also utilities for working with them.\n */\nexport class BufferSet extends Disposable implements IBufferSet {\n private _normal!: Buffer;\n private _alt!: Buffer;\n private _activeBuffer!: Buffer;\n\n private _onBufferActivate = this.register(new EventEmitter<{activeBuffer: IBuffer, inactiveBuffer: IBuffer}>());\n public get onBufferActivate(): IEvent<{activeBuffer: IBuffer, inactiveBuffer: IBuffer}> { return this._onBufferActivate.event; }\n\n /**\n * Create a new BufferSet for the given terminal.\n * @param _terminal - The terminal the BufferSet will belong to\n */\n constructor(\n private readonly _optionsService: IOptionsService,\n private readonly _bufferService: IBufferService\n ) {\n super();\n this.reset();\n }\n\n public reset(): void {\n this._normal = new Buffer(true, this._optionsService, this._bufferService);\n this._normal.fillViewportRows();\n\n // The alt buffer should never have scrollback.\n // See http://invisible-island.net/xterm/ctlseqs/ctlseqs.html#h2-The-Alternate-Screen-Buffer\n this._alt = new Buffer(false, this._optionsService, this._bufferService);\n this._activeBuffer = this._normal;\n\n this.setupTabStops();\n }\n\n /**\n * Returns the alt Buffer of the BufferSet\n */\n public get alt(): Buffer {\n return this._alt;\n }\n\n /**\n * Returns the normal Buffer of the BufferSet\n */\n public get active(): Buffer {\n return this._activeBuffer;\n }\n\n /**\n * Returns the currently active Buffer of the BufferSet\n */\n public get normal(): Buffer {\n return this._normal;\n }\n\n /**\n * Sets the normal Buffer of the BufferSet as its currently active Buffer\n */\n public activateNormalBuffer(): void {\n if (this._activeBuffer === this._normal) {\n return;\n }\n this._normal.x = this._alt.x;\n this._normal.y = this._alt.y;\n // The alt buffer should always be cleared when we switch to the normal\n // buffer. This frees up memory since the alt buffer should always be new\n // when activated.\n this._alt.clear();\n this._activeBuffer = this._normal;\n this._onBufferActivate.fire({\n activeBuffer: this._normal,\n inactiveBuffer: this._alt\n });\n }\n\n /**\n * Sets the alt Buffer of the BufferSet as its currently active Buffer\n */\n public activateAltBuffer(fillAttr?: IAttributeData): void {\n if (this._activeBuffer === this._alt) {\n return;\n }\n // Since the alt buffer is always cleared when the normal buffer is\n // activated, we want to fill it when switching to it.\n this._alt.fillViewportRows(fillAttr);\n this._alt.x = this._normal.x;\n this._alt.y = this._normal.y;\n this._activeBuffer = this._alt;\n this._onBufferActivate.fire({\n activeBuffer: this._alt,\n inactiveBuffer: this._normal\n });\n }\n\n /**\n * Resizes both normal and alt buffers, adjusting their data accordingly.\n * @param newCols The new number of columns.\n * @param newRows The new number of rows.\n */\n public resize(newCols: number, newRows: number): void {\n this._normal.resize(newCols, newRows);\n this._alt.resize(newCols, newRows);\n }\n\n /**\n * Setup the tab stops.\n * @param i The index to start setting up tab stops from.\n */\n public setupTabStops(i?: number): void {\n this._normal.setupTabStops(i);\n this._alt.setupTabStops(i);\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { CharData, ICellData, IExtendedAttrs } from 'common/Types';\nimport { stringFromCodePoint } from 'common/input/TextDecoder';\nimport { CHAR_DATA_CHAR_INDEX, CHAR_DATA_WIDTH_INDEX, CHAR_DATA_ATTR_INDEX, Content } from 'common/buffer/Constants';\nimport { AttributeData, ExtendedAttrs } from 'common/buffer/AttributeData';\n\n/**\n * CellData - represents a single Cell in the terminal buffer.\n */\nexport class CellData extends AttributeData implements ICellData {\n /** Helper to create CellData from CharData. */\n public static fromCharData(value: CharData): CellData {\n const obj = new CellData();\n obj.setFromCharData(value);\n return obj;\n }\n /** Primitives from terminal buffer. */\n public content = 0;\n public fg = 0;\n public bg = 0;\n public extended: IExtendedAttrs = new ExtendedAttrs();\n public combinedData = '';\n /** Whether cell contains a combined string. */\n public isCombined(): number {\n return this.content & Content.IS_COMBINED_MASK;\n }\n /** Width of the cell. */\n public getWidth(): number {\n return this.content >> Content.WIDTH_SHIFT;\n }\n /** JS string of the content. */\n public getChars(): string {\n if (this.content & Content.IS_COMBINED_MASK) {\n return this.combinedData;\n }\n if (this.content & Content.CODEPOINT_MASK) {\n return stringFromCodePoint(this.content & Content.CODEPOINT_MASK);\n }\n return '';\n }\n /**\n * Codepoint of cell\n * Note this returns the UTF32 codepoint of single chars,\n * if content is a combined string it returns the codepoint\n * of the last char in string to be in line with code in CharData.\n * */\n public getCode(): number {\n return (this.isCombined())\n ? this.combinedData.charCodeAt(this.combinedData.length - 1)\n : this.content & Content.CODEPOINT_MASK;\n }\n /** Set data from CharData */\n public setFromCharData(value: CharData): void {\n this.fg = value[CHAR_DATA_ATTR_INDEX];\n this.bg = 0;\n let combined = false;\n // surrogates and combined strings need special treatment\n if (value[CHAR_DATA_CHAR_INDEX].length > 2) {\n combined = true;\n }\n else if (value[CHAR_DATA_CHAR_INDEX].length === 2) {\n const code = value[CHAR_DATA_CHAR_INDEX].charCodeAt(0);\n // if the 2-char string is a surrogate create single codepoint\n // everything else is combined\n if (0xD800 <= code && code <= 0xDBFF) {\n const second = value[CHAR_DATA_CHAR_INDEX].charCodeAt(1);\n if (0xDC00 <= second && second <= 0xDFFF) {\n this.content = ((code - 0xD800) * 0x400 + second - 0xDC00 + 0x10000) | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT);\n }\n else {\n combined = true;\n }\n }\n else {\n combined = true;\n }\n }\n else {\n this.content = value[CHAR_DATA_CHAR_INDEX].charCodeAt(0) | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT);\n }\n if (combined) {\n this.combinedData = value[CHAR_DATA_CHAR_INDEX];\n this.content = Content.IS_COMBINED_MASK | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT);\n }\n }\n /** Get data as CharData. */\n public getAsCharData(): CharData {\n return [this.fg, this.getChars(), this.getWidth(), this.getCode()];\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nexport const DEFAULT_COLOR = 256;\nexport const DEFAULT_ATTR = (0 << 18) | (DEFAULT_COLOR << 9) | (256 << 0);\n\nexport const CHAR_DATA_ATTR_INDEX = 0;\nexport const CHAR_DATA_CHAR_INDEX = 1;\nexport const CHAR_DATA_WIDTH_INDEX = 2;\nexport const CHAR_DATA_CODE_INDEX = 3;\n\n/**\n * Null cell - a real empty cell (containing nothing).\n * Note that code should always be 0 for a null cell as\n * several test condition of the buffer line rely on this.\n */\nexport const NULL_CELL_CHAR = '';\nexport const NULL_CELL_WIDTH = 1;\nexport const NULL_CELL_CODE = 0;\n\n/**\n * Whitespace cell.\n * This is meant as a replacement for empty cells when needed\n * during rendering lines to preserve correct aligment.\n */\nexport const WHITESPACE_CELL_CHAR = ' ';\nexport const WHITESPACE_CELL_WIDTH = 1;\nexport const WHITESPACE_CELL_CODE = 32;\n\n/**\n * Bitmasks for accessing data in `content`.\n */\nexport const enum Content {\n /**\n * bit 1..21 codepoint, max allowed in UTF32 is 0x10FFFF (21 bits taken)\n * read: `codepoint = content & Content.codepointMask;`\n * write: `content |= codepoint & Content.codepointMask;`\n * shortcut if precondition `codepoint <= 0x10FFFF` is met:\n * `content |= codepoint;`\n */\n CODEPOINT_MASK = 0x1FFFFF,\n\n /**\n * bit 22 flag indication whether a cell contains combined content\n * read: `isCombined = content & Content.isCombined;`\n * set: `content |= Content.isCombined;`\n * clear: `content &= ~Content.isCombined;`\n */\n IS_COMBINED_MASK = 0x200000, // 1 << 21\n\n /**\n * bit 1..22 mask to check whether a cell contains any string data\n * we need to check for codepoint and isCombined bits to see\n * whether a cell contains anything\n * read: `isEmpty = !(content & Content.hasContent)`\n */\n HAS_CONTENT_MASK = 0x3FFFFF,\n\n /**\n * bit 23..24 wcwidth value of cell, takes 2 bits (ranges from 0..2)\n * read: `width = (content & Content.widthMask) >> Content.widthShift;`\n * `hasWidth = content & Content.widthMask;`\n * as long as wcwidth is highest value in `content`:\n * `width = content >> Content.widthShift;`\n * write: `content |= (width << Content.widthShift) & Content.widthMask;`\n * shortcut if precondition `0 <= width <= 3` is met:\n * `content |= width << Content.widthShift;`\n */\n WIDTH_MASK = 0xC00000, // 3 << 22\n WIDTH_SHIFT = 22\n}\n\nexport const enum Attributes {\n /**\n * bit 1..8 blue in RGB, color in P256 and P16\n */\n BLUE_MASK = 0xFF,\n BLUE_SHIFT = 0,\n PCOLOR_MASK = 0xFF,\n PCOLOR_SHIFT = 0,\n\n /**\n * bit 9..16 green in RGB\n */\n GREEN_MASK = 0xFF00,\n GREEN_SHIFT = 8,\n\n /**\n * bit 17..24 red in RGB\n */\n RED_MASK = 0xFF0000,\n RED_SHIFT = 16,\n\n /**\n * bit 25..26 color mode: DEFAULT (0) | P16 (1) | P256 (2) | RGB (3)\n */\n CM_MASK = 0x3000000,\n CM_DEFAULT = 0,\n CM_P16 = 0x1000000,\n CM_P256 = 0x2000000,\n CM_RGB = 0x3000000,\n\n /**\n * bit 1..24 RGB room\n */\n RGB_MASK = 0xFFFFFF\n}\n\nexport const enum FgFlags {\n /**\n * bit 27..31 (32th bit unused)\n */\n INVERSE = 0x4000000,\n BOLD = 0x8000000,\n UNDERLINE = 0x10000000,\n BLINK = 0x20000000,\n INVISIBLE = 0x40000000\n}\n\nexport const enum BgFlags {\n /**\n * bit 27..32 (upper 3 unused)\n */\n ITALIC = 0x4000000,\n DIM = 0x8000000,\n HAS_EXTENDED = 0x10000000\n}\n\nexport const enum UnderlineStyle {\n NONE = 0,\n SINGLE = 1,\n DOUBLE = 2,\n CURLY = 3,\n DOTTED = 4,\n DASHED = 5\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { Disposable } from 'common/Lifecycle';\nimport { IMarker } from 'common/Types';\n\nexport class Marker extends Disposable implements IMarker {\n private static _nextId = 1;\n\n private _id: number = Marker._nextId++;\n public isDisposed: boolean = false;\n\n public get id(): number { return this._id; }\n\n private _onDispose = new EventEmitter();\n public get onDispose(): IEvent { return this._onDispose.event; }\n\n constructor(\n public line: number\n ) {\n super();\n }\n\n public dispose(): void {\n if (this.isDisposed) {\n return;\n }\n this.isDisposed = true;\n this.line = -1;\n // Emit before super.dispose such that dispose listeners get a change to react\n this._onDispose.fire();\n super.dispose();\n }\n}\n","/**\n * Copyright (c) 2016 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ICharset } from 'common/Types';\n\n/**\n * The character sets supported by the terminal. These enable several languages\n * to be represented within the terminal with only 8-bit encoding. See ISO 2022\n * for a discussion on character sets. Only VT100 character sets are supported.\n */\nexport const CHARSETS: { [key: string]: ICharset | undefined } = {};\n\n/**\n * The default character set, US.\n */\nexport const DEFAULT_CHARSET: ICharset | undefined = CHARSETS['B'];\n\n/**\n * DEC Special Character and Line Drawing Set.\n * Reference: http://vt100.net/docs/vt102-ug/table5-13.html\n * A lot of curses apps use this if they see TERM=xterm.\n * testing: echo -e '\\e(0a\\e(B'\n * The xterm output sometimes seems to conflict with the\n * reference above. xterm seems in line with the reference\n * when running vttest however.\n * The table below now uses xterm's output from vttest.\n */\nCHARSETS['0'] = {\n '`': '\\u25c6', // '◆'\n 'a': '\\u2592', // '▒'\n 'b': '\\u2409', // '␉' (HT)\n 'c': '\\u240c', // '␌' (FF)\n 'd': '\\u240d', // '␍' (CR)\n 'e': '\\u240a', // '␊' (LF)\n 'f': '\\u00b0', // '°'\n 'g': '\\u00b1', // '±'\n 'h': '\\u2424', // '␤' (NL)\n 'i': '\\u240b', // '␋' (VT)\n 'j': '\\u2518', // '┘'\n 'k': '\\u2510', // '┐'\n 'l': '\\u250c', // '┌'\n 'm': '\\u2514', // '└'\n 'n': '\\u253c', // '┼'\n 'o': '\\u23ba', // '⎺'\n 'p': '\\u23bb', // '⎻'\n 'q': '\\u2500', // '─'\n 'r': '\\u23bc', // '⎼'\n 's': '\\u23bd', // '⎽'\n 't': '\\u251c', // '├'\n 'u': '\\u2524', // '┤'\n 'v': '\\u2534', // '┴'\n 'w': '\\u252c', // '┬'\n 'x': '\\u2502', // '│'\n 'y': '\\u2264', // '≤'\n 'z': '\\u2265', // '≥'\n '{': '\\u03c0', // 'π'\n '|': '\\u2260', // '≠'\n '}': '\\u00a3', // '£'\n '~': '\\u00b7' // '·'\n};\n\n/**\n * British character set\n * ESC (A\n * Reference: http://vt100.net/docs/vt220-rm/table2-5.html\n */\nCHARSETS['A'] = {\n '#': '£'\n};\n\n/**\n * United States character set\n * ESC (B\n */\nCHARSETS['B'] = undefined;\n\n/**\n * Dutch character set\n * ESC (4\n * Reference: http://vt100.net/docs/vt220-rm/table2-6.html\n */\nCHARSETS['4'] = {\n '#': '£',\n '@': '¾',\n '[': 'ij',\n '\\\\': '½',\n ']': '|',\n '{': '¨',\n '|': 'f',\n '}': '¼',\n '~': '´'\n};\n\n/**\n * Finnish character set\n * ESC (C or ESC (5\n * Reference: http://vt100.net/docs/vt220-rm/table2-7.html\n */\nCHARSETS['C'] =\nCHARSETS['5'] = {\n '[': 'Ä',\n '\\\\': 'Ö',\n ']': 'Å',\n '^': 'Ü',\n '`': 'é',\n '{': 'ä',\n '|': 'ö',\n '}': 'å',\n '~': 'ü'\n};\n\n/**\n * French character set\n * ESC (R\n * Reference: http://vt100.net/docs/vt220-rm/table2-8.html\n */\nCHARSETS['R'] = {\n '#': '£',\n '@': 'à',\n '[': '°',\n '\\\\': 'ç',\n ']': '§',\n '{': 'é',\n '|': 'ù',\n '}': 'è',\n '~': '¨'\n};\n\n/**\n * French Canadian character set\n * ESC (Q\n * Reference: http://vt100.net/docs/vt220-rm/table2-9.html\n */\nCHARSETS['Q'] = {\n '@': 'à',\n '[': 'â',\n '\\\\': 'ç',\n ']': 'ê',\n '^': 'î',\n '`': 'ô',\n '{': 'é',\n '|': 'ù',\n '}': 'è',\n '~': 'û'\n};\n\n/**\n * German character set\n * ESC (K\n * Reference: http://vt100.net/docs/vt220-rm/table2-10.html\n */\nCHARSETS['K'] = {\n '@': '§',\n '[': 'Ä',\n '\\\\': 'Ö',\n ']': 'Ü',\n '{': 'ä',\n '|': 'ö',\n '}': 'ü',\n '~': 'ß'\n};\n\n/**\n * Italian character set\n * ESC (Y\n * Reference: http://vt100.net/docs/vt220-rm/table2-11.html\n */\nCHARSETS['Y'] = {\n '#': '£',\n '@': '§',\n '[': '°',\n '\\\\': 'ç',\n ']': 'é',\n '`': 'ù',\n '{': 'à',\n '|': 'ò',\n '}': 'è',\n '~': 'ì'\n};\n\n/**\n * Norwegian/Danish character set\n * ESC (E or ESC (6\n * Reference: http://vt100.net/docs/vt220-rm/table2-12.html\n */\nCHARSETS['E'] =\nCHARSETS['6'] = {\n '@': 'Ä',\n '[': 'Æ',\n '\\\\': 'Ø',\n ']': 'Å',\n '^': 'Ü',\n '`': 'ä',\n '{': 'æ',\n '|': 'ø',\n '}': 'å',\n '~': 'ü'\n};\n\n/**\n * Spanish character set\n * ESC (Z\n * Reference: http://vt100.net/docs/vt220-rm/table2-13.html\n */\nCHARSETS['Z'] = {\n '#': '£',\n '@': '§',\n '[': '¡',\n '\\\\': 'Ñ',\n ']': '¿',\n '{': '°',\n '|': 'ñ',\n '}': 'ç'\n};\n\n/**\n * Swedish character set\n * ESC (H or ESC (7\n * Reference: http://vt100.net/docs/vt220-rm/table2-14.html\n */\nCHARSETS['H'] =\nCHARSETS['7'] = {\n '@': 'É',\n '[': 'Ä',\n '\\\\': 'Ö',\n ']': 'Å',\n '^': 'Ü',\n '`': 'é',\n '{': 'ä',\n '|': 'ö',\n '}': 'å',\n '~': 'ü'\n};\n\n/**\n * Swiss character set\n * ESC (=\n * Reference: http://vt100.net/docs/vt220-rm/table2-15.html\n */\nCHARSETS['='] = {\n '#': 'ù',\n '@': 'à',\n '[': 'é',\n '\\\\': 'ç',\n ']': 'ê',\n '^': 'î',\n // eslint-disable-next-line @typescript-eslint/naming-convention\n '_': 'è',\n '`': 'ô',\n '{': 'ä',\n '|': 'ö',\n '}': 'ü',\n '~': 'û'\n};\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\n/**\n * C0 control codes\n * See = https://en.wikipedia.org/wiki/C0_and_C1_control_codes\n */\nexport namespace C0 {\n /** Null (Caret = ^@, C = \\0) */\n export const NUL = '\\x00';\n /** Start of Heading (Caret = ^A) */\n export const SOH = '\\x01';\n /** Start of Text (Caret = ^B) */\n export const STX = '\\x02';\n /** End of Text (Caret = ^C) */\n export const ETX = '\\x03';\n /** End of Transmission (Caret = ^D) */\n export const EOT = '\\x04';\n /** Enquiry (Caret = ^E) */\n export const ENQ = '\\x05';\n /** Acknowledge (Caret = ^F) */\n export const ACK = '\\x06';\n /** Bell (Caret = ^G, C = \\a) */\n export const BEL = '\\x07';\n /** Backspace (Caret = ^H, C = \\b) */\n export const BS = '\\x08';\n /** Character Tabulation, Horizontal Tabulation (Caret = ^I, C = \\t) */\n export const HT = '\\x09';\n /** Line Feed (Caret = ^J, C = \\n) */\n export const LF = '\\x0a';\n /** Line Tabulation, Vertical Tabulation (Caret = ^K, C = \\v) */\n export const VT = '\\x0b';\n /** Form Feed (Caret = ^L, C = \\f) */\n export const FF = '\\x0c';\n /** Carriage Return (Caret = ^M, C = \\r) */\n export const CR = '\\x0d';\n /** Shift Out (Caret = ^N) */\n export const SO = '\\x0e';\n /** Shift In (Caret = ^O) */\n export const SI = '\\x0f';\n /** Data Link Escape (Caret = ^P) */\n export const DLE = '\\x10';\n /** Device Control One (XON) (Caret = ^Q) */\n export const DC1 = '\\x11';\n /** Device Control Two (Caret = ^R) */\n export const DC2 = '\\x12';\n /** Device Control Three (XOFF) (Caret = ^S) */\n export const DC3 = '\\x13';\n /** Device Control Four (Caret = ^T) */\n export const DC4 = '\\x14';\n /** Negative Acknowledge (Caret = ^U) */\n export const NAK = '\\x15';\n /** Synchronous Idle (Caret = ^V) */\n export const SYN = '\\x16';\n /** End of Transmission Block (Caret = ^W) */\n export const ETB = '\\x17';\n /** Cancel (Caret = ^X) */\n export const CAN = '\\x18';\n /** End of Medium (Caret = ^Y) */\n export const EM = '\\x19';\n /** Substitute (Caret = ^Z) */\n export const SUB = '\\x1a';\n /** Escape (Caret = ^[, C = \\e) */\n export const ESC = '\\x1b';\n /** File Separator (Caret = ^\\) */\n export const FS = '\\x1c';\n /** Group Separator (Caret = ^]) */\n export const GS = '\\x1d';\n /** Record Separator (Caret = ^^) */\n export const RS = '\\x1e';\n /** Unit Separator (Caret = ^_) */\n export const US = '\\x1f';\n /** Space */\n export const SP = '\\x20';\n /** Delete (Caret = ^?) */\n export const DEL = '\\x7f';\n}\n\n/**\n * C1 control codes\n * See = https://en.wikipedia.org/wiki/C0_and_C1_control_codes\n */\nexport namespace C1 {\n /** padding character */\n export const PAD = '\\x80';\n /** High Octet Preset */\n export const HOP = '\\x81';\n /** Break Permitted Here */\n export const BPH = '\\x82';\n /** No Break Here */\n export const NBH = '\\x83';\n /** Index */\n export const IND = '\\x84';\n /** Next Line */\n export const NEL = '\\x85';\n /** Start of Selected Area */\n export const SSA = '\\x86';\n /** End of Selected Area */\n export const ESA = '\\x87';\n /** Horizontal Tabulation Set */\n export const HTS = '\\x88';\n /** Horizontal Tabulation With Justification */\n export const HTJ = '\\x89';\n /** Vertical Tabulation Set */\n export const VTS = '\\x8a';\n /** Partial Line Down */\n export const PLD = '\\x8b';\n /** Partial Line Up */\n export const PLU = '\\x8c';\n /** Reverse Index */\n export const RI = '\\x8d';\n /** Single-Shift 2 */\n export const SS2 = '\\x8e';\n /** Single-Shift 3 */\n export const SS3 = '\\x8f';\n /** Device Control String */\n export const DCS = '\\x90';\n /** Private Use 1 */\n export const PU1 = '\\x91';\n /** Private Use 2 */\n export const PU2 = '\\x92';\n /** Set Transmit State */\n export const STS = '\\x93';\n /** Destructive backspace, intended to eliminate ambiguity about meaning of BS. */\n export const CCH = '\\x94';\n /** Message Waiting */\n export const MW = '\\x95';\n /** Start of Protected Area */\n export const SPA = '\\x96';\n /** End of Protected Area */\n export const EPA = '\\x97';\n /** Start of String */\n export const SOS = '\\x98';\n /** Single Graphic Character Introducer */\n export const SGCI = '\\x99';\n /** Single Character Introducer */\n export const SCI = '\\x9a';\n /** Control Sequence Introducer */\n export const CSI = '\\x9b';\n /** String Terminator */\n export const ST = '\\x9c';\n /** Operating System Command */\n export const OSC = '\\x9d';\n /** Privacy Message */\n export const PM = '\\x9e';\n /** Application Program Command */\n export const APC = '\\x9f';\n}\n","/**\n * Copyright (c) 2014 The xterm.js authors. All rights reserved.\n * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)\n * @license MIT\n */\n\nimport { IKeyboardEvent, IKeyboardResult, KeyboardResultType } from 'common/Types';\nimport { C0 } from 'common/data/EscapeSequences';\n\n// reg + shift key mappings for digits and special chars\nconst KEYCODE_KEY_MAPPINGS: { [key: number]: [string, string]} = {\n // digits 0-9\n 48: ['0', ')'],\n 49: ['1', '!'],\n 50: ['2', '@'],\n 51: ['3', '#'],\n 52: ['4', '$'],\n 53: ['5', '%'],\n 54: ['6', '^'],\n 55: ['7', '&'],\n 56: ['8', '*'],\n 57: ['9', '('],\n\n // special chars\n 186: [';', ':'],\n 187: ['=', '+'],\n 188: [',', '<'],\n 189: ['-', '_'],\n 190: ['.', '>'],\n 191: ['/', '?'],\n 192: ['`', '~'],\n 219: ['[', '{'],\n 220: ['\\\\', '|'],\n 221: [']', '}'],\n 222: ['\\'', '\"']\n};\n\nexport function evaluateKeyboardEvent(\n ev: IKeyboardEvent,\n applicationCursorMode: boolean,\n isMac: boolean,\n macOptionIsMeta: boolean\n): IKeyboardResult {\n const result: IKeyboardResult = {\n type: KeyboardResultType.SEND_KEY,\n // Whether to cancel event propagation (NOTE: this may not be needed since the event is\n // canceled at the end of keyDown\n cancel: false,\n // The new key even to emit\n key: undefined\n };\n const modifiers = (ev.shiftKey ? 1 : 0) | (ev.altKey ? 2 : 0) | (ev.ctrlKey ? 4 : 0) | (ev.metaKey ? 8 : 0);\n switch (ev.keyCode) {\n case 0:\n if (ev.key === 'UIKeyInputUpArrow') {\n if (applicationCursorMode) {\n result.key = C0.ESC + 'OA';\n } else {\n result.key = C0.ESC + '[A';\n }\n }\n else if (ev.key === 'UIKeyInputLeftArrow') {\n if (applicationCursorMode) {\n result.key = C0.ESC + 'OD';\n } else {\n result.key = C0.ESC + '[D';\n }\n }\n else if (ev.key === 'UIKeyInputRightArrow') {\n if (applicationCursorMode) {\n result.key = C0.ESC + 'OC';\n } else {\n result.key = C0.ESC + '[C';\n }\n }\n else if (ev.key === 'UIKeyInputDownArrow') {\n if (applicationCursorMode) {\n result.key = C0.ESC + 'OB';\n } else {\n result.key = C0.ESC + '[B';\n }\n }\n break;\n case 8:\n // backspace\n if (ev.shiftKey) {\n result.key = C0.BS; // ^H\n break;\n } else if (ev.altKey) {\n result.key = C0.ESC + C0.DEL; // \\e ^?\n break;\n }\n result.key = C0.DEL; // ^?\n break;\n case 9:\n // tab\n if (ev.shiftKey) {\n result.key = C0.ESC + '[Z';\n break;\n }\n result.key = C0.HT;\n result.cancel = true;\n break;\n case 13:\n // return/enter\n result.key = ev.altKey ? C0.ESC + C0.CR : C0.CR;\n result.cancel = true;\n break;\n case 27:\n // escape\n result.key = C0.ESC;\n if (ev.altKey) {\n result.key = C0.ESC + C0.ESC;\n }\n result.cancel = true;\n break;\n case 37:\n // left-arrow\n if (ev.metaKey) {\n break;\n }\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'D';\n // HACK: Make Alt + left-arrow behave like Ctrl + left-arrow: move one word backwards\n // http://unix.stackexchange.com/a/108106\n // macOS uses different escape sequences than linux\n if (result.key === C0.ESC + '[1;3D') {\n result.key = C0.ESC + (isMac ? 'b' : '[1;5D');\n }\n } else if (applicationCursorMode) {\n result.key = C0.ESC + 'OD';\n } else {\n result.key = C0.ESC + '[D';\n }\n break;\n case 39:\n // right-arrow\n if (ev.metaKey) {\n break;\n }\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'C';\n // HACK: Make Alt + right-arrow behave like Ctrl + right-arrow: move one word forward\n // http://unix.stackexchange.com/a/108106\n // macOS uses different escape sequences than linux\n if (result.key === C0.ESC + '[1;3C') {\n result.key = C0.ESC + (isMac ? 'f' : '[1;5C');\n }\n } else if (applicationCursorMode) {\n result.key = C0.ESC + 'OC';\n } else {\n result.key = C0.ESC + '[C';\n }\n break;\n case 38:\n // up-arrow\n if (ev.metaKey) {\n break;\n }\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'A';\n // HACK: Make Alt + up-arrow behave like Ctrl + up-arrow\n // http://unix.stackexchange.com/a/108106\n // macOS uses different escape sequences than linux\n if (!isMac && result.key === C0.ESC + '[1;3A') {\n result.key = C0.ESC + '[1;5A';\n }\n } else if (applicationCursorMode) {\n result.key = C0.ESC + 'OA';\n } else {\n result.key = C0.ESC + '[A';\n }\n break;\n case 40:\n // down-arrow\n if (ev.metaKey) {\n break;\n }\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'B';\n // HACK: Make Alt + down-arrow behave like Ctrl + down-arrow\n // http://unix.stackexchange.com/a/108106\n // macOS uses different escape sequences than linux\n if (!isMac && result.key === C0.ESC + '[1;3B') {\n result.key = C0.ESC + '[1;5B';\n }\n } else if (applicationCursorMode) {\n result.key = C0.ESC + 'OB';\n } else {\n result.key = C0.ESC + '[B';\n }\n break;\n case 45:\n // insert\n if (!ev.shiftKey && !ev.ctrlKey) {\n // or + are used to\n // copy-paste on some systems.\n result.key = C0.ESC + '[2~';\n }\n break;\n case 46:\n // delete\n if (modifiers) {\n result.key = C0.ESC + '[3;' + (modifiers + 1) + '~';\n } else {\n result.key = C0.ESC + '[3~';\n }\n break;\n case 36:\n // home\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'H';\n } else if (applicationCursorMode) {\n result.key = C0.ESC + 'OH';\n } else {\n result.key = C0.ESC + '[H';\n }\n break;\n case 35:\n // end\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'F';\n } else if (applicationCursorMode) {\n result.key = C0.ESC + 'OF';\n } else {\n result.key = C0.ESC + '[F';\n }\n break;\n case 33:\n // page up\n if (ev.shiftKey) {\n result.type = KeyboardResultType.PAGE_UP;\n } else {\n result.key = C0.ESC + '[5~';\n }\n break;\n case 34:\n // page down\n if (ev.shiftKey) {\n result.type = KeyboardResultType.PAGE_DOWN;\n } else {\n result.key = C0.ESC + '[6~';\n }\n break;\n case 112:\n // F1-F12\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'P';\n } else {\n result.key = C0.ESC + 'OP';\n }\n break;\n case 113:\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'Q';\n } else {\n result.key = C0.ESC + 'OQ';\n }\n break;\n case 114:\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'R';\n } else {\n result.key = C0.ESC + 'OR';\n }\n break;\n case 115:\n if (modifiers) {\n result.key = C0.ESC + '[1;' + (modifiers + 1) + 'S';\n } else {\n result.key = C0.ESC + 'OS';\n }\n break;\n case 116:\n if (modifiers) {\n result.key = C0.ESC + '[15;' + (modifiers + 1) + '~';\n } else {\n result.key = C0.ESC + '[15~';\n }\n break;\n case 117:\n if (modifiers) {\n result.key = C0.ESC + '[17;' + (modifiers + 1) + '~';\n } else {\n result.key = C0.ESC + '[17~';\n }\n break;\n case 118:\n if (modifiers) {\n result.key = C0.ESC + '[18;' + (modifiers + 1) + '~';\n } else {\n result.key = C0.ESC + '[18~';\n }\n break;\n case 119:\n if (modifiers) {\n result.key = C0.ESC + '[19;' + (modifiers + 1) + '~';\n } else {\n result.key = C0.ESC + '[19~';\n }\n break;\n case 120:\n if (modifiers) {\n result.key = C0.ESC + '[20;' + (modifiers + 1) + '~';\n } else {\n result.key = C0.ESC + '[20~';\n }\n break;\n case 121:\n if (modifiers) {\n result.key = C0.ESC + '[21;' + (modifiers + 1) + '~';\n } else {\n result.key = C0.ESC + '[21~';\n }\n break;\n case 122:\n if (modifiers) {\n result.key = C0.ESC + '[23;' + (modifiers + 1) + '~';\n } else {\n result.key = C0.ESC + '[23~';\n }\n break;\n case 123:\n if (modifiers) {\n result.key = C0.ESC + '[24;' + (modifiers + 1) + '~';\n } else {\n result.key = C0.ESC + '[24~';\n }\n break;\n default:\n // a-z and space\n if (ev.ctrlKey && !ev.shiftKey && !ev.altKey && !ev.metaKey) {\n if (ev.keyCode >= 65 && ev.keyCode <= 90) {\n result.key = String.fromCharCode(ev.keyCode - 64);\n } else if (ev.keyCode === 32) {\n result.key = C0.NUL;\n } else if (ev.keyCode >= 51 && ev.keyCode <= 55) {\n // escape, file sep, group sep, record sep, unit sep\n result.key = String.fromCharCode(ev.keyCode - 51 + 27);\n } else if (ev.keyCode === 56) {\n result.key = C0.DEL;\n } else if (ev.keyCode === 219) {\n result.key = C0.ESC;\n } else if (ev.keyCode === 220) {\n result.key = C0.FS;\n } else if (ev.keyCode === 221) {\n result.key = C0.GS;\n }\n } else if ((!isMac || macOptionIsMeta) && ev.altKey && !ev.metaKey) {\n // On macOS this is a third level shift when !macOptionIsMeta. Use instead.\n const keyMapping = KEYCODE_KEY_MAPPINGS[ev.keyCode];\n const key = keyMapping && keyMapping[!ev.shiftKey ? 0 : 1];\n if (key) {\n result.key = C0.ESC + key;\n } else if (ev.keyCode >= 65 && ev.keyCode <= 90) {\n const keyCode = ev.ctrlKey ? ev.keyCode - 64 : ev.keyCode + 32;\n result.key = C0.ESC + String.fromCharCode(keyCode);\n }\n } else if (isMac && !ev.altKey && !ev.ctrlKey && !ev.shiftKey && ev.metaKey) {\n if (ev.keyCode === 65) { // cmd + a\n result.type = KeyboardResultType.SELECT_ALL;\n }\n } else if (ev.key && !ev.ctrlKey && !ev.altKey && !ev.metaKey && ev.keyCode >= 48 && ev.key.length === 1) {\n // Include only keys that that result in a _single_ character; don't include num lock, volume up, etc.\n result.key = ev.key;\n } else if (ev.key && ev.ctrlKey) {\n if (ev.key === '_') { // ^_\n result.key = C0.US;\n }\n }\n break;\n }\n\n return result;\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\n/**\n * Polyfill - Convert UTF32 codepoint into JS string.\n * Note: The built-in String.fromCodePoint happens to be much slower\n * due to additional sanity checks. We can avoid them since\n * we always operate on legal UTF32 (granted by the input decoders)\n * and use this faster version instead.\n */\nexport function stringFromCodePoint(codePoint: number): string {\n if (codePoint > 0xFFFF) {\n codePoint -= 0x10000;\n return String.fromCharCode((codePoint >> 10) + 0xD800) + String.fromCharCode((codePoint % 0x400) + 0xDC00);\n }\n return String.fromCharCode(codePoint);\n}\n\n/**\n * Convert UTF32 char codes into JS string.\n * Basically the same as `stringFromCodePoint` but for multiple codepoints\n * in a loop (which is a lot faster).\n */\nexport function utf32ToString(data: Uint32Array, start: number = 0, end: number = data.length): string {\n let result = '';\n for (let i = start; i < end; ++i) {\n let codepoint = data[i];\n if (codepoint > 0xFFFF) {\n // JS strings are encoded as UTF16, thus a non BMP codepoint gets converted into a surrogate pair\n // conversion rules:\n // - subtract 0x10000 from code point, leaving a 20 bit number\n // - add high 10 bits to 0xD800 --> first surrogate\n // - add low 10 bits to 0xDC00 --> second surrogate\n codepoint -= 0x10000;\n result += String.fromCharCode((codepoint >> 10) + 0xD800) + String.fromCharCode((codepoint % 0x400) + 0xDC00);\n } else {\n result += String.fromCharCode(codepoint);\n }\n }\n return result;\n}\n\n/**\n * StringToUtf32 - decodes UTF16 sequences into UTF32 codepoints.\n * To keep the decoder in line with JS strings it handles single surrogates as UCS2.\n */\nexport class StringToUtf32 {\n private _interim: number = 0;\n\n /**\n * Clears interim and resets decoder to clean state.\n */\n public clear(): void {\n this._interim = 0;\n }\n\n /**\n * Decode JS string to UTF32 codepoints.\n * The methods assumes stream input and will store partly transmitted\n * surrogate pairs and decode them with the next data chunk.\n * Note: The method does no bound checks for target, therefore make sure\n * the provided input data does not exceed the size of `target`.\n * Returns the number of written codepoints in `target`.\n */\n public decode(input: string, target: Uint32Array): number {\n const length = input.length;\n\n if (!length) {\n return 0;\n }\n\n let size = 0;\n let startPos = 0;\n\n // handle leftover surrogate high\n if (this._interim) {\n const second = input.charCodeAt(startPos++);\n if (0xDC00 <= second && second <= 0xDFFF) {\n target[size++] = (this._interim - 0xD800) * 0x400 + second - 0xDC00 + 0x10000;\n } else {\n // illegal codepoint (USC2 handling)\n target[size++] = this._interim;\n target[size++] = second;\n }\n this._interim = 0;\n }\n\n for (let i = startPos; i < length; ++i) {\n const code = input.charCodeAt(i);\n // surrogate pair first\n if (0xD800 <= code && code <= 0xDBFF) {\n if (++i >= length) {\n this._interim = code;\n return size;\n }\n const second = input.charCodeAt(i);\n if (0xDC00 <= second && second <= 0xDFFF) {\n target[size++] = (code - 0xD800) * 0x400 + second - 0xDC00 + 0x10000;\n } else {\n // illegal codepoint (USC2 handling)\n target[size++] = code;\n target[size++] = second;\n }\n continue;\n }\n if (code === 0xFEFF) {\n // BOM\n continue;\n }\n target[size++] = code;\n }\n return size;\n }\n}\n\n/**\n * Utf8Decoder - decodes UTF8 byte sequences into UTF32 codepoints.\n */\nexport class Utf8ToUtf32 {\n public interim: Uint8Array = new Uint8Array(3);\n\n /**\n * Clears interim bytes and resets decoder to clean state.\n */\n public clear(): void {\n this.interim.fill(0);\n }\n\n /**\n * Decodes UTF8 byte sequences in `input` to UTF32 codepoints in `target`.\n * The methods assumes stream input and will store partly transmitted bytes\n * and decode them with the next data chunk.\n * Note: The method does no bound checks for target, therefore make sure\n * the provided data chunk does not exceed the size of `target`.\n * Returns the number of written codepoints in `target`.\n */\n public decode(input: Uint8Array, target: Uint32Array): number {\n const length = input.length;\n\n if (!length) {\n return 0;\n }\n\n let size = 0;\n let byte1: number;\n let byte2: number;\n let byte3: number;\n let byte4: number;\n let codepoint = 0;\n let startPos = 0;\n\n // handle leftover bytes\n if (this.interim[0]) {\n let discardInterim = false;\n let cp = this.interim[0];\n cp &= ((((cp & 0xE0) === 0xC0)) ? 0x1F : (((cp & 0xF0) === 0xE0)) ? 0x0F : 0x07);\n let pos = 0;\n let tmp: number;\n while ((tmp = this.interim[++pos] & 0x3F) && pos < 4) {\n cp <<= 6;\n cp |= tmp;\n }\n // missing bytes - read ahead from input\n const type = (((this.interim[0] & 0xE0) === 0xC0)) ? 2 : (((this.interim[0] & 0xF0) === 0xE0)) ? 3 : 4;\n const missing = type - pos;\n while (startPos < missing) {\n if (startPos >= length) {\n return 0;\n }\n tmp = input[startPos++];\n if ((tmp & 0xC0) !== 0x80) {\n // wrong continuation, discard interim bytes completely\n startPos--;\n discardInterim = true;\n break;\n } else {\n // need to save so we can continue short inputs in next call\n this.interim[pos++] = tmp;\n cp <<= 6;\n cp |= tmp & 0x3F;\n }\n }\n if (!discardInterim) {\n // final test is type dependent\n if (type === 2) {\n if (cp < 0x80) {\n // wrong starter byte\n startPos--;\n } else {\n target[size++] = cp;\n }\n } else if (type === 3) {\n if (cp < 0x0800 || (cp >= 0xD800 && cp <= 0xDFFF) || cp === 0xFEFF) {\n // illegal codepoint or BOM\n } else {\n target[size++] = cp;\n }\n } else {\n if (cp < 0x010000 || cp > 0x10FFFF) {\n // illegal codepoint\n } else {\n target[size++] = cp;\n }\n }\n }\n this.interim.fill(0);\n }\n\n // loop through input\n const fourStop = length - 4;\n let i = startPos;\n while (i < length) {\n /**\n * ASCII shortcut with loop unrolled to 4 consecutive ASCII chars.\n * This is a compromise between speed gain for ASCII\n * and penalty for non ASCII:\n * For best ASCII performance the char should be stored directly into target,\n * but even a single attempt to write to target and compare afterwards\n * penalizes non ASCII really bad (-50%), thus we load the char into byteX first,\n * which reduces ASCII performance by ~15%.\n * This trial for ASCII reduces non ASCII performance by ~10% which seems acceptible\n * compared to the gains.\n * Note that this optimization only takes place for 4 consecutive ASCII chars,\n * for any shorter it bails out. Worst case - all 4 bytes being read but\n * thrown away due to the last being a non ASCII char (-10% performance).\n */\n while (i < fourStop\n && !((byte1 = input[i]) & 0x80)\n && !((byte2 = input[i + 1]) & 0x80)\n && !((byte3 = input[i + 2]) & 0x80)\n && !((byte4 = input[i + 3]) & 0x80))\n {\n target[size++] = byte1;\n target[size++] = byte2;\n target[size++] = byte3;\n target[size++] = byte4;\n i += 4;\n }\n\n // reread byte1\n byte1 = input[i++];\n\n // 1 byte\n if (byte1 < 0x80) {\n target[size++] = byte1;\n\n // 2 bytes\n } else if ((byte1 & 0xE0) === 0xC0) {\n if (i >= length) {\n this.interim[0] = byte1;\n return size;\n }\n byte2 = input[i++];\n if ((byte2 & 0xC0) !== 0x80) {\n // wrong continuation\n i--;\n continue;\n }\n codepoint = (byte1 & 0x1F) << 6 | (byte2 & 0x3F);\n if (codepoint < 0x80) {\n // wrong starter byte\n i--;\n continue;\n }\n target[size++] = codepoint;\n\n // 3 bytes\n } else if ((byte1 & 0xF0) === 0xE0) {\n if (i >= length) {\n this.interim[0] = byte1;\n return size;\n }\n byte2 = input[i++];\n if ((byte2 & 0xC0) !== 0x80) {\n // wrong continuation\n i--;\n continue;\n }\n if (i >= length) {\n this.interim[0] = byte1;\n this.interim[1] = byte2;\n return size;\n }\n byte3 = input[i++];\n if ((byte3 & 0xC0) !== 0x80) {\n // wrong continuation\n i--;\n continue;\n }\n codepoint = (byte1 & 0x0F) << 12 | (byte2 & 0x3F) << 6 | (byte3 & 0x3F);\n if (codepoint < 0x0800 || (codepoint >= 0xD800 && codepoint <= 0xDFFF) || codepoint === 0xFEFF) {\n // illegal codepoint or BOM, no i-- here\n continue;\n }\n target[size++] = codepoint;\n\n // 4 bytes\n } else if ((byte1 & 0xF8) === 0xF0) {\n if (i >= length) {\n this.interim[0] = byte1;\n return size;\n }\n byte2 = input[i++];\n if ((byte2 & 0xC0) !== 0x80) {\n // wrong continuation\n i--;\n continue;\n }\n if (i >= length) {\n this.interim[0] = byte1;\n this.interim[1] = byte2;\n return size;\n }\n byte3 = input[i++];\n if ((byte3 & 0xC0) !== 0x80) {\n // wrong continuation\n i--;\n continue;\n }\n if (i >= length) {\n this.interim[0] = byte1;\n this.interim[1] = byte2;\n this.interim[2] = byte3;\n return size;\n }\n byte4 = input[i++];\n if ((byte4 & 0xC0) !== 0x80) {\n // wrong continuation\n i--;\n continue;\n }\n codepoint = (byte1 & 0x07) << 18 | (byte2 & 0x3F) << 12 | (byte3 & 0x3F) << 6 | (byte4 & 0x3F);\n if (codepoint < 0x010000 || codepoint > 0x10FFFF) {\n // illegal codepoint, no i-- here\n continue;\n }\n target[size++] = codepoint;\n } else {\n // illegal byte, just skip\n }\n }\n return size;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\nimport { IUnicodeVersionProvider } from 'common/services/Services';\nimport { fill } from 'common/TypedArrayUtils';\n\ntype CharWidth = 0 | 1 | 2;\n\nconst BMP_COMBINING = [\n [0x0300, 0x036F], [0x0483, 0x0486], [0x0488, 0x0489],\n [0x0591, 0x05BD], [0x05BF, 0x05BF], [0x05C1, 0x05C2],\n [0x05C4, 0x05C5], [0x05C7, 0x05C7], [0x0600, 0x0603],\n [0x0610, 0x0615], [0x064B, 0x065E], [0x0670, 0x0670],\n [0x06D6, 0x06E4], [0x06E7, 0x06E8], [0x06EA, 0x06ED],\n [0x070F, 0x070F], [0x0711, 0x0711], [0x0730, 0x074A],\n [0x07A6, 0x07B0], [0x07EB, 0x07F3], [0x0901, 0x0902],\n [0x093C, 0x093C], [0x0941, 0x0948], [0x094D, 0x094D],\n [0x0951, 0x0954], [0x0962, 0x0963], [0x0981, 0x0981],\n [0x09BC, 0x09BC], [0x09C1, 0x09C4], [0x09CD, 0x09CD],\n [0x09E2, 0x09E3], [0x0A01, 0x0A02], [0x0A3C, 0x0A3C],\n [0x0A41, 0x0A42], [0x0A47, 0x0A48], [0x0A4B, 0x0A4D],\n [0x0A70, 0x0A71], [0x0A81, 0x0A82], [0x0ABC, 0x0ABC],\n [0x0AC1, 0x0AC5], [0x0AC7, 0x0AC8], [0x0ACD, 0x0ACD],\n [0x0AE2, 0x0AE3], [0x0B01, 0x0B01], [0x0B3C, 0x0B3C],\n [0x0B3F, 0x0B3F], [0x0B41, 0x0B43], [0x0B4D, 0x0B4D],\n [0x0B56, 0x0B56], [0x0B82, 0x0B82], [0x0BC0, 0x0BC0],\n [0x0BCD, 0x0BCD], [0x0C3E, 0x0C40], [0x0C46, 0x0C48],\n [0x0C4A, 0x0C4D], [0x0C55, 0x0C56], [0x0CBC, 0x0CBC],\n [0x0CBF, 0x0CBF], [0x0CC6, 0x0CC6], [0x0CCC, 0x0CCD],\n [0x0CE2, 0x0CE3], [0x0D41, 0x0D43], [0x0D4D, 0x0D4D],\n [0x0DCA, 0x0DCA], [0x0DD2, 0x0DD4], [0x0DD6, 0x0DD6],\n [0x0E31, 0x0E31], [0x0E34, 0x0E3A], [0x0E47, 0x0E4E],\n [0x0EB1, 0x0EB1], [0x0EB4, 0x0EB9], [0x0EBB, 0x0EBC],\n [0x0EC8, 0x0ECD], [0x0F18, 0x0F19], [0x0F35, 0x0F35],\n [0x0F37, 0x0F37], [0x0F39, 0x0F39], [0x0F71, 0x0F7E],\n [0x0F80, 0x0F84], [0x0F86, 0x0F87], [0x0F90, 0x0F97],\n [0x0F99, 0x0FBC], [0x0FC6, 0x0FC6], [0x102D, 0x1030],\n [0x1032, 0x1032], [0x1036, 0x1037], [0x1039, 0x1039],\n [0x1058, 0x1059], [0x1160, 0x11FF], [0x135F, 0x135F],\n [0x1712, 0x1714], [0x1732, 0x1734], [0x1752, 0x1753],\n [0x1772, 0x1773], [0x17B4, 0x17B5], [0x17B7, 0x17BD],\n [0x17C6, 0x17C6], [0x17C9, 0x17D3], [0x17DD, 0x17DD],\n [0x180B, 0x180D], [0x18A9, 0x18A9], [0x1920, 0x1922],\n [0x1927, 0x1928], [0x1932, 0x1932], [0x1939, 0x193B],\n [0x1A17, 0x1A18], [0x1B00, 0x1B03], [0x1B34, 0x1B34],\n [0x1B36, 0x1B3A], [0x1B3C, 0x1B3C], [0x1B42, 0x1B42],\n [0x1B6B, 0x1B73], [0x1DC0, 0x1DCA], [0x1DFE, 0x1DFF],\n [0x200B, 0x200F], [0x202A, 0x202E], [0x2060, 0x2063],\n [0x206A, 0x206F], [0x20D0, 0x20EF], [0x302A, 0x302F],\n [0x3099, 0x309A], [0xA806, 0xA806], [0xA80B, 0xA80B],\n [0xA825, 0xA826], [0xFB1E, 0xFB1E], [0xFE00, 0xFE0F],\n [0xFE20, 0xFE23], [0xFEFF, 0xFEFF], [0xFFF9, 0xFFFB]\n];\nconst HIGH_COMBINING = [\n [0x10A01, 0x10A03], [0x10A05, 0x10A06], [0x10A0C, 0x10A0F],\n [0x10A38, 0x10A3A], [0x10A3F, 0x10A3F], [0x1D167, 0x1D169],\n [0x1D173, 0x1D182], [0x1D185, 0x1D18B], [0x1D1AA, 0x1D1AD],\n [0x1D242, 0x1D244], [0xE0001, 0xE0001], [0xE0020, 0xE007F],\n [0xE0100, 0xE01EF]\n];\n\n// BMP lookup table, lazy initialized during first addon loading\nlet table: Uint8Array;\n\nfunction bisearch(ucs: number, data: number[][]): boolean {\n let min = 0;\n let max = data.length - 1;\n let mid;\n if (ucs < data[0][0] || ucs > data[max][1]) {\n return false;\n }\n while (max >= min) {\n mid = (min + max) >> 1;\n if (ucs > data[mid][1]) {\n min = mid + 1;\n } else if (ucs < data[mid][0]) {\n max = mid - 1;\n } else {\n return true;\n }\n }\n return false;\n}\n\nexport class UnicodeV6 implements IUnicodeVersionProvider {\n public readonly version = '6';\n\n constructor() {\n // init lookup table once\n if (!table) {\n table = new Uint8Array(65536);\n fill(table, 1);\n table[0] = 0;\n // control chars\n fill(table, 0, 1, 32);\n fill(table, 0, 0x7f, 0xa0);\n\n // apply wide char rules first\n // wide chars\n fill(table, 2, 0x1100, 0x1160);\n table[0x2329] = 2;\n table[0x232a] = 2;\n fill(table, 2, 0x2e80, 0xa4d0);\n table[0x303f] = 1; // wrongly in last line\n\n fill(table, 2, 0xac00, 0xd7a4);\n fill(table, 2, 0xf900, 0xfb00);\n fill(table, 2, 0xfe10, 0xfe1a);\n fill(table, 2, 0xfe30, 0xfe70);\n fill(table, 2, 0xff00, 0xff61);\n fill(table, 2, 0xffe0, 0xffe7);\n\n // apply combining last to ensure we overwrite\n // wrongly wide set chars:\n // the original algo evals combining first and falls\n // through to wide check so we simply do here the opposite\n // combining 0\n for (let r = 0; r < BMP_COMBINING.length; ++r) {\n fill(table, 0, BMP_COMBINING[r][0], BMP_COMBINING[r][1] + 1);\n }\n }\n }\n\n public wcwidth(num: number): CharWidth {\n if (num < 32) return 0;\n if (num < 127) return 1;\n if (num < 65536) return table[num] as CharWidth;\n if (bisearch(num, HIGH_COMBINING)) return 0;\n if ((num >= 0x20000 && num <= 0x2fffd) || (num >= 0x30000 && num <= 0x3fffd)) return 2;\n return 1;\n }\n}\n","\n/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\ndeclare const setTimeout: (handler: () => void, timeout?: number) => void;\n\n/**\n * Safety watermark to avoid memory exhaustion and browser engine crash on fast data input.\n * Enable flow control to avoid this limit and make sure that your backend correctly\n * propagates this to the underlying pty. (see docs for further instructions)\n * Since this limit is meant as a safety parachute to prevent browser crashs,\n * it is set to a very high number. Typically xterm.js gets unresponsive with\n * a 100 times lower number (>500 kB).\n */\nconst DISCARD_WATERMARK = 50000000; // ~50 MB\n\n/**\n * The max number of ms to spend on writes before allowing the renderer to\n * catch up with a 0ms setTimeout. A value of < 33 to keep us close to\n * 30fps, and a value of < 16 to try to run at 60fps. Of course, the real FPS\n * depends on the time it takes for the renderer to draw the frame.\n */\nconst WRITE_TIMEOUT_MS = 12;\n\n/**\n * Threshold of max held chunks in the write buffer, that were already processed.\n * This is a tradeoff between extensive write buffer shifts (bad runtime) and high\n * memory consumption by data thats not used anymore.\n */\nconst WRITE_BUFFER_LENGTH_THRESHOLD = 50;\n\nexport class WriteBuffer {\n private _writeBuffer: (string | Uint8Array)[] = [];\n private _callbacks: ((() => void) | undefined)[] = [];\n private _pendingData = 0;\n private _bufferOffset = 0;\n\n constructor(private _action: (data: string | Uint8Array) => void) { }\n\n public writeSync(data: string | Uint8Array): void {\n // force sync processing on pending data chunks to avoid in-band data scrambling\n // does the same as innerWrite but without event loop\n if (this._writeBuffer.length) {\n for (let i = this._bufferOffset; i < this._writeBuffer.length; ++i) {\n const data = this._writeBuffer[i];\n const cb = this._callbacks[i];\n this._action(data);\n if (cb) cb();\n }\n // reset all to avoid reprocessing of chunks with scheduled innerWrite call\n this._writeBuffer = [];\n this._callbacks = [];\n this._pendingData = 0;\n // stop scheduled innerWrite by offset > length condition\n this._bufferOffset = 0x7FFFFFFF;\n }\n // handle current data chunk\n this._action(data);\n }\n\n public write(data: string | Uint8Array, callback?: () => void): void {\n if (this._pendingData > DISCARD_WATERMARK) {\n throw new Error('write data discarded, use flow control to avoid losing data');\n }\n\n // schedule chunk processing for next event loop run\n if (!this._writeBuffer.length) {\n this._bufferOffset = 0;\n setTimeout(() => this._innerWrite());\n }\n\n this._pendingData += data.length;\n this._writeBuffer.push(data);\n this._callbacks.push(callback);\n }\n\n protected _innerWrite(): void {\n const startTime = Date.now();\n while (this._writeBuffer.length > this._bufferOffset) {\n const data = this._writeBuffer[this._bufferOffset];\n const cb = this._callbacks[this._bufferOffset];\n this._bufferOffset++;\n\n this._action(data);\n this._pendingData -= data.length;\n if (cb) cb();\n\n if (Date.now() - startTime >= WRITE_TIMEOUT_MS) {\n break;\n }\n }\n if (this._writeBuffer.length > this._bufferOffset) {\n // Allow renderer to catch up before processing the next batch\n // trim already processed chunks if we are above threshold\n if (this._bufferOffset > WRITE_BUFFER_LENGTH_THRESHOLD) {\n this._writeBuffer = this._writeBuffer.slice(this._bufferOffset);\n this._callbacks = this._callbacks.slice(this._bufferOffset);\n this._bufferOffset = 0;\n }\n setTimeout(() => this._innerWrite(), 0);\n } else {\n this._writeBuffer = [];\n this._callbacks = [];\n this._pendingData = 0;\n this._bufferOffset = 0;\n }\n }\n}\n","/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\n/**\n * Internal states of EscapeSequenceParser.\n */\nexport const enum ParserState {\n GROUND = 0,\n ESCAPE = 1,\n ESCAPE_INTERMEDIATE = 2,\n CSI_ENTRY = 3,\n CSI_PARAM = 4,\n CSI_INTERMEDIATE = 5,\n CSI_IGNORE = 6,\n SOS_PM_APC_STRING = 7,\n OSC_STRING = 8,\n DCS_ENTRY = 9,\n DCS_PARAM = 10,\n DCS_IGNORE = 11,\n DCS_INTERMEDIATE = 12,\n DCS_PASSTHROUGH = 13\n}\n\n/**\n* Internal actions of EscapeSequenceParser.\n*/\nexport const enum ParserAction {\n IGNORE = 0,\n ERROR = 1,\n PRINT = 2,\n EXECUTE = 3,\n OSC_START = 4,\n OSC_PUT = 5,\n OSC_END = 6,\n CSI_DISPATCH = 7,\n PARAM = 8,\n COLLECT = 9,\n ESC_DISPATCH = 10,\n CLEAR = 11,\n DCS_HOOK = 12,\n DCS_PUT = 13,\n DCS_UNHOOK = 14\n}\n\n/**\n * Internal states of OscParser.\n */\nexport const enum OscState {\n START = 0,\n ID = 1,\n PAYLOAD = 2,\n ABORT = 3\n}\n\n// payload limit for OSC and DCS\nexport const PAYLOAD_LIMIT = 10000000;\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IDisposable } from 'common/Types';\nimport { IDcsHandler, IParams, IHandlerCollection, IDcsParser, DcsFallbackHandlerType } from 'common/parser/Types';\nimport { utf32ToString } from 'common/input/TextDecoder';\nimport { Params } from 'common/parser/Params';\nimport { PAYLOAD_LIMIT } from 'common/parser/Constants';\n\nconst EMPTY_HANDLERS: IDcsHandler[] = [];\n\nexport class DcsParser implements IDcsParser {\n private _handlers: IHandlerCollection = Object.create(null);\n private _active: IDcsHandler[] = EMPTY_HANDLERS;\n private _ident: number = 0;\n private _handlerFb: DcsFallbackHandlerType = () => {};\n\n public dispose(): void {\n this._handlers = Object.create(null);\n this._handlerFb = () => {};\n this._active = EMPTY_HANDLERS;\n }\n\n public registerHandler(ident: number, handler: IDcsHandler): IDisposable {\n if (this._handlers[ident] === undefined) {\n this._handlers[ident] = [];\n }\n const handlerList = this._handlers[ident];\n handlerList.push(handler);\n return {\n dispose: () => {\n const handlerIndex = handlerList.indexOf(handler);\n if (handlerIndex !== -1) {\n handlerList.splice(handlerIndex, 1);\n }\n }\n };\n }\n\n public clearHandler(ident: number): void {\n if (this._handlers[ident]) delete this._handlers[ident];\n }\n\n public setHandlerFallback(handler: DcsFallbackHandlerType): void {\n this._handlerFb = handler;\n }\n\n public reset(): void {\n if (this._active.length) {\n this.unhook(false);\n }\n this._active = EMPTY_HANDLERS;\n this._ident = 0;\n }\n\n public hook(ident: number, params: IParams): void {\n // always reset leftover handlers\n this.reset();\n this._ident = ident;\n this._active = this._handlers[ident] || EMPTY_HANDLERS;\n if (!this._active.length) {\n this._handlerFb(this._ident, 'HOOK', params);\n } else {\n for (let j = this._active.length - 1; j >= 0; j--) {\n this._active[j].hook(params);\n }\n }\n }\n\n public put(data: Uint32Array, start: number, end: number): void {\n if (!this._active.length) {\n this._handlerFb(this._ident, 'PUT', utf32ToString(data, start, end));\n } else {\n for (let j = this._active.length - 1; j >= 0; j--) {\n this._active[j].put(data, start, end);\n }\n }\n }\n\n public unhook(success: boolean): void {\n if (!this._active.length) {\n this._handlerFb(this._ident, 'UNHOOK', success);\n } else {\n let j = this._active.length - 1;\n for (; j >= 0; j--) {\n if (this._active[j].unhook(success)) {\n break;\n }\n }\n j--;\n // cleanup left over handlers\n for (; j >= 0; j--) {\n this._active[j].unhook(false);\n }\n }\n this._active = EMPTY_HANDLERS;\n this._ident = 0;\n }\n}\n\n// predefine empty params as [0] (ZDM)\nconst EMPTY_PARAMS = new Params();\nEMPTY_PARAMS.addParam(0);\n\n/**\n * Convenient class to create a DCS handler from a single callback function.\n * Note: The payload is currently limited to 50 MB (hardcoded).\n */\nexport class DcsHandler implements IDcsHandler {\n private _data = '';\n private _params: IParams = EMPTY_PARAMS;\n private _hitLimit: boolean = false;\n\n constructor(private _handler: (data: string, params: IParams) => boolean) {}\n\n public hook(params: IParams): void {\n // since we need to preserve params until `unhook`, we have to clone it\n // (only borrowed from parser and spans multiple parser states)\n // perf optimization:\n // clone only, if we have non empty params, otherwise stick with default\n this._params = (params.length > 1 || params.params[0]) ? params.clone() : EMPTY_PARAMS;\n this._data = '';\n this._hitLimit = false;\n }\n\n public put(data: Uint32Array, start: number, end: number): void {\n if (this._hitLimit) {\n return;\n }\n this._data += utf32ToString(data, start, end);\n if (this._data.length > PAYLOAD_LIMIT) {\n this._data = '';\n this._hitLimit = true;\n }\n }\n\n public unhook(success: boolean): boolean {\n let ret = false;\n if (this._hitLimit) {\n ret = false;\n } else if (success) {\n ret = this._handler(this._data, this._params);\n }\n this._params = EMPTY_PARAMS;\n this._data = '';\n this._hitLimit = false;\n return ret;\n }\n}\n","/**\n * Copyright (c) 2018 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IParsingState, IDcsHandler, IEscapeSequenceParser, IParams, IOscHandler, IHandlerCollection, CsiHandlerType, OscFallbackHandlerType, IOscParser, EscHandlerType, IDcsParser, DcsFallbackHandlerType, IFunctionIdentifier, ExecuteFallbackHandlerType, CsiFallbackHandlerType, EscFallbackHandlerType, PrintHandlerType, PrintFallbackHandlerType, ExecuteHandlerType } from 'common/parser/Types';\nimport { ParserState, ParserAction } from 'common/parser/Constants';\nimport { Disposable } from 'common/Lifecycle';\nimport { IDisposable } from 'common/Types';\nimport { fill } from 'common/TypedArrayUtils';\nimport { Params } from 'common/parser/Params';\nimport { OscParser } from 'common/parser/OscParser';\nimport { DcsParser } from 'common/parser/DcsParser';\n\n/**\n * Table values are generated like this:\n * index: currentState << TableValue.INDEX_STATE_SHIFT | charCode\n * value: action << TableValue.TRANSITION_ACTION_SHIFT | nextState\n */\nconst enum TableAccess {\n TRANSITION_ACTION_SHIFT = 4,\n TRANSITION_STATE_MASK = 15,\n INDEX_STATE_SHIFT = 8\n}\n\n/**\n * Transition table for EscapeSequenceParser.\n */\nexport class TransitionTable {\n public table: Uint8Array;\n\n constructor(length: number) {\n this.table = new Uint8Array(length);\n }\n\n /**\n * Set default transition.\n * @param action default action\n * @param next default next state\n */\n public setDefault(action: ParserAction, next: ParserState): void {\n fill(this.table, action << TableAccess.TRANSITION_ACTION_SHIFT | next);\n }\n\n /**\n * Add a transition to the transition table.\n * @param code input character code\n * @param state current parser state\n * @param action parser action to be done\n * @param next next parser state\n */\n public add(code: number, state: ParserState, action: ParserAction, next: ParserState): void {\n this.table[state << TableAccess.INDEX_STATE_SHIFT | code] = action << TableAccess.TRANSITION_ACTION_SHIFT | next;\n }\n\n /**\n * Add transitions for multiple input character codes.\n * @param codes input character code array\n * @param state current parser state\n * @param action parser action to be done\n * @param next next parser state\n */\n public addMany(codes: number[], state: ParserState, action: ParserAction, next: ParserState): void {\n for (let i = 0; i < codes.length; i++) {\n this.table[state << TableAccess.INDEX_STATE_SHIFT | codes[i]] = action << TableAccess.TRANSITION_ACTION_SHIFT | next;\n }\n }\n}\n\n\n// Pseudo-character placeholder for printable non-ascii characters (unicode).\nconst NON_ASCII_PRINTABLE = 0xA0;\n\n\n/**\n * VT500 compatible transition table.\n * Taken from https://vt100.net/emu/dec_ansi_parser.\n */\nexport const VT500_TRANSITION_TABLE = (function (): TransitionTable {\n const table: TransitionTable = new TransitionTable(4095);\n\n // range macro for byte\n const BYTE_VALUES = 256;\n const blueprint = Array.apply(null, Array(BYTE_VALUES)).map((unused: any, i: number) => i);\n const r = (start: number, end: number): number[] => blueprint.slice(start, end);\n\n // Default definitions.\n const PRINTABLES = r(0x20, 0x7f); // 0x20 (SP) included, 0x7F (DEL) excluded\n const EXECUTABLES = r(0x00, 0x18);\n EXECUTABLES.push(0x19);\n EXECUTABLES.push.apply(EXECUTABLES, r(0x1c, 0x20));\n\n const states: number[] = r(ParserState.GROUND, ParserState.DCS_PASSTHROUGH + 1);\n let state: any;\n\n // set default transition\n table.setDefault(ParserAction.ERROR, ParserState.GROUND);\n // printables\n table.addMany(PRINTABLES, ParserState.GROUND, ParserAction.PRINT, ParserState.GROUND);\n // global anywhere rules\n for (state in states) {\n table.addMany([0x18, 0x1a, 0x99, 0x9a], state, ParserAction.EXECUTE, ParserState.GROUND);\n table.addMany(r(0x80, 0x90), state, ParserAction.EXECUTE, ParserState.GROUND);\n table.addMany(r(0x90, 0x98), state, ParserAction.EXECUTE, ParserState.GROUND);\n table.add(0x9c, state, ParserAction.IGNORE, ParserState.GROUND); // ST as terminator\n table.add(0x1b, state, ParserAction.CLEAR, ParserState.ESCAPE); // ESC\n table.add(0x9d, state, ParserAction.OSC_START, ParserState.OSC_STRING); // OSC\n table.addMany([0x98, 0x9e, 0x9f], state, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING);\n table.add(0x9b, state, ParserAction.CLEAR, ParserState.CSI_ENTRY); // CSI\n table.add(0x90, state, ParserAction.CLEAR, ParserState.DCS_ENTRY); // DCS\n }\n // rules for executables and 7f\n table.addMany(EXECUTABLES, ParserState.GROUND, ParserAction.EXECUTE, ParserState.GROUND);\n table.addMany(EXECUTABLES, ParserState.ESCAPE, ParserAction.EXECUTE, ParserState.ESCAPE);\n table.add(0x7f, ParserState.ESCAPE, ParserAction.IGNORE, ParserState.ESCAPE);\n table.addMany(EXECUTABLES, ParserState.OSC_STRING, ParserAction.IGNORE, ParserState.OSC_STRING);\n table.addMany(EXECUTABLES, ParserState.CSI_ENTRY, ParserAction.EXECUTE, ParserState.CSI_ENTRY);\n table.add(0x7f, ParserState.CSI_ENTRY, ParserAction.IGNORE, ParserState.CSI_ENTRY);\n table.addMany(EXECUTABLES, ParserState.CSI_PARAM, ParserAction.EXECUTE, ParserState.CSI_PARAM);\n table.add(0x7f, ParserState.CSI_PARAM, ParserAction.IGNORE, ParserState.CSI_PARAM);\n table.addMany(EXECUTABLES, ParserState.CSI_IGNORE, ParserAction.EXECUTE, ParserState.CSI_IGNORE);\n table.addMany(EXECUTABLES, ParserState.CSI_INTERMEDIATE, ParserAction.EXECUTE, ParserState.CSI_INTERMEDIATE);\n table.add(0x7f, ParserState.CSI_INTERMEDIATE, ParserAction.IGNORE, ParserState.CSI_INTERMEDIATE);\n table.addMany(EXECUTABLES, ParserState.ESCAPE_INTERMEDIATE, ParserAction.EXECUTE, ParserState.ESCAPE_INTERMEDIATE);\n table.add(0x7f, ParserState.ESCAPE_INTERMEDIATE, ParserAction.IGNORE, ParserState.ESCAPE_INTERMEDIATE);\n // osc\n table.add(0x5d, ParserState.ESCAPE, ParserAction.OSC_START, ParserState.OSC_STRING);\n table.addMany(PRINTABLES, ParserState.OSC_STRING, ParserAction.OSC_PUT, ParserState.OSC_STRING);\n table.add(0x7f, ParserState.OSC_STRING, ParserAction.OSC_PUT, ParserState.OSC_STRING);\n table.addMany([0x9c, 0x1b, 0x18, 0x1a, 0x07], ParserState.OSC_STRING, ParserAction.OSC_END, ParserState.GROUND);\n table.addMany(r(0x1c, 0x20), ParserState.OSC_STRING, ParserAction.IGNORE, ParserState.OSC_STRING);\n // sos/pm/apc does nothing\n table.addMany([0x58, 0x5e, 0x5f], ParserState.ESCAPE, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING);\n table.addMany(PRINTABLES, ParserState.SOS_PM_APC_STRING, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING);\n table.addMany(EXECUTABLES, ParserState.SOS_PM_APC_STRING, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING);\n table.add(0x9c, ParserState.SOS_PM_APC_STRING, ParserAction.IGNORE, ParserState.GROUND);\n table.add(0x7f, ParserState.SOS_PM_APC_STRING, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING);\n // csi entries\n table.add(0x5b, ParserState.ESCAPE, ParserAction.CLEAR, ParserState.CSI_ENTRY);\n table.addMany(r(0x40, 0x7f), ParserState.CSI_ENTRY, ParserAction.CSI_DISPATCH, ParserState.GROUND);\n table.addMany(r(0x30, 0x3c), ParserState.CSI_ENTRY, ParserAction.PARAM, ParserState.CSI_PARAM);\n table.addMany([0x3c, 0x3d, 0x3e, 0x3f], ParserState.CSI_ENTRY, ParserAction.COLLECT, ParserState.CSI_PARAM);\n table.addMany(r(0x30, 0x3c), ParserState.CSI_PARAM, ParserAction.PARAM, ParserState.CSI_PARAM);\n table.addMany(r(0x40, 0x7f), ParserState.CSI_PARAM, ParserAction.CSI_DISPATCH, ParserState.GROUND);\n table.addMany([0x3c, 0x3d, 0x3e, 0x3f], ParserState.CSI_PARAM, ParserAction.IGNORE, ParserState.CSI_IGNORE);\n table.addMany(r(0x20, 0x40), ParserState.CSI_IGNORE, ParserAction.IGNORE, ParserState.CSI_IGNORE);\n table.add(0x7f, ParserState.CSI_IGNORE, ParserAction.IGNORE, ParserState.CSI_IGNORE);\n table.addMany(r(0x40, 0x7f), ParserState.CSI_IGNORE, ParserAction.IGNORE, ParserState.GROUND);\n table.addMany(r(0x20, 0x30), ParserState.CSI_ENTRY, ParserAction.COLLECT, ParserState.CSI_INTERMEDIATE);\n table.addMany(r(0x20, 0x30), ParserState.CSI_INTERMEDIATE, ParserAction.COLLECT, ParserState.CSI_INTERMEDIATE);\n table.addMany(r(0x30, 0x40), ParserState.CSI_INTERMEDIATE, ParserAction.IGNORE, ParserState.CSI_IGNORE);\n table.addMany(r(0x40, 0x7f), ParserState.CSI_INTERMEDIATE, ParserAction.CSI_DISPATCH, ParserState.GROUND);\n table.addMany(r(0x20, 0x30), ParserState.CSI_PARAM, ParserAction.COLLECT, ParserState.CSI_INTERMEDIATE);\n // esc_intermediate\n table.addMany(r(0x20, 0x30), ParserState.ESCAPE, ParserAction.COLLECT, ParserState.ESCAPE_INTERMEDIATE);\n table.addMany(r(0x20, 0x30), ParserState.ESCAPE_INTERMEDIATE, ParserAction.COLLECT, ParserState.ESCAPE_INTERMEDIATE);\n table.addMany(r(0x30, 0x7f), ParserState.ESCAPE_INTERMEDIATE, ParserAction.ESC_DISPATCH, ParserState.GROUND);\n table.addMany(r(0x30, 0x50), ParserState.ESCAPE, ParserAction.ESC_DISPATCH, ParserState.GROUND);\n table.addMany(r(0x51, 0x58), ParserState.ESCAPE, ParserAction.ESC_DISPATCH, ParserState.GROUND);\n table.addMany([0x59, 0x5a, 0x5c], ParserState.ESCAPE, ParserAction.ESC_DISPATCH, ParserState.GROUND);\n table.addMany(r(0x60, 0x7f), ParserState.ESCAPE, ParserAction.ESC_DISPATCH, ParserState.GROUND);\n // dcs entry\n table.add(0x50, ParserState.ESCAPE, ParserAction.CLEAR, ParserState.DCS_ENTRY);\n table.addMany(EXECUTABLES, ParserState.DCS_ENTRY, ParserAction.IGNORE, ParserState.DCS_ENTRY);\n table.add(0x7f, ParserState.DCS_ENTRY, ParserAction.IGNORE, ParserState.DCS_ENTRY);\n table.addMany(r(0x1c, 0x20), ParserState.DCS_ENTRY, ParserAction.IGNORE, ParserState.DCS_ENTRY);\n table.addMany(r(0x20, 0x30), ParserState.DCS_ENTRY, ParserAction.COLLECT, ParserState.DCS_INTERMEDIATE);\n table.addMany(r(0x30, 0x3c), ParserState.DCS_ENTRY, ParserAction.PARAM, ParserState.DCS_PARAM);\n table.addMany([0x3c, 0x3d, 0x3e, 0x3f], ParserState.DCS_ENTRY, ParserAction.COLLECT, ParserState.DCS_PARAM);\n table.addMany(EXECUTABLES, ParserState.DCS_IGNORE, ParserAction.IGNORE, ParserState.DCS_IGNORE);\n table.addMany(r(0x20, 0x80), ParserState.DCS_IGNORE, ParserAction.IGNORE, ParserState.DCS_IGNORE);\n table.addMany(r(0x1c, 0x20), ParserState.DCS_IGNORE, ParserAction.IGNORE, ParserState.DCS_IGNORE);\n table.addMany(EXECUTABLES, ParserState.DCS_PARAM, ParserAction.IGNORE, ParserState.DCS_PARAM);\n table.add(0x7f, ParserState.DCS_PARAM, ParserAction.IGNORE, ParserState.DCS_PARAM);\n table.addMany(r(0x1c, 0x20), ParserState.DCS_PARAM, ParserAction.IGNORE, ParserState.DCS_PARAM);\n table.addMany(r(0x30, 0x3c), ParserState.DCS_PARAM, ParserAction.PARAM, ParserState.DCS_PARAM);\n table.addMany([0x3c, 0x3d, 0x3e, 0x3f], ParserState.DCS_PARAM, ParserAction.IGNORE, ParserState.DCS_IGNORE);\n table.addMany(r(0x20, 0x30), ParserState.DCS_PARAM, ParserAction.COLLECT, ParserState.DCS_INTERMEDIATE);\n table.addMany(EXECUTABLES, ParserState.DCS_INTERMEDIATE, ParserAction.IGNORE, ParserState.DCS_INTERMEDIATE);\n table.add(0x7f, ParserState.DCS_INTERMEDIATE, ParserAction.IGNORE, ParserState.DCS_INTERMEDIATE);\n table.addMany(r(0x1c, 0x20), ParserState.DCS_INTERMEDIATE, ParserAction.IGNORE, ParserState.DCS_INTERMEDIATE);\n table.addMany(r(0x20, 0x30), ParserState.DCS_INTERMEDIATE, ParserAction.COLLECT, ParserState.DCS_INTERMEDIATE);\n table.addMany(r(0x30, 0x40), ParserState.DCS_INTERMEDIATE, ParserAction.IGNORE, ParserState.DCS_IGNORE);\n table.addMany(r(0x40, 0x7f), ParserState.DCS_INTERMEDIATE, ParserAction.DCS_HOOK, ParserState.DCS_PASSTHROUGH);\n table.addMany(r(0x40, 0x7f), ParserState.DCS_PARAM, ParserAction.DCS_HOOK, ParserState.DCS_PASSTHROUGH);\n table.addMany(r(0x40, 0x7f), ParserState.DCS_ENTRY, ParserAction.DCS_HOOK, ParserState.DCS_PASSTHROUGH);\n table.addMany(EXECUTABLES, ParserState.DCS_PASSTHROUGH, ParserAction.DCS_PUT, ParserState.DCS_PASSTHROUGH);\n table.addMany(PRINTABLES, ParserState.DCS_PASSTHROUGH, ParserAction.DCS_PUT, ParserState.DCS_PASSTHROUGH);\n table.add(0x7f, ParserState.DCS_PASSTHROUGH, ParserAction.IGNORE, ParserState.DCS_PASSTHROUGH);\n table.addMany([0x1b, 0x9c, 0x18, 0x1a], ParserState.DCS_PASSTHROUGH, ParserAction.DCS_UNHOOK, ParserState.GROUND);\n // special handling of unicode chars\n table.add(NON_ASCII_PRINTABLE, ParserState.GROUND, ParserAction.PRINT, ParserState.GROUND);\n table.add(NON_ASCII_PRINTABLE, ParserState.OSC_STRING, ParserAction.OSC_PUT, ParserState.OSC_STRING);\n table.add(NON_ASCII_PRINTABLE, ParserState.CSI_IGNORE, ParserAction.IGNORE, ParserState.CSI_IGNORE);\n table.add(NON_ASCII_PRINTABLE, ParserState.DCS_IGNORE, ParserAction.IGNORE, ParserState.DCS_IGNORE);\n table.add(NON_ASCII_PRINTABLE, ParserState.DCS_PASSTHROUGH, ParserAction.DCS_PUT, ParserState.DCS_PASSTHROUGH);\n return table;\n})();\n\n\n/**\n * EscapeSequenceParser.\n * This class implements the ANSI/DEC compatible parser described by\n * Paul Williams (https://vt100.net/emu/dec_ansi_parser).\n *\n * To implement custom ANSI compliant escape sequences it is not needed to\n * alter this parser, instead consider registering a custom handler.\n * For non ANSI compliant sequences change the transition table with\n * the optional `transitions` constructor argument and\n * reimplement the `parse` method.\n *\n * This parser is currently hardcoded to operate in ZDM (Zero Default Mode)\n * as suggested by the original parser, thus empty parameters are set to 0.\n * This this is not in line with the latest ECMA-48 specification\n * (ZDM was part of the early specs and got completely removed later on).\n *\n * Other than the original parser from vt100.net this parser supports\n * sub parameters in digital parameters separated by colons. Empty sub parameters\n * are set to -1 (no ZDM for sub parameters).\n *\n * About prefix and intermediate bytes:\n * This parser follows the assumptions of the vt100.net parser with these restrictions:\n * - only one prefix byte is allowed as first parameter byte, byte range 0x3c .. 0x3f\n * - max. two intermediates are respected, byte range 0x20 .. 0x2f\n * Note that this is not in line with ECMA-48 which does not limit either of those.\n * Furthermore ECMA-48 allows the prefix byte range at any param byte position. Currently\n * there are no known sequences that follow the broader definition of the specification.\n *\n * TODO: implement error recovery hook via error handler return values\n */\nexport class EscapeSequenceParser extends Disposable implements IEscapeSequenceParser {\n public initialState: number;\n public currentState: number;\n public precedingCodepoint: number;\n\n // buffers over several parse calls\n protected _params: Params;\n protected _collect: number;\n\n // handler lookup containers\n protected _printHandler: PrintHandlerType;\n protected _executeHandlers: {[flag: number]: ExecuteHandlerType};\n protected _csiHandlers: IHandlerCollection;\n protected _escHandlers: IHandlerCollection;\n protected _oscParser: IOscParser;\n protected _dcsParser: IDcsParser;\n protected _errorHandler: (state: IParsingState) => IParsingState;\n\n // fallback handlers\n protected _printHandlerFb: PrintFallbackHandlerType;\n protected _executeHandlerFb: ExecuteFallbackHandlerType;\n protected _csiHandlerFb: CsiFallbackHandlerType;\n protected _escHandlerFb: EscFallbackHandlerType;\n protected _errorHandlerFb: (state: IParsingState) => IParsingState;\n\n constructor(\n protected readonly _transitions: TransitionTable = VT500_TRANSITION_TABLE\n ) {\n super();\n\n this.initialState = ParserState.GROUND;\n this.currentState = this.initialState;\n this._params = new Params(); // defaults to 32 storable params/subparams\n this._params.addParam(0); // ZDM\n this._collect = 0;\n this.precedingCodepoint = 0;\n\n // set default fallback handlers and handler lookup containers\n this._printHandlerFb = (data, start, end): void => { };\n this._executeHandlerFb = (code: number): void => { };\n this._csiHandlerFb = (ident: number, params: IParams): void => { };\n this._escHandlerFb = (ident: number): void => { };\n this._errorHandlerFb = (state: IParsingState): IParsingState => state;\n this._printHandler = this._printHandlerFb;\n this._executeHandlers = Object.create(null);\n this._csiHandlers = Object.create(null);\n this._escHandlers = Object.create(null);\n this._oscParser = new OscParser();\n this._dcsParser = new DcsParser();\n this._errorHandler = this._errorHandlerFb;\n\n // swallow 7bit ST (ESC+\\)\n this.registerEscHandler({final: '\\\\'}, () => true);\n }\n\n protected _identifier(id: IFunctionIdentifier, finalRange: number[] = [0x40, 0x7e]): number {\n let res = 0;\n if (id.prefix) {\n if (id.prefix.length > 1) {\n throw new Error('only one byte as prefix supported');\n }\n res = id.prefix.charCodeAt(0);\n if (res && 0x3c > res || res > 0x3f) {\n throw new Error('prefix must be in range 0x3c .. 0x3f');\n }\n }\n if (id.intermediates) {\n if (id.intermediates.length > 2) {\n throw new Error('only two bytes as intermediates are supported');\n }\n for (let i = 0; i < id.intermediates.length; ++i) {\n const intermediate = id.intermediates.charCodeAt(i);\n if (0x20 > intermediate || intermediate > 0x2f) {\n throw new Error('intermediate must be in range 0x20 .. 0x2f');\n }\n res <<= 8;\n res |= intermediate;\n }\n }\n if (id.final.length !== 1) {\n throw new Error('final must be a single byte');\n }\n const finalCode = id.final.charCodeAt(0);\n if (finalRange[0] > finalCode || finalCode > finalRange[1]) {\n throw new Error(`final must be in range ${finalRange[0]} .. ${finalRange[1]}`);\n }\n res <<= 8;\n res |= finalCode;\n\n return res;\n }\n\n public identToString(ident: number): string {\n const res: string[] = [];\n while (ident) {\n res.push(String.fromCharCode(ident & 0xFF));\n ident >>= 8;\n }\n return res.reverse().join('');\n }\n\n public dispose(): void {\n this._csiHandlers = Object.create(null);\n this._executeHandlers = Object.create(null);\n this._escHandlers = Object.create(null);\n this._oscParser.dispose();\n this._dcsParser.dispose();\n }\n\n public setPrintHandler(handler: PrintHandlerType): void {\n this._printHandler = handler;\n }\n public clearPrintHandler(): void {\n this._printHandler = this._printHandlerFb;\n }\n\n public registerEscHandler(id: IFunctionIdentifier, handler: EscHandlerType): IDisposable {\n const ident = this._identifier(id, [0x30, 0x7e]);\n if (this._escHandlers[ident] === undefined) {\n this._escHandlers[ident] = [];\n }\n const handlerList = this._escHandlers[ident];\n handlerList.push(handler);\n return {\n dispose: () => {\n const handlerIndex = handlerList.indexOf(handler);\n if (handlerIndex !== -1) {\n handlerList.splice(handlerIndex, 1);\n }\n }\n };\n }\n public clearEscHandler(id: IFunctionIdentifier): void {\n if (this._escHandlers[this._identifier(id, [0x30, 0x7e])]) delete this._escHandlers[this._identifier(id, [0x30, 0x7e])];\n }\n public setEscHandlerFallback(handler: EscFallbackHandlerType): void {\n this._escHandlerFb = handler;\n }\n\n public setExecuteHandler(flag: string, handler: ExecuteHandlerType): void {\n this._executeHandlers[flag.charCodeAt(0)] = handler;\n }\n public clearExecuteHandler(flag: string): void {\n if (this._executeHandlers[flag.charCodeAt(0)]) delete this._executeHandlers[flag.charCodeAt(0)];\n }\n public setExecuteHandlerFallback(handler: ExecuteFallbackHandlerType): void {\n this._executeHandlerFb = handler;\n }\n\n public registerCsiHandler(id: IFunctionIdentifier, handler: CsiHandlerType): IDisposable {\n const ident = this._identifier(id);\n if (this._csiHandlers[ident] === undefined) {\n this._csiHandlers[ident] = [];\n }\n const handlerList = this._csiHandlers[ident];\n handlerList.push(handler);\n return {\n dispose: () => {\n const handlerIndex = handlerList.indexOf(handler);\n if (handlerIndex !== -1) {\n handlerList.splice(handlerIndex, 1);\n }\n }\n };\n }\n public clearCsiHandler(id: IFunctionIdentifier): void {\n if (this._csiHandlers[this._identifier(id)]) delete this._csiHandlers[this._identifier(id)];\n }\n public setCsiHandlerFallback(callback: (ident: number, params: IParams) => void): void {\n this._csiHandlerFb = callback;\n }\n\n public registerDcsHandler(id: IFunctionIdentifier, handler: IDcsHandler): IDisposable {\n return this._dcsParser.registerHandler(this._identifier(id), handler);\n }\n public clearDcsHandler(id: IFunctionIdentifier): void {\n this._dcsParser.clearHandler(this._identifier(id));\n }\n public setDcsHandlerFallback(handler: DcsFallbackHandlerType): void {\n this._dcsParser.setHandlerFallback(handler);\n }\n\n public registerOscHandler(ident: number, handler: IOscHandler): IDisposable {\n return this._oscParser.registerHandler(ident, handler);\n }\n public clearOscHandler(ident: number): void {\n this._oscParser.clearHandler(ident);\n }\n public setOscHandlerFallback(handler: OscFallbackHandlerType): void {\n this._oscParser.setHandlerFallback(handler);\n }\n\n public setErrorHandler(callback: (state: IParsingState) => IParsingState): void {\n this._errorHandler = callback;\n }\n public clearErrorHandler(): void {\n this._errorHandler = this._errorHandlerFb;\n }\n\n public reset(): void {\n this.currentState = this.initialState;\n this._oscParser.reset();\n this._dcsParser.reset();\n this._params.reset();\n this._params.addParam(0); // ZDM\n this._collect = 0;\n this.precedingCodepoint = 0;\n }\n\n\n\n /**\n * Parse UTF32 codepoints in `data` up to `length`.\n *\n * Note: For several actions with high data load the parsing is optimized\n * by using local read ahead loops with hardcoded conditions to\n * avoid costly table lookups. Make sure that any change of table values\n * will be reflected in the loop conditions as well and vice versa.\n * Affected states/actions:\n * - GROUND:PRINT\n * - CSI_PARAM:PARAM\n * - DCS_PARAM:PARAM\n * - OSC_STRING:OSC_PUT\n * - DCS_PASSTHROUGH:DCS_PUT\n */\n public parse(data: Uint32Array, length: number): void {\n let code = 0;\n let transition = 0;\n let currentState = this.currentState;\n const osc = this._oscParser;\n const dcs = this._dcsParser;\n let collect = this._collect;\n const params = this._params;\n const table: Uint8Array = this._transitions.table;\n\n // process input string\n for (let i = 0; i < length; ++i) {\n code = data[i];\n\n // normal transition & action lookup\n transition = table[currentState << TableAccess.INDEX_STATE_SHIFT | (code < 0xa0 ? code : NON_ASCII_PRINTABLE)];\n switch (transition >> TableAccess.TRANSITION_ACTION_SHIFT) {\n case ParserAction.PRINT:\n // read ahead with loop unrolling\n // Note: 0x20 (SP) is included, 0x7F (DEL) is excluded\n for (let j = i + 1; ; ++j) {\n if (j >= length || (code = data[j]) < 0x20 || (code > 0x7e && code < NON_ASCII_PRINTABLE)) {\n this._printHandler(data, i, j);\n i = j - 1;\n break;\n }\n if (++j >= length || (code = data[j]) < 0x20 || (code > 0x7e && code < NON_ASCII_PRINTABLE)) {\n this._printHandler(data, i, j);\n i = j - 1;\n break;\n }\n if (++j >= length || (code = data[j]) < 0x20 || (code > 0x7e && code < NON_ASCII_PRINTABLE)) {\n this._printHandler(data, i, j);\n i = j - 1;\n break;\n }\n if (++j >= length || (code = data[j]) < 0x20 || (code > 0x7e && code < NON_ASCII_PRINTABLE)) {\n this._printHandler(data, i, j);\n i = j - 1;\n break;\n }\n }\n break;\n case ParserAction.EXECUTE:\n if (this._executeHandlers[code]) this._executeHandlers[code]();\n else this._executeHandlerFb(code);\n this.precedingCodepoint = 0;\n break;\n case ParserAction.IGNORE:\n break;\n case ParserAction.ERROR:\n const inject: IParsingState = this._errorHandler(\n {\n position: i,\n code,\n currentState,\n collect,\n params,\n abort: false\n });\n if (inject.abort) return;\n // inject values: currently not implemented\n break;\n case ParserAction.CSI_DISPATCH:\n // Trigger CSI Handler\n const handlers = this._csiHandlers[collect << 8 | code];\n let j = handlers ? handlers.length - 1 : -1;\n for (; j >= 0; j--) {\n // true means success and to stop bubbling\n if (handlers[j](params)) {\n break;\n }\n }\n if (j < 0) {\n this._csiHandlerFb(collect << 8 | code, params);\n }\n this.precedingCodepoint = 0;\n break;\n case ParserAction.PARAM:\n // inner loop: digits (0x30 - 0x39) and ; (0x3b) and : (0x3a)\n do {\n switch (code) {\n case 0x3b:\n params.addParam(0); // ZDM\n break;\n case 0x3a:\n params.addSubParam(-1);\n break;\n default: // 0x30 - 0x39\n params.addDigit(code - 48);\n }\n } while (++i < length && (code = data[i]) > 0x2f && code < 0x3c);\n i--;\n break;\n case ParserAction.COLLECT:\n collect <<= 8;\n collect |= code;\n break;\n case ParserAction.ESC_DISPATCH:\n const handlersEsc = this._escHandlers[collect << 8 | code];\n let jj = handlersEsc ? handlersEsc.length - 1 : -1;\n for (; jj >= 0; jj--) {\n // true means success and to stop bubbling\n if (handlersEsc[jj]()) {\n break;\n }\n }\n if (jj < 0) {\n this._escHandlerFb(collect << 8 | code);\n }\n this.precedingCodepoint = 0;\n break;\n case ParserAction.CLEAR:\n params.reset();\n params.addParam(0); // ZDM\n collect = 0;\n break;\n case ParserAction.DCS_HOOK:\n dcs.hook(collect << 8 | code, params);\n break;\n case ParserAction.DCS_PUT:\n // inner loop - exit DCS_PUT: 0x18, 0x1a, 0x1b, 0x7f, 0x80 - 0x9f\n // unhook triggered by: 0x1b, 0x9c (success) and 0x18, 0x1a (abort)\n for (let j = i + 1; ; ++j) {\n if (j >= length || (code = data[j]) === 0x18 || code === 0x1a || code === 0x1b || (code > 0x7f && code < NON_ASCII_PRINTABLE)) {\n dcs.put(data, i, j);\n i = j - 1;\n break;\n }\n }\n break;\n case ParserAction.DCS_UNHOOK:\n dcs.unhook(code !== 0x18 && code !== 0x1a);\n if (code === 0x1b) transition |= ParserState.ESCAPE;\n params.reset();\n params.addParam(0); // ZDM\n collect = 0;\n this.precedingCodepoint = 0;\n break;\n case ParserAction.OSC_START:\n osc.start();\n break;\n case ParserAction.OSC_PUT:\n // inner loop: 0x20 (SP) included, 0x7F (DEL) included\n for (let j = i + 1; ; j++) {\n if (j >= length || (code = data[j]) < 0x20 || (code > 0x7f && code < NON_ASCII_PRINTABLE)) {\n osc.put(data, i, j);\n i = j - 1;\n break;\n }\n }\n break;\n case ParserAction.OSC_END:\n osc.end(code !== 0x18 && code !== 0x1a);\n if (code === 0x1b) transition |= ParserState.ESCAPE;\n params.reset();\n params.addParam(0); // ZDM\n collect = 0;\n this.precedingCodepoint = 0;\n break;\n }\n currentState = transition & TableAccess.TRANSITION_STATE_MASK;\n }\n\n // save collected intermediates\n this._collect = collect;\n\n // save state\n this.currentState = currentState;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IOscHandler, IHandlerCollection, OscFallbackHandlerType, IOscParser } from 'common/parser/Types';\nimport { OscState, PAYLOAD_LIMIT } from 'common/parser/Constants';\nimport { utf32ToString } from 'common/input/TextDecoder';\nimport { IDisposable } from 'common/Types';\n\nconst EMPTY_HANDLERS: IOscHandler[] = [];\n\nexport class OscParser implements IOscParser {\n private _state = OscState.START;\n private _active = EMPTY_HANDLERS;\n private _id = -1;\n private _handlers: IHandlerCollection = Object.create(null);\n private _handlerFb: OscFallbackHandlerType = () => { };\n\n public registerHandler(ident: number, handler: IOscHandler): IDisposable {\n if (this._handlers[ident] === undefined) {\n this._handlers[ident] = [];\n }\n const handlerList = this._handlers[ident];\n handlerList.push(handler);\n return {\n dispose: () => {\n const handlerIndex = handlerList.indexOf(handler);\n if (handlerIndex !== -1) {\n handlerList.splice(handlerIndex, 1);\n }\n }\n };\n }\n public clearHandler(ident: number): void {\n if (this._handlers[ident]) delete this._handlers[ident];\n }\n public setHandlerFallback(handler: OscFallbackHandlerType): void {\n this._handlerFb = handler;\n }\n\n public dispose(): void {\n this._handlers = Object.create(null);\n this._handlerFb = () => {};\n this._active = EMPTY_HANDLERS;\n }\n\n public reset(): void {\n // cleanup handlers if payload was already sent\n if (this._state === OscState.PAYLOAD) {\n this.end(false);\n }\n this._active = EMPTY_HANDLERS;\n this._id = -1;\n this._state = OscState.START;\n }\n\n private _start(): void {\n this._active = this._handlers[this._id] || EMPTY_HANDLERS;\n if (!this._active.length) {\n this._handlerFb(this._id, 'START');\n } else {\n for (let j = this._active.length - 1; j >= 0; j--) {\n this._active[j].start();\n }\n }\n }\n\n private _put(data: Uint32Array, start: number, end: number): void {\n if (!this._active.length) {\n this._handlerFb(this._id, 'PUT', utf32ToString(data, start, end));\n } else {\n for (let j = this._active.length - 1; j >= 0; j--) {\n this._active[j].put(data, start, end);\n }\n }\n }\n\n private _end(success: boolean): void {\n // other than the old code we always have to call .end\n // to keep the bubbling we use `success` to indicate\n // whether a handler should execute\n if (!this._active.length) {\n this._handlerFb(this._id, 'END', success);\n } else {\n let j = this._active.length - 1;\n for (; j >= 0; j--) {\n if (this._active[j].end(success)) {\n break;\n }\n }\n j--;\n // cleanup left over handlers\n for (; j >= 0; j--) {\n this._active[j].end(false);\n }\n }\n }\n\n public start(): void {\n // always reset leftover handlers\n this.reset();\n this._state = OscState.ID;\n }\n\n /**\n * Put data to current OSC command.\n * Expects the identifier of the OSC command in the form\n * OSC id ; payload ST/BEL\n * Payload chunks are not further processed and get\n * directly passed to the handlers.\n */\n public put(data: Uint32Array, start: number, end: number): void {\n if (this._state === OscState.ABORT) {\n return;\n }\n if (this._state === OscState.ID) {\n while (start < end) {\n const code = data[start++];\n if (code === 0x3b) {\n this._state = OscState.PAYLOAD;\n this._start();\n break;\n }\n if (code < 0x30 || 0x39 < code) {\n this._state = OscState.ABORT;\n return;\n }\n if (this._id === -1) {\n this._id = 0;\n }\n this._id = this._id * 10 + code - 48;\n }\n }\n if (this._state === OscState.PAYLOAD && end - start > 0) {\n this._put(data, start, end);\n }\n }\n\n /**\n * Indicates end of an OSC command.\n * Whether the OSC got aborted or finished normally\n * is indicated by `success`.\n */\n public end(success: boolean): void {\n if (this._state === OscState.START) {\n return;\n }\n // do nothing if command was faulty\n if (this._state !== OscState.ABORT) {\n // if we are still in ID state and get an early end\n // means that the command has no payload thus we still have\n // to announce START and send END right after\n if (this._state === OscState.ID) {\n this._start();\n }\n this._end(success);\n }\n this._active = EMPTY_HANDLERS;\n this._id = -1;\n this._state = OscState.START;\n }\n}\n\n/**\n * Convenient class to allow attaching string based handler functions\n * as OSC handlers.\n */\nexport class OscHandler implements IOscHandler {\n private _data = '';\n private _hitLimit: boolean = false;\n\n constructor(private _handler: (data: string) => boolean) {}\n\n public start(): void {\n this._data = '';\n this._hitLimit = false;\n }\n\n public put(data: Uint32Array, start: number, end: number): void {\n if (this._hitLimit) {\n return;\n }\n this._data += utf32ToString(data, start, end);\n if (this._data.length > PAYLOAD_LIMIT) {\n this._data = '';\n this._hitLimit = true;\n }\n }\n\n public end(success: boolean): boolean {\n let ret = false;\n if (this._hitLimit) {\n ret = false;\n } else if (success) {\n ret = this._handler(this._data);\n }\n this._data = '';\n this._hitLimit = false;\n return ret;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\nimport { IParams, ParamsArray } from 'common/parser/Types';\n\n// max value supported for a single param/subparam (clamped to positive int32 range)\nconst MAX_VALUE = 0x7FFFFFFF;\n// max allowed subparams for a single sequence (hardcoded limitation)\nconst MAX_SUBPARAMS = 256;\n\n/**\n * Params storage class.\n * This type is used by the parser to accumulate sequence parameters and sub parameters\n * and transmit them to the input handler actions.\n *\n * NOTES:\n * - params object for action handlers is borrowed, use `.toArray` or `.clone` to get a copy\n * - never read beyond `params.length - 1` (likely to contain arbitrary data)\n * - `.getSubParams` returns a borrowed typed array, use `.getSubParamsAll` for cloned sub params\n * - hardcoded limitations:\n * - max. value for a single (sub) param is 2^31 - 1 (greater values are clamped to that)\n * - max. 256 sub params possible\n * - negative values are not allowed beside -1 (placeholder for default value)\n *\n * About ZDM (Zero Default Mode):\n * ZDM is not orchestrated by this class. If the parser is in ZDM,\n * it should add 0 for empty params, otherwise -1. This does not apply\n * to subparams, empty subparams should always be added with -1.\n */\nexport class Params implements IParams {\n // params store and length\n public params: Int32Array;\n public length: number;\n\n // sub params store and length\n protected _subParams: Int32Array;\n protected _subParamsLength: number;\n\n // sub params offsets from param: param idx --> [start, end] offset\n private _subParamsIdx: Uint16Array;\n private _rejectDigits: boolean;\n private _rejectSubDigits: boolean;\n private _digitIsSub: boolean;\n\n /**\n * Create a `Params` type from JS array representation.\n */\n public static fromArray(values: ParamsArray): Params {\n const params = new Params();\n if (!values.length) {\n return params;\n }\n // skip leading sub params\n for (let i = (values[0] instanceof Array) ? 1 : 0; i < values.length; ++i) {\n const value = values[i];\n if (value instanceof Array) {\n for (let k = 0; k < value.length; ++k) {\n params.addSubParam(value[k]);\n }\n } else {\n params.addParam(value);\n }\n }\n return params;\n }\n\n /**\n * @param maxLength max length of storable parameters\n * @param maxSubParamsLength max length of storable sub parameters\n */\n constructor(public maxLength: number = 32, public maxSubParamsLength: number = 32) {\n if (maxSubParamsLength > MAX_SUBPARAMS) {\n throw new Error('maxSubParamsLength must not be greater than 256');\n }\n this.params = new Int32Array(maxLength);\n this.length = 0;\n this._subParams = new Int32Array(maxSubParamsLength);\n this._subParamsLength = 0;\n this._subParamsIdx = new Uint16Array(maxLength);\n this._rejectDigits = false;\n this._rejectSubDigits = false;\n this._digitIsSub = false;\n }\n\n /**\n * Clone object.\n */\n public clone(): Params {\n const newParams = new Params(this.maxLength, this.maxSubParamsLength);\n newParams.params.set(this.params);\n newParams.length = this.length;\n newParams._subParams.set(this._subParams);\n newParams._subParamsLength = this._subParamsLength;\n newParams._subParamsIdx.set(this._subParamsIdx);\n newParams._rejectDigits = this._rejectDigits;\n newParams._rejectSubDigits = this._rejectSubDigits;\n newParams._digitIsSub = this._digitIsSub;\n return newParams;\n }\n\n /**\n * Get a JS array representation of the current parameters and sub parameters.\n * The array is structured as follows:\n * sequence: \"1;2:3:4;5::6\"\n * array : [1, 2, [3, 4], 5, [-1, 6]]\n */\n public toArray(): ParamsArray {\n const res: ParamsArray = [];\n for (let i = 0; i < this.length; ++i) {\n res.push(this.params[i]);\n const start = this._subParamsIdx[i] >> 8;\n const end = this._subParamsIdx[i] & 0xFF;\n if (end - start > 0) {\n res.push(Array.prototype.slice.call(this._subParams, start, end));\n }\n }\n return res;\n }\n\n /**\n * Reset to initial empty state.\n */\n public reset(): void {\n this.length = 0;\n this._subParamsLength = 0;\n this._rejectDigits = false;\n this._rejectSubDigits = false;\n this._digitIsSub = false;\n }\n\n /**\n * Add a parameter value.\n * `Params` only stores up to `maxLength` parameters, any later\n * parameter will be ignored.\n * Note: VT devices only stored up to 16 values, xterm seems to\n * store up to 30.\n */\n public addParam(value: number): void {\n this._digitIsSub = false;\n if (this.length >= this.maxLength) {\n this._rejectDigits = true;\n return;\n }\n if (value < -1) {\n throw new Error('values lesser than -1 are not allowed');\n }\n this._subParamsIdx[this.length] = this._subParamsLength << 8 | this._subParamsLength;\n this.params[this.length++] = value > MAX_VALUE ? MAX_VALUE : value;\n }\n\n /**\n * Add a sub parameter value.\n * The sub parameter is automatically associated with the last parameter value.\n * Thus it is not possible to add a subparameter without any parameter added yet.\n * `Params` only stores up to `subParamsLength` sub parameters, any later\n * sub parameter will be ignored.\n */\n public addSubParam(value: number): void {\n this._digitIsSub = true;\n if (!this.length) {\n return;\n }\n if (this._rejectDigits || this._subParamsLength >= this.maxSubParamsLength) {\n this._rejectSubDigits = true;\n return;\n }\n if (value < -1) {\n throw new Error('values lesser than -1 are not allowed');\n }\n this._subParams[this._subParamsLength++] = value > MAX_VALUE ? MAX_VALUE : value;\n this._subParamsIdx[this.length - 1]++;\n }\n\n /**\n * Whether parameter at index `idx` has sub parameters.\n */\n public hasSubParams(idx: number): boolean {\n return ((this._subParamsIdx[idx] & 0xFF) - (this._subParamsIdx[idx] >> 8) > 0);\n }\n\n /**\n * Return sub parameters for parameter at index `idx`.\n * Note: The values are borrowed, thus you need to copy\n * the values if you need to hold them in nonlocal scope.\n */\n public getSubParams(idx: number): Int32Array | null {\n const start = this._subParamsIdx[idx] >> 8;\n const end = this._subParamsIdx[idx] & 0xFF;\n if (end - start > 0) {\n return this._subParams.subarray(start, end);\n }\n return null;\n }\n\n /**\n * Return all sub parameters as {idx: subparams} mapping.\n * Note: The values are not borrowed.\n */\n public getSubParamsAll(): {[idx: number]: Int32Array} {\n const result: {[idx: number]: Int32Array} = {};\n for (let i = 0; i < this.length; ++i) {\n const start = this._subParamsIdx[i] >> 8;\n const end = this._subParamsIdx[i] & 0xFF;\n if (end - start > 0) {\n result[i] = this._subParams.slice(start, end);\n }\n }\n return result;\n }\n\n /**\n * Add a single digit value to current parameter.\n * This is used by the parser to account digits on a char by char basis.\n */\n public addDigit(value: number): void {\n let length;\n if (this._rejectDigits\n || !(length = this._digitIsSub ? this._subParamsLength : this.length)\n || (this._digitIsSub && this._rejectSubDigits)\n ) {\n return;\n }\n\n const store = this._digitIsSub ? this._subParams : this.params;\n const cur = store[length - 1];\n store[length - 1] = ~cur ? Math.min(cur * 10 + value, MAX_VALUE) : value;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IBufferService, IOptionsService } from 'common/services/Services';\nimport { BufferSet } from 'common/buffer/BufferSet';\nimport { IBufferSet, IBuffer } from 'common/buffer/Types';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { Disposable } from 'common/Lifecycle';\n\nexport const MINIMUM_COLS = 2; // Less than 2 can mess with wide chars\nexport const MINIMUM_ROWS = 1;\n\nexport class BufferService extends Disposable implements IBufferService {\n public serviceBrand: any;\n\n public cols: number;\n public rows: number;\n public buffers: IBufferSet;\n /** Whether the user is scrolling (locks the scroll position) */\n public isUserScrolling: boolean = false;\n\n private _onResize = new EventEmitter<{ cols: number, rows: number }>();\n public get onResize(): IEvent<{ cols: number, rows: number }> { return this._onResize.event; }\n\n public get buffer(): IBuffer { return this.buffers.active; }\n\n constructor(\n @IOptionsService private _optionsService: IOptionsService\n ) {\n super();\n this.cols = Math.max(_optionsService.options.cols, MINIMUM_COLS);\n this.rows = Math.max(_optionsService.options.rows, MINIMUM_ROWS);\n this.buffers = new BufferSet(_optionsService, this);\n }\n\n public dispose(): void {\n super.dispose();\n this.buffers.dispose();\n }\n\n public resize(cols: number, rows: number): void {\n this.cols = cols;\n this.rows = rows;\n this.buffers.resize(cols, rows);\n this.buffers.setupTabStops(this.cols);\n this._onResize.fire({ cols, rows });\n }\n\n public reset(): void {\n this.buffers.reset();\n this.isUserScrolling = false;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ICharsetService } from 'common/services/Services';\nimport { ICharset } from 'common/Types';\n\nexport class CharsetService implements ICharsetService {\n public serviceBrand: any;\n\n public charset: ICharset | undefined;\n public glevel: number = 0;\n\n private _charsets: (ICharset | undefined)[] = [];\n\n public reset(): void {\n this.charset = undefined;\n this._charsets = [];\n this.glevel = 0;\n }\n\n public setgLevel(g: number): void {\n this.glevel = g;\n this.charset = this._charsets[g];\n }\n\n public setgCharset(g: number, charset: ICharset | undefined): void {\n this._charsets[g] = charset;\n if (this.glevel === g) {\n this.charset = charset;\n }\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\nimport { IBufferService, ICoreService, ICoreMouseService } from 'common/services/Services';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { ICoreMouseProtocol, ICoreMouseEvent, CoreMouseEncoding, CoreMouseEventType, CoreMouseButton, CoreMouseAction } from 'common/Types';\n\n/**\n * Supported default protocols.\n */\nconst DEFAULT_PROTOCOLS: {[key: string]: ICoreMouseProtocol} = {\n /**\n * NONE\n * Events: none\n * Modifiers: none\n */\n NONE: {\n events: CoreMouseEventType.NONE,\n restrict: () => false\n },\n /**\n * X10\n * Events: mousedown\n * Modifiers: none\n */\n X10: {\n events: CoreMouseEventType.DOWN,\n restrict: (e: ICoreMouseEvent) => {\n // no wheel, no move, no up\n if (e.button === CoreMouseButton.WHEEL || e.action !== CoreMouseAction.DOWN) {\n return false;\n }\n // no modifiers\n e.ctrl = false;\n e.alt = false;\n e.shift = false;\n return true;\n }\n },\n /**\n * VT200\n * Events: mousedown / mouseup / wheel\n * Modifiers: all\n */\n VT200: {\n events: CoreMouseEventType.DOWN | CoreMouseEventType.UP | CoreMouseEventType.WHEEL,\n restrict: (e: ICoreMouseEvent) => {\n // no move\n if (e.action === CoreMouseAction.MOVE) {\n return false;\n }\n return true;\n }\n },\n /**\n * DRAG\n * Events: mousedown / mouseup / wheel / mousedrag\n * Modifiers: all\n */\n DRAG: {\n events: CoreMouseEventType.DOWN | CoreMouseEventType.UP | CoreMouseEventType.WHEEL | CoreMouseEventType.DRAG,\n restrict: (e: ICoreMouseEvent) => {\n // no move without button\n if (e.action === CoreMouseAction.MOVE && e.button === CoreMouseButton.NONE) {\n return false;\n }\n return true;\n }\n },\n /**\n * ANY\n * Events: all mouse related events\n * Modifiers: all\n */\n ANY: {\n events:\n CoreMouseEventType.DOWN | CoreMouseEventType.UP | CoreMouseEventType.WHEEL\n | CoreMouseEventType.DRAG | CoreMouseEventType.MOVE,\n restrict: (e: ICoreMouseEvent) => true\n }\n};\n\nconst enum Modifiers {\n SHIFT = 4,\n ALT = 8,\n CTRL = 16\n}\n\n// helper for default encoders to generate the event code.\nfunction eventCode(e: ICoreMouseEvent, isSGR: boolean): number {\n let code = (e.ctrl ? Modifiers.CTRL : 0) | (e.shift ? Modifiers.SHIFT : 0) | (e.alt ? Modifiers.ALT : 0);\n if (e.button === CoreMouseButton.WHEEL) {\n code |= 64;\n code |= e.action;\n } else {\n code |= e.button & 3;\n if (e.button & 4) {\n code |= 64;\n }\n if (e.button & 8) {\n code |= 128;\n }\n if (e.action === CoreMouseAction.MOVE) {\n code |= CoreMouseAction.MOVE;\n } else if (e.action === CoreMouseAction.UP && !isSGR) {\n // special case - only SGR can report button on release\n // all others have to go with NONE\n code |= CoreMouseButton.NONE;\n }\n }\n return code;\n}\n\nconst S = String.fromCharCode;\n\n/**\n * Supported default encodings.\n */\nconst DEFAULT_ENCODINGS: {[key: string]: CoreMouseEncoding} = {\n /**\n * DEFAULT - CSI M Pb Px Py\n * Single byte encoding for coords and event code.\n * Can encode values up to 223 (1-based).\n */\n DEFAULT: (e: ICoreMouseEvent) => {\n const params = [eventCode(e, false) + 32, e.col + 32, e.row + 32];\n // supress mouse report if we exceed addressible range\n // Note this is handled differently by emulators\n // - xterm: sends 0;0 coords instead\n // - vte, konsole: no report\n if (params[0] > 255 || params[1] > 255 || params[2] > 255) {\n return '';\n }\n return `\\x1b[M${S(params[0])}${S(params[1])}${S(params[2])}`;\n },\n /**\n * SGR - CSI < Pb ; Px ; Py M|m\n * No encoding limitation.\n * Can report button on release and works with a well formed sequence.\n */\n SGR: (e: ICoreMouseEvent) => {\n const final = (e.action === CoreMouseAction.UP && e.button !== CoreMouseButton.WHEEL) ? 'm' : 'M';\n return `\\x1b[<${eventCode(e, true)};${e.col};${e.row}${final}`;\n }\n};\n\n/**\n * CoreMouseService\n *\n * Provides mouse tracking reports with different protocols and encodings.\n * - protocols: NONE (default), X10, VT200, DRAG, ANY\n * - encodings: DEFAULT, SGR (UTF8, URXVT removed in #2507)\n *\n * Custom protocols/encodings can be added by `addProtocol` / `addEncoding`.\n * To activate a protocol/encoding, set `activeProtocol` / `activeEncoding`.\n * Switching a protocol will send a notification event `onProtocolChange`\n * with a list of needed events to track.\n *\n * The service handles the mouse tracking state and decides whether to send\n * a tracking report to the backend based on protocol and encoding limitations.\n * To send a mouse event call `triggerMouseEvent`.\n */\nexport class CoreMouseService implements ICoreMouseService {\n private _protocols: {[name: string]: ICoreMouseProtocol} = {};\n private _encodings: {[name: string]: CoreMouseEncoding} = {};\n private _activeProtocol: string = '';\n private _activeEncoding: string = '';\n private _onProtocolChange = new EventEmitter();\n private _lastEvent: ICoreMouseEvent | null = null;\n\n constructor(\n @IBufferService private readonly _bufferService: IBufferService,\n @ICoreService private readonly _coreService: ICoreService\n ) {\n // register default protocols and encodings\n for (const name of Object.keys(DEFAULT_PROTOCOLS)) this.addProtocol(name, DEFAULT_PROTOCOLS[name]);\n for (const name of Object.keys(DEFAULT_ENCODINGS)) this.addEncoding(name, DEFAULT_ENCODINGS[name]);\n // call reset to set defaults\n this.reset();\n }\n\n public addProtocol(name: string, protocol: ICoreMouseProtocol): void {\n this._protocols[name] = protocol;\n }\n\n public addEncoding(name: string, encoding: CoreMouseEncoding): void {\n this._encodings[name] = encoding;\n }\n\n public get activeProtocol(): string {\n return this._activeProtocol;\n }\n\n public get areMouseEventsActive(): boolean {\n return this._protocols[this._activeProtocol].events !== 0;\n }\n\n public set activeProtocol(name: string) {\n if (!this._protocols[name]) {\n throw new Error(`unknown protocol \"${name}\"`);\n }\n this._activeProtocol = name;\n this._onProtocolChange.fire(this._protocols[name].events);\n }\n\n public get activeEncoding(): string {\n return this._activeEncoding;\n }\n\n public set activeEncoding(name: string) {\n if (!this._encodings[name]) {\n throw new Error(`unknown encoding \"${name}\"`);\n }\n this._activeEncoding = name;\n }\n\n public reset(): void {\n this.activeProtocol = 'NONE';\n this.activeEncoding = 'DEFAULT';\n this._lastEvent = null;\n }\n\n /**\n * Event to announce changes in mouse tracking.\n */\n public get onProtocolChange(): IEvent {\n return this._onProtocolChange.event;\n }\n\n /**\n * Triggers a mouse event to be sent.\n *\n * Returns true if the event passed all protocol restrictions and a report\n * was sent, otherwise false. The return value may be used to decide whether\n * the default event action in the bowser component should be omitted.\n *\n * Note: The method will change values of the given event object\n * to fullfill protocol and encoding restrictions.\n */\n public triggerMouseEvent(e: ICoreMouseEvent): boolean {\n // range check for col/row\n if (e.col < 0 || e.col >= this._bufferService.cols\n || e.row < 0 || e.row >= this._bufferService.rows) {\n return false;\n }\n\n // filter nonsense combinations of button + action\n if (e.button === CoreMouseButton.WHEEL && e.action === CoreMouseAction.MOVE) {\n return false;\n }\n if (e.button === CoreMouseButton.NONE && e.action !== CoreMouseAction.MOVE) {\n return false;\n }\n if (e.button !== CoreMouseButton.WHEEL && (e.action === CoreMouseAction.LEFT || e.action === CoreMouseAction.RIGHT)) {\n return false;\n }\n\n // report 1-based coords\n e.col++;\n e.row++;\n\n // debounce move at grid level\n if (e.action === CoreMouseAction.MOVE && this._lastEvent && this._compareEvents(this._lastEvent, e)) {\n return false;\n }\n\n // apply protocol restrictions\n if (!this._protocols[this._activeProtocol].restrict(e)) {\n return false;\n }\n\n // encode report and send\n const report = this._encodings[this._activeEncoding](e);\n if (report) {\n // always send DEFAULT as binary data\n if (this._activeEncoding === 'DEFAULT') {\n this._coreService.triggerBinaryEvent(report);\n } else {\n this._coreService.triggerDataEvent(report, true);\n }\n }\n\n this._lastEvent = e;\n\n return true;\n }\n\n public explainEvents(events: CoreMouseEventType): {[event: string]: boolean} {\n return {\n down: !!(events & CoreMouseEventType.DOWN),\n up: !!(events & CoreMouseEventType.UP),\n drag: !!(events & CoreMouseEventType.DRAG),\n move: !!(events & CoreMouseEventType.MOVE),\n wheel: !!(events & CoreMouseEventType.WHEEL)\n };\n }\n\n private _compareEvents(e1: ICoreMouseEvent, e2: ICoreMouseEvent): boolean {\n if (e1.col !== e2.col) return false;\n if (e1.row !== e2.row) return false;\n if (e1.button !== e2.button) return false;\n if (e1.action !== e2.action) return false;\n if (e1.ctrl !== e2.ctrl) return false;\n if (e1.alt !== e2.alt) return false;\n if (e1.shift !== e2.shift) return false;\n return true;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ICoreService, ILogService, IOptionsService, IBufferService } from 'common/services/Services';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { IDecPrivateModes, IModes } from 'common/Types';\nimport { clone } from 'common/Clone';\nimport { Disposable } from 'common/Lifecycle';\n\nconst DEFAULT_MODES: IModes = Object.freeze({\n insertMode: false\n});\n\nconst DEFAULT_DEC_PRIVATE_MODES: IDecPrivateModes = Object.freeze({\n applicationCursorKeys: false,\n applicationKeypad: false,\n bracketedPasteMode: false,\n origin: false,\n reverseWraparound: false,\n sendFocus: false,\n wraparound: true // defaults: xterm - true, vt100 - false\n});\n\nexport class CoreService extends Disposable implements ICoreService {\n public serviceBrand: any;\n\n public isCursorInitialized: boolean = false;\n public isCursorHidden: boolean = false;\n public modes: IModes;\n public decPrivateModes: IDecPrivateModes;\n\n // Circular dependency, this must be unset or memory will leak after Terminal.dispose\n private _scrollToBottom: (() => void) | undefined;\n\n private _onData = this.register(new EventEmitter());\n public get onData(): IEvent { return this._onData.event; }\n private _onUserInput = this.register(new EventEmitter());\n public get onUserInput(): IEvent { return this._onUserInput.event; }\n private _onBinary = this.register(new EventEmitter());\n public get onBinary(): IEvent { return this._onBinary.event; }\n\n constructor(\n // TODO: Move this into a service\n scrollToBottom: () => void,\n @IBufferService private readonly _bufferService: IBufferService,\n @ILogService private readonly _logService: ILogService,\n @IOptionsService private readonly _optionsService: IOptionsService\n ) {\n super();\n this._scrollToBottom = scrollToBottom;\n this.register({ dispose: () => this._scrollToBottom = undefined });\n this.modes = clone(DEFAULT_MODES);\n this.decPrivateModes = clone(DEFAULT_DEC_PRIVATE_MODES);\n }\n\n public reset(): void {\n this.modes = clone(DEFAULT_MODES);\n this.decPrivateModes = clone(DEFAULT_DEC_PRIVATE_MODES);\n }\n\n public triggerDataEvent(data: string, wasUserInput: boolean = false): void {\n // Prevents all events to pty process if stdin is disabled\n if (this._optionsService.options.disableStdin) {\n return;\n }\n\n // Input is being sent to the terminal, the terminal should focus the prompt.\n const buffer = this._bufferService.buffer;\n if (buffer.ybase !== buffer.ydisp) {\n this._scrollToBottom!();\n }\n\n // Fire onUserInput so listeners can react as well (eg. clear selection)\n if (wasUserInput) {\n this._onUserInput.fire();\n }\n\n // Fire onData API\n this._logService.debug(`sending data \"${data}\"`, () => data.split('').map(e => e.charCodeAt(0)));\n this._onData.fire(data);\n }\n\n public triggerBinaryEvent(data: string): void {\n if (this._optionsService.options.disableStdin) {\n return;\n }\n this._logService.debug(`sending binary \"${data}\"`, () => data.split('').map(e => e.charCodeAt(0)));\n this._onBinary.fire(data);\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IBufferService, IDirtyRowService } from 'common/services/Services';\n\nexport class DirtyRowService implements IDirtyRowService {\n public serviceBrand: any;\n\n private _start!: number;\n private _end!: number;\n\n public get start(): number { return this._start; }\n public get end(): number { return this._end; }\n\n constructor(\n @IBufferService private readonly _bufferService: IBufferService\n ) {\n this.clearRange();\n }\n\n public clearRange(): void {\n this._start = this._bufferService.buffer.y;\n this._end = this._bufferService.buffer.y;\n }\n\n public markDirty(y: number): void {\n if (y < this._start) {\n this._start = y;\n } else if (y > this._end) {\n this._end = y;\n }\n }\n\n public markRangeDirty(y1: number, y2: number): void {\n if (y1 > y2) {\n const temp = y1;\n y1 = y2;\n y2 = temp;\n }\n if (y1 < this._start) {\n this._start = y1;\n }\n if (y2 > this._end) {\n this._end = y2;\n }\n }\n\n public markAllDirty(): void {\n this.markRangeDirty(0, this._bufferService.rows - 1);\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n *\n * This was heavily inspired from microsoft/vscode's dependency injection system (MIT).\n */\n/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n\nimport { IInstantiationService, IServiceIdentifier } from 'common/services/Services';\nimport { getServiceDependencies } from 'common/services/ServiceRegistry';\n\nexport class ServiceCollection {\n\n private _entries = new Map, any>();\n\n constructor(...entries: [IServiceIdentifier, any][]) {\n for (const [id, service] of entries) {\n this.set(id, service);\n }\n }\n\n public set(id: IServiceIdentifier, instance: T): T {\n const result = this._entries.get(id);\n this._entries.set(id, instance);\n return result;\n }\n\n public forEach(callback: (id: IServiceIdentifier, instance: any) => any): void {\n this._entries.forEach((value, key) => callback(key, value));\n }\n\n public has(id: IServiceIdentifier): boolean {\n return this._entries.has(id);\n }\n\n public get(id: IServiceIdentifier): T | undefined {\n return this._entries.get(id);\n }\n}\n\nexport class InstantiationService implements IInstantiationService {\n private readonly _services: ServiceCollection = new ServiceCollection();\n\n constructor() {\n this._services.set(IInstantiationService, this);\n }\n\n public setService(id: IServiceIdentifier, instance: T): void {\n this._services.set(id, instance);\n }\n\n public getService(id: IServiceIdentifier): T | undefined {\n return this._services.get(id);\n }\n\n public createInstance(ctor: any, ...args: any[]): T {\n const serviceDependencies = getServiceDependencies(ctor).sort((a, b) => a.index - b.index);\n\n const serviceArgs: any[] = [];\n for (const dependency of serviceDependencies) {\n const service = this._services.get(dependency.id);\n if (!service) {\n throw new Error(`[createInstance] ${ctor.name} depends on UNKNOWN service ${dependency.id}.`);\n }\n serviceArgs.push(service);\n }\n\n const firstServiceArgPos = serviceDependencies.length > 0 ? serviceDependencies[0].index : args.length;\n\n // check for argument mismatches, adjust static args if needed\n if (args.length !== firstServiceArgPos) {\n throw new Error(`[createInstance] First service dependency of ${ctor.name} at position ${firstServiceArgPos + 1} conflicts with ${args.length} static arguments`);\n }\n\n // now create the instance\n return new ctor(...[...args, ...serviceArgs]);\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { ILogService, IOptionsService } from 'common/services/Services';\n\ntype LogType = (message?: any, ...optionalParams: any[]) => void;\n\ninterface IConsole {\n log: LogType;\n error: LogType;\n info: LogType;\n trace: LogType;\n warn: LogType;\n}\n\n// console is available on both node.js and browser contexts but the common\n// module doesn't depend on them so we need to explicitly declare it.\ndeclare const console: IConsole;\n\n\nexport enum LogLevel {\n DEBUG = 0,\n INFO = 1,\n WARN = 2,\n ERROR = 3,\n OFF = 4\n}\n\nconst optionsKeyToLogLevel: { [key: string]: LogLevel } = {\n debug: LogLevel.DEBUG,\n info: LogLevel.INFO,\n warn: LogLevel.WARN,\n error: LogLevel.ERROR,\n off: LogLevel.OFF\n};\n\nconst LOG_PREFIX = 'xterm.js: ';\n\nexport class LogService implements ILogService {\n public serviceBrand: any;\n\n private _logLevel!: LogLevel;\n\n constructor(\n @IOptionsService private readonly _optionsService: IOptionsService\n ) {\n this._updateLogLevel();\n this._optionsService.onOptionChange(key => {\n if (key === 'logLevel') {\n this._updateLogLevel();\n }\n });\n }\n\n private _updateLogLevel(): void {\n this._logLevel = optionsKeyToLogLevel[this._optionsService.options.logLevel];\n }\n\n private _evalLazyOptionalParams(optionalParams: any[]): void {\n for (let i = 0; i < optionalParams.length; i++) {\n if (typeof optionalParams[i] === 'function') {\n optionalParams[i] = optionalParams[i]();\n }\n }\n }\n\n private _log(type: LogType, message: string, optionalParams: any[]): void {\n this._evalLazyOptionalParams(optionalParams);\n type.call(console, LOG_PREFIX + message, ...optionalParams);\n }\n\n public debug(message: string, ...optionalParams: any[]): void {\n if (this._logLevel <= LogLevel.DEBUG) {\n this._log(console.log, message, optionalParams);\n }\n }\n\n public info(message: string, ...optionalParams: any[]): void {\n if (this._logLevel <= LogLevel.INFO) {\n this._log(console.info, message, optionalParams);\n }\n }\n\n public warn(message: string, ...optionalParams: any[]): void {\n if (this._logLevel <= LogLevel.WARN) {\n this._log(console.warn, message, optionalParams);\n }\n }\n\n public error(message: string, ...optionalParams: any[]): void {\n if (this._logLevel <= LogLevel.ERROR) {\n this._log(console.error, message, optionalParams);\n }\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IOptionsService, ITerminalOptions, IPartialTerminalOptions, FontWeight } from 'common/services/Services';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { isMac } from 'common/Platform';\nimport { clone } from 'common/Clone';\n\n// Source: https://freesound.org/people/altemark/sounds/45759/\n// This sound is released under the Creative Commons Attribution 3.0 Unported\n// (CC BY 3.0) license. It was created by 'altemark'. No modifications have been\n// made, apart from the conversion to base64.\nexport const DEFAULT_BELL_SOUND = 'data:audio/mp3;base64,SUQzBAAAAAAAI1RTU0UAAAAPAAADTGF2ZjU4LjMyLjEwNAAAAAAAAAAAAAAA//tQxAADB8AhSmxhIIEVCSiJrDCQBTcu3UrAIwUdkRgQbFAZC1CQEwTJ9mjRvBA4UOLD8nKVOWfh+UlK3z/177OXrfOdKl7pyn3Xf//WreyTRUoAWgBgkOAGbZHBgG1OF6zM82DWbZaUmMBptgQhGjsyYqc9ae9XFz280948NMBWInljyzsNRFLPWdnZGWrddDsjK1unuSrVN9jJsK8KuQtQCtMBjCEtImISdNKJOopIpBFpNSMbIHCSRpRR5iakjTiyzLhchUUBwCgyKiweBv/7UsQbg8isVNoMPMjAAAA0gAAABEVFGmgqK////9bP/6XCykxBTUUzLjEwMKqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq';\n\n// TODO: Freeze?\nexport const DEFAULT_OPTIONS: ITerminalOptions = Object.freeze({\n cols: 80,\n rows: 24,\n cursorBlink: false,\n cursorStyle: 'block',\n cursorWidth: 1,\n bellSound: DEFAULT_BELL_SOUND,\n bellStyle: 'none',\n drawBoldTextInBrightColors: true,\n fastScrollModifier: 'alt',\n fastScrollSensitivity: 5,\n fontFamily: 'courier-new, courier, monospace',\n fontSize: 15,\n fontWeight: 'normal',\n fontWeightBold: 'bold',\n lineHeight: 1.0,\n linkTooltipHoverDuration: 500,\n letterSpacing: 0,\n logLevel: 'info',\n scrollback: 1000,\n scrollSensitivity: 1,\n screenReaderMode: false,\n macOptionIsMeta: false,\n macOptionClickForcesSelection: false,\n minimumContrastRatio: 1,\n disableStdin: false,\n allowProposedApi: true,\n allowTransparency: false,\n tabStopWidth: 8,\n theme: {},\n rightClickSelectsWord: isMac,\n rendererType: 'canvas',\n windowOptions: {},\n windowsMode: false,\n wordSeparator: ' ()[]{}\\',\"`',\n altClickMovesCursor: true,\n convertEol: false,\n termName: 'xterm',\n cancelEvents: false\n});\n\nconst FONT_WEIGHT_OPTIONS: Extract[] = ['normal', 'bold', '100', '200', '300', '400', '500', '600', '700', '800', '900'];\n\n/**\n * The set of options that only have an effect when set in the Terminal constructor.\n */\nconst CONSTRUCTOR_ONLY_OPTIONS = ['cols', 'rows'];\n\nexport class OptionsService implements IOptionsService {\n public serviceBrand: any;\n\n public options: ITerminalOptions;\n\n private _onOptionChange = new EventEmitter();\n public get onOptionChange(): IEvent { return this._onOptionChange.event; }\n\n constructor(options: IPartialTerminalOptions) {\n this.options = clone(DEFAULT_OPTIONS);\n for (const k of Object.keys(options)) {\n if (k in this.options) {\n try {\n const newValue = options[k as keyof IPartialTerminalOptions] as any;\n this.options[k] = this._sanitizeAndValidateOption(k, newValue);\n } catch (e) {\n console.error(e);\n }\n }\n }\n }\n\n public setOption(key: string, value: any): void {\n if (!(key in DEFAULT_OPTIONS)) {\n throw new Error('No option with key \"' + key + '\"');\n }\n if (CONSTRUCTOR_ONLY_OPTIONS.includes(key)) {\n throw new Error(`Option \"${key}\" can only be set in the constructor`);\n }\n if (this.options[key] === value) {\n return;\n }\n\n value = this._sanitizeAndValidateOption(key, value);\n\n // Don't fire an option change event if they didn't change\n if (this.options[key] === value) {\n return;\n }\n\n this.options[key] = value;\n this._onOptionChange.fire(key);\n }\n\n private _sanitizeAndValidateOption(key: string, value: any): any {\n switch (key) {\n case 'bellStyle':\n case 'cursorStyle':\n case 'rendererType':\n case 'wordSeparator':\n if (!value) {\n value = DEFAULT_OPTIONS[key];\n }\n break;\n case 'fontWeight':\n case 'fontWeightBold':\n if (typeof value === 'number' && 1 <= value && value <= 1000) {\n // already valid numeric value\n break;\n }\n value = FONT_WEIGHT_OPTIONS.includes(value) ? value : DEFAULT_OPTIONS[key];\n break;\n case 'cursorWidth':\n value = Math.floor(value);\n // Fall through for bounds check\n case 'lineHeight':\n case 'tabStopWidth':\n if (value < 1) {\n throw new Error(`${key} cannot be less than 1, value: ${value}`);\n }\n break;\n case 'minimumContrastRatio':\n value = Math.max(1, Math.min(21, Math.round(value * 10) / 10));\n break;\n case 'scrollback':\n value = Math.min(value, 4294967295);\n if (value < 0) {\n throw new Error(`${key} cannot be less than 0, value: ${value}`);\n }\n break;\n case 'fastScrollSensitivity':\n case 'scrollSensitivity':\n if (value <= 0) {\n throw new Error(`${key} cannot be less than or equal to 0, value: ${value}`);\n }\n break;\n }\n return value;\n }\n\n public getOption(key: string): any {\n if (!(key in DEFAULT_OPTIONS)) {\n throw new Error(`No option with key \"${key}\"`);\n }\n return this.options[key];\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n *\n * This was heavily inspired from microsoft/vscode's dependency injection system (MIT).\n */\n/*---------------------------------------------------------------------------------------------\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n *--------------------------------------------------------------------------------------------*/\n\nimport { IServiceIdentifier } from 'common/services/Services';\n\nconst DI_TARGET = 'di$target';\nconst DI_DEPENDENCIES = 'di$dependencies';\n\nexport const serviceRegistry: Map> = new Map();\n\nexport function getServiceDependencies(ctor: any): { id: IServiceIdentifier, index: number, optional: boolean }[] {\n return ctor[DI_DEPENDENCIES] || [];\n}\n\nexport function createDecorator(id: string): IServiceIdentifier {\n if (serviceRegistry.has(id)) {\n return serviceRegistry.get(id)!;\n }\n\n const decorator: any = function (target: Function, key: string, index: number): any {\n if (arguments.length !== 3) {\n throw new Error('@IServiceName-decorator can only be used to decorate a parameter');\n }\n\n storeServiceDependency(decorator, target, index);\n };\n\n decorator.toString = () => id;\n\n serviceRegistry.set(id, decorator);\n return decorator;\n}\n\nfunction storeServiceDependency(id: Function, target: Function, index: number): void {\n if ((target as any)[DI_TARGET] === target) {\n (target as any)[DI_DEPENDENCIES].push({ id, index });\n } else {\n (target as any)[DI_DEPENDENCIES] = [{ id, index }];\n (target as any)[DI_TARGET] = target;\n }\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { IEvent } from 'common/EventEmitter';\nimport { IBuffer, IBufferSet } from 'common/buffer/Types';\nimport { IDecPrivateModes, ICoreMouseEvent, CoreMouseEncoding, ICoreMouseProtocol, CoreMouseEventType, ICharset, IWindowOptions, IModes } from 'common/Types';\nimport { createDecorator } from 'common/services/ServiceRegistry';\n\nexport const IBufferService = createDecorator('BufferService');\nexport interface IBufferService {\n serviceBrand: undefined;\n\n readonly cols: number;\n readonly rows: number;\n readonly buffer: IBuffer;\n readonly buffers: IBufferSet;\n isUserScrolling: boolean;\n\n onResize: IEvent<{ cols: number, rows: number }>;\n\n resize(cols: number, rows: number): void;\n reset(): void;\n}\n\nexport const ICoreMouseService = createDecorator('CoreMouseService');\nexport interface ICoreMouseService {\n activeProtocol: string;\n activeEncoding: string;\n areMouseEventsActive: boolean;\n addProtocol(name: string, protocol: ICoreMouseProtocol): void;\n addEncoding(name: string, encoding: CoreMouseEncoding): void;\n reset(): void;\n\n /**\n * Triggers a mouse event to be sent.\n *\n * Returns true if the event passed all protocol restrictions and a report\n * was sent, otherwise false. The return value may be used to decide whether\n * the default event action in the bowser component should be omitted.\n *\n * Note: The method will change values of the given event object\n * to fullfill protocol and encoding restrictions.\n */\n triggerMouseEvent(event: ICoreMouseEvent): boolean;\n\n /**\n * Event to announce changes in mouse tracking.\n */\n onProtocolChange: IEvent;\n\n /**\n * Human readable version of mouse events.\n */\n explainEvents(events: CoreMouseEventType): { [event: string]: boolean };\n}\n\nexport const ICoreService = createDecorator('CoreService');\nexport interface ICoreService {\n serviceBrand: undefined;\n\n /**\n * Initially the cursor will not be visible until the first time the terminal\n * is focused.\n */\n isCursorInitialized: boolean;\n isCursorHidden: boolean;\n\n readonly modes: IModes;\n readonly decPrivateModes: IDecPrivateModes;\n\n readonly onData: IEvent;\n readonly onUserInput: IEvent;\n readonly onBinary: IEvent;\n\n reset(): void;\n\n /**\n * Triggers the onData event in the public API.\n * @param data The data that is being emitted.\n * @param wasFromUser Whether the data originated from the user (as opposed to\n * resulting from parsing incoming data). When true this will also:\n * - Scroll to the bottom of the buffer.s\n * - Fire the `onUserInput` event (so selection can be cleared).\n */\n triggerDataEvent(data: string, wasUserInput?: boolean): void;\n\n /**\n * Triggers the onBinary event in the public API.\n * @param data The data that is being emitted.\n */\n triggerBinaryEvent(data: string): void;\n}\n\nexport const ICharsetService = createDecorator('CharsetService');\nexport interface ICharsetService {\n serviceBrand: undefined;\n\n charset: ICharset | undefined;\n readonly glevel: number;\n\n reset(): void;\n\n /**\n * Set the G level of the terminal.\n * @param g\n */\n setgLevel(g: number): void;\n\n /**\n * Set the charset for the given G level of the terminal.\n * @param g\n * @param charset\n */\n setgCharset(g: number, charset: ICharset | undefined): void;\n}\n\nexport const IDirtyRowService = createDecorator('DirtyRowService');\nexport interface IDirtyRowService {\n serviceBrand: undefined;\n\n readonly start: number;\n readonly end: number;\n\n clearRange(): void;\n markDirty(y: number): void;\n markRangeDirty(y1: number, y2: number): void;\n markAllDirty(): void;\n}\n\nexport interface IServiceIdentifier {\n (...args: any[]): void;\n type: T;\n}\n\nexport interface IBrandedService {\n serviceBrand: undefined;\n}\n\ntype GetLeadingNonServiceArgs =\n Args extends [...IBrandedService[]] ? []\n : Args extends [infer A1, ...IBrandedService[]] ? [A1]\n : Args extends [infer A1, infer A2, ...IBrandedService[]] ? [A1, A2]\n : Args extends [infer A1, infer A2, infer A3, ...IBrandedService[]] ? [A1, A2, A3]\n : Args extends [infer A1, infer A2, infer A3, infer A4, ...IBrandedService[]] ? [A1, A2, A3, A4]\n : Args extends [infer A1, infer A2, infer A3, infer A4, infer A5, ...IBrandedService[]] ? [A1, A2, A3, A4, A5]\n : Args extends [infer A1, infer A2, infer A3, infer A4, infer A5, infer A6, ...IBrandedService[]] ? [A1, A2, A3, A4, A5, A6]\n : Args extends [infer A1, infer A2, infer A3, infer A4, infer A5, infer A6, infer A7, ...IBrandedService[]] ? [A1, A2, A3, A4, A5, A6, A7]\n : Args extends [infer A1, infer A2, infer A3, infer A4, infer A5, infer A6, infer A7, infer A8, ...IBrandedService[]] ? [A1, A2, A3, A4, A5, A6, A7, A8]\n : never;\n\nexport const IInstantiationService = createDecorator('InstantiationService');\nexport interface IInstantiationService {\n setService(id: IServiceIdentifier, instance: T): void;\n getService(id: IServiceIdentifier): T | undefined;\n createInstance any, R extends InstanceType>(t: Ctor, ...args: GetLeadingNonServiceArgs>): R;\n}\n\nexport const ILogService = createDecorator('LogService');\nexport interface ILogService {\n serviceBrand: undefined;\n\n debug(message: any, ...optionalParams: any[]): void;\n info(message: any, ...optionalParams: any[]): void;\n warn(message: any, ...optionalParams: any[]): void;\n error(message: any, ...optionalParams: any[]): void;\n}\n\nexport const IOptionsService = createDecorator('OptionsService');\nexport interface IOptionsService {\n serviceBrand: undefined;\n\n readonly options: ITerminalOptions;\n\n readonly onOptionChange: IEvent;\n\n setOption(key: string, value: T): void;\n getOption(key: string): T | undefined;\n}\n\nexport type FontWeight = 'normal' | 'bold' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900' | number;\nexport type LogLevel = 'debug' | 'info' | 'warn' | 'error' | 'off';\nexport type RendererType = 'dom' | 'canvas';\n\nexport interface IPartialTerminalOptions {\n altClickMovesCursor?: boolean;\n allowTransparency?: boolean;\n bellSound?: string;\n bellStyle?: 'none' | 'sound' /* | 'visual' | 'both' */;\n cols?: number;\n cursorBlink?: boolean;\n cursorStyle?: 'block' | 'underline' | 'bar';\n cursorWidth?: number;\n disableStdin?: boolean;\n drawBoldTextInBrightColors?: boolean;\n fastScrollModifier?: 'alt' | 'ctrl' | 'shift';\n fastScrollSensitivity?: number;\n fontSize?: number;\n fontFamily?: string;\n fontWeight?: FontWeight;\n fontWeightBold?: FontWeight;\n letterSpacing?: number;\n lineHeight?: number;\n logLevel?: LogLevel;\n macOptionIsMeta?: boolean;\n macOptionClickForcesSelection?: boolean;\n rendererType?: RendererType;\n rightClickSelectsWord?: boolean;\n rows?: number;\n screenReaderMode?: boolean;\n scrollback?: number;\n scrollSensitivity?: number;\n tabStopWidth?: number;\n theme?: ITheme;\n windowsMode?: boolean;\n wordSeparator?: string;\n windowOptions?: IWindowOptions;\n}\n\nexport interface ITerminalOptions {\n allowProposedApi: boolean;\n allowTransparency: boolean;\n altClickMovesCursor: boolean;\n bellSound: string;\n bellStyle: 'none' | 'sound' /* | 'visual' | 'both' */;\n cols: number;\n cursorBlink: boolean;\n cursorStyle: 'block' | 'underline' | 'bar';\n cursorWidth: number;\n disableStdin: boolean;\n drawBoldTextInBrightColors: boolean;\n fastScrollModifier: 'alt' | 'ctrl' | 'shift' | undefined;\n fastScrollSensitivity: number;\n fontSize: number;\n fontFamily: string;\n fontWeight: FontWeight;\n fontWeightBold: FontWeight;\n letterSpacing: number;\n lineHeight: number;\n linkTooltipHoverDuration: number;\n logLevel: LogLevel;\n macOptionIsMeta: boolean;\n macOptionClickForcesSelection: boolean;\n minimumContrastRatio: number;\n rendererType: RendererType;\n rightClickSelectsWord: boolean;\n rows: number;\n screenReaderMode: boolean;\n scrollback: number;\n scrollSensitivity: number;\n tabStopWidth: number;\n theme: ITheme;\n windowsMode: boolean;\n windowOptions: IWindowOptions;\n wordSeparator: string;\n\n [key: string]: any;\n cancelEvents: boolean;\n convertEol: boolean;\n termName: string;\n}\n\nexport interface ITheme {\n foreground?: string;\n background?: string;\n cursor?: string;\n cursorAccent?: string;\n selection?: string;\n black?: string;\n red?: string;\n green?: string;\n yellow?: string;\n blue?: string;\n magenta?: string;\n cyan?: string;\n white?: string;\n brightBlack?: string;\n brightRed?: string;\n brightGreen?: string;\n brightYellow?: string;\n brightBlue?: string;\n brightMagenta?: string;\n brightCyan?: string;\n brightWhite?: string;\n}\n\nexport const IUnicodeService = createDecorator('UnicodeService');\nexport interface IUnicodeService {\n serviceBrand: undefined;\n /** Register an Unicode version provider. */\n register(provider: IUnicodeVersionProvider): void;\n /** Registered Unicode versions. */\n readonly versions: string[];\n /** Currently active version. */\n activeVersion: string;\n /** Event triggered, when activate version changed. */\n readonly onChange: IEvent;\n\n /**\n * Unicode version dependent\n */\n wcwidth(codepoint: number): number;\n getStringCellWidth(s: string): number;\n}\n\nexport interface IUnicodeVersionProvider {\n readonly version: string;\n wcwidth(ucs: number): 0 | 1 | 2;\n}\n","/**\n * Copyright (c) 2019 The xterm.js authors. All rights reserved.\n * @license MIT\n */\nimport { IUnicodeService, IUnicodeVersionProvider } from 'common/services/Services';\nimport { EventEmitter, IEvent } from 'common/EventEmitter';\nimport { UnicodeV6 } from 'common/input/UnicodeV6';\n\n\nexport class UnicodeService implements IUnicodeService {\n public serviceBrand: any;\n\n private _providers: {[key: string]: IUnicodeVersionProvider} = Object.create(null);\n private _active: string = '';\n private _activeProvider: IUnicodeVersionProvider;\n private _onChange = new EventEmitter();\n public get onChange(): IEvent { return this._onChange.event; }\n\n constructor() {\n const defaultProvider = new UnicodeV6();\n this.register(defaultProvider);\n this._active = defaultProvider.version;\n this._activeProvider = defaultProvider;\n }\n\n public get versions(): string[] {\n return Object.keys(this._providers);\n }\n\n public get activeVersion(): string {\n return this._active;\n }\n\n public set activeVersion(version: string) {\n if (!this._providers[version]) {\n throw new Error(`unknown Unicode version \"${version}\"`);\n }\n this._active = version;\n this._activeProvider = this._providers[version];\n this._onChange.fire(version);\n }\n\n public register(provider: IUnicodeVersionProvider): void {\n this._providers[provider.version] = provider;\n }\n\n /**\n * Unicode version dependent interface.\n */\n public wcwidth(num: number): number {\n return this._activeProvider.wcwidth(num);\n }\n\n public getStringCellWidth(s: string): number {\n let result = 0;\n const length = s.length;\n for (let i = 0; i < length; ++i) {\n let code = s.charCodeAt(i);\n // surrogate pair first\n if (0xD800 <= code && code <= 0xDBFF) {\n if (++i >= length) {\n // this should not happen with strings retrieved from\n // Buffer.translateToString as it converts from UTF-32\n // and therefore always should contain the second part\n // for any other string we still have to handle it somehow:\n // simply treat the lonely surrogate first as a single char (UCS-2 behavior)\n return result + this.wcwidth(code);\n }\n const second = s.charCodeAt(i);\n // convert surrogate pair to high codepoint only for valid second part (UTF-16)\n // otherwise treat them independently (UCS-2 behavior)\n if (0xDC00 <= second && second <= 0xDFFF) {\n code = (code - 0xD800) * 0x400 + second - 0xDC00 + 0x10000;\n } else {\n result += this.wcwidth(second);\n }\n }\n result += this.wcwidth(code);\n }\n return result;\n }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tif(__webpack_module_cache__[moduleId]) {\n\t\treturn __webpack_module_cache__[moduleId].exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// module exports must be returned from runtime so entry inlining is disabled\n// startup\n// Load entry module and return exports\nreturn __webpack_require__(4389);\n"],"sourceRoot":""} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/AccessibilityManager.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/AccessibilityManager.ts deleted file mode 100755 index e5cbb372e..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/AccessibilityManager.ts +++ /dev/null @@ -1,300 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import * as Strings from 'browser/LocalizableStrings'; -import { ITerminal } from 'browser/Types'; -import { IBuffer } from 'common/buffer/Types'; -import { isMac } from 'common/Platform'; -import { RenderDebouncer } from 'browser/RenderDebouncer'; -import { addDisposableDomListener } from 'browser/Lifecycle'; -import { Disposable } from 'common/Lifecycle'; -import { ScreenDprMonitor } from 'browser/ScreenDprMonitor'; -import { IRenderService } from 'browser/services/Services'; -import { removeElementFromParent } from 'browser/Dom'; - -const MAX_ROWS_TO_READ = 20; - -const enum BoundaryPosition { - TOP, - BOTTOM -} - -export class AccessibilityManager extends Disposable { - private _accessibilityTreeRoot: HTMLElement; - private _rowContainer: HTMLElement; - private _rowElements: HTMLElement[]; - private _liveRegion: HTMLElement; - private _liveRegionLineCount: number = 0; - - private _renderRowsDebouncer: RenderDebouncer; - private _screenDprMonitor: ScreenDprMonitor; - - private _topBoundaryFocusListener: (e: FocusEvent) => void; - private _bottomBoundaryFocusListener: (e: FocusEvent) => void; - - /** - * This queue has a character pushed to it for keys that are pressed, if the - * next character added to the terminal is equal to the key char then it is - * not announced (added to live region) because it has already been announced - * by the textarea event (which cannot be canceled). There are some race - * condition cases if there is typing while data is streaming, but this covers - * the main case of typing into the prompt and inputting the answer to a - * question (Y/N, etc.). - */ - private _charsToConsume: string[] = []; - - private _charsToAnnounce: string = ''; - - constructor( - private readonly _terminal: ITerminal, - private readonly _renderService: IRenderService - ) { - super(); - this._accessibilityTreeRoot = document.createElement('div'); - this._accessibilityTreeRoot.classList.add('xterm-accessibility'); - - this._rowContainer = document.createElement('div'); - this._rowContainer.setAttribute('role', 'list'); - this._rowContainer.classList.add('xterm-accessibility-tree'); - this._rowElements = []; - for (let i = 0; i < this._terminal.rows; i++) { - this._rowElements[i] = this._createAccessibilityTreeNode(); - this._rowContainer.appendChild(this._rowElements[i]); - } - - this._topBoundaryFocusListener = e => this._onBoundaryFocus(e, BoundaryPosition.TOP); - this._bottomBoundaryFocusListener = e => this._onBoundaryFocus(e, BoundaryPosition.BOTTOM); - this._rowElements[0].addEventListener('focus', this._topBoundaryFocusListener); - this._rowElements[this._rowElements.length - 1].addEventListener('focus', this._bottomBoundaryFocusListener); - - this._refreshRowsDimensions(); - this._accessibilityTreeRoot.appendChild(this._rowContainer); - - this._renderRowsDebouncer = new RenderDebouncer(this._renderRows.bind(this)); - this._refreshRows(); - - this._liveRegion = document.createElement('div'); - this._liveRegion.classList.add('live-region'); - this._liveRegion.setAttribute('aria-live', 'assertive'); - this._accessibilityTreeRoot.appendChild(this._liveRegion); - - if (!this._terminal.element) { - throw new Error('Cannot enable accessibility before Terminal.open'); - } - this._terminal.element.insertAdjacentElement('afterbegin', this._accessibilityTreeRoot); - - this.register(this._renderRowsDebouncer); - this.register(this._terminal.onResize(e => this._onResize(e.rows))); - this.register(this._terminal.onRender(e => this._refreshRows(e.start, e.end))); - this.register(this._terminal.onScroll(() => this._refreshRows())); - // Line feed is an issue as the prompt won't be read out after a command is run - this.register(this._terminal.onA11yChar(char => this._onChar(char))); - this.register(this._terminal.onLineFeed(() => this._onChar('\n'))); - this.register(this._terminal.onA11yTab(spaceCount => this._onTab(spaceCount))); - this.register(this._terminal.onKey(e => this._onKey(e.key))); - this.register(this._terminal.onBlur(() => this._clearLiveRegion())); - this.register(this._renderService.onDimensionsChange(() => this._refreshRowsDimensions())); - - this._screenDprMonitor = new ScreenDprMonitor(); - this.register(this._screenDprMonitor); - this._screenDprMonitor.setListener(() => this._refreshRowsDimensions()); - // This shouldn't be needed on modern browsers but is present in case the - // media query that drives the ScreenDprMonitor isn't supported - this.register(addDisposableDomListener(window, 'resize', () => this._refreshRowsDimensions())); - } - - public dispose(): void { - super.dispose(); - removeElementFromParent(this._accessibilityTreeRoot); - this._rowElements.length = 0; - } - - private _onBoundaryFocus(e: FocusEvent, position: BoundaryPosition): void { - const boundaryElement = e.target; - const beforeBoundaryElement = this._rowElements[position === BoundaryPosition.TOP ? 1 : this._rowElements.length - 2]; - - // Don't scroll if the buffer top has reached the end in that direction - const posInSet = boundaryElement.getAttribute('aria-posinset'); - const lastRowPos = position === BoundaryPosition.TOP ? '1' : `${this._terminal.buffer.lines.length}`; - if (posInSet === lastRowPos) { - return; - } - - // Don't scroll when the last focused item was not the second row (focus is going the other - // direction) - if (e.relatedTarget !== beforeBoundaryElement) { - return; - } - - // Remove old boundary element from array - let topBoundaryElement: HTMLElement; - let bottomBoundaryElement: HTMLElement; - if (position === BoundaryPosition.TOP) { - topBoundaryElement = boundaryElement; - bottomBoundaryElement = this._rowElements.pop()!; - this._rowContainer.removeChild(bottomBoundaryElement); - } else { - topBoundaryElement = this._rowElements.shift()!; - bottomBoundaryElement = boundaryElement; - this._rowContainer.removeChild(topBoundaryElement); - } - - // Remove listeners from old boundary elements - topBoundaryElement.removeEventListener('focus', this._topBoundaryFocusListener); - bottomBoundaryElement.removeEventListener('focus', this._bottomBoundaryFocusListener); - - // Add new element to array/DOM - if (position === BoundaryPosition.TOP) { - const newElement = this._createAccessibilityTreeNode(); - this._rowElements.unshift(newElement); - this._rowContainer.insertAdjacentElement('afterbegin', newElement); - } else { - const newElement = this._createAccessibilityTreeNode(); - this._rowElements.push(newElement); - this._rowContainer.appendChild(newElement); - } - - // Add listeners to new boundary elements - this._rowElements[0].addEventListener('focus', this._topBoundaryFocusListener); - this._rowElements[this._rowElements.length - 1].addEventListener('focus', this._bottomBoundaryFocusListener); - - // Scroll up - this._terminal.scrollLines(position === BoundaryPosition.TOP ? -1 : 1); - - // Focus new boundary before element - this._rowElements[position === BoundaryPosition.TOP ? 1 : this._rowElements.length - 2].focus(); - - // Prevent the standard behavior - e.preventDefault(); - e.stopImmediatePropagation(); - } - - private _onResize(rows: number): void { - // Remove bottom boundary listener - this._rowElements[this._rowElements.length - 1].removeEventListener('focus', this._bottomBoundaryFocusListener); - - // Grow rows as required - for (let i = this._rowContainer.children.length; i < this._terminal.rows; i++) { - this._rowElements[i] = this._createAccessibilityTreeNode(); - this._rowContainer.appendChild(this._rowElements[i]); - } - // Shrink rows as required - while (this._rowElements.length > rows) { - this._rowContainer.removeChild(this._rowElements.pop()!); - } - - // Add bottom boundary listener - this._rowElements[this._rowElements.length - 1].addEventListener('focus', this._bottomBoundaryFocusListener); - - this._refreshRowsDimensions(); - } - - private _createAccessibilityTreeNode(): HTMLElement { - const element = document.createElement('div'); - element.setAttribute('role', 'listitem'); - element.tabIndex = -1; - this._refreshRowDimensions(element); - return element; - } - - private _onTab(spaceCount: number): void { - for (let i = 0; i < spaceCount; i++) { - this._onChar(' '); - } - } - - private _onChar(char: string): void { - if (this._liveRegionLineCount < MAX_ROWS_TO_READ + 1) { - if (this._charsToConsume.length > 0) { - // Have the screen reader ignore the char if it was just input - const shiftedChar = this._charsToConsume.shift(); - if (shiftedChar !== char) { - this._charsToAnnounce += char; - } - } else { - this._charsToAnnounce += char; - } - - if (char === '\n') { - this._liveRegionLineCount++; - if (this._liveRegionLineCount === MAX_ROWS_TO_READ + 1) { - this._liveRegion.textContent += Strings.tooMuchOutput; - } - } - - // Only detach/attach on mac as otherwise messages can go unaccounced - if (isMac) { - if (this._liveRegion.textContent && this._liveRegion.textContent.length > 0 && !this._liveRegion.parentNode) { - setTimeout(() => { - this._accessibilityTreeRoot.appendChild(this._liveRegion); - }, 0); - } - } - } - } - - private _clearLiveRegion(): void { - this._liveRegion.textContent = ''; - this._liveRegionLineCount = 0; - - // Only detach/attach on mac as otherwise messages can go unaccounced - if (isMac) { - removeElementFromParent(this._liveRegion); - } - } - - private _onKey(keyChar: string): void { - this._clearLiveRegion(); - this._charsToConsume.push(keyChar); - } - - private _refreshRows(start?: number, end?: number): void { - this._renderRowsDebouncer.refresh(start, end, this._terminal.rows); - } - - private _renderRows(start: number, end: number): void { - const buffer: IBuffer = this._terminal.buffer; - const setSize = buffer.lines.length.toString(); - for (let i = start; i <= end; i++) { - const lineData = buffer.translateBufferLineToString(buffer.ydisp + i, true); - const posInSet = (buffer.ydisp + i + 1).toString(); - const element = this._rowElements[i]; - if (element) { - if (lineData.length === 0) { - element.innerText = '\u00a0'; - } else { - element.textContent = lineData; - } - element.setAttribute('aria-posinset', posInSet); - element.setAttribute('aria-setsize', setSize); - } - } - this._announceCharacters(); - } - - private _refreshRowsDimensions(): void { - if (!this._renderService.dimensions.actualCellHeight) { - return; - } - if (this._rowElements.length !== this._terminal.rows) { - this._onResize(this._terminal.rows); - } - for (let i = 0; i < this._terminal.rows; i++) { - this._refreshRowDimensions(this._rowElements[i]); - } - } - - private _refreshRowDimensions(element: HTMLElement): void { - element.style.height = `${this._renderService.dimensions.actualCellHeight}px`; - } - - private _announceCharacters(): void { - if (this._charsToAnnounce.length === 0) { - return; - } - this._liveRegion.textContent += this._charsToAnnounce; - this._charsToAnnounce = ''; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Clipboard.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Clipboard.ts deleted file mode 100755 index 29e865c89..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Clipboard.ts +++ /dev/null @@ -1,99 +0,0 @@ -/** - * Copyright (c) 2016 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ISelectionService } from 'browser/services/Services'; -import { ICoreService } from 'common/services/Services'; - -/** - * Prepares text to be pasted into the terminal by normalizing the line endings - * @param text The pasted text that needs processing before inserting into the terminal - */ -export function prepareTextForTerminal(text: string): string { - return text.replace(/\r?\n/g, '\r'); -} - -/** - * Bracket text for paste, if necessary, as per https://cirw.in/blog/bracketed-paste - * @param text The pasted text to bracket - */ -export function bracketTextForPaste(text: string, bracketedPasteMode: boolean): string { - if (bracketedPasteMode) { - return '\x1b[200~' + text + '\x1b[201~'; - } - return text; -} - -/** - * Binds copy functionality to the given terminal. - * @param ev The original copy event to be handled - */ -export function copyHandler(ev: ClipboardEvent, selectionService: ISelectionService): void { - if (ev.clipboardData) { - ev.clipboardData.setData('text/plain', selectionService.selectionText); - } - // Prevent or the original text will be copied. - ev.preventDefault(); -} - -/** - * Redirect the clipboard's data to the terminal's input handler. - * @param ev The original paste event to be handled - * @param term The terminal on which to apply the handled paste event - */ -export function handlePasteEvent(ev: ClipboardEvent, textarea: HTMLTextAreaElement, coreService: ICoreService): void { - ev.stopPropagation(); - if (ev.clipboardData) { - const text = ev.clipboardData.getData('text/plain'); - paste(text, textarea, coreService); - } -} - -export function paste(text: string, textarea: HTMLTextAreaElement, coreService: ICoreService): void { - text = prepareTextForTerminal(text); - text = bracketTextForPaste(text, coreService.decPrivateModes.bracketedPasteMode); - coreService.triggerDataEvent(text, true); - textarea.value = ''; -} - -/** - * Moves the textarea under the mouse cursor and focuses it. - * @param ev The original right click event to be handled. - * @param textarea The terminal's textarea. - */ -export function moveTextAreaUnderMouseCursor(ev: MouseEvent, textarea: HTMLTextAreaElement, screenElement: HTMLElement): void { - - // Calculate textarea position relative to the screen element - const pos = screenElement.getBoundingClientRect(); - const left = ev.clientX - pos.left - 10; - const top = ev.clientY - pos.top - 10; - - // Bring textarea at the cursor position - textarea.style.width = '20px'; - textarea.style.height = '20px'; - textarea.style.left = `${left}px`; - textarea.style.top = `${top}px`; - textarea.style.zIndex = '1000'; - - textarea.focus(); -} - -/** - * Bind to right-click event and allow right-click copy and paste. - * @param ev The original right click event to be handled. - * @param textarea The terminal's textarea. - * @param selectionService The terminal's selection manager. - * @param shouldSelectWord If true and there is no selection the current word will be selected - */ -export function rightClickHandler(ev: MouseEvent, textarea: HTMLTextAreaElement, screenElement: HTMLElement, selectionService: ISelectionService, shouldSelectWord: boolean): void { - moveTextAreaUnderMouseCursor(ev, textarea, screenElement); - - if (shouldSelectWord) { - selectionService.rightClickSelect(ev); - } - - // Get textarea ready to copy from the context menu - textarea.value = selectionService.selectionText; - textarea.select(); -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Color.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Color.ts deleted file mode 100755 index c43c5eb50..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Color.ts +++ /dev/null @@ -1,228 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IColor } from 'browser/Types'; - -/** - * Helper functions where the source type is "channels" (individual color channels as numbers). - */ -export namespace channels { - export function toCss(r: number, g: number, b: number, a?: number): string { - if (a !== undefined) { - return `#${toPaddedHex(r)}${toPaddedHex(g)}${toPaddedHex(b)}${toPaddedHex(a)}`; - } - return `#${toPaddedHex(r)}${toPaddedHex(g)}${toPaddedHex(b)}`; - } - - export function toRgba(r: number, g: number, b: number, a: number = 0xFF): number { - // >>> 0 forces an unsigned int - return (r << 24 | g << 16 | b << 8 | a) >>> 0; - } -} - -/** - * Helper functions where the source type is `IColor`. - */ -export namespace color { - export function blend(bg: IColor, fg: IColor): IColor { - const a = (fg.rgba & 0xFF) / 255; - if (a === 1) { - return { - css: fg.css, - rgba: fg.rgba - }; - } - const fgR = (fg.rgba >> 24) & 0xFF; - const fgG = (fg.rgba >> 16) & 0xFF; - const fgB = (fg.rgba >> 8) & 0xFF; - const bgR = (bg.rgba >> 24) & 0xFF; - const bgG = (bg.rgba >> 16) & 0xFF; - const bgB = (bg.rgba >> 8) & 0xFF; - const r = bgR + Math.round((fgR - bgR) * a); - const g = bgG + Math.round((fgG - bgG) * a); - const b = bgB + Math.round((fgB - bgB) * a); - const css = channels.toCss(r, g, b); - const rgba = channels.toRgba(r, g, b); - return { css, rgba }; - } - - export function isOpaque(color: IColor): boolean { - return (color.rgba & 0xFF) === 0xFF; - } - - export function ensureContrastRatio(bg: IColor, fg: IColor, ratio: number): IColor | undefined { - const result = rgba.ensureContrastRatio(bg.rgba, fg.rgba, ratio); - if (!result) { - return undefined; - } - return rgba.toColor( - (result >> 24 & 0xFF), - (result >> 16 & 0xFF), - (result >> 8 & 0xFF) - ); - } - - export function opaque(color: IColor): IColor { - const rgbaColor = (color.rgba | 0xFF) >>> 0; - const [r, g, b] = rgba.toChannels(rgbaColor); - return { - css: channels.toCss(r, g, b), - rgba: rgbaColor - }; - } - - export function opacity(color: IColor, opacity: number): IColor { - const a = Math.round(opacity * 0xFF); - const [r, g, b] = rgba.toChannels(color.rgba); - return { - css: channels.toCss(r, g, b, a), - rgba: channels.toRgba(r, g, b, a) - }; - } -} - -/** - * Helper functions where the source type is "css" (string: '#rgb', '#rgba', '#rrggbb', '#rrggbbaa'). - */ -export namespace css { - export function toColor(css: string): IColor { - switch (css.length) { - case 7: // #rrggbb - return { - css, - rgba: (parseInt(css.slice(1), 16) << 8 | 0xFF) >>> 0 - }; - case 9: // #rrggbbaa - return { - css, - rgba: parseInt(css.slice(1), 16) >>> 0 - }; - } - throw new Error('css.toColor: Unsupported css format'); - } -} - -/** - * Helper functions where the source type is "rgb" (number: 0xrrggbb). - */ -export namespace rgb { - /** - * Gets the relative luminance of an RGB color, this is useful in determining the contrast ratio - * between two colors. - * @param rgb The color to use. - * @see https://www.w3.org/TR/WCAG20/#relativeluminancedef - */ - export function relativeLuminance(rgb: number): number { - return relativeLuminance2( - (rgb >> 16) & 0xFF, - (rgb >> 8 ) & 0xFF, - (rgb ) & 0xFF); - } - - /** - * Gets the relative luminance of an RGB color, this is useful in determining the contrast ratio - * between two colors. - * @param r The red channel (0x00 to 0xFF). - * @param g The green channel (0x00 to 0xFF). - * @param b The blue channel (0x00 to 0xFF). - * @see https://www.w3.org/TR/WCAG20/#relativeluminancedef - */ - export function relativeLuminance2(r: number, g: number, b: number): number { - const rs = r / 255; - const gs = g / 255; - const bs = b / 255; - const rr = rs <= 0.03928 ? rs / 12.92 : Math.pow((rs + 0.055) / 1.055, 2.4); - const rg = gs <= 0.03928 ? gs / 12.92 : Math.pow((gs + 0.055) / 1.055, 2.4); - const rb = bs <= 0.03928 ? bs / 12.92 : Math.pow((bs + 0.055) / 1.055, 2.4); - return rr * 0.2126 + rg * 0.7152 + rb * 0.0722; - } -} - -/** - * Helper functions where the source type is "rgba" (number: 0xrrggbbaa). - */ -export namespace rgba { - export function ensureContrastRatio(bgRgba: number, fgRgba: number, ratio: number): number | undefined { - const bgL = rgb.relativeLuminance(bgRgba >> 8); - const fgL = rgb.relativeLuminance(fgRgba >> 8); - const cr = contrastRatio(bgL, fgL); - if (cr < ratio) { - if (fgL < bgL) { - return reduceLuminance(bgRgba, fgRgba, ratio); - } - return increaseLuminance(bgRgba, fgRgba, ratio); - } - return undefined; - } - - export function reduceLuminance(bgRgba: number, fgRgba: number, ratio: number): number { - // This is a naive but fast approach to reducing luminance as converting to - // HSL and back is expensive - const bgR = (bgRgba >> 24) & 0xFF; - const bgG = (bgRgba >> 16) & 0xFF; - const bgB = (bgRgba >> 8) & 0xFF; - let fgR = (fgRgba >> 24) & 0xFF; - let fgG = (fgRgba >> 16) & 0xFF; - let fgB = (fgRgba >> 8) & 0xFF; - let cr = contrastRatio(rgb.relativeLuminance2(fgR, fgB, fgG), rgb.relativeLuminance2(bgR, bgG, bgB)); - while (cr < ratio && (fgR > 0 || fgG > 0 || fgB > 0)) { - // Reduce by 10% until the ratio is hit - fgR -= Math.max(0, Math.ceil(fgR * 0.1)); - fgG -= Math.max(0, Math.ceil(fgG * 0.1)); - fgB -= Math.max(0, Math.ceil(fgB * 0.1)); - cr = contrastRatio(rgb.relativeLuminance2(fgR, fgB, fgG), rgb.relativeLuminance2(bgR, bgG, bgB)); - } - return (fgR << 24 | fgG << 16 | fgB << 8 | 0xFF) >>> 0; - } - - export function increaseLuminance(bgRgba: number, fgRgba: number, ratio: number): number { - // This is a naive but fast approach to increasing luminance as converting to - // HSL and back is expensive - const bgR = (bgRgba >> 24) & 0xFF; - const bgG = (bgRgba >> 16) & 0xFF; - const bgB = (bgRgba >> 8) & 0xFF; - let fgR = (fgRgba >> 24) & 0xFF; - let fgG = (fgRgba >> 16) & 0xFF; - let fgB = (fgRgba >> 8) & 0xFF; - let cr = contrastRatio(rgb.relativeLuminance2(fgR, fgB, fgG), rgb.relativeLuminance2(bgR, bgG, bgB)); - while (cr < ratio && (fgR < 0xFF || fgG < 0xFF || fgB < 0xFF)) { - // Increase by 10% until the ratio is hit - fgR = Math.min(0xFF, fgR + Math.ceil((255 - fgR) * 0.1)); - fgG = Math.min(0xFF, fgG + Math.ceil((255 - fgG) * 0.1)); - fgB = Math.min(0xFF, fgB + Math.ceil((255 - fgB) * 0.1)); - cr = contrastRatio(rgb.relativeLuminance2(fgR, fgB, fgG), rgb.relativeLuminance2(bgR, bgG, bgB)); - } - return (fgR << 24 | fgG << 16 | fgB << 8 | 0xFF) >>> 0; - } - - export function toChannels(value: number): [number, number, number, number] { - return [(value >> 24) & 0xFF, (value >> 16) & 0xFF, (value >> 8) & 0xFF, value & 0xFF]; - } - - export function toColor(r: number, g: number, b: number): IColor { - return { - css: channels.toCss(r, g, b), - rgba: channels.toRgba(r, g, b) - }; - } -} - -export function toPaddedHex(c: number): string { - const s = c.toString(16); - return s.length < 2 ? '0' + s : s; -} - -/** - * Gets the contrast ratio between two relative luminance values. - * @param l1 The first relative luminance. - * @param l2 The first relative luminance. - * @see https://www.w3.org/TR/WCAG20/#contrast-ratiodef - */ -export function contrastRatio(l1: number, l2: number): number { - if (l1 < l2) { - return (l2 + 0.05) / (l1 + 0.05); - } - return (l1 + 0.05) / (l2 + 0.05); -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/ColorContrastCache.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/ColorContrastCache.ts deleted file mode 100755 index b96b66cc4..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/ColorContrastCache.ts +++ /dev/null @@ -1,38 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IColor, IColorContrastCache } from 'browser/Types'; - -export class ColorContrastCache implements IColorContrastCache { - private _color: { [bg: number]: { [fg: number]: IColor | null | undefined } | undefined } = {}; - private _rgba: { [bg: number]: { [fg: number]: string | null | undefined } | undefined } = {}; - - public clear(): void { - this._color = {}; - this._rgba = {}; - } - - public setCss(bg: number, fg: number, value: string | null): void { - if (!this._rgba[bg]) { - this._rgba[bg] = {}; - } - this._rgba[bg]![fg] = value; - } - - public getCss(bg: number, fg: number): string | null | undefined { - return this._rgba[bg] ? this._rgba[bg]![fg] : undefined; - } - - public setColor(bg: number, fg: number, value: IColor | null): void { - if (!this._color[bg]) { - this._color[bg] = {}; - } - this._color[bg]![fg] = value; - } - - public getColor(bg: number, fg: number): IColor | null | undefined { - return this._color[bg] ? this._color[bg]![fg] : undefined; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/ColorManager.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/ColorManager.ts deleted file mode 100755 index b6950d282..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/ColorManager.ts +++ /dev/null @@ -1,213 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IColorManager, IColor, IColorSet, IColorContrastCache } from 'browser/Types'; -import { ITheme } from 'common/services/Services'; -import { channels, color, css } from 'browser/Color'; -import { ColorContrastCache } from 'browser/ColorContrastCache'; - -const DEFAULT_FOREGROUND = css.toColor('#ffffff'); -const DEFAULT_BACKGROUND = css.toColor('#000000'); -const DEFAULT_CURSOR = css.toColor('#ffffff'); -const DEFAULT_CURSOR_ACCENT = css.toColor('#000000'); -const DEFAULT_SELECTION = { - css: 'rgba(255, 255, 255, 0.3)', - rgba: 0xFFFFFF4D -}; - -// An IIFE to generate DEFAULT_ANSI_COLORS. -export const DEFAULT_ANSI_COLORS = Object.freeze((() => { - const colors = [ - // dark: - css.toColor('#2e3436'), - css.toColor('#cc0000'), - css.toColor('#4e9a06'), - css.toColor('#c4a000'), - css.toColor('#3465a4'), - css.toColor('#75507b'), - css.toColor('#06989a'), - css.toColor('#d3d7cf'), - // bright: - css.toColor('#555753'), - css.toColor('#ef2929'), - css.toColor('#8ae234'), - css.toColor('#fce94f'), - css.toColor('#729fcf'), - css.toColor('#ad7fa8'), - css.toColor('#34e2e2'), - css.toColor('#eeeeec') - ]; - - // Fill in the remaining 240 ANSI colors. - // Generate colors (16-231) - const v = [0x00, 0x5f, 0x87, 0xaf, 0xd7, 0xff]; - for (let i = 0; i < 216; i++) { - const r = v[(i / 36) % 6 | 0]; - const g = v[(i / 6) % 6 | 0]; - const b = v[i % 6]; - colors.push({ - css: channels.toCss(r, g, b), - rgba: channels.toRgba(r, g, b) - }); - } - - // Generate greys (232-255) - for (let i = 0; i < 24; i++) { - const c = 8 + i * 10; - colors.push({ - css: channels.toCss(c, c, c), - rgba: channels.toRgba(c, c, c) - }); - } - - return colors; -})()); - -/** - * Manages the source of truth for a terminal's colors. - */ -export class ColorManager implements IColorManager { - public colors: IColorSet; - private _ctx: CanvasRenderingContext2D; - private _litmusColor: CanvasGradient; - private _contrastCache: IColorContrastCache; - - constructor(document: Document, public allowTransparency: boolean) { - const canvas = document.createElement('canvas'); - canvas.width = 1; - canvas.height = 1; - const ctx = canvas.getContext('2d'); - if (!ctx) { - throw new Error('Could not get rendering context'); - } - this._ctx = ctx; - this._ctx.globalCompositeOperation = 'copy'; - this._litmusColor = this._ctx.createLinearGradient(0, 0, 1, 1); - this._contrastCache = new ColorContrastCache(); - this.colors = { - foreground: DEFAULT_FOREGROUND, - background: DEFAULT_BACKGROUND, - cursor: DEFAULT_CURSOR, - cursorAccent: DEFAULT_CURSOR_ACCENT, - selectionTransparent: DEFAULT_SELECTION, - selectionOpaque: color.blend(DEFAULT_BACKGROUND, DEFAULT_SELECTION), - ansi: DEFAULT_ANSI_COLORS.slice(), - contrastCache: this._contrastCache - }; - } - - public onOptionsChange(key: string): void { - if (key === 'minimumContrastRatio') { - this._contrastCache.clear(); - } - } - - /** - * Sets the terminal's theme. - * @param theme The theme to use. If a partial theme is provided then default - * colors will be used where colors are not defined. - */ - public setTheme(theme: ITheme = {}): void { - this.colors.foreground = this._parseColor(theme.foreground, DEFAULT_FOREGROUND); - this.colors.background = this._parseColor(theme.background, DEFAULT_BACKGROUND); - this.colors.cursor = this._parseColor(theme.cursor, DEFAULT_CURSOR, true); - this.colors.cursorAccent = this._parseColor(theme.cursorAccent, DEFAULT_CURSOR_ACCENT, true); - this.colors.selectionTransparent = this._parseColor(theme.selection, DEFAULT_SELECTION, true); - this.colors.selectionOpaque = color.blend(this.colors.background, this.colors.selectionTransparent); - /** - * If selection color is opaque, blend it with background with 0.3 opacity - * Issue #2737 - */ - if (color.isOpaque(this.colors.selectionTransparent)) { - const opacity = 0.3; - this.colors.selectionTransparent = color.opacity(this.colors.selectionTransparent, opacity); - } - this.colors.ansi[0] = this._parseColor(theme.black, DEFAULT_ANSI_COLORS[0]); - this.colors.ansi[1] = this._parseColor(theme.red, DEFAULT_ANSI_COLORS[1]); - this.colors.ansi[2] = this._parseColor(theme.green, DEFAULT_ANSI_COLORS[2]); - this.colors.ansi[3] = this._parseColor(theme.yellow, DEFAULT_ANSI_COLORS[3]); - this.colors.ansi[4] = this._parseColor(theme.blue, DEFAULT_ANSI_COLORS[4]); - this.colors.ansi[5] = this._parseColor(theme.magenta, DEFAULT_ANSI_COLORS[5]); - this.colors.ansi[6] = this._parseColor(theme.cyan, DEFAULT_ANSI_COLORS[6]); - this.colors.ansi[7] = this._parseColor(theme.white, DEFAULT_ANSI_COLORS[7]); - this.colors.ansi[8] = this._parseColor(theme.brightBlack, DEFAULT_ANSI_COLORS[8]); - this.colors.ansi[9] = this._parseColor(theme.brightRed, DEFAULT_ANSI_COLORS[9]); - this.colors.ansi[10] = this._parseColor(theme.brightGreen, DEFAULT_ANSI_COLORS[10]); - this.colors.ansi[11] = this._parseColor(theme.brightYellow, DEFAULT_ANSI_COLORS[11]); - this.colors.ansi[12] = this._parseColor(theme.brightBlue, DEFAULT_ANSI_COLORS[12]); - this.colors.ansi[13] = this._parseColor(theme.brightMagenta, DEFAULT_ANSI_COLORS[13]); - this.colors.ansi[14] = this._parseColor(theme.brightCyan, DEFAULT_ANSI_COLORS[14]); - this.colors.ansi[15] = this._parseColor(theme.brightWhite, DEFAULT_ANSI_COLORS[15]); - // Clear our the cache - this._contrastCache.clear(); - } - - private _parseColor( - css: string | undefined, - fallback: IColor, - allowTransparency: boolean = this.allowTransparency - ): IColor { - if (css === undefined) { - return fallback; - } - - // If parsing the value results in failure, then it must be ignored, and the attribute must - // retain its previous value. - // -- https://html.spec.whatwg.org/multipage/canvas.html#fill-and-stroke-styles - this._ctx.fillStyle = this._litmusColor; - this._ctx.fillStyle = css; - if (typeof this._ctx.fillStyle !== 'string') { - console.warn(`Color: ${css} is invalid using fallback ${fallback.css}`); - return fallback; - } - - this._ctx.fillRect(0, 0, 1, 1); - const data = this._ctx.getImageData(0, 0, 1, 1).data; - - // Check if the printed color was transparent - if (data[3] !== 0xFF) { - if (!allowTransparency) { - // Ideally we'd just ignore the alpha channel, but... - // - // Browsers may not give back exactly the same RGB values we put in, because most/all - // convert the color to a pre-multiplied representation. getImageData converts that back to - // a un-premultipled representation, but the precision loss may make the RGB channels unuable - // on their own. - // - // E.g. In Chrome #12345610 turns into #10305010, and in the extreme case, 0xFFFFFF00 turns - // into 0x00000000. - // - // "Note: Due to the lossy nature of converting to and from premultiplied alpha color values, - // pixels that have just been set using putImageData() might be returned to an equivalent - // getImageData() as different values." - // -- https://html.spec.whatwg.org/multipage/canvas.html#pixel-manipulation - // - // So let's just use the fallback color in this case instead. - console.warn( - `Color: ${css} is using transparency, but allowTransparency is false. ` + - `Using fallback ${fallback.css}.` - ); - return fallback; - } - - // https://html.spec.whatwg.org/multipage/canvas.html#serialisation-of-a-color - // the color value has alpha less than 1.0, and the string is the color value in the CSS rgba() - const [r, g, b, a] = this._ctx.fillStyle.substring(5, this._ctx.fillStyle.length - 1).split(',').map(component => Number(component)); - const alpha = Math.round(a * 255); - const rgba: number = channels.toRgba(r, g, b, alpha); - return { - rgba, - css - }; - } - - return { - // https://html.spec.whatwg.org/multipage/canvas.html#serialisation-of-a-color - // if it has alpha equal to 1.0, then the string is a lowercase six-digit hex value, prefixed with a "#" character - css: this._ctx.fillStyle, - rgba: channels.toRgba(data[0], data[1], data[2], data[3]) - }; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Dom.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Dom.ts deleted file mode 100755 index c558a8b1b..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Dom.ts +++ /dev/null @@ -1,10 +0,0 @@ -/** - * Copyright (c) 2020 The xterm.js authors. All rights reserved. - * @license MIT - */ - -export function removeElementFromParent(...elements: (HTMLElement | undefined)[]): void { - for (const e of elements) { - e?.parentElement?.removeChild(e); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Lifecycle.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Lifecycle.ts deleted file mode 100755 index 6e841794f..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Lifecycle.ts +++ /dev/null @@ -1,30 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IDisposable } from 'common/Types'; - -/** - * Adds a disposable listener to a node in the DOM, returning the disposable. - * @param type The event type. - * @param handler The handler for the listener. - */ -export function addDisposableDomListener( - node: Element | Window | Document, - type: string, - handler: (e: any) => void, - options?: boolean | AddEventListenerOptions -): IDisposable { - node.addEventListener(type, handler, options); - let disposed = false; - return { - dispose: () => { - if (disposed) { - return; - } - disposed = true; - node.removeEventListener(type, handler, options); - } - }; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Linkifier.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Linkifier.ts deleted file mode 100755 index 6d25e7303..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Linkifier.ts +++ /dev/null @@ -1,354 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ILinkifierEvent, ILinkMatcher, LinkMatcherHandler, ILinkMatcherOptions, ILinkifier, IMouseZoneManager, IMouseZone, IRegisteredLinkMatcher } from 'browser/Types'; -import { IBufferStringIteratorResult } from 'common/buffer/Types'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { ILogService, IBufferService, IOptionsService, IUnicodeService } from 'common/services/Services'; - -/** - * Limit of the unwrapping line expansion (overscan) at the top and bottom - * of the actual viewport in ASCII characters. - * A limit of 2000 should match most sane urls. - */ -const OVERSCAN_CHAR_LIMIT = 2000; - -/** - * The Linkifier applies links to rows shortly after they have been refreshed. - */ -export class Linkifier implements ILinkifier { - /** - * The time to wait after a row is changed before it is linkified. This prevents - * the costly operation of searching every row multiple times, potentially a - * huge amount of times. - */ - protected static _timeBeforeLatency = 200; - - protected _linkMatchers: IRegisteredLinkMatcher[] = []; - - private _mouseZoneManager: IMouseZoneManager | undefined; - private _element: HTMLElement | undefined; - - private _rowsTimeoutId: number | undefined; - private _nextLinkMatcherId = 0; - private _rowsToLinkify: { start: number | undefined, end: number | undefined }; - - private _onShowLinkUnderline = new EventEmitter(); - public get onShowLinkUnderline(): IEvent { return this._onShowLinkUnderline.event; } - private _onHideLinkUnderline = new EventEmitter(); - public get onHideLinkUnderline(): IEvent { return this._onHideLinkUnderline.event; } - private _onLinkTooltip = new EventEmitter(); - public get onLinkTooltip(): IEvent { return this._onLinkTooltip.event; } - - constructor( - @IBufferService protected readonly _bufferService: IBufferService, - @ILogService private readonly _logService: ILogService, - @IUnicodeService private readonly _unicodeService: IUnicodeService - ) { - this._rowsToLinkify = { - start: undefined, - end: undefined - }; - } - - /** - * Attaches the linkifier to the DOM, enabling linkification. - * @param mouseZoneManager The mouse zone manager to register link zones with. - */ - public attachToDom(element: HTMLElement, mouseZoneManager: IMouseZoneManager): void { - this._element = element; - this._mouseZoneManager = mouseZoneManager; - } - - /** - * Queue linkification on a set of rows. - * @param start The row to linkify from (inclusive). - * @param end The row to linkify to (inclusive). - */ - public linkifyRows(start: number, end: number): void { - // Don't attempt linkify if not yet attached to DOM - if (!this._mouseZoneManager) { - return; - } - - // Increase range to linkify - if (this._rowsToLinkify.start === undefined || this._rowsToLinkify.end === undefined) { - this._rowsToLinkify.start = start; - this._rowsToLinkify.end = end; - } else { - this._rowsToLinkify.start = Math.min(this._rowsToLinkify.start, start); - this._rowsToLinkify.end = Math.max(this._rowsToLinkify.end, end); - } - - // Clear out any existing links on this row range - this._mouseZoneManager.clearAll(start, end); - - // Restart timer - if (this._rowsTimeoutId) { - clearTimeout(this._rowsTimeoutId); - } - this._rowsTimeoutId = setTimeout(() => this._linkifyRows(), Linkifier._timeBeforeLatency); - } - - /** - * Linkifies the rows requested. - */ - private _linkifyRows(): void { - this._rowsTimeoutId = undefined; - const buffer = this._bufferService.buffer; - - if (this._rowsToLinkify.start === undefined || this._rowsToLinkify.end === undefined) { - this._logService.debug('_rowToLinkify was unset before _linkifyRows was called'); - return; - } - - // Ensure the start row exists - const absoluteRowIndexStart = buffer.ydisp + this._rowsToLinkify.start; - if (absoluteRowIndexStart >= buffer.lines.length) { - return; - } - - // Invalidate bad end row values (if a resize happened) - const absoluteRowIndexEnd = buffer.ydisp + Math.min(this._rowsToLinkify.end, this._bufferService.rows) + 1; - - // Iterate over the range of unwrapped content strings within start..end - // (excluding). - // _doLinkifyRow gets full unwrapped lines with the start row as buffer offset - // for every matcher. - // The unwrapping is needed to also match content that got wrapped across - // several buffer lines. To avoid a worst case scenario where the whole buffer - // contains just a single unwrapped string we limit this line expansion beyond - // the viewport to +OVERSCAN_CHAR_LIMIT chars (overscan) at top and bottom. - // This comes with the tradeoff that matches longer than OVERSCAN_CHAR_LIMIT - // chars will not match anymore at the viewport borders. - const overscanLineLimit = Math.ceil(OVERSCAN_CHAR_LIMIT / this._bufferService.cols); - const iterator = this._bufferService.buffer.iterator( - false, absoluteRowIndexStart, absoluteRowIndexEnd, overscanLineLimit, overscanLineLimit); - while (iterator.hasNext()) { - const lineData: IBufferStringIteratorResult = iterator.next(); - for (let i = 0; i < this._linkMatchers.length; i++) { - this._doLinkifyRow(lineData.range.first, lineData.content, this._linkMatchers[i]); - } - } - - this._rowsToLinkify.start = undefined; - this._rowsToLinkify.end = undefined; - } - - /** - * Registers a link matcher, allowing custom link patterns to be matched and - * handled. - * @param regex The regular expression to search for. Specifically, this - * searches the textContent of the rows. You will want to use \s to match a - * space ' ' character for example. - * @param handler The callback when the link is called. - * @param options Options for the link matcher. - * @return The ID of the new matcher, this can be used to deregister. - */ - public registerLinkMatcher(regex: RegExp, handler: LinkMatcherHandler, options: ILinkMatcherOptions = {}): number { - if (!handler) { - throw new Error('handler must be defined'); - } - const matcher: IRegisteredLinkMatcher = { - id: this._nextLinkMatcherId++, - regex, - handler, - matchIndex: options.matchIndex, - validationCallback: options.validationCallback, - hoverTooltipCallback: options.tooltipCallback, - hoverLeaveCallback: options.leaveCallback, - willLinkActivate: options.willLinkActivate, - priority: options.priority || 0 - }; - this._addLinkMatcherToList(matcher); - return matcher.id; - } - - /** - * Inserts a link matcher to the list in the correct position based on the - * priority of each link matcher. New link matchers of equal priority are - * considered after older link matchers. - * @param matcher The link matcher to be added. - */ - private _addLinkMatcherToList(matcher: IRegisteredLinkMatcher): void { - if (this._linkMatchers.length === 0) { - this._linkMatchers.push(matcher); - return; - } - - for (let i = this._linkMatchers.length - 1; i >= 0; i--) { - if (matcher.priority <= this._linkMatchers[i].priority) { - this._linkMatchers.splice(i + 1, 0, matcher); - return; - } - } - - this._linkMatchers.splice(0, 0, matcher); - } - - /** - * Deregisters a link matcher if it has been registered. - * @param matcherId The link matcher's ID (returned after register) - * @return Whether a link matcher was found and deregistered. - */ - public deregisterLinkMatcher(matcherId: number): boolean { - for (let i = 0; i < this._linkMatchers.length; i++) { - if (this._linkMatchers[i].id === matcherId) { - this._linkMatchers.splice(i, 1); - return true; - } - } - return false; - } - - /** - * Linkifies a row given a specific handler. - * @param rowIndex The row index to linkify (absolute index). - * @param text string content of the unwrapped row. - * @param matcher The link matcher for this line. - */ - private _doLinkifyRow(rowIndex: number, text: string, matcher: ILinkMatcher): void { - // clone regex to do a global search on text - const rex = new RegExp(matcher.regex.source, (matcher.regex.flags || '') + 'g'); - let match; - let stringIndex = -1; - while ((match = rex.exec(text)) !== null) { - const uri = match[typeof matcher.matchIndex !== 'number' ? 0 : matcher.matchIndex]; - if (!uri) { - // something matched but does not comply with the given matchIndex - // since this is most likely a bug the regex itself we simply do nothing here - this._logService.debug('match found without corresponding matchIndex', match, matcher); - break; - } - - // Get index, match.index is for the outer match which includes negated chars - // therefore we cannot use match.index directly, instead we search the position - // of the match group in text again - // also correct regex and string search offsets for the next loop run - stringIndex = text.indexOf(uri, stringIndex + 1); - rex.lastIndex = stringIndex + uri.length; - if (stringIndex < 0) { - // invalid stringIndex (should not have happened) - break; - } - - // get the buffer index as [absolute row, col] for the match - const bufferIndex = this._bufferService.buffer.stringIndexToBufferIndex(rowIndex, stringIndex); - if (bufferIndex[0] < 0) { - // invalid bufferIndex (should not have happened) - break; - } - - const line = this._bufferService.buffer.lines.get(bufferIndex[0]); - if (!line) { - break; - } - - const attr = line.getFg(bufferIndex[1]); - const fg = attr ? (attr >> 9) & 0x1ff : undefined; - - if (matcher.validationCallback) { - matcher.validationCallback(uri, isValid => { - // Discard link if the line has already changed - if (this._rowsTimeoutId) { - return; - } - if (isValid) { - this._addLink(bufferIndex[1], bufferIndex[0] - this._bufferService.buffer.ydisp, uri, matcher, fg); - } - }); - } else { - this._addLink(bufferIndex[1], bufferIndex[0] - this._bufferService.buffer.ydisp, uri, matcher, fg); - } - } - } - - /** - * Registers a link to the mouse zone manager. - * @param x The column the link starts. - * @param y The row the link is on. - * @param uri The URI of the link. - * @param matcher The link matcher for the link. - * @param fg The link color for hover event. - */ - private _addLink(x: number, y: number, uri: string, matcher: ILinkMatcher, fg: number | undefined): void { - if (!this._mouseZoneManager || !this._element) { - return; - } - // FIXME: get cell length from buffer to avoid mismatch after Unicode version change - const width = this._unicodeService.getStringCellWidth(uri); - const x1 = x % this._bufferService.cols; - const y1 = y + Math.floor(x / this._bufferService.cols); - let x2 = (x1 + width) % this._bufferService.cols; - let y2 = y1 + Math.floor((x1 + width) / this._bufferService.cols); - if (x2 === 0) { - x2 = this._bufferService.cols; - y2--; - } - - this._mouseZoneManager.add(new MouseZone( - x1 + 1, - y1 + 1, - x2 + 1, - y2 + 1, - e => { - if (matcher.handler) { - return matcher.handler(e, uri); - } - const newWindow = window.open(); - if (newWindow) { - newWindow.opener = null; - newWindow.location.href = uri; - } else { - console.warn('Opening link blocked as opener could not be cleared'); - } - }, - () => { - this._onShowLinkUnderline.fire(this._createLinkHoverEvent(x1, y1, x2, y2, fg)); - this._element!.classList.add('xterm-cursor-pointer'); - }, - e => { - this._onLinkTooltip.fire(this._createLinkHoverEvent(x1, y1, x2, y2, fg)); - if (matcher.hoverTooltipCallback) { - // Note that IViewportRange use 1-based coordinates to align with escape sequences such - // as CUP which use 1,1 as the default for row/col - matcher.hoverTooltipCallback(e, uri, { start: { x: x1, y: y1 }, end: { x: x2, y: y2 } }); - } - }, - () => { - this._onHideLinkUnderline.fire(this._createLinkHoverEvent(x1, y1, x2, y2, fg)); - this._element!.classList.remove('xterm-cursor-pointer'); - if (matcher.hoverLeaveCallback) { - matcher.hoverLeaveCallback(); - } - }, - e => { - if (matcher.willLinkActivate) { - return matcher.willLinkActivate(e, uri); - } - return true; - } - )); - } - - private _createLinkHoverEvent(x1: number, y1: number, x2: number, y2: number, fg: number | undefined): ILinkifierEvent { - return { x1, y1, x2, y2, cols: this._bufferService.cols, fg }; - } -} - -export class MouseZone implements IMouseZone { - constructor( - public x1: number, - public y1: number, - public x2: number, - public y2: number, - public clickCallback: (e: MouseEvent) => any, - public hoverCallback: (e: MouseEvent) => any, - public tooltipCallback: (e: MouseEvent) => any, - public leaveCallback: () => void, - public willLinkActivate: (e: MouseEvent) => boolean - ) { - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Linkifier2.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Linkifier2.ts deleted file mode 100755 index 73ea02689..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Linkifier2.ts +++ /dev/null @@ -1,401 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ILinkifier2, ILinkProvider, IBufferCellPosition, ILink, ILinkifierEvent, ILinkDecorations } from 'browser/Types'; -import { IDisposable } from 'common/Types'; -import { IMouseService, IRenderService } from './services/Services'; -import { IBufferService } from 'common/services/Services'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { Disposable, getDisposeArrayDisposable, disposeArray } from 'common/Lifecycle'; -import { addDisposableDomListener } from 'browser/Lifecycle'; - -interface ILinkState { - decorations: ILinkDecorations; - isHovered: boolean; -} - -interface ILinkWithState { - link: ILink; - state?: ILinkState; -} - -export class Linkifier2 extends Disposable implements ILinkifier2 { - private _element: HTMLElement | undefined; - private _mouseService: IMouseService | undefined; - private _renderService: IRenderService | undefined; - private _linkProviders: ILinkProvider[] = []; - protected _currentLink: ILinkWithState | undefined; - private _lastMouseEvent: MouseEvent | undefined; - private _linkCacheDisposables: IDisposable[] = []; - private _lastBufferCell: IBufferCellPosition | undefined; - private _isMouseOut: boolean = true; - private _activeProviderReplies: Map | undefined; - private _activeLine: number = -1; - - private _onShowLinkUnderline = this.register(new EventEmitter()); - public get onShowLinkUnderline(): IEvent { return this._onShowLinkUnderline.event; } - private _onHideLinkUnderline = this.register(new EventEmitter()); - public get onHideLinkUnderline(): IEvent { return this._onHideLinkUnderline.event; } - - constructor( - @IBufferService private readonly _bufferService: IBufferService - ) { - super(); - this.register(getDisposeArrayDisposable(this._linkCacheDisposables)); - } - - public registerLinkProvider(linkProvider: ILinkProvider): IDisposable { - this._linkProviders.push(linkProvider); - return { - dispose: () => { - // Remove the link provider from the list - const providerIndex = this._linkProviders.indexOf(linkProvider); - - if (providerIndex !== -1) { - this._linkProviders.splice(providerIndex, 1); - } - } - }; - } - - public attachToDom(element: HTMLElement, mouseService: IMouseService, renderService: IRenderService): void { - this._element = element; - this._mouseService = mouseService; - this._renderService = renderService; - - this.register(addDisposableDomListener(this._element, 'mouseleave', () => { - this._isMouseOut = true; - this._clearCurrentLink(); - })); - this.register(addDisposableDomListener(this._element, 'mousemove', this._onMouseMove.bind(this))); - this.register(addDisposableDomListener(this._element, 'click', this._onClick.bind(this))); - } - - private _onMouseMove(event: MouseEvent): void { - this._lastMouseEvent = event; - - if (!this._element || !this._mouseService) { - return; - } - - const position = this._positionFromMouseEvent(event, this._element, this._mouseService); - if (!position) { - return; - } - this._isMouseOut = false; - - // Ignore the event if it's an embedder created hover widget - const composedPath = event.composedPath() as HTMLElement[]; - for (let i = 0; i < composedPath.length; i++) { - const target = composedPath[i]; - // Hit Terminal.element, break and continue - if (target.classList.contains('xterm')) { - break; - } - // It's a hover, don't respect hover event - if (target.classList.contains('xterm-hover')) { - return; - } - } - - if (!this._lastBufferCell || (position.x !== this._lastBufferCell.x || position.y !== this._lastBufferCell.y)) { - this._onHover(position); - this._lastBufferCell = position; - } - } - - private _onHover(position: IBufferCellPosition): void { - // TODO: This currently does not cache link provider results across wrapped lines, activeLine should be something like `activeRange: {startY, endY}` - // Check if we need to clear the link - if (this._activeLine !== position.y) { - this._clearCurrentLink(); - this._askForLink(position, false); - return; - } - - // Check the if the link is in the mouse position - const isCurrentLinkInPosition = this._currentLink && this._linkAtPosition(this._currentLink.link, position); - if (!isCurrentLinkInPosition) { - this._clearCurrentLink(); - this._askForLink(position, true); - } - } - - private _askForLink(position: IBufferCellPosition, useLineCache: boolean): void { - if (!this._activeProviderReplies || !useLineCache) { - this._activeProviderReplies?.forEach(reply => { - reply?.forEach(linkWithState => { - if (linkWithState.link.dispose) { - linkWithState.link.dispose(); - } - }); - }); - this._activeProviderReplies = new Map(); - this._activeLine = position.y; - } - let linkProvided = false; - - // There is no link cached, so ask for one - this._linkProviders.forEach((linkProvider, i) => { - if (useLineCache) { - const existingReply = this._activeProviderReplies?.get(i); - // If there isn't a reply, the provider hasn't responded yet. - - // TODO: If there isn't a reply yet it means that the provider is still resolving. Ensuring - // provideLinks isn't triggered again saves ILink.hover firing twice though. This probably - // needs promises to get fixed - if (existingReply) { - linkProvided = this._checkLinkProviderResult(i, position, linkProvided); - } - } else { - linkProvider.provideLinks(position.y, (links: ILink[] | undefined) => { - if (this._isMouseOut) { - return; - } - const linksWithState: ILinkWithState[] | undefined = links?.map(link => ({ link })); - this._activeProviderReplies?.set(i, linksWithState); - linkProvided = this._checkLinkProviderResult(i, position, linkProvided); - - // If all providers have responded, remove lower priority links that intersect ranges of - // higher priority links - if (this._activeProviderReplies?.size === this._linkProviders.length) { - this._removeIntersectingLinks(position.y, this._activeProviderReplies); - } - }); - } - }); - } - - private _removeIntersectingLinks(y: number, replies: Map): void { - const occupiedCells = new Set(); - for (let i = 0; i < replies.size; i++) { - const providerReply = replies.get(i); - if (!providerReply) { - continue; - } - for (let i = 0; i < providerReply.length; i++) { - const linkWithState = providerReply[i]; - const startX = linkWithState.link.range.start.y < y ? 0 : linkWithState.link.range.start.x; - const endX = linkWithState.link.range.end.y > y ? this._bufferService.cols : linkWithState.link.range.end.x; - for (let x = startX; x <= endX; x++) { - if (occupiedCells.has(x)) { - providerReply.splice(i--, 1); - break; - } - occupiedCells.add(x); - } - } - } - } - - private _checkLinkProviderResult(index: number, position: IBufferCellPosition, linkProvided: boolean): boolean { - if (!this._activeProviderReplies) { - return linkProvided; - } - - const links = this._activeProviderReplies.get(index); - - // Check if every provider before this one has come back undefined - let hasLinkBefore = false; - for (let j = 0; j < index; j++) { - if (!this._activeProviderReplies.has(j) || this._activeProviderReplies.get(j)) { - hasLinkBefore = true; - } - } - - // If all providers with higher priority came back undefined, then this provider's link for - // the position should be used - if (!hasLinkBefore && links) { - const linkAtPosition = links.find(link => this._linkAtPosition(link.link, position)); - if (linkAtPosition) { - linkProvided = true; - this._handleNewLink(linkAtPosition); - } - } - - // Check if all the providers have responded - if (this._activeProviderReplies.size === this._linkProviders.length && !linkProvided) { - // Respect the order of the link providers - for (let j = 0; j < this._activeProviderReplies.size; j++) { - const currentLink = this._activeProviderReplies.get(j)?.find(link => this._linkAtPosition(link.link, position)); - if (currentLink) { - linkProvided = true; - this._handleNewLink(currentLink); - break; - } - } - } - - return linkProvided; - } - - private _onClick(event: MouseEvent): void { - if (!this._element || !this._mouseService || !this._currentLink) { - return; - } - - const position = this._positionFromMouseEvent(event, this._element, this._mouseService); - - if (!position) { - return; - } - - if (this._linkAtPosition(this._currentLink.link, position)) { - this._currentLink.link.activate(event, this._currentLink.link.text); - } - } - - private _clearCurrentLink(startRow?: number, endRow?: number): void { - if (!this._element || !this._currentLink || !this._lastMouseEvent) { - return; - } - - // If we have a start and end row, check that the link is within it - if (!startRow || !endRow || (this._currentLink.link.range.start.y >= startRow && this._currentLink.link.range.end.y <= endRow)) { - this._linkLeave(this._element, this._currentLink.link, this._lastMouseEvent); - this._currentLink = undefined; - disposeArray(this._linkCacheDisposables); - } - } - - private _handleNewLink(linkWithState: ILinkWithState): void { - if (!this._element || !this._lastMouseEvent || !this._mouseService) { - return; - } - - const position = this._positionFromMouseEvent(this._lastMouseEvent, this._element, this._mouseService); - - if (!position) { - return; - } - - // Trigger hover if the we have a link at the position - if (this._linkAtPosition(linkWithState.link, position)) { - this._currentLink = linkWithState; - this._currentLink.state = { - decorations: { - underline: linkWithState.link.decorations === undefined ? true : linkWithState.link.decorations.underline, - pointerCursor: linkWithState.link.decorations === undefined ? true : linkWithState.link.decorations.pointerCursor - }, - isHovered: true - }; - this._linkHover(this._element, linkWithState.link, this._lastMouseEvent); - - // Add listener for tracking decorations changes - linkWithState.link.decorations = {} as ILinkDecorations; - Object.defineProperties(linkWithState.link.decorations, { - pointerCursor: { - get: () => this._currentLink?.state?.decorations.pointerCursor, - set: v => { - if (this._currentLink?.state && this._currentLink.state.decorations.pointerCursor !== v) { - this._currentLink.state.decorations.pointerCursor = v; - if (this._currentLink.state.isHovered) { - this._element?.classList.toggle('xterm-cursor-pointer', v); - } - } - } - }, - underline: { - get: () => this._currentLink?.state?.decorations.underline, - set: v => { - if (this._currentLink?.state && this._currentLink?.state?.decorations.underline !== v) { - this._currentLink.state.decorations.underline = v; - if (this._currentLink.state.isHovered) { - this._fireUnderlineEvent(linkWithState.link, v); - } - } - } - } - }); - - // Add listener for rerendering - if (this._renderService) { - this._linkCacheDisposables.push(this._renderService.onRenderedBufferChange(e => { - // When start is 0 a scroll most likely occurred, make sure links above the fold also get - // cleared. - const start = e.start === 0 ? 0 : e.start + 1 + this._bufferService.buffer.ydisp; - this._clearCurrentLink(start, e.end + 1 + this._bufferService.buffer.ydisp); - })); - } - } - } - - protected _linkHover(element: HTMLElement, link: ILink, event: MouseEvent): void { - if (this._currentLink?.state) { - this._currentLink.state.isHovered = true; - if (this._currentLink.state.decorations.underline) { - this._fireUnderlineEvent(link, true); - } - if (this._currentLink.state.decorations.pointerCursor) { - element.classList.add('xterm-cursor-pointer'); - } - } - - if (link.hover) { - link.hover(event, link.text); - } - } - - private _fireUnderlineEvent(link: ILink, showEvent: boolean): void { - const range = link.range; - const scrollOffset = this._bufferService.buffer.ydisp; - const event = this._createLinkUnderlineEvent(range.start.x - 1, range.start.y - scrollOffset - 1, range.end.x, range.end.y - scrollOffset - 1, undefined); - const emitter = showEvent ? this._onShowLinkUnderline : this._onHideLinkUnderline; - emitter.fire(event); - } - - protected _linkLeave(element: HTMLElement, link: ILink, event: MouseEvent): void { - if (this._currentLink?.state) { - this._currentLink.state.isHovered = false; - if (this._currentLink.state.decorations.underline) { - this._fireUnderlineEvent(link, false); - } - if (this._currentLink.state.decorations.pointerCursor) { - element.classList.remove('xterm-cursor-pointer'); - } - } - - if (link.leave) { - link.leave(event, link.text); - } - } - - /** - * Check if the buffer position is within the link - * @param link - * @param position - */ - private _linkAtPosition(link: ILink, position: IBufferCellPosition): boolean { - const sameLine = link.range.start.y === link.range.end.y; - const wrappedFromLeft = link.range.start.y < position.y; - const wrappedToRight = link.range.end.y > position.y; - - // If the start and end have the same y, then the position must be between start and end x - // If not, then handle each case seperately, depending on which way it wraps - return ((sameLine && link.range.start.x <= position.x && link.range.end.x >= position.x) || - (wrappedFromLeft && link.range.end.x >= position.x) || - (wrappedToRight && link.range.start.x <= position.x) || - (wrappedFromLeft && wrappedToRight)) && - link.range.start.y <= position.y && - link.range.end.y >= position.y; - } - - /** - * Get the buffer position from a mouse event - * @param event - */ - private _positionFromMouseEvent(event: MouseEvent, element: HTMLElement, mouseService: IMouseService): IBufferCellPosition | undefined { - const coords = mouseService.getCoords(event, element, this._bufferService.cols, this._bufferService.rows); - if (!coords) { - return; - } - - return { x: coords[0], y: coords[1] + this._bufferService.buffer.ydisp }; - } - - private _createLinkUnderlineEvent(x1: number, y1: number, x2: number, y2: number, fg: number | undefined): ILinkifierEvent { - return { x1, y1, x2, y2, cols: this._bufferService.cols, fg }; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/LocalizableStrings.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/LocalizableStrings.ts deleted file mode 100755 index c0a904cbc..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/LocalizableStrings.ts +++ /dev/null @@ -1,10 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -// eslint-disable-next-line prefer-const -export let promptLabel = 'Terminal input'; - -// eslint-disable-next-line prefer-const -export let tooMuchOutput = 'Too much output to announce, navigate to rows manually to read'; diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/MouseZoneManager.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/MouseZoneManager.ts deleted file mode 100755 index 59b6b0f1d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/MouseZoneManager.ts +++ /dev/null @@ -1,238 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { Disposable } from 'common/Lifecycle'; -import { addDisposableDomListener } from 'browser/Lifecycle'; -import { IMouseService, ISelectionService } from 'browser/services/Services'; -import { IMouseZoneManager, IMouseZone } from 'browser/Types'; -import { IBufferService, IOptionsService } from 'common/services/Services'; - -/** - * The MouseZoneManager allows components to register zones within the terminal - * that trigger hover and click callbacks. - * - * This class was intentionally made not so robust initially as the only case it - * needed to support was single-line links which never overlap. Improvements can - * be made in the future. - */ -export class MouseZoneManager extends Disposable implements IMouseZoneManager { - private _zones: IMouseZone[] = []; - - private _areZonesActive: boolean = false; - private _mouseMoveListener: (e: MouseEvent) => any; - private _mouseLeaveListener: (e: MouseEvent) => any; - private _clickListener: (e: MouseEvent) => any; - - private _tooltipTimeout: number | undefined; - private _currentZone: IMouseZone | undefined; - private _lastHoverCoords: [number | undefined, number | undefined] = [undefined, undefined]; - private _initialSelectionLength: number = 0; - - constructor( - private readonly _element: HTMLElement, - private readonly _screenElement: HTMLElement, - @IBufferService private readonly _bufferService: IBufferService, - @IMouseService private readonly _mouseService: IMouseService, - @ISelectionService private readonly _selectionService: ISelectionService, - @IOptionsService private readonly _optionsService: IOptionsService - ) { - super(); - - this.register(addDisposableDomListener(this._element, 'mousedown', e => this._onMouseDown(e))); - - // These events are expensive, only listen to it when mouse zones are active - this._mouseMoveListener = e => this._onMouseMove(e); - this._mouseLeaveListener = e => this._onMouseLeave(e); - this._clickListener = e => this._onClick(e); - } - - public dispose(): void { - super.dispose(); - this._deactivate(); - } - - public add(zone: IMouseZone): void { - this._zones.push(zone); - if (this._zones.length === 1) { - this._activate(); - } - } - - public clearAll(start?: number, end?: number): void { - // Exit if there's nothing to clear - if (this._zones.length === 0) { - return; - } - - // Clear all if start/end weren't set - if (!start || !end) { - start = 0; - end = this._bufferService.rows - 1; - } - - // Iterate through zones and clear them out if they're within the range - for (let i = 0; i < this._zones.length; i++) { - const zone = this._zones[i]; - if ((zone.y1 > start && zone.y1 <= end + 1) || - (zone.y2 > start && zone.y2 <= end + 1) || - (zone.y1 < start && zone.y2 > end + 1)) { - if (this._currentZone && this._currentZone === zone) { - this._currentZone.leaveCallback(); - this._currentZone = undefined; - } - this._zones.splice(i--, 1); - } - } - - // Deactivate the mouse zone manager if all the zones have been removed - if (this._zones.length === 0) { - this._deactivate(); - } - } - - private _activate(): void { - if (!this._areZonesActive) { - this._areZonesActive = true; - this._element.addEventListener('mousemove', this._mouseMoveListener); - this._element.addEventListener('mouseleave', this._mouseLeaveListener); - this._element.addEventListener('click', this._clickListener); - } - } - - private _deactivate(): void { - if (this._areZonesActive) { - this._areZonesActive = false; - this._element.removeEventListener('mousemove', this._mouseMoveListener); - this._element.removeEventListener('mouseleave', this._mouseLeaveListener); - this._element.removeEventListener('click', this._clickListener); - } - } - - private _onMouseMove(e: MouseEvent): void { - // TODO: Ideally this would only clear the hover state when the mouse moves - // outside of the mouse zone - if (this._lastHoverCoords[0] !== e.pageX || this._lastHoverCoords[1] !== e.pageY) { - this._onHover(e); - // Record the current coordinates - this._lastHoverCoords = [e.pageX, e.pageY]; - } - } - - private _onHover(e: MouseEvent): void { - const zone = this._findZoneEventAt(e); - - // Do nothing if the zone is the same - if (zone === this._currentZone) { - return; - } - - // Fire the hover end callback and cancel any existing timer if a new zone - // is being hovered - if (this._currentZone) { - this._currentZone.leaveCallback(); - this._currentZone = undefined; - if (this._tooltipTimeout) { - clearTimeout(this._tooltipTimeout); - } - } - - // Exit if there is not zone - if (!zone) { - return; - } - this._currentZone = zone; - - // Trigger the hover callback - if (zone.hoverCallback) { - zone.hoverCallback(e); - } - - // Restart the tooltip timeout - this._tooltipTimeout = window.setTimeout(() => this._onTooltip(e), this._optionsService.options.linkTooltipHoverDuration); - } - - private _onTooltip(e: MouseEvent): void { - this._tooltipTimeout = undefined; - const zone = this._findZoneEventAt(e); - if (zone && zone.tooltipCallback) { - zone.tooltipCallback(e); - } - } - - private _onMouseDown(e: MouseEvent): void { - // Store current terminal selection length, to check if we're performing - // a selection operation - this._initialSelectionLength = this._getSelectionLength(); - - // Ignore the event if there are no zones active - if (!this._areZonesActive) { - return; - } - - // Find the active zone, prevent event propagation if found to prevent other - // components from handling the mouse event. - const zone = this._findZoneEventAt(e); - if (zone?.willLinkActivate(e)) { - e.preventDefault(); - e.stopImmediatePropagation(); - } - } - - private _onMouseLeave(e: MouseEvent): void { - // Fire the hover end callback and cancel any existing timer if the mouse - // leaves the terminal element - if (this._currentZone) { - this._currentZone.leaveCallback(); - this._currentZone = undefined; - if (this._tooltipTimeout) { - clearTimeout(this._tooltipTimeout); - } - } - } - - private _onClick(e: MouseEvent): void { - // Find the active zone and click it if found and no selection was - // being performed - const zone = this._findZoneEventAt(e); - const currentSelectionLength = this._getSelectionLength(); - - if (zone && currentSelectionLength === this._initialSelectionLength) { - zone.clickCallback(e); - e.preventDefault(); - e.stopImmediatePropagation(); - } - } - - private _getSelectionLength(): number { - const selectionText = this._selectionService.selectionText; - return selectionText ? selectionText.length : 0; - } - - private _findZoneEventAt(e: MouseEvent): IMouseZone | undefined { - const coords = this._mouseService.getCoords(e, this._screenElement, this._bufferService.cols, this._bufferService.rows); - if (!coords) { - return undefined; - } - const x = coords[0]; - const y = coords[1]; - for (let i = 0; i < this._zones.length; i++) { - const zone = this._zones[i]; - if (zone.y1 === zone.y2) { - // Single line link - if (y === zone.y1 && x >= zone.x1 && x < zone.x2) { - return zone; - } - } else { - // Multi-line link - if ((y === zone.y1 && x >= zone.x1) || - (y === zone.y2 && x < zone.x2) || - (y > zone.y1 && y < zone.y2)) { - return zone; - } - } - } - return undefined; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/RenderDebouncer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/RenderDebouncer.ts deleted file mode 100755 index 2a06fdd66..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/RenderDebouncer.ts +++ /dev/null @@ -1,63 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IDisposable } from 'common/Types'; - -/** - * Debounces calls to render terminal rows using animation frames. - */ -export class RenderDebouncer implements IDisposable { - private _rowStart: number | undefined; - private _rowEnd: number | undefined; - private _rowCount: number | undefined; - private _animationFrame: number | undefined; - - constructor( - private _renderCallback: (start: number, end: number) => void - ) { - } - - public dispose(): void { - if (this._animationFrame) { - window.cancelAnimationFrame(this._animationFrame); - this._animationFrame = undefined; - } - } - - public refresh(rowStart: number | undefined, rowEnd: number | undefined, rowCount: number): void { - this._rowCount = rowCount; - // Get the min/max row start/end for the arg values - rowStart = rowStart !== undefined ? rowStart : 0; - rowEnd = rowEnd !== undefined ? rowEnd : this._rowCount - 1; - // Set the properties to the updated values - this._rowStart = this._rowStart !== undefined ? Math.min(this._rowStart, rowStart) : rowStart; - this._rowEnd = this._rowEnd !== undefined ? Math.max(this._rowEnd, rowEnd) : rowEnd; - - if (this._animationFrame) { - return; - } - - this._animationFrame = window.requestAnimationFrame(() => this._innerRefresh()); - } - - private _innerRefresh(): void { - // Make sure values are set - if (this._rowStart === undefined || this._rowEnd === undefined || this._rowCount === undefined) { - return; - } - - // Clamp values - const start = Math.max(this._rowStart, 0); - const end = Math.min(this._rowEnd, this._rowCount - 1); - - // Reset debouncer (this happens before render callback as the render could trigger it again) - this._rowStart = undefined; - this._rowEnd = undefined; - this._animationFrame = undefined; - - // Run render callback - this._renderCallback(start, end); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/ScreenDprMonitor.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/ScreenDprMonitor.ts deleted file mode 100755 index 27ae231f0..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/ScreenDprMonitor.ts +++ /dev/null @@ -1,69 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { Disposable } from 'common/Lifecycle'; - -export type ScreenDprListener = (newDevicePixelRatio?: number, oldDevicePixelRatio?: number) => void; - -/** - * The screen device pixel ratio monitor allows listening for when the - * window.devicePixelRatio value changes. This is done not with polling but with - * the use of window.matchMedia to watch media queries. When the event fires, - * the listener will be reattached using a different media query to ensure that - * any further changes will register. - * - * The listener should fire on both window zoom changes and switching to a - * monitor with a different DPI. - */ -export class ScreenDprMonitor extends Disposable { - private _currentDevicePixelRatio: number = window.devicePixelRatio; - private _outerListener: ((this: MediaQueryList, ev: MediaQueryListEvent) => any) | undefined; - private _listener: ScreenDprListener | undefined; - private _resolutionMediaMatchList: MediaQueryList | undefined; - - public setListener(listener: ScreenDprListener): void { - if (this._listener) { - this.clearListener(); - } - this._listener = listener; - this._outerListener = () => { - if (!this._listener) { - return; - } - this._listener(window.devicePixelRatio, this._currentDevicePixelRatio); - this._updateDpr(); - }; - this._updateDpr(); - } - - public dispose(): void { - super.dispose(); - this.clearListener(); - } - - private _updateDpr(): void { - if (!this._outerListener) { - return; - } - - // Clear listeners for old DPR - this._resolutionMediaMatchList?.removeListener(this._outerListener); - - // Add listeners for new DPR - this._currentDevicePixelRatio = window.devicePixelRatio; - this._resolutionMediaMatchList = window.matchMedia(`screen and (resolution: ${window.devicePixelRatio}dppx)`); - this._resolutionMediaMatchList.addListener(this._outerListener); - } - - public clearListener(): void { - if (!this._resolutionMediaMatchList || !this._listener || !this._outerListener) { - return; - } - this._resolutionMediaMatchList.removeListener(this._outerListener); - this._resolutionMediaMatchList = undefined; - this._listener = undefined; - this._outerListener = undefined; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Terminal.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Terminal.ts deleted file mode 100755 index b0964c219..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Terminal.ts +++ /dev/null @@ -1,1268 +0,0 @@ -/** - * Copyright (c) 2014 The xterm.js authors. All rights reserved. - * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License) - * @license MIT - * - * Originally forked from (with the author's permission): - * Fabrice Bellard's javascript vt100 for jslinux: - * http://bellard.org/jslinux/ - * Copyright (c) 2011 Fabrice Bellard - * The original design remains. The terminal itself - * has been extended to include xterm CSI codes, among - * other features. - * - * Terminal Emulation References: - * http://vt100.net/ - * http://invisible-island.net/xterm/ctlseqs/ctlseqs.txt - * http://invisible-island.net/xterm/ctlseqs/ctlseqs.html - * http://invisible-island.net/vttest/ - * http://www.inwap.com/pdp10/ansicode.txt - * http://linux.die.net/man/4/console_codes - * http://linux.die.net/man/7/urxvt - */ - -import { ICompositionHelper, ITerminal, IBrowser, CustomKeyEventHandler, ILinkifier, IMouseZoneManager, LinkMatcherHandler, ILinkMatcherOptions, IViewport, ILinkifier2 } from 'browser/Types'; -import { IRenderer, CharacterJoinerHandler } from 'browser/renderer/Types'; -import { CompositionHelper } from 'browser/input/CompositionHelper'; -import { Viewport } from 'browser/Viewport'; -import { rightClickHandler, moveTextAreaUnderMouseCursor, handlePasteEvent, copyHandler, paste } from 'browser/Clipboard'; -import { C0 } from 'common/data/EscapeSequences'; -import { WindowsOptionsReportType } from '../common/InputHandler'; -import { Renderer } from 'browser/renderer/Renderer'; -import { Linkifier } from 'browser/Linkifier'; -import { SelectionService } from 'browser/services/SelectionService'; -import * as Browser from 'common/Platform'; -import { addDisposableDomListener } from 'browser/Lifecycle'; -import * as Strings from 'browser/LocalizableStrings'; -import { SoundService } from 'browser/services/SoundService'; -import { MouseZoneManager } from 'browser/MouseZoneManager'; -import { AccessibilityManager } from './AccessibilityManager'; -import { ITheme, IMarker, IDisposable, ISelectionPosition, ILinkProvider } from 'xterm'; -import { DomRenderer } from 'browser/renderer/dom/DomRenderer'; -import { IKeyboardEvent, KeyboardResultType, CoreMouseEventType, CoreMouseButton, CoreMouseAction, ITerminalOptions, IAnsiColorChangeEvent } from 'common/Types'; -import { evaluateKeyboardEvent } from 'common/input/Keyboard'; -import { EventEmitter, IEvent, forwardEvent } from 'common/EventEmitter'; -import { DEFAULT_ATTR_DATA } from 'common/buffer/BufferLine'; -import { ColorManager } from 'browser/ColorManager'; -import { RenderService } from 'browser/services/RenderService'; -import { ICharSizeService, IRenderService, IMouseService, ISelectionService, ISoundService, ICoreBrowserService } from 'browser/services/Services'; -import { CharSizeService } from 'browser/services/CharSizeService'; -import { IBuffer } from 'common/buffer/Types'; -import { MouseService } from 'browser/services/MouseService'; -import { Linkifier2 } from 'browser/Linkifier2'; -import { CoreBrowserService } from 'browser/services/CoreBrowserService'; -import { CoreTerminal } from 'common/CoreTerminal'; -import { ITerminalOptions as IInitializedTerminalOptions } from 'common/services/Services'; -import { rgba } from 'browser/Color'; - -// Let it work inside Node.js for automated testing purposes. -const document: Document = (typeof window !== 'undefined') ? window.document : null as any; - -export class Terminal extends CoreTerminal implements ITerminal { - public textarea: HTMLTextAreaElement | undefined; - public element: HTMLElement | undefined; - public screenElement: HTMLElement | undefined; - - private _document: Document | undefined; - private _viewportScrollArea: HTMLElement | undefined; - private _viewportElement: HTMLElement | undefined; - private _helperContainer: HTMLElement | undefined; - private _compositionView: HTMLElement | undefined; - - // private _visualBellTimer: number; - - public browser: IBrowser = Browser; - - // TODO: We should remove options once components adopt optionsService - public get options(): IInitializedTerminalOptions { return this.optionsService.options; } - - private _customKeyEventHandler: CustomKeyEventHandler | undefined; - - // browser services - private _charSizeService: ICharSizeService | undefined; - private _mouseService: IMouseService | undefined; - private _renderService: IRenderService | undefined; - private _selectionService: ISelectionService | undefined; - private _soundService: ISoundService | undefined; - - /** - * Records whether the keydown event has already been handled and triggered a data event, if so - * the keypress event should not trigger a data event but should still print to the textarea so - * screen readers will announce it. - */ - private _keyDownHandled: boolean = false; - - public linkifier: ILinkifier; - public linkifier2: ILinkifier2; - public viewport: IViewport | undefined; - private _compositionHelper: ICompositionHelper | undefined; - private _mouseZoneManager: IMouseZoneManager | undefined; - private _accessibilityManager: AccessibilityManager | undefined; - private _colorManager: ColorManager | undefined; - private _theme: ITheme | undefined; - - private _onCursorMove = new EventEmitter(); - public get onCursorMove(): IEvent { return this._onCursorMove.event; } - private _onKey = new EventEmitter<{ key: string, domEvent: KeyboardEvent }>(); - public get onKey(): IEvent<{ key: string, domEvent: KeyboardEvent }> { return this._onKey.event; } - private _onRender = new EventEmitter<{ start: number, end: number }>(); - public get onRender(): IEvent<{ start: number, end: number }> { return this._onRender.event; } - private _onSelectionChange = new EventEmitter(); - public get onSelectionChange(): IEvent { return this._onSelectionChange.event; } - private _onTitleChange = new EventEmitter(); - public get onTitleChange(): IEvent { return this._onTitleChange.event; } - - private _onFocus = new EventEmitter(); - public get onFocus(): IEvent { return this._onFocus.event; } - private _onBlur = new EventEmitter(); - public get onBlur(): IEvent { return this._onBlur.event; } - private _onA11yCharEmitter = new EventEmitter(); - public get onA11yChar(): IEvent { return this._onA11yCharEmitter.event; } - private _onA11yTabEmitter = new EventEmitter(); - public get onA11yTab(): IEvent { return this._onA11yTabEmitter.event; } - - /** - * Creates a new `Terminal` object. - * - * @param options An object containing a set of options, the available options are: - * - `cursorBlink` (boolean): Whether the terminal cursor blinks - * - `cols` (number): The number of columns of the terminal (horizontal size) - * - `rows` (number): The number of rows of the terminal (vertical size) - * - * @public - * @class Xterm Xterm - * @alias module:xterm/src/xterm - */ - constructor( - options: ITerminalOptions = {} - ) { - super(options); - - this._setup(); - - this.linkifier = this._instantiationService.createInstance(Linkifier); - this.linkifier2 = this.register(this._instantiationService.createInstance(Linkifier2)); - - // Setup InputHandler listeners - this.register(this._inputHandler.onRequestBell(() => this.bell())); - this.register(this._inputHandler.onRequestRefreshRows((start, end) => this.refresh(start, end))); - this.register(this._inputHandler.onRequestReset(() => this.reset())); - this.register(this._inputHandler.onRequestScroll((eraseAttr, isWrapped) => this.scroll(eraseAttr, isWrapped || undefined))); - this.register(this._inputHandler.onRequestWindowsOptionsReport(type => this._reportWindowsOptions(type))); - this.register(this._inputHandler.onAnsiColorChange((event) => this._changeAnsiColor(event))); - this.register(forwardEvent(this._inputHandler.onCursorMove, this._onCursorMove)); - this.register(forwardEvent(this._inputHandler.onTitleChange, this._onTitleChange)); - this.register(forwardEvent(this._inputHandler.onA11yChar, this._onA11yCharEmitter)); - this.register(forwardEvent(this._inputHandler.onA11yTab, this._onA11yTabEmitter)); - - // Setup listeners - this.register(this._bufferService.onResize(e => this._afterResize(e.cols, e.rows))); - } - - private _changeAnsiColor(event: IAnsiColorChangeEvent): void { - if (!this._colorManager) { return; } - - event.colors.forEach(ansiColor => { - const color = rgba.toColor(ansiColor.red, ansiColor.green, ansiColor.blue); - - this._colorManager!.colors.ansi[ansiColor.colorIndex] = color; - }); - - this._renderService?.setColors(this._colorManager!.colors); - this.viewport?.onThemeChange(this._colorManager!.colors); - } - - public dispose(): void { - if (this._isDisposed) { - return; - } - super.dispose(); - this._renderService?.dispose(); - this._customKeyEventHandler = undefined; - this.write = () => { }; - this.element?.parentNode?.removeChild(this.element); - } - - protected _setup(): void { - super._setup(); - - this._customKeyEventHandler = undefined; - } - - /** - * Convenience property to active buffer. - */ - public get buffer(): IBuffer { - return this.buffers.active; - } - - /** - * Focus the terminal. Delegates focus handling to the terminal's DOM element. - */ - public focus(): void { - if (this.textarea) { - this.textarea.focus({ preventScroll: true }); - } - } - - protected _updateOptions(key: string): void { - super._updateOptions(key); - - // TODO: These listeners should be owned by individual components - switch (key) { - case 'fontFamily': - case 'fontSize': - // When the font changes the size of the cells may change which requires a renderer clear - this._renderService?.clear(); - this._charSizeService?.measure(); - break; - case 'cursorBlink': - case 'cursorStyle': - // The DOM renderer needs a row refresh to update the cursor styles - this.refresh(this.buffer.y, this.buffer.y); - break; - case 'drawBoldTextInBrightColors': - case 'letterSpacing': - case 'lineHeight': - case 'fontWeight': - case 'fontWeightBold': - case 'minimumContrastRatio': - // When the font changes the size of the cells may change which requires a renderer clear - if (this._renderService) { - this._renderService.clear(); - this._renderService.onResize(this.cols, this.rows); - this.refresh(0, this.rows - 1); - } - break; - case 'rendererType': - if (this._renderService) { - this._renderService.setRenderer(this._createRenderer()); - this._renderService.onResize(this.cols, this.rows); - } - break; - case 'scrollback': - this.viewport?.syncScrollArea(); - break; - case 'screenReaderMode': - if (this.optionsService.options.screenReaderMode) { - if (!this._accessibilityManager && this._renderService) { - this._accessibilityManager = new AccessibilityManager(this, this._renderService); - } - } else { - this._accessibilityManager?.dispose(); - this._accessibilityManager = undefined; - } - break; - case 'tabStopWidth': this.buffers.setupTabStops(); break; - case 'theme': - this._setTheme(this.optionsService.options.theme); - break; - } - } - - /** - * Binds the desired focus behavior on a given terminal object. - */ - private _onTextAreaFocus(ev: KeyboardEvent): void { - if (this._coreService.decPrivateModes.sendFocus) { - this._coreService.triggerDataEvent(C0.ESC + '[I'); - } - this.updateCursorStyle(ev); - this.element!.classList.add('focus'); - this._showCursor(); - this._onFocus.fire(); - } - - /** - * Blur the terminal, calling the blur function on the terminal's underlying - * textarea. - */ - public blur(): void { - return this.textarea?.blur(); - } - - /** - * Binds the desired blur behavior on a given terminal object. - */ - private _onTextAreaBlur(): void { - // Text can safely be removed on blur. Doing it earlier could interfere with - // screen readers reading it out. - this.textarea!.value = ''; - this.refresh(this.buffer.y, this.buffer.y); - if (this._coreService.decPrivateModes.sendFocus) { - this._coreService.triggerDataEvent(C0.ESC + '[O'); - } - this.element!.classList.remove('focus'); - this._onBlur.fire(); - } - - private _syncTextArea(): void { - if (!this.textarea || !this.buffer.isCursorInViewport || this._compositionHelper!.isComposing) { - return; - } - - const cellHeight = Math.ceil(this._charSizeService!.height * this.optionsService.options.lineHeight); - const cursorTop = this._bufferService.buffer.y * cellHeight; - const cursorLeft = this._bufferService.buffer.x * this._charSizeService!.width; - - // Sync the textarea to the exact position of the composition view so the IME knows where the - // text is. - this.textarea.style.left = cursorLeft + 'px'; - this.textarea.style.top = cursorTop + 'px'; - this.textarea.style.width = this._charSizeService!.width + 'px'; - this.textarea.style.height = cellHeight + 'px'; - this.textarea.style.lineHeight = cellHeight + 'px'; - this.textarea.style.zIndex = '-5'; - } - - /** - * Initialize default behavior - */ - private _initGlobal(): void { - this._bindKeys(); - - // Bind clipboard functionality - this.register(addDisposableDomListener(this.element!, 'copy', (event: ClipboardEvent) => { - // If mouse events are active it means the selection manager is disabled and - // copy should be handled by the host program. - if (!this.hasSelection()) { - return; - } - copyHandler(event, this._selectionService!); - })); - const pasteHandlerWrapper = (event: ClipboardEvent): void => handlePasteEvent(event, this.textarea!, this._coreService); - this.register(addDisposableDomListener(this.textarea!, 'paste', pasteHandlerWrapper)); - this.register(addDisposableDomListener(this.element!, 'paste', pasteHandlerWrapper)); - - // Handle right click context menus - if (Browser.isFirefox) { - // Firefox doesn't appear to fire the contextmenu event on right click - this.register(addDisposableDomListener(this.element!, 'mousedown', (event: MouseEvent) => { - if (event.button === 2) { - rightClickHandler(event, this.textarea!, this.screenElement!, this._selectionService!, this.options.rightClickSelectsWord); - } - })); - } else { - this.register(addDisposableDomListener(this.element!, 'contextmenu', (event: MouseEvent) => { - rightClickHandler(event, this.textarea!, this.screenElement!, this._selectionService!, this.options.rightClickSelectsWord); - })); - } - - // Move the textarea under the cursor when middle clicking on Linux to ensure - // middle click to paste selection works. This only appears to work in Chrome - // at the time is writing. - if (Browser.isLinux) { - // Use auxclick event over mousedown the latter doesn't seem to work. Note - // that the regular click event doesn't fire for the middle mouse button. - this.register(addDisposableDomListener(this.element!, 'auxclick', (event: MouseEvent) => { - if (event.button === 1) { - moveTextAreaUnderMouseCursor(event, this.textarea!, this.screenElement!); - } - })); - } - } - - /** - * Apply key handling to the terminal - */ - private _bindKeys(): void { - this.register(addDisposableDomListener(this.textarea!, 'keyup', (ev: KeyboardEvent) => this._keyUp(ev), true)); - this.register(addDisposableDomListener(this.textarea!, 'keydown', (ev: KeyboardEvent) => this._keyDown(ev), true)); - this.register(addDisposableDomListener(this.textarea!, 'keypress', (ev: KeyboardEvent) => this._keyPress(ev), true)); - this.register(addDisposableDomListener(this.textarea!, 'compositionstart', () => this._compositionHelper!.compositionstart())); - this.register(addDisposableDomListener(this.textarea!, 'compositionupdate', (e: CompositionEvent) => this._compositionHelper!.compositionupdate(e))); - this.register(addDisposableDomListener(this.textarea!, 'compositionend', () => this._compositionHelper!.compositionend())); - this.register(this.onRender(() => this._compositionHelper!.updateCompositionElements())); - this.register(this.onRender(e => this._queueLinkification(e.start, e.end))); - } - - /** - * Opens the terminal within an element. - * - * @param parent The element to create the terminal within. - */ - public open(parent: HTMLElement): void { - if (!parent) { - throw new Error('Terminal requires a parent element.'); - } - - if (!parent.isConnected) { - this._logService.debug('Terminal.open was called on an element that was not attached to the DOM'); - } - - this._document = parent.ownerDocument!; - - // Create main element container - this.element = this._document.createElement('div'); - this.element.dir = 'ltr'; // xterm.css assumes LTR - this.element.classList.add('terminal'); - this.element.classList.add('xterm'); - this.element.setAttribute('tabindex', '0'); - this.element.setAttribute('role', 'document'); - parent.appendChild(this.element); - - // Performance: Use a document fragment to build the terminal - // viewport and helper elements detached from the DOM - const fragment = document.createDocumentFragment(); - this._viewportElement = document.createElement('div'); - this._viewportElement.classList.add('xterm-viewport'); - fragment.appendChild(this._viewportElement); - this._viewportScrollArea = document.createElement('div'); - this._viewportScrollArea.classList.add('xterm-scroll-area'); - this._viewportElement.appendChild(this._viewportScrollArea); - - this.screenElement = document.createElement('div'); - this.screenElement.classList.add('xterm-screen'); - // Create the container that will hold helpers like the textarea for - // capturing DOM Events. Then produce the helpers. - this._helperContainer = document.createElement('div'); - this._helperContainer.classList.add('xterm-helpers'); - this.screenElement.appendChild(this._helperContainer); - fragment.appendChild(this.screenElement); - - this.textarea = document.createElement('textarea'); - this.textarea.classList.add('xterm-helper-textarea'); - this.textarea.setAttribute('aria-label', Strings.promptLabel); - this.textarea.setAttribute('aria-multiline', 'false'); - this.textarea.setAttribute('autocorrect', 'off'); - this.textarea.setAttribute('autocapitalize', 'off'); - this.textarea.setAttribute('spellcheck', 'false'); - this.textarea.tabIndex = 0; - this.register(addDisposableDomListener(this.textarea, 'focus', (ev: KeyboardEvent) => this._onTextAreaFocus(ev))); - this.register(addDisposableDomListener(this.textarea, 'blur', () => this._onTextAreaBlur())); - this._helperContainer.appendChild(this.textarea); - - const coreBrowserService = this._instantiationService.createInstance(CoreBrowserService, this.textarea); - this._instantiationService.setService(ICoreBrowserService, coreBrowserService); - - this._charSizeService = this._instantiationService.createInstance(CharSizeService, this._document, this._helperContainer); - this._instantiationService.setService(ICharSizeService, this._charSizeService); - - this._compositionView = document.createElement('div'); - this._compositionView.classList.add('composition-view'); - this._compositionHelper = this._instantiationService.createInstance(CompositionHelper, this.textarea, this._compositionView); - this._helperContainer.appendChild(this._compositionView); - - // Performance: Add viewport and helper elements from the fragment - this.element.appendChild(fragment); - - this._theme = this.options.theme || this._theme; - this._colorManager = new ColorManager(document, this.options.allowTransparency); - this.register(this.optionsService.onOptionChange(e => this._colorManager!.onOptionsChange(e))); - this._colorManager.setTheme(this._theme); - - const renderer = this._createRenderer(); - this._renderService = this.register(this._instantiationService.createInstance(RenderService, renderer, this.rows, this.screenElement)); - this._instantiationService.setService(IRenderService, this._renderService); - this.register(this._renderService.onRenderedBufferChange(e => this._onRender.fire(e))); - this.onResize(e => this._renderService!.resize(e.cols, e.rows)); - - this._soundService = this._instantiationService.createInstance(SoundService); - this._instantiationService.setService(ISoundService, this._soundService); - this._mouseService = this._instantiationService.createInstance(MouseService); - this._instantiationService.setService(IMouseService, this._mouseService); - - this.viewport = this._instantiationService.createInstance(Viewport, - (amount: number, suppressEvent: boolean) => this.scrollLines(amount, suppressEvent), - this._viewportElement, - this._viewportScrollArea - ); - this.viewport.onThemeChange(this._colorManager.colors); - this.register(this._inputHandler.onRequestSyncScrollBar(() => this.viewport!.syncScrollArea())); - this.register(this.viewport); - - this.register(this.onCursorMove(() => { - this._renderService!.onCursorMove(); - this._syncTextArea(); - })); - this.register(this.onResize(() => this._renderService!.onResize(this.cols, this.rows))); - this.register(this.onBlur(() => this._renderService!.onBlur())); - this.register(this.onFocus(() => this._renderService!.onFocus())); - this.register(this._renderService.onDimensionsChange(() => this.viewport!.syncScrollArea())); - - this._selectionService = this.register(this._instantiationService.createInstance(SelectionService, - this.element, - this.screenElement)); - this._instantiationService.setService(ISelectionService, this._selectionService); - this.register(this._selectionService.onRequestScrollLines(e => this.scrollLines(e.amount, e.suppressScrollEvent))); - this.register(this._selectionService.onSelectionChange(() => this._onSelectionChange.fire())); - this.register(this._selectionService.onRequestRedraw(e => this._renderService!.onSelectionChanged(e.start, e.end, e.columnSelectMode))); - this.register(this._selectionService.onLinuxMouseSelection(text => { - // If there's a new selection, put it into the textarea, focus and select it - // in order to register it as a selection on the OS. This event is fired - // only on Linux to enable middle click to paste selection. - this.textarea!.value = text; - this.textarea!.focus(); - this.textarea!.select(); - })); - this.register(this.onScroll(() => { - this.viewport!.syncScrollArea(); - this._selectionService!.refresh(); - })); - this.register(addDisposableDomListener(this._viewportElement, 'scroll', () => this._selectionService!.refresh())); - - this._mouseZoneManager = this._instantiationService.createInstance(MouseZoneManager, this.element, this.screenElement); - this.register(this._mouseZoneManager); - this.register(this.onScroll(() => this._mouseZoneManager!.clearAll())); - this.linkifier.attachToDom(this.element, this._mouseZoneManager); - this.linkifier2.attachToDom(this.element, this._mouseService, this._renderService); - - // This event listener must be registered aftre MouseZoneManager is created - this.register(addDisposableDomListener(this.element, 'mousedown', (e: MouseEvent) => this._selectionService!.onMouseDown(e))); - - // apply mouse event classes set by escape codes before terminal was attached - if (this._coreMouseService.areMouseEventsActive) { - this._selectionService.disable(); - this.element.classList.add('enable-mouse-events'); - } else { - this._selectionService.enable(); - } - - if (this.options.screenReaderMode) { - // Note that this must be done *after* the renderer is created in order to - // ensure the correct order of the dprchange event - this._accessibilityManager = new AccessibilityManager(this, this._renderService); - } - - // Measure the character size - this._charSizeService.measure(); - - // Setup loop that draws to screen - this.refresh(0, this.rows - 1); - - // Initialize global actions that need to be taken on the document. - this._initGlobal(); - - // Listen for mouse events and translate - // them into terminal mouse protocols. - this.bindMouse(); - } - - private _createRenderer(): IRenderer { - switch (this.options.rendererType) { - case 'canvas': return this._instantiationService.createInstance(Renderer, this._colorManager!.colors, this.screenElement!, this.linkifier, this.linkifier2); - case 'dom': return this._instantiationService.createInstance(DomRenderer, this._colorManager!.colors, this.element!, this.screenElement!, this._viewportElement!, this.linkifier, this.linkifier2); - default: throw new Error(`Unrecognized rendererType "${this.options.rendererType}"`); - } - } - - /** - * Sets the theme on the renderer. The renderer must have been initialized. - * @param theme The theme to set. - */ - private _setTheme(theme: ITheme): void { - this._theme = theme; - this._colorManager?.setTheme(theme); - this._renderService?.setColors(this._colorManager!.colors); - this.viewport?.onThemeChange(this._colorManager!.colors); - } - - /** - * Bind certain mouse events to the terminal. - * By default only 3 button + wheel up/down is ativated. For higher buttons - * no mouse report will be created. Typically the standard actions will be active. - * - * There are several reasons not to enable support for higher buttons/wheel: - * - Button 4 and 5 are typically used for history back and forward navigation, - * there is no straight forward way to supress/intercept those standard actions. - * - Support for higher buttons does not work in some platform/browser combinations. - * - Left/right wheel was not tested. - * - Emulators vary in mouse button support, typically only 3 buttons and - * wheel up/down work reliable. - * - * TODO: Move mouse event code into its own file. - */ - public bindMouse(): void { - const self = this; - const el = this.element!; - - // send event to CoreMouseService - function sendEvent(ev: MouseEvent | WheelEvent): boolean { - // get mouse coordinates - const pos = self._mouseService!.getRawByteCoords(ev, self.screenElement!, self.cols, self.rows); - if (!pos) { - return false; - } - - let but: CoreMouseButton; - let action: CoreMouseAction | undefined; - switch ((ev).overrideType || ev.type) { - case 'mousemove': - action = CoreMouseAction.MOVE; - if (ev.buttons === undefined) { - // buttons is not supported on macOS, try to get a value from button instead - but = CoreMouseButton.NONE; - if (ev.button !== undefined) { - but = ev.button < 3 ? ev.button : CoreMouseButton.NONE; - } - } else { - // according to MDN buttons only reports up to button 5 (AUX2) - but = ev.buttons & 1 ? CoreMouseButton.LEFT : - ev.buttons & 4 ? CoreMouseButton.MIDDLE : - ev.buttons & 2 ? CoreMouseButton.RIGHT : - CoreMouseButton.NONE; // fallback to NONE - } - break; - case 'mouseup': - action = CoreMouseAction.UP; - but = ev.button < 3 ? ev.button : CoreMouseButton.NONE; - break; - case 'mousedown': - action = CoreMouseAction.DOWN; - but = ev.button < 3 ? ev.button : CoreMouseButton.NONE; - break; - case 'wheel': - // only UP/DOWN wheel events are respected - if ((ev as WheelEvent).deltaY !== 0) { - action = (ev as WheelEvent).deltaY < 0 ? CoreMouseAction.UP : CoreMouseAction.DOWN; - } - but = CoreMouseButton.WHEEL; - break; - default: - // dont handle other event types by accident - return false; - } - - // exit if we cannot determine valid button/action values - // do nothing for higher buttons than wheel - if (action === undefined || but === undefined || but > CoreMouseButton.WHEEL) { - return false; - } - - return self._coreMouseService.triggerMouseEvent({ - col: pos.x - 33, // FIXME: why -33 here? - row: pos.y - 33, - button: but, - action, - ctrl: ev.ctrlKey, - alt: ev.altKey, - shift: ev.shiftKey - }); - } - - /** - * Event listener state handling. - * We listen to the onProtocolChange event of CoreMouseService and put - * requested listeners in `requestedEvents`. With this the listeners - * have all bits to do the event listener juggling. - * Note: 'mousedown' currently is "always on" and not managed - * by onProtocolChange. - */ - const requestedEvents: { [key: string]: ((ev: Event) => void) | null } = { - mouseup: null, - wheel: null, - mousedrag: null, - mousemove: null - }; - const eventListeners: { [key: string]: (ev: any) => void | boolean } = { - mouseup: (ev: MouseEvent) => { - sendEvent(ev); - if (!ev.buttons) { - // if no other button is held remove global handlers - this._document!.removeEventListener('mouseup', requestedEvents.mouseup!); - if (requestedEvents.mousedrag) { - this._document!.removeEventListener('mousemove', requestedEvents.mousedrag); - } - } - return this.cancel(ev); - }, - wheel: (ev: WheelEvent) => { - sendEvent(ev); - ev.preventDefault(); - return this.cancel(ev); - }, - mousedrag: (ev: MouseEvent) => { - // deal only with move while a button is held - if (ev.buttons) { - sendEvent(ev); - } - }, - mousemove: (ev: MouseEvent) => { - // deal only with move without any button - if (!ev.buttons) { - sendEvent(ev); - } - } - }; - this.register(this._coreMouseService.onProtocolChange(events => { - // apply global changes on events - if (events) { - if (this.optionsService.options.logLevel === 'debug') { - this._logService.debug('Binding to mouse events:', this._coreMouseService.explainEvents(events)); - } - this.element!.classList.add('enable-mouse-events'); - this._selectionService!.disable(); - } else { - this._logService.debug('Unbinding from mouse events.'); - this.element!.classList.remove('enable-mouse-events'); - this._selectionService!.enable(); - } - - // add/remove handlers from requestedEvents - - if (!(events & CoreMouseEventType.MOVE)) { - el.removeEventListener('mousemove', requestedEvents.mousemove!); - requestedEvents.mousemove = null; - } else if (!requestedEvents.mousemove) { - el.addEventListener('mousemove', eventListeners.mousemove); - requestedEvents.mousemove = eventListeners.mousemove; - } - - if (!(events & CoreMouseEventType.WHEEL)) { - el.removeEventListener('wheel', requestedEvents.wheel!); - requestedEvents.wheel = null; - } else if (!requestedEvents.wheel) { - el.addEventListener('wheel', eventListeners.wheel, { passive: false }); - requestedEvents.wheel = eventListeners.wheel; - } - - if (!(events & CoreMouseEventType.UP)) { - this._document!.removeEventListener('mouseup', requestedEvents.mouseup!); - requestedEvents.mouseup = null; - } else if (!requestedEvents.mouseup) { - requestedEvents.mouseup = eventListeners.mouseup; - } - - if (!(events & CoreMouseEventType.DRAG)) { - this._document!.removeEventListener('mousemove', requestedEvents.mousedrag!); - requestedEvents.mousedrag = null; - } else if (!requestedEvents.mousedrag) { - requestedEvents.mousedrag = eventListeners.mousedrag; - } - })); - // force initial onProtocolChange so we dont miss early mouse requests - this._coreMouseService.activeProtocol = this._coreMouseService.activeProtocol; - - /** - * "Always on" event listeners. - */ - this.register(addDisposableDomListener(el, 'mousedown', (ev: MouseEvent) => { - ev.preventDefault(); - this.focus(); - - // Don't send the mouse button to the pty if mouse events are disabled or - // if the selection manager is having selection forced (ie. a modifier is - // held). - if (!this._coreMouseService.areMouseEventsActive || this._selectionService!.shouldForceSelection(ev)) { - return; - } - - sendEvent(ev); - - // Register additional global handlers which should keep reporting outside - // of the terminal element. - // Note: Other emulators also do this for 'mousedown' while a button - // is held, we currently limit 'mousedown' to the terminal only. - if (requestedEvents.mouseup) { - this._document!.addEventListener('mouseup', requestedEvents.mouseup); - } - if (requestedEvents.mousedrag) { - this._document!.addEventListener('mousemove', requestedEvents.mousedrag); - } - - return this.cancel(ev); - })); - - this.register(addDisposableDomListener(el, 'wheel', (ev: WheelEvent) => { - if (!requestedEvents.wheel) { - // Convert wheel events into up/down events when the buffer does not have scrollback, this - // enables scrolling in apps hosted in the alt buffer such as vim or tmux. - if (!this.buffer.hasScrollback) { - const amount = this.viewport!.getLinesScrolled(ev); - - // Do nothing if there's no vertical scroll - if (amount === 0) { - return; - } - - // Construct and send sequences - const sequence = C0.ESC + (this._coreService.decPrivateModes.applicationCursorKeys ? 'O' : '[') + (ev.deltaY < 0 ? 'A' : 'B'); - let data = ''; - for (let i = 0; i < Math.abs(amount); i++) { - data += sequence; - } - this._coreService.triggerDataEvent(data, true); - } - return; - } - }, { passive: true })); - - // allow wheel scrolling in - // the shell for example - this.register(addDisposableDomListener(el, 'wheel', (ev: WheelEvent) => { - if (requestedEvents.wheel) return; - if (!this.viewport!.onWheel(ev)) { - return this.cancel(ev); - } - }, { passive: false })); - - this.register(addDisposableDomListener(el, 'touchstart', (ev: TouchEvent) => { - if (this._coreMouseService.areMouseEventsActive) return; - this.viewport!.onTouchStart(ev); - return this.cancel(ev); - }, { passive: true })); - - this.register(addDisposableDomListener(el, 'touchmove', (ev: TouchEvent) => { - if (this._coreMouseService.areMouseEventsActive) return; - if (!this.viewport!.onTouchMove(ev)) { - return this.cancel(ev); - } - }, { passive: false })); - } - - - /** - * Tells the renderer to refresh terminal content between two rows (inclusive) at the next - * opportunity. - * @param start The row to start from (between 0 and this.rows - 1). - * @param end The row to end at (between start and this.rows - 1). - */ - public refresh(start: number, end: number): void { - this._renderService?.refreshRows(start, end); - } - - /** - * Queues linkification for the specified rows. - * @param start The row to start from (between 0 and this.rows - 1). - * @param end The row to end at (between start and this.rows - 1). - */ - private _queueLinkification(start: number, end: number): void { - this.linkifier?.linkifyRows(start, end); - } - - /** - * Change the cursor style for different selection modes - */ - public updateCursorStyle(ev: KeyboardEvent): void { - if (this._selectionService && this._selectionService.shouldColumnSelect(ev)) { - this.element!.classList.add('column-select'); - } else { - this.element!.classList.remove('column-select'); - } - } - - /** - * Display the cursor element - */ - private _showCursor(): void { - if (!this._coreService.isCursorInitialized) { - this._coreService.isCursorInitialized = true; - this.refresh(this.buffer.y, this.buffer.y); - } - } - - public scrollLines(disp: number, suppressScrollEvent?: boolean): void { - super.scrollLines(disp, suppressScrollEvent); - this.refresh(0, this.rows - 1); - } - - public paste(data: string): void { - paste(data, this.textarea!, this._coreService); - } - - /** - * Attaches a custom key event handler which is run before keys are processed, - * giving consumers of xterm.js ultimate control as to what keys should be - * processed by the terminal and what keys should not. - * @param customKeyEventHandler The custom KeyboardEvent handler to attach. - * This is a function that takes a KeyboardEvent, allowing consumers to stop - * propagation and/or prevent the default action. The function returns whether - * the event should be processed by xterm.js. - */ - public attachCustomKeyEventHandler(customKeyEventHandler: CustomKeyEventHandler): void { - this._customKeyEventHandler = customKeyEventHandler; - } - - /** - * Registers a link matcher, allowing custom link patterns to be matched and - * handled. - * @param regex The regular expression to search for, specifically - * this searches the textContent of the rows. You will want to use \s to match - * a space ' ' character for example. - * @param handler The callback when the link is called. - * @param options Options for the link matcher. - * @return The ID of the new matcher, this can be used to deregister. - */ - public registerLinkMatcher(regex: RegExp, handler: LinkMatcherHandler, options?: ILinkMatcherOptions): number { - const matcherId = this.linkifier.registerLinkMatcher(regex, handler, options); - this.refresh(0, this.rows - 1); - return matcherId; - } - - /** - * Deregisters a link matcher if it has been registered. - * @param matcherId The link matcher's ID (returned after register) - */ - public deregisterLinkMatcher(matcherId: number): void { - if (this.linkifier.deregisterLinkMatcher(matcherId)) { - this.refresh(0, this.rows - 1); - } - } - - public registerLinkProvider(linkProvider: ILinkProvider): IDisposable { - return this.linkifier2.registerLinkProvider(linkProvider); - } - - public registerCharacterJoiner(handler: CharacterJoinerHandler): number { - const joinerId = this._renderService!.registerCharacterJoiner(handler); - this.refresh(0, this.rows - 1); - return joinerId; - } - - public deregisterCharacterJoiner(joinerId: number): void { - if (this._renderService!.deregisterCharacterJoiner(joinerId)) { - this.refresh(0, this.rows - 1); - } - } - - public get markers(): IMarker[] { - return this.buffer.markers; - } - - public addMarker(cursorYOffset: number): IMarker | undefined { - // Disallow markers on the alt buffer - if (this.buffer !== this.buffers.normal) { - return; - } - - return this.buffer.addMarker(this.buffer.ybase + this.buffer.y + cursorYOffset); - } - - /** - * Gets whether the terminal has an active selection. - */ - public hasSelection(): boolean { - return this._selectionService ? this._selectionService.hasSelection : false; - } - - /** - * Selects text within the terminal. - * @param column The column the selection starts at.. - * @param row The row the selection starts at. - * @param length The length of the selection. - */ - public select(column: number, row: number, length: number): void { - this._selectionService!.setSelection(column, row, length); - } - - /** - * Gets the terminal's current selection, this is useful for implementing copy - * behavior outside of xterm.js. - */ - public getSelection(): string { - return this._selectionService ? this._selectionService.selectionText : ''; - } - - public getSelectionPosition(): ISelectionPosition | undefined { - if (!this._selectionService || !this._selectionService.hasSelection) { - return undefined; - } - - return { - startColumn: this._selectionService.selectionStart![0], - startRow: this._selectionService.selectionStart![1], - endColumn: this._selectionService.selectionEnd![0], - endRow: this._selectionService.selectionEnd![1] - }; - } - - /** - * Clears the current terminal selection. - */ - public clearSelection(): void { - this._selectionService?.clearSelection(); - } - - /** - * Selects all text within the terminal. - */ - public selectAll(): void { - this._selectionService?.selectAll(); - } - - public selectLines(start: number, end: number): void { - this._selectionService?.selectLines(start, end); - } - - /** - * Handle a keydown event - * Key Resources: - * - https://developer.mozilla.org/en-US/docs/DOM/KeyboardEvent - * @param ev The keydown event to be handled. - */ - protected _keyDown(event: KeyboardEvent): boolean | undefined { - this._keyDownHandled = false; - - if (this._customKeyEventHandler && this._customKeyEventHandler(event) === false) { - return false; - } - - if (!this._compositionHelper!.keydown(event)) { - if (this.buffer.ybase !== this.buffer.ydisp) { - this.scrollToBottom(); - } - return false; - } - - const result = evaluateKeyboardEvent(event, this._coreService.decPrivateModes.applicationCursorKeys, this.browser.isMac, this.options.macOptionIsMeta); - - this.updateCursorStyle(event); - - if (result.type === KeyboardResultType.PAGE_DOWN || result.type === KeyboardResultType.PAGE_UP) { - const scrollCount = this.rows - 1; - this.scrollLines(result.type === KeyboardResultType.PAGE_UP ? -scrollCount : scrollCount); - return this.cancel(event, true); - } - - if (result.type === KeyboardResultType.SELECT_ALL) { - this.selectAll(); - } - - if (this._isThirdLevelShift(this.browser, event)) { - return true; - } - - if (result.cancel) { - // The event is canceled at the end already, is this necessary? - this.cancel(event, true); - } - - if (!result.key) { - return true; - } - - // If ctrl+c or enter is being sent, clear out the textarea. This is done so that screen readers - // will announce deleted characters. This will not work 100% of the time but it should cover - // most scenarios. - if (result.key === C0.ETX || result.key === C0.CR) { - this.textarea!.value = ''; - } - - this._onKey.fire({ key: result.key, domEvent: event }); - this._showCursor(); - this._coreService.triggerDataEvent(result.key, true); - - // Cancel events when not in screen reader mode so events don't get bubbled up and handled by - // other listeners. When screen reader mode is enabled, this could cause issues if the event - // is handled at a higher level, this is a compromise in order to echo keys to the screen - // reader. - if (!this.optionsService.options.screenReaderMode) { - return this.cancel(event, true); - } - - this._keyDownHandled = true; - } - - private _isThirdLevelShift(browser: IBrowser, ev: IKeyboardEvent): boolean { - const thirdLevelKey = - (browser.isMac && !this.options.macOptionIsMeta && ev.altKey && !ev.ctrlKey && !ev.metaKey) || - (browser.isWindows && ev.altKey && ev.ctrlKey && !ev.metaKey); - - if (ev.type === 'keypress') { - return thirdLevelKey; - } - - // Don't invoke for arrows, pageDown, home, backspace, etc. (on non-keypress events) - return thirdLevelKey && (!ev.keyCode || ev.keyCode > 47); - } - - protected _keyUp(ev: KeyboardEvent): void { - if (this._customKeyEventHandler && this._customKeyEventHandler(ev) === false) { - return; - } - - if (!wasModifierKeyOnlyEvent(ev)) { - this.focus(); - } - - this.updateCursorStyle(ev); - } - - /** - * Handle a keypress event. - * Key Resources: - * - https://developer.mozilla.org/en-US/docs/DOM/KeyboardEvent - * @param ev The keypress event to be handled. - */ - protected _keyPress(ev: KeyboardEvent): boolean { - let key; - - if (this._keyDownHandled) { - return false; - } - - if (this._customKeyEventHandler && this._customKeyEventHandler(ev) === false) { - return false; - } - - this.cancel(ev); - - if (ev.charCode) { - key = ev.charCode; - } else if (ev.which === null || ev.which === undefined) { - key = ev.keyCode; - } else if (ev.which !== 0 && ev.charCode !== 0) { - key = ev.which; - } else { - return false; - } - - if (!key || ( - (ev.altKey || ev.ctrlKey || ev.metaKey) && !this._isThirdLevelShift(this.browser, ev) - )) { - return false; - } - - key = String.fromCharCode(key); - - this._onKey.fire({ key, domEvent: ev }); - this._showCursor(); - this._coreService.triggerDataEvent(key, true); - - return true; - } - - /** - * Ring the bell. - * Note: We could do sweet things with webaudio here - */ - public bell(): void { - if (this._soundBell()) { - this._soundService!.playBellSound(); - } - - // if (this._visualBell()) { - // this.element.classList.add('visual-bell-active'); - // clearTimeout(this._visualBellTimer); - // this._visualBellTimer = window.setTimeout(() => { - // this.element.classList.remove('visual-bell-active'); - // }, 200); - // } - } - - /** - * Resizes the terminal. - * - * @param x The number of columns to resize to. - * @param y The number of rows to resize to. - */ - public resize(x: number, y: number): void { - if (x === this.cols && y === this.rows) { - // Check if we still need to measure the char size (fixes #785). - if (this._charSizeService && !this._charSizeService.hasValidSize) { - this._charSizeService.measure(); - } - return; - } - - super.resize(x, y); - } - - private _afterResize(x: number, y: number): void { - this._charSizeService?.measure(); - - // Sync the scroll area to make sure scroll events don't fire and scroll the viewport to an - // invalid location - this.viewport?.syncScrollArea(true); - } - - /** - * Clear the entire buffer, making the prompt line the new first line. - */ - public clear(): void { - if (this.buffer.ybase === 0 && this.buffer.y === 0) { - // Don't clear if it's already clear - return; - } - this.buffer.lines.set(0, this.buffer.lines.get(this.buffer.ybase + this.buffer.y)!); - this.buffer.lines.length = 1; - this.buffer.ydisp = 0; - this.buffer.ybase = 0; - this.buffer.y = 0; - for (let i = 1; i < this.rows; i++) { - this.buffer.lines.push(this.buffer.getBlankLine(DEFAULT_ATTR_DATA)); - } - this.refresh(0, this.rows - 1); - this._onScroll.fire(this.buffer.ydisp); - } - - /** - * Reset terminal. - * Note: Calling this directly from JS is synchronous but does not clear - * input buffers and does not reset the parser, thus the terminal will - * continue to apply pending input data. - * If you need in band reset (synchronous with input data) consider - * using DECSTR (soft reset, CSI ! p) or RIS instead (hard reset, ESC c). - */ - public reset(): void { - /** - * Since _setup handles a full terminal creation, we have to carry forward - * a few things that should not reset. - */ - this.options.rows = this.rows; - this.options.cols = this.cols; - const customKeyEventHandler = this._customKeyEventHandler; - - this._setup(); - super.reset(); - this._selectionService?.reset(); - - // reattach - this._customKeyEventHandler = customKeyEventHandler; - - // do a full screen refresh - this.refresh(0, this.rows - 1); - this.viewport?.syncScrollArea(); - } - - private _reportWindowsOptions(type: WindowsOptionsReportType): void { - if (!this._renderService) { - return; - } - - switch (type) { - case WindowsOptionsReportType.GET_WIN_SIZE_PIXELS: - const canvasWidth = this._renderService.dimensions.scaledCanvasWidth.toFixed(0); - const canvasHeight = this._renderService.dimensions.scaledCanvasHeight.toFixed(0); - this._coreService.triggerDataEvent(`${C0.ESC}[4;${canvasHeight};${canvasWidth}t`); - break; - case WindowsOptionsReportType.GET_CELL_SIZE_PIXELS: - const cellWidth = this._renderService.dimensions.scaledCellWidth.toFixed(0); - const cellHeight = this._renderService.dimensions.scaledCellHeight.toFixed(0); - this._coreService.triggerDataEvent(`${C0.ESC}[6;${cellHeight};${cellWidth}t`); - break; - } - } - - // TODO: Remove cancel function and cancelEvents option - public cancel(ev: Event, force?: boolean): boolean | undefined { - if (!this.options.cancelEvents && !force) { - return; - } - ev.preventDefault(); - ev.stopPropagation(); - return false; - } - - private _visualBell(): boolean { - return false; - // return this.options.bellStyle === 'visual' || - // this.options.bellStyle === 'both'; - } - - private _soundBell(): boolean { - return this.options.bellStyle === 'sound'; - // return this.options.bellStyle === 'sound' || - // this.options.bellStyle === 'both'; - } -} - -/** - * Helpers - */ - -function wasModifierKeyOnlyEvent(ev: KeyboardEvent): boolean { - return ev.keyCode === 16 || // Shift - ev.keyCode === 17 || // Ctrl - ev.keyCode === 18; // Alt -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Types.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Types.d.ts deleted file mode 100755 index e8e0cabd1..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Types.d.ts +++ /dev/null @@ -1,294 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IDisposable, IMarker, ISelectionPosition } from 'xterm'; -import { IEvent } from 'common/EventEmitter'; -import { ICoreTerminal, CharData, ITerminalOptions } from 'common/Types'; -import { IMouseService, IRenderService } from './services/Services'; -import { IBuffer, IBufferSet } from 'common/buffer/Types'; -import { IFunctionIdentifier, IParams } from 'common/parser/Types'; - -export interface ITerminal extends IPublicTerminal, ICoreTerminal { - element: HTMLElement | undefined; - screenElement: HTMLElement | undefined; - browser: IBrowser; - buffer: IBuffer; - buffers: IBufferSet; - viewport: IViewport | undefined; - // TODO: We should remove options once components adopt optionsService - options: ITerminalOptions; - linkifier: ILinkifier; - linkifier2: ILinkifier2; - - onBlur: IEvent; - onFocus: IEvent; - onA11yChar: IEvent; - onA11yTab: IEvent; - - cancel(ev: Event, force?: boolean): boolean | void; -} - -// Portions of the public API that are required by the internal Terminal -export interface IPublicTerminal extends IDisposable { - textarea: HTMLTextAreaElement | undefined; - rows: number; - cols: number; - buffer: IBuffer; - markers: IMarker[]; - onCursorMove: IEvent; - onData: IEvent; - onBinary: IEvent; - onKey: IEvent<{ key: string, domEvent: KeyboardEvent }>; - onLineFeed: IEvent; - onScroll: IEvent; - onSelectionChange: IEvent; - onRender: IEvent<{ start: number, end: number }>; - onResize: IEvent<{ cols: number, rows: number }>; - onTitleChange: IEvent; - blur(): void; - focus(): void; - resize(columns: number, rows: number): void; - open(parent: HTMLElement): void; - attachCustomKeyEventHandler(customKeyEventHandler: (event: KeyboardEvent) => boolean): void; - addCsiHandler(id: IFunctionIdentifier, callback: (params: IParams) => boolean): IDisposable; - addDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: IParams) => boolean): IDisposable; - addEscHandler(id: IFunctionIdentifier, callback: () => boolean): IDisposable; - addOscHandler(ident: number, callback: (data: string) => boolean): IDisposable; - registerLinkMatcher(regex: RegExp, handler: (event: MouseEvent, uri: string) => void, options?: ILinkMatcherOptions): number; - deregisterLinkMatcher(matcherId: number): void; - registerLinkProvider(linkProvider: ILinkProvider): IDisposable; - registerCharacterJoiner(handler: (text: string) => [number, number][]): number; - deregisterCharacterJoiner(joinerId: number): void; - addMarker(cursorYOffset: number): IMarker | undefined; - hasSelection(): boolean; - getSelection(): string; - getSelectionPosition(): ISelectionPosition | undefined; - clearSelection(): void; - select(column: number, row: number, length: number): void; - selectAll(): void; - selectLines(start: number, end: number): void; - dispose(): void; - scrollLines(amount: number): void; - scrollPages(pageCount: number): void; - scrollToTop(): void; - scrollToBottom(): void; - scrollToLine(line: number): void; - clear(): void; - write(data: string | Uint8Array, callback?: () => void): void; - paste(data: string): void; - refresh(start: number, end: number): void; - reset(): void; -} - -export type CustomKeyEventHandler = (event: KeyboardEvent) => boolean; - -export type LineData = CharData[]; - -export interface ICompositionHelper { - readonly isComposing: boolean; - compositionstart(): void; - compositionupdate(ev: CompositionEvent): void; - compositionend(): void; - updateCompositionElements(dontRecurse?: boolean): void; - keydown(ev: KeyboardEvent): boolean; -} - -export interface IBrowser { - isNode: boolean; - userAgent: string; - platform: string; - isFirefox: boolean; - isMac: boolean; - isIpad: boolean; - isIphone: boolean; - isWindows: boolean; -} - -export interface IColorManager { - colors: IColorSet; - onOptionsChange(key: string): void; -} - -export interface IColor { - css: string; - rgba: number; // 32-bit int with rgba in each byte -} - -export interface IColorSet { - foreground: IColor; - background: IColor; - cursor: IColor; - cursorAccent: IColor; - selectionTransparent: IColor; - /** The selection blended on top of background. */ - selectionOpaque: IColor; - ansi: IColor[]; - contrastCache: IColorContrastCache; -} - -export interface IColorContrastCache { - clear(): void; - setCss(bg: number, fg: number, value: string | null): void; - getCss(bg: number, fg: number): string | null | undefined; - setColor(bg: number, fg: number, value: IColor | null): void; - getColor(bg: number, fg: number): IColor | null | undefined; -} - -export interface IPartialColorSet { - foreground: IColor; - background: IColor; - cursor?: IColor; - cursorAccent?: IColor; - selection?: IColor; - ansi: IColor[]; -} - -export interface IViewport extends IDisposable { - scrollBarWidth: number; - syncScrollArea(immediate?: boolean): void; - getLinesScrolled(ev: WheelEvent): number; - onWheel(ev: WheelEvent): boolean; - onTouchStart(ev: TouchEvent): void; - onTouchMove(ev: TouchEvent): boolean; - onThemeChange(colors: IColorSet): void; -} - -export interface IViewportRange { - start: IViewportRangePosition; - end: IViewportRangePosition; -} - -export interface IViewportRangePosition { - x: number; - y: number; -} - -export type LinkMatcherHandler = (event: MouseEvent, uri: string) => void; -export type LinkMatcherHoverTooltipCallback = (event: MouseEvent, uri: string, position: IViewportRange) => void; -export type LinkMatcherValidationCallback = (uri: string, callback: (isValid: boolean) => void) => void; - -export interface ILinkMatcher { - id: number; - regex: RegExp; - handler: LinkMatcherHandler; - hoverTooltipCallback?: LinkMatcherHoverTooltipCallback; - hoverLeaveCallback?: () => void; - matchIndex?: number; - validationCallback?: LinkMatcherValidationCallback; - priority?: number; - willLinkActivate?: (event: MouseEvent, uri: string) => boolean; -} - -export interface IRegisteredLinkMatcher extends ILinkMatcher { - priority: number; -} - -export interface ILinkifierEvent { - x1: number; - y1: number; - x2: number; - y2: number; - cols: number; - fg: number | undefined; -} - -export interface ILinkifier { - onShowLinkUnderline: IEvent; - onHideLinkUnderline: IEvent; - onLinkTooltip: IEvent; - - attachToDom(element: HTMLElement, mouseZoneManager: IMouseZoneManager): void; - linkifyRows(start: number, end: number): void; - registerLinkMatcher(regex: RegExp, handler: LinkMatcherHandler, options?: ILinkMatcherOptions): number; - deregisterLinkMatcher(matcherId: number): boolean; -} - -export interface ILinkifier2 { - onShowLinkUnderline: IEvent; - onHideLinkUnderline: IEvent; - - attachToDom(element: HTMLElement, mouseService: IMouseService, renderService: IRenderService): void; - registerLinkProvider(linkProvider: ILinkProvider): IDisposable; -} - -export interface ILinkMatcherOptions { - /** - * The index of the link from the regex.match(text) call. This defaults to 0 - * (for regular expressions without capture groups). - */ - matchIndex?: number; - /** - * A callback that validates an individual link, returning true if valid and - * false if invalid. - */ - validationCallback?: LinkMatcherValidationCallback; - /** - * A callback that fires when the mouse hovers over a link. - */ - tooltipCallback?: LinkMatcherHoverTooltipCallback; - /** - * A callback that fires when the mouse leaves a link that was hovered. - */ - leaveCallback?: () => void; - /** - * The priority of the link matcher, this defines the order in which the link - * matcher is evaluated relative to others, from highest to lowest. The - * default value is 0. - */ - priority?: number; - /** - * A callback that fires when the mousedown and click events occur that - * determines whether a link will be activated upon click. This enables - * only activating a link when a certain modifier is held down, if not the - * mouse event will continue propagation (eg. double click to select word). - */ - willLinkActivate?: (event: MouseEvent, uri: string) => boolean; -} - -export interface IMouseZoneManager extends IDisposable { - add(zone: IMouseZone): void; - clearAll(start?: number, end?: number): void; -} - -export interface IMouseZone { - x1: number; - x2: number; - y1: number; - y2: number; - clickCallback: (e: MouseEvent) => any; - hoverCallback: (e: MouseEvent) => any | undefined; - tooltipCallback: (e: MouseEvent) => any | undefined; - leaveCallback: () => any | undefined; - willLinkActivate: (e: MouseEvent) => boolean; -} - -interface ILinkProvider { - provideLinks(y: number, callback: (links: ILink[] | undefined) => void): void; -} - -interface ILink { - range: IBufferRange; - text: string; - decorations?: ILinkDecorations; - activate(event: MouseEvent, text: string): void; - hover?(event: MouseEvent, text: string): void; - leave?(event: MouseEvent, text: string): void; - dispose?(): void; -} - -interface ILinkDecorations { - pointerCursor: boolean; - underline: boolean; -} - -interface IBufferRange { - start: IBufferCellPosition; - end: IBufferCellPosition; -} - -interface IBufferCellPosition { - x: number; - y: number; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Viewport.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Viewport.ts deleted file mode 100755 index 29edce6f7..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/Viewport.ts +++ /dev/null @@ -1,267 +0,0 @@ -/** - * Copyright (c) 2016 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { Disposable } from 'common/Lifecycle'; -import { addDisposableDomListener } from 'browser/Lifecycle'; -import { IColorSet, IViewport } from 'browser/Types'; -import { ICharSizeService, IRenderService } from 'browser/services/Services'; -import { IBufferService, IOptionsService } from 'common/services/Services'; - -const FALLBACK_SCROLL_BAR_WIDTH = 15; - -/** - * Represents the viewport of a terminal, the visible area within the larger buffer of output. - * Logic for the virtual scroll bar is included in this object. - */ -export class Viewport extends Disposable implements IViewport { - public scrollBarWidth: number = 0; - private _currentRowHeight: number = 0; - private _lastRecordedBufferLength: number = 0; - private _lastRecordedViewportHeight: number = 0; - private _lastRecordedBufferHeight: number = 0; - private _lastTouchY: number = 0; - private _lastScrollTop: number = 0; - - // Stores a partial line amount when scrolling, this is used to keep track of how much of a line - // is scrolled so we can "scroll" over partial lines and feel natural on touchpads. This is a - // quick fix and could have a more robust solution in place that reset the value when needed. - private _wheelPartialScroll: number = 0; - - private _refreshAnimationFrame: number | null = null; - private _ignoreNextScrollEvent: boolean = false; - - constructor( - private readonly _scrollLines: (amount: number, suppressEvent: boolean) => void, - private readonly _viewportElement: HTMLElement, - private readonly _scrollArea: HTMLElement, - @IBufferService private readonly _bufferService: IBufferService, - @IOptionsService private readonly _optionsService: IOptionsService, - @ICharSizeService private readonly _charSizeService: ICharSizeService, - @IRenderService private readonly _renderService: IRenderService - ) { - super(); - - // Measure the width of the scrollbar. If it is 0 we can assume it's an OSX overlay scrollbar. - // Unfortunately the overlay scrollbar would be hidden underneath the screen element in that case, - // therefore we account for a standard amount to make it visible - this.scrollBarWidth = (this._viewportElement.offsetWidth - this._scrollArea.offsetWidth) || FALLBACK_SCROLL_BAR_WIDTH; - this.register(addDisposableDomListener(this._viewportElement, 'scroll', this._onScroll.bind(this))); - - // Perform this async to ensure the ICharSizeService is ready. - setTimeout(() => this.syncScrollArea(), 0); - } - - public onThemeChange(colors: IColorSet): void { - this._viewportElement.style.backgroundColor = colors.background.css; - } - - /** - * Refreshes row height, setting line-height, viewport height and scroll area height if - * necessary. - */ - private _refresh(immediate: boolean): void { - if (immediate) { - this._innerRefresh(); - if (this._refreshAnimationFrame !== null) { - cancelAnimationFrame(this._refreshAnimationFrame); - } - return; - } - if (this._refreshAnimationFrame === null) { - this._refreshAnimationFrame = requestAnimationFrame(() => this._innerRefresh()); - } - } - - private _innerRefresh(): void { - if (this._charSizeService.height > 0) { - this._currentRowHeight = this._renderService.dimensions.scaledCellHeight / window.devicePixelRatio; - this._lastRecordedViewportHeight = this._viewportElement.offsetHeight; - const newBufferHeight = Math.round(this._currentRowHeight * this._lastRecordedBufferLength) + (this._lastRecordedViewportHeight - this._renderService.dimensions.canvasHeight); - if (this._lastRecordedBufferHeight !== newBufferHeight) { - this._lastRecordedBufferHeight = newBufferHeight; - this._scrollArea.style.height = this._lastRecordedBufferHeight + 'px'; - } - } - - // Sync scrollTop - const scrollTop = this._bufferService.buffer.ydisp * this._currentRowHeight; - if (this._viewportElement.scrollTop !== scrollTop) { - // Ignore the next scroll event which will be triggered by setting the scrollTop as we do not - // want this event to scroll the terminal - this._ignoreNextScrollEvent = true; - this._viewportElement.scrollTop = scrollTop; - } - - this._refreshAnimationFrame = null; - } - /** - * Updates dimensions and synchronizes the scroll area if necessary. - */ - public syncScrollArea(immediate: boolean = false): void { - // If buffer height changed - if (this._lastRecordedBufferLength !== this._bufferService.buffer.lines.length) { - this._lastRecordedBufferLength = this._bufferService.buffer.lines.length; - this._refresh(immediate); - return; - } - - // If viewport height changed - if (this._lastRecordedViewportHeight !== this._renderService.dimensions.canvasHeight) { - this._refresh(immediate); - return; - } - - // If the buffer position doesn't match last scroll top - const newScrollTop = this._bufferService.buffer.ydisp * this._currentRowHeight; - if (this._lastScrollTop !== newScrollTop) { - this._refresh(immediate); - return; - } - - // If element's scroll top changed, this can happen when hiding the element - if (this._lastScrollTop !== this._viewportElement.scrollTop) { - this._refresh(immediate); - return; - } - - // If row height changed - if (this._renderService.dimensions.scaledCellHeight / window.devicePixelRatio !== this._currentRowHeight) { - this._refresh(immediate); - return; - } - } - - /** - * Handles scroll events on the viewport, calculating the new viewport and requesting the - * terminal to scroll to it. - * @param ev The scroll event. - */ - private _onScroll(ev: Event): void { - // Record current scroll top position - this._lastScrollTop = this._viewportElement.scrollTop; - - // Don't attempt to scroll if the element is not visible, otherwise scrollTop will be corrupt - // which causes the terminal to scroll the buffer to the top - if (!this._viewportElement.offsetParent) { - return; - } - - // Ignore the event if it was flagged to ignore (when the source of the event is from Viewport) - if (this._ignoreNextScrollEvent) { - this._ignoreNextScrollEvent = false; - return; - } - - const newRow = Math.round(this._lastScrollTop / this._currentRowHeight); - const diff = newRow - this._bufferService.buffer.ydisp; - this._scrollLines(diff, true); - } - - /** - * Handles bubbling of scroll event in case the viewport has reached top or bottom - * @param ev The scroll event. - * @param amount The amount scrolled - */ - private _bubbleScroll(ev: Event, amount: number): boolean { - const scrollPosFromTop = this._viewportElement.scrollTop + this._lastRecordedViewportHeight; - if ((amount < 0 && this._viewportElement.scrollTop !== 0) || - (amount > 0 && scrollPosFromTop < this._lastRecordedBufferHeight)) { - if (ev.cancelable) { - ev.preventDefault(); - } - return false; - } - return true; - } - - /** - * Handles mouse wheel events by adjusting the viewport's scrollTop and delegating the actual - * scrolling to `onScroll`, this event needs to be attached manually by the consumer of - * `Viewport`. - * @param ev The mouse wheel event. - */ - public onWheel(ev: WheelEvent): boolean { - const amount = this._getPixelsScrolled(ev); - if (amount === 0) { - return false; - } - this._viewportElement.scrollTop += amount; - return this._bubbleScroll(ev, amount); - } - - private _getPixelsScrolled(ev: WheelEvent): number { - // Do nothing if it's not a vertical scroll event - if (ev.deltaY === 0) { - return 0; - } - - // Fallback to WheelEvent.DOM_DELTA_PIXEL - let amount = this._applyScrollModifier(ev.deltaY, ev); - if (ev.deltaMode === WheelEvent.DOM_DELTA_LINE) { - amount *= this._currentRowHeight; - } else if (ev.deltaMode === WheelEvent.DOM_DELTA_PAGE) { - amount *= this._currentRowHeight * this._bufferService.rows; - } - return amount; - } - - /** - * Gets the number of pixels scrolled by the mouse event taking into account what type of delta - * is being used. - * @param ev The mouse wheel event. - */ - public getLinesScrolled(ev: WheelEvent): number { - // Do nothing if it's not a vertical scroll event - if (ev.deltaY === 0) { - return 0; - } - - // Fallback to WheelEvent.DOM_DELTA_LINE - let amount = this._applyScrollModifier(ev.deltaY, ev); - if (ev.deltaMode === WheelEvent.DOM_DELTA_PIXEL) { - amount /= this._currentRowHeight + 0.0; // Prevent integer division - this._wheelPartialScroll += amount; - amount = Math.floor(Math.abs(this._wheelPartialScroll)) * (this._wheelPartialScroll > 0 ? 1 : -1); - this._wheelPartialScroll %= 1; - } else if (ev.deltaMode === WheelEvent.DOM_DELTA_PAGE) { - amount *= this._bufferService.rows; - } - return amount; - } - - private _applyScrollModifier(amount: number, ev: WheelEvent): number { - const modifier = this._optionsService.options.fastScrollModifier; - // Multiply the scroll speed when the modifier is down - if ((modifier === 'alt' && ev.altKey) || - (modifier === 'ctrl' && ev.ctrlKey) || - (modifier === 'shift' && ev.shiftKey)) { - return amount * this._optionsService.options.fastScrollSensitivity * this._optionsService.options.scrollSensitivity; - } - - return amount * this._optionsService.options.scrollSensitivity; - } - - /** - * Handles the touchstart event, recording the touch occurred. - * @param ev The touch event. - */ - public onTouchStart(ev: TouchEvent): void { - this._lastTouchY = ev.touches[0].pageY; - } - - /** - * Handles the touchmove event, scrolling the viewport if the position shifted. - * @param ev The touch event. - */ - public onTouchMove(ev: TouchEvent): boolean { - const deltaY = this._lastTouchY - ev.touches[0].pageY; - this._lastTouchY = ev.touches[0].pageY; - if (deltaY === 0) { - return false; - } - this._viewportElement.scrollTop += deltaY; - return this._bubbleScroll(ev, deltaY); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/input/CompositionHelper.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/input/CompositionHelper.ts deleted file mode 100755 index f93483d32..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/input/CompositionHelper.ts +++ /dev/null @@ -1,234 +0,0 @@ -/** - * Copyright (c) 2016 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ICharSizeService } from 'browser/services/Services'; -import { IBufferService, ICoreService, IOptionsService } from 'common/services/Services'; - -interface IPosition { - start: number; - end: number; -} - -/** - * Encapsulates the logic for handling compositionstart, compositionupdate and compositionend - * events, displaying the in-progress composition to the UI and forwarding the final composition - * to the handler. - */ -export class CompositionHelper { - /** - * Whether input composition is currently happening, eg. via a mobile keyboard, speech input or - * IME. This variable determines whether the compositionText should be displayed on the UI. - */ - private _isComposing: boolean; - public get isComposing(): boolean { return this._isComposing; } - - /** - * The position within the input textarea's value of the current composition. - */ - private _compositionPosition: IPosition; - - /** - * Whether a composition is in the process of being sent, setting this to false will cancel any - * in-progress composition. - */ - private _isSendingComposition: boolean; - - /** - * Data already sent due to keydown event. - */ - private _dataAlreadySent: string; - - constructor( - private readonly _textarea: HTMLTextAreaElement, - private readonly _compositionView: HTMLElement, - @IBufferService private readonly _bufferService: IBufferService, - @IOptionsService private readonly _optionsService: IOptionsService, - @ICharSizeService private readonly _charSizeService: ICharSizeService, - @ICoreService private readonly _coreService: ICoreService - ) { - this._isComposing = false; - this._isSendingComposition = false; - this._compositionPosition = { start: 0, end: 0 }; - this._dataAlreadySent = ''; - } - - /** - * Handles the compositionstart event, activating the composition view. - */ - public compositionstart(): void { - this._isComposing = true; - this._compositionPosition.start = this._textarea.value.length; - this._compositionView.textContent = ''; - this._dataAlreadySent = ''; - this._compositionView.classList.add('active'); - } - - /** - * Handles the compositionupdate event, updating the composition view. - * @param ev The event. - */ - public compositionupdate(ev: CompositionEvent): void { - this._compositionView.textContent = ev.data; - this.updateCompositionElements(); - setTimeout(() => { - this._compositionPosition.end = this._textarea.value.length; - }, 0); - } - - /** - * Handles the compositionend event, hiding the composition view and sending the composition to - * the handler. - */ - public compositionend(): void { - this._finalizeComposition(true); - } - - /** - * Handles the keydown event, routing any necessary events to the CompositionHelper functions. - * @param ev The keydown event. - * @return Whether the Terminal should continue processing the keydown event. - */ - public keydown(ev: KeyboardEvent): boolean { - if (this._isComposing || this._isSendingComposition) { - if (ev.keyCode === 229) { - // Continue composing if the keyCode is the "composition character" - return false; - } - if (ev.keyCode === 16 || ev.keyCode === 17 || ev.keyCode === 18) { - // Continue composing if the keyCode is a modifier key - return false; - } - // Finish composition immediately. This is mainly here for the case where enter is - // pressed and the handler needs to be triggered before the command is executed. - this._finalizeComposition(false); - } - - if (ev.keyCode === 229) { - // If the "composition character" is used but gets to this point it means a non-composition - // character (eg. numbers and punctuation) was pressed when the IME was active. - this._handleAnyTextareaChanges(); - return false; - } - - return true; - } - - /** - * Finalizes the composition, resuming regular input actions. This is called when a composition - * is ending. - * @param waitForPropagation Whether to wait for events to propagate before sending - * the input. This should be false if a non-composition keystroke is entered before the - * compositionend event is triggered, such as enter, so that the composition is sent before - * the command is executed. - */ - private _finalizeComposition(waitForPropagation: boolean): void { - this._compositionView.classList.remove('active'); - this._isComposing = false; - - if (!waitForPropagation) { - // Cancel any delayed composition send requests and send the input immediately. - this._isSendingComposition = false; - const input = this._textarea.value.substring(this._compositionPosition.start, this._compositionPosition.end); - this._coreService.triggerDataEvent(input, true); - } else { - // Make a deep copy of the composition position here as a new compositionstart event may - // fire before the setTimeout executes. - const currentCompositionPosition = { - start: this._compositionPosition.start, - end: this._compositionPosition.end - }; - - // Since composition* events happen before the changes take place in the textarea on most - // browsers, use a setTimeout with 0ms time to allow the native compositionend event to - // complete. This ensures the correct character is retrieved. - // This solution was used because: - // - The compositionend event's data property is unreliable, at least on Chromium - // - The last compositionupdate event's data property does not always accurately describe - // the character, a counter example being Korean where an ending consonsant can move to - // the following character if the following input is a vowel. - this._isSendingComposition = true; - setTimeout(() => { - // Ensure that the input has not already been sent - if (this._isSendingComposition) { - this._isSendingComposition = false; - let input; - // Add length of data already sent due to keydown event, - // otherwise input characters can be duplicated. (Issue #3191) - currentCompositionPosition.start += this._dataAlreadySent.length; - if (this._isComposing) { - // Use the end position to get the string if a new composition has started. - input = this._textarea.value.substring(currentCompositionPosition.start, currentCompositionPosition.end); - } else { - // Don't use the end position here in order to pick up any characters after the - // composition has finished, for example when typing a non-composition character - // (eg. 2) after a composition character. - input = this._textarea.value.substring(currentCompositionPosition.start); - } - if (input.length > 0) { - this._coreService.triggerDataEvent(input, true); - } - } - }, 0); - } - } - - /** - * Apply any changes made to the textarea after the current event chain is allowed to complete. - * This should be called when not currently composing but a keydown event with the "composition - * character" (229) is triggered, in order to allow non-composition text to be entered when an - * IME is active. - */ - private _handleAnyTextareaChanges(): void { - const oldValue = this._textarea.value; - setTimeout(() => { - // Ignore if a composition has started since the timeout - if (!this._isComposing) { - const newValue = this._textarea.value; - const diff = newValue.replace(oldValue, ''); - if (diff.length > 0) { - this._dataAlreadySent = diff; - this._coreService.triggerDataEvent(diff, true); - } - } - }, 0); - } - - /** - * Positions the composition view on top of the cursor and the textarea just below it (so the - * IME helper dialog is positioned correctly). - * @param dontRecurse Whether to use setTimeout to recursively trigger another update, this is - * necessary as the IME events across browsers are not consistently triggered. - */ - public updateCompositionElements(dontRecurse?: boolean): void { - if (!this._isComposing) { - return; - } - - if (this._bufferService.buffer.isCursorInViewport) { - const cellHeight = Math.ceil(this._charSizeService.height * this._optionsService.options.lineHeight); - const cursorTop = this._bufferService.buffer.y * cellHeight; - const cursorLeft = this._bufferService.buffer.x * this._charSizeService.width; - - this._compositionView.style.left = cursorLeft + 'px'; - this._compositionView.style.top = cursorTop + 'px'; - this._compositionView.style.height = cellHeight + 'px'; - this._compositionView.style.lineHeight = cellHeight + 'px'; - this._compositionView.style.fontFamily = this._optionsService.options.fontFamily; - this._compositionView.style.fontSize = this._optionsService.options.fontSize + 'px'; - // Sync the textarea to the exact position of the composition view so the IME knows where the - // text is. - const compositionViewBounds = this._compositionView.getBoundingClientRect(); - this._textarea.style.left = cursorLeft + 'px'; - this._textarea.style.top = cursorTop + 'px'; - this._textarea.style.width = compositionViewBounds.width + 'px'; - this._textarea.style.height = compositionViewBounds.height + 'px'; - this._textarea.style.lineHeight = compositionViewBounds.height + 'px'; - } - - if (!dontRecurse) { - setTimeout(() => this.updateCompositionElements(true), 0); - } - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/input/Mouse.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/input/Mouse.ts deleted file mode 100755 index 2986fb3c6..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/input/Mouse.ts +++ /dev/null @@ -1,58 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -export function getCoordsRelativeToElement(event: {clientX: number, clientY: number}, element: HTMLElement): [number, number] { - const rect = element.getBoundingClientRect(); - return [event.clientX - rect.left, event.clientY - rect.top]; -} - -/** - * Gets coordinates within the terminal for a particular mouse event. The result - * is returned as an array in the form [x, y] instead of an object as it's a - * little faster and this function is used in some low level code. - * @param event The mouse event. - * @param element The terminal's container element. - * @param colCount The number of columns in the terminal. - * @param rowCount The number of rows n the terminal. - * @param isSelection Whether the request is for the selection or not. This will - * apply an offset to the x value such that the left half of the cell will - * select that cell and the right half will select the next cell. - */ -export function getCoords(event: {clientX: number, clientY: number}, element: HTMLElement, colCount: number, rowCount: number, hasValidCharSize: boolean, actualCellWidth: number, actualCellHeight: number, isSelection?: boolean): [number, number] | undefined { - // Coordinates cannot be measured if there are no valid - if (!hasValidCharSize) { - return undefined; - } - - const coords = getCoordsRelativeToElement(event, element); - if (!coords) { - return undefined; - } - - coords[0] = Math.ceil((coords[0] + (isSelection ? actualCellWidth / 2 : 0)) / actualCellWidth); - coords[1] = Math.ceil(coords[1] / actualCellHeight); - - // Ensure coordinates are within the terminal viewport. Note that selections - // need an addition point of precision to cover the end point (as characters - // cover half of one char and half of the next). - coords[0] = Math.min(Math.max(coords[0], 1), colCount + (isSelection ? 1 : 0)); - coords[1] = Math.min(Math.max(coords[1], 1), rowCount); - - return coords; -} - -/** - * Gets coordinates within the terminal for a particular mouse event, wrapping - * them to the bounds of the terminal and adding 32 to both the x and y values - * as expected by xterm. - */ -export function getRawByteCoords(coords: [number, number] | undefined): { x: number, y: number } | undefined { - if (!coords) { - return undefined; - } - - // xterm sends raw bytes and starts at 32 (SP) for each. - return { x: coords[0] + 32, y: coords[1] + 32 }; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/input/MoveToCell.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/input/MoveToCell.ts deleted file mode 100755 index 25e1844d4..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/input/MoveToCell.ts +++ /dev/null @@ -1,249 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { C0 } from 'common/data/EscapeSequences'; -import { IBufferService } from 'common/services/Services'; - -const enum Direction { - UP = 'A', - DOWN = 'B', - RIGHT = 'C', - LEFT = 'D' -} - -/** - * Concatenates all the arrow sequences together. - * Resets the starting row to an unwrapped row, moves to the requested row, - * then moves to requested col. - */ -export function moveToCellSequence(targetX: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): string { - const startX = bufferService.buffer.x; - const startY = bufferService.buffer.y; - - // The alt buffer should try to navigate between rows - if (!bufferService.buffer.hasScrollback) { - return resetStartingRow(startX, startY, targetX, targetY, bufferService, applicationCursor) + - moveToRequestedRow(startY, targetY, bufferService, applicationCursor) + - moveToRequestedCol(startX, startY, targetX, targetY, bufferService, applicationCursor); - } - - // Only move horizontally for the normal buffer - let direction; - if (startY === targetY) { - direction = startX > targetX ? Direction.LEFT : Direction.RIGHT; - return repeat(Math.abs(startX - targetX), sequence(direction, applicationCursor)); - } - direction = startY > targetY ? Direction.LEFT : Direction.RIGHT; - const rowDifference = Math.abs(startY - targetY); - const cellsToMove = colsFromRowEnd(startY > targetY ? targetX : startX, bufferService) + - (rowDifference - 1) * bufferService.cols + 1 /* wrap around 1 row */ + - colsFromRowBeginning(startY > targetY ? startX : targetX, bufferService); - return repeat(cellsToMove, sequence(direction, applicationCursor)); -} - -/** - * Find the number of cols from a row beginning to a col. - */ -function colsFromRowBeginning(currX: number, bufferService: IBufferService): number { - return currX - 1; -} - -/** - * Find the number of cols from a col to row end. - */ -function colsFromRowEnd(currX: number, bufferService: IBufferService): number { - return bufferService.cols - currX; -} - -/** - * If the initial position of the cursor is on a row that is wrapped, move the - * cursor up to the first row that is not wrapped to have accurate vertical - * positioning. - */ -function resetStartingRow(startX: number, startY: number, targetX: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): string { - if (moveToRequestedRow(startY, targetY, bufferService, applicationCursor).length === 0) { - return ''; - } - return repeat(bufferLine( - startX, startY, startX, - startY - wrappedRowsForRow(bufferService, startY), false, bufferService - ).length, sequence(Direction.LEFT, applicationCursor)); -} - -/** - * Using the reset starting and ending row, move to the requested row, - * ignoring wrapped rows - */ -function moveToRequestedRow(startY: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): string { - const startRow = startY - wrappedRowsForRow(bufferService, startY); - const endRow = targetY - wrappedRowsForRow(bufferService, targetY); - - const rowsToMove = Math.abs(startRow - endRow) - wrappedRowsCount(startY, targetY, bufferService); - - return repeat(rowsToMove, sequence(verticalDirection(startY, targetY), applicationCursor)); -} - -/** - * Move to the requested col on the ending row - */ -function moveToRequestedCol(startX: number, startY: number, targetX: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): string { - let startRow; - if (moveToRequestedRow(startY, targetY, bufferService, applicationCursor).length > 0) { - startRow = targetY - wrappedRowsForRow(bufferService, targetY); - } else { - startRow = startY; - } - - const endRow = targetY; - const direction = horizontalDirection(startX, startY, targetX, targetY, bufferService, applicationCursor); - - return repeat(bufferLine( - startX, startRow, targetX, endRow, - direction === Direction.RIGHT, bufferService - ).length, sequence(direction, applicationCursor)); -} - -/** - * Utility functions - */ - -/** - * Calculates the number of wrapped rows between the unwrapped starting and - * ending rows. These rows need to ignored since the cursor skips over them. - */ -function wrappedRowsCount(startY: number, targetY: number, bufferService: IBufferService): number { - let wrappedRows = 0; - const startRow = startY - wrappedRowsForRow(bufferService, startY); - const endRow = targetY - wrappedRowsForRow(bufferService, targetY); - - for (let i = 0; i < Math.abs(startRow - endRow); i++) { - const direction = verticalDirection(startY, targetY) === Direction.UP ? -1 : 1; - const line = bufferService.buffer.lines.get(startRow + (direction * i)); - if (line && line.isWrapped) { - wrappedRows++; - } - } - - return wrappedRows; -} - -/** - * Calculates the number of wrapped rows that make up a given row. - * @param currentRow The row to determine how many wrapped rows make it up - */ -function wrappedRowsForRow(bufferService: IBufferService, currentRow: number): number { - let rowCount = 0; - let line = bufferService.buffer.lines.get(currentRow); - let lineWraps = line && line.isWrapped; - - while (lineWraps && currentRow >= 0 && currentRow < bufferService.rows) { - rowCount++; - line = bufferService.buffer.lines.get(--currentRow); - lineWraps = line && line.isWrapped; - } - - return rowCount; -} - -/** - * Direction determiners - */ - -/** - * Determines if the right or left arrow is needed - */ -function horizontalDirection(startX: number, startY: number, targetX: number, targetY: number, bufferService: IBufferService, applicationCursor: boolean): Direction { - let startRow; - if (moveToRequestedRow(targetX, targetY, bufferService, applicationCursor).length > 0) { - startRow = targetY - wrappedRowsForRow(bufferService, targetY); - } else { - startRow = startY; - } - - if ((startX < targetX && - startRow <= targetY) || // down/right or same y/right - (startX >= targetX && - startRow < targetY)) { // down/left or same y/left - return Direction.RIGHT; - } - return Direction.LEFT; -} - -/** - * Determines if the up or down arrow is needed - */ -function verticalDirection(startY: number, targetY: number): Direction { - return startY > targetY ? Direction.UP : Direction.DOWN; -} - -/** - * Constructs the string of chars in the buffer from a starting row and col - * to an ending row and col - * @param startCol The starting column position - * @param startRow The starting row position - * @param endCol The ending column position - * @param endRow The ending row position - * @param forward Direction to move - */ -function bufferLine( - startCol: number, - startRow: number, - endCol: number, - endRow: number, - forward: boolean, - bufferService: IBufferService -): string { - let currentCol = startCol; - let currentRow = startRow; - let bufferStr = ''; - - while (currentCol !== endCol || currentRow !== endRow) { - currentCol += forward ? 1 : -1; - - if (forward && currentCol > bufferService.cols - 1) { - bufferStr += bufferService.buffer.translateBufferLineToString( - currentRow, false, startCol, currentCol - ); - currentCol = 0; - startCol = 0; - currentRow++; - } else if (!forward && currentCol < 0) { - bufferStr += bufferService.buffer.translateBufferLineToString( - currentRow, false, 0, startCol + 1 - ); - currentCol = bufferService.cols - 1; - startCol = currentCol; - currentRow--; - } - } - - return bufferStr + bufferService.buffer.translateBufferLineToString( - currentRow, false, startCol, currentCol - ); -} - -/** - * Constructs the escape sequence for clicking an arrow - * @param direction The direction to move - */ -function sequence(direction: Direction, applicationCursor: boolean): string { - const mod = applicationCursor ? 'O' : '['; - return C0.ESC + mod + direction; -} - -/** - * Returns a string repeated a given number of times - * Polyfill from https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/repeat - * @param count The number of times to repeat the string - * @param string The string that is to be repeated - */ -function repeat(count: number, str: string): string { - count = Math.floor(count); - let rpt = ''; - for (let i = 0; i < count; i++) { - rpt += str; - } - return rpt; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/public/AddonManager.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/public/AddonManager.ts deleted file mode 100755 index 0261fd682..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/public/AddonManager.ts +++ /dev/null @@ -1,56 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ITerminalAddon, IDisposable, Terminal } from 'xterm'; - -export interface ILoadedAddon { - instance: ITerminalAddon; - dispose: () => void; - isDisposed: boolean; -} - -export class AddonManager implements IDisposable { - protected _addons: ILoadedAddon[] = []; - - constructor() { - } - - public dispose(): void { - for (let i = this._addons.length - 1; i >= 0; i--) { - this._addons[i].instance.dispose(); - } - } - - public loadAddon(terminal: Terminal, instance: ITerminalAddon): void { - const loadedAddon: ILoadedAddon = { - instance, - dispose: instance.dispose, - isDisposed: false - }; - this._addons.push(loadedAddon); - instance.dispose = () => this._wrappedAddonDispose(loadedAddon); - instance.activate(terminal); - } - - private _wrappedAddonDispose(loadedAddon: ILoadedAddon): void { - if (loadedAddon.isDisposed) { - // Do nothing if already disposed - return; - } - let index = -1; - for (let i = 0; i < this._addons.length; i++) { - if (this._addons[i] === loadedAddon) { - index = i; - break; - } - } - if (index === -1) { - throw new Error('Could not dispose an addon that has not been loaded'); - } - loadedAddon.isDisposed = true; - loadedAddon.dispose.apply(loadedAddon.instance); - this._addons.splice(index, 1); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/public/Terminal.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/public/Terminal.ts deleted file mode 100755 index 70247f88e..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/public/Terminal.ts +++ /dev/null @@ -1,339 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { Terminal as ITerminalApi, ITerminalOptions, IMarker, IDisposable, ILinkMatcherOptions, ITheme, ILocalizableStrings, ITerminalAddon, ISelectionPosition, IBuffer as IBufferApi, IBufferNamespace as IBufferNamespaceApi, IBufferLine as IBufferLineApi, IBufferCell as IBufferCellApi, IParser, IFunctionIdentifier, ILinkProvider, IUnicodeHandling, IUnicodeVersionProvider, FontWeight } from 'xterm'; -import { ITerminal } from 'browser/Types'; -import { IBufferLine, ICellData } from 'common/Types'; -import { IBuffer, IBufferSet } from 'common/buffer/Types'; -import { CellData } from 'common/buffer/CellData'; -import { Terminal as TerminalCore } from '../Terminal'; -import * as Strings from '../LocalizableStrings'; -import { IEvent, EventEmitter } from 'common/EventEmitter'; -import { AddonManager } from './AddonManager'; -import { IParams } from 'common/parser/Types'; -import { BufferSet } from 'common/buffer/BufferSet'; - -export class Terminal implements ITerminalApi { - private _core: ITerminal; - private _addonManager: AddonManager; - private _parser: IParser | undefined; - private _buffer: BufferNamespaceApi | undefined; - - constructor(options?: ITerminalOptions) { - this._core = new TerminalCore(options); - this._addonManager = new AddonManager(); - } - - private _checkProposedApi(): void { - if (!this._core.optionsService.options.allowProposedApi) { - throw new Error('You must set the allowProposedApi option to true to use proposed API'); - } - } - - public get onCursorMove(): IEvent { return this._core.onCursorMove; } - public get onLineFeed(): IEvent { return this._core.onLineFeed; } - public get onSelectionChange(): IEvent { return this._core.onSelectionChange; } - public get onData(): IEvent { return this._core.onData; } - public get onBinary(): IEvent { return this._core.onBinary; } - public get onTitleChange(): IEvent { return this._core.onTitleChange; } - public get onScroll(): IEvent { return this._core.onScroll; } - public get onKey(): IEvent<{ key: string, domEvent: KeyboardEvent }> { return this._core.onKey; } - public get onRender(): IEvent<{ start: number, end: number }> { return this._core.onRender; } - public get onResize(): IEvent<{ cols: number, rows: number }> { return this._core.onResize; } - - public get element(): HTMLElement | undefined { return this._core.element; } - public get parser(): IParser { - this._checkProposedApi(); - if (!this._parser) { - this._parser = new ParserApi(this._core); - } - return this._parser; - } - public get unicode(): IUnicodeHandling { - this._checkProposedApi(); - return new UnicodeApi(this._core); - } - public get textarea(): HTMLTextAreaElement | undefined { return this._core.textarea; } - public get rows(): number { return this._core.rows; } - public get cols(): number { return this._core.cols; } - public get buffer(): IBufferNamespaceApi { - this._checkProposedApi(); - if (!this._buffer) { - this._buffer = new BufferNamespaceApi(this._core); - } - return this._buffer; - } - public get markers(): ReadonlyArray { - this._checkProposedApi(); - return this._core.markers; - } - public blur(): void { - this._core.blur(); - } - public focus(): void { - this._core.focus(); - } - public resize(columns: number, rows: number): void { - this._verifyIntegers(columns, rows); - this._core.resize(columns, rows); - } - public open(parent: HTMLElement): void { - this._core.open(parent); - } - public attachCustomKeyEventHandler(customKeyEventHandler: (event: KeyboardEvent) => boolean): void { - this._core.attachCustomKeyEventHandler(customKeyEventHandler); - } - public registerLinkMatcher(regex: RegExp, handler: (event: MouseEvent, uri: string) => void, options?: ILinkMatcherOptions): number { - this._checkProposedApi(); - return this._core.registerLinkMatcher(regex, handler, options); - } - public deregisterLinkMatcher(matcherId: number): void { - this._checkProposedApi(); - this._core.deregisterLinkMatcher(matcherId); - } - public registerLinkProvider(linkProvider: ILinkProvider): IDisposable { - this._checkProposedApi(); - return this._core.registerLinkProvider(linkProvider); - } - public registerCharacterJoiner(handler: (text: string) => [number, number][]): number { - this._checkProposedApi(); - return this._core.registerCharacterJoiner(handler); - } - public deregisterCharacterJoiner(joinerId: number): void { - this._checkProposedApi(); - this._core.deregisterCharacterJoiner(joinerId); - } - public registerMarker(cursorYOffset: number): IMarker | undefined { - this._checkProposedApi(); - this._verifyIntegers(cursorYOffset); - return this._core.addMarker(cursorYOffset); - } - public addMarker(cursorYOffset: number): IMarker | undefined { - return this.registerMarker(cursorYOffset); - } - public hasSelection(): boolean { - return this._core.hasSelection(); - } - public select(column: number, row: number, length: number): void { - this._verifyIntegers(column, row, length); - this._core.select(column, row, length); - } - public getSelection(): string { - return this._core.getSelection(); - } - public getSelectionPosition(): ISelectionPosition | undefined { - return this._core.getSelectionPosition(); - } - public clearSelection(): void { - this._core.clearSelection(); - } - public selectAll(): void { - this._core.selectAll(); - } - public selectLines(start: number, end: number): void { - this._verifyIntegers(start, end); - this._core.selectLines(start, end); - } - public dispose(): void { - this._addonManager.dispose(); - this._core.dispose(); - } - public scrollLines(amount: number): void { - this._verifyIntegers(amount); - this._core.scrollLines(amount); - } - public scrollPages(pageCount: number): void { - this._verifyIntegers(pageCount); - this._core.scrollPages(pageCount); - } - public scrollToTop(): void { - this._core.scrollToTop(); - } - public scrollToBottom(): void { - this._core.scrollToBottom(); - } - public scrollToLine(line: number): void { - this._verifyIntegers(line); - this._core.scrollToLine(line); - } - public clear(): void { - this._core.clear(); - } - public write(data: string | Uint8Array, callback?: () => void): void { - this._core.write(data, callback); - } - public writeUtf8(data: Uint8Array, callback?: () => void): void { - this._core.write(data, callback); - } - public writeln(data: string | Uint8Array, callback?: () => void): void { - this._core.write(data); - this._core.write('\r\n', callback); - } - public paste(data: string): void { - this._core.paste(data); - } - public getOption(key: 'bellSound' | 'bellStyle' | 'cursorStyle' | 'fontFamily' | 'logLevel' | 'rendererType' | 'termName' | 'wordSeparator'): string; - public getOption(key: 'allowTransparency' | 'altClickMovesCursor' | 'cancelEvents' | 'convertEol' | 'cursorBlink' | 'disableStdin' | 'macOptionIsMeta' | 'rightClickSelectsWord' | 'popOnBell' | 'visualBell'): boolean; - public getOption(key: 'cols' | 'fontSize' | 'letterSpacing' | 'lineHeight' | 'rows' | 'tabStopWidth' | 'scrollback'): number; - public getOption(key: 'fontWeight' | 'fontWeightBold'): FontWeight; - public getOption(key: string): any; - public getOption(key: any): any { - return this._core.optionsService.getOption(key); - } - public setOption(key: 'bellSound' | 'fontFamily' | 'termName' | 'wordSeparator', value: string): void; - public setOption(key: 'fontWeight' | 'fontWeightBold', value: 'normal' | 'bold' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900' | number): void; - public setOption(key: 'logLevel', value: 'debug' | 'info' | 'warn' | 'error' | 'off'): void; - public setOption(key: 'bellStyle', value: 'none' | 'visual' | 'sound' | 'both'): void; - public setOption(key: 'cursorStyle', value: 'block' | 'underline' | 'bar'): void; - public setOption(key: 'allowTransparency' | 'altClickMovesCursor' | 'cancelEvents' | 'convertEol' | 'cursorBlink' | 'disableStdin' | 'macOptionIsMeta' | 'rightClickSelectsWord' | 'popOnBell' | 'visualBell', value: boolean): void; - public setOption(key: 'fontSize' | 'letterSpacing' | 'lineHeight' | 'tabStopWidth' | 'scrollback', value: number): void; - public setOption(key: 'theme', value: ITheme): void; - public setOption(key: 'cols' | 'rows', value: number): void; - public setOption(key: string, value: any): void; - public setOption(key: any, value: any): void { - this._core.optionsService.setOption(key, value); - } - public refresh(start: number, end: number): void { - this._verifyIntegers(start, end); - this._core.refresh(start, end); - } - public reset(): void { - this._core.reset(); - } - public loadAddon(addon: ITerminalAddon): void { - return this._addonManager.loadAddon(this, addon); - } - public static get strings(): ILocalizableStrings { - return Strings; - } - - private _verifyIntegers(...values: number[]): void { - for (const value of values) { - if (value === Infinity || isNaN(value) || value % 1 !== 0) { - throw new Error('This API only accepts integers'); - } - } - } -} - -class BufferApiView implements IBufferApi { - constructor( - private _buffer: IBuffer, - public readonly type: 'normal' | 'alternate' - ) { } - - public init(buffer: IBuffer): BufferApiView { - this._buffer = buffer; - return this; - } - - public get cursorY(): number { return this._buffer.y; } - public get cursorX(): number { return this._buffer.x; } - public get viewportY(): number { return this._buffer.ydisp; } - public get baseY(): number { return this._buffer.ybase; } - public get length(): number { return this._buffer.lines.length; } - public getLine(y: number): IBufferLineApi | undefined { - const line = this._buffer.lines.get(y); - if (!line) { - return undefined; - } - return new BufferLineApiView(line); - } - public getNullCell(): IBufferCellApi { return new CellData(); } -} - -class BufferNamespaceApi implements IBufferNamespaceApi { - private _normal: BufferApiView; - private _alternate: BufferApiView; - private _onBufferChange = new EventEmitter(); - public get onBufferChange(): IEvent { return this._onBufferChange.event; } - - constructor(private _core: ITerminal) { - this._normal = new BufferApiView(this._core.buffers.normal, 'normal'); - this._alternate = new BufferApiView(this._core.buffers.alt, 'alternate'); - this._core.buffers.onBufferActivate(() => this._onBufferChange.fire(this.active)); - } - public get active(): IBufferApi { - if (this._core.buffers.active === this._core.buffers.normal) { return this.normal; } - if (this._core.buffers.active === this._core.buffers.alt) { return this.alternate; } - throw new Error('Active buffer is neither normal nor alternate'); - } - public get normal(): IBufferApi { - return this._normal.init(this._core.buffers.normal); - } - public get alternate(): IBufferApi { - return this._alternate.init(this._core.buffers.alt); - } -} - -class BufferLineApiView implements IBufferLineApi { - constructor(private _line: IBufferLine) { } - - public get isWrapped(): boolean { return this._line.isWrapped; } - public get length(): number { return this._line.length; } - public getCell(x: number, cell?: IBufferCellApi): IBufferCellApi | undefined { - if (x < 0 || x >= this._line.length) { - return undefined; - } - - if (cell) { - this._line.loadCell(x, cell); - return cell; - } - return this._line.loadCell(x, new CellData()); - } - public translateToString(trimRight?: boolean, startColumn?: number, endColumn?: number): string { - return this._line.translateToString(trimRight, startColumn, endColumn); - } -} - -class ParserApi implements IParser { - constructor(private _core: ITerminal) { } - - public registerCsiHandler(id: IFunctionIdentifier, callback: (params: (number | number[])[]) => boolean): IDisposable { - return this._core.addCsiHandler(id, (params: IParams) => callback(params.toArray())); - } - public addCsiHandler(id: IFunctionIdentifier, callback: (params: (number | number[])[]) => boolean): IDisposable { - return this.registerCsiHandler(id, callback); - } - public registerDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: (number | number[])[]) => boolean): IDisposable { - return this._core.addDcsHandler(id, (data: string, params: IParams) => callback(data, params.toArray())); - } - public addDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: (number | number[])[]) => boolean): IDisposable { - return this.registerDcsHandler(id, callback); - } - public registerEscHandler(id: IFunctionIdentifier, handler: () => boolean): IDisposable { - return this._core.addEscHandler(id, handler); - } - public addEscHandler(id: IFunctionIdentifier, handler: () => boolean): IDisposable { - return this.registerEscHandler(id, handler); - } - public registerOscHandler(ident: number, callback: (data: string) => boolean): IDisposable { - return this._core.addOscHandler(ident, callback); - } - public addOscHandler(ident: number, callback: (data: string) => boolean): IDisposable { - return this.registerOscHandler(ident, callback); - } -} - -class UnicodeApi implements IUnicodeHandling { - constructor(private _core: ITerminal) { } - - public register(provider: IUnicodeVersionProvider): void { - this._core.unicodeService.register(provider); - } - - public get versions(): string[] { - return this._core.unicodeService.versions; - } - - public get activeVersion(): string { - return this._core.unicodeService.activeVersion; - } - - public set activeVersion(version: string) { - this._core.unicodeService.activeVersion = version; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/BaseRenderLayer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/BaseRenderLayer.ts deleted file mode 100755 index 8afec352c..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/BaseRenderLayer.ts +++ /dev/null @@ -1,477 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IRenderDimensions, IRenderLayer } from 'browser/renderer/Types'; -import { ICellData } from 'common/Types'; -import { DEFAULT_COLOR, WHITESPACE_CELL_CHAR, WHITESPACE_CELL_CODE, Attributes } from 'common/buffer/Constants'; -import { IGlyphIdentifier } from 'browser/renderer/atlas/Types'; -import { DIM_OPACITY, INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants'; -import { BaseCharAtlas } from 'browser/renderer/atlas/BaseCharAtlas'; -import { acquireCharAtlas } from 'browser/renderer/atlas/CharAtlasCache'; -import { AttributeData } from 'common/buffer/AttributeData'; -import { IColorSet, IColor } from 'browser/Types'; -import { CellData } from 'common/buffer/CellData'; -import { IBufferService, IOptionsService } from 'common/services/Services'; -import { throwIfFalsy } from 'browser/renderer/RendererUtils'; -import { channels, color, rgba } from 'browser/Color'; -import { removeElementFromParent } from 'browser/Dom'; - -export abstract class BaseRenderLayer implements IRenderLayer { - private _canvas: HTMLCanvasElement; - protected _ctx!: CanvasRenderingContext2D; - private _scaledCharWidth: number = 0; - private _scaledCharHeight: number = 0; - private _scaledCellWidth: number = 0; - private _scaledCellHeight: number = 0; - private _scaledCharLeft: number = 0; - private _scaledCharTop: number = 0; - - protected _charAtlas: BaseCharAtlas | undefined; - - /** - * An object that's reused when drawing glyphs in order to reduce GC. - */ - private _currentGlyphIdentifier: IGlyphIdentifier = { - chars: '', - code: 0, - bg: 0, - fg: 0, - bold: false, - dim: false, - italic: false - }; - - constructor( - private _container: HTMLElement, - id: string, - zIndex: number, - private _alpha: boolean, - protected _colors: IColorSet, - private _rendererId: number, - protected readonly _bufferService: IBufferService, - protected readonly _optionsService: IOptionsService - ) { - this._canvas = document.createElement('canvas'); - this._canvas.classList.add(`xterm-${id}-layer`); - this._canvas.style.zIndex = zIndex.toString(); - this._initCanvas(); - this._container.appendChild(this._canvas); - } - - public dispose(): void { - removeElementFromParent(this._canvas); - this._charAtlas?.dispose(); - } - - private _initCanvas(): void { - this._ctx = throwIfFalsy(this._canvas.getContext('2d', {alpha: this._alpha})); - // Draw the background if this is an opaque layer - if (!this._alpha) { - this._clearAll(); - } - } - - public onOptionsChanged(): void {} - public onBlur(): void {} - public onFocus(): void {} - public onCursorMove(): void {} - public onGridChanged(startRow: number, endRow: number): void {} - public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean = false): void {} - - public setColors(colorSet: IColorSet): void { - this._refreshCharAtlas(colorSet); - } - - protected _setTransparency(alpha: boolean): void { - // Do nothing when alpha doesn't change - if (alpha === this._alpha) { - return; - } - - // Create new canvas and replace old one - const oldCanvas = this._canvas; - this._alpha = alpha; - // Cloning preserves properties - this._canvas = this._canvas.cloneNode() as HTMLCanvasElement; - this._initCanvas(); - this._container.replaceChild(this._canvas, oldCanvas); - - // Regenerate char atlas and force a full redraw - this._refreshCharAtlas(this._colors); - this.onGridChanged(0, this._bufferService.rows - 1); - } - - /** - * Refreshes the char atlas, aquiring a new one if necessary. - * @param colorSet The color set to use for the char atlas. - */ - private _refreshCharAtlas(colorSet: IColorSet): void { - if (this._scaledCharWidth <= 0 && this._scaledCharHeight <= 0) { - return; - } - this._charAtlas = acquireCharAtlas(this._optionsService.options, this._rendererId, colorSet, this._scaledCharWidth, this._scaledCharHeight); - this._charAtlas.warmUp(); - } - - public resize(dim: IRenderDimensions): void { - this._scaledCellWidth = dim.scaledCellWidth; - this._scaledCellHeight = dim.scaledCellHeight; - this._scaledCharWidth = dim.scaledCharWidth; - this._scaledCharHeight = dim.scaledCharHeight; - this._scaledCharLeft = dim.scaledCharLeft; - this._scaledCharTop = dim.scaledCharTop; - this._canvas.width = dim.scaledCanvasWidth; - this._canvas.height = dim.scaledCanvasHeight; - this._canvas.style.width = `${dim.canvasWidth}px`; - this._canvas.style.height = `${dim.canvasHeight}px`; - - // Draw the background if this is an opaque layer - if (!this._alpha) { - this._clearAll(); - } - - this._refreshCharAtlas(this._colors); - } - - public abstract reset(): void; - - /** - * Fills 1+ cells completely. This uses the existing fillStyle on the context. - * @param x The column to start at. - * @param y The row to start at - * @param width The number of columns to fill. - * @param height The number of rows to fill. - */ - protected _fillCells(x: number, y: number, width: number, height: number): void { - this._ctx.fillRect( - x * this._scaledCellWidth, - y * this._scaledCellHeight, - width * this._scaledCellWidth, - height * this._scaledCellHeight); - } - - /** - * Fills a 1px line (2px on HDPI) at the bottom of the cell. This uses the - * existing fillStyle on the context. - * @param x The column to fill. - * @param y The row to fill. - */ - protected _fillBottomLineAtCells(x: number, y: number, width: number = 1): void { - this._ctx.fillRect( - x * this._scaledCellWidth, - (y + 1) * this._scaledCellHeight - window.devicePixelRatio - 1 /* Ensure it's drawn within the cell */, - width * this._scaledCellWidth, - window.devicePixelRatio); - } - - /** - * Fills a 1px line (2px on HDPI) at the left of the cell. This uses the - * existing fillStyle on the context. - * @param x The column to fill. - * @param y The row to fill. - */ - protected _fillLeftLineAtCell(x: number, y: number, width: number): void { - this._ctx.fillRect( - x * this._scaledCellWidth, - y * this._scaledCellHeight, - window.devicePixelRatio * width, - this._scaledCellHeight); - } - - /** - * Strokes a 1px rectangle (2px on HDPI) around a cell. This uses the existing - * strokeStyle on the context. - * @param x The column to fill. - * @param y The row to fill. - */ - protected _strokeRectAtCell(x: number, y: number, width: number, height: number): void { - this._ctx.lineWidth = window.devicePixelRatio; - this._ctx.strokeRect( - x * this._scaledCellWidth + window.devicePixelRatio / 2, - y * this._scaledCellHeight + (window.devicePixelRatio / 2), - width * this._scaledCellWidth - window.devicePixelRatio, - (height * this._scaledCellHeight) - window.devicePixelRatio); - } - - /** - * Clears the entire canvas. - */ - protected _clearAll(): void { - if (this._alpha) { - this._ctx.clearRect(0, 0, this._canvas.width, this._canvas.height); - } else { - this._ctx.fillStyle = this._colors.background.css; - this._ctx.fillRect(0, 0, this._canvas.width, this._canvas.height); - } - } - - /** - * Clears 1+ cells completely. - * @param x The column to start at. - * @param y The row to start at. - * @param width The number of columns to clear. - * @param height The number of rows to clear. - */ - protected _clearCells(x: number, y: number, width: number, height: number): void { - if (this._alpha) { - this._ctx.clearRect( - x * this._scaledCellWidth, - y * this._scaledCellHeight, - width * this._scaledCellWidth, - height * this._scaledCellHeight); - } else { - this._ctx.fillStyle = this._colors.background.css; - this._ctx.fillRect( - x * this._scaledCellWidth, - y * this._scaledCellHeight, - width * this._scaledCellWidth, - height * this._scaledCellHeight); - } - } - - /** - * Draws a truecolor character at the cell. The character will be clipped to - * ensure that it fits with the cell, including the cell to the right if it's - * a wide character. This uses the existing fillStyle on the context. - * @param cell The cell data for the character to draw. - * @param x The column to draw at. - * @param y The row to draw at. - * @param color The color of the character. - */ - protected _fillCharTrueColor(cell: CellData, x: number, y: number): void { - this._ctx.font = this._getFont(false, false); - this._ctx.textBaseline = 'middle'; - this._clipRow(y); - this._ctx.fillText( - cell.getChars(), - x * this._scaledCellWidth + this._scaledCharLeft, - y * this._scaledCellHeight + this._scaledCharTop + this._scaledCharHeight / 2); - } - - /** - * Draws one or more characters at a cell. If possible this will draw using - * the character atlas to reduce draw time. - * @param chars The character or characters. - * @param code The character code. - * @param width The width of the characters. - * @param x The column to draw at. - * @param y The row to draw at. - * @param fg The foreground color, in the format stored within the attributes. - * @param bg The background color, in the format stored within the attributes. - * This is used to validate whether a cached image can be used. - * @param bold Whether the text is bold. - */ - protected _drawChars(cell: ICellData, x: number, y: number): void { - const contrastColor = this._getContrastColor(cell); - - // skip cache right away if we draw in RGB - // Note: to avoid bad runtime JoinedCellData will be skipped - // in the cache handler itself (atlasDidDraw == false) and - // fall through to uncached later down below - if (contrastColor || cell.isFgRGB() || cell.isBgRGB()) { - this._drawUncachedChars(cell, x, y, contrastColor); - return; - } - - let fg; - let bg; - if (cell.isInverse()) { - fg = (cell.isBgDefault()) ? INVERTED_DEFAULT_COLOR : cell.getBgColor(); - bg = (cell.isFgDefault()) ? INVERTED_DEFAULT_COLOR : cell.getFgColor(); - } else { - bg = (cell.isBgDefault()) ? DEFAULT_COLOR : cell.getBgColor(); - fg = (cell.isFgDefault()) ? DEFAULT_COLOR : cell.getFgColor(); - } - - const drawInBrightColor = this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && fg < 8; - - fg += drawInBrightColor ? 8 : 0; - this._currentGlyphIdentifier.chars = cell.getChars() || WHITESPACE_CELL_CHAR; - this._currentGlyphIdentifier.code = cell.getCode() || WHITESPACE_CELL_CODE; - this._currentGlyphIdentifier.bg = bg; - this._currentGlyphIdentifier.fg = fg; - this._currentGlyphIdentifier.bold = !!cell.isBold(); - this._currentGlyphIdentifier.dim = !!cell.isDim(); - this._currentGlyphIdentifier.italic = !!cell.isItalic(); - const atlasDidDraw = this._charAtlas && this._charAtlas.draw( - this._ctx, - this._currentGlyphIdentifier, - x * this._scaledCellWidth + this._scaledCharLeft, - y * this._scaledCellHeight + this._scaledCharTop - ); - - if (!atlasDidDraw) { - this._drawUncachedChars(cell, x, y); - } - } - - /** - * Draws one or more characters at one or more cells. The character(s) will be - * clipped to ensure that they fit with the cell(s), including the cell to the - * right if the last character is a wide character. - * @param chars The character. - * @param width The width of the character. - * @param fg The foreground color, in the format stored within the attributes. - * @param x The column to draw at. - * @param y The row to draw at. - */ - private _drawUncachedChars(cell: ICellData, x: number, y: number, fgOverride?: IColor): void { - this._ctx.save(); - this._ctx.font = this._getFont(!!cell.isBold(), !!cell.isItalic()); - this._ctx.textBaseline = 'middle'; - - if (cell.isInverse()) { - if (fgOverride) { - this._ctx.fillStyle = fgOverride.css; - } else if (cell.isBgDefault()) { - this._ctx.fillStyle = color.opaque(this._colors.background).css; - } else if (cell.isBgRGB()) { - this._ctx.fillStyle = `rgb(${AttributeData.toColorRGB(cell.getBgColor()).join(',')})`; - } else { - let bg = cell.getBgColor(); - if (this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && bg < 8) { - bg += 8; - } - this._ctx.fillStyle = this._colors.ansi[bg].css; - } - } else { - if (fgOverride) { - this._ctx.fillStyle = fgOverride.css; - } else if (cell.isFgDefault()) { - this._ctx.fillStyle = this._colors.foreground.css; - } else if (cell.isFgRGB()) { - this._ctx.fillStyle = `rgb(${AttributeData.toColorRGB(cell.getFgColor()).join(',')})`; - } else { - let fg = cell.getFgColor(); - if (this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && fg < 8) { - fg += 8; - } - this._ctx.fillStyle = this._colors.ansi[fg].css; - } - } - - this._clipRow(y); - - // Apply alpha to dim the character - if (cell.isDim()) { - this._ctx.globalAlpha = DIM_OPACITY; - } - // Draw the character - this._ctx.fillText( - cell.getChars(), - x * this._scaledCellWidth + this._scaledCharLeft, - y * this._scaledCellHeight + this._scaledCharTop + this._scaledCharHeight / 2); - this._ctx.restore(); - } - - /** - * Clips a row to ensure no pixels will be drawn outside the cells in the row. - * @param y The row to clip. - */ - private _clipRow(y: number): void { - this._ctx.beginPath(); - this._ctx.rect( - 0, - y * this._scaledCellHeight, - this._bufferService.cols * this._scaledCellWidth, - this._scaledCellHeight); - this._ctx.clip(); - } - - /** - * Gets the current font. - * @param isBold If we should use the bold fontWeight. - */ - protected _getFont(isBold: boolean, isItalic: boolean): string { - const fontWeight = isBold ? this._optionsService.options.fontWeightBold : this._optionsService.options.fontWeight; - const fontStyle = isItalic ? 'italic' : ''; - - return `${fontStyle} ${fontWeight} ${this._optionsService.options.fontSize * window.devicePixelRatio}px ${this._optionsService.options.fontFamily}`; - } - - private _getContrastColor(cell: CellData): IColor | undefined { - if (this._optionsService.options.minimumContrastRatio === 1) { - return undefined; - } - - // Try get from cache first - const adjustedColor = this._colors.contrastCache.getColor(cell.bg, cell.fg); - if (adjustedColor !== undefined) { - return adjustedColor || undefined; - } - - let fgColor = cell.getFgColor(); - let fgColorMode = cell.getFgColorMode(); - let bgColor = cell.getBgColor(); - let bgColorMode = cell.getBgColorMode(); - const isInverse = !!cell.isInverse(); - const isBold = !!cell.isInverse(); - if (isInverse) { - const temp = fgColor; - fgColor = bgColor; - bgColor = temp; - const temp2 = fgColorMode; - fgColorMode = bgColorMode; - bgColorMode = temp2; - } - - const bgRgba = this._resolveBackgroundRgba(bgColorMode, bgColor, isInverse); - const fgRgba = this._resolveForegroundRgba(fgColorMode, fgColor, isInverse, isBold); - const result = rgba.ensureContrastRatio(bgRgba, fgRgba, this._optionsService.options.minimumContrastRatio); - - if (!result) { - this._colors.contrastCache.setColor(cell.bg, cell.fg, null); - return undefined; - } - - const color: IColor = { - css: channels.toCss( - (result >> 24) & 0xFF, - (result >> 16) & 0xFF, - (result >> 8) & 0xFF - ), - rgba: result - }; - this._colors.contrastCache.setColor(cell.bg, cell.fg, color); - - return color; - } - - private _resolveBackgroundRgba(bgColorMode: number, bgColor: number, inverse: boolean): number { - switch (bgColorMode) { - case Attributes.CM_P16: - case Attributes.CM_P256: - return this._colors.ansi[bgColor].rgba; - case Attributes.CM_RGB: - return bgColor << 8; - case Attributes.CM_DEFAULT: - default: - if (inverse) { - return this._colors.foreground.rgba; - } - return this._colors.background.rgba; - } - } - - private _resolveForegroundRgba(fgColorMode: number, fgColor: number, inverse: boolean, bold: boolean): number { - switch (fgColorMode) { - case Attributes.CM_P16: - case Attributes.CM_P256: - if (this._optionsService.options.drawBoldTextInBrightColors && bold && fgColor < 8) { - fgColor += 8; - } - return this._colors.ansi[fgColor].rgba; - case Attributes.CM_RGB: - return fgColor << 8; - case Attributes.CM_DEFAULT: - default: - if (inverse) { - return this._colors.background.rgba; - } - return this._colors.foreground.rgba; - } - } -} - diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/CharacterJoinerRegistry.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/CharacterJoinerRegistry.ts deleted file mode 100755 index 5385b76b4..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/CharacterJoinerRegistry.ts +++ /dev/null @@ -1,326 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IBufferLine, ICellData, CharData } from 'common/Types'; -import { ICharacterJoinerRegistry, ICharacterJoiner } from 'browser/renderer/Types'; -import { AttributeData } from 'common/buffer/AttributeData'; -import { WHITESPACE_CELL_CHAR, Content } from 'common/buffer/Constants'; -import { CellData } from 'common/buffer/CellData'; -import { IBufferService } from 'common/services/Services'; - -export class JoinedCellData extends AttributeData implements ICellData { - private _width: number; - // .content carries no meaning for joined CellData, simply nullify it - // thus we have to overload all other .content accessors - public content: number = 0; - public fg: number; - public bg: number; - public combinedData: string = ''; - - constructor(firstCell: ICellData, chars: string, width: number) { - super(); - this.fg = firstCell.fg; - this.bg = firstCell.bg; - this.combinedData = chars; - this._width = width; - } - - public isCombined(): number { - // always mark joined cell data as combined - return Content.IS_COMBINED_MASK; - } - - public getWidth(): number { - return this._width; - } - - public getChars(): string { - return this.combinedData; - } - - public getCode(): number { - // code always gets the highest possible fake codepoint (read as -1) - // this is needed as code is used by caches as identifier - return 0x1FFFFF; - } - - public setFromCharData(value: CharData): void { - throw new Error('not implemented'); - } - - public getAsCharData(): CharData { - return [this.fg, this.getChars(), this.getWidth(), this.getCode()]; - } -} - -export class CharacterJoinerRegistry implements ICharacterJoinerRegistry { - - private _characterJoiners: ICharacterJoiner[] = []; - private _nextCharacterJoinerId: number = 0; - private _workCell: CellData = new CellData(); - - constructor(private _bufferService: IBufferService) { } - - public registerCharacterJoiner(handler: (text: string) => [number, number][]): number { - const joiner: ICharacterJoiner = { - id: this._nextCharacterJoinerId++, - handler - }; - - this._characterJoiners.push(joiner); - return joiner.id; - } - - public deregisterCharacterJoiner(joinerId: number): boolean { - for (let i = 0; i < this._characterJoiners.length; i++) { - if (this._characterJoiners[i].id === joinerId) { - this._characterJoiners.splice(i, 1); - return true; - } - } - - return false; - } - - public getJoinedCharacters(row: number): [number, number][] { - if (this._characterJoiners.length === 0) { - return []; - } - - const line = this._bufferService.buffer.lines.get(row); - if (!line || line.length === 0) { - return []; - } - - const ranges: [number, number][] = []; - const lineStr = line.translateToString(true); - - // Because some cells can be represented by multiple javascript characters, - // we track the cell and the string indexes separately. This allows us to - // translate the string ranges we get from the joiners back into cell ranges - // for use when rendering - let rangeStartColumn = 0; - let currentStringIndex = 0; - let rangeStartStringIndex = 0; - let rangeAttrFG = line.getFg(0); - let rangeAttrBG = line.getBg(0); - - for (let x = 0; x < line.getTrimmedLength(); x++) { - line.loadCell(x, this._workCell); - - if (this._workCell.getWidth() === 0) { - // If this character is of width 0, skip it. - continue; - } - - // End of range - if (this._workCell.fg !== rangeAttrFG || this._workCell.bg !== rangeAttrBG) { - // If we ended up with a sequence of more than one character, - // look for ranges to join. - if (x - rangeStartColumn > 1) { - const joinedRanges = this._getJoinedRanges( - lineStr, - rangeStartStringIndex, - currentStringIndex, - line, - rangeStartColumn - ); - for (let i = 0; i < joinedRanges.length; i++) { - ranges.push(joinedRanges[i]); - } - } - - // Reset our markers for a new range. - rangeStartColumn = x; - rangeStartStringIndex = currentStringIndex; - rangeAttrFG = this._workCell.fg; - rangeAttrBG = this._workCell.bg; - } - - currentStringIndex += this._workCell.getChars().length || WHITESPACE_CELL_CHAR.length; - } - - // Process any trailing ranges. - if (this._bufferService.cols - rangeStartColumn > 1) { - const joinedRanges = this._getJoinedRanges( - lineStr, - rangeStartStringIndex, - currentStringIndex, - line, - rangeStartColumn - ); - for (let i = 0; i < joinedRanges.length; i++) { - ranges.push(joinedRanges[i]); - } - } - - return ranges; - } - - /** - * Given a segment of a line of text, find all ranges of text that should be - * joined in a single rendering unit. Ranges are internally converted to - * column ranges, rather than string ranges. - * @param line String representation of the full line of text - * @param startIndex Start position of the range to search in the string (inclusive) - * @param endIndex End position of the range to search in the string (exclusive) - */ - private _getJoinedRanges(line: string, startIndex: number, endIndex: number, lineData: IBufferLine, startCol: number): [number, number][] { - const text = line.substring(startIndex, endIndex); - // At this point we already know that there is at least one joiner so - // we can just pull its value and assign it directly rather than - // merging it into an empty array, which incurs unnecessary writes. - const joinedRanges: [number, number][] = this._characterJoiners[0].handler(text); - for (let i = 1; i < this._characterJoiners.length; i++) { - // We merge any overlapping ranges across the different joiners - const joinerRanges = this._characterJoiners[i].handler(text); - for (let j = 0; j < joinerRanges.length; j++) { - CharacterJoinerRegistry._mergeRanges(joinedRanges, joinerRanges[j]); - } - } - this._stringRangesToCellRanges(joinedRanges, lineData, startCol); - return joinedRanges; - } - - /** - * Modifies the provided ranges in-place to adjust for variations between - * string length and cell width so that the range represents a cell range, - * rather than the string range the joiner provides. - * @param ranges String ranges containing start (inclusive) and end (exclusive) index - * @param line Cell data for the relevant line in the terminal - * @param startCol Offset within the line to start from - */ - private _stringRangesToCellRanges(ranges: [number, number][], line: IBufferLine, startCol: number): void { - let currentRangeIndex = 0; - let currentRangeStarted = false; - let currentStringIndex = 0; - let currentRange = ranges[currentRangeIndex]; - - // If we got through all of the ranges, stop searching - if (!currentRange) { - return; - } - - for (let x = startCol; x < this._bufferService.cols; x++) { - const width = line.getWidth(x); - const length = line.getString(x).length || WHITESPACE_CELL_CHAR.length; - - // We skip zero-width characters when creating the string to join the text - // so we do the same here - if (width === 0) { - continue; - } - - // Adjust the start of the range - if (!currentRangeStarted && currentRange[0] <= currentStringIndex) { - currentRange[0] = x; - currentRangeStarted = true; - } - - // Adjust the end of the range - if (currentRange[1] <= currentStringIndex) { - currentRange[1] = x; - - // We're finished with this range, so we move to the next one - currentRange = ranges[++currentRangeIndex]; - - // If there are no more ranges left, stop searching - if (!currentRange) { - break; - } - - // Ranges can be on adjacent characters. Because the end index of the - // ranges are exclusive, this means that the index for the start of a - // range can be the same as the end index of the previous range. To - // account for the start of the next range, we check here just in case. - if (currentRange[0] <= currentStringIndex) { - currentRange[0] = x; - currentRangeStarted = true; - } else { - currentRangeStarted = false; - } - } - - // Adjust the string index based on the character length to line up with - // the column adjustment - currentStringIndex += length; - } - - // If there is still a range left at the end, it must extend all the way to - // the end of the line. - if (currentRange) { - currentRange[1] = this._bufferService.cols; - } - } - - /** - * Merges the range defined by the provided start and end into the list of - * existing ranges. The merge is done in place on the existing range for - * performance and is also returned. - * @param ranges Existing range list - * @param newRange Tuple of two numbers representing the new range to merge in. - * @returns The ranges input with the new range merged in place - */ - private static _mergeRanges(ranges: [number, number][], newRange: [number, number]): [number, number][] { - let inRange = false; - for (let i = 0; i < ranges.length; i++) { - const range = ranges[i]; - if (!inRange) { - if (newRange[1] <= range[0]) { - // Case 1: New range is before the search range - ranges.splice(i, 0, newRange); - return ranges; - } - - if (newRange[1] <= range[1]) { - // Case 2: New range is either wholly contained within the - // search range or overlaps with the front of it - range[0] = Math.min(newRange[0], range[0]); - return ranges; - } - - if (newRange[0] < range[1]) { - // Case 3: New range either wholly contains the search range - // or overlaps with the end of it - range[0] = Math.min(newRange[0], range[0]); - inRange = true; - } - - // Case 4: New range starts after the search range - continue; - } else { - if (newRange[1] <= range[0]) { - // Case 5: New range extends from previous range but doesn't - // reach the current one - ranges[i - 1][1] = newRange[1]; - return ranges; - } - - if (newRange[1] <= range[1]) { - // Case 6: New range extends from prvious range into the - // current range - ranges[i - 1][1] = Math.max(newRange[1], range[1]); - ranges.splice(i, 1); - return ranges; - } - - // Case 7: New range extends from previous range past the - // end of the current range - ranges.splice(i, 1); - i--; - } - } - - if (inRange) { - // Case 8: New range extends past the last existing range - ranges[ranges.length - 1][1] = newRange[1]; - } else { - // Case 9: New range starts after the last existing range - ranges.push(newRange); - } - - return ranges; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/CursorRenderLayer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/CursorRenderLayer.ts deleted file mode 100755 index d358d580b..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/CursorRenderLayer.ts +++ /dev/null @@ -1,374 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IRenderDimensions, IRequestRedrawEvent } from 'browser/renderer/Types'; -import { BaseRenderLayer } from 'browser/renderer/BaseRenderLayer'; -import { ICellData } from 'common/Types'; -import { CellData } from 'common/buffer/CellData'; -import { IColorSet } from 'browser/Types'; -import { IBufferService, IOptionsService, ICoreService } from 'common/services/Services'; -import { IEventEmitter } from 'common/EventEmitter'; -import { ICoreBrowserService } from 'browser/services/Services'; - -interface ICursorState { - x: number; - y: number; - isFocused: boolean; - style: string; - width: number; -} - -/** - * The time between cursor blinks. - */ -const BLINK_INTERVAL = 600; - -export class CursorRenderLayer extends BaseRenderLayer { - private _state: ICursorState; - private _cursorRenderers: {[key: string]: (x: number, y: number, cell: ICellData) => void}; - private _cursorBlinkStateManager: CursorBlinkStateManager | undefined; - private _cell: ICellData = new CellData(); - - constructor( - container: HTMLElement, - zIndex: number, - colors: IColorSet, - rendererId: number, - private _onRequestRedraw: IEventEmitter, - bufferService: IBufferService, - optionsService: IOptionsService, - private readonly _coreService: ICoreService, - private readonly _coreBrowserService: ICoreBrowserService - ) { - super(container, 'cursor', zIndex, true, colors, rendererId, bufferService, optionsService); - this._state = { - x: 0, - y: 0, - isFocused: false, - style: '', - width: 0 - }; - this._cursorRenderers = { - 'bar': this._renderBarCursor.bind(this), - 'block': this._renderBlockCursor.bind(this), - 'underline': this._renderUnderlineCursor.bind(this) - }; - // TODO: Consider initial options? Maybe onOptionsChanged should be called at the end of open? - } - - public resize(dim: IRenderDimensions): void { - super.resize(dim); - // Resizing the canvas discards the contents of the canvas so clear state - this._state = { - x: 0, - y: 0, - isFocused: false, - style: '', - width: 0 - }; - } - - public reset(): void { - this._clearCursor(); - if (this._cursorBlinkStateManager) { - this._cursorBlinkStateManager.dispose(); - this._cursorBlinkStateManager = undefined; - this.onOptionsChanged(); - } - } - - public onBlur(): void { - if (this._cursorBlinkStateManager) { - this._cursorBlinkStateManager.pause(); - } - this._onRequestRedraw.fire({ start: this._bufferService.buffer.y, end: this._bufferService.buffer.y }); - } - - public onFocus(): void { - if (this._cursorBlinkStateManager) { - this._cursorBlinkStateManager.resume(); - } else { - this._onRequestRedraw.fire({ start: this._bufferService.buffer.y, end: this._bufferService.buffer.y }); - } - } - - public onOptionsChanged(): void { - if (this._optionsService.options.cursorBlink) { - if (!this._cursorBlinkStateManager) { - this._cursorBlinkStateManager = new CursorBlinkStateManager(this._coreBrowserService.isFocused, () => { - this._render(true); - }); - } - } else { - this._cursorBlinkStateManager?.dispose(); - this._cursorBlinkStateManager = undefined; - } - // Request a refresh from the terminal as management of rendering is being - // moved back to the terminal - this._onRequestRedraw.fire({ start: this._bufferService.buffer.y, end: this._bufferService.buffer.y }); - } - - public onCursorMove(): void { - if (this._cursorBlinkStateManager) { - this._cursorBlinkStateManager.restartBlinkAnimation(); - } - } - - public onGridChanged(startRow: number, endRow: number): void { - if (!this._cursorBlinkStateManager || this._cursorBlinkStateManager.isPaused) { - this._render(false); - } else { - this._cursorBlinkStateManager.restartBlinkAnimation(); - } - } - - private _render(triggeredByAnimationFrame: boolean): void { - // Don't draw the cursor if it's hidden - if (!this._coreService.isCursorInitialized || this._coreService.isCursorHidden) { - this._clearCursor(); - return; - } - - const cursorY = this._bufferService.buffer.ybase + this._bufferService.buffer.y; - const viewportRelativeCursorY = cursorY - this._bufferService.buffer.ydisp; - - // Don't draw the cursor if it's off-screen - if (viewportRelativeCursorY < 0 || viewportRelativeCursorY >= this._bufferService.rows) { - this._clearCursor(); - return; - } - - // in case cursor.x == cols adjust visual cursor to cols - 1 - const cursorX = Math.min(this._bufferService.buffer.x, this._bufferService.cols - 1); - this._bufferService.buffer.lines.get(cursorY)!.loadCell(cursorX, this._cell); - if (this._cell.content === undefined) { - return; - } - - if (!this._coreBrowserService.isFocused) { - this._clearCursor(); - this._ctx.save(); - this._ctx.fillStyle = this._colors.cursor.css; - const cursorStyle = this._optionsService.options.cursorStyle; - if (cursorStyle && cursorStyle !== 'block') { - this._cursorRenderers[cursorStyle](cursorX, viewportRelativeCursorY, this._cell); - } else { - this._renderBlurCursor(cursorX, viewportRelativeCursorY, this._cell); - } - this._ctx.restore(); - this._state.x = cursorX; - this._state.y = viewportRelativeCursorY; - this._state.isFocused = false; - this._state.style = cursorStyle; - this._state.width = this._cell.getWidth(); - return; - } - - // Don't draw the cursor if it's blinking - if (this._cursorBlinkStateManager && !this._cursorBlinkStateManager.isCursorVisible) { - this._clearCursor(); - return; - } - - if (this._state) { - // The cursor is already in the correct spot, don't redraw - if (this._state.x === cursorX && - this._state.y === viewportRelativeCursorY && - this._state.isFocused === this._coreBrowserService.isFocused && - this._state.style === this._optionsService.options.cursorStyle && - this._state.width === this._cell.getWidth()) { - return; - } - this._clearCursor(); - } - - this._ctx.save(); - this._cursorRenderers[this._optionsService.options.cursorStyle || 'block'](cursorX, viewportRelativeCursorY, this._cell); - this._ctx.restore(); - - this._state.x = cursorX; - this._state.y = viewportRelativeCursorY; - this._state.isFocused = false; - this._state.style = this._optionsService.options.cursorStyle; - this._state.width = this._cell.getWidth(); - } - - private _clearCursor(): void { - if (this._state) { - this._clearCells(this._state.x, this._state.y, this._state.width, 1); - this._state = { - x: 0, - y: 0, - isFocused: false, - style: '', - width: 0 - }; - } - } - - private _renderBarCursor(x: number, y: number, cell: ICellData): void { - this._ctx.save(); - this._ctx.fillStyle = this._colors.cursor.css; - this._fillLeftLineAtCell(x, y, this._optionsService.options.cursorWidth); - this._ctx.restore(); - } - - private _renderBlockCursor(x: number, y: number, cell: ICellData): void { - this._ctx.save(); - this._ctx.fillStyle = this._colors.cursor.css; - this._fillCells(x, y, cell.getWidth(), 1); - this._ctx.fillStyle = this._colors.cursorAccent.css; - this._fillCharTrueColor(cell, x, y); - this._ctx.restore(); - } - - private _renderUnderlineCursor(x: number, y: number, cell: ICellData): void { - this._ctx.save(); - this._ctx.fillStyle = this._colors.cursor.css; - this._fillBottomLineAtCells(x, y); - this._ctx.restore(); - } - - private _renderBlurCursor(x: number, y: number, cell: ICellData): void { - this._ctx.save(); - this._ctx.strokeStyle = this._colors.cursor.css; - this._strokeRectAtCell(x, y, cell.getWidth(), 1); - this._ctx.restore(); - } -} - -class CursorBlinkStateManager { - public isCursorVisible: boolean; - - private _animationFrame: number | undefined; - private _blinkStartTimeout: number | undefined; - private _blinkInterval: number | undefined; - - /** - * The time at which the animation frame was restarted, this is used on the - * next render to restart the timers so they don't need to restart the timers - * multiple times over a short period. - */ - private _animationTimeRestarted: number | undefined; - - constructor( - isFocused: boolean, - private _renderCallback: () => void - ) { - this.isCursorVisible = true; - if (isFocused) { - this._restartInterval(); - } - } - - public get isPaused(): boolean { return !(this._blinkStartTimeout || this._blinkInterval); } - - public dispose(): void { - if (this._blinkInterval) { - window.clearInterval(this._blinkInterval); - this._blinkInterval = undefined; - } - if (this._blinkStartTimeout) { - window.clearTimeout(this._blinkStartTimeout); - this._blinkStartTimeout = undefined; - } - if (this._animationFrame) { - window.cancelAnimationFrame(this._animationFrame); - this._animationFrame = undefined; - } - } - - public restartBlinkAnimation(): void { - if (this.isPaused) { - return; - } - // Save a timestamp so that the restart can be done on the next interval - this._animationTimeRestarted = Date.now(); - // Force a cursor render to ensure it's visible and in the correct position - this.isCursorVisible = true; - if (!this._animationFrame) { - this._animationFrame = window.requestAnimationFrame(() => { - this._renderCallback(); - this._animationFrame = undefined; - }); - } - } - - private _restartInterval(timeToStart: number = BLINK_INTERVAL): void { - // Clear any existing interval - if (this._blinkInterval) { - window.clearInterval(this._blinkInterval); - } - - // Setup the initial timeout which will hide the cursor, this is done before - // the regular interval is setup in order to support restarting the blink - // animation in a lightweight way (without thrashing clearInterval and - // setInterval). - this._blinkStartTimeout = window.setTimeout(() => { - // Check if another animation restart was requested while this was being - // started - if (this._animationTimeRestarted) { - const time = BLINK_INTERVAL - (Date.now() - this._animationTimeRestarted); - this._animationTimeRestarted = undefined; - if (time > 0) { - this._restartInterval(time); - return; - } - } - - // Hide the cursor - this.isCursorVisible = false; - this._animationFrame = window.requestAnimationFrame(() => { - this._renderCallback(); - this._animationFrame = undefined; - }); - - // Setup the blink interval - this._blinkInterval = window.setInterval(() => { - // Adjust the animation time if it was restarted - if (this._animationTimeRestarted) { - // calc time diff - // Make restart interval do a setTimeout initially? - const time = BLINK_INTERVAL - (Date.now() - this._animationTimeRestarted); - this._animationTimeRestarted = undefined; - this._restartInterval(time); - return; - } - - // Invert visibility and render - this.isCursorVisible = !this.isCursorVisible; - this._animationFrame = window.requestAnimationFrame(() => { - this._renderCallback(); - this._animationFrame = undefined; - }); - }, BLINK_INTERVAL); - }, timeToStart); - } - - public pause(): void { - this.isCursorVisible = true; - if (this._blinkInterval) { - window.clearInterval(this._blinkInterval); - this._blinkInterval = undefined; - } - if (this._blinkStartTimeout) { - window.clearTimeout(this._blinkStartTimeout); - this._blinkStartTimeout = undefined; - } - if (this._animationFrame) { - window.cancelAnimationFrame(this._animationFrame); - this._animationFrame = undefined; - } - } - - public resume(): void { - // Clear out any existing timers just in case - this.pause(); - - this._animationTimeRestarted = undefined; - this._restartInterval(); - this.restartBlinkAnimation(); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/GridCache.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/GridCache.ts deleted file mode 100755 index b48798d2c..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/GridCache.ts +++ /dev/null @@ -1,33 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -export class GridCache { - public cache: (T | undefined)[][]; - - public constructor() { - this.cache = []; - } - - public resize(width: number, height: number): void { - for (let x = 0; x < width; x++) { - if (this.cache.length <= x) { - this.cache.push([]); - } - for (let y = this.cache[x].length; y < height; y++) { - this.cache[x].push(undefined); - } - this.cache[x].length = height; - } - this.cache.length = width; - } - - public clear(): void { - for (let x = 0; x < this.cache.length; x++) { - for (let y = 0; y < this.cache[x].length; y++) { - this.cache[x][y] = undefined; - } - } - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/LinkRenderLayer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/LinkRenderLayer.ts deleted file mode 100755 index c41955d93..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/LinkRenderLayer.ts +++ /dev/null @@ -1,83 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IRenderDimensions } from 'browser/renderer/Types'; -import { BaseRenderLayer } from './BaseRenderLayer'; -import { INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants'; -import { is256Color } from 'browser/renderer/atlas/CharAtlasUtils'; -import { IColorSet, ILinkifierEvent, ILinkifier, ILinkifier2 } from 'browser/Types'; -import { IBufferService, IOptionsService } from 'common/services/Services'; - -export class LinkRenderLayer extends BaseRenderLayer { - private _state: ILinkifierEvent | undefined; - - constructor( - container: HTMLElement, - zIndex: number, - colors: IColorSet, - rendererId: number, - linkifier: ILinkifier, - linkifier2: ILinkifier2, - bufferService: IBufferService, - optionsService: IOptionsService - ) { - super(container, 'link', zIndex, true, colors, rendererId, bufferService, optionsService); - linkifier.onShowLinkUnderline(e => this._onShowLinkUnderline(e)); - linkifier.onHideLinkUnderline(e => this._onHideLinkUnderline(e)); - - linkifier2.onShowLinkUnderline(e => this._onShowLinkUnderline(e)); - linkifier2.onHideLinkUnderline(e => this._onHideLinkUnderline(e)); - } - - public resize(dim: IRenderDimensions): void { - super.resize(dim); - // Resizing the canvas discards the contents of the canvas so clear state - this._state = undefined; - } - - public reset(): void { - this._clearCurrentLink(); - } - - private _clearCurrentLink(): void { - if (this._state) { - this._clearCells(this._state.x1, this._state.y1, this._state.cols - this._state.x1, 1); - const middleRowCount = this._state.y2 - this._state.y1 - 1; - if (middleRowCount > 0) { - this._clearCells(0, this._state.y1 + 1, this._state.cols, middleRowCount); - } - this._clearCells(0, this._state.y2, this._state.x2, 1); - this._state = undefined; - } - } - - private _onShowLinkUnderline(e: ILinkifierEvent): void { - if (e.fg === INVERTED_DEFAULT_COLOR) { - this._ctx.fillStyle = this._colors.background.css; - } else if (e.fg && is256Color(e.fg)) { - // 256 color support - this._ctx.fillStyle = this._colors.ansi[e.fg].css; - } else { - this._ctx.fillStyle = this._colors.foreground.css; - } - - if (e.y1 === e.y2) { - // Single line link - this._fillBottomLineAtCells(e.x1, e.y1, e.x2 - e.x1); - } else { - // Multi-line link - this._fillBottomLineAtCells(e.x1, e.y1, e.cols - e.x1); - for (let y = e.y1 + 1; y < e.y2; y++) { - this._fillBottomLineAtCells(0, y, e.cols); - } - this._fillBottomLineAtCells(0, e.y2, e.x2); - } - this._state = e; - } - - private _onHideLinkUnderline(e: ILinkifierEvent): void { - this._clearCurrentLink(); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/Renderer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/Renderer.ts deleted file mode 100755 index b9d02ff86..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/Renderer.ts +++ /dev/null @@ -1,221 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { TextRenderLayer } from 'browser/renderer/TextRenderLayer'; -import { SelectionRenderLayer } from 'browser/renderer/SelectionRenderLayer'; -import { CursorRenderLayer } from 'browser/renderer/CursorRenderLayer'; -import { IRenderLayer, IRenderer, IRenderDimensions, CharacterJoinerHandler, ICharacterJoinerRegistry, IRequestRedrawEvent } from 'browser/renderer/Types'; -import { LinkRenderLayer } from 'browser/renderer/LinkRenderLayer'; -import { CharacterJoinerRegistry } from 'browser/renderer/CharacterJoinerRegistry'; -import { Disposable } from 'common/Lifecycle'; -import { IColorSet, ILinkifier, ILinkifier2 } from 'browser/Types'; -import { ICharSizeService, ICoreBrowserService } from 'browser/services/Services'; -import { IBufferService, IOptionsService, ICoreService } from 'common/services/Services'; -import { removeTerminalFromCache } from 'browser/renderer/atlas/CharAtlasCache'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; - -let nextRendererId = 1; - -export class Renderer extends Disposable implements IRenderer { - private _id = nextRendererId++; - - private _renderLayers: IRenderLayer[]; - private _devicePixelRatio: number; - private _characterJoinerRegistry: ICharacterJoinerRegistry; - - public dimensions: IRenderDimensions; - - private _onRequestRedraw = new EventEmitter(); - public get onRequestRedraw(): IEvent { return this._onRequestRedraw.event; } - - constructor( - private _colors: IColorSet, - private readonly _screenElement: HTMLElement, - linkifier: ILinkifier, - linkifier2: ILinkifier2, - @IBufferService private readonly _bufferService: IBufferService, - @ICharSizeService private readonly _charSizeService: ICharSizeService, - @IOptionsService private readonly _optionsService: IOptionsService, - @ICoreService coreService: ICoreService, - @ICoreBrowserService coreBrowserService: ICoreBrowserService - ) { - super(); - const allowTransparency = this._optionsService.options.allowTransparency; - this._characterJoinerRegistry = new CharacterJoinerRegistry(this._bufferService); - this._renderLayers = [ - new TextRenderLayer(this._screenElement, 0, this._colors, this._characterJoinerRegistry, allowTransparency, this._id, this._bufferService, _optionsService), - new SelectionRenderLayer(this._screenElement, 1, this._colors, this._id, this._bufferService, _optionsService), - new LinkRenderLayer(this._screenElement, 2, this._colors, this._id, linkifier, linkifier2, this._bufferService, _optionsService), - new CursorRenderLayer(this._screenElement, 3, this._colors, this._id, this._onRequestRedraw, this._bufferService, _optionsService, coreService, coreBrowserService) - ]; - this.dimensions = { - scaledCharWidth: 0, - scaledCharHeight: 0, - scaledCellWidth: 0, - scaledCellHeight: 0, - scaledCharLeft: 0, - scaledCharTop: 0, - scaledCanvasWidth: 0, - scaledCanvasHeight: 0, - canvasWidth: 0, - canvasHeight: 0, - actualCellWidth: 0, - actualCellHeight: 0 - }; - this._devicePixelRatio = window.devicePixelRatio; - this._updateDimensions(); - this.onOptionsChanged(); - } - - public dispose(): void { - for (const l of this._renderLayers) { - l.dispose(); - } - super.dispose(); - removeTerminalFromCache(this._id); - } - - public onDevicePixelRatioChange(): void { - // If the device pixel ratio changed, the char atlas needs to be regenerated - // and the terminal needs to refreshed - if (this._devicePixelRatio !== window.devicePixelRatio) { - this._devicePixelRatio = window.devicePixelRatio; - this.onResize(this._bufferService.cols, this._bufferService.rows); - } - } - - public setColors(colors: IColorSet): void { - this._colors = colors; - // Clear layers and force a full render - for (const l of this._renderLayers) { - l.setColors(this._colors); - l.reset(); - } - } - - public onResize(cols: number, rows: number): void { - // Update character and canvas dimensions - this._updateDimensions(); - - // Resize all render layers - for (const l of this._renderLayers) { - l.resize(this.dimensions); - } - - // Resize the screen - this._screenElement.style.width = `${this.dimensions.canvasWidth}px`; - this._screenElement.style.height = `${this.dimensions.canvasHeight}px`; - } - - public onCharSizeChanged(): void { - this.onResize(this._bufferService.cols, this._bufferService.rows); - } - - public onBlur(): void { - this._runOperation(l => l.onBlur()); - } - - public onFocus(): void { - this._runOperation(l => l.onFocus()); - } - - public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean = false): void { - this._runOperation(l => l.onSelectionChanged(start, end, columnSelectMode)); - } - - public onCursorMove(): void { - this._runOperation(l => l.onCursorMove()); - } - - public onOptionsChanged(): void { - this._runOperation(l => l.onOptionsChanged()); - } - - public clear(): void { - this._runOperation(l => l.reset()); - } - - private _runOperation(operation: (layer: IRenderLayer) => void): void { - for (const l of this._renderLayers) { - operation(l); - } - } - - /** - * Performs the refresh loop callback, calling refresh only if a refresh is - * necessary before queueing up the next one. - */ - public renderRows(start: number, end: number): void { - for (const l of this._renderLayers) { - l.onGridChanged(start, end); - } - } - - /** - * Recalculates the character and canvas dimensions. - */ - private _updateDimensions(): void { - if (!this._charSizeService.hasValidSize) { - return; - } - - // Calculate the scaled character width. Width is floored as it must be - // drawn to an integer grid in order for the CharAtlas "stamps" to not be - // blurry. When text is drawn to the grid not using the CharAtlas, it is - // clipped to ensure there is no overlap with the next cell. - this.dimensions.scaledCharWidth = Math.floor(this._charSizeService.width * window.devicePixelRatio); - - // Calculate the scaled character height. Height is ceiled in case - // devicePixelRatio is a floating point number in order to ensure there is - // enough space to draw the character to the cell. - this.dimensions.scaledCharHeight = Math.ceil(this._charSizeService.height * window.devicePixelRatio); - - // Calculate the scaled cell height, if lineHeight is not 1 then the value - // will be floored because since lineHeight can never be lower then 1, there - // is a guarentee that the scaled line height will always be larger than - // scaled char height. - this.dimensions.scaledCellHeight = Math.floor(this.dimensions.scaledCharHeight * this._optionsService.options.lineHeight); - - // Calculate the y coordinate within a cell that text should draw from in - // order to draw in the center of a cell. - this.dimensions.scaledCharTop = this._optionsService.options.lineHeight === 1 ? 0 : Math.round((this.dimensions.scaledCellHeight - this.dimensions.scaledCharHeight) / 2); - - // Calculate the scaled cell width, taking the letterSpacing into account. - this.dimensions.scaledCellWidth = this.dimensions.scaledCharWidth + Math.round(this._optionsService.options.letterSpacing); - - // Calculate the x coordinate with a cell that text should draw from in - // order to draw in the center of a cell. - this.dimensions.scaledCharLeft = Math.floor(this._optionsService.options.letterSpacing / 2); - - // Recalculate the canvas dimensions; scaled* define the actual number of - // pixel in the canvas - this.dimensions.scaledCanvasHeight = this._bufferService.rows * this.dimensions.scaledCellHeight; - this.dimensions.scaledCanvasWidth = this._bufferService.cols * this.dimensions.scaledCellWidth; - - // The the size of the canvas on the page. It's very important that this - // rounds to nearest integer and not ceils as browsers often set - // window.devicePixelRatio as something like 1.100000023841858, when it's - // actually 1.1. Ceiling causes blurriness as the backing canvas image is 1 - // pixel too large for the canvas element size. - this.dimensions.canvasHeight = Math.round(this.dimensions.scaledCanvasHeight / window.devicePixelRatio); - this.dimensions.canvasWidth = Math.round(this.dimensions.scaledCanvasWidth / window.devicePixelRatio); - - // Get the _actual_ dimensions of an individual cell. This needs to be - // derived from the canvasWidth/Height calculated above which takes into - // account window.devicePixelRatio. ICharSizeService.width/height by itself - // is insufficient when the page is not at 100% zoom level as it's measured - // in CSS pixels, but the actual char size on the canvas can differ. - this.dimensions.actualCellHeight = this.dimensions.canvasHeight / this._bufferService.rows; - this.dimensions.actualCellWidth = this.dimensions.canvasWidth / this._bufferService.cols; - } - - public registerCharacterJoiner(handler: CharacterJoinerHandler): number { - return this._characterJoinerRegistry.registerCharacterJoiner(handler); - } - - public deregisterCharacterJoiner(joinerId: number): boolean { - return this._characterJoinerRegistry.deregisterCharacterJoiner(joinerId); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/RendererUtils.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/RendererUtils.ts deleted file mode 100755 index 48fd26a45..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/RendererUtils.ts +++ /dev/null @@ -1,11 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -export function throwIfFalsy(value: T | undefined | null): T { - if (!value) { - throw new Error('value must not be falsy'); - } - return value; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/SelectionRenderLayer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/SelectionRenderLayer.ts deleted file mode 100755 index 80022f011..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/SelectionRenderLayer.ts +++ /dev/null @@ -1,128 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IRenderDimensions } from 'browser/renderer/Types'; -import { BaseRenderLayer } from 'browser/renderer/BaseRenderLayer'; -import { IColorSet } from 'browser/Types'; -import { IBufferService, IOptionsService } from 'common/services/Services'; - -interface ISelectionState { - start?: [number, number]; - end?: [number, number]; - columnSelectMode?: boolean; - ydisp?: number; -} - -export class SelectionRenderLayer extends BaseRenderLayer { - private _state!: ISelectionState; - - constructor( - container: HTMLElement, - zIndex: number, - colors: IColorSet, - rendererId: number, - bufferService: IBufferService, - optionsService: IOptionsService - ) { - super(container, 'selection', zIndex, true, colors, rendererId, bufferService, optionsService); - this._clearState(); - } - - private _clearState(): void { - this._state = { - start: undefined, - end: undefined, - columnSelectMode: undefined, - ydisp: undefined - }; - } - - public resize(dim: IRenderDimensions): void { - super.resize(dim); - // Resizing the canvas discards the contents of the canvas so clear state - this._clearState(); - } - - public reset(): void { - if (this._state.start && this._state.end) { - this._clearState(); - this._clearAll(); - } - } - - public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void { - // Selection has not changed - if (!this._didStateChange(start, end, columnSelectMode, this._bufferService.buffer.ydisp)) { - return; - } - - // Remove all selections - this._clearAll(); - - // Selection does not exist - if (!start || !end) { - this._clearState(); - return; - } - - // Translate from buffer position to viewport position - const viewportStartRow = start[1] - this._bufferService.buffer.ydisp; - const viewportEndRow = end[1] - this._bufferService.buffer.ydisp; - const viewportCappedStartRow = Math.max(viewportStartRow, 0); - const viewportCappedEndRow = Math.min(viewportEndRow, this._bufferService.rows - 1); - - // No need to draw the selection - if (viewportCappedStartRow >= this._bufferService.rows || viewportCappedEndRow < 0) { - this._state.ydisp = this._bufferService.buffer.ydisp; - return; - } - - this._ctx.fillStyle = this._colors.selectionTransparent.css; - - if (columnSelectMode) { - const startCol = start[0]; - const width = end[0] - startCol; - const height = viewportCappedEndRow - viewportCappedStartRow + 1; - this._fillCells(startCol, viewportCappedStartRow, width, height); - } else { - // Draw first row - const startCol = viewportStartRow === viewportCappedStartRow ? start[0] : 0; - const startRowEndCol = viewportCappedStartRow === viewportEndRow ? end[0] : this._bufferService.cols; - this._fillCells(startCol, viewportCappedStartRow, startRowEndCol - startCol, 1); - - // Draw middle rows - const middleRowsCount = Math.max(viewportCappedEndRow - viewportCappedStartRow - 1, 0); - this._fillCells(0, viewportCappedStartRow + 1, this._bufferService.cols, middleRowsCount); - - // Draw final row - if (viewportCappedStartRow !== viewportCappedEndRow) { - // Only draw viewportEndRow if it's not the same as viewportStartRow - const endCol = viewportEndRow === viewportCappedEndRow ? end[0] : this._bufferService.cols; - this._fillCells(0, viewportCappedEndRow, endCol, 1); - } - } - - // Save state for next render - this._state.start = [start[0], start[1]]; - this._state.end = [end[0], end[1]]; - this._state.columnSelectMode = columnSelectMode; - this._state.ydisp = this._bufferService.buffer.ydisp; - } - - private _didStateChange(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean, ydisp: number): boolean { - return !this._areCoordinatesEqual(start, this._state.start) || - !this._areCoordinatesEqual(end, this._state.end) || - columnSelectMode !== this._state.columnSelectMode || - ydisp !== this._state.ydisp; - } - - private _areCoordinatesEqual(coord1: [number, number] | undefined, coord2: [number, number] | undefined): boolean { - if (!coord1 || !coord2) { - return false; - } - - return coord1[0] === coord2[0] && coord1[1] === coord2[1]; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/TextRenderLayer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/TextRenderLayer.ts deleted file mode 100755 index 1f35fae16..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/TextRenderLayer.ts +++ /dev/null @@ -1,328 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ICharacterJoinerRegistry, IRenderDimensions } from 'browser/renderer/Types'; -import { CharData, ICellData } from 'common/Types'; -import { GridCache } from 'browser/renderer/GridCache'; -import { BaseRenderLayer } from 'browser/renderer/BaseRenderLayer'; -import { AttributeData } from 'common/buffer/AttributeData'; -import { NULL_CELL_CODE, Content } from 'common/buffer/Constants'; -import { JoinedCellData } from 'browser/renderer/CharacterJoinerRegistry'; -import { IColorSet } from 'browser/Types'; -import { CellData } from 'common/buffer/CellData'; -import { IOptionsService, IBufferService } from 'common/services/Services'; - -/** - * This CharData looks like a null character, which will forc a clear and render - * when the character changes (a regular space ' ' character may not as it's - * drawn state is a cleared cell). - */ -// const OVERLAP_OWNED_CHAR_DATA: CharData = [null, '', 0, -1]; - -export class TextRenderLayer extends BaseRenderLayer { - private _state: GridCache; - private _characterWidth: number = 0; - private _characterFont: string = ''; - private _characterOverlapCache: { [key: string]: boolean } = {}; - private _characterJoinerRegistry: ICharacterJoinerRegistry; - private _workCell = new CellData(); - - constructor( - container: HTMLElement, - zIndex: number, - colors: IColorSet, - characterJoinerRegistry: ICharacterJoinerRegistry, - alpha: boolean, - rendererId: number, - bufferService: IBufferService, - optionsService: IOptionsService - ) { - super(container, 'text', zIndex, alpha, colors, rendererId, bufferService, optionsService); - this._state = new GridCache(); - this._characterJoinerRegistry = characterJoinerRegistry; - } - - public resize(dim: IRenderDimensions): void { - super.resize(dim); - - // Clear the character width cache if the font or width has changed - const terminalFont = this._getFont(false, false); - if (this._characterWidth !== dim.scaledCharWidth || this._characterFont !== terminalFont) { - this._characterWidth = dim.scaledCharWidth; - this._characterFont = terminalFont; - this._characterOverlapCache = {}; - } - // Resizing the canvas discards the contents of the canvas so clear state - this._state.clear(); - this._state.resize(this._bufferService.cols, this._bufferService.rows); - } - - public reset(): void { - this._state.clear(); - this._clearAll(); - } - - private _forEachCell( - firstRow: number, - lastRow: number, - joinerRegistry: ICharacterJoinerRegistry | null, - callback: ( - cell: ICellData, - x: number, - y: number - ) => void - ): void { - for (let y = firstRow; y <= lastRow; y++) { - const row = y + this._bufferService.buffer.ydisp; - const line = this._bufferService.buffer.lines.get(row); - const joinedRanges = joinerRegistry ? joinerRegistry.getJoinedCharacters(row) : []; - for (let x = 0; x < this._bufferService.cols; x++) { - line!.loadCell(x, this._workCell); - let cell = this._workCell; - - // If true, indicates that the current character(s) to draw were joined. - let isJoined = false; - let lastCharX = x; - - // The character to the left is a wide character, drawing is owned by - // the char at x-1 - if (cell.getWidth() === 0) { - continue; - } - - // Process any joined character ranges as needed. Because of how the - // ranges are produced, we know that they are valid for the characters - // and attributes of our input. - if (joinedRanges.length > 0 && x === joinedRanges[0][0]) { - isJoined = true; - const range = joinedRanges.shift()!; - - // We already know the exact start and end column of the joined range, - // so we get the string and width representing it directly - - cell = new JoinedCellData( - this._workCell, - line!.translateToString(true, range[0], range[1]), - range[1] - range[0] - ); - - // Skip over the cells occupied by this range in the loop - lastCharX = range[1] - 1; - } - - // If the character is an overlapping char and the character to the - // right is a space, take ownership of the cell to the right. We skip - // this check for joined characters because their rendering likely won't - // yield the same result as rendering the last character individually. - if (!isJoined && this._isOverlapping(cell)) { - // If the character is overlapping, we want to force a re-render on every - // frame. This is specifically to work around the case where two - // overlaping chars `a` and `b` are adjacent, the cursor is moved to b and a - // space is added. Without this, the first half of `b` would never - // get removed, and `a` would not re-render because it thinks it's - // already in the correct state. - // this._state.cache[x][y] = OVERLAP_OWNED_CHAR_DATA; - if (lastCharX < line!.length - 1 && line!.getCodePoint(lastCharX + 1) === NULL_CELL_CODE) { - // patch width to 2 - cell.content &= ~Content.WIDTH_MASK; - cell.content |= 2 << Content.WIDTH_SHIFT; - // this._clearChar(x + 1, y); - // The overlapping char's char data will force a clear and render when the - // overlapping char is no longer to the left of the character and also when - // the space changes to another character. - // this._state.cache[x + 1][y] = OVERLAP_OWNED_CHAR_DATA; - } - } - - callback( - cell, - x, - y - ); - - x = lastCharX; - } - } - } - - /** - * Draws the background for a specified range of columns. Tries to batch adjacent cells of the - * same color together to reduce draw calls. - */ - private _drawBackground(firstRow: number, lastRow: number): void { - const ctx = this._ctx; - const cols = this._bufferService.cols; - let startX: number = 0; - let startY: number = 0; - let prevFillStyle: string | null = null; - - ctx.save(); - - this._forEachCell(firstRow, lastRow, null, (cell, x, y) => { - // libvte and xterm both draw the background (but not foreground) of invisible characters, - // so we should too. - let nextFillStyle = null; // null represents default background color - - if (cell.isInverse()) { - if (cell.isFgDefault()) { - nextFillStyle = this._colors.foreground.css; - } else if (cell.isFgRGB()) { - nextFillStyle = `rgb(${AttributeData.toColorRGB(cell.getFgColor()).join(',')})`; - } else { - nextFillStyle = this._colors.ansi[cell.getFgColor()].css; - } - } else if (cell.isBgRGB()) { - nextFillStyle = `rgb(${AttributeData.toColorRGB(cell.getBgColor()).join(',')})`; - } else if (cell.isBgPalette()) { - nextFillStyle = this._colors.ansi[cell.getBgColor()].css; - } - - if (prevFillStyle === null) { - // This is either the first iteration, or the default background was set. Either way, we - // don't need to draw anything. - startX = x; - startY = y; - } - - if (y !== startY) { - // our row changed, draw the previous row - ctx.fillStyle = prevFillStyle || ''; - this._fillCells(startX, startY, cols - startX, 1); - startX = x; - startY = y; - } else if (prevFillStyle !== nextFillStyle) { - // our color changed, draw the previous characters in this row - ctx.fillStyle = prevFillStyle || ''; - this._fillCells(startX, startY, x - startX, 1); - startX = x; - startY = y; - } - - prevFillStyle = nextFillStyle; - }); - - // flush the last color we encountered - if (prevFillStyle !== null) { - ctx.fillStyle = prevFillStyle; - this._fillCells(startX, startY, cols - startX, 1); - } - - ctx.restore(); - } - - private _drawForeground(firstRow: number, lastRow: number): void { - this._forEachCell(firstRow, lastRow, this._characterJoinerRegistry, (cell, x, y) => { - if (cell.isInvisible()) { - return; - } - this._drawChars(cell, x, y); - if (cell.isUnderline()) { - this._ctx.save(); - - if (cell.isInverse()) { - if (cell.isBgDefault()) { - this._ctx.fillStyle = this._colors.background.css; - } else if (cell.isBgRGB()) { - this._ctx.fillStyle = `rgb(${AttributeData.toColorRGB(cell.getBgColor()).join(',')})`; - } else { - let bg = cell.getBgColor(); - if (this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && bg < 8) { - bg += 8; - } - this._ctx.fillStyle = this._colors.ansi[bg].css; - } - } else { - if (cell.isFgDefault()) { - this._ctx.fillStyle = this._colors.foreground.css; - } else if (cell.isFgRGB()) { - this._ctx.fillStyle = `rgb(${AttributeData.toColorRGB(cell.getFgColor()).join(',')})`; - } else { - let fg = cell.getFgColor(); - if (this._optionsService.options.drawBoldTextInBrightColors && cell.isBold() && fg < 8) { - fg += 8; - } - this._ctx.fillStyle = this._colors.ansi[fg].css; - } - } - - this._fillBottomLineAtCells(x, y, cell.getWidth()); - this._ctx.restore(); - } - }); - } - - public onGridChanged(firstRow: number, lastRow: number): void { - // Resize has not been called yet - if (this._state.cache.length === 0) { - return; - } - - if (this._charAtlas) { - this._charAtlas.beginFrame(); - } - - this._clearCells(0, firstRow, this._bufferService.cols, lastRow - firstRow + 1); - this._drawBackground(firstRow, lastRow); - this._drawForeground(firstRow, lastRow); - } - - public onOptionsChanged(): void { - this._setTransparency(this._optionsService.options.allowTransparency); - } - - /** - * Whether a character is overlapping to the next cell. - */ - private _isOverlapping(cell: ICellData): boolean { - // Only single cell characters can be overlapping, rendering issues can - // occur without this check - if (cell.getWidth() !== 1) { - return false; - } - - // We assume that any ascii character will not overlap - if (cell.getCode() < 256) { - return false; - } - - const chars = cell.getChars(); - - // Deliver from cache if available - if (this._characterOverlapCache.hasOwnProperty(chars)) { - return this._characterOverlapCache[chars]; - } - - // Setup the font - this._ctx.save(); - this._ctx.font = this._characterFont; - - // Measure the width of the character, but Math.floor it - // because that is what the renderer does when it calculates - // the character dimensions we are comparing against - const overlaps = Math.floor(this._ctx.measureText(chars).width) > this._characterWidth; - - // Restore the original context - this._ctx.restore(); - - // Cache and return - this._characterOverlapCache[chars] = overlaps; - return overlaps; - } - - /** - * Clear the charcater at the cell specified. - * @param x The column of the char. - * @param y The row of the char. - */ - // private _clearChar(x: number, y: number): void { - // let colsToClear = 1; - // // Clear the adjacent character if it was wide - // const state = this._state.cache[x][y]; - // if (state && state[CHAR_DATA_WIDTH_INDEX] === 2) { - // colsToClear = 2; - // } - // this.clearCells(x, y, colsToClear, 1); - // } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/Types.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/Types.d.ts deleted file mode 100755 index cab14b88e..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/Types.d.ts +++ /dev/null @@ -1,128 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IDisposable } from 'common/Types'; -import { IColorSet } from 'browser/Types'; -import { IEvent } from 'common/EventEmitter'; - -export type CharacterJoinerHandler = (text: string) => [number, number][]; - -export interface IRenderDimensions { - scaledCharWidth: number; - scaledCharHeight: number; - scaledCellWidth: number; - scaledCellHeight: number; - scaledCharLeft: number; - scaledCharTop: number; - scaledCanvasWidth: number; - scaledCanvasHeight: number; - canvasWidth: number; - canvasHeight: number; - actualCellWidth: number; - actualCellHeight: number; -} - -export interface IRequestRedrawEvent { - start: number; - end: number; -} - -/** - * Note that IRenderer implementations should emit the refresh event after - * rendering rows to the screen. - */ -export interface IRenderer extends IDisposable { - readonly dimensions: IRenderDimensions; - - /** - * Fires when the renderer is requesting to be redrawn on the next animation - * frame but is _not_ a result of content changing (eg. selection changes). - */ - readonly onRequestRedraw: IEvent; - - dispose(): void; - setColors(colors: IColorSet): void; - onDevicePixelRatioChange(): void; - onResize(cols: number, rows: number): void; - onCharSizeChanged(): void; - onBlur(): void; - onFocus(): void; - onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void; - onCursorMove(): void; - onOptionsChanged(): void; - clear(): void; - renderRows(start: number, end: number): void; - registerCharacterJoiner(handler: CharacterJoinerHandler): number; - deregisterCharacterJoiner(joinerId: number): boolean; -} - -export interface ICharacterJoiner { - id: number; - handler: CharacterJoinerHandler; -} - -export interface ICharacterJoinerRegistry { - registerCharacterJoiner(handler: (text: string) => [number, number][]): number; - deregisterCharacterJoiner(joinerId: number): boolean; - getJoinedCharacters(row: number): [number, number][]; -} - -export interface IRenderLayer extends IDisposable { - /** - * Called when the terminal loses focus. - */ - onBlur(): void; - - /** - * * Called when the terminal gets focus. - */ - onFocus(): void; - - /** - * Called when the cursor is moved. - */ - onCursorMove(): void; - - /** - * Called when options change. - */ - onOptionsChanged(): void; - - /** - * Called when the theme changes. - */ - setColors(colorSet: IColorSet): void; - - /** - * Called when the data in the grid has changed (or needs to be rendered - * again). - */ - onGridChanged(startRow: number, endRow: number): void; - - /** - * Calls when the selection changes. - */ - onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void; - - /** - * Registers a handler to join characters to render as a group - */ - registerCharacterJoiner?(joiner: ICharacterJoiner): void; - - /** - * Deregisters the specified character joiner handler - */ - deregisterCharacterJoiner?(joinerId: number): void; - - /** - * Resize the render layer. - */ - resize(dim: IRenderDimensions): void; - - /** - * Clear the state of the render layer. - */ - reset(): void; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/BaseCharAtlas.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/BaseCharAtlas.ts deleted file mode 100755 index 4ebaaa471..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/BaseCharAtlas.ts +++ /dev/null @@ -1,56 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IGlyphIdentifier } from 'browser/renderer/atlas/Types'; -import { IDisposable } from 'common/Types'; - -export abstract class BaseCharAtlas implements IDisposable { - private _didWarmUp: boolean = false; - - public dispose(): void { } - - /** - * Perform any work needed to warm the cache before it can be used. May be called multiple times. - * Implement _doWarmUp instead if you only want to get called once. - */ - public warmUp(): void { - if (!this._didWarmUp) { - this._doWarmUp(); - this._didWarmUp = true; - } - } - - /** - * Perform any work needed to warm the cache before it can be used. Used by the default - * implementation of warmUp(), and will only be called once. - */ - private _doWarmUp(): void { } - - /** - * Called when we start drawing a new frame. - * - * TODO: We rely on this getting called by TextRenderLayer. This should really be called by - * Renderer instead, but we need to make Renderer the source-of-truth for the char atlas, instead - * of BaseRenderLayer. - */ - public beginFrame(): void { } - - /** - * May be called before warmUp finishes, however it is okay for the implementation to - * do nothing and return false in that case. - * - * @param ctx Where to draw the character onto. - * @param glyph Information about what to draw - * @param x The position on the context to start drawing at - * @param y The position on the context to start drawing at - * @returns The success state. True if we drew the character. - */ - public abstract draw( - ctx: CanvasRenderingContext2D, - glyph: IGlyphIdentifier, - x: number, - y: number - ): boolean; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/CharAtlasCache.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/CharAtlasCache.ts deleted file mode 100755 index 257835ba0..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/CharAtlasCache.ts +++ /dev/null @@ -1,95 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { generateConfig, configEquals } from 'browser/renderer/atlas/CharAtlasUtils'; -import { BaseCharAtlas } from 'browser/renderer/atlas/BaseCharAtlas'; -import { DynamicCharAtlas } from 'browser/renderer/atlas/DynamicCharAtlas'; -import { ICharAtlasConfig } from 'browser/renderer/atlas/Types'; -import { IColorSet } from 'browser/Types'; -import { ITerminalOptions } from 'common/services/Services'; - -interface ICharAtlasCacheEntry { - atlas: BaseCharAtlas; - config: ICharAtlasConfig; - // N.B. This implementation potentially holds onto copies of the terminal forever, so - // this may cause memory leaks. - ownedBy: number[]; -} - -const charAtlasCache: ICharAtlasCacheEntry[] = []; - -/** - * Acquires a char atlas, either generating a new one or returning an existing - * one that is in use by another terminal. - */ -export function acquireCharAtlas( - options: ITerminalOptions, - rendererId: number, - colors: IColorSet, - scaledCharWidth: number, - scaledCharHeight: number -): BaseCharAtlas { - const newConfig = generateConfig(scaledCharWidth, scaledCharHeight, options, colors); - - // Check to see if the renderer already owns this config - for (let i = 0; i < charAtlasCache.length; i++) { - const entry = charAtlasCache[i]; - const ownedByIndex = entry.ownedBy.indexOf(rendererId); - if (ownedByIndex >= 0) { - if (configEquals(entry.config, newConfig)) { - return entry.atlas; - } - // The configs differ, release the renderer from the entry - if (entry.ownedBy.length === 1) { - entry.atlas.dispose(); - charAtlasCache.splice(i, 1); - } else { - entry.ownedBy.splice(ownedByIndex, 1); - } - break; - } - } - - // Try match a char atlas from the cache - for (let i = 0; i < charAtlasCache.length; i++) { - const entry = charAtlasCache[i]; - if (configEquals(entry.config, newConfig)) { - // Add the renderer to the cache entry and return - entry.ownedBy.push(rendererId); - return entry.atlas; - } - } - - const newEntry: ICharAtlasCacheEntry = { - atlas: new DynamicCharAtlas( - document, - newConfig - ), - config: newConfig, - ownedBy: [rendererId] - }; - charAtlasCache.push(newEntry); - return newEntry.atlas; -} - -/** - * Removes a terminal reference from the cache, allowing its memory to be freed. - */ -export function removeTerminalFromCache(rendererId: number): void { - for (let i = 0; i < charAtlasCache.length; i++) { - const index = charAtlasCache[i].ownedBy.indexOf(rendererId); - if (index !== -1) { - if (charAtlasCache[i].ownedBy.length === 1) { - // Remove the cache entry if it's the only renderer - charAtlasCache[i].atlas.dispose(); - charAtlasCache.splice(i, 1); - } else { - // Remove the reference from the cache entry - charAtlasCache[i].ownedBy.splice(index, 1); - } - break; - } - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/CharAtlasUtils.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/CharAtlasUtils.ts deleted file mode 100755 index 20695d3c4..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/CharAtlasUtils.ts +++ /dev/null @@ -1,54 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ICharAtlasConfig } from 'browser/renderer/atlas/Types'; -import { DEFAULT_COLOR } from 'common/buffer/Constants'; -import { IColorSet, IPartialColorSet } from 'browser/Types'; -import { ITerminalOptions } from 'common/services/Services'; - -export function generateConfig(scaledCharWidth: number, scaledCharHeight: number, options: ITerminalOptions, colors: IColorSet): ICharAtlasConfig { - // null out some fields that don't matter - const clonedColors = { - foreground: colors.foreground, - background: colors.background, - cursor: undefined, - cursorAccent: undefined, - selection: undefined, - ansi: colors.ansi - }; - return { - devicePixelRatio: window.devicePixelRatio, - scaledCharWidth, - scaledCharHeight, - fontFamily: options.fontFamily, - fontSize: options.fontSize, - fontWeight: options.fontWeight, - fontWeightBold: options.fontWeightBold, - allowTransparency: options.allowTransparency, - colors: clonedColors - }; -} - -export function configEquals(a: ICharAtlasConfig, b: ICharAtlasConfig): boolean { - for (let i = 0; i < a.colors.ansi.length; i++) { - if (a.colors.ansi[i].rgba !== b.colors.ansi[i].rgba) { - return false; - } - } - return a.devicePixelRatio === b.devicePixelRatio && - a.fontFamily === b.fontFamily && - a.fontSize === b.fontSize && - a.fontWeight === b.fontWeight && - a.fontWeightBold === b.fontWeightBold && - a.allowTransparency === b.allowTransparency && - a.scaledCharWidth === b.scaledCharWidth && - a.scaledCharHeight === b.scaledCharHeight && - a.colors.foreground === b.colors.foreground && - a.colors.background === b.colors.background; -} - -export function is256Color(colorCode: number): boolean { - return colorCode < DEFAULT_COLOR; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/Constants.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/Constants.ts deleted file mode 100755 index 150aad888..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/Constants.ts +++ /dev/null @@ -1,9 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -export const INVERTED_DEFAULT_COLOR = 257; -export const DIM_OPACITY = 0.5; - -export const CHAR_ATLAS_CELL_SPACING = 1; diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/DynamicCharAtlas.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/DynamicCharAtlas.ts deleted file mode 100755 index 696fb63c4..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/DynamicCharAtlas.ts +++ /dev/null @@ -1,374 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { DIM_OPACITY, INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants'; -import { IGlyphIdentifier, ICharAtlasConfig } from 'browser/renderer/atlas/Types'; -import { BaseCharAtlas } from 'browser/renderer/atlas/BaseCharAtlas'; -import { DEFAULT_ANSI_COLORS } from 'browser/ColorManager'; -import { LRUMap } from 'browser/renderer/atlas/LRUMap'; -import { isFirefox, isSafari } from 'common/Platform'; -import { IColor } from 'browser/Types'; -import { throwIfFalsy } from 'browser/renderer/RendererUtils'; -import { color } from 'browser/Color'; - -// In practice we're probably never going to exhaust a texture this large. For debugging purposes, -// however, it can be useful to set this to a really tiny value, to verify that LRU eviction works. -const TEXTURE_WIDTH = 1024; -const TEXTURE_HEIGHT = 1024; - -const TRANSPARENT_COLOR = { - css: 'rgba(0, 0, 0, 0)', - rgba: 0 -}; - -// Drawing to the cache is expensive: If we have to draw more than this number of glyphs to the -// cache in a single frame, give up on trying to cache anything else, and try to finish the current -// frame ASAP. -// -// This helps to limit the amount of damage a program can do when it would otherwise thrash the -// cache. -const FRAME_CACHE_DRAW_LIMIT = 100; - -/** - * The number of milliseconds to wait before generating the ImageBitmap, this is to debounce/batch - * the operation as window.createImageBitmap is asynchronous. - */ -const GLYPH_BITMAP_COMMIT_DELAY = 100; - -interface IGlyphCacheValue { - index: number; - isEmpty: boolean; - inBitmap: boolean; -} - -export function getGlyphCacheKey(glyph: IGlyphIdentifier): number { - // Note that this only returns a valid key when code < 256 - // Layout: - // 0b00000000000000000000000000000001: italic (1) - // 0b00000000000000000000000000000010: dim (1) - // 0b00000000000000000000000000000100: bold (1) - // 0b00000000000000000000111111111000: fg (9) - // 0b00000000000111111111000000000000: bg (9) - // 0b00011111111000000000000000000000: code (8) - // 0b11100000000000000000000000000000: unused (3) - return glyph.code << 21 | glyph.bg << 12 | glyph.fg << 3 | (glyph.bold ? 0 : 4) + (glyph.dim ? 0 : 2) + (glyph.italic ? 0 : 1); -} - -export class DynamicCharAtlas extends BaseCharAtlas { - // An ordered map that we're using to keep track of where each glyph is in the atlas texture. - // It's ordered so that we can determine when to remove the old entries. - private _cacheMap: LRUMap; - - // The texture that the atlas is drawn to - private _cacheCanvas: HTMLCanvasElement; - private _cacheCtx: CanvasRenderingContext2D; - - // A temporary context that glyphs are drawn to before being transfered to the atlas. - private _tmpCtx: CanvasRenderingContext2D; - - // The number of characters stored in the atlas by width/height - private _width: number; - private _height: number; - - private _drawToCacheCount: number = 0; - - // An array of glyph keys that are waiting on the bitmap to be generated. - private _glyphsWaitingOnBitmap: IGlyphCacheValue[] = []; - - // The timeout that is used to batch bitmap generation so it's not requested for every new glyph. - private _bitmapCommitTimeout: number | null = null; - - // The bitmap to draw from, this is much faster on other browsers than others. - private _bitmap: ImageBitmap | null = null; - - constructor(document: Document, private _config: ICharAtlasConfig) { - super(); - this._cacheCanvas = document.createElement('canvas'); - this._cacheCanvas.width = TEXTURE_WIDTH; - this._cacheCanvas.height = TEXTURE_HEIGHT; - // The canvas needs alpha because we use clearColor to convert the background color to alpha. - // It might also contain some characters with transparent backgrounds if allowTransparency is - // set. - this._cacheCtx = throwIfFalsy(this._cacheCanvas.getContext('2d', {alpha: true})); - - const tmpCanvas = document.createElement('canvas'); - tmpCanvas.width = this._config.scaledCharWidth; - tmpCanvas.height = this._config.scaledCharHeight; - this._tmpCtx = throwIfFalsy(tmpCanvas.getContext('2d', {alpha: this._config.allowTransparency})); - - this._width = Math.floor(TEXTURE_WIDTH / this._config.scaledCharWidth); - this._height = Math.floor(TEXTURE_HEIGHT / this._config.scaledCharHeight); - const capacity = this._width * this._height; - this._cacheMap = new LRUMap(capacity); - this._cacheMap.prealloc(capacity); - - // This is useful for debugging - // document.body.appendChild(this._cacheCanvas); - } - - public dispose(): void { - if (this._bitmapCommitTimeout !== null) { - window.clearTimeout(this._bitmapCommitTimeout); - this._bitmapCommitTimeout = null; - } - } - - public beginFrame(): void { - this._drawToCacheCount = 0; - } - - public draw( - ctx: CanvasRenderingContext2D, - glyph: IGlyphIdentifier, - x: number, - y: number - ): boolean { - // Space is always an empty cell, special case this as it's so common - if (glyph.code === 32) { - return true; - } - - // Exit early for uncachable glyphs - if (!this._canCache(glyph)) { - return false; - } - - const glyphKey = getGlyphCacheKey(glyph); - const cacheValue = this._cacheMap.get(glyphKey); - if (cacheValue !== null && cacheValue !== undefined) { - this._drawFromCache(ctx, cacheValue, x, y); - return true; - } - if (this._drawToCacheCount < FRAME_CACHE_DRAW_LIMIT) { - let index; - if (this._cacheMap.size < this._cacheMap.capacity) { - index = this._cacheMap.size; - } else { - // we're out of space, so our call to set will delete this item - index = this._cacheMap.peek()!.index; - } - const cacheValue = this._drawToCache(glyph, index); - this._cacheMap.set(glyphKey, cacheValue); - this._drawFromCache(ctx, cacheValue, x, y); - return true; - } - return false; - } - - private _canCache(glyph: IGlyphIdentifier): boolean { - // Only cache ascii and extended characters for now, to be safe. In the future, we could do - // something more complicated to determine the expected width of a character. - // - // If we switch the renderer over to webgl at some point, we may be able to use blending modes - // to draw overlapping glyphs from the atlas: - // https://github.com/servo/webrender/issues/464#issuecomment-255632875 - // https://webglfundamentals.org/webgl/lessons/webgl-text-texture.html - return glyph.code < 256; - } - - private _toCoordinateX(index: number): number { - return (index % this._width) * this._config.scaledCharWidth; - } - - private _toCoordinateY(index: number): number { - return Math.floor(index / this._width) * this._config.scaledCharHeight; - } - - private _drawFromCache( - ctx: CanvasRenderingContext2D, - cacheValue: IGlyphCacheValue, - x: number, - y: number - ): void { - // We don't actually need to do anything if this is whitespace. - if (cacheValue.isEmpty) { - return; - } - const cacheX = this._toCoordinateX(cacheValue.index); - const cacheY = this._toCoordinateY(cacheValue.index); - ctx.drawImage( - cacheValue.inBitmap ? this._bitmap! : this._cacheCanvas, - cacheX, - cacheY, - this._config.scaledCharWidth, - this._config.scaledCharHeight, - x, - y, - this._config.scaledCharWidth, - this._config.scaledCharHeight - ); - } - - private _getColorFromAnsiIndex(idx: number): IColor { - if (idx < this._config.colors.ansi.length) { - return this._config.colors.ansi[idx]; - } - return DEFAULT_ANSI_COLORS[idx]; - } - - private _getBackgroundColor(glyph: IGlyphIdentifier): IColor { - if (this._config.allowTransparency) { - // The background color might have some transparency, so we need to render it as fully - // transparent in the atlas. Otherwise we'd end up drawing the transparent background twice - // around the anti-aliased edges of the glyph, and it would look too dark. - return TRANSPARENT_COLOR; - } - if (glyph.bg === INVERTED_DEFAULT_COLOR) { - return this._config.colors.foreground; - } - if (glyph.bg < 256) { - return this._getColorFromAnsiIndex(glyph.bg); - } - return this._config.colors.background; - } - - private _getForegroundColor(glyph: IGlyphIdentifier): IColor { - if (glyph.fg === INVERTED_DEFAULT_COLOR) { - return color.opaque(this._config.colors.background); - } - if (glyph.fg < 256) { - // 256 color support - return this._getColorFromAnsiIndex(glyph.fg); - } - return this._config.colors.foreground; - } - - // TODO: We do this (or something similar) in multiple places. We should split this off - // into a shared function. - private _drawToCache(glyph: IGlyphIdentifier, index: number): IGlyphCacheValue { - this._drawToCacheCount++; - - this._tmpCtx.save(); - - // draw the background - const backgroundColor = this._getBackgroundColor(glyph); - // Use a 'copy' composite operation to clear any existing glyph out of _tmpCtxWithAlpha, regardless of - // transparency in backgroundColor - this._tmpCtx.globalCompositeOperation = 'copy'; - this._tmpCtx.fillStyle = backgroundColor.css; - this._tmpCtx.fillRect(0, 0, this._config.scaledCharWidth, this._config.scaledCharHeight); - this._tmpCtx.globalCompositeOperation = 'source-over'; - - // draw the foreground/glyph - const fontWeight = glyph.bold ? this._config.fontWeightBold : this._config.fontWeight; - const fontStyle = glyph.italic ? 'italic' : ''; - this._tmpCtx.font = - `${fontStyle} ${fontWeight} ${this._config.fontSize * this._config.devicePixelRatio}px ${this._config.fontFamily}`; - this._tmpCtx.textBaseline = 'middle'; - - this._tmpCtx.fillStyle = this._getForegroundColor(glyph).css; - - // Apply alpha to dim the character - if (glyph.dim) { - this._tmpCtx.globalAlpha = DIM_OPACITY; - } - // Draw the character - this._tmpCtx.fillText(glyph.chars, 0, this._config.scaledCharHeight / 2); - this._tmpCtx.restore(); - - // clear the background from the character to avoid issues with drawing over the previous - // character if it extends past it's bounds - const imageData = this._tmpCtx.getImageData( - 0, 0, this._config.scaledCharWidth, this._config.scaledCharHeight - ); - let isEmpty = false; - if (!this._config.allowTransparency) { - isEmpty = clearColor(imageData, backgroundColor); - } - - // copy the data from imageData to _cacheCanvas - const x = this._toCoordinateX(index); - const y = this._toCoordinateY(index); - // putImageData doesn't do any blending, so it will overwrite any existing cache entry for us - this._cacheCtx.putImageData(imageData, x, y); - - // Add the glyph and queue it to the bitmap (if the browser supports it) - const cacheValue = { - index, - isEmpty, - inBitmap: false - }; - this._addGlyphToBitmap(cacheValue); - - return cacheValue; - } - - private _addGlyphToBitmap(cacheValue: IGlyphCacheValue): void { - // Support is patchy for createImageBitmap at the moment, pass a canvas back - // if support is lacking as drawImage works there too. Firefox is also - // included here as ImageBitmap appears both buggy and has horrible - // performance (tested on v55). - if (!('createImageBitmap' in window) || isFirefox || isSafari) { - return; - } - - // Add the glyph to the queue - this._glyphsWaitingOnBitmap.push(cacheValue); - - // Check if bitmap generation timeout already exists - if (this._bitmapCommitTimeout !== null) { - return; - } - - this._bitmapCommitTimeout = window.setTimeout(() => this._generateBitmap(), GLYPH_BITMAP_COMMIT_DELAY); - } - - private _generateBitmap(): void { - const glyphsMovingToBitmap = this._glyphsWaitingOnBitmap; - this._glyphsWaitingOnBitmap = []; - window.createImageBitmap(this._cacheCanvas).then(bitmap => { - // Set bitmap - this._bitmap = bitmap; - - // Mark all new glyphs as in bitmap, excluding glyphs that came in after - // the bitmap was requested - for (let i = 0; i < glyphsMovingToBitmap.length; i++) { - const value = glyphsMovingToBitmap[i]; - // It doesn't matter if the value was already evicted, it will be - // released from memory after this block if so. - value.inBitmap = true; - } - }); - this._bitmapCommitTimeout = null; - } -} - -// This is used for debugging the renderer, just swap out `new DynamicCharAtlas` with -// `new NoneCharAtlas`. -export class NoneCharAtlas extends BaseCharAtlas { - constructor(document: Document, config: ICharAtlasConfig) { - super(); - } - - public draw( - ctx: CanvasRenderingContext2D, - glyph: IGlyphIdentifier, - x: number, - y: number - ): boolean { - return false; - } -} - -/** - * Makes a partiicular rgb color in an ImageData completely transparent. - * @returns True if the result is "empty", meaning all pixels are fully transparent. - */ -function clearColor(imageData: ImageData, color: IColor): boolean { - let isEmpty = true; - const r = color.rgba >>> 24; - const g = color.rgba >>> 16 & 0xFF; - const b = color.rgba >>> 8 & 0xFF; - for (let offset = 0; offset < imageData.data.length; offset += 4) { - if (imageData.data[offset] === r && - imageData.data[offset + 1] === g && - imageData.data[offset + 2] === b) { - imageData.data[offset + 3] = 0; - } else { - isEmpty = false; - } - } - return isEmpty; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/LRUMap.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/LRUMap.ts deleted file mode 100755 index f70962fe1..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/LRUMap.ts +++ /dev/null @@ -1,136 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -interface ILinkedListNode { - prev: ILinkedListNode | null; - next: ILinkedListNode | null; - key: number | null; - value: T | null; -} - -export class LRUMap { - private _map: { [key: number]: ILinkedListNode } = {}; - private _head: ILinkedListNode | null = null; - private _tail: ILinkedListNode | null = null; - private _nodePool: ILinkedListNode[] = []; - public size: number = 0; - - constructor(public capacity: number) { } - - private _unlinkNode(node: ILinkedListNode): void { - const prev = node.prev; - const next = node.next; - if (node === this._head) { - this._head = next; - } - if (node === this._tail) { - this._tail = prev; - } - if (prev !== null) { - prev.next = next; - } - if (next !== null) { - next.prev = prev; - } - } - - private _appendNode(node: ILinkedListNode): void { - const tail = this._tail; - if (tail !== null) { - tail.next = node; - } - node.prev = tail; - node.next = null; - this._tail = node; - if (this._head === null) { - this._head = node; - } - } - - /** - * Preallocate a bunch of linked-list nodes. Allocating these nodes ahead of time means that - * they're more likely to live next to each other in memory, which seems to improve performance. - * - * Each empty object only consumes about 60 bytes of memory, so this is pretty cheap, even for - * large maps. - */ - public prealloc(count: number): void { - const nodePool = this._nodePool; - for (let i = 0; i < count; i++) { - nodePool.push({ - prev: null, - next: null, - key: null, - value: null - }); - } - } - - public get(key: number): T | null { - // This is unsafe: We're assuming our keyspace doesn't overlap with Object.prototype. However, - // it's faster than calling hasOwnProperty, and in our case, it would never overlap. - const node = this._map[key]; - if (node !== undefined) { - this._unlinkNode(node); - this._appendNode(node); - return node.value; - } - return null; - } - - /** - * Gets a value from a key without marking it as the most recently used item. - */ - public peekValue(key: number): T | null { - const node = this._map[key]; - if (node !== undefined) { - return node.value; - } - return null; - } - - public peek(): T | null { - const head = this._head; - return head === null ? null : head.value; - } - - public set(key: number, value: T): void { - // This is unsafe: See note above. - let node = this._map[key]; - if (node !== undefined) { - // already exists, we just need to mutate it and move it to the end of the list - node = this._map[key]; - this._unlinkNode(node); - node.value = value; - } else if (this.size >= this.capacity) { - // we're out of space: recycle the head node, move it to the tail - node = this._head!; - this._unlinkNode(node); - delete this._map[node.key!]; - node.key = key; - node.value = value; - this._map[key] = node; - } else { - // make a new element - const nodePool = this._nodePool; - if (nodePool.length > 0) { - // use a preallocated node if we can - node = nodePool.pop()!; - node.key = key; - node.value = value; - } else { - node = { - prev: null, - next: null, - key, - value - }; - } - this._map[key] = node; - this.size++; - } - this._appendNode(node); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/Types.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/Types.d.ts deleted file mode 100755 index d8bc54c19..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/atlas/Types.d.ts +++ /dev/null @@ -1,29 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { FontWeight } from 'common/services/Services'; -import { IPartialColorSet } from 'browser/Types'; - -export interface IGlyphIdentifier { - chars: string; - code: number; - bg: number; - fg: number; - bold: boolean; - dim: boolean; - italic: boolean; -} - -export interface ICharAtlasConfig { - devicePixelRatio: number; - fontSize: number; - fontFamily: string; - fontWeight: FontWeight; - fontWeightBold: FontWeight; - scaledCharWidth: number; - scaledCharHeight: number; - allowTransparency: boolean; - colors: IPartialColorSet; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/dom/DomRenderer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/dom/DomRenderer.ts deleted file mode 100755 index f0a922594..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/dom/DomRenderer.ts +++ /dev/null @@ -1,402 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IRenderer, IRenderDimensions, CharacterJoinerHandler, IRequestRedrawEvent } from 'browser/renderer/Types'; -import { BOLD_CLASS, ITALIC_CLASS, CURSOR_CLASS, CURSOR_STYLE_BLOCK_CLASS, CURSOR_BLINK_CLASS, CURSOR_STYLE_BAR_CLASS, CURSOR_STYLE_UNDERLINE_CLASS, DomRendererRowFactory } from 'browser/renderer/dom/DomRendererRowFactory'; -import { INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants'; -import { Disposable } from 'common/Lifecycle'; -import { IColorSet, ILinkifierEvent, ILinkifier, ILinkifier2 } from 'browser/Types'; -import { ICharSizeService } from 'browser/services/Services'; -import { IOptionsService, IBufferService } from 'common/services/Services'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { color } from 'browser/Color'; -import { removeElementFromParent } from 'browser/Dom'; - -const TERMINAL_CLASS_PREFIX = 'xterm-dom-renderer-owner-'; -const ROW_CONTAINER_CLASS = 'xterm-rows'; -const FG_CLASS_PREFIX = 'xterm-fg-'; -const BG_CLASS_PREFIX = 'xterm-bg-'; -const FOCUS_CLASS = 'xterm-focus'; -const SELECTION_CLASS = 'xterm-selection'; - -let nextTerminalId = 1; - -/** - * A fallback renderer for when canvas is slow. This is not meant to be - * particularly fast or feature complete, more just stable and usable for when - * canvas is not an option. - */ -export class DomRenderer extends Disposable implements IRenderer { - private _rowFactory: DomRendererRowFactory; - private _terminalClass: number = nextTerminalId++; - - private _themeStyleElement!: HTMLStyleElement; - private _dimensionsStyleElement!: HTMLStyleElement; - private _rowContainer: HTMLElement; - private _rowElements: HTMLElement[] = []; - private _selectionContainer: HTMLElement; - - public dimensions: IRenderDimensions; - - public get onRequestRedraw(): IEvent { return new EventEmitter().event; } - - constructor( - private _colors: IColorSet, - private readonly _element: HTMLElement, - private readonly _screenElement: HTMLElement, - private readonly _viewportElement: HTMLElement, - private readonly _linkifier: ILinkifier, - private readonly _linkifier2: ILinkifier2, - @ICharSizeService private readonly _charSizeService: ICharSizeService, - @IOptionsService private readonly _optionsService: IOptionsService, - @IBufferService private readonly _bufferService: IBufferService - ) { - super(); - this._rowContainer = document.createElement('div'); - this._rowContainer.classList.add(ROW_CONTAINER_CLASS); - this._rowContainer.style.lineHeight = 'normal'; - this._rowContainer.setAttribute('aria-hidden', 'true'); - this._refreshRowElements(this._bufferService.cols, this._bufferService.rows); - this._selectionContainer = document.createElement('div'); - this._selectionContainer.classList.add(SELECTION_CLASS); - this._selectionContainer.setAttribute('aria-hidden', 'true'); - - this.dimensions = { - scaledCharWidth: 0, - scaledCharHeight: 0, - scaledCellWidth: 0, - scaledCellHeight: 0, - scaledCharLeft: 0, - scaledCharTop: 0, - scaledCanvasWidth: 0, - scaledCanvasHeight: 0, - canvasWidth: 0, - canvasHeight: 0, - actualCellWidth: 0, - actualCellHeight: 0 - }; - this._updateDimensions(); - this._injectCss(); - - this._rowFactory = new DomRendererRowFactory(document, this._optionsService, this._colors); - - this._element.classList.add(TERMINAL_CLASS_PREFIX + this._terminalClass); - this._screenElement.appendChild(this._rowContainer); - this._screenElement.appendChild(this._selectionContainer); - - this._linkifier.onShowLinkUnderline(e => this._onLinkHover(e)); - this._linkifier.onHideLinkUnderline(e => this._onLinkLeave(e)); - - this._linkifier2.onShowLinkUnderline(e => this._onLinkHover(e)); - this._linkifier2.onHideLinkUnderline(e => this._onLinkLeave(e)); - } - - public dispose(): void { - this._element.classList.remove(TERMINAL_CLASS_PREFIX + this._terminalClass); - - // Outside influences such as React unmounts may manipulate the DOM before our disposal. - // https://github.com/xtermjs/xterm.js/issues/2960 - removeElementFromParent(this._rowContainer, this._selectionContainer, this._themeStyleElement, this._dimensionsStyleElement); - - super.dispose(); - } - - private _updateDimensions(): void { - this.dimensions.scaledCharWidth = this._charSizeService.width * window.devicePixelRatio; - this.dimensions.scaledCharHeight = Math.ceil(this._charSizeService.height * window.devicePixelRatio); - this.dimensions.scaledCellWidth = this.dimensions.scaledCharWidth + Math.round(this._optionsService.options.letterSpacing); - this.dimensions.scaledCellHeight = Math.floor(this.dimensions.scaledCharHeight * this._optionsService.options.lineHeight); - this.dimensions.scaledCharLeft = 0; - this.dimensions.scaledCharTop = 0; - this.dimensions.scaledCanvasWidth = this.dimensions.scaledCellWidth * this._bufferService.cols; - this.dimensions.scaledCanvasHeight = this.dimensions.scaledCellHeight * this._bufferService.rows; - this.dimensions.canvasWidth = Math.round(this.dimensions.scaledCanvasWidth / window.devicePixelRatio); - this.dimensions.canvasHeight = Math.round(this.dimensions.scaledCanvasHeight / window.devicePixelRatio); - this.dimensions.actualCellWidth = this.dimensions.canvasWidth / this._bufferService.cols; - this.dimensions.actualCellHeight = this.dimensions.canvasHeight / this._bufferService.rows; - - for (const element of this._rowElements) { - element.style.width = `${this.dimensions.canvasWidth}px`; - element.style.height = `${this.dimensions.actualCellHeight}px`; - element.style.lineHeight = `${this.dimensions.actualCellHeight}px`; - // Make sure rows don't overflow onto following row - element.style.overflow = 'hidden'; - } - - if (!this._dimensionsStyleElement) { - this._dimensionsStyleElement = document.createElement('style'); - this._screenElement.appendChild(this._dimensionsStyleElement); - } - - const styles = - `${this._terminalSelector} .${ROW_CONTAINER_CLASS} span {` + - ` display: inline-block;` + - ` height: 100%;` + - ` vertical-align: top;` + - ` width: ${this.dimensions.actualCellWidth}px` + - `}`; - - this._dimensionsStyleElement.textContent = styles; - - this._selectionContainer.style.height = this._viewportElement.style.height; - this._screenElement.style.width = `${this.dimensions.canvasWidth}px`; - this._screenElement.style.height = `${this.dimensions.canvasHeight}px`; - } - - public setColors(colors: IColorSet): void { - this._colors = colors; - this._injectCss(); - } - - private _injectCss(): void { - if (!this._themeStyleElement) { - this._themeStyleElement = document.createElement('style'); - this._screenElement.appendChild(this._themeStyleElement); - } - - // Base CSS - let styles = - `${this._terminalSelector} .${ROW_CONTAINER_CLASS} {` + - ` color: ${this._colors.foreground.css};` + - ` font-family: ${this._optionsService.options.fontFamily};` + - ` font-size: ${this._optionsService.options.fontSize}px;` + - `}`; - // Text styles - styles += - `${this._terminalSelector} span:not(.${BOLD_CLASS}) {` + - ` font-weight: ${this._optionsService.options.fontWeight};` + - `}` + - `${this._terminalSelector} span.${BOLD_CLASS} {` + - ` font-weight: ${this._optionsService.options.fontWeightBold};` + - `}` + - `${this._terminalSelector} span.${ITALIC_CLASS} {` + - ` font-style: italic;` + - `}`; - // Blink animation - styles += - `@keyframes blink_box_shadow` + `_` + this._terminalClass + ` {` + - ` 50% {` + - ` box-shadow: none;` + - ` }` + - `}`; - styles += - `@keyframes blink_block` + `_` + this._terminalClass + ` {` + - ` 0% {` + - ` background-color: ${this._colors.cursor.css};` + - ` color: ${this._colors.cursorAccent.css};` + - ` }` + - ` 50% {` + - ` background-color: ${this._colors.cursorAccent.css};` + - ` color: ${this._colors.cursor.css};` + - ` }` + - `}`; - // Cursor - styles += - `${this._terminalSelector} .${ROW_CONTAINER_CLASS}:not(.${FOCUS_CLASS}) .${CURSOR_CLASS}.${CURSOR_STYLE_BLOCK_CLASS} {` + - ` outline: 1px solid ${this._colors.cursor.css};` + - ` outline-offset: -1px;` + - `}` + - `${this._terminalSelector} .${ROW_CONTAINER_CLASS}.${FOCUS_CLASS} .${CURSOR_CLASS}.${CURSOR_BLINK_CLASS}:not(.${CURSOR_STYLE_BLOCK_CLASS}) {` + - ` animation: blink_box_shadow` + `_` + this._terminalClass + ` 1s step-end infinite;` + - `}` + - `${this._terminalSelector} .${ROW_CONTAINER_CLASS}.${FOCUS_CLASS} .${CURSOR_CLASS}.${CURSOR_BLINK_CLASS}.${CURSOR_STYLE_BLOCK_CLASS} {` + - ` animation: blink_block` + `_` + this._terminalClass + ` 1s step-end infinite;` + - `}` + - `${this._terminalSelector} .${ROW_CONTAINER_CLASS}.${FOCUS_CLASS} .${CURSOR_CLASS}.${CURSOR_STYLE_BLOCK_CLASS} {` + - ` background-color: ${this._colors.cursor.css};` + - ` color: ${this._colors.cursorAccent.css};` + - `}` + - `${this._terminalSelector} .${ROW_CONTAINER_CLASS} .${CURSOR_CLASS}.${CURSOR_STYLE_BAR_CLASS} {` + - ` box-shadow: ${this._optionsService.options.cursorWidth}px 0 0 ${this._colors.cursor.css} inset;` + - `}` + - `${this._terminalSelector} .${ROW_CONTAINER_CLASS} .${CURSOR_CLASS}.${CURSOR_STYLE_UNDERLINE_CLASS} {` + - ` box-shadow: 0 -1px 0 ${this._colors.cursor.css} inset;` + - `}`; - // Selection - styles += - `${this._terminalSelector} .${SELECTION_CLASS} {` + - ` position: absolute;` + - ` top: 0;` + - ` left: 0;` + - ` z-index: 1;` + - ` pointer-events: none;` + - `}` + - `${this._terminalSelector} .${SELECTION_CLASS} div {` + - ` position: absolute;` + - ` background-color: ${this._colors.selectionTransparent.css};` + - `}`; - // Colors - this._colors.ansi.forEach((c, i) => { - styles += - `${this._terminalSelector} .${FG_CLASS_PREFIX}${i} { color: ${c.css}; }` + - `${this._terminalSelector} .${BG_CLASS_PREFIX}${i} { background-color: ${c.css}; }`; - }); - styles += - `${this._terminalSelector} .${FG_CLASS_PREFIX}${INVERTED_DEFAULT_COLOR} { color: ${color.opaque(this._colors.background).css}; }` + - `${this._terminalSelector} .${BG_CLASS_PREFIX}${INVERTED_DEFAULT_COLOR} { background-color: ${this._colors.foreground.css}; }`; - - this._themeStyleElement.textContent = styles; - } - - public onDevicePixelRatioChange(): void { - this._updateDimensions(); - } - - private _refreshRowElements(cols: number, rows: number): void { - // Add missing elements - for (let i = this._rowElements.length; i <= rows; i++) { - const row = document.createElement('div'); - this._rowContainer.appendChild(row); - this._rowElements.push(row); - } - // Remove excess elements - while (this._rowElements.length > rows) { - this._rowContainer.removeChild(this._rowElements.pop()!); - } - } - - public onResize(cols: number, rows: number): void { - this._refreshRowElements(cols, rows); - this._updateDimensions(); - } - - public onCharSizeChanged(): void { - this._updateDimensions(); - } - - public onBlur(): void { - this._rowContainer.classList.remove(FOCUS_CLASS); - } - - public onFocus(): void { - this._rowContainer.classList.add(FOCUS_CLASS); - } - - public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void { - // Remove all selections - while (this._selectionContainer.children.length) { - this._selectionContainer.removeChild(this._selectionContainer.children[0]); - } - - // Selection does not exist - if (!start || !end) { - return; - } - - // Translate from buffer position to viewport position - const viewportStartRow = start[1] - this._bufferService.buffer.ydisp; - const viewportEndRow = end[1] - this._bufferService.buffer.ydisp; - const viewportCappedStartRow = Math.max(viewportStartRow, 0); - const viewportCappedEndRow = Math.min(viewportEndRow, this._bufferService.rows - 1); - - // No need to draw the selection - if (viewportCappedStartRow >= this._bufferService.rows || viewportCappedEndRow < 0) { - return; - } - - // Create the selections - const documentFragment = document.createDocumentFragment(); - - if (columnSelectMode) { - documentFragment.appendChild( - this._createSelectionElement(viewportCappedStartRow, start[0], end[0], viewportCappedEndRow - viewportCappedStartRow + 1) - ); - } else { - // Draw first row - const startCol = viewportStartRow === viewportCappedStartRow ? start[0] : 0; - const endCol = viewportCappedStartRow === viewportEndRow ? end[0] : this._bufferService.cols; - documentFragment.appendChild(this._createSelectionElement(viewportCappedStartRow, startCol, endCol)); - // Draw middle rows - const middleRowsCount = viewportCappedEndRow - viewportCappedStartRow - 1; - documentFragment.appendChild(this._createSelectionElement(viewportCappedStartRow + 1, 0, this._bufferService.cols, middleRowsCount)); - // Draw final row - if (viewportCappedStartRow !== viewportCappedEndRow) { - // Only draw viewportEndRow if it's not the same as viewporttartRow - const endCol = viewportEndRow === viewportCappedEndRow ? end[0] : this._bufferService.cols; - documentFragment.appendChild(this._createSelectionElement(viewportCappedEndRow, 0, endCol)); - } - } - this._selectionContainer.appendChild(documentFragment); - } - - /** - * Creates a selection element at the specified position. - * @param row The row of the selection. - * @param colStart The start column. - * @param colEnd The end columns. - */ - private _createSelectionElement(row: number, colStart: number, colEnd: number, rowCount: number = 1): HTMLElement { - const element = document.createElement('div'); - element.style.height = `${rowCount * this.dimensions.actualCellHeight}px`; - element.style.top = `${row * this.dimensions.actualCellHeight}px`; - element.style.left = `${colStart * this.dimensions.actualCellWidth}px`; - element.style.width = `${this.dimensions.actualCellWidth * (colEnd - colStart)}px`; - return element; - } - - public onCursorMove(): void { - // No-op, the cursor is drawn when rows are drawn - } - - public onOptionsChanged(): void { - // Force a refresh - this._updateDimensions(); - this._injectCss(); - } - - public clear(): void { - for (const e of this._rowElements) { - e.innerText = ''; - } - } - - public renderRows(start: number, end: number): void { - const cursorAbsoluteY = this._bufferService.buffer.ybase + this._bufferService.buffer.y; - const cursorX = Math.min(this._bufferService.buffer.x, this._bufferService.cols - 1); - const cursorBlink = this._optionsService.options.cursorBlink; - - for (let y = start; y <= end; y++) { - const rowElement = this._rowElements[y]; - rowElement.innerText = ''; - - const row = y + this._bufferService.buffer.ydisp; - const lineData = this._bufferService.buffer.lines.get(row); - const cursorStyle = this._optionsService.options.cursorStyle; - rowElement.appendChild(this._rowFactory.createRow(lineData!, row === cursorAbsoluteY, cursorStyle, cursorX, cursorBlink, this.dimensions.actualCellWidth, this._bufferService.cols)); - } - } - - private get _terminalSelector(): string { - return `.${TERMINAL_CLASS_PREFIX}${this._terminalClass}`; - } - - public registerCharacterJoiner(handler: CharacterJoinerHandler): number { return -1; } - public deregisterCharacterJoiner(joinerId: number): boolean { return false; } - - private _onLinkHover(e: ILinkifierEvent): void { - this._setCellUnderline(e.x1, e.x2, e.y1, e.y2, e.cols, true); - } - - private _onLinkLeave(e: ILinkifierEvent): void { - this._setCellUnderline(e.x1, e.x2, e.y1, e.y2, e.cols, false); - } - - private _setCellUnderline(x: number, x2: number, y: number, y2: number, cols: number, enabled: boolean): void { - while (x !== x2 || y !== y2) { - const row = this._rowElements[y]; - if (!row) { - return; - } - const span = row.children[x]; - if (span) { - span.style.textDecoration = enabled ? 'underline' : 'none'; - } - if (++x >= cols) { - x = 0; - y++; - } - } - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/dom/DomRendererRowFactory.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/dom/DomRendererRowFactory.ts deleted file mode 100755 index c7c87451e..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/renderer/dom/DomRendererRowFactory.ts +++ /dev/null @@ -1,207 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IBufferLine } from 'common/Types'; -import { INVERTED_DEFAULT_COLOR } from 'browser/renderer/atlas/Constants'; -import { NULL_CELL_CODE, WHITESPACE_CELL_CHAR, Attributes } from 'common/buffer/Constants'; -import { CellData } from 'common/buffer/CellData'; -import { IOptionsService } from 'common/services/Services'; -import { color, rgba } from 'browser/Color'; -import { IColorSet, IColor } from 'browser/Types'; - -export const BOLD_CLASS = 'xterm-bold'; -export const DIM_CLASS = 'xterm-dim'; -export const ITALIC_CLASS = 'xterm-italic'; -export const UNDERLINE_CLASS = 'xterm-underline'; -export const CURSOR_CLASS = 'xterm-cursor'; -export const CURSOR_BLINK_CLASS = 'xterm-cursor-blink'; -export const CURSOR_STYLE_BLOCK_CLASS = 'xterm-cursor-block'; -export const CURSOR_STYLE_BAR_CLASS = 'xterm-cursor-bar'; -export const CURSOR_STYLE_UNDERLINE_CLASS = 'xterm-cursor-underline'; - -export class DomRendererRowFactory { - private _workCell: CellData = new CellData(); - - constructor( - private readonly _document: Document, - private readonly _optionsService: IOptionsService, - private _colors: IColorSet - ) { - } - - public setColors(colors: IColorSet): void { - this._colors = colors; - } - - public createRow(lineData: IBufferLine, isCursorRow: boolean, cursorStyle: string | undefined, cursorX: number, cursorBlink: boolean, cellWidth: number, cols: number): DocumentFragment { - const fragment = this._document.createDocumentFragment(); - - // Find the line length first, this prevents the need to output a bunch of - // empty cells at the end. This cannot easily be integrated into the main - // loop below because of the colCount feature (which can be removed after we - // properly support reflow and disallow data to go beyond the right-side of - // the viewport). - let lineLength = 0; - for (let x = Math.min(lineData.length, cols) - 1; x >= 0; x--) { - if (lineData.loadCell(x, this._workCell).getCode() !== NULL_CELL_CODE || (isCursorRow && x === cursorX)) { - lineLength = x + 1; - break; - } - } - - for (let x = 0; x < lineLength; x++) { - lineData.loadCell(x, this._workCell); - const width = this._workCell.getWidth(); - - // The character to the left is a wide character, drawing is owned by the char at x-1 - if (width === 0) { - continue; - } - - const charElement = this._document.createElement('span'); - if (width > 1) { - charElement.style.width = `${cellWidth * width}px`; - } - - if (isCursorRow && x === cursorX) { - charElement.classList.add(CURSOR_CLASS); - - if (cursorBlink) { - charElement.classList.add(CURSOR_BLINK_CLASS); - } - - switch (cursorStyle) { - case 'bar': - charElement.classList.add(CURSOR_STYLE_BAR_CLASS); - break; - case 'underline': - charElement.classList.add(CURSOR_STYLE_UNDERLINE_CLASS); - break; - default: - charElement.classList.add(CURSOR_STYLE_BLOCK_CLASS); - break; - } - } - - if (this._workCell.isBold()) { - charElement.classList.add(BOLD_CLASS); - } - - if (this._workCell.isItalic()) { - charElement.classList.add(ITALIC_CLASS); - } - - if (this._workCell.isDim()) { - charElement.classList.add(DIM_CLASS); - } - - if (this._workCell.isUnderline()) { - charElement.classList.add(UNDERLINE_CLASS); - } - - if (this._workCell.isInvisible()) { - charElement.textContent = WHITESPACE_CELL_CHAR; - } else { - charElement.textContent = this._workCell.getChars() || WHITESPACE_CELL_CHAR; - } - - let fg = this._workCell.getFgColor(); - let fgColorMode = this._workCell.getFgColorMode(); - let bg = this._workCell.getBgColor(); - let bgColorMode = this._workCell.getBgColorMode(); - const isInverse = !!this._workCell.isInverse(); - if (isInverse) { - const temp = fg; - fg = bg; - bg = temp; - const temp2 = fgColorMode; - fgColorMode = bgColorMode; - bgColorMode = temp2; - } - - // Foreground - switch (fgColorMode) { - case Attributes.CM_P16: - case Attributes.CM_P256: - if (this._workCell.isBold() && fg < 8 && this._optionsService.options.drawBoldTextInBrightColors) { - fg += 8; - } - if (!this._applyMinimumContrast(charElement, this._colors.background, this._colors.ansi[fg])) { - charElement.classList.add(`xterm-fg-${fg}`); - } - break; - case Attributes.CM_RGB: - const color = rgba.toColor( - (fg >> 16) & 0xFF, - (fg >> 8) & 0xFF, - (fg ) & 0xFF - ); - if (!this._applyMinimumContrast(charElement, this._colors.background, color)) { - this._addStyle(charElement, `color:#${padStart(fg.toString(16), '0', 6)}`); - } - break; - case Attributes.CM_DEFAULT: - default: - if (!this._applyMinimumContrast(charElement, this._colors.background, this._colors.foreground)) { - if (isInverse) { - charElement.classList.add(`xterm-fg-${INVERTED_DEFAULT_COLOR}`); - } - } - } - - // Background - switch (bgColorMode) { - case Attributes.CM_P16: - case Attributes.CM_P256: - charElement.classList.add(`xterm-bg-${bg}`); - break; - case Attributes.CM_RGB: - this._addStyle(charElement, `background-color:#${padStart(bg.toString(16), '0', 6)}`); - break; - case Attributes.CM_DEFAULT: - default: - if (isInverse) { - charElement.classList.add(`xterm-bg-${INVERTED_DEFAULT_COLOR}`); - } - } - - fragment.appendChild(charElement); - } - return fragment; - } - - private _applyMinimumContrast(element: HTMLElement, bg: IColor, fg: IColor): boolean { - if (this._optionsService.options.minimumContrastRatio === 1) { - return false; - } - - // Try get from cache first - let adjustedColor = this._colors.contrastCache.getColor(this._workCell.bg, this._workCell.fg); - - // Calculate and store in cache - if (adjustedColor === undefined) { - adjustedColor = color.ensureContrastRatio(bg, fg, this._optionsService.options.minimumContrastRatio); - this._colors.contrastCache.setColor(this._workCell.bg, this._workCell.fg, adjustedColor ?? null); - } - - if (adjustedColor) { - this._addStyle(element, `color:${adjustedColor.css}`); - return true; - } - - return false; - } - - private _addStyle(element: HTMLElement, style: string): void { - element.setAttribute('style', `${element.getAttribute('style') || ''}${style};`); - } -} - -function padStart(text: string, padChar: string, length: number): string { - while (text.length < length) { - text = padChar + text; - } - return text; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/selection/SelectionModel.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/selection/SelectionModel.ts deleted file mode 100755 index 1420444e2..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/selection/SelectionModel.ts +++ /dev/null @@ -1,135 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IBufferService } from 'common/services/Services'; - -/** - * Represents a selection within the buffer. This model only cares about column - * and row coordinates, not wide characters. - */ -export class SelectionModel { - /** - * Whether select all is currently active. - */ - public isSelectAllActive: boolean = false; - - /** - * The minimal length of the selection from the start position. When double - * clicking on a word, the word will be selected which makes the selection - * start at the start of the word and makes this variable the length. - */ - public selectionStartLength: number = 0; - - /** - * The [x, y] position the selection starts at. - */ - public selectionStart: [number, number] | undefined; - - /** - * The [x, y] position the selection ends at. - */ - public selectionEnd: [number, number] | undefined; - - constructor( - private _bufferService: IBufferService - ) { - } - - /** - * Clears the current selection. - */ - public clearSelection(): void { - this.selectionStart = undefined; - this.selectionEnd = undefined; - this.isSelectAllActive = false; - this.selectionStartLength = 0; - } - - /** - * The final selection start, taking into consideration select all. - */ - public get finalSelectionStart(): [number, number] | undefined { - if (this.isSelectAllActive) { - return [0, 0]; - } - - if (!this.selectionEnd || !this.selectionStart) { - return this.selectionStart; - } - - return this.areSelectionValuesReversed() ? this.selectionEnd : this.selectionStart; - } - - /** - * The final selection end, taking into consideration select all, double click - * word selection and triple click line selection. - */ - public get finalSelectionEnd(): [number, number] | undefined { - if (this.isSelectAllActive) { - return [this._bufferService.cols, this._bufferService.buffer.ybase + this._bufferService.rows - 1]; - } - - if (!this.selectionStart) { - return undefined; - } - - // Use the selection start + length if the end doesn't exist or they're reversed - if (!this.selectionEnd || this.areSelectionValuesReversed()) { - const startPlusLength = this.selectionStart[0] + this.selectionStartLength; - if (startPlusLength > this._bufferService.cols) { - return [startPlusLength % this._bufferService.cols, this.selectionStart[1] + Math.floor(startPlusLength / this._bufferService.cols)]; - } - return [startPlusLength, this.selectionStart[1]]; - } - - // Ensure the the word/line is selected after a double/triple click - if (this.selectionStartLength) { - // Select the larger of the two when start and end are on the same line - if (this.selectionEnd[1] === this.selectionStart[1]) { - return [Math.max(this.selectionStart[0] + this.selectionStartLength, this.selectionEnd[0]), this.selectionEnd[1]]; - } - } - return this.selectionEnd; - } - - /** - * Returns whether the selection start and end are reversed. - */ - public areSelectionValuesReversed(): boolean { - const start = this.selectionStart; - const end = this.selectionEnd; - if (!start || !end) { - return false; - } - return start[1] > end[1] || (start[1] === end[1] && start[0] > end[0]); - } - - /** - * Handle the buffer being trimmed, adjust the selection position. - * @param amount The amount the buffer is being trimmed. - * @return Whether a refresh is necessary. - */ - public onTrim(amount: number): boolean { - // Adjust the selection position based on the trimmed amount. - if (this.selectionStart) { - this.selectionStart[1] -= amount; - } - if (this.selectionEnd) { - this.selectionEnd[1] -= amount; - } - - // The selection has moved off the buffer, clear it. - if (this.selectionEnd && this.selectionEnd[1] < 0) { - this.clearSelection(); - return true; - } - - // If the selection start is trimmed, ensure the start column is 0. - if (this.selectionStart && this.selectionStart[1] < 0) { - this.selectionStart[1] = 0; - } - return false; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/selection/Types.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/selection/Types.d.ts deleted file mode 100755 index 8adfc17c4..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/selection/Types.d.ts +++ /dev/null @@ -1,15 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -export interface ISelectionRedrawRequestEvent { - start: [number, number] | undefined; - end: [number, number] | undefined; - columnSelectMode: boolean; -} - -export interface ISelectionRequestScrollLinesEvent { - amount: number; - suppressScrollEvent: boolean; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/CharSizeService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/CharSizeService.ts deleted file mode 100755 index 79696a281..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/CharSizeService.ts +++ /dev/null @@ -1,87 +0,0 @@ -/** - * Copyright (c) 2016 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IOptionsService } from 'common/services/Services'; -import { IEvent, EventEmitter } from 'common/EventEmitter'; -import { ICharSizeService } from 'browser/services/Services'; - -export class CharSizeService implements ICharSizeService { - public serviceBrand: undefined; - - public width: number = 0; - public height: number = 0; - private _measureStrategy: IMeasureStrategy; - - public get hasValidSize(): boolean { return this.width > 0 && this.height > 0; } - - private _onCharSizeChange = new EventEmitter(); - public get onCharSizeChange(): IEvent { return this._onCharSizeChange.event; } - - constructor( - document: Document, - parentElement: HTMLElement, - @IOptionsService private readonly _optionsService: IOptionsService - ) { - this._measureStrategy = new DomMeasureStrategy(document, parentElement, this._optionsService); - } - - public measure(): void { - const result = this._measureStrategy.measure(); - if (result.width !== this.width || result.height !== this.height) { - this.width = result.width; - this.height = result.height; - this._onCharSizeChange.fire(); - } - } -} - -interface IMeasureStrategy { - measure(): IReadonlyMeasureResult; -} - -interface IReadonlyMeasureResult { - readonly width: number; - readonly height: number; -} - -interface IMeasureResult { - width: number; - height: number; -} - -// TODO: For supporting browsers we should also provide a CanvasCharDimensionsProvider that uses ctx.measureText -class DomMeasureStrategy implements IMeasureStrategy { - private _result: IMeasureResult = { width: 0, height: 0 }; - private _measureElement: HTMLElement; - - constructor( - private _document: Document, - private _parentElement: HTMLElement, - private _optionsService: IOptionsService - ) { - this._measureElement = this._document.createElement('span'); - this._measureElement.classList.add('xterm-char-measure-element'); - this._measureElement.textContent = 'W'; - this._measureElement.setAttribute('aria-hidden', 'true'); - this._parentElement.appendChild(this._measureElement); - } - - public measure(): IReadonlyMeasureResult { - this._measureElement.style.fontFamily = this._optionsService.options.fontFamily; - this._measureElement.style.fontSize = `${this._optionsService.options.fontSize}px`; - - // Note that this triggers a synchronous layout - const geometry = this._measureElement.getBoundingClientRect(); - - // If values are 0 then the element is likely currently display:none, in which case we should - // retain the previous value. - if (geometry.width !== 0 && geometry.height !== 0) { - this._result.width = geometry.width; - this._result.height = Math.ceil(geometry.height); - } - - return this._result; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/CoreBrowserService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/CoreBrowserService.ts deleted file mode 100755 index 4eabc895d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/CoreBrowserService.ts +++ /dev/null @@ -1,20 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ICoreBrowserService } from './Services'; - -export class CoreBrowserService implements ICoreBrowserService { - public serviceBrand: undefined; - - constructor( - private _textarea: HTMLTextAreaElement - ) { - } - - public get isFocused(): boolean { - const docOrShadowRoot = this._textarea.getRootNode ? this._textarea.getRootNode() as Document | ShadowRoot : document; - return docOrShadowRoot.activeElement === this._textarea && document.hasFocus(); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/MouseService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/MouseService.ts deleted file mode 100755 index 348ba64e6..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/MouseService.ts +++ /dev/null @@ -1,35 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ICharSizeService, IRenderService, IMouseService } from './Services'; -import { getCoords, getRawByteCoords } from 'browser/input/Mouse'; - -export class MouseService implements IMouseService { - public serviceBrand: undefined; - - constructor( - @IRenderService private readonly _renderService: IRenderService, - @ICharSizeService private readonly _charSizeService: ICharSizeService - ) { - } - - public getCoords(event: {clientX: number, clientY: number}, element: HTMLElement, colCount: number, rowCount: number, isSelection?: boolean): [number, number] | undefined { - return getCoords( - event, - element, - colCount, - rowCount, - this._charSizeService.hasValidSize, - this._renderService.dimensions.actualCellWidth, - this._renderService.dimensions.actualCellHeight, - isSelection - ); - } - - public getRawByteCoords(event: MouseEvent, element: HTMLElement, colCount: number, rowCount: number): { x: number, y: number } | undefined { - const coords = this.getCoords(event, element, colCount, rowCount); - return getRawByteCoords(coords); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/RenderService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/RenderService.ts deleted file mode 100755 index 51971091c..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/RenderService.ts +++ /dev/null @@ -1,225 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IRenderer, IRenderDimensions, CharacterJoinerHandler } from 'browser/renderer/Types'; -import { RenderDebouncer } from 'browser/RenderDebouncer'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { Disposable } from 'common/Lifecycle'; -import { ScreenDprMonitor } from 'browser/ScreenDprMonitor'; -import { addDisposableDomListener } from 'browser/Lifecycle'; -import { IColorSet } from 'browser/Types'; -import { IOptionsService, IBufferService } from 'common/services/Services'; -import { ICharSizeService, IRenderService } from 'browser/services/Services'; - -interface ISelectionState { - start: [number, number] | undefined; - end: [number, number] | undefined; - columnSelectMode: boolean; -} - -export class RenderService extends Disposable implements IRenderService { - public serviceBrand: undefined; - - private _renderDebouncer: RenderDebouncer; - private _screenDprMonitor: ScreenDprMonitor; - - private _isPaused: boolean = false; - private _needsFullRefresh: boolean = false; - private _isNextRenderRedrawOnly: boolean = true; - private _needsSelectionRefresh: boolean = false; - private _canvasWidth: number = 0; - private _canvasHeight: number = 0; - private _selectionState: ISelectionState = { - start: undefined, - end: undefined, - columnSelectMode: false - }; - - private _onDimensionsChange = new EventEmitter(); - public get onDimensionsChange(): IEvent { return this._onDimensionsChange.event; } - private _onRender = new EventEmitter<{ start: number, end: number }>(); - public get onRenderedBufferChange(): IEvent<{ start: number, end: number }> { return this._onRender.event; } - private _onRefreshRequest = new EventEmitter<{ start: number, end: number }>(); - public get onRefreshRequest(): IEvent<{ start: number, end: number }> { return this._onRefreshRequest.event; } - - public get dimensions(): IRenderDimensions { return this._renderer.dimensions; } - - constructor( - private _renderer: IRenderer, - private _rowCount: number, - screenElement: HTMLElement, - @IOptionsService optionsService: IOptionsService, - @ICharSizeService private readonly _charSizeService: ICharSizeService, - @IBufferService bufferService: IBufferService - ) { - super(); - - this.register({ dispose: () => this._renderer.dispose() }); - - this._renderDebouncer = new RenderDebouncer((start, end) => this._renderRows(start, end)); - this.register(this._renderDebouncer); - - this._screenDprMonitor = new ScreenDprMonitor(); - this._screenDprMonitor.setListener(() => this.onDevicePixelRatioChange()); - this.register(this._screenDprMonitor); - - this.register(bufferService.onResize(e => this._fullRefresh())); - this.register(optionsService.onOptionChange(() => this._renderer.onOptionsChanged())); - this.register(this._charSizeService.onCharSizeChange(() => this.onCharSizeChanged())); - - // No need to register this as renderer is explicitly disposed in RenderService.dispose - this._renderer.onRequestRedraw(e => this.refreshRows(e.start, e.end, true)); - - // dprchange should handle this case, we need this as well for browsers that don't support the - // matchMedia query. - this.register(addDisposableDomListener(window, 'resize', () => this.onDevicePixelRatioChange())); - - // Detect whether IntersectionObserver is detected and enable renderer pause - // and resume based on terminal visibility if so - if ('IntersectionObserver' in window) { - const observer = new IntersectionObserver(e => this._onIntersectionChange(e[e.length - 1]), { threshold: 0 }); - observer.observe(screenElement); - this.register({ dispose: () => observer.disconnect() }); - } - } - - private _onIntersectionChange(entry: IntersectionObserverEntry): void { - this._isPaused = entry.isIntersecting === undefined ? (entry.intersectionRatio === 0) : !entry.isIntersecting; - - // Terminal was hidden on open - if (!this._isPaused && !this._charSizeService.hasValidSize) { - this._charSizeService.measure(); - } - - if (!this._isPaused && this._needsFullRefresh) { - this.refreshRows(0, this._rowCount - 1); - this._needsFullRefresh = false; - } - } - - public refreshRows(start: number, end: number, isRedrawOnly: boolean = false): void { - if (this._isPaused) { - this._needsFullRefresh = true; - return; - } - if (!isRedrawOnly) { - this._isNextRenderRedrawOnly = false; - } - this._renderDebouncer.refresh(start, end, this._rowCount); - } - - private _renderRows(start: number, end: number): void { - this._renderer.renderRows(start, end); - - // Update selection if needed - if (this._needsSelectionRefresh) { - this._renderer.onSelectionChanged(this._selectionState.start, this._selectionState.end, this._selectionState.columnSelectMode); - this._needsSelectionRefresh = false; - } - - // Fire render event only if it was not a redraw - if (!this._isNextRenderRedrawOnly) { - this._onRender.fire({ start, end }); - } - this._isNextRenderRedrawOnly = true; - } - - public resize(cols: number, rows: number): void { - this._rowCount = rows; - this._fireOnCanvasResize(); - } - - public changeOptions(): void { - this._renderer.onOptionsChanged(); - this.refreshRows(0, this._rowCount - 1); - this._fireOnCanvasResize(); - } - - private _fireOnCanvasResize(): void { - // Don't fire the event if the dimensions haven't changed - if (this._renderer.dimensions.canvasWidth === this._canvasWidth && this._renderer.dimensions.canvasHeight === this._canvasHeight) { - return; - } - this._onDimensionsChange.fire(this._renderer.dimensions); - } - - public dispose(): void { - super.dispose(); - } - - public setRenderer(renderer: IRenderer): void { - // TODO: RenderService should be the only one to dispose the renderer - this._renderer.dispose(); - this._renderer = renderer; - this._renderer.onRequestRedraw(e => this.refreshRows(e.start, e.end, true)); - - // Force a refresh - this._needsSelectionRefresh = true; - this._fullRefresh(); - } - - private _fullRefresh(): void { - if (this._isPaused) { - this._needsFullRefresh = true; - } else { - this.refreshRows(0, this._rowCount - 1); - } - } - - public setColors(colors: IColorSet): void { - this._renderer.setColors(colors); - this._fullRefresh(); - } - - public onDevicePixelRatioChange(): void { - // Force char size measurement as DomMeasureStrategy(getBoundingClientRect) is not stable - // when devicePixelRatio changes - this._charSizeService.measure(); - - this._renderer.onDevicePixelRatioChange(); - this.refreshRows(0, this._rowCount - 1); - } - - public onResize(cols: number, rows: number): void { - this._renderer.onResize(cols, rows); - this._fullRefresh(); - } - - // TODO: Is this useful when we have onResize? - public onCharSizeChanged(): void { - this._renderer.onCharSizeChanged(); - } - - public onBlur(): void { - this._renderer.onBlur(); - } - - public onFocus(): void { - this._renderer.onFocus(); - } - - public onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void { - this._selectionState.start = start; - this._selectionState.end = end; - this._selectionState.columnSelectMode = columnSelectMode; - this._renderer.onSelectionChanged(start, end, columnSelectMode); - } - - public onCursorMove(): void { - this._renderer.onCursorMove(); - } - - public clear(): void { - this._renderer.clear(); - } - - public registerCharacterJoiner(handler: CharacterJoinerHandler): number { - return this._renderer.registerCharacterJoiner(handler); - } - - public deregisterCharacterJoiner(joinerId: number): boolean { - return this._renderer.deregisterCharacterJoiner(joinerId); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/SelectionService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/SelectionService.ts deleted file mode 100755 index 3b9938768..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/SelectionService.ts +++ /dev/null @@ -1,996 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ISelectionRedrawRequestEvent, ISelectionRequestScrollLinesEvent } from 'browser/selection/Types'; -import { IBuffer } from 'common/buffer/Types'; -import { IBufferLine, IDisposable } from 'common/Types'; -import * as Browser from 'common/Platform'; -import { SelectionModel } from 'browser/selection/SelectionModel'; -import { CellData } from 'common/buffer/CellData'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { ICharSizeService, IMouseService, ISelectionService, IRenderService } from 'browser/services/Services'; -import { IBufferService, IOptionsService, ICoreService } from 'common/services/Services'; -import { getCoordsRelativeToElement } from 'browser/input/Mouse'; -import { moveToCellSequence } from 'browser/input/MoveToCell'; -import { Disposable } from 'common/Lifecycle'; - -/** - * The number of pixels the mouse needs to be above or below the viewport in - * order to scroll at the maximum speed. - */ -const DRAG_SCROLL_MAX_THRESHOLD = 50; - -/** - * The maximum scrolling speed - */ -const DRAG_SCROLL_MAX_SPEED = 15; - -/** - * The number of milliseconds between drag scroll updates. - */ -const DRAG_SCROLL_INTERVAL = 50; - -/** - * The maximum amount of time that can have elapsed for an alt click to move the - * cursor. - */ -const ALT_CLICK_MOVE_CURSOR_TIME = 500; - -const NON_BREAKING_SPACE_CHAR = String.fromCharCode(160); -const ALL_NON_BREAKING_SPACE_REGEX = new RegExp(NON_BREAKING_SPACE_CHAR, 'g'); - -/** - * Represents a position of a word on a line. - */ -interface IWordPosition { - start: number; - length: number; -} - -/** - * A selection mode, this drives how the selection behaves on mouse move. - */ -export const enum SelectionMode { - NORMAL, - WORD, - LINE, - COLUMN -} - -/** - * A class that manages the selection of the terminal. With help from - * SelectionModel, SelectionService handles with all logic associated with - * dealing with the selection, including handling mouse interaction, wide - * characters and fetching the actual text within the selection. Rendering is - * not handled by the SelectionService but the onRedrawRequest event is fired - * when the selection is ready to be redrawn (on an animation frame). - */ -export class SelectionService extends Disposable implements ISelectionService { - public serviceBrand: undefined; - - protected _model: SelectionModel; - - /** - * The amount to scroll every drag scroll update (depends on how far the mouse - * drag is above or below the terminal). - */ - private _dragScrollAmount: number = 0; - - /** - * The current selection mode. - */ - protected _activeSelectionMode: SelectionMode; - - /** - * A setInterval timer that is active while the mouse is down whose callback - * scrolls the viewport when necessary. - */ - private _dragScrollIntervalTimer: number | undefined; - - /** - * The animation frame ID used for refreshing the selection. - */ - private _refreshAnimationFrame: number | undefined; - - /** - * Whether selection is enabled. - */ - private _enabled = true; - - private _mouseMoveListener: EventListener; - private _mouseUpListener: EventListener; - private _trimListener: IDisposable; - private _workCell: CellData = new CellData(); - - private _mouseDownTimeStamp: number = 0; - private _oldHasSelection: boolean = false; - private _oldSelectionStart: [number, number] | undefined = undefined; - private _oldSelectionEnd: [number, number] | undefined = undefined; - - private _onLinuxMouseSelection = this.register(new EventEmitter()); - public get onLinuxMouseSelection(): IEvent { return this._onLinuxMouseSelection.event; } - private _onRedrawRequest = this.register(new EventEmitter()); - public get onRequestRedraw(): IEvent { return this._onRedrawRequest.event; } - private _onSelectionChange = this.register(new EventEmitter()); - public get onSelectionChange(): IEvent { return this._onSelectionChange.event; } - private _onRequestScrollLines = this.register(new EventEmitter()); - public get onRequestScrollLines(): IEvent { return this._onRequestScrollLines.event; } - - constructor( - private readonly _element: HTMLElement, - private readonly _screenElement: HTMLElement, - @IBufferService private readonly _bufferService: IBufferService, - @ICoreService private readonly _coreService: ICoreService, - @IMouseService private readonly _mouseService: IMouseService, - @IOptionsService private readonly _optionsService: IOptionsService, - @IRenderService private readonly _renderService: IRenderService - ) { - super(); - - // Init listeners - this._mouseMoveListener = event => this._onMouseMove(event); - this._mouseUpListener = event => this._onMouseUp(event); - this._coreService.onUserInput(() => { - if (this.hasSelection) { - this.clearSelection(); - } - }); - this._trimListener = this._bufferService.buffer.lines.onTrim(amount => this._onTrim(amount)); - this.register(this._bufferService.buffers.onBufferActivate(e => this._onBufferActivate(e))); - - this.enable(); - - this._model = new SelectionModel(this._bufferService); - this._activeSelectionMode = SelectionMode.NORMAL; - } - - public dispose(): void { - this._removeMouseDownListeners(); - } - - public reset(): void { - this.clearSelection(); - } - - /** - * Disables the selection manager. This is useful for when terminal mouse - * are enabled. - */ - public disable(): void { - this.clearSelection(); - this._enabled = false; - } - - /** - * Enable the selection manager. - */ - public enable(): void { - this._enabled = true; - } - - public get selectionStart(): [number, number] | undefined { return this._model.finalSelectionStart; } - public get selectionEnd(): [number, number] | undefined { return this._model.finalSelectionEnd; } - - /** - * Gets whether there is an active text selection. - */ - public get hasSelection(): boolean { - const start = this._model.finalSelectionStart; - const end = this._model.finalSelectionEnd; - if (!start || !end) { - return false; - } - return start[0] !== end[0] || start[1] !== end[1]; - } - - /** - * Gets the text currently selected. - */ - public get selectionText(): string { - const start = this._model.finalSelectionStart; - const end = this._model.finalSelectionEnd; - if (!start || !end) { - return ''; - } - - const buffer = this._bufferService.buffer; - const result: string[] = []; - - if (this._activeSelectionMode === SelectionMode.COLUMN) { - // Ignore zero width selections - if (start[0] === end[0]) { - return ''; - } - - for (let i = start[1]; i <= end[1]; i++) { - const lineText = buffer.translateBufferLineToString(i, true, start[0], end[0]); - result.push(lineText); - } - } else { - // Get first row - const startRowEndCol = start[1] === end[1] ? end[0] : undefined; - result.push(buffer.translateBufferLineToString(start[1], true, start[0], startRowEndCol)); - - // Get middle rows - for (let i = start[1] + 1; i <= end[1] - 1; i++) { - const bufferLine = buffer.lines.get(i); - const lineText = buffer.translateBufferLineToString(i, true); - if (bufferLine && bufferLine.isWrapped) { - result[result.length - 1] += lineText; - } else { - result.push(lineText); - } - } - - // Get final row - if (start[1] !== end[1]) { - const bufferLine = buffer.lines.get(end[1]); - const lineText = buffer.translateBufferLineToString(end[1], true, 0, end[0]); - if (bufferLine && bufferLine!.isWrapped) { - result[result.length - 1] += lineText; - } else { - result.push(lineText); - } - } - } - - // Format string by replacing non-breaking space chars with regular spaces - // and joining the array into a multi-line string. - const formattedResult = result.map(line => { - return line.replace(ALL_NON_BREAKING_SPACE_REGEX, ' '); - }).join(Browser.isWindows ? '\r\n' : '\n'); - - return formattedResult; - } - - /** - * Clears the current terminal selection. - */ - public clearSelection(): void { - this._model.clearSelection(); - this._removeMouseDownListeners(); - this.refresh(); - this._onSelectionChange.fire(); - } - - /** - * Queues a refresh, redrawing the selection on the next opportunity. - * @param isLinuxMouseSelection Whether the selection should be registered as a new - * selection on Linux. - */ - public refresh(isLinuxMouseSelection?: boolean): void { - // Queue the refresh for the renderer - if (!this._refreshAnimationFrame) { - this._refreshAnimationFrame = window.requestAnimationFrame(() => this._refresh()); - } - - // If the platform is Linux and the refresh call comes from a mouse event, - // we need to update the selection for middle click to paste selection. - if (Browser.isLinux && isLinuxMouseSelection) { - const selectionText = this.selectionText; - if (selectionText.length) { - this._onLinuxMouseSelection.fire(this.selectionText); - } - } - } - - /** - * Fires the refresh event, causing consumers to pick it up and redraw the - * selection state. - */ - private _refresh(): void { - this._refreshAnimationFrame = undefined; - this._onRedrawRequest.fire({ - start: this._model.finalSelectionStart, - end: this._model.finalSelectionEnd, - columnSelectMode: this._activeSelectionMode === SelectionMode.COLUMN - }); - } - - /** - * Checks if the current click was inside the current selection - * @param event The mouse event - */ - private _isClickInSelection(event: MouseEvent): boolean { - const coords = this._getMouseBufferCoords(event); - const start = this._model.finalSelectionStart; - const end = this._model.finalSelectionEnd; - - if (!start || !end || !coords) { - return false; - } - - return this._areCoordsInSelection(coords, start, end); - } - - protected _areCoordsInSelection(coords: [number, number], start: [number, number], end: [number, number]): boolean { - return (coords[1] > start[1] && coords[1] < end[1]) || - (start[1] === end[1] && coords[1] === start[1] && coords[0] >= start[0] && coords[0] < end[0]) || - (start[1] < end[1] && coords[1] === end[1] && coords[0] < end[0]) || - (start[1] < end[1] && coords[1] === start[1] && coords[0] >= start[0]); - } - - /** - * Selects word at the current mouse event coordinates. - * @param event The mouse event. - */ - private _selectWordAtCursor(event: MouseEvent): void { - const coords = this._getMouseBufferCoords(event); - if (coords) { - this._selectWordAt(coords, false); - this._model.selectionEnd = undefined; - this.refresh(true); - } - } - - /** - * Selects all text within the terminal. - */ - public selectAll(): void { - this._model.isSelectAllActive = true; - this.refresh(); - this._onSelectionChange.fire(); - } - - public selectLines(start: number, end: number): void { - this._model.clearSelection(); - start = Math.max(start, 0); - end = Math.min(end, this._bufferService.buffer.lines.length - 1); - this._model.selectionStart = [0, start]; - this._model.selectionEnd = [this._bufferService.cols, end]; - this.refresh(); - this._onSelectionChange.fire(); - } - - /** - * Handle the buffer being trimmed, adjust the selection position. - * @param amount The amount the buffer is being trimmed. - */ - private _onTrim(amount: number): void { - const needsRefresh = this._model.onTrim(amount); - if (needsRefresh) { - this.refresh(); - } - } - - /** - * Gets the 0-based [x, y] buffer coordinates of the current mouse event. - * @param event The mouse event. - */ - private _getMouseBufferCoords(event: MouseEvent): [number, number] | undefined { - const coords = this._mouseService.getCoords(event, this._screenElement, this._bufferService.cols, this._bufferService.rows, true); - if (!coords) { - return undefined; - } - - // Convert to 0-based - coords[0]--; - coords[1]--; - - // Convert viewport coords to buffer coords - coords[1] += this._bufferService.buffer.ydisp; - return coords; - } - - /** - * Gets the amount the viewport should be scrolled based on how far out of the - * terminal the mouse is. - * @param event The mouse event. - */ - private _getMouseEventScrollAmount(event: MouseEvent): number { - let offset = getCoordsRelativeToElement(event, this._screenElement)[1]; - const terminalHeight = this._renderService.dimensions.canvasHeight; - if (offset >= 0 && offset <= terminalHeight) { - return 0; - } - if (offset > terminalHeight) { - offset -= terminalHeight; - } - - offset = Math.min(Math.max(offset, -DRAG_SCROLL_MAX_THRESHOLD), DRAG_SCROLL_MAX_THRESHOLD); - offset /= DRAG_SCROLL_MAX_THRESHOLD; - return (offset / Math.abs(offset)) + Math.round(offset * (DRAG_SCROLL_MAX_SPEED - 1)); - } - - /** - * Returns whether the selection manager should force selection, regardless of - * whether the terminal is in mouse events mode. - * @param event The mouse event. - */ - public shouldForceSelection(event: MouseEvent): boolean { - if (Browser.isMac) { - return event.altKey && this._optionsService.options.macOptionClickForcesSelection; - } - - return event.shiftKey; - } - - /** - * Handles te mousedown event, setting up for a new selection. - * @param event The mousedown event. - */ - public onMouseDown(event: MouseEvent): void { - this._mouseDownTimeStamp = event.timeStamp; - // If we have selection, we want the context menu on right click even if the - // terminal is in mouse mode. - if (event.button === 2 && this.hasSelection) { - return; - } - - // Only action the primary button - if (event.button !== 0) { - return; - } - - // Allow selection when using a specific modifier key, even when disabled - if (!this._enabled) { - if (!this.shouldForceSelection(event)) { - return; - } - - // Don't send the mouse down event to the current process, we want to select - event.stopPropagation(); - } - - // Tell the browser not to start a regular selection - event.preventDefault(); - - // Reset drag scroll state - this._dragScrollAmount = 0; - - if (this._enabled && event.shiftKey) { - this._onIncrementalClick(event); - } else { - if (event.detail === 1) { - this._onSingleClick(event); - } else if (event.detail === 2) { - this._onDoubleClick(event); - } else if (event.detail === 3) { - this._onTripleClick(event); - } - } - - this._addMouseDownListeners(); - this.refresh(true); - } - - /** - * Adds listeners when mousedown is triggered. - */ - private _addMouseDownListeners(): void { - // Listen on the document so that dragging outside of viewport works - if (this._screenElement.ownerDocument) { - this._screenElement.ownerDocument.addEventListener('mousemove', this._mouseMoveListener); - this._screenElement.ownerDocument.addEventListener('mouseup', this._mouseUpListener); - } - this._dragScrollIntervalTimer = window.setInterval(() => this._dragScroll(), DRAG_SCROLL_INTERVAL); - } - - /** - * Removes the listeners that are registered when mousedown is triggered. - */ - private _removeMouseDownListeners(): void { - if (this._screenElement.ownerDocument) { - this._screenElement.ownerDocument.removeEventListener('mousemove', this._mouseMoveListener); - this._screenElement.ownerDocument.removeEventListener('mouseup', this._mouseUpListener); - } - clearInterval(this._dragScrollIntervalTimer); - this._dragScrollIntervalTimer = undefined; - } - - /** - * Performs an incremental click, setting the selection end position to the mouse - * position. - * @param event The mouse event. - */ - private _onIncrementalClick(event: MouseEvent): void { - if (this._model.selectionStart) { - this._model.selectionEnd = this._getMouseBufferCoords(event); - } - } - - /** - * Performs a single click, resetting relevant state and setting the selection - * start position. - * @param event The mouse event. - */ - private _onSingleClick(event: MouseEvent): void { - this._model.selectionStartLength = 0; - this._model.isSelectAllActive = false; - this._activeSelectionMode = this.shouldColumnSelect(event) ? SelectionMode.COLUMN : SelectionMode.NORMAL; - - // Initialize the new selection - this._model.selectionStart = this._getMouseBufferCoords(event); - if (!this._model.selectionStart) { - return; - } - this._model.selectionEnd = undefined; - - // Ensure the line exists - const line = this._bufferService.buffer.lines.get(this._model.selectionStart[1]); - if (!line) { - return; - } - - // Return early if the click event is not in the buffer (eg. in scroll bar) - if (line.length === this._model.selectionStart[0]) { - return; - } - - // If the mouse is over the second half of a wide character, adjust the - // selection to cover the whole character - if (line.hasWidth(this._model.selectionStart[0]) === 0) { - this._model.selectionStart[0]++; - } - } - - /** - * Performs a double click, selecting the current work. - * @param event The mouse event. - */ - private _onDoubleClick(event: MouseEvent): void { - const coords = this._getMouseBufferCoords(event); - if (coords) { - this._activeSelectionMode = SelectionMode.WORD; - this._selectWordAt(coords, true); - } - } - - /** - * Performs a triple click, selecting the current line and activating line - * select mode. - * @param event The mouse event. - */ - private _onTripleClick(event: MouseEvent): void { - const coords = this._getMouseBufferCoords(event); - if (coords) { - this._activeSelectionMode = SelectionMode.LINE; - this._selectLineAt(coords[1]); - } - } - - /** - * Returns whether the selection manager should operate in column select mode - * @param event the mouse or keyboard event - */ - public shouldColumnSelect(event: KeyboardEvent | MouseEvent): boolean { - return event.altKey && !(Browser.isMac && this._optionsService.options.macOptionClickForcesSelection); - } - - /** - * Handles the mousemove event when the mouse button is down, recording the - * end of the selection and refreshing the selection. - * @param event The mousemove event. - */ - private _onMouseMove(event: MouseEvent): void { - // If the mousemove listener is active it means that a selection is - // currently being made, we should stop propagation to prevent mouse events - // to be sent to the pty. - event.stopImmediatePropagation(); - - // Do nothing if there is no selection start, this can happen if the first - // click in the terminal is an incremental click - if (!this._model.selectionStart) { - return; - } - - // Record the previous position so we know whether to redraw the selection - // at the end. - const previousSelectionEnd = this._model.selectionEnd ? [this._model.selectionEnd[0], this._model.selectionEnd[1]] : null; - - // Set the initial selection end based on the mouse coordinates - this._model.selectionEnd = this._getMouseBufferCoords(event); - if (!this._model.selectionEnd) { - this.refresh(true); - return; - } - - // Select the entire line if line select mode is active. - if (this._activeSelectionMode === SelectionMode.LINE) { - if (this._model.selectionEnd[1] < this._model.selectionStart[1]) { - this._model.selectionEnd[0] = 0; - } else { - this._model.selectionEnd[0] = this._bufferService.cols; - } - } else if (this._activeSelectionMode === SelectionMode.WORD) { - this._selectToWordAt(this._model.selectionEnd); - } - - // Determine the amount of scrolling that will happen. - this._dragScrollAmount = this._getMouseEventScrollAmount(event); - - // If the cursor was above or below the viewport, make sure it's at the - // start or end of the viewport respectively. This should only happen when - // NOT in column select mode. - if (this._activeSelectionMode !== SelectionMode.COLUMN) { - if (this._dragScrollAmount > 0) { - this._model.selectionEnd[0] = this._bufferService.cols; - } else if (this._dragScrollAmount < 0) { - this._model.selectionEnd[0] = 0; - } - } - - // If the character is a wide character include the cell to the right in the - // selection. Note that selections at the very end of the line will never - // have a character. - const buffer = this._bufferService.buffer; - if (this._model.selectionEnd[1] < buffer.lines.length) { - const line = buffer.lines.get(this._model.selectionEnd[1]); - if (line && line.hasWidth(this._model.selectionEnd[0]) === 0) { - this._model.selectionEnd[0]++; - } - } - - // Only draw here if the selection changes. - if (!previousSelectionEnd || - previousSelectionEnd[0] !== this._model.selectionEnd[0] || - previousSelectionEnd[1] !== this._model.selectionEnd[1]) { - this.refresh(true); - } - } - - /** - * The callback that occurs every DRAG_SCROLL_INTERVAL ms that does the - * scrolling of the viewport. - */ - private _dragScroll(): void { - if (!this._model.selectionEnd || !this._model.selectionStart) { - return; - } - if (this._dragScrollAmount) { - this._onRequestScrollLines.fire({ amount: this._dragScrollAmount, suppressScrollEvent: false }); - // Re-evaluate selection - // If the cursor was above or below the viewport, make sure it's at the - // start or end of the viewport respectively. This should only happen when - // NOT in column select mode. - const buffer = this._bufferService.buffer; - if (this._dragScrollAmount > 0) { - if (this._activeSelectionMode !== SelectionMode.COLUMN) { - this._model.selectionEnd[0] = this._bufferService.cols; - } - this._model.selectionEnd[1] = Math.min(buffer.ydisp + this._bufferService.rows, buffer.lines.length - 1); - } else { - if (this._activeSelectionMode !== SelectionMode.COLUMN) { - this._model.selectionEnd[0] = 0; - } - this._model.selectionEnd[1] = buffer.ydisp; - } - this.refresh(); - } - } - - /** - * Handles the mouseup event, removing the mousedown listeners. - * @param event The mouseup event. - */ - private _onMouseUp(event: MouseEvent): void { - const timeElapsed = event.timeStamp - this._mouseDownTimeStamp; - - this._removeMouseDownListeners(); - - if (this.selectionText.length <= 1 && timeElapsed < ALT_CLICK_MOVE_CURSOR_TIME && event.altKey && this._optionsService.getOption('altClickMovesCursor')) { - if (this._bufferService.buffer.ybase === this._bufferService.buffer.ydisp) { - const coordinates = this._mouseService.getCoords( - event, - this._element, - this._bufferService.cols, - this._bufferService.rows, - false - ); - if (coordinates && coordinates[0] !== undefined && coordinates[1] !== undefined) { - const sequence = moveToCellSequence(coordinates[0] - 1, coordinates[1] - 1, this._bufferService, this._coreService.decPrivateModes.applicationCursorKeys); - this._coreService.triggerDataEvent(sequence, true); - } - } - } else { - this._fireEventIfSelectionChanged(); - } - } - - private _fireEventIfSelectionChanged(): void { - const start = this._model.finalSelectionStart; - const end = this._model.finalSelectionEnd; - const hasSelection = !!start && !!end && (start[0] !== end[0] || start[1] !== end[1]); - - if (!hasSelection) { - if (this._oldHasSelection) { - this._fireOnSelectionChange(start, end, hasSelection); - } - return; - } - - // Sanity check, these should not be undefined as there is a selection - if (!start || !end) { - return; - } - - if (!this._oldSelectionStart || !this._oldSelectionEnd || ( - start[0] !== this._oldSelectionStart[0] || start[1] !== this._oldSelectionStart[1] || - end[0] !== this._oldSelectionEnd[0] || end[1] !== this._oldSelectionEnd[1])) { - - this._fireOnSelectionChange(start, end, hasSelection); - } - } - - private _fireOnSelectionChange(start: [number, number] | undefined, end: [number, number] | undefined, hasSelection: boolean): void { - this._oldSelectionStart = start; - this._oldSelectionEnd = end; - this._oldHasSelection = hasSelection; - this._onSelectionChange.fire(); - } - - private _onBufferActivate(e: {activeBuffer: IBuffer, inactiveBuffer: IBuffer}): void { - this.clearSelection(); - // Only adjust the selection on trim, shiftElements is rarely used (only in - // reverseIndex) and delete in a splice is only ever used when the same - // number of elements was just added. Given this is could actually be - // beneficial to leave the selection as is for these cases. - this._trimListener.dispose(); - this._trimListener = e.activeBuffer.lines.onTrim(amount => this._onTrim(amount)); - } - - /** - * Converts a viewport column to the character index on the buffer line, the - * latter takes into account wide characters. - * @param coords The coordinates to find the 2 index for. - */ - private _convertViewportColToCharacterIndex(bufferLine: IBufferLine, coords: [number, number]): number { - let charIndex = coords[0]; - for (let i = 0; coords[0] >= i; i++) { - const length = bufferLine.loadCell(i, this._workCell).getChars().length; - if (this._workCell.getWidth() === 0) { - // Wide characters aren't included in the line string so decrement the - // index so the index is back on the wide character. - charIndex--; - } else if (length > 1 && coords[0] !== i) { - // Emojis take up multiple characters, so adjust accordingly. For these - // we don't want ot include the character at the column as we're - // returning the start index in the string, not the end index. - charIndex += length - 1; - } - } - return charIndex; - } - - public setSelection(col: number, row: number, length: number): void { - this._model.clearSelection(); - this._removeMouseDownListeners(); - this._model.selectionStart = [col, row]; - this._model.selectionStartLength = length; - this.refresh(); - } - - public rightClickSelect(ev: MouseEvent): void { - if (!this._isClickInSelection(ev)) { - this._selectWordAtCursor(ev); - this._fireEventIfSelectionChanged(); - } - } - - /** - * Gets positional information for the word at the coordinated specified. - * @param coords The coordinates to get the word at. - */ - private _getWordAt(coords: [number, number], allowWhitespaceOnlySelection: boolean, followWrappedLinesAbove: boolean = true, followWrappedLinesBelow: boolean = true): IWordPosition | undefined { - // Ensure coords are within viewport (eg. not within scroll bar) - if (coords[0] >= this._bufferService.cols) { - return undefined; - } - - const buffer = this._bufferService.buffer; - const bufferLine = buffer.lines.get(coords[1]); - if (!bufferLine) { - return undefined; - } - - const line = buffer.translateBufferLineToString(coords[1], false); - - // Get actual index, taking into consideration wide characters - let startIndex = this._convertViewportColToCharacterIndex(bufferLine, coords); - let endIndex = startIndex; - - // Record offset to be used later - const charOffset = coords[0] - startIndex; - let leftWideCharCount = 0; - let rightWideCharCount = 0; - let leftLongCharOffset = 0; - let rightLongCharOffset = 0; - - if (line.charAt(startIndex) === ' ') { - // Expand until non-whitespace is hit - while (startIndex > 0 && line.charAt(startIndex - 1) === ' ') { - startIndex--; - } - while (endIndex < line.length && line.charAt(endIndex + 1) === ' ') { - endIndex++; - } - } else { - // Expand until whitespace is hit. This algorithm works by scanning left - // and right from the starting position, keeping both the index format - // (line) and the column format (bufferLine) in sync. When a wide - // character is hit, it is recorded and the column index is adjusted. - let startCol = coords[0]; - let endCol = coords[0]; - - // Consider the initial position, skip it and increment the wide char - // variable - if (bufferLine.getWidth(startCol) === 0) { - leftWideCharCount++; - startCol--; - } - if (bufferLine.getWidth(endCol) === 2) { - rightWideCharCount++; - endCol++; - } - - // Adjust the end index for characters whose length are > 1 (emojis) - const length = bufferLine.getString(endCol).length; - if (length > 1) { - rightLongCharOffset += length - 1; - endIndex += length - 1; - } - - // Expand the string in both directions until a space is hit - while (startCol > 0 && startIndex > 0 && !this._isCharWordSeparator(bufferLine.loadCell(startCol - 1, this._workCell))) { - bufferLine.loadCell(startCol - 1, this._workCell); - const length = this._workCell.getChars().length; - if (this._workCell.getWidth() === 0) { - // If the next character is a wide char, record it and skip the column - leftWideCharCount++; - startCol--; - } else if (length > 1) { - // If the next character's string is longer than 1 char (eg. emoji), - // adjust the index - leftLongCharOffset += length - 1; - startIndex -= length - 1; - } - startIndex--; - startCol--; - } - while (endCol < bufferLine.length && endIndex + 1 < line.length && !this._isCharWordSeparator(bufferLine.loadCell(endCol + 1, this._workCell))) { - bufferLine.loadCell(endCol + 1, this._workCell); - const length = this._workCell.getChars().length; - if (this._workCell.getWidth() === 2) { - // If the next character is a wide char, record it and skip the column - rightWideCharCount++; - endCol++; - } else if (length > 1) { - // If the next character's string is longer than 1 char (eg. emoji), - // adjust the index - rightLongCharOffset += length - 1; - endIndex += length - 1; - } - endIndex++; - endCol++; - } - } - - // Incremenet the end index so it is at the start of the next character - endIndex++; - - // Calculate the start _column_, converting the the string indexes back to - // column coordinates. - let start = - startIndex // The index of the selection's start char in the line string - + charOffset // The difference between the initial char's column and index - - leftWideCharCount // The number of wide chars left of the initial char - + leftLongCharOffset; // The number of additional chars left of the initial char added by columns with strings longer than 1 (emojis) - - // Calculate the length in _columns_, converting the the string indexes back - // to column coordinates. - let length = Math.min(this._bufferService.cols, // Disallow lengths larger than the terminal cols - endIndex // The index of the selection's end char in the line string - - startIndex // The index of the selection's start char in the line string - + leftWideCharCount // The number of wide chars left of the initial char - + rightWideCharCount // The number of wide chars right of the initial char (inclusive) - - leftLongCharOffset // The number of additional chars left of the initial char added by columns with strings longer than 1 (emojis) - - rightLongCharOffset); // The number of additional chars right of the initial char (inclusive) added by columns with strings longer than 1 (emojis) - - if (!allowWhitespaceOnlySelection && line.slice(startIndex, endIndex).trim() === '') { - return undefined; - } - - // Recurse upwards if the line is wrapped and the word wraps to the above line - if (followWrappedLinesAbove) { - if (start === 0 && bufferLine.getCodePoint(0) !== 32 /* ' ' */) { - const previousBufferLine = buffer.lines.get(coords[1] - 1); - if (previousBufferLine && bufferLine.isWrapped && previousBufferLine.getCodePoint(this._bufferService.cols - 1) !== 32 /* ' ' */) { - const previousLineWordPosition = this._getWordAt([this._bufferService.cols - 1, coords[1] - 1], false, true, false); - if (previousLineWordPosition) { - const offset = this._bufferService.cols - previousLineWordPosition.start; - start -= offset; - length += offset; - } - } - } - } - - // Recurse downwards if the line is wrapped and the word wraps to the next line - if (followWrappedLinesBelow) { - if (start + length === this._bufferService.cols && bufferLine.getCodePoint(this._bufferService.cols - 1) !== 32 /* ' ' */) { - const nextBufferLine = buffer.lines.get(coords[1] + 1); - if (nextBufferLine && nextBufferLine.isWrapped && nextBufferLine.getCodePoint(0) !== 32 /* ' ' */) { - const nextLineWordPosition = this._getWordAt([0, coords[1] + 1], false, false, true); - if (nextLineWordPosition) { - length += nextLineWordPosition.length; - } - } - } - } - - return { start, length }; - } - - /** - * Selects the word at the coordinates specified. - * @param coords The coordinates to get the word at. - * @param allowWhitespaceOnlySelection If whitespace should be selected - */ - protected _selectWordAt(coords: [number, number], allowWhitespaceOnlySelection: boolean): void { - const wordPosition = this._getWordAt(coords, allowWhitespaceOnlySelection); - if (wordPosition) { - // Adjust negative start value - while (wordPosition.start < 0) { - wordPosition.start += this._bufferService.cols; - coords[1]--; - } - this._model.selectionStart = [wordPosition.start, coords[1]]; - this._model.selectionStartLength = wordPosition.length; - } - } - - /** - * Sets the selection end to the word at the coordinated specified. - * @param coords The coordinates to get the word at. - */ - private _selectToWordAt(coords: [number, number]): void { - const wordPosition = this._getWordAt(coords, true); - if (wordPosition) { - let endRow = coords[1]; - - // Adjust negative start value - while (wordPosition.start < 0) { - wordPosition.start += this._bufferService.cols; - endRow--; - } - - // Adjust wrapped length value, this only needs to happen when values are reversed as in that - // case we're interested in the start of the word, not the end - if (!this._model.areSelectionValuesReversed()) { - while (wordPosition.start + wordPosition.length > this._bufferService.cols) { - wordPosition.length -= this._bufferService.cols; - endRow++; - } - } - - this._model.selectionEnd = [this._model.areSelectionValuesReversed() ? wordPosition.start : wordPosition.start + wordPosition.length, endRow]; - } - } - - /** - * Gets whether the character is considered a word separator by the select - * word logic. - * @param char The character to check. - */ - private _isCharWordSeparator(cell: CellData): boolean { - // Zero width characters are never separators as they are always to the - // right of wide characters - if (cell.getWidth() === 0) { - return false; - } - return this._optionsService.options.wordSeparator.indexOf(cell.getChars()) >= 0; - } - - /** - * Selects the line specified. - * @param line The line index. - */ - protected _selectLineAt(line: number): void { - const wrappedRange = this._bufferService.buffer.getWrappedRangeForLine(line); - this._model.selectionStart = [0, wrappedRange.first]; - this._model.selectionEnd = [this._bufferService.cols, wrappedRange.last]; - this._model.selectionStartLength = 0; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/Services.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/Services.ts deleted file mode 100755 index f06e320bf..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/Services.ts +++ /dev/null @@ -1,106 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IEvent } from 'common/EventEmitter'; -import { IRenderDimensions, IRenderer, CharacterJoinerHandler } from 'browser/renderer/Types'; -import { IColorSet } from 'browser/Types'; -import { ISelectionRedrawRequestEvent as ISelectionRequestRedrawEvent, ISelectionRequestScrollLinesEvent } from 'browser/selection/Types'; -import { createDecorator } from 'common/services/ServiceRegistry'; -import { IDisposable } from 'common/Types'; - -export const ICharSizeService = createDecorator('CharSizeService'); -export interface ICharSizeService { - serviceBrand: undefined; - - readonly width: number; - readonly height: number; - readonly hasValidSize: boolean; - - readonly onCharSizeChange: IEvent; - - measure(): void; -} - -export const ICoreBrowserService = createDecorator('CoreBrowserService'); -export interface ICoreBrowserService { - serviceBrand: undefined; - - readonly isFocused: boolean; -} - -export const IMouseService = createDecorator('MouseService'); -export interface IMouseService { - serviceBrand: undefined; - - getCoords(event: {clientX: number, clientY: number}, element: HTMLElement, colCount: number, rowCount: number, isSelection?: boolean): [number, number] | undefined; - getRawByteCoords(event: MouseEvent, element: HTMLElement, colCount: number, rowCount: number): { x: number, y: number } | undefined; -} - -export const IRenderService = createDecorator('RenderService'); -export interface IRenderService extends IDisposable { - serviceBrand: undefined; - - onDimensionsChange: IEvent; - /** - * Fires when buffer changes are rendered. This does not fire when only cursor - * or selections are rendered. - */ - onRenderedBufferChange: IEvent<{ start: number, end: number }>; - onRefreshRequest: IEvent<{ start: number, end: number }>; - - dimensions: IRenderDimensions; - - refreshRows(start: number, end: number): void; - resize(cols: number, rows: number): void; - changeOptions(): void; - setRenderer(renderer: IRenderer): void; - setColors(colors: IColorSet): void; - onDevicePixelRatioChange(): void; - onResize(cols: number, rows: number): void; - // TODO: Is this useful when we have onResize? - onCharSizeChanged(): void; - onBlur(): void; - onFocus(): void; - onSelectionChanged(start: [number, number] | undefined, end: [number, number] | undefined, columnSelectMode: boolean): void; - onCursorMove(): void; - clear(): void; - registerCharacterJoiner(handler: CharacterJoinerHandler): number; - deregisterCharacterJoiner(joinerId: number): boolean; -} - -export const ISelectionService = createDecorator('SelectionService'); -export interface ISelectionService { - serviceBrand: undefined; - - readonly selectionText: string; - readonly hasSelection: boolean; - readonly selectionStart: [number, number] | undefined; - readonly selectionEnd: [number, number] | undefined; - - readonly onLinuxMouseSelection: IEvent; - readonly onRequestRedraw: IEvent; - readonly onRequestScrollLines: IEvent; - readonly onSelectionChange: IEvent; - - disable(): void; - enable(): void; - reset(): void; - setSelection(row: number, col: number, length: number): void; - selectAll(): void; - selectLines(start: number, end: number): void; - clearSelection(): void; - rightClickSelect(event: MouseEvent): void; - shouldColumnSelect(event: KeyboardEvent | MouseEvent): boolean; - shouldForceSelection(event: MouseEvent): boolean; - refresh(isLinuxMouseSelection?: boolean): void; - onMouseDown(event: MouseEvent): void; -} - -export const ISoundService = createDecorator('SoundService'); -export interface ISoundService { - serviceBrand: undefined; - - playBellSound(): void; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/SoundService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/SoundService.ts deleted file mode 100755 index 8d940c13d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/services/SoundService.ts +++ /dev/null @@ -1,63 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IOptionsService } from 'common/services/Services'; -import { ISoundService } from 'browser/services/Services'; - -export class SoundService implements ISoundService { - public serviceBrand: undefined; - - private static _audioContext: AudioContext; - - public static get audioContext(): AudioContext | null { - if (!SoundService._audioContext) { - const audioContextCtor: typeof AudioContext = (window).AudioContext || (window).webkitAudioContext; - if (!audioContextCtor) { - console.warn('Web Audio API is not supported by this browser. Consider upgrading to the latest version'); - return null; - } - SoundService._audioContext = new audioContextCtor(); - } - return SoundService._audioContext; - } - - constructor( - @IOptionsService private _optionsService: IOptionsService - ) { - } - - public playBellSound(): void { - const ctx = SoundService.audioContext; - if (!ctx) { - return; - } - const bellAudioSource = ctx.createBufferSource(); - ctx.decodeAudioData(this._base64ToArrayBuffer(this._removeMimeType(this._optionsService.options.bellSound)), (buffer) => { - bellAudioSource.buffer = buffer; - bellAudioSource.connect(ctx.destination); - bellAudioSource.start(0); - }); - } - - private _base64ToArrayBuffer(base64: string): ArrayBuffer { - const binaryString = window.atob(base64); - const len = binaryString.length; - const bytes = new Uint8Array(len); - - for (let i = 0; i < len; i++) { - bytes[i] = binaryString.charCodeAt(i); - } - - return bytes.buffer; - } - - private _removeMimeType(dataURI: string): string { - // Split the input to get the mime-type and the data itself - const splitUri = dataURI.split(','); - - // Return only the data - return splitUri[1]; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/tsconfig.json b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/tsconfig.json deleted file mode 100755 index 212aeab83..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/browser/tsconfig.json +++ /dev/null @@ -1,25 +0,0 @@ -{ - "extends": "../tsconfig-library-base", - "compilerOptions": { - "lib": [ - "dom", - "es2015", - "es2016.Array.Include" - ], - "outDir": "../../out", - "types": [ - "../../node_modules/@types/mocha" - ], - "baseUrl": "..", - "paths": { - "common/*": [ "./common/*" ] - } - }, - "include": [ - "./**/*", - "../../typings/xterm.d.ts" - ], - "references": [ - { "path": "../common" } - ] -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/CircularList.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/CircularList.ts deleted file mode 100755 index ab00e6812..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/CircularList.ts +++ /dev/null @@ -1,239 +0,0 @@ -/** - * Copyright (c) 2016 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ICircularList } from 'common/Types'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; - -export interface IInsertEvent { - index: number; - amount: number; -} - -export interface IDeleteEvent { - index: number; - amount: number; -} - -/** - * Represents a circular list; a list with a maximum size that wraps around when push is called, - * overriding values at the start of the list. - */ -export class CircularList implements ICircularList { - protected _array: (T | undefined)[]; - private _startIndex: number; - private _length: number; - - public onDeleteEmitter = new EventEmitter(); - public get onDelete(): IEvent { return this.onDeleteEmitter.event; } - public onInsertEmitter = new EventEmitter(); - public get onInsert(): IEvent { return this.onInsertEmitter.event; } - public onTrimEmitter = new EventEmitter(); - public get onTrim(): IEvent { return this.onTrimEmitter.event; } - - constructor( - private _maxLength: number - ) { - this._array = new Array(this._maxLength); - this._startIndex = 0; - this._length = 0; - } - - public get maxLength(): number { - return this._maxLength; - } - - public set maxLength(newMaxLength: number) { - // There was no change in maxLength, return early. - if (this._maxLength === newMaxLength) { - return; - } - - // Reconstruct array, starting at index 0. Only transfer values from the - // indexes 0 to length. - const newArray = new Array(newMaxLength); - for (let i = 0; i < Math.min(newMaxLength, this.length); i++) { - newArray[i] = this._array[this._getCyclicIndex(i)]; - } - this._array = newArray; - this._maxLength = newMaxLength; - this._startIndex = 0; - } - - public get length(): number { - return this._length; - } - - public set length(newLength: number) { - if (newLength > this._length) { - for (let i = this._length; i < newLength; i++) { - this._array[i] = undefined; - } - } - this._length = newLength; - } - - /** - * Gets the value at an index. - * - * Note that for performance reasons there is no bounds checking here, the index reference is - * circular so this should always return a value and never throw. - * @param index The index of the value to get. - * @return The value corresponding to the index. - */ - public get(index: number): T | undefined { - return this._array[this._getCyclicIndex(index)]; - } - - /** - * Sets the value at an index. - * - * Note that for performance reasons there is no bounds checking here, the index reference is - * circular so this should always return a value and never throw. - * @param index The index to set. - * @param value The value to set. - */ - public set(index: number, value: T | undefined): void { - this._array[this._getCyclicIndex(index)] = value; - } - - /** - * Pushes a new value onto the list, wrapping around to the start of the array, overriding index 0 - * if the maximum length is reached. - * @param value The value to push onto the list. - */ - public push(value: T): void { - this._array[this._getCyclicIndex(this._length)] = value; - if (this._length === this._maxLength) { - this._startIndex = ++this._startIndex % this._maxLength; - this.onTrimEmitter.fire(1); - } else { - this._length++; - } - } - - /** - * Advance ringbuffer index and return current element for recycling. - * Note: The buffer must be full for this method to work. - * @throws When the buffer is not full. - */ - public recycle(): T { - if (this._length !== this._maxLength) { - throw new Error('Can only recycle when the buffer is full'); - } - this._startIndex = ++this._startIndex % this._maxLength; - this.onTrimEmitter.fire(1); - return this._array[this._getCyclicIndex(this._length - 1)]!; - } - - /** - * Ringbuffer is at max length. - */ - public get isFull(): boolean { - return this._length === this._maxLength; - } - - /** - * Removes and returns the last value on the list. - * @return The popped value. - */ - public pop(): T | undefined { - return this._array[this._getCyclicIndex(this._length-- - 1)]; - } - - /** - * Deletes and/or inserts items at a particular index (in that order). Unlike - * Array.prototype.splice, this operation does not return the deleted items as a new array in - * order to save creating a new array. Note that this operation may shift all values in the list - * in the worst case. - * @param start The index to delete and/or insert. - * @param deleteCount The number of elements to delete. - * @param items The items to insert. - */ - public splice(start: number, deleteCount: number, ...items: T[]): void { - // Delete items - if (deleteCount) { - for (let i = start; i < this._length - deleteCount; i++) { - this._array[this._getCyclicIndex(i)] = this._array[this._getCyclicIndex(i + deleteCount)]; - } - this._length -= deleteCount; - this.onDeleteEmitter.fire({index: start, amount: deleteCount}); - } - - // Add items - for (let i = this._length - 1; i >= start; i--) { - this._array[this._getCyclicIndex(i + items.length)] = this._array[this._getCyclicIndex(i)]; - } - for (let i = 0; i < items.length; i++) { - this._array[this._getCyclicIndex(start + i)] = items[i]; - } - if (items.length) { - this.onInsertEmitter.fire({index: start, amount: items.length}); - } - - // Adjust length as needed - if (this._length + items.length > this._maxLength) { - const countToTrim = (this._length + items.length) - this._maxLength; - this._startIndex += countToTrim; - this._length = this._maxLength; - this.onTrimEmitter.fire(countToTrim); - } else { - this._length += items.length; - } - } - - /** - * Trims a number of items from the start of the list. - * @param count The number of items to remove. - */ - public trimStart(count: number): void { - if (count > this._length) { - count = this._length; - } - this._startIndex += count; - this._length -= count; - this.onTrimEmitter.fire(count); - } - - public shiftElements(start: number, count: number, offset: number): void { - if (count <= 0) { - return; - } - if (start < 0 || start >= this._length) { - throw new Error('start argument out of range'); - } - if (start + offset < 0) { - throw new Error('Cannot shift elements in list beyond index 0'); - } - - if (offset > 0) { - for (let i = count - 1; i >= 0; i--) { - this.set(start + i + offset, this.get(start + i)); - } - const expandListBy = (start + count + offset) - this._length; - if (expandListBy > 0) { - this._length += expandListBy; - while (this._length > this._maxLength) { - this._length--; - this._startIndex++; - this.onTrimEmitter.fire(1); - } - } - } else { - for (let i = 0; i < count; i++) { - this.set(start + i + offset, this.get(start + i)); - } - } - } - - /** - * Gets the cyclic index for the specified regular index. The cyclic index can then be used on the - * backing array to get the element associated with the regular index. - * @param index The regular index. - * @returns The cyclic index. - */ - private _getCyclicIndex(index: number): number { - return (this._startIndex + index) % this._maxLength; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Clone.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Clone.ts deleted file mode 100755 index 51c5abaa7..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Clone.ts +++ /dev/null @@ -1,23 +0,0 @@ -/** - * Copyright (c) 2016 The xterm.js authors. All rights reserved. - * @license MIT - */ - -/* - * A simple utility for cloning values - */ -export function clone(val: T, depth: number = 5): T { - if (typeof val !== 'object') { - return val; - } - - // If we're cloning an array, use an array as the base, otherwise use an object - const clonedObject: any = Array.isArray(val) ? [] : {}; - - for (const key in val) { - // Recursively clone eack item unless we're at the maximum depth - clonedObject[key] = depth <= 1 ? val[key] : (val[key] ? clone(val[key], depth - 1) : val[key]); - } - - return clonedObject as T; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/CoreTerminal.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/CoreTerminal.ts deleted file mode 100755 index 2f6363490..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/CoreTerminal.ts +++ /dev/null @@ -1,338 +0,0 @@ -/** - * Copyright (c) 2014-2020 The xterm.js authors. All rights reserved. - * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License) - * @license MIT - * - * Originally forked from (with the author's permission): - * Fabrice Bellard's javascript vt100 for jslinux: - * http://bellard.org/jslinux/ - * Copyright (c) 2011 Fabrice Bellard - * The original design remains. The terminal itself - * has been extended to include xterm CSI codes, among - * other features. - * - * Terminal Emulation References: - * http://vt100.net/ - * http://invisible-island.net/xterm/ctlseqs/ctlseqs.txt - * http://invisible-island.net/xterm/ctlseqs/ctlseqs.html - * http://invisible-island.net/vttest/ - * http://www.inwap.com/pdp10/ansicode.txt - * http://linux.die.net/man/4/console_codes - * http://linux.die.net/man/7/urxvt - */ - -import { Disposable } from 'common/Lifecycle'; -import { IInstantiationService, IOptionsService, IBufferService, ILogService, ICharsetService, ICoreService, ICoreMouseService, IUnicodeService, IDirtyRowService } from 'common/services/Services'; -import { InstantiationService } from 'common/services/InstantiationService'; -import { LogService } from 'common/services/LogService'; -import { BufferService, MINIMUM_COLS, MINIMUM_ROWS } from 'common/services/BufferService'; -import { OptionsService } from 'common/services/OptionsService'; -import { ITerminalOptions, IDisposable, IBufferLine, IAttributeData, ICoreTerminal } from 'common/Types'; -import { CoreService } from 'common/services/CoreService'; -import { EventEmitter, IEvent, forwardEvent } from 'common/EventEmitter'; -import { CoreMouseService } from 'common/services/CoreMouseService'; -import { DirtyRowService } from 'common/services/DirtyRowService'; -import { UnicodeService } from 'common/services/UnicodeService'; -import { CharsetService } from 'common/services/CharsetService'; -import { updateWindowsModeWrappedState } from 'common/WindowsMode'; -import { IFunctionIdentifier, IParams } from 'common/parser/Types'; -import { IBufferSet } from 'common/buffer/Types'; -import { InputHandler } from 'common/InputHandler'; -import { WriteBuffer } from 'common/input/WriteBuffer'; - -export abstract class CoreTerminal extends Disposable implements ICoreTerminal { - protected readonly _instantiationService: IInstantiationService; - protected readonly _bufferService: IBufferService; - protected readonly _logService: ILogService; - protected readonly _coreService: ICoreService; - protected readonly _charsetService: ICharsetService; - protected readonly _coreMouseService: ICoreMouseService; - protected readonly _dirtyRowService: IDirtyRowService; - - public readonly unicodeService: IUnicodeService; - public readonly optionsService: IOptionsService; - - protected _inputHandler: InputHandler; - private _writeBuffer: WriteBuffer; - private _windowsMode: IDisposable | undefined; - /** An IBufferline to clone/copy from for new blank lines */ - private _cachedBlankLine: IBufferLine | undefined; - - private _onBinary = new EventEmitter(); - public get onBinary(): IEvent { return this._onBinary.event; } - private _onData = new EventEmitter(); - public get onData(): IEvent { return this._onData.event; } - protected _onLineFeed = new EventEmitter(); - public get onLineFeed(): IEvent { return this._onLineFeed.event; } - private _onResize = new EventEmitter<{ cols: number, rows: number }>(); - public get onResize(): IEvent<{ cols: number, rows: number }> { return this._onResize.event; } - protected _onScroll = new EventEmitter(); - public get onScroll(): IEvent { return this._onScroll.event; } - - public get cols(): number { return this._bufferService.cols; } - public get rows(): number { return this._bufferService.rows; } - public get buffers(): IBufferSet { return this._bufferService.buffers; } - - constructor( - options: ITerminalOptions - ) { - super(); - - // Setup and initialize services - this._instantiationService = new InstantiationService(); - this.optionsService = new OptionsService(options); - this._instantiationService.setService(IOptionsService, this.optionsService); - this._bufferService = this.register(this._instantiationService.createInstance(BufferService)); - this._instantiationService.setService(IBufferService, this._bufferService); - this._logService = this._instantiationService.createInstance(LogService); - this._instantiationService.setService(ILogService, this._logService); - this._coreService = this.register(this._instantiationService.createInstance(CoreService, () => this.scrollToBottom())); - this._instantiationService.setService(ICoreService, this._coreService); - this._coreMouseService = this._instantiationService.createInstance(CoreMouseService); - this._instantiationService.setService(ICoreMouseService, this._coreMouseService); - this._dirtyRowService = this._instantiationService.createInstance(DirtyRowService); - this._instantiationService.setService(IDirtyRowService, this._dirtyRowService); - this.unicodeService = this._instantiationService.createInstance(UnicodeService); - this._instantiationService.setService(IUnicodeService, this.unicodeService); - this._charsetService = this._instantiationService.createInstance(CharsetService); - this._instantiationService.setService(ICharsetService, this._charsetService); - - // Register input handler and handle/forward events - this._inputHandler = new InputHandler(this._bufferService, this._charsetService, this._coreService, this._dirtyRowService, this._logService, this.optionsService, this._coreMouseService, this.unicodeService); - this.register(forwardEvent(this._inputHandler.onLineFeed, this._onLineFeed)); - this.register(this._inputHandler); - - // Setup listeners - this.register(forwardEvent(this._bufferService.onResize, this._onResize)); - this.register(forwardEvent(this._coreService.onData, this._onData)); - this.register(forwardEvent(this._coreService.onBinary, this._onBinary)); - this.register(this.optionsService.onOptionChange(key => this._updateOptions(key))); - - // Setup WriteBuffer - this._writeBuffer = new WriteBuffer(data => this._inputHandler.parse(data)); - } - - public dispose(): void { - if (this._isDisposed) { - return; - } - super.dispose(); - this._windowsMode?.dispose(); - this._windowsMode = undefined; - } - - public write(data: string | Uint8Array, callback?: () => void): void { - this._writeBuffer.write(data, callback); - } - - public writeSync(data: string | Uint8Array): void { - this._writeBuffer.writeSync(data); - } - - public resize(x: number, y: number): void { - if (isNaN(x) || isNaN(y)) { - return; - } - - x = Math.max(x, MINIMUM_COLS); - y = Math.max(y, MINIMUM_ROWS); - - this._bufferService.resize(x, y); - } - - /** - * Scroll the terminal down 1 row, creating a blank line. - * @param isWrapped Whether the new line is wrapped from the previous line. - */ - public scroll(eraseAttr: IAttributeData, isWrapped: boolean = false): void { - const buffer = this._bufferService.buffer; - - let newLine: IBufferLine | undefined; - newLine = this._cachedBlankLine; - if (!newLine || newLine.length !== this.cols || newLine.getFg(0) !== eraseAttr.fg || newLine.getBg(0) !== eraseAttr.bg) { - newLine = buffer.getBlankLine(eraseAttr, isWrapped); - this._cachedBlankLine = newLine; - } - newLine.isWrapped = isWrapped; - - const topRow = buffer.ybase + buffer.scrollTop; - const bottomRow = buffer.ybase + buffer.scrollBottom; - - if (buffer.scrollTop === 0) { - // Determine whether the buffer is going to be trimmed after insertion. - const willBufferBeTrimmed = buffer.lines.isFull; - - // Insert the line using the fastest method - if (bottomRow === buffer.lines.length - 1) { - if (willBufferBeTrimmed) { - buffer.lines.recycle().copyFrom(newLine); - } else { - buffer.lines.push(newLine.clone()); - } - } else { - buffer.lines.splice(bottomRow + 1, 0, newLine.clone()); - } - - // Only adjust ybase and ydisp when the buffer is not trimmed - if (!willBufferBeTrimmed) { - buffer.ybase++; - // Only scroll the ydisp with ybase if the user has not scrolled up - if (!this._bufferService.isUserScrolling) { - buffer.ydisp++; - } - } else { - // When the buffer is full and the user has scrolled up, keep the text - // stable unless ydisp is right at the top - if (this._bufferService.isUserScrolling) { - buffer.ydisp = Math.max(buffer.ydisp - 1, 0); - } - } - } else { - // scrollTop is non-zero which means no line will be going to the - // scrollback, instead we can just shift them in-place. - const scrollRegionHeight = bottomRow - topRow + 1 /* as it's zero-based */; - buffer.lines.shiftElements(topRow + 1, scrollRegionHeight - 1, -1); - buffer.lines.set(bottomRow, newLine.clone()); - } - - // Move the viewport to the bottom of the buffer unless the user is - // scrolling. - if (!this._bufferService.isUserScrolling) { - buffer.ydisp = buffer.ybase; - } - - // Flag rows that need updating - this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom); - - this._onScroll.fire(buffer.ydisp); - } - - /** - * Scroll the display of the terminal - * @param disp The number of lines to scroll down (negative scroll up). - * @param suppressScrollEvent Don't emit the scroll event as scrollLines. This is used - * to avoid unwanted events being handled by the viewport when the event was triggered from the - * viewport originally. - */ - public scrollLines(disp: number, suppressScrollEvent?: boolean): void { - const buffer = this._bufferService.buffer; - if (disp < 0) { - if (buffer.ydisp === 0) { - return; - } - this._bufferService.isUserScrolling = true; - } else if (disp + buffer.ydisp >= buffer.ybase) { - this._bufferService.isUserScrolling = false; - } - - const oldYdisp = buffer.ydisp; - buffer.ydisp = Math.max(Math.min(buffer.ydisp + disp, buffer.ybase), 0); - - // No change occurred, don't trigger scroll/refresh - if (oldYdisp === buffer.ydisp) { - return; - } - - if (!suppressScrollEvent) { - this._onScroll.fire(buffer.ydisp); - } - } - - /** - * Scroll the display of the terminal by a number of pages. - * @param pageCount The number of pages to scroll (negative scrolls up). - */ - public scrollPages(pageCount: number): void { - this.scrollLines(pageCount * (this.rows - 1)); - } - - /** - * Scrolls the display of the terminal to the top. - */ - public scrollToTop(): void { - this.scrollLines(-this._bufferService.buffer.ydisp); - } - - /** - * Scrolls the display of the terminal to the bottom. - */ - public scrollToBottom(): void { - this.scrollLines(this._bufferService.buffer.ybase - this._bufferService.buffer.ydisp); - } - - public scrollToLine(line: number): void { - const scrollAmount = line - this._bufferService.buffer.ydisp; - if (scrollAmount !== 0) { - this.scrollLines(scrollAmount); - } - } - - /** Add handler for ESC escape sequence. See xterm.d.ts for details. */ - public addEscHandler(id: IFunctionIdentifier, callback: () => boolean): IDisposable { - return this._inputHandler.addEscHandler(id, callback); - } - - /** Add handler for DCS escape sequence. See xterm.d.ts for details. */ - public addDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: IParams) => boolean): IDisposable { - return this._inputHandler.addDcsHandler(id, callback); - } - - /** Add handler for CSI escape sequence. See xterm.d.ts for details. */ - public addCsiHandler(id: IFunctionIdentifier, callback: (params: IParams) => boolean): IDisposable { - return this._inputHandler.addCsiHandler(id, callback); - } - - /** Add handler for OSC escape sequence. See xterm.d.ts for details. */ - public addOscHandler(ident: number, callback: (data: string) => boolean): IDisposable { - return this._inputHandler.addOscHandler(ident, callback); - } - - protected _setup(): void { - if (this.optionsService.options.windowsMode) { - this._enableWindowsMode(); - } - } - - public reset(): void { - this._inputHandler.reset(); - this._bufferService.reset(); - this._charsetService.reset(); - this._coreService.reset(); - this._coreMouseService.reset(); - } - - protected _updateOptions(key: string): void { - // TODO: These listeners should be owned by individual components - switch (key) { - case 'scrollback': - this.buffers.resize(this.cols, this.rows); - break; - case 'windowsMode': - if (this.optionsService.options.windowsMode) { - this._enableWindowsMode(); - } else { - this._windowsMode?.dispose(); - this._windowsMode = undefined; - } - break; - } - } - - protected _enableWindowsMode(): void { - if (!this._windowsMode) { - const disposables: IDisposable[] = []; - disposables.push(this.onLineFeed(updateWindowsModeWrappedState.bind(null, this._bufferService))); - disposables.push(this.addCsiHandler({ final: 'H' }, () => { - updateWindowsModeWrappedState(this._bufferService); - return false; - })); - this._windowsMode = { - dispose: () => { - for (const d of disposables) { - d.dispose(); - } - } - }; - } - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/EventEmitter.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/EventEmitter.ts deleted file mode 100755 index 4684809f3..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/EventEmitter.ts +++ /dev/null @@ -1,69 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IDisposable } from 'common/Types'; - -interface IListener { - (arg1: T, arg2: U): void; -} - -export interface IEvent { - (listener: (arg1: T, arg2: U) => any): IDisposable; -} - -export interface IEventEmitter { - event: IEvent; - fire(arg1: T, arg2: U): void; - dispose(): void; -} - -export class EventEmitter implements IEventEmitter { - private _listeners: IListener[] = []; - private _event?: IEvent; - private _disposed: boolean = false; - - public get event(): IEvent { - if (!this._event) { - this._event = (listener: (arg1: T, arg2: U) => any) => { - this._listeners.push(listener); - const disposable = { - dispose: () => { - if (!this._disposed) { - for (let i = 0; i < this._listeners.length; i++) { - if (this._listeners[i] === listener) { - this._listeners.splice(i, 1); - return; - } - } - } - } - }; - return disposable; - }; - } - return this._event; - } - - public fire(arg1: T, arg2: U): void { - const queue: IListener[] = []; - for (let i = 0; i < this._listeners.length; i++) { - queue.push(this._listeners[i]); - } - for (let i = 0; i < queue.length; i++) { - queue[i].call(undefined, arg1, arg2); - } - } - - public dispose(): void { - if (this._listeners) { - this._listeners.length = 0; - } - this._disposed = true; - } -} - -export function forwardEvent(from: IEvent, to: IEventEmitter): IDisposable { - return from(e => to.fire(e)); -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/InputHandler.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/InputHandler.ts deleted file mode 100755 index 60c1e3576..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/InputHandler.ts +++ /dev/null @@ -1,3032 +0,0 @@ -/** - * Copyright (c) 2014 The xterm.js authors. All rights reserved. - * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License) - * @license MIT - */ - -import { IInputHandler, IAttributeData, IDisposable, IWindowOptions, IAnsiColorChangeEvent } from 'common/Types'; -import { C0, C1 } from 'common/data/EscapeSequences'; -import { CHARSETS, DEFAULT_CHARSET } from 'common/data/Charsets'; -import { EscapeSequenceParser } from 'common/parser/EscapeSequenceParser'; -import { Disposable } from 'common/Lifecycle'; -import { concat } from 'common/TypedArrayUtils'; -import { StringToUtf32, stringFromCodePoint, utf32ToString, Utf8ToUtf32 } from 'common/input/TextDecoder'; -import { DEFAULT_ATTR_DATA } from 'common/buffer/BufferLine'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { IParsingState, IDcsHandler, IEscapeSequenceParser, IParams, IFunctionIdentifier } from 'common/parser/Types'; -import { NULL_CELL_CODE, NULL_CELL_WIDTH, Attributes, FgFlags, BgFlags, Content, UnderlineStyle } from 'common/buffer/Constants'; -import { CellData } from 'common/buffer/CellData'; -import { AttributeData } from 'common/buffer/AttributeData'; -import { ICoreService, IBufferService, IOptionsService, ILogService, IDirtyRowService, ICoreMouseService, ICharsetService, IUnicodeService } from 'common/services/Services'; -import { OscHandler } from 'common/parser/OscParser'; -import { DcsHandler } from 'common/parser/DcsParser'; - -/** - * Map collect to glevel. Used in `selectCharset`. - */ -const GLEVEL: {[key: string]: number} = {'(': 0, ')': 1, '*': 2, '+': 3, '-': 1, '.': 2}; - -/** - * VT commands done by the parser - FIXME: move this to the parser? - */ -// @vt: #Y ESC CSI "Control Sequence Introducer" "ESC [" "Start of a CSI sequence." -// @vt: #Y ESC OSC "Operating System Command" "ESC ]" "Start of an OSC sequence." -// @vt: #Y ESC DCS "Device Control String" "ESC P" "Start of a DCS sequence." -// @vt: #Y ESC ST "String Terminator" "ESC \" "Terminator used for string type sequences." -// @vt: #Y ESC PM "Privacy Message" "ESC ^" "Start of a privacy message." -// @vt: #Y ESC APC "Application Program Command" "ESC _" "Start of an APC sequence." -// @vt: #Y C1 CSI "Control Sequence Introducer" "\x9B" "Start of a CSI sequence." -// @vt: #Y C1 OSC "Operating System Command" "\x9D" "Start of an OSC sequence." -// @vt: #Y C1 DCS "Device Control String" "\x90" "Start of a DCS sequence." -// @vt: #Y C1 ST "String Terminator" "\x9C" "Terminator used for string type sequences." -// @vt: #Y C1 PM "Privacy Message" "\x9E" "Start of a privacy message." -// @vt: #Y C1 APC "Application Program Command" "\x9F" "Start of an APC sequence." -// @vt: #Y C0 NUL "Null" "\0, \x00" "NUL is ignored." -// @vt: #Y C0 ESC "Escape" "\e, \x1B" "Start of a sequence. Cancels any other sequence." - -/** - * Document common VT features here that are currently unsupported - */ -// @vt: #N DCS SIXEL "SIXEL Graphics" "DCS Ps ; Ps ; Ps ; q Pt ST" "Draw SIXEL image starting at cursor position." -// @vt: #N OSC 1 "Set Icon Name" "OSC 1 ; Pt BEL" "Set icon name." - -/** - * Max length of the UTF32 input buffer. Real memory consumption is 4 times higher. - */ -const MAX_PARSEBUFFER_LENGTH = 131072; - -/** - * Limit length of title and icon name stacks. - */ -const STACK_LIMIT = 10; - -// map params to window option -function paramToWindowOption(n: number, opts: IWindowOptions): boolean { - if (n > 24) { - return opts.setWinLines || false; - } - switch (n) { - case 1: return !!opts.restoreWin; - case 2: return !!opts.minimizeWin; - case 3: return !!opts.setWinPosition; - case 4: return !!opts.setWinSizePixels; - case 5: return !!opts.raiseWin; - case 6: return !!opts.lowerWin; - case 7: return !!opts.refreshWin; - case 8: return !!opts.setWinSizeChars; - case 9: return !!opts.maximizeWin; - case 10: return !!opts.fullscreenWin; - case 11: return !!opts.getWinState; - case 13: return !!opts.getWinPosition; - case 14: return !!opts.getWinSizePixels; - case 15: return !!opts.getScreenSizePixels; - case 16: return !!opts.getCellSizePixels; - case 18: return !!opts.getWinSizeChars; - case 19: return !!opts.getScreenSizeChars; - case 20: return !!opts.getIconTitle; - case 21: return !!opts.getWinTitle; - case 22: return !!opts.pushTitle; - case 23: return !!opts.popTitle; - case 24: return !!opts.setWinLines; - } - return false; -} - -export enum WindowsOptionsReportType { - GET_WIN_SIZE_PIXELS = 0, - GET_CELL_SIZE_PIXELS = 1 -} - -/** - * DCS subparser implementations - */ - -/** - * DCS $ q Pt ST - * DECRQSS (https://vt100.net/docs/vt510-rm/DECRQSS.html) - * Request Status String (DECRQSS), VT420 and up. - * Response: DECRPSS (https://vt100.net/docs/vt510-rm/DECRPSS.html) - * - * @vt: #P[See limited support below.] DCS DECRQSS "Request Selection or Setting" "DCS $ q Pt ST" "Request several terminal settings." - * Response is in the form `ESC P 1 $ r Pt ST` for valid requests, where `Pt` contains the corresponding CSI string, - * `ESC P 0 ST` for invalid requests. - * - * Supported requests and responses: - * - * | Type | Request | Response (`Pt`) | - * | -------------------------------- | ----------------- | ----------------------------------------------------- | - * | Graphic Rendition (SGR) | `DCS $ q m ST` | always reporting `0m` (currently broken) | - * | Top and Bottom Margins (DECSTBM) | `DCS $ q r ST` | `Ps ; Ps r` | - * | Cursor Style (DECSCUSR) | `DCS $ q SP q ST` | `Ps SP q` | - * | Protection Attribute (DECSCA) | `DCS $ q " q ST` | always reporting `0 " q` (DECSCA is unsupported) | - * | Conformance Level (DECSCL) | `DCS $ q " p ST` | always reporting `61 ; 1 " p` (DECSCL is unsupported) | - * - * - * TODO: - * - fix SGR report - * - either implement DECSCA or remove the report - * - either check which conformance is better suited or remove the report completely - * --> we are currently a mixture of all up to VT400 but dont follow anyone strictly - */ -class DECRQSS implements IDcsHandler { - private _data: Uint32Array = new Uint32Array(0); - - constructor( - private _bufferService: IBufferService, - private _coreService: ICoreService, - private _logService: ILogService, - private _optionsService: IOptionsService - ) { } - - public hook(params: IParams): void { - this._data = new Uint32Array(0); - } - - public put(data: Uint32Array, start: number, end: number): void { - this._data = concat(this._data, data.subarray(start, end)); - } - - public unhook(success: boolean): boolean { - if (!success) { - this._data = new Uint32Array(0); - return true; - } - const data = utf32ToString(this._data); - this._data = new Uint32Array(0); - switch (data) { - // valid: DCS 1 $ r Pt ST (xterm) - case '"q': // DECSCA - this._coreService.triggerDataEvent(`${C0.ESC}P1$r0"q${C0.ESC}\\`); - break; - case '"p': // DECSCL - this._coreService.triggerDataEvent(`${C0.ESC}P1$r61;1"p${C0.ESC}\\`); - break; - case 'r': // DECSTBM - const pt = '' + (this._bufferService.buffer.scrollTop + 1) + - ';' + (this._bufferService.buffer.scrollBottom + 1) + 'r'; - this._coreService.triggerDataEvent(`${C0.ESC}P1$r${pt}${C0.ESC}\\`); - break; - case 'm': // SGR - // TODO: report real settings instead of 0m - this._coreService.triggerDataEvent(`${C0.ESC}P1$r0m${C0.ESC}\\`); - break; - case ' q': // DECSCUSR - const STYLES: {[key: string]: number} = {'block': 2, 'underline': 4, 'bar': 6}; - let style = STYLES[this._optionsService.options.cursorStyle]; - style -= this._optionsService.options.cursorBlink ? 1 : 0; - this._coreService.triggerDataEvent(`${C0.ESC}P1$r${style} q${C0.ESC}\\`); - break; - default: - // invalid: DCS 0 $ r Pt ST (xterm) - this._logService.debug('Unknown DCS $q %s', data); - this._coreService.triggerDataEvent(`${C0.ESC}P0$r${C0.ESC}\\`); - } - return true; - } -} - -/** - * DCS Ps; Ps| Pt ST - * DECUDK (https://vt100.net/docs/vt510-rm/DECUDK.html) - * not supported - * - * @vt: #N DCS DECUDK "User Defined Keys" "DCS Ps ; Ps | Pt ST" "Definitions for user-defined keys." - */ - -/** - * DCS + q Pt ST (xterm) - * Request Terminfo String - * not implemented - * - * @vt: #N DCS XTGETTCAP "Request Terminfo String" "DCS + q Pt ST" "Request Terminfo String." - */ - -/** - * DCS + p Pt ST (xterm) - * Set Terminfo Data - * not supported - * - * @vt: #N DCS XTSETTCAP "Set Terminfo Data" "DCS + p Pt ST" "Set Terminfo Data." - */ - - - -/** - * The terminal's standard implementation of IInputHandler, this handles all - * input from the Parser. - * - * Refer to http://invisible-island.net/xterm/ctlseqs/ctlseqs.html to understand - * each function's header comment. - */ -export class InputHandler extends Disposable implements IInputHandler { - private _parseBuffer: Uint32Array = new Uint32Array(4096); - private _stringDecoder: StringToUtf32 = new StringToUtf32(); - private _utf8Decoder: Utf8ToUtf32 = new Utf8ToUtf32(); - private _workCell: CellData = new CellData(); - private _windowTitle = ''; - private _iconName = ''; - protected _windowTitleStack: string[] = []; - protected _iconNameStack: string[] = []; - - private _curAttrData: IAttributeData = DEFAULT_ATTR_DATA.clone(); - private _eraseAttrDataInternal: IAttributeData = DEFAULT_ATTR_DATA.clone(); - - private _onRequestBell = new EventEmitter(); - public get onRequestBell(): IEvent { return this._onRequestBell.event; } - private _onRequestRefreshRows = new EventEmitter(); - public get onRequestRefreshRows(): IEvent { return this._onRequestRefreshRows.event; } - private _onRequestReset = new EventEmitter(); - public get onRequestReset(): IEvent { return this._onRequestReset.event; } - private _onRequestScroll = new EventEmitter(); - public get onRequestScroll(): IEvent { return this._onRequestScroll.event; } - private _onRequestSyncScrollBar = new EventEmitter(); - public get onRequestSyncScrollBar(): IEvent { return this._onRequestSyncScrollBar.event; } - private _onRequestWindowsOptionsReport = new EventEmitter(); - public get onRequestWindowsOptionsReport(): IEvent { return this._onRequestWindowsOptionsReport.event; } - - private _onA11yChar = new EventEmitter(); - public get onA11yChar(): IEvent { return this._onA11yChar.event; } - private _onA11yTab = new EventEmitter(); - public get onA11yTab(): IEvent { return this._onA11yTab.event; } - private _onCursorMove = new EventEmitter(); - public get onCursorMove(): IEvent { return this._onCursorMove.event; } - private _onLineFeed = new EventEmitter(); - public get onLineFeed(): IEvent { return this._onLineFeed.event; } - private _onScroll = new EventEmitter(); - public get onScroll(): IEvent { return this._onScroll.event; } - private _onTitleChange = new EventEmitter(); - public get onTitleChange(): IEvent { return this._onTitleChange.event; } - private _onAnsiColorChange = new EventEmitter(); - public get onAnsiColorChange(): IEvent { return this._onAnsiColorChange.event; } - - constructor( - private readonly _bufferService: IBufferService, - private readonly _charsetService: ICharsetService, - private readonly _coreService: ICoreService, - private readonly _dirtyRowService: IDirtyRowService, - private readonly _logService: ILogService, - private readonly _optionsService: IOptionsService, - private readonly _coreMouseService: ICoreMouseService, - private readonly _unicodeService: IUnicodeService, - private readonly _parser: IEscapeSequenceParser = new EscapeSequenceParser() - ) { - super(); - this.register(this._parser); - - /** - * custom fallback handlers - */ - this._parser.setCsiHandlerFallback((ident, params) => { - this._logService.debug('Unknown CSI code: ', { identifier: this._parser.identToString(ident), params: params.toArray() }); - }); - this._parser.setEscHandlerFallback(ident => { - this._logService.debug('Unknown ESC code: ', { identifier: this._parser.identToString(ident) }); - }); - this._parser.setExecuteHandlerFallback(code => { - this._logService.debug('Unknown EXECUTE code: ', { code }); - }); - this._parser.setOscHandlerFallback((identifier, action, data) => { - this._logService.debug('Unknown OSC code: ', { identifier, action, data }); - }); - this._parser.setDcsHandlerFallback((ident, action, payload) => { - if (action === 'HOOK') { - payload = payload.toArray(); - } - this._logService.debug('Unknown DCS code: ', { identifier: this._parser.identToString(ident), action, payload }); - }); - - /** - * print handler - */ - this._parser.setPrintHandler((data, start, end) => this.print(data, start, end)); - - /** - * CSI handler - */ - this._parser.registerCsiHandler({final: '@'}, params => this.insertChars(params)); - this._parser.registerCsiHandler({intermediates: ' ', final: '@'}, params => this.scrollLeft(params)); - this._parser.registerCsiHandler({final: 'A'}, params => this.cursorUp(params)); - this._parser.registerCsiHandler({intermediates: ' ', final: 'A'}, params => this.scrollRight(params)); - this._parser.registerCsiHandler({final: 'B'}, params => this.cursorDown(params)); - this._parser.registerCsiHandler({final: 'C'}, params => this.cursorForward(params)); - this._parser.registerCsiHandler({final: 'D'}, params => this.cursorBackward(params)); - this._parser.registerCsiHandler({final: 'E'}, params => this.cursorNextLine(params)); - this._parser.registerCsiHandler({final: 'F'}, params => this.cursorPrecedingLine(params)); - this._parser.registerCsiHandler({final: 'G'}, params => this.cursorCharAbsolute(params)); - this._parser.registerCsiHandler({final: 'H'}, params => this.cursorPosition(params)); - this._parser.registerCsiHandler({final: 'I'}, params => this.cursorForwardTab(params)); - this._parser.registerCsiHandler({final: 'J'}, params => this.eraseInDisplay(params)); - this._parser.registerCsiHandler({prefix: '?', final: 'J'}, params => this.eraseInDisplay(params)); - this._parser.registerCsiHandler({final: 'K'}, params => this.eraseInLine(params)); - this._parser.registerCsiHandler({prefix: '?', final: 'K'}, params => this.eraseInLine(params)); - this._parser.registerCsiHandler({final: 'L'}, params => this.insertLines(params)); - this._parser.registerCsiHandler({final: 'M'}, params => this.deleteLines(params)); - this._parser.registerCsiHandler({final: 'P'}, params => this.deleteChars(params)); - this._parser.registerCsiHandler({final: 'S'}, params => this.scrollUp(params)); - this._parser.registerCsiHandler({final: 'T'}, params => this.scrollDown(params)); - this._parser.registerCsiHandler({final: 'X'}, params => this.eraseChars(params)); - this._parser.registerCsiHandler({final: 'Z'}, params => this.cursorBackwardTab(params)); - this._parser.registerCsiHandler({final: '`'}, params => this.charPosAbsolute(params)); - this._parser.registerCsiHandler({final: 'a'}, params => this.hPositionRelative(params)); - this._parser.registerCsiHandler({final: 'b'}, params => this.repeatPrecedingCharacter(params)); - this._parser.registerCsiHandler({final: 'c'}, params => this.sendDeviceAttributesPrimary(params)); - this._parser.registerCsiHandler({prefix: '>', final: 'c'}, params => this.sendDeviceAttributesSecondary(params)); - this._parser.registerCsiHandler({final: 'd'}, params => this.linePosAbsolute(params)); - this._parser.registerCsiHandler({final: 'e'}, params => this.vPositionRelative(params)); - this._parser.registerCsiHandler({final: 'f'}, params => this.hVPosition(params)); - this._parser.registerCsiHandler({final: 'g'}, params => this.tabClear(params)); - this._parser.registerCsiHandler({final: 'h'}, params => this.setMode(params)); - this._parser.registerCsiHandler({prefix: '?', final: 'h'}, params => this.setModePrivate(params)); - this._parser.registerCsiHandler({final: 'l'}, params => this.resetMode(params)); - this._parser.registerCsiHandler({prefix: '?', final: 'l'}, params => this.resetModePrivate(params)); - this._parser.registerCsiHandler({final: 'm'}, params => this.charAttributes(params)); - this._parser.registerCsiHandler({final: 'n'}, params => this.deviceStatus(params)); - this._parser.registerCsiHandler({prefix: '?', final: 'n'}, params => this.deviceStatusPrivate(params)); - this._parser.registerCsiHandler({intermediates: '!', final: 'p'}, params => this.softReset(params)); - this._parser.registerCsiHandler({intermediates: ' ', final: 'q'}, params => this.setCursorStyle(params)); - this._parser.registerCsiHandler({final: 'r'}, params => this.setScrollRegion(params)); - this._parser.registerCsiHandler({final: 's'}, params => this.saveCursor(params)); - this._parser.registerCsiHandler({final: 't'}, params => this.windowOptions(params)); - this._parser.registerCsiHandler({final: 'u'}, params => this.restoreCursor(params)); - this._parser.registerCsiHandler({intermediates: '\'', final: '}'}, params => this.insertColumns(params)); - this._parser.registerCsiHandler({intermediates: '\'', final: '~'}, params => this.deleteColumns(params)); - - /** - * execute handler - */ - this._parser.setExecuteHandler(C0.BEL, () => this.bell()); - this._parser.setExecuteHandler(C0.LF, () => this.lineFeed()); - this._parser.setExecuteHandler(C0.VT, () => this.lineFeed()); - this._parser.setExecuteHandler(C0.FF, () => this.lineFeed()); - this._parser.setExecuteHandler(C0.CR, () => this.carriageReturn()); - this._parser.setExecuteHandler(C0.BS, () => this.backspace()); - this._parser.setExecuteHandler(C0.HT, () => this.tab()); - this._parser.setExecuteHandler(C0.SO, () => this.shiftOut()); - this._parser.setExecuteHandler(C0.SI, () => this.shiftIn()); - // FIXME: What do to with missing? Old code just added those to print. - - this._parser.setExecuteHandler(C1.IND, () => this.index()); - this._parser.setExecuteHandler(C1.NEL, () => this.nextLine()); - this._parser.setExecuteHandler(C1.HTS, () => this.tabSet()); - - /** - * OSC handler - */ - // 0 - icon name + title - this._parser.registerOscHandler(0, new OscHandler(data => { this.setTitle(data); this.setIconName(data); return true; })); - // 1 - icon name - this._parser.registerOscHandler(1, new OscHandler(data => this.setIconName(data))); - // 2 - title - this._parser.registerOscHandler(2, new OscHandler(data => this.setTitle(data))); - // 3 - set property X in the form "prop=value" - // 4 - Change Color Number - this._parser.registerOscHandler(4, new OscHandler(data => this.setAnsiColor(data))); - // 5 - Change Special Color Number - // 6 - Enable/disable Special Color Number c - // 7 - current directory? (not in xterm spec, see https://gitlab.com/gnachman/iterm2/issues/3939) - // 10 - Change VT100 text foreground color to Pt. - // 11 - Change VT100 text background color to Pt. - // 12 - Change text cursor color to Pt. - // 13 - Change mouse foreground color to Pt. - // 14 - Change mouse background color to Pt. - // 15 - Change Tektronix foreground color to Pt. - // 16 - Change Tektronix background color to Pt. - // 17 - Change highlight background color to Pt. - // 18 - Change Tektronix cursor color to Pt. - // 19 - Change highlight foreground color to Pt. - // 46 - Change Log File to Pt. - // 50 - Set Font to Pt. - // 51 - reserved for Emacs shell. - // 52 - Manipulate Selection Data. - // 104 ; c - Reset Color Number c. - // 105 ; c - Reset Special Color Number c. - // 106 ; c; f - Enable/disable Special Color Number c. - // 110 - Reset VT100 text foreground color. - // 111 - Reset VT100 text background color. - // 112 - Reset text cursor color. - // 113 - Reset mouse foreground color. - // 114 - Reset mouse background color. - // 115 - Reset Tektronix foreground color. - // 116 - Reset Tektronix background color. - // 117 - Reset highlight color. - // 118 - Reset Tektronix cursor color. - // 119 - Reset highlight foreground color. - - /** - * ESC handlers - */ - this._parser.registerEscHandler({final: '7'}, () => this.saveCursor()); - this._parser.registerEscHandler({final: '8'}, () => this.restoreCursor()); - this._parser.registerEscHandler({final: 'D'}, () => this.index()); - this._parser.registerEscHandler({final: 'E'}, () => this.nextLine()); - this._parser.registerEscHandler({final: 'H'}, () => this.tabSet()); - this._parser.registerEscHandler({final: 'M'}, () => this.reverseIndex()); - this._parser.registerEscHandler({final: '='}, () => this.keypadApplicationMode()); - this._parser.registerEscHandler({final: '>'}, () => this.keypadNumericMode()); - this._parser.registerEscHandler({final: 'c'}, () => this.fullReset()); - this._parser.registerEscHandler({final: 'n'}, () => this.setgLevel(2)); - this._parser.registerEscHandler({final: 'o'}, () => this.setgLevel(3)); - this._parser.registerEscHandler({final: '|'}, () => this.setgLevel(3)); - this._parser.registerEscHandler({final: '}'}, () => this.setgLevel(2)); - this._parser.registerEscHandler({final: '~'}, () => this.setgLevel(1)); - this._parser.registerEscHandler({intermediates: '%', final: '@'}, () => this.selectDefaultCharset()); - this._parser.registerEscHandler({intermediates: '%', final: 'G'}, () => this.selectDefaultCharset()); - for (const flag in CHARSETS) { - this._parser.registerEscHandler({intermediates: '(', final: flag}, () => this.selectCharset('(' + flag)); - this._parser.registerEscHandler({intermediates: ')', final: flag}, () => this.selectCharset(')' + flag)); - this._parser.registerEscHandler({intermediates: '*', final: flag}, () => this.selectCharset('*' + flag)); - this._parser.registerEscHandler({intermediates: '+', final: flag}, () => this.selectCharset('+' + flag)); - this._parser.registerEscHandler({intermediates: '-', final: flag}, () => this.selectCharset('-' + flag)); - this._parser.registerEscHandler({intermediates: '.', final: flag}, () => this.selectCharset('.' + flag)); - this._parser.registerEscHandler({intermediates: '/', final: flag}, () => this.selectCharset('/' + flag)); // TODO: supported? - } - this._parser.registerEscHandler({intermediates: '#', final: '8'}, () => this.screenAlignmentPattern()); - - /** - * error handler - */ - this._parser.setErrorHandler((state: IParsingState) => { - this._logService.error('Parsing error: ', state); - return state; - }); - - /** - * DCS handler - */ - this._parser.registerDcsHandler({intermediates: '$', final: 'q'}, new DECRQSS(this._bufferService, this._coreService, this._logService, this._optionsService)); - } - - public dispose(): void { - super.dispose(); - } - - public parse(data: string | Uint8Array): void { - let buffer = this._bufferService.buffer; - const cursorStartX = buffer.x; - const cursorStartY = buffer.y; - - this._logService.debug('parsing data', data); - - // resize input buffer if needed - if (this._parseBuffer.length < data.length) { - if (this._parseBuffer.length < MAX_PARSEBUFFER_LENGTH) { - this._parseBuffer = new Uint32Array(Math.min(data.length, MAX_PARSEBUFFER_LENGTH)); - } - } - - // Clear the dirty row service so we know which lines changed as a result of parsing - this._dirtyRowService.clearRange(); - - // process big data in smaller chunks - if (data.length > MAX_PARSEBUFFER_LENGTH) { - for (let i = 0; i < data.length; i += MAX_PARSEBUFFER_LENGTH) { - const end = i + MAX_PARSEBUFFER_LENGTH < data.length ? i + MAX_PARSEBUFFER_LENGTH : data.length; - const len = (typeof data === 'string') - ? this._stringDecoder.decode(data.substring(i, end), this._parseBuffer) - : this._utf8Decoder.decode(data.subarray(i, end), this._parseBuffer); - this._parser.parse(this._parseBuffer, len); - } - } else { - const len = (typeof data === 'string') - ? this._stringDecoder.decode(data, this._parseBuffer) - : this._utf8Decoder.decode(data, this._parseBuffer); - this._parser.parse(this._parseBuffer, len); - } - - buffer = this._bufferService.buffer; - if (buffer.x !== cursorStartX || buffer.y !== cursorStartY) { - this._onCursorMove.fire(); - } - - // Refresh any dirty rows accumulated as part of parsing - this._onRequestRefreshRows.fire(this._dirtyRowService.start, this._dirtyRowService.end); - } - - public print(data: Uint32Array, start: number, end: number): void { - let code: number; - let chWidth: number; - const buffer = this._bufferService.buffer; - const charset = this._charsetService.charset; - const screenReaderMode = this._optionsService.options.screenReaderMode; - const cols = this._bufferService.cols; - const wraparoundMode = this._coreService.decPrivateModes.wraparound; - const insertMode = this._coreService.modes.insertMode; - const curAttr = this._curAttrData; - let bufferRow = buffer.lines.get(buffer.ybase + buffer.y)!; - - this._dirtyRowService.markDirty(buffer.y); - - // handle wide chars: reset start_cell-1 if we would overwrite the second cell of a wide char - if (buffer.x && end - start > 0 && bufferRow.getWidth(buffer.x - 1) === 2) { - bufferRow.setCellFromCodePoint(buffer.x - 1, 0, 1, curAttr.fg, curAttr.bg, curAttr.extended); - } - - for (let pos = start; pos < end; ++pos) { - code = data[pos]; - - // calculate print space - // expensive call, therefore we save width in line buffer - chWidth = this._unicodeService.wcwidth(code); - - // get charset replacement character - // charset is only defined for ASCII, therefore we only - // search for an replacement char if code < 127 - if (code < 127 && charset) { - const ch = charset[String.fromCharCode(code)]; - if (ch) { - code = ch.charCodeAt(0); - } - } - - if (screenReaderMode) { - this._onA11yChar.fire(stringFromCodePoint(code)); - } - - // insert combining char at last cursor position - // buffer.x should never be 0 for a combining char - // since they always follow a cell consuming char - // therefore we can test for buffer.x to avoid overflow left - if (!chWidth && buffer.x) { - if (!bufferRow.getWidth(buffer.x - 1)) { - // found empty cell after fullwidth, need to go 2 cells back - // it is save to step 2 cells back here - // since an empty cell is only set by fullwidth chars - bufferRow.addCodepointToCell(buffer.x - 2, code); - } else { - bufferRow.addCodepointToCell(buffer.x - 1, code); - } - continue; - } - - // goto next line if ch would overflow - // NOTE: To avoid costly width checks here, - // the terminal does not allow a cols < 2. - if (buffer.x + chWidth - 1 >= cols) { - // autowrap - DECAWM - // automatically wraps to the beginning of the next line - if (wraparoundMode) { - // clear left over cells to the right - while (buffer.x < cols) { - bufferRow.setCellFromCodePoint(buffer.x++, 0, 1, curAttr.fg, curAttr.bg, curAttr.extended); - } - buffer.x = 0; - buffer.y++; - if (buffer.y === buffer.scrollBottom + 1) { - buffer.y--; - this._onRequestScroll.fire(this._eraseAttrData(), true); - } else { - if (buffer.y >= this._bufferService.rows) { - buffer.y = this._bufferService.rows - 1; - } - // The line already exists (eg. the initial viewport), mark it as a - // wrapped line - buffer.lines.get(buffer.ybase + buffer.y)!.isWrapped = true; - } - // row changed, get it again - bufferRow = buffer.lines.get(buffer.ybase + buffer.y)!; - } else { - buffer.x = cols - 1; - if (chWidth === 2) { - // FIXME: check for xterm behavior - // What to do here? We got a wide char that does not fit into last cell - continue; - } - } - } - - // insert mode: move characters to right - if (insertMode) { - // right shift cells according to the width - bufferRow.insertCells(buffer.x, chWidth, buffer.getNullCell(curAttr), curAttr); - // test last cell - since the last cell has only room for - // a halfwidth char any fullwidth shifted there is lost - // and will be set to empty cell - if (bufferRow.getWidth(cols - 1) === 2) { - bufferRow.setCellFromCodePoint(cols - 1, NULL_CELL_CODE, NULL_CELL_WIDTH, curAttr.fg, curAttr.bg, curAttr.extended); - } - } - - // write current char to buffer and advance cursor - bufferRow.setCellFromCodePoint(buffer.x++, code, chWidth, curAttr.fg, curAttr.bg, curAttr.extended); - - // fullwidth char - also set next cell to placeholder stub and advance cursor - // for graphemes bigger than fullwidth we can simply loop to zero - // we already made sure above, that buffer.x + chWidth will not overflow right - if (chWidth > 0) { - while (--chWidth) { - // other than a regular empty cell a cell following a wide char has no width - bufferRow.setCellFromCodePoint(buffer.x++, 0, 0, curAttr.fg, curAttr.bg, curAttr.extended); - } - } - } - // store last char in Parser.precedingCodepoint for REP to work correctly - // This needs to check whether: - // - fullwidth + surrogates: reset - // - combining: only base char gets carried on (bug in xterm?) - if (end - start > 0) { - bufferRow.loadCell(buffer.x - 1, this._workCell); - if (this._workCell.getWidth() === 2 || this._workCell.getCode() > 0xFFFF) { - this._parser.precedingCodepoint = 0; - } else if (this._workCell.isCombined()) { - this._parser.precedingCodepoint = this._workCell.getChars().charCodeAt(0); - } else { - this._parser.precedingCodepoint = this._workCell.content; - } - } - - // handle wide chars: reset cell to the right if it is second cell of a wide char - if (buffer.x < cols && end - start > 0 && bufferRow.getWidth(buffer.x) === 0 && !bufferRow.hasContent(buffer.x)) { - bufferRow.setCellFromCodePoint(buffer.x, 0, 1, curAttr.fg, curAttr.bg, curAttr.extended); - } - - this._dirtyRowService.markDirty(buffer.y); - } - - /** - * Forward addCsiHandler from parser. - */ - public addCsiHandler(id: IFunctionIdentifier, callback: (params: IParams) => boolean): IDisposable { - if (id.final === 't' && !id.prefix && !id.intermediates) { - // security: always check whether window option is allowed - return this._parser.registerCsiHandler(id, params => { - if (!paramToWindowOption(params.params[0], this._optionsService.options.windowOptions)) { - return true; - } - return callback(params); - }); - } - return this._parser.registerCsiHandler(id, callback); - } - - /** - * Forward addDcsHandler from parser. - */ - public addDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: IParams) => boolean): IDisposable { - return this._parser.registerDcsHandler(id, new DcsHandler(callback)); - } - - /** - * Forward addEscHandler from parser. - */ - public addEscHandler(id: IFunctionIdentifier, callback: () => boolean): IDisposable { - return this._parser.registerEscHandler(id, callback); - } - - /** - * Forward addOscHandler from parser. - */ - public addOscHandler(ident: number, callback: (data: string) => boolean): IDisposable { - return this._parser.registerOscHandler(ident, new OscHandler(callback)); - } - - /** - * BEL - * Bell (Ctrl-G). - * - * @vt: #Y C0 BEL "Bell" "\a, \x07" "Ring the bell." - * The behavior of the bell is further customizable with `ITerminalOptions.bellStyle` - * and `ITerminalOptions.bellSound`. - */ - public bell(): boolean { - this._onRequestBell.fire(); - return true; - } - - /** - * LF - * Line Feed or New Line (NL). (LF is Ctrl-J). - * - * @vt: #Y C0 LF "Line Feed" "\n, \x0A" "Move the cursor one row down, scrolling if needed." - * Scrolling is restricted to scroll margins and will only happen on the bottom line. - * - * @vt: #Y C0 VT "Vertical Tabulation" "\v, \x0B" "Treated as LF." - * @vt: #Y C0 FF "Form Feed" "\f, \x0C" "Treated as LF." - */ - public lineFeed(): boolean { - // make buffer local for faster access - const buffer = this._bufferService.buffer; - - this._dirtyRowService.markDirty(buffer.y); - if (this._optionsService.options.convertEol) { - buffer.x = 0; - } - buffer.y++; - if (buffer.y === buffer.scrollBottom + 1) { - buffer.y--; - this._onRequestScroll.fire(this._eraseAttrData()); - } else if (buffer.y >= this._bufferService.rows) { - buffer.y = this._bufferService.rows - 1; - } - // If the end of the line is hit, prevent this action from wrapping around to the next line. - if (buffer.x >= this._bufferService.cols) { - buffer.x--; - } - this._dirtyRowService.markDirty(buffer.y); - - this._onLineFeed.fire(); - return true; - } - - /** - * CR - * Carriage Return (Ctrl-M). - * - * @vt: #Y C0 CR "Carriage Return" "\r, \x0D" "Move the cursor to the beginning of the row." - */ - public carriageReturn(): boolean { - this._bufferService.buffer.x = 0; - return true; - } - - /** - * BS - * Backspace (Ctrl-H). - * - * @vt: #Y C0 BS "Backspace" "\b, \x08" "Move the cursor one position to the left." - * By default it is not possible to move the cursor past the leftmost position. - * If `reverse wrap-around` (`CSI ? 45 h`) is set, a previous soft line wrap (DECAWM) - * can be undone with BS within the scroll margins. In that case the cursor will wrap back - * to the end of the previous row. Note that it is not possible to peek back into the scrollbuffer - * with the cursor, thus at the home position (top-leftmost cell) this has no effect. - */ - public backspace(): boolean { - const buffer = this._bufferService.buffer; - - // reverse wrap-around is disabled - if (!this._coreService.decPrivateModes.reverseWraparound) { - this._restrictCursor(); - if (buffer.x > 0) { - buffer.x--; - } - return true; - } - - // reverse wrap-around is enabled - // other than for normal operation mode, reverse wrap-around allows the cursor - // to be at x=cols to be able to address the last cell of a row by BS - this._restrictCursor(this._bufferService.cols); - - if (buffer.x > 0) { - buffer.x--; - } else { - /** - * reverse wrap-around handling: - * Our implementation deviates from xterm on purpose. Details: - * - only previous soft NLs can be reversed (isWrapped=true) - * - only works within scrollborders (top/bottom, left/right not yet supported) - * - cannot peek into scrollbuffer - * - any cursor movement sequence keeps working as expected - */ - if (buffer.x === 0 - && buffer.y > buffer.scrollTop - && buffer.y <= buffer.scrollBottom - && buffer.lines.get(buffer.ybase + buffer.y)?.isWrapped) - { - buffer.lines.get(buffer.ybase + buffer.y)!.isWrapped = false; - buffer.y--; - buffer.x = this._bufferService.cols - 1; - // find last taken cell - last cell can have 3 different states: - // - hasContent(true) + hasWidth(1): narrow char - we are done - // - hasWidth(0): second part of wide char - we are done - // - hasContent(false) + hasWidth(1): empty cell due to early wrapping wide char, go one cell further back - const line = buffer.lines.get(buffer.ybase + buffer.y)!; - if (line.hasWidth(buffer.x) && !line.hasContent(buffer.x)) { - buffer.x--; - // We do this only once, since width=1 + hasContent=false currently happens only once before - // early wrapping of a wide char. - // This needs to be fixed once we support graphemes taking more than 2 cells. - } - } - } - this._restrictCursor(); - return true; - } - - /** - * TAB - * Horizontal Tab (HT) (Ctrl-I). - * - * @vt: #Y C0 HT "Horizontal Tabulation" "\t, \x09" "Move the cursor to the next character tab stop." - */ - public tab(): boolean { - if (this._bufferService.buffer.x >= this._bufferService.cols) { - return true; - } - const originalX = this._bufferService.buffer.x; - this._bufferService.buffer.x = this._bufferService.buffer.nextStop(); - if (this._optionsService.options.screenReaderMode) { - this._onA11yTab.fire(this._bufferService.buffer.x - originalX); - } - return true; - } - - /** - * SO - * Shift Out (Ctrl-N) -> Switch to Alternate Character Set. This invokes the - * G1 character set. - * - * @vt: #P[Only limited ISO-2022 charset support.] C0 SO "Shift Out" "\x0E" "Switch to an alternative character set." - */ - public shiftOut(): boolean { - this._charsetService.setgLevel(1); - return true; - } - - /** - * SI - * Shift In (Ctrl-O) -> Switch to Standard Character Set. This invokes the G0 - * character set (the default). - * - * @vt: #Y C0 SI "Shift In" "\x0F" "Return to regular character set after Shift Out." - */ - public shiftIn(): boolean { - this._charsetService.setgLevel(0); - return true; - } - - /** - * Restrict cursor to viewport size / scroll margin (origin mode). - */ - private _restrictCursor(maxCol: number = this._bufferService.cols - 1): void { - this._bufferService.buffer.x = Math.min(maxCol, Math.max(0, this._bufferService.buffer.x)); - this._bufferService.buffer.y = this._coreService.decPrivateModes.origin - ? Math.min(this._bufferService.buffer.scrollBottom, Math.max(this._bufferService.buffer.scrollTop, this._bufferService.buffer.y)) - : Math.min(this._bufferService.rows - 1, Math.max(0, this._bufferService.buffer.y)); - this._dirtyRowService.markDirty(this._bufferService.buffer.y); - } - - /** - * Set absolute cursor position. - */ - private _setCursor(x: number, y: number): void { - this._dirtyRowService.markDirty(this._bufferService.buffer.y); - if (this._coreService.decPrivateModes.origin) { - this._bufferService.buffer.x = x; - this._bufferService.buffer.y = this._bufferService.buffer.scrollTop + y; - } else { - this._bufferService.buffer.x = x; - this._bufferService.buffer.y = y; - } - this._restrictCursor(); - this._dirtyRowService.markDirty(this._bufferService.buffer.y); - } - - /** - * Set relative cursor position. - */ - private _moveCursor(x: number, y: number): void { - // for relative changes we have to make sure we are within 0 .. cols/rows - 1 - // before calculating the new position - this._restrictCursor(); - this._setCursor(this._bufferService.buffer.x + x, this._bufferService.buffer.y + y); - } - - /** - * CSI Ps A - * Cursor Up Ps Times (default = 1) (CUU). - * - * @vt: #Y CSI CUU "Cursor Up" "CSI Ps A" "Move cursor `Ps` times up (default=1)." - * If the cursor would pass the top scroll margin, it will stop there. - */ - public cursorUp(params: IParams): boolean { - // stop at scrollTop - const diffToTop = this._bufferService.buffer.y - this._bufferService.buffer.scrollTop; - if (diffToTop >= 0) { - this._moveCursor(0, -Math.min(diffToTop, params.params[0] || 1)); - } else { - this._moveCursor(0, -(params.params[0] || 1)); - } - return true; - } - - /** - * CSI Ps B - * Cursor Down Ps Times (default = 1) (CUD). - * - * @vt: #Y CSI CUD "Cursor Down" "CSI Ps B" "Move cursor `Ps` times down (default=1)." - * If the cursor would pass the bottom scroll margin, it will stop there. - */ - public cursorDown(params: IParams): boolean { - // stop at scrollBottom - const diffToBottom = this._bufferService.buffer.scrollBottom - this._bufferService.buffer.y; - if (diffToBottom >= 0) { - this._moveCursor(0, Math.min(diffToBottom, params.params[0] || 1)); - } else { - this._moveCursor(0, params.params[0] || 1); - } - return true; - } - - /** - * CSI Ps C - * Cursor Forward Ps Times (default = 1) (CUF). - * - * @vt: #Y CSI CUF "Cursor Forward" "CSI Ps C" "Move cursor `Ps` times forward (default=1)." - */ - public cursorForward(params: IParams): boolean { - this._moveCursor(params.params[0] || 1, 0); - return true; - } - - /** - * CSI Ps D - * Cursor Backward Ps Times (default = 1) (CUB). - * - * @vt: #Y CSI CUB "Cursor Backward" "CSI Ps D" "Move cursor `Ps` times backward (default=1)." - */ - public cursorBackward(params: IParams): boolean { - this._moveCursor(-(params.params[0] || 1), 0); - return true; - } - - /** - * CSI Ps E - * Cursor Next Line Ps Times (default = 1) (CNL). - * Other than cursorDown (CUD) also set the cursor to first column. - * - * @vt: #Y CSI CNL "Cursor Next Line" "CSI Ps E" "Move cursor `Ps` times down (default=1) and to the first column." - * Same as CUD, additionally places the cursor at the first column. - */ - public cursorNextLine(params: IParams): boolean { - this.cursorDown(params); - this._bufferService.buffer.x = 0; - return true; - } - - /** - * CSI Ps F - * Cursor Previous Line Ps Times (default = 1) (CPL). - * Other than cursorUp (CUU) also set the cursor to first column. - * - * @vt: #Y CSI CPL "Cursor Backward" "CSI Ps F" "Move cursor `Ps` times up (default=1) and to the first column." - * Same as CUU, additionally places the cursor at the first column. - */ - public cursorPrecedingLine(params: IParams): boolean { - this.cursorUp(params); - this._bufferService.buffer.x = 0; - return true; - } - - /** - * CSI Ps G - * Cursor Character Absolute [column] (default = [row,1]) (CHA). - * - * @vt: #Y CSI CHA "Cursor Horizontal Absolute" "CSI Ps G" "Move cursor to `Ps`-th column of the active row (default=1)." - */ - public cursorCharAbsolute(params: IParams): boolean { - this._setCursor((params.params[0] || 1) - 1, this._bufferService.buffer.y); - return true; - } - - /** - * CSI Ps ; Ps H - * Cursor Position [row;column] (default = [1,1]) (CUP). - * - * @vt: #Y CSI CUP "Cursor Position" "CSI Ps ; Ps H" "Set cursor to position [`Ps`, `Ps`] (default = [1, 1])." - * If ORIGIN mode is set, places the cursor to the absolute position within the scroll margins. - * If ORIGIN mode is not set, places the cursor to the absolute position within the viewport. - * Note that the coordinates are 1-based, thus the top left position starts at `1 ; 1`. - */ - public cursorPosition(params: IParams): boolean { - this._setCursor( - // col - (params.length >= 2) ? (params.params[1] || 1) - 1 : 0, - // row - (params.params[0] || 1) - 1 - ); - return true; - } - - /** - * CSI Pm ` Character Position Absolute - * [column] (default = [row,1]) (HPA). - * Currently same functionality as CHA. - * - * @vt: #Y CSI HPA "Horizontal Position Absolute" "CSI Ps ` " "Same as CHA." - */ - public charPosAbsolute(params: IParams): boolean { - this._setCursor((params.params[0] || 1) - 1, this._bufferService.buffer.y); - return true; - } - - /** - * CSI Pm a Character Position Relative - * [columns] (default = [row,col+1]) (HPR) - * - * @vt: #Y CSI HPR "Horizontal Position Relative" "CSI Ps a" "Same as CUF." - */ - public hPositionRelative(params: IParams): boolean { - this._moveCursor(params.params[0] || 1, 0); - return true; - } - - /** - * CSI Pm d Vertical Position Absolute (VPA) - * [row] (default = [1,column]) - * - * @vt: #Y CSI VPA "Vertical Position Absolute" "CSI Ps d" "Move cursor to `Ps`-th row (default=1)." - */ - public linePosAbsolute(params: IParams): boolean { - this._setCursor(this._bufferService.buffer.x, (params.params[0] || 1) - 1); - return true; - } - - /** - * CSI Pm e Vertical Position Relative (VPR) - * [rows] (default = [row+1,column]) - * reuse CSI Ps B ? - * - * @vt: #Y CSI VPR "Vertical Position Relative" "CSI Ps e" "Move cursor `Ps` times down (default=1)." - */ - public vPositionRelative(params: IParams): boolean { - this._moveCursor(0, params.params[0] || 1); - return true; - } - - /** - * CSI Ps ; Ps f - * Horizontal and Vertical Position [row;column] (default = - * [1,1]) (HVP). - * Same as CUP. - * - * @vt: #Y CSI HVP "Horizontal and Vertical Position" "CSI Ps ; Ps f" "Same as CUP." - */ - public hVPosition(params: IParams): boolean { - this.cursorPosition(params); - return true; - } - - /** - * CSI Ps g Tab Clear (TBC). - * Ps = 0 -> Clear Current Column (default). - * Ps = 3 -> Clear All. - * Potentially: - * Ps = 2 -> Clear Stops on Line. - * http://vt100.net/annarbor/aaa-ug/section6.html - * - * @vt: #Y CSI TBC "Tab Clear" "CSI Ps g" "Clear tab stops at current position (0) or all (3) (default=0)." - * Clearing tabstops off the active row (Ps = 2, VT100) is currently not supported. - */ - public tabClear(params: IParams): boolean { - const param = params.params[0]; - if (param === 0) { - delete this._bufferService.buffer.tabs[this._bufferService.buffer.x]; - } else if (param === 3) { - this._bufferService.buffer.tabs = {}; - } - return true; - } - - /** - * CSI Ps I - * Cursor Forward Tabulation Ps tab stops (default = 1) (CHT). - * - * @vt: #Y CSI CHT "Cursor Horizontal Tabulation" "CSI Ps I" "Move cursor `Ps` times tabs forward (default=1)." - */ - public cursorForwardTab(params: IParams): boolean { - if (this._bufferService.buffer.x >= this._bufferService.cols) { - return true; - } - let param = params.params[0] || 1; - while (param--) { - this._bufferService.buffer.x = this._bufferService.buffer.nextStop(); - } - return true; - } - - /** - * CSI Ps Z Cursor Backward Tabulation Ps tab stops (default = 1) (CBT). - * - * @vt: #Y CSI CBT "Cursor Backward Tabulation" "CSI Ps Z" "Move cursor `Ps` tabs backward (default=1)." - */ - public cursorBackwardTab(params: IParams): boolean { - if (this._bufferService.buffer.x >= this._bufferService.cols) { - return true; - } - let param = params.params[0] || 1; - - // make buffer local for faster access - const buffer = this._bufferService.buffer; - - while (param--) { - buffer.x = buffer.prevStop(); - } - return true; - } - - - /** - * Helper method to erase cells in a terminal row. - * The cell gets replaced with the eraseChar of the terminal. - * @param y row index - * @param start first cell index to be erased - * @param end end - 1 is last erased cell - */ - private _eraseInBufferLine(y: number, start: number, end: number, clearWrap: boolean = false): void { - const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + y)!; - line.replaceCells( - start, - end, - this._bufferService.buffer.getNullCell(this._eraseAttrData()), - this._eraseAttrData() - ); - if (clearWrap) { - line.isWrapped = false; - } - } - - /** - * Helper method to reset cells in a terminal row. - * The cell gets replaced with the eraseChar of the terminal and the isWrapped property is set to false. - * @param y row index - */ - private _resetBufferLine(y: number): void { - const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + y)!; - line.fill(this._bufferService.buffer.getNullCell(this._eraseAttrData())); - line.isWrapped = false; - } - - /** - * CSI Ps J Erase in Display (ED). - * Ps = 0 -> Erase Below (default). - * Ps = 1 -> Erase Above. - * Ps = 2 -> Erase All. - * Ps = 3 -> Erase Saved Lines (xterm). - * CSI ? Ps J - * Erase in Display (DECSED). - * Ps = 0 -> Selective Erase Below (default). - * Ps = 1 -> Selective Erase Above. - * Ps = 2 -> Selective Erase All. - * - * @vt: #Y CSI ED "Erase In Display" "CSI Ps J" "Erase various parts of the viewport." - * Supported param values: - * - * | Ps | Effect | - * | -- | ------------------------------------------------------------ | - * | 0 | Erase from the cursor through the end of the viewport. | - * | 1 | Erase from the beginning of the viewport through the cursor. | - * | 2 | Erase complete viewport. | - * | 3 | Erase scrollback. | - * - * @vt: #P[Protection attributes are not supported.] CSI DECSED "Selective Erase In Display" "CSI ? Ps J" "Currently the same as ED." - */ - public eraseInDisplay(params: IParams): boolean { - this._restrictCursor(); - let j; - switch (params.params[0]) { - case 0: - j = this._bufferService.buffer.y; - this._dirtyRowService.markDirty(j); - this._eraseInBufferLine(j++, this._bufferService.buffer.x, this._bufferService.cols, this._bufferService.buffer.x === 0); - for (; j < this._bufferService.rows; j++) { - this._resetBufferLine(j); - } - this._dirtyRowService.markDirty(j); - break; - case 1: - j = this._bufferService.buffer.y; - this._dirtyRowService.markDirty(j); - // Deleted front part of line and everything before. This line will no longer be wrapped. - this._eraseInBufferLine(j, 0, this._bufferService.buffer.x + 1, true); - if (this._bufferService.buffer.x + 1 >= this._bufferService.cols) { - // Deleted entire previous line. This next line can no longer be wrapped. - this._bufferService.buffer.lines.get(j + 1)!.isWrapped = false; - } - while (j--) { - this._resetBufferLine(j); - } - this._dirtyRowService.markDirty(0); - break; - case 2: - j = this._bufferService.rows; - this._dirtyRowService.markDirty(j - 1); - while (j--) { - this._resetBufferLine(j); - } - this._dirtyRowService.markDirty(0); - break; - case 3: - // Clear scrollback (everything not in viewport) - const scrollBackSize = this._bufferService.buffer.lines.length - this._bufferService.rows; - if (scrollBackSize > 0) { - this._bufferService.buffer.lines.trimStart(scrollBackSize); - this._bufferService.buffer.ybase = Math.max(this._bufferService.buffer.ybase - scrollBackSize, 0); - this._bufferService.buffer.ydisp = Math.max(this._bufferService.buffer.ydisp - scrollBackSize, 0); - // Force a scroll event to refresh viewport - this._onScroll.fire(0); - } - break; - } - return true; - } - - /** - * CSI Ps K Erase in Line (EL). - * Ps = 0 -> Erase to Right (default). - * Ps = 1 -> Erase to Left. - * Ps = 2 -> Erase All. - * CSI ? Ps K - * Erase in Line (DECSEL). - * Ps = 0 -> Selective Erase to Right (default). - * Ps = 1 -> Selective Erase to Left. - * Ps = 2 -> Selective Erase All. - * - * @vt: #Y CSI EL "Erase In Line" "CSI Ps K" "Erase various parts of the active row." - * Supported param values: - * - * | Ps | Effect | - * | -- | -------------------------------------------------------- | - * | 0 | Erase from the cursor through the end of the row. | - * | 1 | Erase from the beginning of the line through the cursor. | - * | 2 | Erase complete line. | - * - * @vt: #P[Protection attributes are not supported.] CSI DECSEL "Selective Erase In Line" "CSI ? Ps K" "Currently the same as EL." - */ - public eraseInLine(params: IParams): boolean { - this._restrictCursor(); - switch (params.params[0]) { - case 0: - this._eraseInBufferLine(this._bufferService.buffer.y, this._bufferService.buffer.x, this._bufferService.cols); - break; - case 1: - this._eraseInBufferLine(this._bufferService.buffer.y, 0, this._bufferService.buffer.x + 1); - break; - case 2: - this._eraseInBufferLine(this._bufferService.buffer.y, 0, this._bufferService.cols); - break; - } - this._dirtyRowService.markDirty(this._bufferService.buffer.y); - return true; - } - - /** - * CSI Ps L - * Insert Ps Line(s) (default = 1) (IL). - * - * @vt: #Y CSI IL "Insert Line" "CSI Ps L" "Insert `Ps` blank lines at active row (default=1)." - * For every inserted line at the scroll top one line at the scroll bottom gets removed. - * The cursor is set to the first column. - * IL has no effect if the cursor is outside the scroll margins. - */ - public insertLines(params: IParams): boolean { - this._restrictCursor(); - let param = params.params[0] || 1; - - // make buffer local for faster access - const buffer = this._bufferService.buffer; - - if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) { - return true; - } - - const row: number = buffer.ybase + buffer.y; - - const scrollBottomRowsOffset = this._bufferService.rows - 1 - buffer.scrollBottom; - const scrollBottomAbsolute = this._bufferService.rows - 1 + buffer.ybase - scrollBottomRowsOffset + 1; - while (param--) { - // test: echo -e '\e[44m\e[1L\e[0m' - // blankLine(true) - xterm/linux behavior - buffer.lines.splice(scrollBottomAbsolute - 1, 1); - buffer.lines.splice(row, 0, buffer.getBlankLine(this._eraseAttrData())); - } - - this._dirtyRowService.markRangeDirty(buffer.y, buffer.scrollBottom); - buffer.x = 0; // see https://vt100.net/docs/vt220-rm/chapter4.html - vt220 only? - return true; - } - - /** - * CSI Ps M - * Delete Ps Line(s) (default = 1) (DL). - * - * @vt: #Y CSI DL "Delete Line" "CSI Ps M" "Delete `Ps` lines at active row (default=1)." - * For every deleted line at the scroll top one blank line at the scroll bottom gets appended. - * The cursor is set to the first column. - * DL has no effect if the cursor is outside the scroll margins. - */ - public deleteLines(params: IParams): boolean { - this._restrictCursor(); - let param = params.params[0] || 1; - - // make buffer local for faster access - const buffer = this._bufferService.buffer; - - if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) { - return true; - } - - const row: number = buffer.ybase + buffer.y; - - let j: number; - j = this._bufferService.rows - 1 - buffer.scrollBottom; - j = this._bufferService.rows - 1 + buffer.ybase - j; - while (param--) { - // test: echo -e '\e[44m\e[1M\e[0m' - // blankLine(true) - xterm/linux behavior - buffer.lines.splice(row, 1); - buffer.lines.splice(j, 0, buffer.getBlankLine(this._eraseAttrData())); - } - - this._dirtyRowService.markRangeDirty(buffer.y, buffer.scrollBottom); - buffer.x = 0; // see https://vt100.net/docs/vt220-rm/chapter4.html - vt220 only? - return true; - } - - /** - * CSI Ps @ - * Insert Ps (Blank) Character(s) (default = 1) (ICH). - * - * @vt: #Y CSI ICH "Insert Characters" "CSI Ps @" "Insert `Ps` (blank) characters (default = 1)." - * The ICH sequence inserts `Ps` blank characters. The cursor remains at the beginning of the blank characters. - * Text between the cursor and right margin moves to the right. Characters moved past the right margin are lost. - * - * - * FIXME: check against xterm - should not work outside of scroll margins (see VT520 manual) - */ - public insertChars(params: IParams): boolean { - this._restrictCursor(); - const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + this._bufferService.buffer.y); - if (line) { - line.insertCells( - this._bufferService.buffer.x, - params.params[0] || 1, - this._bufferService.buffer.getNullCell(this._eraseAttrData()), - this._eraseAttrData() - ); - this._dirtyRowService.markDirty(this._bufferService.buffer.y); - } - return true; - } - - /** - * CSI Ps P - * Delete Ps Character(s) (default = 1) (DCH). - * - * @vt: #Y CSI DCH "Delete Character" "CSI Ps P" "Delete `Ps` characters (default=1)." - * As characters are deleted, the remaining characters between the cursor and right margin move to the left. - * Character attributes move with the characters. The terminal adds blank characters at the right margin. - * - * - * FIXME: check against xterm - should not work outside of scroll margins (see VT520 manual) - */ - public deleteChars(params: IParams): boolean { - this._restrictCursor(); - const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + this._bufferService.buffer.y); - if (line) { - line.deleteCells( - this._bufferService.buffer.x, - params.params[0] || 1, - this._bufferService.buffer.getNullCell(this._eraseAttrData()), - this._eraseAttrData() - ); - this._dirtyRowService.markDirty(this._bufferService.buffer.y); - } - return true; - } - - /** - * CSI Ps S Scroll up Ps lines (default = 1) (SU). - * - * @vt: #Y CSI SU "Scroll Up" "CSI Ps S" "Scroll `Ps` lines up (default=1)." - * - * - * FIXME: scrolled out lines at top = 1 should add to scrollback (xterm) - */ - public scrollUp(params: IParams): boolean { - let param = params.params[0] || 1; - - // make buffer local for faster access - const buffer = this._bufferService.buffer; - - while (param--) { - buffer.lines.splice(buffer.ybase + buffer.scrollTop, 1); - buffer.lines.splice(buffer.ybase + buffer.scrollBottom, 0, buffer.getBlankLine(this._eraseAttrData())); - } - this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom); - return true; - } - - /** - * CSI Ps T Scroll down Ps lines (default = 1) (SD). - * - * @vt: #Y CSI SD "Scroll Down" "CSI Ps T" "Scroll `Ps` lines down (default=1)." - */ - public scrollDown(params: IParams): boolean { - let param = params.params[0] || 1; - - // make buffer local for faster access - const buffer = this._bufferService.buffer; - - while (param--) { - buffer.lines.splice(buffer.ybase + buffer.scrollBottom, 1); - buffer.lines.splice(buffer.ybase + buffer.scrollTop, 0, buffer.getBlankLine(DEFAULT_ATTR_DATA)); - } - this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom); - return true; - } - - /** - * CSI Ps SP @ Scroll left Ps columns (default = 1) (SL) ECMA-48 - * - * Notation: (Pn) - * Representation: CSI Pn 02/00 04/00 - * Parameter default value: Pn = 1 - * SL causes the data in the presentation component to be moved by n character positions - * if the line orientation is horizontal, or by n line positions if the line orientation - * is vertical, such that the data appear to move to the left; where n equals the value of Pn. - * The active presentation position is not affected by this control function. - * - * Supported: - * - always left shift (no line orientation setting respected) - * - * @vt: #Y CSI SL "Scroll Left" "CSI Ps SP @" "Scroll viewport `Ps` times to the left." - * SL moves the content of all lines within the scroll margins `Ps` times to the left. - * SL has no effect outside of the scroll margins. - */ - public scrollLeft(params: IParams): boolean { - const buffer = this._bufferService.buffer; - if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) { - return true; - } - const param = params.params[0] || 1; - for (let y = buffer.scrollTop; y <= buffer.scrollBottom; ++y) { - const line = buffer.lines.get(buffer.ybase + y)!; - line.deleteCells(0, param, buffer.getNullCell(this._eraseAttrData()), this._eraseAttrData()); - line.isWrapped = false; - } - this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom); - return true; - } - - /** - * CSI Ps SP A Scroll right Ps columns (default = 1) (SR) ECMA-48 - * - * Notation: (Pn) - * Representation: CSI Pn 02/00 04/01 - * Parameter default value: Pn = 1 - * SR causes the data in the presentation component to be moved by n character positions - * if the line orientation is horizontal, or by n line positions if the line orientation - * is vertical, such that the data appear to move to the right; where n equals the value of Pn. - * The active presentation position is not affected by this control function. - * - * Supported: - * - always right shift (no line orientation setting respected) - * - * @vt: #Y CSI SR "Scroll Right" "CSI Ps SP A" "Scroll viewport `Ps` times to the right." - * SL moves the content of all lines within the scroll margins `Ps` times to the right. - * Content at the right margin is lost. - * SL has no effect outside of the scroll margins. - */ - public scrollRight(params: IParams): boolean { - const buffer = this._bufferService.buffer; - if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) { - return true; - } - const param = params.params[0] || 1; - for (let y = buffer.scrollTop; y <= buffer.scrollBottom; ++y) { - const line = buffer.lines.get(buffer.ybase + y)!; - line.insertCells(0, param, buffer.getNullCell(this._eraseAttrData()), this._eraseAttrData()); - line.isWrapped = false; - } - this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom); - return true; - } - - /** - * CSI Pm ' } - * Insert Ps Column(s) (default = 1) (DECIC), VT420 and up. - * - * @vt: #Y CSI DECIC "Insert Columns" "CSI Ps ' }" "Insert `Ps` columns at cursor position." - * DECIC inserts `Ps` times blank columns at the cursor position for all lines with the scroll margins, - * moving content to the right. Content at the right margin is lost. - * DECIC has no effect outside the scrolling margins. - */ - public insertColumns(params: IParams): boolean { - const buffer = this._bufferService.buffer; - if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) { - return true; - } - const param = params.params[0] || 1; - for (let y = buffer.scrollTop; y <= buffer.scrollBottom; ++y) { - const line = this._bufferService.buffer.lines.get(buffer.ybase + y)!; - line.insertCells(buffer.x, param, buffer.getNullCell(this._eraseAttrData()), this._eraseAttrData()); - line.isWrapped = false; - } - this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom); - return true; - } - - /** - * CSI Pm ' ~ - * Delete Ps Column(s) (default = 1) (DECDC), VT420 and up. - * - * @vt: #Y CSI DECDC "Delete Columns" "CSI Ps ' ~" "Delete `Ps` columns at cursor position." - * DECDC deletes `Ps` times columns at the cursor position for all lines with the scroll margins, - * moving content to the left. Blank columns are added at the right margin. - * DECDC has no effect outside the scrolling margins. - */ - public deleteColumns(params: IParams): boolean { - const buffer = this._bufferService.buffer; - if (buffer.y > buffer.scrollBottom || buffer.y < buffer.scrollTop) { - return true; - } - const param = params.params[0] || 1; - for (let y = buffer.scrollTop; y <= buffer.scrollBottom; ++y) { - const line = buffer.lines.get(buffer.ybase + y)!; - line.deleteCells(buffer.x, param, buffer.getNullCell(this._eraseAttrData()), this._eraseAttrData()); - line.isWrapped = false; - } - this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom); - return true; - } - - /** - * CSI Ps X - * Erase Ps Character(s) (default = 1) (ECH). - * - * @vt: #Y CSI ECH "Erase Character" "CSI Ps X" "Erase `Ps` characters from current cursor position to the right (default=1)." - * ED erases `Ps` characters from current cursor position to the right. - * ED works inside or outside the scrolling margins. - */ - public eraseChars(params: IParams): boolean { - this._restrictCursor(); - const line = this._bufferService.buffer.lines.get(this._bufferService.buffer.ybase + this._bufferService.buffer.y); - if (line) { - line.replaceCells( - this._bufferService.buffer.x, - this._bufferService.buffer.x + (params.params[0] || 1), - this._bufferService.buffer.getNullCell(this._eraseAttrData()), - this._eraseAttrData() - ); - this._dirtyRowService.markDirty(this._bufferService.buffer.y); - } - return true; - } - - /** - * CSI Ps b Repeat the preceding graphic character Ps times (REP). - * From ECMA 48 (@see http://www.ecma-international.org/publications/files/ECMA-ST/Ecma-048.pdf) - * Notation: (Pn) - * Representation: CSI Pn 06/02 - * Parameter default value: Pn = 1 - * REP is used to indicate that the preceding character in the data stream, - * if it is a graphic character (represented by one or more bit combinations) including SPACE, - * is to be repeated n times, where n equals the value of Pn. - * If the character preceding REP is a control function or part of a control function, - * the effect of REP is not defined by this Standard. - * - * Since we propagate the terminal as xterm-256color we have to follow xterm's behavior: - * - fullwidth + surrogate chars are ignored - * - for combining chars only the base char gets repeated - * - text attrs are applied normally - * - wrap around is respected - * - any valid sequence resets the carried forward char - * - * Note: To get reset on a valid sequence working correctly without much runtime penalty, - * the preceding codepoint is stored on the parser in `this.print` and reset during `parser.parse`. - * - * @vt: #Y CSI REP "Repeat Preceding Character" "CSI Ps b" "Repeat preceding character `Ps` times (default=1)." - * REP repeats the previous character `Ps` times advancing the cursor, also wrapping if DECAWM is set. - * REP has no effect if the sequence does not follow a printable ASCII character - * (NOOP for any other sequence in between or NON ASCII characters). - */ - public repeatPrecedingCharacter(params: IParams): boolean { - if (!this._parser.precedingCodepoint) { - return true; - } - // call print to insert the chars and handle correct wrapping - const length = params.params[0] || 1; - const data = new Uint32Array(length); - for (let i = 0; i < length; ++i) { - data[i] = this._parser.precedingCodepoint; - } - this.print(data, 0, data.length); - return true; - } - - /** - * CSI Ps c Send Device Attributes (Primary DA). - * Ps = 0 or omitted -> request attributes from terminal. The - * response depends on the decTerminalID resource setting. - * -> CSI ? 1 ; 2 c (``VT100 with Advanced Video Option'') - * -> CSI ? 1 ; 0 c (``VT101 with No Options'') - * -> CSI ? 6 c (``VT102'') - * -> CSI ? 6 0 ; 1 ; 2 ; 6 ; 8 ; 9 ; 1 5 ; c (``VT220'') - * The VT100-style response parameters do not mean anything by - * themselves. VT220 parameters do, telling the host what fea- - * tures the terminal supports: - * Ps = 1 -> 132-columns. - * Ps = 2 -> Printer. - * Ps = 6 -> Selective erase. - * Ps = 8 -> User-defined keys. - * Ps = 9 -> National replacement character sets. - * Ps = 1 5 -> Technical characters. - * Ps = 2 2 -> ANSI color, e.g., VT525. - * Ps = 2 9 -> ANSI text locator (i.e., DEC Locator mode). - * - * @vt: #Y CSI DA1 "Primary Device Attributes" "CSI c" "Send primary device attributes." - * - * - * TODO: fix and cleanup response - */ - public sendDeviceAttributesPrimary(params: IParams): boolean { - if (params.params[0] > 0) { - return true; - } - if (this._is('xterm') || this._is('rxvt-unicode') || this._is('screen')) { - this._coreService.triggerDataEvent(C0.ESC + '[?1;2c'); - } else if (this._is('linux')) { - this._coreService.triggerDataEvent(C0.ESC + '[?6c'); - } - return true; - } - - /** - * CSI > Ps c - * Send Device Attributes (Secondary DA). - * Ps = 0 or omitted -> request the terminal's identification - * code. The response depends on the decTerminalID resource set- - * ting. It should apply only to VT220 and up, but xterm extends - * this to VT100. - * -> CSI > Pp ; Pv ; Pc c - * where Pp denotes the terminal type - * Pp = 0 -> ``VT100''. - * Pp = 1 -> ``VT220''. - * and Pv is the firmware version (for xterm, this was originally - * the XFree86 patch number, starting with 95). In a DEC termi- - * nal, Pc indicates the ROM cartridge registration number and is - * always zero. - * More information: - * xterm/charproc.c - line 2012, for more information. - * vim responds with ^[[?0c or ^[[?1c after the terminal's response (?) - * - * @vt: #Y CSI DA2 "Secondary Device Attributes" "CSI > c" "Send primary device attributes." - * - * - * TODO: fix and cleanup response - */ - public sendDeviceAttributesSecondary(params: IParams): boolean { - if (params.params[0] > 0) { - return true; - } - // xterm and urxvt - // seem to spit this - // out around ~370 times (?). - if (this._is('xterm')) { - this._coreService.triggerDataEvent(C0.ESC + '[>0;276;0c'); - } else if (this._is('rxvt-unicode')) { - this._coreService.triggerDataEvent(C0.ESC + '[>85;95;0c'); - } else if (this._is('linux')) { - // not supported by linux console. - // linux console echoes parameters. - this._coreService.triggerDataEvent(params.params[0] + 'c'); - } else if (this._is('screen')) { - this._coreService.triggerDataEvent(C0.ESC + '[>83;40003;0c'); - } - return true; - } - - /** - * Evaluate if the current terminal is the given argument. - * @param term The terminal name to evaluate - */ - private _is(term: string): boolean { - return (this._optionsService.options.termName + '').indexOf(term) === 0; - } - - /** - * CSI Pm h Set Mode (SM). - * Ps = 2 -> Keyboard Action Mode (AM). - * Ps = 4 -> Insert Mode (IRM). - * Ps = 1 2 -> Send/receive (SRM). - * Ps = 2 0 -> Automatic Newline (LNM). - * - * @vt: #P[Only IRM is supported.] CSI SM "Set Mode" "CSI Pm h" "Set various terminal modes." - * Supported param values by SM: - * - * | Param | Action | Support | - * | ----- | -------------------------------------- | ------- | - * | 2 | Keyboard Action Mode (KAM). Always on. | #N | - * | 4 | Insert Mode (IRM). | #Y | - * | 12 | Send/receive (SRM). Always off. | #N | - * | 20 | Automatic Newline (LNM). Always off. | #N | - */ - public setMode(params: IParams): boolean { - for (let i = 0; i < params.length; i++) { - switch (params.params[i]) { - case 4: - this._coreService.modes.insertMode = true; - break; - case 20: - // this._t.convertEol = true; - break; - } - } - return true; - } - - /** - * CSI ? Pm h - * DEC Private Mode Set (DECSET). - * Ps = 1 -> Application Cursor Keys (DECCKM). - * Ps = 2 -> Designate USASCII for character sets G0-G3 - * (DECANM), and set VT100 mode. - * Ps = 3 -> 132 Column Mode (DECCOLM). - * Ps = 4 -> Smooth (Slow) Scroll (DECSCLM). - * Ps = 5 -> Reverse Video (DECSCNM). - * Ps = 6 -> Origin Mode (DECOM). - * Ps = 7 -> Wraparound Mode (DECAWM). - * Ps = 8 -> Auto-repeat Keys (DECARM). - * Ps = 9 -> Send Mouse X & Y on button press. See the sec- - * tion Mouse Tracking. - * Ps = 1 0 -> Show toolbar (rxvt). - * Ps = 1 2 -> Start Blinking Cursor (att610). - * Ps = 1 8 -> Print form feed (DECPFF). - * Ps = 1 9 -> Set print extent to full screen (DECPEX). - * Ps = 2 5 -> Show Cursor (DECTCEM). - * Ps = 3 0 -> Show scrollbar (rxvt). - * Ps = 3 5 -> Enable font-shifting functions (rxvt). - * Ps = 3 8 -> Enter Tektronix Mode (DECTEK). - * Ps = 4 0 -> Allow 80 -> 132 Mode. - * Ps = 4 1 -> more(1) fix (see curses resource). - * Ps = 4 2 -> Enable Nation Replacement Character sets (DECN- - * RCM). - * Ps = 4 4 -> Turn On Margin Bell. - * Ps = 4 5 -> Reverse-wraparound Mode. - * Ps = 4 6 -> Start Logging. This is normally disabled by a - * compile-time option. - * Ps = 4 7 -> Use Alternate Screen Buffer. (This may be dis- - * abled by the titeInhibit resource). - * Ps = 6 6 -> Application keypad (DECNKM). - * Ps = 6 7 -> Backarrow key sends backspace (DECBKM). - * Ps = 1 0 0 0 -> Send Mouse X & Y on button press and - * release. See the section Mouse Tracking. - * Ps = 1 0 0 1 -> Use Hilite Mouse Tracking. - * Ps = 1 0 0 2 -> Use Cell Motion Mouse Tracking. - * Ps = 1 0 0 3 -> Use All Motion Mouse Tracking. - * Ps = 1 0 0 4 -> Send FocusIn/FocusOut events. - * Ps = 1 0 0 5 -> Enable Extended Mouse Mode. - * Ps = 1 0 1 0 -> Scroll to bottom on tty output (rxvt). - * Ps = 1 0 1 1 -> Scroll to bottom on key press (rxvt). - * Ps = 1 0 3 4 -> Interpret "meta" key, sets eighth bit. - * (enables the eightBitInput resource). - * Ps = 1 0 3 5 -> Enable special modifiers for Alt and Num- - * Lock keys. (This enables the numLock resource). - * Ps = 1 0 3 6 -> Send ESC when Meta modifies a key. (This - * enables the metaSendsEscape resource). - * Ps = 1 0 3 7 -> Send DEL from the editing-keypad Delete - * key. - * Ps = 1 0 3 9 -> Send ESC when Alt modifies a key. (This - * enables the altSendsEscape resource). - * Ps = 1 0 4 0 -> Keep selection even if not highlighted. - * (This enables the keepSelection resource). - * Ps = 1 0 4 1 -> Use the CLIPBOARD selection. (This enables - * the selectToClipboard resource). - * Ps = 1 0 4 2 -> Enable Urgency window manager hint when - * Control-G is received. (This enables the bellIsUrgent - * resource). - * Ps = 1 0 4 3 -> Enable raising of the window when Control-G - * is received. (enables the popOnBell resource). - * Ps = 1 0 4 7 -> Use Alternate Screen Buffer. (This may be - * disabled by the titeInhibit resource). - * Ps = 1 0 4 8 -> Save cursor as in DECSC. (This may be dis- - * abled by the titeInhibit resource). - * Ps = 1 0 4 9 -> Save cursor as in DECSC and use Alternate - * Screen Buffer, clearing it first. (This may be disabled by - * the titeInhibit resource). This combines the effects of the 1 - * 0 4 7 and 1 0 4 8 modes. Use this with terminfo-based - * applications rather than the 4 7 mode. - * Ps = 1 0 5 0 -> Set terminfo/termcap function-key mode. - * Ps = 1 0 5 1 -> Set Sun function-key mode. - * Ps = 1 0 5 2 -> Set HP function-key mode. - * Ps = 1 0 5 3 -> Set SCO function-key mode. - * Ps = 1 0 6 0 -> Set legacy keyboard emulation (X11R6). - * Ps = 1 0 6 1 -> Set VT220 keyboard emulation. - * Ps = 2 0 0 4 -> Set bracketed paste mode. - * Modes: - * http: *vt100.net/docs/vt220-rm/chapter4.html - * - * @vt: #P[See below for supported modes.] CSI DECSET "DEC Private Set Mode" "CSI ? Pm h" "Set various terminal attributes." - * Supported param values by DECSET: - * - * | param | Action | Support | - * | ----- | ------------------------------------------------------- | --------| - * | 1 | Application Cursor Keys (DECCKM). | #Y | - * | 2 | Designate US-ASCII for character sets G0-G3 (DECANM). | #Y | - * | 3 | 132 Column Mode (DECCOLM). | #Y | - * | 6 | Origin Mode (DECOM). | #Y | - * | 7 | Auto-wrap Mode (DECAWM). | #Y | - * | 8 | Auto-repeat Keys (DECARM). Always on. | #N | - * | 9 | X10 xterm mouse protocol. | #Y | - * | 12 | Start Blinking Cursor. | #Y | - * | 25 | Show Cursor (DECTCEM). | #Y | - * | 45 | Reverse wrap-around. | #Y | - * | 47 | Use Alternate Screen Buffer. | #Y | - * | 66 | Application keypad (DECNKM). | #Y | - * | 1000 | X11 xterm mouse protocol. | #Y | - * | 1002 | Use Cell Motion Mouse Tracking. | #Y | - * | 1003 | Use All Motion Mouse Tracking. | #Y | - * | 1004 | Send FocusIn/FocusOut events | #Y | - * | 1005 | Enable UTF-8 Mouse Mode. | #N | - * | 1006 | Enable SGR Mouse Mode. | #Y | - * | 1015 | Enable urxvt Mouse Mode. | #N | - * | 1047 | Use Alternate Screen Buffer. | #Y | - * | 1048 | Save cursor as in DECSC. | #Y | - * | 1049 | Save cursor and switch to alternate buffer clearing it. | #P[Does not clear the alternate buffer.] | - * | 2004 | Set bracketed paste mode. | #Y | - * - * - * FIXME: implement DECSCNM, 1049 should clear altbuffer - */ - public setModePrivate(params: IParams): boolean { - for (let i = 0; i < params.length; i++) { - switch (params.params[i]) { - case 1: - this._coreService.decPrivateModes.applicationCursorKeys = true; - break; - case 2: - this._charsetService.setgCharset(0, DEFAULT_CHARSET); - this._charsetService.setgCharset(1, DEFAULT_CHARSET); - this._charsetService.setgCharset(2, DEFAULT_CHARSET); - this._charsetService.setgCharset(3, DEFAULT_CHARSET); - // set VT100 mode here - break; - case 3: - /** - * DECCOLM - 132 column mode. - * This is only active if 'SetWinLines' (24) is enabled - * through `options.windowsOptions`. - */ - if (this._optionsService.options.windowOptions.setWinLines) { - this._bufferService.resize(132, this._bufferService.rows); - this._onRequestReset.fire(); - } - break; - case 6: - this._coreService.decPrivateModes.origin = true; - this._setCursor(0, 0); - break; - case 7: - this._coreService.decPrivateModes.wraparound = true; - break; - case 12: - // this.cursorBlink = true; - break; - case 45: - this._coreService.decPrivateModes.reverseWraparound = true; - break; - case 66: - this._logService.debug('Serial port requested application keypad.'); - this._coreService.decPrivateModes.applicationKeypad = true; - this._onRequestSyncScrollBar.fire(); - break; - case 9: // X10 Mouse - // no release, no motion, no wheel, no modifiers. - this._coreMouseService.activeProtocol = 'X10'; - break; - case 1000: // vt200 mouse - // no motion. - this._coreMouseService.activeProtocol = 'VT200'; - break; - case 1002: // button event mouse - this._coreMouseService.activeProtocol = 'DRAG'; - break; - case 1003: // any event mouse - // any event - sends motion events, - // even if there is no button held down. - this._coreMouseService.activeProtocol = 'ANY'; - break; - case 1004: // send focusin/focusout events - // focusin: ^[[I - // focusout: ^[[O - this._coreService.decPrivateModes.sendFocus = true; - break; - case 1005: // utf8 ext mode mouse - removed in #2507 - this._logService.debug('DECSET 1005 not supported (see #2507)'); - break; - case 1006: // sgr ext mode mouse - this._coreMouseService.activeEncoding = 'SGR'; - break; - case 1015: // urxvt ext mode mouse - removed in #2507 - this._logService.debug('DECSET 1015 not supported (see #2507)'); - break; - case 25: // show cursor - this._coreService.isCursorHidden = false; - break; - case 1048: // alt screen cursor - this.saveCursor(); - break; - case 1049: // alt screen buffer cursor - this.saveCursor(); - // FALL-THROUGH - case 47: // alt screen buffer - case 1047: // alt screen buffer - this._bufferService.buffers.activateAltBuffer(this._eraseAttrData()); - this._coreService.isCursorInitialized = true; - this._onRequestRefreshRows.fire(0, this._bufferService.rows - 1); - this._onRequestSyncScrollBar.fire(); - break; - case 2004: // bracketed paste mode (https://cirw.in/blog/bracketed-paste) - this._coreService.decPrivateModes.bracketedPasteMode = true; - break; - } - } - return true; - } - - - /** - * CSI Pm l Reset Mode (RM). - * Ps = 2 -> Keyboard Action Mode (AM). - * Ps = 4 -> Replace Mode (IRM). - * Ps = 1 2 -> Send/receive (SRM). - * Ps = 2 0 -> Normal Linefeed (LNM). - * - * @vt: #P[Only IRM is supported.] CSI RM "Reset Mode" "CSI Pm l" "Set various terminal attributes." - * Supported param values by RM: - * - * | Param | Action | Support | - * | ----- | -------------------------------------- | ------- | - * | 2 | Keyboard Action Mode (KAM). Always on. | #N | - * | 4 | Replace Mode (IRM). (default) | #Y | - * | 12 | Send/receive (SRM). Always off. | #N | - * | 20 | Normal Linefeed (LNM). Always off. | #N | - * - * - * FIXME: why is LNM commented out? - */ - public resetMode(params: IParams): boolean { - for (let i = 0; i < params.length; i++) { - switch (params.params[i]) { - case 4: - this._coreService.modes.insertMode = false; - break; - case 20: - // this._t.convertEol = false; - break; - } - } - return true; - } - - /** - * CSI ? Pm l - * DEC Private Mode Reset (DECRST). - * Ps = 1 -> Normal Cursor Keys (DECCKM). - * Ps = 2 -> Designate VT52 mode (DECANM). - * Ps = 3 -> 80 Column Mode (DECCOLM). - * Ps = 4 -> Jump (Fast) Scroll (DECSCLM). - * Ps = 5 -> Normal Video (DECSCNM). - * Ps = 6 -> Normal Cursor Mode (DECOM). - * Ps = 7 -> No Wraparound Mode (DECAWM). - * Ps = 8 -> No Auto-repeat Keys (DECARM). - * Ps = 9 -> Don't send Mouse X & Y on button press. - * Ps = 1 0 -> Hide toolbar (rxvt). - * Ps = 1 2 -> Stop Blinking Cursor (att610). - * Ps = 1 8 -> Don't print form feed (DECPFF). - * Ps = 1 9 -> Limit print to scrolling region (DECPEX). - * Ps = 2 5 -> Hide Cursor (DECTCEM). - * Ps = 3 0 -> Don't show scrollbar (rxvt). - * Ps = 3 5 -> Disable font-shifting functions (rxvt). - * Ps = 4 0 -> Disallow 80 -> 132 Mode. - * Ps = 4 1 -> No more(1) fix (see curses resource). - * Ps = 4 2 -> Disable Nation Replacement Character sets (DEC- - * NRCM). - * Ps = 4 4 -> Turn Off Margin Bell. - * Ps = 4 5 -> No Reverse-wraparound Mode. - * Ps = 4 6 -> Stop Logging. (This is normally disabled by a - * compile-time option). - * Ps = 4 7 -> Use Normal Screen Buffer. - * Ps = 6 6 -> Numeric keypad (DECNKM). - * Ps = 6 7 -> Backarrow key sends delete (DECBKM). - * Ps = 1 0 0 0 -> Don't send Mouse X & Y on button press and - * release. See the section Mouse Tracking. - * Ps = 1 0 0 1 -> Don't use Hilite Mouse Tracking. - * Ps = 1 0 0 2 -> Don't use Cell Motion Mouse Tracking. - * Ps = 1 0 0 3 -> Don't use All Motion Mouse Tracking. - * Ps = 1 0 0 4 -> Don't send FocusIn/FocusOut events. - * Ps = 1 0 0 5 -> Disable Extended Mouse Mode. - * Ps = 1 0 1 0 -> Don't scroll to bottom on tty output - * (rxvt). - * Ps = 1 0 1 1 -> Don't scroll to bottom on key press (rxvt). - * Ps = 1 0 3 4 -> Don't interpret "meta" key. (This disables - * the eightBitInput resource). - * Ps = 1 0 3 5 -> Disable special modifiers for Alt and Num- - * Lock keys. (This disables the numLock resource). - * Ps = 1 0 3 6 -> Don't send ESC when Meta modifies a key. - * (This disables the metaSendsEscape resource). - * Ps = 1 0 3 7 -> Send VT220 Remove from the editing-keypad - * Delete key. - * Ps = 1 0 3 9 -> Don't send ESC when Alt modifies a key. - * (This disables the altSendsEscape resource). - * Ps = 1 0 4 0 -> Do not keep selection when not highlighted. - * (This disables the keepSelection resource). - * Ps = 1 0 4 1 -> Use the PRIMARY selection. (This disables - * the selectToClipboard resource). - * Ps = 1 0 4 2 -> Disable Urgency window manager hint when - * Control-G is received. (This disables the bellIsUrgent - * resource). - * Ps = 1 0 4 3 -> Disable raising of the window when Control- - * G is received. (This disables the popOnBell resource). - * Ps = 1 0 4 7 -> Use Normal Screen Buffer, clearing screen - * first if in the Alternate Screen. (This may be disabled by - * the titeInhibit resource). - * Ps = 1 0 4 8 -> Restore cursor as in DECRC. (This may be - * disabled by the titeInhibit resource). - * Ps = 1 0 4 9 -> Use Normal Screen Buffer and restore cursor - * as in DECRC. (This may be disabled by the titeInhibit - * resource). This combines the effects of the 1 0 4 7 and 1 0 - * 4 8 modes. Use this with terminfo-based applications rather - * than the 4 7 mode. - * Ps = 1 0 5 0 -> Reset terminfo/termcap function-key mode. - * Ps = 1 0 5 1 -> Reset Sun function-key mode. - * Ps = 1 0 5 2 -> Reset HP function-key mode. - * Ps = 1 0 5 3 -> Reset SCO function-key mode. - * Ps = 1 0 6 0 -> Reset legacy keyboard emulation (X11R6). - * Ps = 1 0 6 1 -> Reset keyboard emulation to Sun/PC style. - * Ps = 2 0 0 4 -> Reset bracketed paste mode. - * - * @vt: #P[See below for supported modes.] CSI DECRST "DEC Private Reset Mode" "CSI ? Pm l" "Reset various terminal attributes." - * Supported param values by DECRST: - * - * | param | Action | Support | - * | ----- | ------------------------------------------------------- | ------- | - * | 1 | Normal Cursor Keys (DECCKM). | #Y | - * | 2 | Designate VT52 mode (DECANM). | #N | - * | 3 | 80 Column Mode (DECCOLM). | #B[Switches to old column width instead of 80.] | - * | 6 | Normal Cursor Mode (DECOM). | #Y | - * | 7 | No Wraparound Mode (DECAWM). | #Y | - * | 8 | No Auto-repeat Keys (DECARM). | #N | - * | 9 | Don't send Mouse X & Y on button press. | #Y | - * | 12 | Stop Blinking Cursor. | #Y | - * | 25 | Hide Cursor (DECTCEM). | #Y | - * | 45 | No reverse wrap-around. | #Y | - * | 47 | Use Normal Screen Buffer. | #Y | - * | 66 | Numeric keypad (DECNKM). | #Y | - * | 1000 | Don't send Mouse reports. | #Y | - * | 1002 | Don't use Cell Motion Mouse Tracking. | #Y | - * | 1003 | Don't use All Motion Mouse Tracking. | #Y | - * | 1004 | Don't send FocusIn/FocusOut events. | #Y | - * | 1005 | Disable UTF-8 Mouse Mode. | #N | - * | 1006 | Disable SGR Mouse Mode. | #Y | - * | 1015 | Disable urxvt Mouse Mode. | #N | - * | 1047 | Use Normal Screen Buffer (clearing screen if in alt). | #Y | - * | 1048 | Restore cursor as in DECRC. | #Y | - * | 1049 | Use Normal Screen Buffer and restore cursor. | #Y | - * | 2004 | Reset bracketed paste mode. | #Y | - * - * - * FIXME: DECCOLM is currently broken (already fixed in window options PR) - */ - public resetModePrivate(params: IParams): boolean { - for (let i = 0; i < params.length; i++) { - switch (params.params[i]) { - case 1: - this._coreService.decPrivateModes.applicationCursorKeys = false; - break; - case 3: - /** - * DECCOLM - 80 column mode. - * This is only active if 'SetWinLines' (24) is enabled - * through `options.windowsOptions`. - */ - if (this._optionsService.options.windowOptions.setWinLines) { - this._bufferService.resize(80, this._bufferService.rows); - this._onRequestReset.fire(); - } - break; - case 6: - this._coreService.decPrivateModes.origin = false; - this._setCursor(0, 0); - break; - case 7: - this._coreService.decPrivateModes.wraparound = false; - break; - case 12: - // this.cursorBlink = false; - break; - case 45: - this._coreService.decPrivateModes.reverseWraparound = false; - break; - case 66: - this._logService.debug('Switching back to normal keypad.'); - this._coreService.decPrivateModes.applicationKeypad = false; - this._onRequestSyncScrollBar.fire(); - break; - case 9: // X10 Mouse - case 1000: // vt200 mouse - case 1002: // button event mouse - case 1003: // any event mouse - this._coreMouseService.activeProtocol = 'NONE'; - break; - case 1004: // send focusin/focusout events - this._coreService.decPrivateModes.sendFocus = false; - break; - case 1005: // utf8 ext mode mouse - removed in #2507 - this._logService.debug('DECRST 1005 not supported (see #2507)'); - break; - case 1006: // sgr ext mode mouse - this._coreMouseService.activeEncoding = 'DEFAULT'; - break; - case 1015: // urxvt ext mode mouse - removed in #2507 - this._logService.debug('DECRST 1015 not supported (see #2507)'); - break; - case 25: // hide cursor - this._coreService.isCursorHidden = true; - break; - case 1048: // alt screen cursor - this.restoreCursor(); - break; - case 1049: // alt screen buffer cursor - // FALL-THROUGH - case 47: // normal screen buffer - case 1047: // normal screen buffer - clearing it first - // Ensure the selection manager has the correct buffer - this._bufferService.buffers.activateNormalBuffer(); - if (params.params[i] === 1049) { - this.restoreCursor(); - } - this._coreService.isCursorInitialized = true; - this._onRequestRefreshRows.fire(0, this._bufferService.rows - 1); - this._onRequestSyncScrollBar.fire(); - break; - case 2004: // bracketed paste mode (https://cirw.in/blog/bracketed-paste) - this._coreService.decPrivateModes.bracketedPasteMode = false; - break; - } - } - return true; - } - - /** - * Helper to write color information packed with color mode. - */ - private _updateAttrColor(color: number, mode: number, c1: number, c2: number, c3: number): number { - if (mode === 2) { - color |= Attributes.CM_RGB; - color &= ~Attributes.RGB_MASK; - color |= AttributeData.fromColorRGB([c1, c2, c3]); - } else if (mode === 5) { - color &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK); - color |= Attributes.CM_P256 | (c1 & 0xff); - } - return color; - } - - /** - * Helper to extract and apply color params/subparams. - * Returns advance for params index. - */ - private _extractColor(params: IParams, pos: number, attr: IAttributeData): number { - // normalize params - // meaning: [target, CM, ign, val, val, val] - // RGB : [ 38/48, 2, ign, r, g, b] - // P256 : [ 38/48, 5, ign, v, ign, ign] - const accu = [0, 0, -1, 0, 0, 0]; - - // alignment placeholder for non color space sequences - let cSpace = 0; - - // return advance we took in params - let advance = 0; - - do { - accu[advance + cSpace] = params.params[pos + advance]; - if (params.hasSubParams(pos + advance)) { - const subparams = params.getSubParams(pos + advance)!; - let i = 0; - do { - if (accu[1] === 5) { - cSpace = 1; - } - accu[advance + i + 1 + cSpace] = subparams[i]; - } while (++i < subparams.length && i + advance + 1 + cSpace < accu.length); - break; - } - // exit early if can decide color mode with semicolons - if ((accu[1] === 5 && advance + cSpace >= 2) - || (accu[1] === 2 && advance + cSpace >= 5)) { - break; - } - // offset colorSpace slot for semicolon mode - if (accu[1]) { - cSpace = 1; - } - } while (++advance + pos < params.length && advance + cSpace < accu.length); - - // set default values to 0 - for (let i = 2; i < accu.length; ++i) { - if (accu[i] === -1) { - accu[i] = 0; - } - } - - // apply colors - switch (accu[0]) { - case 38: - attr.fg = this._updateAttrColor(attr.fg, accu[1], accu[3], accu[4], accu[5]); - break; - case 48: - attr.bg = this._updateAttrColor(attr.bg, accu[1], accu[3], accu[4], accu[5]); - break; - case 58: - attr.extended = attr.extended.clone(); - attr.extended.underlineColor = this._updateAttrColor(attr.extended.underlineColor, accu[1], accu[3], accu[4], accu[5]); - } - - return advance; - } - - /** - * SGR 4 subparams: - * 4:0 - equal to SGR 24 (turn off all underline) - * 4:1 - equal to SGR 4 (single underline) - * 4:2 - equal to SGR 21 (double underline) - * 4:3 - curly underline - * 4:4 - dotted underline - * 4:5 - dashed underline - */ - private _processUnderline(style: number, attr: IAttributeData): void { - // treat extended attrs as immutable, thus always clone from old one - // this is needed since the buffer only holds references to it - attr.extended = attr.extended.clone(); - - // default to 1 == single underline - if (!~style || style > 5) { - style = 1; - } - attr.extended.underlineStyle = style; - attr.fg |= FgFlags.UNDERLINE; - - // 0 deactivates underline - if (style === 0) { - attr.fg &= ~FgFlags.UNDERLINE; - } - - // update HAS_EXTENDED in BG - attr.updateExtended(); - } - - /** - * CSI Pm m Character Attributes (SGR). - * - * @vt: #P[See below for supported attributes.] CSI SGR "Select Graphic Rendition" "CSI Pm m" "Set/Reset various text attributes." - * SGR selects one or more character attributes at the same time. Multiple params (up to 32) - * are applied in order from left to right. The changed attributes are applied to all new - * characters received. If you move characters in the viewport by scrolling or any other means, - * then the attributes move with the characters. - * - * Supported param values by SGR: - * - * | Param | Meaning | Support | - * | --------- | -------------------------------------------------------- | ------- | - * | 0 | Normal (default). Resets any other preceding SGR. | #Y | - * | 1 | Bold. (also see `options.drawBoldTextInBrightColors`) | #Y | - * | 2 | Faint, decreased intensity. | #Y | - * | 3 | Italic. | #Y | - * | 4 | Underlined (see below for style support). | #Y | - * | 5 | Slowly blinking. | #N | - * | 6 | Rapidly blinking. | #N | - * | 7 | Inverse. Flips foreground and background color. | #Y | - * | 8 | Invisible (hidden). | #Y | - * | 9 | Crossed-out characters. | #N | - * | 21 | Doubly underlined. | #P[Currently outputs a single underline.] | - * | 22 | Normal (neither bold nor faint). | #Y | - * | 23 | No italic. | #Y | - * | 24 | Not underlined. | #Y | - * | 25 | Steady (not blinking). | #Y | - * | 27 | Positive (not inverse). | #Y | - * | 28 | Visible (not hidden). | #Y | - * | 29 | Not Crossed-out. | #N | - * | 30 | Foreground color: Black. | #Y | - * | 31 | Foreground color: Red. | #Y | - * | 32 | Foreground color: Green. | #Y | - * | 33 | Foreground color: Yellow. | #Y | - * | 34 | Foreground color: Blue. | #Y | - * | 35 | Foreground color: Magenta. | #Y | - * | 36 | Foreground color: Cyan. | #Y | - * | 37 | Foreground color: White. | #Y | - * | 38 | Foreground color: Extended color. | #P[Support for RGB and indexed colors, see below.] | - * | 39 | Foreground color: Default (original). | #Y | - * | 40 | Background color: Black. | #Y | - * | 41 | Background color: Red. | #Y | - * | 42 | Background color: Green. | #Y | - * | 43 | Background color: Yellow. | #Y | - * | 44 | Background color: Blue. | #Y | - * | 45 | Background color: Magenta. | #Y | - * | 46 | Background color: Cyan. | #Y | - * | 47 | Background color: White. | #Y | - * | 48 | Background color: Extended color. | #P[Support for RGB and indexed colors, see below.] | - * | 49 | Background color: Default (original). | #Y | - * | 90 - 97 | Bright foreground color (analogous to 30 - 37). | #Y | - * | 100 - 107 | Bright background color (analogous to 40 - 47). | #Y | - * - * Underline supports subparams to denote the style in the form `4 : x`: - * - * | x | Meaning | Support | - * | ------ | ------------------------------------------------------------- | ------- | - * | 0 | No underline. Same as `SGR 24 m`. | #Y | - * | 1 | Single underline. Same as `SGR 4 m`. | #Y | - * | 2 | Double underline. | #P[Currently outputs a single underline.] | - * | 3 | Curly underline. | #P[Currently outputs a single underline.] | - * | 4 | Dotted underline. | #P[Currently outputs a single underline.] | - * | 5 | Dashed underline. | #P[Currently outputs a single underline.] | - * | other | Single underline. Same as `SGR 4 m`. | #Y | - * - * Extended colors are supported for foreground (Ps=38) and background (Ps=48) as follows: - * - * | Ps + 1 | Meaning | Support | - * | ------ | ------------------------------------------------------------- | ------- | - * | 0 | Implementation defined. | #N | - * | 1 | Transparent. | #N | - * | 2 | RGB color as `Ps ; 2 ; R ; G ; B` or `Ps : 2 : : R : G : B`. | #Y | - * | 3 | CMY color. | #N | - * | 4 | CMYK color. | #N | - * | 5 | Indexed (256 colors) as `Ps ; 5 ; INDEX` or `Ps : 5 : INDEX`. | #Y | - * - * - * FIXME: blinking is implemented in attrs, but not working in renderers? - * FIXME: remove dead branch for p=100 - */ - public charAttributes(params: IParams): boolean { - // Optimize a single SGR0. - if (params.length === 1 && params.params[0] === 0) { - this._curAttrData.fg = DEFAULT_ATTR_DATA.fg; - this._curAttrData.bg = DEFAULT_ATTR_DATA.bg; - return true; - } - - const l = params.length; - let p; - const attr = this._curAttrData; - - for (let i = 0; i < l; i++) { - p = params.params[i]; - if (p >= 30 && p <= 37) { - // fg color 8 - attr.fg &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK); - attr.fg |= Attributes.CM_P16 | (p - 30); - } else if (p >= 40 && p <= 47) { - // bg color 8 - attr.bg &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK); - attr.bg |= Attributes.CM_P16 | (p - 40); - } else if (p >= 90 && p <= 97) { - // fg color 16 - attr.fg &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK); - attr.fg |= Attributes.CM_P16 | (p - 90) | 8; - } else if (p >= 100 && p <= 107) { - // bg color 16 - attr.bg &= ~(Attributes.CM_MASK | Attributes.PCOLOR_MASK); - attr.bg |= Attributes.CM_P16 | (p - 100) | 8; - } else if (p === 0) { - // default - attr.fg = DEFAULT_ATTR_DATA.fg; - attr.bg = DEFAULT_ATTR_DATA.bg; - } else if (p === 1) { - // bold text - attr.fg |= FgFlags.BOLD; - } else if (p === 3) { - // italic text - attr.bg |= BgFlags.ITALIC; - } else if (p === 4) { - // underlined text - attr.fg |= FgFlags.UNDERLINE; - this._processUnderline(params.hasSubParams(i) ? params.getSubParams(i)![0] : UnderlineStyle.SINGLE, attr); - } else if (p === 5) { - // blink - attr.fg |= FgFlags.BLINK; - } else if (p === 7) { - // inverse and positive - // test with: echo -e '\e[31m\e[42mhello\e[7mworld\e[27mhi\e[m' - attr.fg |= FgFlags.INVERSE; - } else if (p === 8) { - // invisible - attr.fg |= FgFlags.INVISIBLE; - } else if (p === 2) { - // dimmed text - attr.bg |= BgFlags.DIM; - } else if (p === 21) { - // double underline - this._processUnderline(UnderlineStyle.DOUBLE, attr); - } else if (p === 22) { - // not bold nor faint - attr.fg &= ~FgFlags.BOLD; - attr.bg &= ~BgFlags.DIM; - } else if (p === 23) { - // not italic - attr.bg &= ~BgFlags.ITALIC; - } else if (p === 24) { - // not underlined - attr.fg &= ~FgFlags.UNDERLINE; - } else if (p === 25) { - // not blink - attr.fg &= ~FgFlags.BLINK; - } else if (p === 27) { - // not inverse - attr.fg &= ~FgFlags.INVERSE; - } else if (p === 28) { - // not invisible - attr.fg &= ~FgFlags.INVISIBLE; - } else if (p === 39) { - // reset fg - attr.fg &= ~(Attributes.CM_MASK | Attributes.RGB_MASK); - attr.fg |= DEFAULT_ATTR_DATA.fg & (Attributes.PCOLOR_MASK | Attributes.RGB_MASK); - } else if (p === 49) { - // reset bg - attr.bg &= ~(Attributes.CM_MASK | Attributes.RGB_MASK); - attr.bg |= DEFAULT_ATTR_DATA.bg & (Attributes.PCOLOR_MASK | Attributes.RGB_MASK); - } else if (p === 38 || p === 48 || p === 58) { - // fg color 256 and RGB - i += this._extractColor(params, i, attr); - } else if (p === 59) { - attr.extended = attr.extended.clone(); - attr.extended.underlineColor = -1; - attr.updateExtended(); - } else if (p === 100) { // FIXME: dead branch, p=100 already handled above! - // reset fg/bg - attr.fg &= ~(Attributes.CM_MASK | Attributes.RGB_MASK); - attr.fg |= DEFAULT_ATTR_DATA.fg & (Attributes.PCOLOR_MASK | Attributes.RGB_MASK); - attr.bg &= ~(Attributes.CM_MASK | Attributes.RGB_MASK); - attr.bg |= DEFAULT_ATTR_DATA.bg & (Attributes.PCOLOR_MASK | Attributes.RGB_MASK); - } else { - this._logService.debug('Unknown SGR attribute: %d.', p); - } - } - return true; - } - - /** - * CSI Ps n Device Status Report (DSR). - * Ps = 5 -> Status Report. Result (``OK'') is - * CSI 0 n - * Ps = 6 -> Report Cursor Position (CPR) [row;column]. - * Result is - * CSI r ; c R - * CSI ? Ps n - * Device Status Report (DSR, DEC-specific). - * Ps = 6 -> Report Cursor Position (CPR) [row;column] as CSI - * ? r ; c R (assumes page is zero). - * Ps = 1 5 -> Report Printer status as CSI ? 1 0 n (ready). - * or CSI ? 1 1 n (not ready). - * Ps = 2 5 -> Report UDK status as CSI ? 2 0 n (unlocked) - * or CSI ? 2 1 n (locked). - * Ps = 2 6 -> Report Keyboard status as - * CSI ? 2 7 ; 1 ; 0 ; 0 n (North American). - * The last two parameters apply to VT400 & up, and denote key- - * board ready and LK01 respectively. - * Ps = 5 3 -> Report Locator status as - * CSI ? 5 3 n Locator available, if compiled-in, or - * CSI ? 5 0 n No Locator, if not. - * - * @vt: #Y CSI DSR "Device Status Report" "CSI Ps n" "Request cursor position (CPR) with `Ps` = 6." - */ - public deviceStatus(params: IParams): boolean { - switch (params.params[0]) { - case 5: - // status report - this._coreService.triggerDataEvent(`${C0.ESC}[0n`); - break; - case 6: - // cursor position - const y = this._bufferService.buffer.y + 1; - const x = this._bufferService.buffer.x + 1; - this._coreService.triggerDataEvent(`${C0.ESC}[${y};${x}R`); - break; - } - return true; - } - - // @vt: #P[Only CPR is supported.] CSI DECDSR "DEC Device Status Report" "CSI ? Ps n" "Only CPR is supported (same as DSR)." - public deviceStatusPrivate(params: IParams): boolean { - // modern xterm doesnt seem to - // respond to any of these except ?6, 6, and 5 - switch (params.params[0]) { - case 6: - // cursor position - const y = this._bufferService.buffer.y + 1; - const x = this._bufferService.buffer.x + 1; - this._coreService.triggerDataEvent(`${C0.ESC}[?${y};${x}R`); - break; - case 15: - // no printer - // this.handler(C0.ESC + '[?11n'); - break; - case 25: - // dont support user defined keys - // this.handler(C0.ESC + '[?21n'); - break; - case 26: - // north american keyboard - // this.handler(C0.ESC + '[?27;1;0;0n'); - break; - case 53: - // no dec locator/mouse - // this.handler(C0.ESC + '[?50n'); - break; - } - return true; - } - - /** - * CSI ! p Soft terminal reset (DECSTR). - * http://vt100.net/docs/vt220-rm/table4-10.html - * - * @vt: #Y CSI DECSTR "Soft Terminal Reset" "CSI ! p" "Reset several terminal attributes to initial state." - * There are two terminal reset sequences - RIS and DECSTR. While RIS performs almost a full terminal bootstrap, - * DECSTR only resets certain attributes. For most needs DECSTR should be sufficient. - * - * The following terminal attributes are reset to default values: - * - IRM is reset (dafault = false) - * - scroll margins are reset (default = viewport size) - * - erase attributes are reset to default - * - charsets are reset - * - DECSC data is reset to initial values - * - DECOM is reset to absolute mode - * - * - * FIXME: there are several more attributes missing (see VT520 manual) - */ - public softReset(params: IParams): boolean { - this._coreService.isCursorHidden = false; - this._onRequestSyncScrollBar.fire(); - this._bufferService.buffer.scrollTop = 0; - this._bufferService.buffer.scrollBottom = this._bufferService.rows - 1; - this._curAttrData = DEFAULT_ATTR_DATA.clone(); - this._coreService.reset(); - this._charsetService.reset(); - - // reset DECSC data - this._bufferService.buffer.savedX = 0; - this._bufferService.buffer.savedY = this._bufferService.buffer.ybase; - this._bufferService.buffer.savedCurAttrData.fg = this._curAttrData.fg; - this._bufferService.buffer.savedCurAttrData.bg = this._curAttrData.bg; - this._bufferService.buffer.savedCharset = this._charsetService.charset; - - // reset DECOM - this._coreService.decPrivateModes.origin = false; - return true; - } - - /** - * CSI Ps SP q Set cursor style (DECSCUSR, VT520). - * Ps = 0 -> blinking block. - * Ps = 1 -> blinking block (default). - * Ps = 2 -> steady block. - * Ps = 3 -> blinking underline. - * Ps = 4 -> steady underline. - * Ps = 5 -> blinking bar (xterm). - * Ps = 6 -> steady bar (xterm). - * - * @vt: #Y CSI DECSCUSR "Set Cursor Style" "CSI Ps SP q" "Set cursor style." - * Supported cursor styles: - * - empty, 0 or 1: steady block - * - 2: blink block - * - 3: steady underline - * - 4: blink underline - * - 5: steady bar - * - 6: blink bar - */ - public setCursorStyle(params: IParams): boolean { - const param = params.params[0] || 1; - switch (param) { - case 1: - case 2: - this._optionsService.options.cursorStyle = 'block'; - break; - case 3: - case 4: - this._optionsService.options.cursorStyle = 'underline'; - break; - case 5: - case 6: - this._optionsService.options.cursorStyle = 'bar'; - break; - } - const isBlinking = param % 2 === 1; - this._optionsService.options.cursorBlink = isBlinking; - return true; - } - - /** - * CSI Ps ; Ps r - * Set Scrolling Region [top;bottom] (default = full size of win- - * dow) (DECSTBM). - * - * @vt: #Y CSI DECSTBM "Set Top and Bottom Margin" "CSI Ps ; Ps r" "Set top and bottom margins of the viewport [top;bottom] (default = viewport size)." - */ - public setScrollRegion(params: IParams): boolean { - const top = params.params[0] || 1; - let bottom: number; - - if (params.length < 2 || (bottom = params.params[1]) > this._bufferService.rows || bottom === 0) { - bottom = this._bufferService.rows; - } - - if (bottom > top) { - this._bufferService.buffer.scrollTop = top - 1; - this._bufferService.buffer.scrollBottom = bottom - 1; - this._setCursor(0, 0); - } - return true; - } - - /** - * CSI Ps ; Ps ; Ps t - Various window manipulations and reports (xterm) - * - * Note: Only those listed below are supported. All others are left to integrators and - * need special treatment based on the embedding environment. - * - * Ps = 1 4 supported - * Report xterm text area size in pixels. - * Result is CSI 4 ; height ; width t - * Ps = 14 ; 2 not implemented - * Ps = 16 supported - * Report xterm character cell size in pixels. - * Result is CSI 6 ; height ; width t - * Ps = 18 supported - * Report the size of the text area in characters. - * Result is CSI 8 ; height ; width t - * Ps = 20 supported - * Report xterm window's icon label. - * Result is OSC L label ST - * Ps = 21 supported - * Report xterm window's title. - * Result is OSC l label ST - * Ps = 22 ; 0 -> Save xterm icon and window title on stack. supported - * Ps = 22 ; 1 -> Save xterm icon title on stack. supported - * Ps = 22 ; 2 -> Save xterm window title on stack. supported - * Ps = 23 ; 0 -> Restore xterm icon and window title from stack. supported - * Ps = 23 ; 1 -> Restore xterm icon title from stack. supported - * Ps = 23 ; 2 -> Restore xterm window title from stack. supported - * Ps >= 24 not implemented - */ - public windowOptions(params: IParams): boolean { - if (!paramToWindowOption(params.params[0], this._optionsService.options.windowOptions)) { - return true; - } - const second = (params.length > 1) ? params.params[1] : 0; - switch (params.params[0]) { - case 14: // GetWinSizePixels, returns CSI 4 ; height ; width t - if (second !== 2) { - this._onRequestWindowsOptionsReport.fire(WindowsOptionsReportType.GET_WIN_SIZE_PIXELS); - } - break; - case 16: // GetCellSizePixels, returns CSI 6 ; height ; width t - this._onRequestWindowsOptionsReport.fire(WindowsOptionsReportType.GET_CELL_SIZE_PIXELS); - break; - case 18: // GetWinSizeChars, returns CSI 8 ; height ; width t - if (this._bufferService) { - this._coreService.triggerDataEvent(`${C0.ESC}[8;${this._bufferService.rows};${this._bufferService.cols}t`); - } - break; - case 22: // PushTitle - if (second === 0 || second === 2) { - this._windowTitleStack.push(this._windowTitle); - if (this._windowTitleStack.length > STACK_LIMIT) { - this._windowTitleStack.shift(); - } - } - if (second === 0 || second === 1) { - this._iconNameStack.push(this._iconName); - if (this._iconNameStack.length > STACK_LIMIT) { - this._iconNameStack.shift(); - } - } - break; - case 23: // PopTitle - if (second === 0 || second === 2) { - if (this._windowTitleStack.length) { - this.setTitle(this._windowTitleStack.pop()!); - } - } - if (second === 0 || second === 1) { - if (this._iconNameStack.length) { - this.setIconName(this._iconNameStack.pop()!); - } - } - break; - } - return true; - } - - - /** - * CSI s - * ESC 7 - * Save cursor (ANSI.SYS). - * - * @vt: #P[TODO...] CSI SCOSC "Save Cursor" "CSI s" "Save cursor position, charmap and text attributes." - * @vt: #Y ESC SC "Save Cursor" "ESC 7" "Save cursor position, charmap and text attributes." - */ - public saveCursor(params?: IParams): boolean { - this._bufferService.buffer.savedX = this._bufferService.buffer.x; - this._bufferService.buffer.savedY = this._bufferService.buffer.ybase + this._bufferService.buffer.y; - this._bufferService.buffer.savedCurAttrData.fg = this._curAttrData.fg; - this._bufferService.buffer.savedCurAttrData.bg = this._curAttrData.bg; - this._bufferService.buffer.savedCharset = this._charsetService.charset; - return true; - } - - - /** - * CSI u - * ESC 8 - * Restore cursor (ANSI.SYS). - * - * @vt: #P[TODO...] CSI SCORC "Restore Cursor" "CSI u" "Restore cursor position, charmap and text attributes." - * @vt: #Y ESC RC "Restore Cursor" "ESC 8" "Restore cursor position, charmap and text attributes." - */ - public restoreCursor(params?: IParams): boolean { - this._bufferService.buffer.x = this._bufferService.buffer.savedX || 0; - this._bufferService.buffer.y = Math.max(this._bufferService.buffer.savedY - this._bufferService.buffer.ybase, 0); - this._curAttrData.fg = this._bufferService.buffer.savedCurAttrData.fg; - this._curAttrData.bg = this._bufferService.buffer.savedCurAttrData.bg; - this._charsetService.charset = (this as any)._savedCharset; - if (this._bufferService.buffer.savedCharset) { - this._charsetService.charset = this._bufferService.buffer.savedCharset; - } - this._restrictCursor(); - return true; - } - - - /** - * OSC 2; ST (set window title) - * Proxy to set window title. - * - * @vt: #P[Icon name is not exposed.] OSC 0 "Set Windows Title and Icon Name" "OSC 0 ; Pt BEL" "Set window title and icon name." - * Icon name is not supported. For Window Title see below. - * - * @vt: #Y OSC 2 "Set Windows Title" "OSC 2 ; Pt BEL" "Set window title." - * xterm.js does not manipulate the title directly, instead exposes changes via the event `Terminal.onTitleChange`. - */ - public setTitle(data: string): boolean { - this._windowTitle = data; - this._onTitleChange.fire(data); - return true; - } - - /** - * OSC 1; ST - * Note: Icon name is not exposed. - */ - public setIconName(data: string): boolean { - this._iconName = data; - return true; - } - - protected _parseAnsiColorChange(data: string): IAnsiColorChangeEvent | null { - const result: IAnsiColorChangeEvent = { colors: [] }; - // example data: 5;rgb:aa/bb/cc - const regex = /(\d+);rgb:([0-9a-f]{2})\/([0-9a-f]{2})\/([0-9a-f]{2})/gi; - let match; - - while ((match = regex.exec(data)) !== null) { - result.colors.push({ - colorIndex: parseInt(match[1]), - red: parseInt(match[2], 16), - green: parseInt(match[3], 16), - blue: parseInt(match[4], 16) - }); - } - - if (result.colors.length === 0) { - return null; - } - - return result; - } - - /** - * OSC 4; ; ST (set ANSI color to ) - * - * @vt: #Y OSC 4 "Set ANSI color" "OSC 4 ; c ; spec BEL" "Change color number `c` to the color specified by `spec`." - * `c` is the color index between 0 and 255. `spec` color format is 'rgb:hh/hh/hh' where `h` are hexadecimal digits. - * There may be multipe c ; spec elements present in the same instruction, e.g. 1;rgb:10/20/30;2;rgb:a0/b0/c0. - */ - public setAnsiColor(data: string): boolean { - const event = this._parseAnsiColorChange(data); - if (event) { - this._onAnsiColorChange.fire(event); - } - else { - this._logService.warn(`Expected format ;rgb:// but got data: ${data}`); - } - return true; - } - - /** - * ESC E - * C1.NEL - * DEC mnemonic: NEL (https://vt100.net/docs/vt510-rm/NEL) - * Moves cursor to first position on next line. - * - * @vt: #Y C1 NEL "Next Line" "\x85" "Move the cursor to the beginning of the next row." - * @vt: #Y ESC NEL "Next Line" "ESC E" "Move the cursor to the beginning of the next row." - */ - public nextLine(): boolean { - this._bufferService.buffer.x = 0; - this.index(); - return true; - } - - /** - * ESC = - * DEC mnemonic: DECKPAM (https://vt100.net/docs/vt510-rm/DECKPAM.html) - * Enables the numeric keypad to send application sequences to the host. - */ - public keypadApplicationMode(): boolean { - this._logService.debug('Serial port requested application keypad.'); - this._coreService.decPrivateModes.applicationKeypad = true; - this._onRequestSyncScrollBar.fire(); - return true; - } - - /** - * ESC > - * DEC mnemonic: DECKPNM (https://vt100.net/docs/vt510-rm/DECKPNM.html) - * Enables the keypad to send numeric characters to the host. - */ - public keypadNumericMode(): boolean { - this._logService.debug('Switching back to normal keypad.'); - this._coreService.decPrivateModes.applicationKeypad = false; - this._onRequestSyncScrollBar.fire(); - return true; - } - - /** - * ESC % @ - * ESC % G - * Select default character set. UTF-8 is not supported (string are unicode anyways) - * therefore ESC % G does the same. - */ - public selectDefaultCharset(): boolean { - this._charsetService.setgLevel(0); - this._charsetService.setgCharset(0, DEFAULT_CHARSET); // US (default) - return true; - } - - /** - * ESC ( C - * Designate G0 Character Set, VT100, ISO 2022. - * ESC ) C - * Designate G1 Character Set (ISO 2022, VT100). - * ESC * C - * Designate G2 Character Set (ISO 2022, VT220). - * ESC + C - * Designate G3 Character Set (ISO 2022, VT220). - * ESC - C - * Designate G1 Character Set (VT300). - * ESC . C - * Designate G2 Character Set (VT300). - * ESC / C - * Designate G3 Character Set (VT300). C = A -> ISO Latin-1 Supplemental. - Supported? - */ - public selectCharset(collectAndFlag: string): boolean { - if (collectAndFlag.length !== 2) { - this.selectDefaultCharset(); - return true; - } - if (collectAndFlag[0] === '/') { - return true; // TODO: Is this supported? - } - this._charsetService.setgCharset(GLEVEL[collectAndFlag[0]], CHARSETS[collectAndFlag[1]] || DEFAULT_CHARSET); - return true; - } - - /** - * ESC D - * C1.IND - * DEC mnemonic: IND (https://vt100.net/docs/vt510-rm/IND.html) - * Moves the cursor down one line in the same column. - * - * @vt: #Y C1 IND "Index" "\x84" "Move the cursor one line down scrolling if needed." - * @vt: #Y ESC IND "Index" "ESC D" "Move the cursor one line down scrolling if needed." - */ - public index(): boolean { - this._restrictCursor(); - const buffer = this._bufferService.buffer; - this._bufferService.buffer.y++; - if (buffer.y === buffer.scrollBottom + 1) { - buffer.y--; - this._onRequestScroll.fire(this._eraseAttrData()); - } else if (buffer.y >= this._bufferService.rows) { - buffer.y = this._bufferService.rows - 1; - } - this._restrictCursor(); - return true; - } - - /** - * ESC H - * C1.HTS - * DEC mnemonic: HTS (https://vt100.net/docs/vt510-rm/HTS.html) - * Sets a horizontal tab stop at the column position indicated by - * the value of the active column when the terminal receives an HTS. - * - * @vt: #Y C1 HTS "Horizontal Tabulation Set" "\x88" "Places a tab stop at the current cursor position." - * @vt: #Y ESC HTS "Horizontal Tabulation Set" "ESC H" "Places a tab stop at the current cursor position." - */ - public tabSet(): boolean { - this._bufferService.buffer.tabs[this._bufferService.buffer.x] = true; - return true; - } - - /** - * ESC M - * C1.RI - * DEC mnemonic: HTS - * Moves the cursor up one line in the same column. If the cursor is at the top margin, - * the page scrolls down. - * - * @vt: #Y ESC IR "Reverse Index" "ESC M" "Move the cursor one line up scrolling if needed." - */ - public reverseIndex(): boolean { - this._restrictCursor(); - const buffer = this._bufferService.buffer; - if (buffer.y === buffer.scrollTop) { - // possibly move the code below to term.reverseScroll(); - // test: echo -ne '\e[1;1H\e[44m\eM\e[0m' - // blankLine(true) is xterm/linux behavior - const scrollRegionHeight = buffer.scrollBottom - buffer.scrollTop; - buffer.lines.shiftElements(buffer.ybase + buffer.y, scrollRegionHeight, 1); - buffer.lines.set(buffer.ybase + buffer.y, buffer.getBlankLine(this._eraseAttrData())); - this._dirtyRowService.markRangeDirty(buffer.scrollTop, buffer.scrollBottom); - } else { - buffer.y--; - this._restrictCursor(); // quickfix to not run out of bounds - } - return true; - } - - /** - * ESC c - * DEC mnemonic: RIS (https://vt100.net/docs/vt510-rm/RIS.html) - * Reset to initial state. - */ - public fullReset(): boolean { - this._parser.reset(); - this._onRequestReset.fire(); - return true; - } - - public reset(): void { - this._curAttrData = DEFAULT_ATTR_DATA.clone(); - this._eraseAttrDataInternal = DEFAULT_ATTR_DATA.clone(); - } - - /** - * back_color_erase feature for xterm. - */ - private _eraseAttrData(): IAttributeData { - this._eraseAttrDataInternal.bg &= ~(Attributes.CM_MASK | 0xFFFFFF); - this._eraseAttrDataInternal.bg |= this._curAttrData.bg & ~0xFC000000; - return this._eraseAttrDataInternal; - } - - /** - * ESC n - * ESC o - * ESC | - * ESC } - * ESC ~ - * DEC mnemonic: LS (https://vt100.net/docs/vt510-rm/LS.html) - * When you use a locking shift, the character set remains in GL or GR until - * you use another locking shift. (partly supported) - */ - public setgLevel(level: number): boolean { - this._charsetService.setgLevel(level); - return true; - } - - /** - * ESC # 8 - * DEC mnemonic: DECALN (https://vt100.net/docs/vt510-rm/DECALN.html) - * This control function fills the complete screen area with - * a test pattern (E) used for adjusting screen alignment. - * - * @vt: #Y ESC DECALN "Screen Alignment Pattern" "ESC # 8" "Fill viewport with a test pattern (E)." - */ - public screenAlignmentPattern(): boolean { - // prepare cell data - const cell = new CellData(); - cell.content = 1 << Content.WIDTH_SHIFT | 'E'.charCodeAt(0); - cell.fg = this._curAttrData.fg; - cell.bg = this._curAttrData.bg; - - const buffer = this._bufferService.buffer; - - this._setCursor(0, 0); - for (let yOffset = 0; yOffset < this._bufferService.rows; ++yOffset) { - const row = buffer.ybase + buffer.y + yOffset; - const line = buffer.lines.get(row); - if (line) { - line.fill(cell); - line.isWrapped = false; - } - } - this._dirtyRowService.markAllDirty(); - this._setCursor(0, 0); - return true; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Lifecycle.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Lifecycle.ts deleted file mode 100755 index 56bcfdcd9..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Lifecycle.ts +++ /dev/null @@ -1,68 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IDisposable } from 'common/Types'; - -/** - * A base class that can be extended to provide convenience methods for managing the lifecycle of an - * object and its components. - */ -export abstract class Disposable implements IDisposable { - protected _disposables: IDisposable[] = []; - protected _isDisposed: boolean = false; - - constructor() { - } - - /** - * Disposes the object, triggering the `dispose` method on all registered IDisposables. - */ - public dispose(): void { - this._isDisposed = true; - for (const d of this._disposables) { - d.dispose(); - } - this._disposables.length = 0; - } - - /** - * Registers a disposable object. - * @param d The disposable to register. - * @returns The disposable. - */ - public register(d: T): T { - this._disposables.push(d); - return d; - } - - /** - * Unregisters a disposable object if it has been registered, if not do - * nothing. - * @param d The disposable to unregister. - */ - public unregister(d: T): void { - const index = this._disposables.indexOf(d); - if (index !== -1) { - this._disposables.splice(index, 1); - } - } -} - -/** - * Dispose of all disposables in an array and set its length to 0. - */ -export function disposeArray(disposables: IDisposable[]): void { - for (const d of disposables) { - d.dispose(); - } - disposables.length = 0; -} - -/** - * Creates a disposable that will dispose of an array of disposables when disposed. - */ -export function getDisposeArrayDisposable(array: IDisposable[]): IDisposable { - return { dispose: () => disposeArray(array) }; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Platform.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Platform.ts deleted file mode 100755 index 8838ca9d4..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Platform.ts +++ /dev/null @@ -1,30 +0,0 @@ -/** - * Copyright (c) 2016 The xterm.js authors. All rights reserved. - * @license MIT - */ - -interface INavigator { - userAgent: string; - language: string; - platform: string; -} - -// We're declaring a navigator global here as we expect it in all runtimes (node and browser), but -// we want this module to live in common. -declare const navigator: INavigator; - -const isNode = (typeof navigator === 'undefined') ? true : false; -const userAgent = (isNode) ? 'node' : navigator.userAgent; -const platform = (isNode) ? 'node' : navigator.platform; - -export const isFirefox = userAgent.includes('Firefox'); -export const isSafari = /^((?!chrome|android).)*safari/i.test(userAgent); - -// Find the users platform. We use this to interpret the meta key -// and ISO third level shifts. -// http://stackoverflow.com/q/19877924/577598 -export const isMac = ['Macintosh', 'MacIntel', 'MacPPC', 'Mac68K'].includes(platform); -export const isIpad = platform === 'iPad'; -export const isIphone = platform === 'iPhone'; -export const isWindows = ['Windows', 'Win16', 'Win32', 'WinCE'].includes(platform); -export const isLinux = platform.indexOf('Linux') >= 0; diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/TypedArrayUtils.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/TypedArrayUtils.ts deleted file mode 100755 index 158c717b3..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/TypedArrayUtils.ts +++ /dev/null @@ -1,50 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -export type TypedArray = Uint8Array | Uint16Array | Uint32Array | Uint8ClampedArray | Int8Array | Int16Array | Int32Array | Float32Array | Float64Array; - - -/** - * polyfill for TypedArray.fill - * This is needed to support .fill in all safari versions and IE 11. - */ -export function fill(array: T, value: number, start?: number, end?: number): T { - // all modern engines that support .fill - if (array.fill) { - return array.fill(value, start, end) as T; - } - return fillFallback(array, value, start, end); -} - -export function fillFallback(array: T, value: number, start: number = 0, end: number = array.length): T { - // safari and IE 11 - // since IE 11 does not support Array.prototype.fill either - // we cannot use the suggested polyfill from MDN - // instead we simply fall back to looping - if (start >= array.length) { - return array; - } - start = (array.length + start) % array.length; - if (end >= array.length) { - end = array.length; - } else { - end = (array.length + end) % array.length; - } - for (let i = start; i < end; ++i) { - array[i] = value; - } - return array; -} - -/** - * Concat two typed arrays `a` and `b`. - * Returns a new typed array. - */ -export function concat(a: T, b: T): T { - const result = new (a.constructor as any)(a.length + b.length); - result.set(a); - result.set(b, a.length); - return result; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Types.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Types.d.ts deleted file mode 100755 index 1ea26c2a7..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/Types.d.ts +++ /dev/null @@ -1,429 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ITerminalOptions as IPublicTerminalOptions } from 'xterm'; -import { IEvent, IEventEmitter } from 'common/EventEmitter'; -import { IDeleteEvent, IInsertEvent } from 'common/CircularList'; -import { IParams } from 'common/parser/Types'; -import { IOptionsService, IUnicodeService } from 'common/services/Services'; - -export interface ICoreTerminal { - optionsService: IOptionsService; - unicodeService: IUnicodeService; -} - -export interface IDisposable { - dispose(): void; -} - -// TODO: The options that are not in the public API should be reviewed -export interface ITerminalOptions extends IPublicTerminalOptions { - [key: string]: any; - cancelEvents?: boolean; - convertEol?: boolean; - termName?: string; -} - -export type XtermListener = (...args: any[]) => void; - -/** - * A keyboard event interface which does not depend on the DOM, KeyboardEvent implicitly extends - * this event. - */ -export interface IKeyboardEvent { - altKey: boolean; - ctrlKey: boolean; - shiftKey: boolean; - metaKey: boolean; - keyCode: number; - key: string; - type: string; -} - -export interface ICircularList { - length: number; - maxLength: number; - isFull: boolean; - - onDeleteEmitter: IEventEmitter; - onDelete: IEvent; - onInsertEmitter: IEventEmitter; - onInsert: IEvent; - onTrimEmitter: IEventEmitter; - onTrim: IEvent; - - get(index: number): T | undefined; - set(index: number, value: T): void; - push(value: T): void; - recycle(): T; - pop(): T | undefined; - splice(start: number, deleteCount: number, ...items: T[]): void; - trimStart(count: number): void; - shiftElements(start: number, count: number, offset: number): void; -} - -export const enum KeyboardResultType { - SEND_KEY, - SELECT_ALL, - PAGE_UP, - PAGE_DOWN -} - -export interface IKeyboardResult { - type: KeyboardResultType; - cancel: boolean; - key: string | undefined; -} - -export interface ICharset { - [key: string]: string | undefined; -} - -export type CharData = [number, string, number, number]; -export type IColorRGB = [number, number, number]; - -export interface IExtendedAttrs { - underlineStyle: number; - underlineColor: number; - clone(): IExtendedAttrs; - isEmpty(): boolean; -} - -/** Attribute data */ -export interface IAttributeData { - fg: number; - bg: number; - extended: IExtendedAttrs; - - clone(): IAttributeData; - - // flags - isInverse(): number; - isBold(): number; - isUnderline(): number; - isBlink(): number; - isInvisible(): number; - isItalic(): number; - isDim(): number; - - // color modes - getFgColorMode(): number; - getBgColorMode(): number; - isFgRGB(): boolean; - isBgRGB(): boolean; - isFgPalette(): boolean; - isBgPalette(): boolean; - isFgDefault(): boolean; - isBgDefault(): boolean; - isAttributeDefault(): boolean; - - // colors - getFgColor(): number; - getBgColor(): number; - - // extended attrs - hasExtendedAttrs(): number; - updateExtended(): void; - getUnderlineColor(): number; - getUnderlineColorMode(): number; - isUnderlineColorRGB(): boolean; - isUnderlineColorPalette(): boolean; - isUnderlineColorDefault(): boolean; - getUnderlineStyle(): number; -} - -/** Cell data */ -export interface ICellData extends IAttributeData { - content: number; - combinedData: string; - isCombined(): number; - getWidth(): number; - getChars(): string; - getCode(): number; - setFromCharData(value: CharData): void; - getAsCharData(): CharData; -} - -/** - * Interface for a line in the terminal buffer. - */ -export interface IBufferLine { - length: number; - isWrapped: boolean; - get(index: number): CharData; - set(index: number, value: CharData): void; - loadCell(index: number, cell: ICellData): ICellData; - setCell(index: number, cell: ICellData): void; - setCellFromCodePoint(index: number, codePoint: number, width: number, fg: number, bg: number, eAttrs: IExtendedAttrs): void; - addCodepointToCell(index: number, codePoint: number): void; - insertCells(pos: number, n: number, ch: ICellData, eraseAttr?: IAttributeData): void; - deleteCells(pos: number, n: number, fill: ICellData, eraseAttr?: IAttributeData): void; - replaceCells(start: number, end: number, fill: ICellData, eraseAttr?: IAttributeData): void; - resize(cols: number, fill: ICellData): void; - fill(fillCellData: ICellData): void; - copyFrom(line: IBufferLine): void; - clone(): IBufferLine; - getTrimmedLength(): number; - translateToString(trimRight?: boolean, startCol?: number, endCol?: number): string; - - /* direct access to cell attrs */ - getWidth(index: number): number; - hasWidth(index: number): number; - getFg(index: number): number; - getBg(index: number): number; - hasContent(index: number): number; - getCodePoint(index: number): number; - isCombined(index: number): number; - getString(index: number): string; -} - -export interface IMarker extends IDisposable { - readonly id: number; - readonly isDisposed: boolean; - readonly line: number; - onDispose: IEvent; -} -export interface IModes { - insertMode: boolean; -} - -export interface IDecPrivateModes { - applicationCursorKeys: boolean; - applicationKeypad: boolean; - bracketedPasteMode: boolean; - origin: boolean; - reverseWraparound: boolean; - sendFocus: boolean; - wraparound: boolean; // defaults: xterm - true, vt100 - false -} - -export interface IRowRange { - start: number; - end: number; -} - -/** - * Interface for mouse events in the core. - */ -export const enum CoreMouseButton { - LEFT = 0, - MIDDLE = 1, - RIGHT = 2, - NONE = 3, - WHEEL = 4, - // additional buttons 1..8 - // untested! - AUX1 = 8, - AUX2 = 9, - AUX3 = 10, - AUX4 = 11, - AUX5 = 12, - AUX6 = 13, - AUX7 = 14, - AUX8 = 15 -} - -export const enum CoreMouseAction { - UP = 0, // buttons, wheel - DOWN = 1, // buttons, wheel - LEFT = 2, // wheel only - RIGHT = 3, // wheel only - MOVE = 32 // buttons only -} - -export interface ICoreMouseEvent { - /** column (zero based). */ - col: number; - /** row (zero based). */ - row: number; - /** - * Button the action occured. Due to restrictions of the tracking protocols - * it is not possible to report multiple buttons at once. - * Wheel is treated as a button. - * There are invalid combinations of buttons and actions possible - * (like move + wheel), those are silently ignored by the CoreMouseService. - */ - button: CoreMouseButton; - action: CoreMouseAction; - /** - * Modifier states. - * Protocols will add/ignore those based on specific restrictions. - */ - ctrl?: boolean; - alt?: boolean; - shift?: boolean; -} - -/** - * CoreMouseEventType - * To be reported to the browser component which events a mouse - * protocol wants to be catched and forwarded as an ICoreMouseEvent - * to CoreMouseService. - */ -export const enum CoreMouseEventType { - NONE = 0, - /** any mousedown event */ - DOWN = 1, - /** any mouseup event */ - UP = 2, - /** any mousemove event while a button is held */ - DRAG = 4, - /** any mousemove event without a button */ - MOVE = 8, - /** any wheel event */ - WHEEL = 16 -} - -/** - * Mouse protocol interface. - * A mouse protocol can be registered and activated at the CoreMouseService. - * `events` should contain a list of needed events as a hint for the browser component - * to install/remove the appropriate event handlers. - * `restrict` applies further protocol specific restrictions like not allowed - * modifiers or filtering invalid event types. - */ -export interface ICoreMouseProtocol { - events: CoreMouseEventType; - restrict: (e: ICoreMouseEvent) => boolean; -} - -/** - * CoreMouseEncoding - * The tracking encoding can be registered and activated at the CoreMouseService. - * If a ICoreMouseEvent passes all procotol restrictions it will be encoded - * with the active encoding and sent out. - * Note: Returning an empty string will supress sending a mouse report, - * which can be used to skip creating falsey reports in limited encodings - * (DEFAULT only supports up to 223 1-based as coord value). - */ -export type CoreMouseEncoding = (event: ICoreMouseEvent) => string; - -/** - * windowOptions - */ -export interface IWindowOptions { - restoreWin?: boolean; - minimizeWin?: boolean; - setWinPosition?: boolean; - setWinSizePixels?: boolean; - raiseWin?: boolean; - lowerWin?: boolean; - refreshWin?: boolean; - setWinSizeChars?: boolean; - maximizeWin?: boolean; - fullscreenWin?: boolean; - getWinState?: boolean; - getWinPosition?: boolean; - getWinSizePixels?: boolean; - getScreenSizePixels?: boolean; - getCellSizePixels?: boolean; - getWinSizeChars?: boolean; - getScreenSizeChars?: boolean; - getIconTitle?: boolean; - getWinTitle?: boolean; - pushTitle?: boolean; - popTitle?: boolean; - setWinLines?: boolean; -} - -export interface IAnsiColorChangeEventColor { - colorIndex: number; - red: number; - green: number; - blue: number; -} - -/** - * Event fired for OSC 4 command - to change ANSI color based on its index. - */ -export interface IAnsiColorChangeEvent { - colors: IAnsiColorChangeEventColor[]; -} - -/** - * Calls the parser and handles actions generated by the parser. - */ -export interface IInputHandler { - onTitleChange: IEvent; - onRequestScroll: IEvent; - - parse(data: string | Uint8Array): void; - print(data: Uint32Array, start: number, end: number): void; - - /** C0 BEL */ bell(): void; - /** C0 LF */ lineFeed(): void; - /** C0 CR */ carriageReturn(): void; - /** C0 BS */ backspace(): void; - /** C0 HT */ tab(): void; - /** C0 SO */ shiftOut(): void; - /** C0 SI */ shiftIn(): void; - - /** CSI @ */ insertChars(params: IParams): void; - /** CSI SP @ */ scrollLeft(params: IParams): void; - /** CSI A */ cursorUp(params: IParams): void; - /** CSI SP A */ scrollRight(params: IParams): void; - /** CSI B */ cursorDown(params: IParams): void; - /** CSI C */ cursorForward(params: IParams): void; - /** CSI D */ cursorBackward(params: IParams): void; - /** CSI E */ cursorNextLine(params: IParams): void; - /** CSI F */ cursorPrecedingLine(params: IParams): void; - /** CSI G */ cursorCharAbsolute(params: IParams): void; - /** CSI H */ cursorPosition(params: IParams): void; - /** CSI I */ cursorForwardTab(params: IParams): void; - /** CSI J */ eraseInDisplay(params: IParams): void; - /** CSI K */ eraseInLine(params: IParams): void; - /** CSI L */ insertLines(params: IParams): void; - /** CSI M */ deleteLines(params: IParams): void; - /** CSI P */ deleteChars(params: IParams): void; - /** CSI S */ scrollUp(params: IParams): void; - /** CSI T */ scrollDown(params: IParams, collect?: string): void; - /** CSI X */ eraseChars(params: IParams): void; - /** CSI Z */ cursorBackwardTab(params: IParams): void; - /** CSI ` */ charPosAbsolute(params: IParams): void; - /** CSI a */ hPositionRelative(params: IParams): void; - /** CSI b */ repeatPrecedingCharacter(params: IParams): void; - /** CSI c */ sendDeviceAttributesPrimary(params: IParams): void; - /** CSI > c */ sendDeviceAttributesSecondary(params: IParams): void; - /** CSI d */ linePosAbsolute(params: IParams): void; - /** CSI e */ vPositionRelative(params: IParams): void; - /** CSI f */ hVPosition(params: IParams): void; - /** CSI g */ tabClear(params: IParams): void; - /** CSI h */ setMode(params: IParams, collect?: string): void; - /** CSI l */ resetMode(params: IParams, collect?: string): void; - /** CSI m */ charAttributes(params: IParams): void; - /** CSI n */ deviceStatus(params: IParams, collect?: string): void; - /** CSI p */ softReset(params: IParams, collect?: string): void; - /** CSI q */ setCursorStyle(params: IParams, collect?: string): void; - /** CSI r */ setScrollRegion(params: IParams, collect?: string): void; - /** CSI s */ saveCursor(params: IParams): void; - /** CSI u */ restoreCursor(params: IParams): void; - /** CSI ' } */ insertColumns(params: IParams): void; - /** CSI ' ~ */ deleteColumns(params: IParams): void; - /** OSC 0 - OSC 2 */ setTitle(data: string): void; - /** OSC 4 */ setAnsiColor(data: string): void; - /** ESC E */ nextLine(): void; - /** ESC = */ keypadApplicationMode(): void; - /** ESC > */ keypadNumericMode(): void; - /** ESC % G - ESC % @ */ selectDefaultCharset(): void; - /** ESC ( C - ESC ) C - ESC * C - ESC + C - ESC - C - ESC . C - ESC / C */ selectCharset(collectAndFlag: string): void; - /** ESC D */ index(): void; - /** ESC H */ tabSet(): void; - /** ESC M */ reverseIndex(): void; - /** ESC c */ fullReset(): void; - /** ESC n - ESC o - ESC | - ESC } - ESC ~ */ setgLevel(level: number): void; - /** ESC # 8 */ screenAlignmentPattern(): void; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/WindowsMode.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/WindowsMode.ts deleted file mode 100755 index 7cff094b2..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/WindowsMode.ts +++ /dev/null @@ -1,27 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { CHAR_DATA_CODE_INDEX, NULL_CELL_CODE, WHITESPACE_CELL_CODE } from 'common/buffer/Constants'; -import { IBufferService } from 'common/services/Services'; - -export function updateWindowsModeWrappedState(bufferService: IBufferService): void { - // Winpty does not support wraparound mode which means that lines will never - // be marked as wrapped. This causes issues for things like copying a line - // retaining the wrapped new line characters or if consumers are listening - // in on the data stream. - // - // The workaround for this is to listen to every incoming line feed and mark - // the line as wrapped if the last character in the previous line is not a - // space. This is certainly not without its problems, but generally on - // Windows when text reaches the end of the terminal it's likely going to be - // wrapped. - const line = bufferService.buffer.lines.get(bufferService.buffer.ybase + bufferService.buffer.y - 1); - const lastChar = line?.get(bufferService.cols - 1); - - const nextLine = bufferService.buffer.lines.get(bufferService.buffer.ybase + bufferService.buffer.y); - if (nextLine && lastChar) { - nextLine.isWrapped = (lastChar[CHAR_DATA_CODE_INDEX] !== NULL_CELL_CODE && lastChar[CHAR_DATA_CODE_INDEX] !== WHITESPACE_CELL_CODE); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/AttributeData.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/AttributeData.ts deleted file mode 100755 index c7217a2a0..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/AttributeData.ts +++ /dev/null @@ -1,147 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IAttributeData, IColorRGB, IExtendedAttrs } from 'common/Types'; -import { Attributes, FgFlags, BgFlags, UnderlineStyle } from 'common/buffer/Constants'; - -export class AttributeData implements IAttributeData { - public static toColorRGB(value: number): IColorRGB { - return [ - value >>> Attributes.RED_SHIFT & 255, - value >>> Attributes.GREEN_SHIFT & 255, - value & 255 - ]; - } - - public static fromColorRGB(value: IColorRGB): number { - return (value[0] & 255) << Attributes.RED_SHIFT | (value[1] & 255) << Attributes.GREEN_SHIFT | value[2] & 255; - } - - public clone(): IAttributeData { - const newObj = new AttributeData(); - newObj.fg = this.fg; - newObj.bg = this.bg; - newObj.extended = this.extended.clone(); - return newObj; - } - - // data - public fg = 0; - public bg = 0; - public extended = new ExtendedAttrs(); - - // flags - public isInverse(): number { return this.fg & FgFlags.INVERSE; } - public isBold(): number { return this.fg & FgFlags.BOLD; } - public isUnderline(): number { return this.fg & FgFlags.UNDERLINE; } - public isBlink(): number { return this.fg & FgFlags.BLINK; } - public isInvisible(): number { return this.fg & FgFlags.INVISIBLE; } - public isItalic(): number { return this.bg & BgFlags.ITALIC; } - public isDim(): number { return this.bg & BgFlags.DIM; } - - // color modes - public getFgColorMode(): number { return this.fg & Attributes.CM_MASK; } - public getBgColorMode(): number { return this.bg & Attributes.CM_MASK; } - public isFgRGB(): boolean { return (this.fg & Attributes.CM_MASK) === Attributes.CM_RGB; } - public isBgRGB(): boolean { return (this.bg & Attributes.CM_MASK) === Attributes.CM_RGB; } - public isFgPalette(): boolean { return (this.fg & Attributes.CM_MASK) === Attributes.CM_P16 || (this.fg & Attributes.CM_MASK) === Attributes.CM_P256; } - public isBgPalette(): boolean { return (this.bg & Attributes.CM_MASK) === Attributes.CM_P16 || (this.bg & Attributes.CM_MASK) === Attributes.CM_P256; } - public isFgDefault(): boolean { return (this.fg & Attributes.CM_MASK) === 0; } - public isBgDefault(): boolean { return (this.bg & Attributes.CM_MASK) === 0; } - public isAttributeDefault(): boolean { return this.fg === 0 && this.bg === 0; } - - // colors - public getFgColor(): number { - switch (this.fg & Attributes.CM_MASK) { - case Attributes.CM_P16: - case Attributes.CM_P256: return this.fg & Attributes.PCOLOR_MASK; - case Attributes.CM_RGB: return this.fg & Attributes.RGB_MASK; - default: return -1; // CM_DEFAULT defaults to -1 - } - } - public getBgColor(): number { - switch (this.bg & Attributes.CM_MASK) { - case Attributes.CM_P16: - case Attributes.CM_P256: return this.bg & Attributes.PCOLOR_MASK; - case Attributes.CM_RGB: return this.bg & Attributes.RGB_MASK; - default: return -1; // CM_DEFAULT defaults to -1 - } - } - - // extended attrs - public hasExtendedAttrs(): number { - return this.bg & BgFlags.HAS_EXTENDED; - } - public updateExtended(): void { - if (this.extended.isEmpty()) { - this.bg &= ~BgFlags.HAS_EXTENDED; - } else { - this.bg |= BgFlags.HAS_EXTENDED; - } - } - public getUnderlineColor(): number { - if ((this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor) { - switch (this.extended.underlineColor & Attributes.CM_MASK) { - case Attributes.CM_P16: - case Attributes.CM_P256: return this.extended.underlineColor & Attributes.PCOLOR_MASK; - case Attributes.CM_RGB: return this.extended.underlineColor & Attributes.RGB_MASK; - default: return this.getFgColor(); - } - } - return this.getFgColor(); - } - public getUnderlineColorMode(): number { - return (this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor - ? this.extended.underlineColor & Attributes.CM_MASK - : this.getFgColorMode(); - } - public isUnderlineColorRGB(): boolean { - return (this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor - ? (this.extended.underlineColor & Attributes.CM_MASK) === Attributes.CM_RGB - : this.isFgRGB(); - } - public isUnderlineColorPalette(): boolean { - return (this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor - ? (this.extended.underlineColor & Attributes.CM_MASK) === Attributes.CM_P16 - || (this.extended.underlineColor & Attributes.CM_MASK) === Attributes.CM_P256 - : this.isFgPalette(); - } - public isUnderlineColorDefault(): boolean { - return (this.bg & BgFlags.HAS_EXTENDED) && ~this.extended.underlineColor - ? (this.extended.underlineColor & Attributes.CM_MASK) === 0 - : this.isFgDefault(); - } - public getUnderlineStyle(): UnderlineStyle { - return this.fg & FgFlags.UNDERLINE - ? (this.bg & BgFlags.HAS_EXTENDED ? this.extended.underlineStyle : UnderlineStyle.SINGLE) - : UnderlineStyle.NONE; - } -} - - -/** - * Extended attributes for a cell. - * Holds information about different underline styles and color. - */ -export class ExtendedAttrs implements IExtendedAttrs { - constructor( - // underline style, NONE is empty - public underlineStyle: UnderlineStyle = UnderlineStyle.NONE, - // underline color, -1 is empty (same as FG) - public underlineColor: number = -1 - ) {} - - public clone(): IExtendedAttrs { - return new ExtendedAttrs(this.underlineStyle, this.underlineColor); - } - - /** - * Convenient method to indicate whether the object holds no additional information, - * that needs to be persistant in the buffer. - */ - public isEmpty(): boolean { - return this.underlineStyle === UnderlineStyle.NONE; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Buffer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Buffer.ts deleted file mode 100755 index e06ffb018..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Buffer.ts +++ /dev/null @@ -1,676 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { CircularList, IInsertEvent } from 'common/CircularList'; -import { IBuffer, BufferIndex, IBufferStringIterator, IBufferStringIteratorResult } from 'common/buffer/Types'; -import { IBufferLine, ICellData, IAttributeData, ICharset } from 'common/Types'; -import { BufferLine, DEFAULT_ATTR_DATA } from 'common/buffer/BufferLine'; -import { CellData } from 'common/buffer/CellData'; -import { NULL_CELL_CHAR, NULL_CELL_WIDTH, NULL_CELL_CODE, WHITESPACE_CELL_CHAR, WHITESPACE_CELL_WIDTH, WHITESPACE_CELL_CODE, CHAR_DATA_WIDTH_INDEX, CHAR_DATA_CHAR_INDEX } from 'common/buffer/Constants'; -import { reflowLargerApplyNewLayout, reflowLargerCreateNewLayout, reflowLargerGetLinesToRemove, reflowSmallerGetNewLineLengths, getWrappedLineTrimmedLength } from 'common/buffer/BufferReflow'; -import { Marker } from 'common/buffer/Marker'; -import { IOptionsService, IBufferService } from 'common/services/Services'; -import { DEFAULT_CHARSET } from 'common/data/Charsets'; -import { ExtendedAttrs } from 'common/buffer/AttributeData'; - -export const MAX_BUFFER_SIZE = 4294967295; // 2^32 - 1 - -/** - * This class represents a terminal buffer (an internal state of the terminal), where the - * following information is stored (in high-level): - * - text content of this particular buffer - * - cursor position - * - scroll position - */ -export class Buffer implements IBuffer { - public lines: CircularList; - public ydisp: number = 0; - public ybase: number = 0; - public y: number = 0; - public x: number = 0; - public scrollBottom: number; - public scrollTop: number; - // TODO: Type me - public tabs: any; - public savedY: number = 0; - public savedX: number = 0; - public savedCurAttrData = DEFAULT_ATTR_DATA.clone(); - public savedCharset: ICharset | undefined = DEFAULT_CHARSET; - public markers: Marker[] = []; - private _nullCell: ICellData = CellData.fromCharData([0, NULL_CELL_CHAR, NULL_CELL_WIDTH, NULL_CELL_CODE]); - private _whitespaceCell: ICellData = CellData.fromCharData([0, WHITESPACE_CELL_CHAR, WHITESPACE_CELL_WIDTH, WHITESPACE_CELL_CODE]); - private _cols: number; - private _rows: number; - - constructor( - private _hasScrollback: boolean, - private _optionsService: IOptionsService, - private _bufferService: IBufferService - ) { - this._cols = this._bufferService.cols; - this._rows = this._bufferService.rows; - this.lines = new CircularList(this._getCorrectBufferLength(this._rows)); - this.scrollTop = 0; - this.scrollBottom = this._rows - 1; - this.setupTabStops(); - } - - public getNullCell(attr?: IAttributeData): ICellData { - if (attr) { - this._nullCell.fg = attr.fg; - this._nullCell.bg = attr.bg; - this._nullCell.extended = attr.extended; - } else { - this._nullCell.fg = 0; - this._nullCell.bg = 0; - this._nullCell.extended = new ExtendedAttrs(); - } - return this._nullCell; - } - - public getWhitespaceCell(attr?: IAttributeData): ICellData { - if (attr) { - this._whitespaceCell.fg = attr.fg; - this._whitespaceCell.bg = attr.bg; - this._whitespaceCell.extended = attr.extended; - } else { - this._whitespaceCell.fg = 0; - this._whitespaceCell.bg = 0; - this._whitespaceCell.extended = new ExtendedAttrs(); - } - return this._whitespaceCell; - } - - public getBlankLine(attr: IAttributeData, isWrapped?: boolean): IBufferLine { - return new BufferLine(this._bufferService.cols, this.getNullCell(attr), isWrapped); - } - - public get hasScrollback(): boolean { - return this._hasScrollback && this.lines.maxLength > this._rows; - } - - public get isCursorInViewport(): boolean { - const absoluteY = this.ybase + this.y; - const relativeY = absoluteY - this.ydisp; - return (relativeY >= 0 && relativeY < this._rows); - } - - /** - * Gets the correct buffer length based on the rows provided, the terminal's - * scrollback and whether this buffer is flagged to have scrollback or not. - * @param rows The terminal rows to use in the calculation. - */ - private _getCorrectBufferLength(rows: number): number { - if (!this._hasScrollback) { - return rows; - } - - const correctBufferLength = rows + this._optionsService.options.scrollback; - - return correctBufferLength > MAX_BUFFER_SIZE ? MAX_BUFFER_SIZE : correctBufferLength; - } - - /** - * Fills the buffer's viewport with blank lines. - */ - public fillViewportRows(fillAttr?: IAttributeData): void { - if (this.lines.length === 0) { - if (fillAttr === undefined) { - fillAttr = DEFAULT_ATTR_DATA; - } - let i = this._rows; - while (i--) { - this.lines.push(this.getBlankLine(fillAttr)); - } - } - } - - /** - * Clears the buffer to it's initial state, discarding all previous data. - */ - public clear(): void { - this.ydisp = 0; - this.ybase = 0; - this.y = 0; - this.x = 0; - this.lines = new CircularList(this._getCorrectBufferLength(this._rows)); - this.scrollTop = 0; - this.scrollBottom = this._rows - 1; - this.setupTabStops(); - } - - /** - * Resizes the buffer, adjusting its data accordingly. - * @param newCols The new number of columns. - * @param newRows The new number of rows. - */ - public resize(newCols: number, newRows: number): void { - // store reference to null cell with default attrs - const nullCell = this.getNullCell(DEFAULT_ATTR_DATA); - - // Increase max length if needed before adjustments to allow space to fill - // as required. - const newMaxLength = this._getCorrectBufferLength(newRows); - if (newMaxLength > this.lines.maxLength) { - this.lines.maxLength = newMaxLength; - } - - // The following adjustments should only happen if the buffer has been - // initialized/filled. - if (this.lines.length > 0) { - // Deal with columns increasing (reducing needs to happen after reflow) - if (this._cols < newCols) { - for (let i = 0; i < this.lines.length; i++) { - this.lines.get(i)!.resize(newCols, nullCell); - } - } - - // Resize rows in both directions as needed - let addToY = 0; - if (this._rows < newRows) { - for (let y = this._rows; y < newRows; y++) { - if (this.lines.length < newRows + this.ybase) { - if (this._optionsService.options.windowsMode) { - // Just add the new missing rows on Windows as conpty reprints the screen with it's - // view of the world. Once a line enters scrollback for conpty it remains there - this.lines.push(new BufferLine(newCols, nullCell)); - } else { - if (this.ybase > 0 && this.lines.length <= this.ybase + this.y + addToY + 1) { - // There is room above the buffer and there are no empty elements below the line, - // scroll up - this.ybase--; - addToY++; - if (this.ydisp > 0) { - // Viewport is at the top of the buffer, must increase downwards - this.ydisp--; - } - } else { - // Add a blank line if there is no buffer left at the top to scroll to, or if there - // are blank lines after the cursor - this.lines.push(new BufferLine(newCols, nullCell)); - } - } - } - } - } else { // (this._rows >= newRows) - for (let y = this._rows; y > newRows; y--) { - if (this.lines.length > newRows + this.ybase) { - if (this.lines.length > this.ybase + this.y + 1) { - // The line is a blank line below the cursor, remove it - this.lines.pop(); - } else { - // The line is the cursor, scroll down - this.ybase++; - this.ydisp++; - } - } - } - } - - // Reduce max length if needed after adjustments, this is done after as it - // would otherwise cut data from the bottom of the buffer. - if (newMaxLength < this.lines.maxLength) { - // Trim from the top of the buffer and adjust ybase and ydisp. - const amountToTrim = this.lines.length - newMaxLength; - if (amountToTrim > 0) { - this.lines.trimStart(amountToTrim); - this.ybase = Math.max(this.ybase - amountToTrim, 0); - this.ydisp = Math.max(this.ydisp - amountToTrim, 0); - this.savedY = Math.max(this.savedY - amountToTrim, 0); - } - this.lines.maxLength = newMaxLength; - } - - // Make sure that the cursor stays on screen - this.x = Math.min(this.x, newCols - 1); - this.y = Math.min(this.y, newRows - 1); - if (addToY) { - this.y += addToY; - } - this.savedX = Math.min(this.savedX, newCols - 1); - - this.scrollTop = 0; - } - - this.scrollBottom = newRows - 1; - - if (this._isReflowEnabled) { - this._reflow(newCols, newRows); - - // Trim the end of the line off if cols shrunk - if (this._cols > newCols) { - for (let i = 0; i < this.lines.length; i++) { - this.lines.get(i)!.resize(newCols, nullCell); - } - } - } - - this._cols = newCols; - this._rows = newRows; - } - - private get _isReflowEnabled(): boolean { - return this._hasScrollback && !this._optionsService.options.windowsMode; - } - - private _reflow(newCols: number, newRows: number): void { - if (this._cols === newCols) { - return; - } - - // Iterate through rows, ignore the last one as it cannot be wrapped - if (newCols > this._cols) { - this._reflowLarger(newCols, newRows); - } else { - this._reflowSmaller(newCols, newRows); - } - } - - private _reflowLarger(newCols: number, newRows: number): void { - const toRemove: number[] = reflowLargerGetLinesToRemove(this.lines, this._cols, newCols, this.ybase + this.y, this.getNullCell(DEFAULT_ATTR_DATA)); - if (toRemove.length > 0) { - const newLayoutResult = reflowLargerCreateNewLayout(this.lines, toRemove); - reflowLargerApplyNewLayout(this.lines, newLayoutResult.layout); - this._reflowLargerAdjustViewport(newCols, newRows, newLayoutResult.countRemoved); - } - } - - private _reflowLargerAdjustViewport(newCols: number, newRows: number, countRemoved: number): void { - const nullCell = this.getNullCell(DEFAULT_ATTR_DATA); - // Adjust viewport based on number of items removed - let viewportAdjustments = countRemoved; - while (viewportAdjustments-- > 0) { - if (this.ybase === 0) { - if (this.y > 0) { - this.y--; - } - if (this.lines.length < newRows) { - // Add an extra row at the bottom of the viewport - this.lines.push(new BufferLine(newCols, nullCell)); - } - } else { - if (this.ydisp === this.ybase) { - this.ydisp--; - } - this.ybase--; - } - } - this.savedY = Math.max(this.savedY - countRemoved, 0); - } - - private _reflowSmaller(newCols: number, newRows: number): void { - const nullCell = this.getNullCell(DEFAULT_ATTR_DATA); - // Gather all BufferLines that need to be inserted into the Buffer here so that they can be - // batched up and only committed once - const toInsert = []; - let countToInsert = 0; - // Go backwards as many lines may be trimmed and this will avoid considering them - for (let y = this.lines.length - 1; y >= 0; y--) { - // Check whether this line is a problem - let nextLine = this.lines.get(y) as BufferLine; - if (!nextLine || !nextLine.isWrapped && nextLine.getTrimmedLength() <= newCols) { - continue; - } - - // Gather wrapped lines and adjust y to be the starting line - const wrappedLines: BufferLine[] = [nextLine]; - while (nextLine.isWrapped && y > 0) { - nextLine = this.lines.get(--y) as BufferLine; - wrappedLines.unshift(nextLine); - } - - // If these lines contain the cursor don't touch them, the program will handle fixing up - // wrapped lines with the cursor - const absoluteY = this.ybase + this.y; - if (absoluteY >= y && absoluteY < y + wrappedLines.length) { - continue; - } - - const lastLineLength = wrappedLines[wrappedLines.length - 1].getTrimmedLength(); - const destLineLengths = reflowSmallerGetNewLineLengths(wrappedLines, this._cols, newCols); - const linesToAdd = destLineLengths.length - wrappedLines.length; - let trimmedLines: number; - if (this.ybase === 0 && this.y !== this.lines.length - 1) { - // If the top section of the buffer is not yet filled - trimmedLines = Math.max(0, this.y - this.lines.maxLength + linesToAdd); - } else { - trimmedLines = Math.max(0, this.lines.length - this.lines.maxLength + linesToAdd); - } - - // Add the new lines - const newLines: BufferLine[] = []; - for (let i = 0; i < linesToAdd; i++) { - const newLine = this.getBlankLine(DEFAULT_ATTR_DATA, true) as BufferLine; - newLines.push(newLine); - } - if (newLines.length > 0) { - toInsert.push({ - // countToInsert here gets the actual index, taking into account other inserted items. - // using this we can iterate through the list forwards - start: y + wrappedLines.length + countToInsert, - newLines - }); - countToInsert += newLines.length; - } - wrappedLines.push(...newLines); - - // Copy buffer data to new locations, this needs to happen backwards to do in-place - let destLineIndex = destLineLengths.length - 1; // Math.floor(cellsNeeded / newCols); - let destCol = destLineLengths[destLineIndex]; // cellsNeeded % newCols; - if (destCol === 0) { - destLineIndex--; - destCol = destLineLengths[destLineIndex]; - } - let srcLineIndex = wrappedLines.length - linesToAdd - 1; - let srcCol = lastLineLength; - while (srcLineIndex >= 0) { - const cellsToCopy = Math.min(srcCol, destCol); - wrappedLines[destLineIndex].copyCellsFrom(wrappedLines[srcLineIndex], srcCol - cellsToCopy, destCol - cellsToCopy, cellsToCopy, true); - destCol -= cellsToCopy; - if (destCol === 0) { - destLineIndex--; - destCol = destLineLengths[destLineIndex]; - } - srcCol -= cellsToCopy; - if (srcCol === 0) { - srcLineIndex--; - const wrappedLinesIndex = Math.max(srcLineIndex, 0); - srcCol = getWrappedLineTrimmedLength(wrappedLines, wrappedLinesIndex, this._cols); - } - } - - // Null out the end of the line ends if a wide character wrapped to the following line - for (let i = 0; i < wrappedLines.length; i++) { - if (destLineLengths[i] < newCols) { - wrappedLines[i].setCell(destLineLengths[i], nullCell); - } - } - - // Adjust viewport as needed - let viewportAdjustments = linesToAdd - trimmedLines; - while (viewportAdjustments-- > 0) { - if (this.ybase === 0) { - if (this.y < newRows - 1) { - this.y++; - this.lines.pop(); - } else { - this.ybase++; - this.ydisp++; - } - } else { - // Ensure ybase does not exceed its maximum value - if (this.ybase < Math.min(this.lines.maxLength, this.lines.length + countToInsert) - newRows) { - if (this.ybase === this.ydisp) { - this.ydisp++; - } - this.ybase++; - } - } - } - this.savedY = Math.min(this.savedY + linesToAdd, this.ybase + newRows - 1); - } - - // Rearrange lines in the buffer if there are any insertions, this is done at the end rather - // than earlier so that it's a single O(n) pass through the buffer, instead of O(n^2) from many - // costly calls to CircularList.splice. - if (toInsert.length > 0) { - // Record buffer insert events and then play them back backwards so that the indexes are - // correct - const insertEvents: IInsertEvent[] = []; - - // Record original lines so they don't get overridden when we rearrange the list - const originalLines: BufferLine[] = []; - for (let i = 0; i < this.lines.length; i++) { - originalLines.push(this.lines.get(i) as BufferLine); - } - const originalLinesLength = this.lines.length; - - let originalLineIndex = originalLinesLength - 1; - let nextToInsertIndex = 0; - let nextToInsert = toInsert[nextToInsertIndex]; - this.lines.length = Math.min(this.lines.maxLength, this.lines.length + countToInsert); - let countInsertedSoFar = 0; - for (let i = Math.min(this.lines.maxLength - 1, originalLinesLength + countToInsert - 1); i >= 0; i--) { - if (nextToInsert && nextToInsert.start > originalLineIndex + countInsertedSoFar) { - // Insert extra lines here, adjusting i as needed - for (let nextI = nextToInsert.newLines.length - 1; nextI >= 0; nextI--) { - this.lines.set(i--, nextToInsert.newLines[nextI]); - } - i++; - - // Create insert events for later - insertEvents.push({ - index: originalLineIndex + 1, - amount: nextToInsert.newLines.length - }); - - countInsertedSoFar += nextToInsert.newLines.length; - nextToInsert = toInsert[++nextToInsertIndex]; - } else { - this.lines.set(i, originalLines[originalLineIndex--]); - } - } - - // Update markers - let insertCountEmitted = 0; - for (let i = insertEvents.length - 1; i >= 0; i--) { - insertEvents[i].index += insertCountEmitted; - this.lines.onInsertEmitter.fire(insertEvents[i]); - insertCountEmitted += insertEvents[i].amount; - } - const amountToTrim = Math.max(0, originalLinesLength + countToInsert - this.lines.maxLength); - if (amountToTrim > 0) { - this.lines.onTrimEmitter.fire(amountToTrim); - } - } - } - - // private _reflowSmallerGetLinesNeeded() - - /** - * Translates a string index back to a BufferIndex. - * To get the correct buffer position the string must start at `startCol` 0 - * (default in translateBufferLineToString). - * The method also works on wrapped line strings given rows were not trimmed. - * The method operates on the CharData string length, there are no - * additional content or boundary checks. Therefore the string and the buffer - * should not be altered in between. - * TODO: respect trim flag after fixing #1685 - * @param lineIndex line index the string was retrieved from - * @param stringIndex index within the string - * @param startCol column offset the string was retrieved from - */ - public stringIndexToBufferIndex(lineIndex: number, stringIndex: number, trimRight: boolean = false): BufferIndex { - while (stringIndex) { - const line = this.lines.get(lineIndex); - if (!line) { - return [-1, -1]; - } - const length = (trimRight) ? line.getTrimmedLength() : line.length; - for (let i = 0; i < length; ++i) { - if (line.get(i)[CHAR_DATA_WIDTH_INDEX]) { - // empty cells report a string length of 0, but get replaced - // with a whitespace in translateToString, thus replace with 1 - stringIndex -= line.get(i)[CHAR_DATA_CHAR_INDEX].length || 1; - } - if (stringIndex < 0) { - return [lineIndex, i]; - } - } - lineIndex++; - } - return [lineIndex, 0]; - } - - /** - * Translates a buffer line to a string, with optional start and end columns. - * Wide characters will count as two columns in the resulting string. This - * function is useful for getting the actual text underneath the raw selection - * position. - * @param line The line being translated. - * @param trimRight Whether to trim whitespace to the right. - * @param startCol The column to start at. - * @param endCol The column to end at. - */ - public translateBufferLineToString(lineIndex: number, trimRight: boolean, startCol: number = 0, endCol?: number): string { - const line = this.lines.get(lineIndex); - if (!line) { - return ''; - } - return line.translateToString(trimRight, startCol, endCol); - } - - public getWrappedRangeForLine(y: number): { first: number, last: number } { - let first = y; - let last = y; - // Scan upwards for wrapped lines - while (first > 0 && this.lines.get(first)!.isWrapped) { - first--; - } - // Scan downwards for wrapped lines - while (last + 1 < this.lines.length && this.lines.get(last + 1)!.isWrapped) { - last++; - } - return { first, last }; - } - - /** - * Setup the tab stops. - * @param i The index to start setting up tab stops from. - */ - public setupTabStops(i?: number): void { - if (i !== null && i !== undefined) { - if (!this.tabs[i]) { - i = this.prevStop(i); - } - } else { - this.tabs = {}; - i = 0; - } - - for (; i < this._cols; i += this._optionsService.options.tabStopWidth) { - this.tabs[i] = true; - } - } - - /** - * Move the cursor to the previous tab stop from the given position (default is current). - * @param x The position to move the cursor to the previous tab stop. - */ - public prevStop(x?: number): number { - if (x === null || x === undefined) { - x = this.x; - } - while (!this.tabs[--x] && x > 0); - return x >= this._cols ? this._cols - 1 : x < 0 ? 0 : x; - } - - /** - * Move the cursor one tab stop forward from the given position (default is current). - * @param x The position to move the cursor one tab stop forward. - */ - public nextStop(x?: number): number { - if (x === null || x === undefined) { - x = this.x; - } - while (!this.tabs[++x] && x < this._cols); - return x >= this._cols ? this._cols - 1 : x < 0 ? 0 : x; - } - - public addMarker(y: number): Marker { - const marker = new Marker(y); - this.markers.push(marker); - marker.register(this.lines.onTrim(amount => { - marker.line -= amount; - // The marker should be disposed when the line is trimmed from the buffer - if (marker.line < 0) { - marker.dispose(); - } - })); - marker.register(this.lines.onInsert(event => { - if (marker.line >= event.index) { - marker.line += event.amount; - } - })); - marker.register(this.lines.onDelete(event => { - // Delete the marker if it's within the range - if (marker.line >= event.index && marker.line < event.index + event.amount) { - marker.dispose(); - } - - // Shift the marker if it's after the deleted range - if (marker.line > event.index) { - marker.line -= event.amount; - } - })); - marker.register(marker.onDispose(() => this._removeMarker(marker))); - return marker; - } - - private _removeMarker(marker: Marker): void { - this.markers.splice(this.markers.indexOf(marker), 1); - } - - public iterator(trimRight: boolean, startIndex?: number, endIndex?: number, startOverscan?: number, endOverscan?: number): IBufferStringIterator { - return new BufferStringIterator(this, trimRight, startIndex, endIndex, startOverscan, endOverscan); - } -} - -/** - * Iterator to get unwrapped content strings from the buffer. - * The iterator returns at least the string data between the borders - * `startIndex` and `endIndex` (exclusive) and will expand the lines - * by `startOverscan` to the top and by `endOverscan` to the bottom, - * if no new line was found in between. - * It will never read/return string data beyond `startIndex - startOverscan` - * or `endIndex + endOverscan`. Therefore the first and last line might be truncated. - * It is possible to always get the full string for the first and last line as well - * by setting the overscan values to the actual buffer length. This not recommended - * since it might return the whole buffer within a single string in a worst case scenario. - */ -export class BufferStringIterator implements IBufferStringIterator { - private _current: number; - - constructor ( - private _buffer: IBuffer, - private _trimRight: boolean, - private _startIndex: number = 0, - private _endIndex: number = _buffer.lines.length, - private _startOverscan: number = 0, - private _endOverscan: number = 0 - ) { - if (this._startIndex < 0) { - this._startIndex = 0; - } - if (this._endIndex > this._buffer.lines.length) { - this._endIndex = this._buffer.lines.length; - } - this._current = this._startIndex; - } - - public hasNext(): boolean { - return this._current < this._endIndex; - } - - public next(): IBufferStringIteratorResult { - const range = this._buffer.getWrappedRangeForLine(this._current); - // limit search window to overscan value at both borders - if (range.first < this._startIndex - this._startOverscan) { - range.first = this._startIndex - this._startOverscan; - } - if (range.last > this._endIndex + this._endOverscan) { - range.last = this._endIndex + this._endOverscan; - } - // limit to current buffer length - range.first = Math.max(range.first, 0); - range.last = Math.min(range.last, this._buffer.lines.length); - let content = ''; - for (let i = range.first; i <= range.last; ++i) { - content += this._buffer.translateBufferLineToString(i, this._trimRight); - } - this._current = range.last + 1; - return {range, content}; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/BufferLine.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/BufferLine.ts deleted file mode 100755 index f0bf4fcb6..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/BufferLine.ts +++ /dev/null @@ -1,441 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { CharData, IBufferLine, ICellData, IAttributeData, IExtendedAttrs } from 'common/Types'; -import { stringFromCodePoint } from 'common/input/TextDecoder'; -import { CHAR_DATA_CHAR_INDEX, CHAR_DATA_WIDTH_INDEX, CHAR_DATA_ATTR_INDEX, NULL_CELL_CHAR, NULL_CELL_WIDTH, NULL_CELL_CODE, WHITESPACE_CELL_CHAR, Content, BgFlags } from 'common/buffer/Constants'; -import { CellData } from 'common/buffer/CellData'; -import { AttributeData, ExtendedAttrs } from 'common/buffer/AttributeData'; - -/** - * buffer memory layout: - * - * | uint32_t | uint32_t | uint32_t | - * | `content` | `FG` | `BG` | - * | wcwidth(2) comb(1) codepoint(21) | flags(8) R(8) G(8) B(8) | flags(8) R(8) G(8) B(8) | - */ - - -/** typed array slots taken by one cell */ -const CELL_SIZE = 3; - -/** - * Cell member indices. - * - * Direct access: - * `content = data[column * CELL_SIZE + Cell.CONTENT];` - * `fg = data[column * CELL_SIZE + Cell.FG];` - * `bg = data[column * CELL_SIZE + Cell.BG];` - */ -const enum Cell { - CONTENT = 0, - FG = 1, // currently simply holds all known attrs - BG = 2 // currently unused -} - -export const DEFAULT_ATTR_DATA = Object.freeze(new AttributeData()); - -/** - * Typed array based bufferline implementation. - * - * There are 2 ways to insert data into the cell buffer: - * - `setCellFromCodepoint` + `addCodepointToCell` - * Use these for data that is already UTF32. - * Used during normal input in `InputHandler` for faster buffer access. - * - `setCell` - * This method takes a CellData object and stores the data in the buffer. - * Use `CellData.fromCharData` to create the CellData object (e.g. from JS string). - * - * To retrieve data from the buffer use either one of the primitive methods - * (if only one particular value is needed) or `loadCell`. For `loadCell` in a loop - * memory allocs / GC pressure can be greatly reduced by reusing the CellData object. - */ -export class BufferLine implements IBufferLine { - protected _data: Uint32Array; - protected _combined: {[index: number]: string} = {}; - protected _extendedAttrs: {[index: number]: ExtendedAttrs} = {}; - public length: number; - - constructor(cols: number, fillCellData?: ICellData, public isWrapped: boolean = false) { - this._data = new Uint32Array(cols * CELL_SIZE); - const cell = fillCellData || CellData.fromCharData([0, NULL_CELL_CHAR, NULL_CELL_WIDTH, NULL_CELL_CODE]); - for (let i = 0; i < cols; ++i) { - this.setCell(i, cell); - } - this.length = cols; - } - - /** - * Get cell data CharData. - * @deprecated - */ - public get(index: number): CharData { - const content = this._data[index * CELL_SIZE + Cell.CONTENT]; - const cp = content & Content.CODEPOINT_MASK; - return [ - this._data[index * CELL_SIZE + Cell.FG], - (content & Content.IS_COMBINED_MASK) - ? this._combined[index] - : (cp) ? stringFromCodePoint(cp) : '', - content >> Content.WIDTH_SHIFT, - (content & Content.IS_COMBINED_MASK) - ? this._combined[index].charCodeAt(this._combined[index].length - 1) - : cp - ]; - } - - /** - * Set cell data from CharData. - * @deprecated - */ - public set(index: number, value: CharData): void { - this._data[index * CELL_SIZE + Cell.FG] = value[CHAR_DATA_ATTR_INDEX]; - if (value[CHAR_DATA_CHAR_INDEX].length > 1) { - this._combined[index] = value[1]; - this._data[index * CELL_SIZE + Cell.CONTENT] = index | Content.IS_COMBINED_MASK | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT); - } else { - this._data[index * CELL_SIZE + Cell.CONTENT] = value[CHAR_DATA_CHAR_INDEX].charCodeAt(0) | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT); - } - } - - /** - * primitive getters - * use these when only one value is needed, otherwise use `loadCell` - */ - public getWidth(index: number): number { - return this._data[index * CELL_SIZE + Cell.CONTENT] >> Content.WIDTH_SHIFT; - } - - /** Test whether content has width. */ - public hasWidth(index: number): number { - return this._data[index * CELL_SIZE + Cell.CONTENT] & Content.WIDTH_MASK; - } - - /** Get FG cell component. */ - public getFg(index: number): number { - return this._data[index * CELL_SIZE + Cell.FG]; - } - - /** Get BG cell component. */ - public getBg(index: number): number { - return this._data[index * CELL_SIZE + Cell.BG]; - } - - /** - * Test whether contains any chars. - * Basically an empty has no content, but other cells might differ in FG/BG - * from real empty cells. - * */ - public hasContent(index: number): number { - return this._data[index * CELL_SIZE + Cell.CONTENT] & Content.HAS_CONTENT_MASK; - } - - /** - * Get codepoint of the cell. - * To be in line with `code` in CharData this either returns - * a single UTF32 codepoint or the last codepoint of a combined string. - */ - public getCodePoint(index: number): number { - const content = this._data[index * CELL_SIZE + Cell.CONTENT]; - if (content & Content.IS_COMBINED_MASK) { - return this._combined[index].charCodeAt(this._combined[index].length - 1); - } - return content & Content.CODEPOINT_MASK; - } - - /** Test whether the cell contains a combined string. */ - public isCombined(index: number): number { - return this._data[index * CELL_SIZE + Cell.CONTENT] & Content.IS_COMBINED_MASK; - } - - /** Returns the string content of the cell. */ - public getString(index: number): string { - const content = this._data[index * CELL_SIZE + Cell.CONTENT]; - if (content & Content.IS_COMBINED_MASK) { - return this._combined[index]; - } - if (content & Content.CODEPOINT_MASK) { - return stringFromCodePoint(content & Content.CODEPOINT_MASK); - } - // return empty string for empty cells - return ''; - } - - /** - * Load data at `index` into `cell`. This is used to access cells in a way that's more friendly - * to GC as it significantly reduced the amount of new objects/references needed. - */ - public loadCell(index: number, cell: ICellData): ICellData { - const startIndex = index * CELL_SIZE; - cell.content = this._data[startIndex + Cell.CONTENT]; - cell.fg = this._data[startIndex + Cell.FG]; - cell.bg = this._data[startIndex + Cell.BG]; - if (cell.content & Content.IS_COMBINED_MASK) { - cell.combinedData = this._combined[index]; - } - if (cell.bg & BgFlags.HAS_EXTENDED) { - cell.extended = this._extendedAttrs[index]; - } - return cell; - } - - /** - * Set data at `index` to `cell`. - */ - public setCell(index: number, cell: ICellData): void { - if (cell.content & Content.IS_COMBINED_MASK) { - this._combined[index] = cell.combinedData; - } - if (cell.bg & BgFlags.HAS_EXTENDED) { - this._extendedAttrs[index] = cell.extended; - } - this._data[index * CELL_SIZE + Cell.CONTENT] = cell.content; - this._data[index * CELL_SIZE + Cell.FG] = cell.fg; - this._data[index * CELL_SIZE + Cell.BG] = cell.bg; - } - - /** - * Set cell data from input handler. - * Since the input handler see the incoming chars as UTF32 codepoints, - * it gets an optimized access method. - */ - public setCellFromCodePoint(index: number, codePoint: number, width: number, fg: number, bg: number, eAttrs: IExtendedAttrs): void { - if (bg & BgFlags.HAS_EXTENDED) { - this._extendedAttrs[index] = eAttrs; - } - this._data[index * CELL_SIZE + Cell.CONTENT] = codePoint | (width << Content.WIDTH_SHIFT); - this._data[index * CELL_SIZE + Cell.FG] = fg; - this._data[index * CELL_SIZE + Cell.BG] = bg; - } - - /** - * Add a codepoint to a cell from input handler. - * During input stage combining chars with a width of 0 follow and stack - * onto a leading char. Since we already set the attrs - * by the previous `setDataFromCodePoint` call, we can omit it here. - */ - public addCodepointToCell(index: number, codePoint: number): void { - let content = this._data[index * CELL_SIZE + Cell.CONTENT]; - if (content & Content.IS_COMBINED_MASK) { - // we already have a combined string, simply add - this._combined[index] += stringFromCodePoint(codePoint); - } else { - if (content & Content.CODEPOINT_MASK) { - // normal case for combining chars: - // - move current leading char + new one into combined string - // - set combined flag - this._combined[index] = stringFromCodePoint(content & Content.CODEPOINT_MASK) + stringFromCodePoint(codePoint); - content &= ~Content.CODEPOINT_MASK; // set codepoint in buffer to 0 - content |= Content.IS_COMBINED_MASK; - } else { - // should not happen - we actually have no data in the cell yet - // simply set the data in the cell buffer with a width of 1 - content = codePoint | (1 << Content.WIDTH_SHIFT); - } - this._data[index * CELL_SIZE + Cell.CONTENT] = content; - } - } - - public insertCells(pos: number, n: number, fillCellData: ICellData, eraseAttr?: IAttributeData): void { - pos %= this.length; - - // handle fullwidth at pos: reset cell one to the left if pos is second cell of a wide char - if (pos && this.getWidth(pos - 1) === 2) { - this.setCellFromCodePoint(pos - 1, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs()); - } - - if (n < this.length - pos) { - const cell = new CellData(); - for (let i = this.length - pos - n - 1; i >= 0; --i) { - this.setCell(pos + n + i, this.loadCell(pos + i, cell)); - } - for (let i = 0; i < n; ++i) { - this.setCell(pos + i, fillCellData); - } - } else { - for (let i = pos; i < this.length; ++i) { - this.setCell(i, fillCellData); - } - } - - // handle fullwidth at line end: reset last cell if it is first cell of a wide char - if (this.getWidth(this.length - 1) === 2) { - this.setCellFromCodePoint(this.length - 1, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs()); - } - } - - public deleteCells(pos: number, n: number, fillCellData: ICellData, eraseAttr?: IAttributeData): void { - pos %= this.length; - if (n < this.length - pos) { - const cell = new CellData(); - for (let i = 0; i < this.length - pos - n; ++i) { - this.setCell(pos + i, this.loadCell(pos + n + i, cell)); - } - for (let i = this.length - n; i < this.length; ++i) { - this.setCell(i, fillCellData); - } - } else { - for (let i = pos; i < this.length; ++i) { - this.setCell(i, fillCellData); - } - } - - // handle fullwidth at pos: - // - reset pos-1 if wide char - // - reset pos if width==0 (previous second cell of a wide char) - if (pos && this.getWidth(pos - 1) === 2) { - this.setCellFromCodePoint(pos - 1, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs()); - } - if (this.getWidth(pos) === 0 && !this.hasContent(pos)) { - this.setCellFromCodePoint(pos, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs()); - } - } - - public replaceCells(start: number, end: number, fillCellData: ICellData, eraseAttr?: IAttributeData): void { - // handle fullwidth at start: reset cell one to the left if start is second cell of a wide char - if (start && this.getWidth(start - 1) === 2) { - this.setCellFromCodePoint(start - 1, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs()); - } - // handle fullwidth at last cell + 1: reset to empty cell if it is second part of a wide char - if (end < this.length && this.getWidth(end - 1) === 2) { - this.setCellFromCodePoint(end, 0, 1, eraseAttr?.fg || 0, eraseAttr?.bg || 0, eraseAttr?.extended || new ExtendedAttrs()); - } - - while (start < end && start < this.length) { - this.setCell(start++, fillCellData); - } - } - - public resize(cols: number, fillCellData: ICellData): void { - if (cols === this.length) { - return; - } - if (cols > this.length) { - const data = new Uint32Array(cols * CELL_SIZE); - if (this.length) { - if (cols * CELL_SIZE < this._data.length) { - data.set(this._data.subarray(0, cols * CELL_SIZE)); - } else { - data.set(this._data); - } - } - this._data = data; - for (let i = this.length; i < cols; ++i) { - this.setCell(i, fillCellData); - } - } else { - if (cols) { - const data = new Uint32Array(cols * CELL_SIZE); - data.set(this._data.subarray(0, cols * CELL_SIZE)); - this._data = data; - // Remove any cut off combined data, FIXME: repeat this for extended attrs - const keys = Object.keys(this._combined); - for (let i = 0; i < keys.length; i++) { - const key = parseInt(keys[i], 10); - if (key >= cols) { - delete this._combined[key]; - } - } - } else { - this._data = new Uint32Array(0); - this._combined = {}; - } - } - this.length = cols; - } - - /** fill a line with fillCharData */ - public fill(fillCellData: ICellData): void { - this._combined = {}; - this._extendedAttrs = {}; - for (let i = 0; i < this.length; ++i) { - this.setCell(i, fillCellData); - } - } - - /** alter to a full copy of line */ - public copyFrom(line: BufferLine): void { - if (this.length !== line.length) { - this._data = new Uint32Array(line._data); - } else { - // use high speed copy if lengths are equal - this._data.set(line._data); - } - this.length = line.length; - this._combined = {}; - for (const el in line._combined) { - this._combined[el] = line._combined[el]; - } - this._extendedAttrs = {}; - for (const el in line._extendedAttrs) { - this._extendedAttrs[el] = line._extendedAttrs[el]; - } - this.isWrapped = line.isWrapped; - } - - /** create a new clone */ - public clone(): IBufferLine { - const newLine = new BufferLine(0); - newLine._data = new Uint32Array(this._data); - newLine.length = this.length; - for (const el in this._combined) { - newLine._combined[el] = this._combined[el]; - } - for (const el in this._extendedAttrs) { - newLine._extendedAttrs[el] = this._extendedAttrs[el]; - } - newLine.isWrapped = this.isWrapped; - return newLine; - } - - public getTrimmedLength(): number { - for (let i = this.length - 1; i >= 0; --i) { - if ((this._data[i * CELL_SIZE + Cell.CONTENT] & Content.HAS_CONTENT_MASK)) { - return i + (this._data[i * CELL_SIZE + Cell.CONTENT] >> Content.WIDTH_SHIFT); - } - } - return 0; - } - - public copyCellsFrom(src: BufferLine, srcCol: number, destCol: number, length: number, applyInReverse: boolean): void { - const srcData = src._data; - if (applyInReverse) { - for (let cell = length - 1; cell >= 0; cell--) { - for (let i = 0; i < CELL_SIZE; i++) { - this._data[(destCol + cell) * CELL_SIZE + i] = srcData[(srcCol + cell) * CELL_SIZE + i]; - } - } - } else { - for (let cell = 0; cell < length; cell++) { - for (let i = 0; i < CELL_SIZE; i++) { - this._data[(destCol + cell) * CELL_SIZE + i] = srcData[(srcCol + cell) * CELL_SIZE + i]; - } - } - } - - // Move any combined data over as needed, FIXME: repeat for extended attrs - const srcCombinedKeys = Object.keys(src._combined); - for (let i = 0; i < srcCombinedKeys.length; i++) { - const key = parseInt(srcCombinedKeys[i], 10); - if (key >= srcCol) { - this._combined[key - srcCol + destCol] = src._combined[key]; - } - } - } - - public translateToString(trimRight: boolean = false, startCol: number = 0, endCol: number = this.length): string { - if (trimRight) { - endCol = Math.min(endCol, this.getTrimmedLength()); - } - let result = ''; - while (startCol < endCol) { - const content = this._data[startCol * CELL_SIZE + Cell.CONTENT]; - const cp = content & Content.CODEPOINT_MASK; - result += (content & Content.IS_COMBINED_MASK) ? this._combined[startCol] : (cp) ? stringFromCodePoint(cp) : WHITESPACE_CELL_CHAR; - startCol += (content >> Content.WIDTH_SHIFT) || 1; // always advance by 1 - } - return result; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/BufferReflow.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/BufferReflow.ts deleted file mode 100755 index ece9a96ed..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/BufferReflow.ts +++ /dev/null @@ -1,220 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { BufferLine } from 'common/buffer/BufferLine'; -import { CircularList } from 'common/CircularList'; -import { IBufferLine, ICellData } from 'common/Types'; - -export interface INewLayoutResult { - layout: number[]; - countRemoved: number; -} - -/** - * Evaluates and returns indexes to be removed after a reflow larger occurs. Lines will be removed - * when a wrapped line unwraps. - * @param lines The buffer lines. - * @param newCols The columns after resize. - */ -export function reflowLargerGetLinesToRemove(lines: CircularList, oldCols: number, newCols: number, bufferAbsoluteY: number, nullCell: ICellData): number[] { - // Gather all BufferLines that need to be removed from the Buffer here so that they can be - // batched up and only committed once - const toRemove: number[] = []; - - for (let y = 0; y < lines.length - 1; y++) { - // Check if this row is wrapped - let i = y; - let nextLine = lines.get(++i) as BufferLine; - if (!nextLine.isWrapped) { - continue; - } - - // Check how many lines it's wrapped for - const wrappedLines: BufferLine[] = [lines.get(y) as BufferLine]; - while (i < lines.length && nextLine.isWrapped) { - wrappedLines.push(nextLine); - nextLine = lines.get(++i) as BufferLine; - } - - // If these lines contain the cursor don't touch them, the program will handle fixing up wrapped - // lines with the cursor - if (bufferAbsoluteY >= y && bufferAbsoluteY < i) { - y += wrappedLines.length - 1; - continue; - } - - // Copy buffer data to new locations - let destLineIndex = 0; - let destCol = getWrappedLineTrimmedLength(wrappedLines, destLineIndex, oldCols); - let srcLineIndex = 1; - let srcCol = 0; - while (srcLineIndex < wrappedLines.length) { - const srcTrimmedTineLength = getWrappedLineTrimmedLength(wrappedLines, srcLineIndex, oldCols); - const srcRemainingCells = srcTrimmedTineLength - srcCol; - const destRemainingCells = newCols - destCol; - const cellsToCopy = Math.min(srcRemainingCells, destRemainingCells); - - wrappedLines[destLineIndex].copyCellsFrom(wrappedLines[srcLineIndex], srcCol, destCol, cellsToCopy, false); - - destCol += cellsToCopy; - if (destCol === newCols) { - destLineIndex++; - destCol = 0; - } - srcCol += cellsToCopy; - if (srcCol === srcTrimmedTineLength) { - srcLineIndex++; - srcCol = 0; - } - - // Make sure the last cell isn't wide, if it is copy it to the current dest - if (destCol === 0 && destLineIndex !== 0) { - if (wrappedLines[destLineIndex - 1].getWidth(newCols - 1) === 2) { - wrappedLines[destLineIndex].copyCellsFrom(wrappedLines[destLineIndex - 1], newCols - 1, destCol++, 1, false); - // Null out the end of the last row - wrappedLines[destLineIndex - 1].setCell(newCols - 1, nullCell); - } - } - } - - // Clear out remaining cells or fragments could remain; - wrappedLines[destLineIndex].replaceCells(destCol, newCols, nullCell); - - // Work backwards and remove any rows at the end that only contain null cells - let countToRemove = 0; - for (let i = wrappedLines.length - 1; i > 0; i--) { - if (i > destLineIndex || wrappedLines[i].getTrimmedLength() === 0) { - countToRemove++; - } else { - break; - } - } - - if (countToRemove > 0) { - toRemove.push(y + wrappedLines.length - countToRemove); // index - toRemove.push(countToRemove); - } - - y += wrappedLines.length - 1; - } - return toRemove; -} - -/** - * Creates and return the new layout for lines given an array of indexes to be removed. - * @param lines The buffer lines. - * @param toRemove The indexes to remove. - */ -export function reflowLargerCreateNewLayout(lines: CircularList, toRemove: number[]): INewLayoutResult { - const layout: number[] = []; - // First iterate through the list and get the actual indexes to use for rows - let nextToRemoveIndex = 0; - let nextToRemoveStart = toRemove[nextToRemoveIndex]; - let countRemovedSoFar = 0; - for (let i = 0; i < lines.length; i++) { - if (nextToRemoveStart === i) { - const countToRemove = toRemove[++nextToRemoveIndex]; - - // Tell markers that there was a deletion - lines.onDeleteEmitter.fire({ - index: i - countRemovedSoFar, - amount: countToRemove - }); - - i += countToRemove - 1; - countRemovedSoFar += countToRemove; - nextToRemoveStart = toRemove[++nextToRemoveIndex]; - } else { - layout.push(i); - } - } - return { - layout, - countRemoved: countRemovedSoFar - }; -} - -/** - * Applies a new layout to the buffer. This essentially does the same as many splice calls but it's - * done all at once in a single iteration through the list since splice is very expensive. - * @param lines The buffer lines. - * @param newLayout The new layout to apply. - */ -export function reflowLargerApplyNewLayout(lines: CircularList, newLayout: number[]): void { - // Record original lines so they don't get overridden when we rearrange the list - const newLayoutLines: BufferLine[] = []; - for (let i = 0; i < newLayout.length; i++) { - newLayoutLines.push(lines.get(newLayout[i]) as BufferLine); - } - - // Rearrange the list - for (let i = 0; i < newLayoutLines.length; i++) { - lines.set(i, newLayoutLines[i]); - } - lines.length = newLayout.length; -} - -/** - * Gets the new line lengths for a given wrapped line. The purpose of this function it to pre- - * compute the wrapping points since wide characters may need to be wrapped onto the following line. - * This function will return an array of numbers of where each line wraps to, the resulting array - * will only contain the values `newCols` (when the line does not end with a wide character) and - * `newCols - 1` (when the line does end with a wide character), except for the last value which - * will contain the remaining items to fill the line. - * - * Calling this with a `newCols` value of `1` will lock up. - * - * @param wrappedLines The wrapped lines to evaluate. - * @param oldCols The columns before resize. - * @param newCols The columns after resize. - */ -export function reflowSmallerGetNewLineLengths(wrappedLines: BufferLine[], oldCols: number, newCols: number): number[] { - const newLineLengths: number[] = []; - const cellsNeeded = wrappedLines.map((l, i) => getWrappedLineTrimmedLength(wrappedLines, i, oldCols)).reduce((p, c) => p + c); - - // Use srcCol and srcLine to find the new wrapping point, use that to get the cellsAvailable and - // linesNeeded - let srcCol = 0; - let srcLine = 0; - let cellsAvailable = 0; - while (cellsAvailable < cellsNeeded) { - if (cellsNeeded - cellsAvailable < newCols) { - // Add the final line and exit the loop - newLineLengths.push(cellsNeeded - cellsAvailable); - break; - } - srcCol += newCols; - const oldTrimmedLength = getWrappedLineTrimmedLength(wrappedLines, srcLine, oldCols); - if (srcCol > oldTrimmedLength) { - srcCol -= oldTrimmedLength; - srcLine++; - } - const endsWithWide = wrappedLines[srcLine].getWidth(srcCol - 1) === 2; - if (endsWithWide) { - srcCol--; - } - const lineLength = endsWithWide ? newCols - 1 : newCols; - newLineLengths.push(lineLength); - cellsAvailable += lineLength; - } - - return newLineLengths; -} - -export function getWrappedLineTrimmedLength(lines: BufferLine[], i: number, cols: number): number { - // If this is the last row in the wrapped line, get the actual trimmed length - if (i === lines.length - 1) { - return lines[i].getTrimmedLength(); - } - // Detect whether the following line starts with a wide character and the end of the current line - // is null, if so then we can be pretty sure the null character should be excluded from the line - // length] - const endsInNull = !(lines[i].hasContent(cols - 1)) && lines[i].getWidth(cols - 1) === 1; - const followingLineStartsWithWide = lines[i + 1].getWidth(0) === 2; - if (endsInNull && followingLineStartsWithWide) { - return cols - 1; - } - return cols; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/BufferSet.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/BufferSet.ts deleted file mode 100755 index b74c4eac7..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/BufferSet.ts +++ /dev/null @@ -1,127 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IBuffer, IBufferSet } from 'common/buffer/Types'; -import { IAttributeData } from 'common/Types'; -import { Buffer } from 'common/buffer/Buffer'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { IOptionsService, IBufferService } from 'common/services/Services'; -import { Disposable } from 'common/Lifecycle'; - -/** - * The BufferSet represents the set of two buffers used by xterm terminals (normal and alt) and - * provides also utilities for working with them. - */ -export class BufferSet extends Disposable implements IBufferSet { - private _normal!: Buffer; - private _alt!: Buffer; - private _activeBuffer!: Buffer; - - private _onBufferActivate = this.register(new EventEmitter<{activeBuffer: IBuffer, inactiveBuffer: IBuffer}>()); - public get onBufferActivate(): IEvent<{activeBuffer: IBuffer, inactiveBuffer: IBuffer}> { return this._onBufferActivate.event; } - - /** - * Create a new BufferSet for the given terminal. - * @param _terminal - The terminal the BufferSet will belong to - */ - constructor( - private readonly _optionsService: IOptionsService, - private readonly _bufferService: IBufferService - ) { - super(); - this.reset(); - } - - public reset(): void { - this._normal = new Buffer(true, this._optionsService, this._bufferService); - this._normal.fillViewportRows(); - - // The alt buffer should never have scrollback. - // See http://invisible-island.net/xterm/ctlseqs/ctlseqs.html#h2-The-Alternate-Screen-Buffer - this._alt = new Buffer(false, this._optionsService, this._bufferService); - this._activeBuffer = this._normal; - - this.setupTabStops(); - } - - /** - * Returns the alt Buffer of the BufferSet - */ - public get alt(): Buffer { - return this._alt; - } - - /** - * Returns the normal Buffer of the BufferSet - */ - public get active(): Buffer { - return this._activeBuffer; - } - - /** - * Returns the currently active Buffer of the BufferSet - */ - public get normal(): Buffer { - return this._normal; - } - - /** - * Sets the normal Buffer of the BufferSet as its currently active Buffer - */ - public activateNormalBuffer(): void { - if (this._activeBuffer === this._normal) { - return; - } - this._normal.x = this._alt.x; - this._normal.y = this._alt.y; - // The alt buffer should always be cleared when we switch to the normal - // buffer. This frees up memory since the alt buffer should always be new - // when activated. - this._alt.clear(); - this._activeBuffer = this._normal; - this._onBufferActivate.fire({ - activeBuffer: this._normal, - inactiveBuffer: this._alt - }); - } - - /** - * Sets the alt Buffer of the BufferSet as its currently active Buffer - */ - public activateAltBuffer(fillAttr?: IAttributeData): void { - if (this._activeBuffer === this._alt) { - return; - } - // Since the alt buffer is always cleared when the normal buffer is - // activated, we want to fill it when switching to it. - this._alt.fillViewportRows(fillAttr); - this._alt.x = this._normal.x; - this._alt.y = this._normal.y; - this._activeBuffer = this._alt; - this._onBufferActivate.fire({ - activeBuffer: this._alt, - inactiveBuffer: this._normal - }); - } - - /** - * Resizes both normal and alt buffers, adjusting their data accordingly. - * @param newCols The new number of columns. - * @param newRows The new number of rows. - */ - public resize(newCols: number, newRows: number): void { - this._normal.resize(newCols, newRows); - this._alt.resize(newCols, newRows); - } - - /** - * Setup the tab stops. - * @param i The index to start setting up tab stops from. - */ - public setupTabStops(i?: number): void { - this._normal.setupTabStops(i); - this._alt.setupTabStops(i); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/CellData.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/CellData.ts deleted file mode 100755 index a87b5795d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/CellData.ts +++ /dev/null @@ -1,94 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { CharData, ICellData, IExtendedAttrs } from 'common/Types'; -import { stringFromCodePoint } from 'common/input/TextDecoder'; -import { CHAR_DATA_CHAR_INDEX, CHAR_DATA_WIDTH_INDEX, CHAR_DATA_ATTR_INDEX, Content } from 'common/buffer/Constants'; -import { AttributeData, ExtendedAttrs } from 'common/buffer/AttributeData'; - -/** - * CellData - represents a single Cell in the terminal buffer. - */ -export class CellData extends AttributeData implements ICellData { - /** Helper to create CellData from CharData. */ - public static fromCharData(value: CharData): CellData { - const obj = new CellData(); - obj.setFromCharData(value); - return obj; - } - /** Primitives from terminal buffer. */ - public content = 0; - public fg = 0; - public bg = 0; - public extended: IExtendedAttrs = new ExtendedAttrs(); - public combinedData = ''; - /** Whether cell contains a combined string. */ - public isCombined(): number { - return this.content & Content.IS_COMBINED_MASK; - } - /** Width of the cell. */ - public getWidth(): number { - return this.content >> Content.WIDTH_SHIFT; - } - /** JS string of the content. */ - public getChars(): string { - if (this.content & Content.IS_COMBINED_MASK) { - return this.combinedData; - } - if (this.content & Content.CODEPOINT_MASK) { - return stringFromCodePoint(this.content & Content.CODEPOINT_MASK); - } - return ''; - } - /** - * Codepoint of cell - * Note this returns the UTF32 codepoint of single chars, - * if content is a combined string it returns the codepoint - * of the last char in string to be in line with code in CharData. - * */ - public getCode(): number { - return (this.isCombined()) - ? this.combinedData.charCodeAt(this.combinedData.length - 1) - : this.content & Content.CODEPOINT_MASK; - } - /** Set data from CharData */ - public setFromCharData(value: CharData): void { - this.fg = value[CHAR_DATA_ATTR_INDEX]; - this.bg = 0; - let combined = false; - // surrogates and combined strings need special treatment - if (value[CHAR_DATA_CHAR_INDEX].length > 2) { - combined = true; - } - else if (value[CHAR_DATA_CHAR_INDEX].length === 2) { - const code = value[CHAR_DATA_CHAR_INDEX].charCodeAt(0); - // if the 2-char string is a surrogate create single codepoint - // everything else is combined - if (0xD800 <= code && code <= 0xDBFF) { - const second = value[CHAR_DATA_CHAR_INDEX].charCodeAt(1); - if (0xDC00 <= second && second <= 0xDFFF) { - this.content = ((code - 0xD800) * 0x400 + second - 0xDC00 + 0x10000) | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT); - } - else { - combined = true; - } - } - else { - combined = true; - } - } - else { - this.content = value[CHAR_DATA_CHAR_INDEX].charCodeAt(0) | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT); - } - if (combined) { - this.combinedData = value[CHAR_DATA_CHAR_INDEX]; - this.content = Content.IS_COMBINED_MASK | (value[CHAR_DATA_WIDTH_INDEX] << Content.WIDTH_SHIFT); - } - } - /** Get data as CharData. */ - public getAsCharData(): CharData { - return [this.fg, this.getChars(), this.getWidth(), this.getCode()]; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Constants.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Constants.ts deleted file mode 100755 index ee86a804d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Constants.ts +++ /dev/null @@ -1,138 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -export const DEFAULT_COLOR = 256; -export const DEFAULT_ATTR = (0 << 18) | (DEFAULT_COLOR << 9) | (256 << 0); - -export const CHAR_DATA_ATTR_INDEX = 0; -export const CHAR_DATA_CHAR_INDEX = 1; -export const CHAR_DATA_WIDTH_INDEX = 2; -export const CHAR_DATA_CODE_INDEX = 3; - -/** - * Null cell - a real empty cell (containing nothing). - * Note that code should always be 0 for a null cell as - * several test condition of the buffer line rely on this. - */ -export const NULL_CELL_CHAR = ''; -export const NULL_CELL_WIDTH = 1; -export const NULL_CELL_CODE = 0; - -/** - * Whitespace cell. - * This is meant as a replacement for empty cells when needed - * during rendering lines to preserve correct aligment. - */ -export const WHITESPACE_CELL_CHAR = ' '; -export const WHITESPACE_CELL_WIDTH = 1; -export const WHITESPACE_CELL_CODE = 32; - -/** - * Bitmasks for accessing data in `content`. - */ -export const enum Content { - /** - * bit 1..21 codepoint, max allowed in UTF32 is 0x10FFFF (21 bits taken) - * read: `codepoint = content & Content.codepointMask;` - * write: `content |= codepoint & Content.codepointMask;` - * shortcut if precondition `codepoint <= 0x10FFFF` is met: - * `content |= codepoint;` - */ - CODEPOINT_MASK = 0x1FFFFF, - - /** - * bit 22 flag indication whether a cell contains combined content - * read: `isCombined = content & Content.isCombined;` - * set: `content |= Content.isCombined;` - * clear: `content &= ~Content.isCombined;` - */ - IS_COMBINED_MASK = 0x200000, // 1 << 21 - - /** - * bit 1..22 mask to check whether a cell contains any string data - * we need to check for codepoint and isCombined bits to see - * whether a cell contains anything - * read: `isEmpty = !(content & Content.hasContent)` - */ - HAS_CONTENT_MASK = 0x3FFFFF, - - /** - * bit 23..24 wcwidth value of cell, takes 2 bits (ranges from 0..2) - * read: `width = (content & Content.widthMask) >> Content.widthShift;` - * `hasWidth = content & Content.widthMask;` - * as long as wcwidth is highest value in `content`: - * `width = content >> Content.widthShift;` - * write: `content |= (width << Content.widthShift) & Content.widthMask;` - * shortcut if precondition `0 <= width <= 3` is met: - * `content |= width << Content.widthShift;` - */ - WIDTH_MASK = 0xC00000, // 3 << 22 - WIDTH_SHIFT = 22 -} - -export const enum Attributes { - /** - * bit 1..8 blue in RGB, color in P256 and P16 - */ - BLUE_MASK = 0xFF, - BLUE_SHIFT = 0, - PCOLOR_MASK = 0xFF, - PCOLOR_SHIFT = 0, - - /** - * bit 9..16 green in RGB - */ - GREEN_MASK = 0xFF00, - GREEN_SHIFT = 8, - - /** - * bit 17..24 red in RGB - */ - RED_MASK = 0xFF0000, - RED_SHIFT = 16, - - /** - * bit 25..26 color mode: DEFAULT (0) | P16 (1) | P256 (2) | RGB (3) - */ - CM_MASK = 0x3000000, - CM_DEFAULT = 0, - CM_P16 = 0x1000000, - CM_P256 = 0x2000000, - CM_RGB = 0x3000000, - - /** - * bit 1..24 RGB room - */ - RGB_MASK = 0xFFFFFF -} - -export const enum FgFlags { - /** - * bit 27..31 (32th bit unused) - */ - INVERSE = 0x4000000, - BOLD = 0x8000000, - UNDERLINE = 0x10000000, - BLINK = 0x20000000, - INVISIBLE = 0x40000000 -} - -export const enum BgFlags { - /** - * bit 27..32 (upper 3 unused) - */ - ITALIC = 0x4000000, - DIM = 0x8000000, - HAS_EXTENDED = 0x10000000 -} - -export const enum UnderlineStyle { - NONE = 0, - SINGLE = 1, - DOUBLE = 2, - CURLY = 3, - DOTTED = 4, - DASHED = 5 -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Marker.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Marker.ts deleted file mode 100755 index 72c4085ca..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Marker.ts +++ /dev/null @@ -1,37 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { Disposable } from 'common/Lifecycle'; -import { IMarker } from 'common/Types'; - -export class Marker extends Disposable implements IMarker { - private static _nextId = 1; - - private _id: number = Marker._nextId++; - public isDisposed: boolean = false; - - public get id(): number { return this._id; } - - private _onDispose = new EventEmitter(); - public get onDispose(): IEvent { return this._onDispose.event; } - - constructor( - public line: number - ) { - super(); - } - - public dispose(): void { - if (this.isDisposed) { - return; - } - this.isDisposed = true; - this.line = -1; - // Emit before super.dispose such that dispose listeners get a change to react - this._onDispose.fire(); - super.dispose(); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Types.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Types.d.ts deleted file mode 100755 index cbf40a03d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/buffer/Types.d.ts +++ /dev/null @@ -1,62 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IAttributeData, ICircularList, IBufferLine, ICellData, IMarker, ICharset, IDisposable } from 'common/Types'; -import { IEvent } from 'common/EventEmitter'; - -// BufferIndex denotes a position in the buffer: [rowIndex, colIndex] -export type BufferIndex = [number, number]; - -export interface IBufferStringIteratorResult { - range: {first: number, last: number}; - content: string; -} - -export interface IBufferStringIterator { - hasNext(): boolean; - next(): IBufferStringIteratorResult; -} - -export interface IBuffer { - readonly lines: ICircularList; - ydisp: number; - ybase: number; - y: number; - x: number; - tabs: any; - scrollBottom: number; - scrollTop: number; - hasScrollback: boolean; - savedY: number; - savedX: number; - savedCharset: ICharset | undefined; - savedCurAttrData: IAttributeData; - isCursorInViewport: boolean; - markers: IMarker[]; - translateBufferLineToString(lineIndex: number, trimRight: boolean, startCol?: number, endCol?: number): string; - getWrappedRangeForLine(y: number): { first: number, last: number }; - nextStop(x?: number): number; - prevStop(x?: number): number; - getBlankLine(attr: IAttributeData, isWrapped?: boolean): IBufferLine; - stringIndexToBufferIndex(lineIndex: number, stringIndex: number, trimRight?: boolean): number[]; - iterator(trimRight: boolean, startIndex?: number, endIndex?: number, startOverscan?: number, endOverscan?: number): IBufferStringIterator; - getNullCell(attr?: IAttributeData): ICellData; - getWhitespaceCell(attr?: IAttributeData): ICellData; - addMarker(y: number): IMarker; -} - -export interface IBufferSet extends IDisposable { - alt: IBuffer; - normal: IBuffer; - active: IBuffer; - - onBufferActivate: IEvent<{ activeBuffer: IBuffer, inactiveBuffer: IBuffer }>; - - activateNormalBuffer(): void; - activateAltBuffer(fillAttr?: IAttributeData): void; - reset(): void; - resize(newCols: number, newRows: number): void; - setupTabStops(i?: number): void; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/data/Charsets.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/data/Charsets.ts deleted file mode 100755 index c72d5a237..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/data/Charsets.ts +++ /dev/null @@ -1,256 +0,0 @@ -/** - * Copyright (c) 2016 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ICharset } from 'common/Types'; - -/** - * The character sets supported by the terminal. These enable several languages - * to be represented within the terminal with only 8-bit encoding. See ISO 2022 - * for a discussion on character sets. Only VT100 character sets are supported. - */ -export const CHARSETS: { [key: string]: ICharset | undefined } = {}; - -/** - * The default character set, US. - */ -export const DEFAULT_CHARSET: ICharset | undefined = CHARSETS['B']; - -/** - * DEC Special Character and Line Drawing Set. - * Reference: http://vt100.net/docs/vt102-ug/table5-13.html - * A lot of curses apps use this if they see TERM=xterm. - * testing: echo -e '\e(0a\e(B' - * The xterm output sometimes seems to conflict with the - * reference above. xterm seems in line with the reference - * when running vttest however. - * The table below now uses xterm's output from vttest. - */ -CHARSETS['0'] = { - '`': '\u25c6', // '◆' - 'a': '\u2592', // '▒' - 'b': '\u2409', // '␉' (HT) - 'c': '\u240c', // '␌' (FF) - 'd': '\u240d', // '␍' (CR) - 'e': '\u240a', // '␊' (LF) - 'f': '\u00b0', // '°' - 'g': '\u00b1', // '±' - 'h': '\u2424', // '␤' (NL) - 'i': '\u240b', // '␋' (VT) - 'j': '\u2518', // '┘' - 'k': '\u2510', // '┐' - 'l': '\u250c', // '┌' - 'm': '\u2514', // '└' - 'n': '\u253c', // '┼' - 'o': '\u23ba', // '⎺' - 'p': '\u23bb', // '⎻' - 'q': '\u2500', // '─' - 'r': '\u23bc', // '⎼' - 's': '\u23bd', // '⎽' - 't': '\u251c', // '├' - 'u': '\u2524', // '┤' - 'v': '\u2534', // '┴' - 'w': '\u252c', // '┬' - 'x': '\u2502', // '│' - 'y': '\u2264', // '≤' - 'z': '\u2265', // '≥' - '{': '\u03c0', // 'π' - '|': '\u2260', // '≠' - '}': '\u00a3', // '£' - '~': '\u00b7' // '·' -}; - -/** - * British character set - * ESC (A - * Reference: http://vt100.net/docs/vt220-rm/table2-5.html - */ -CHARSETS['A'] = { - '#': '£' -}; - -/** - * United States character set - * ESC (B - */ -CHARSETS['B'] = undefined; - -/** - * Dutch character set - * ESC (4 - * Reference: http://vt100.net/docs/vt220-rm/table2-6.html - */ -CHARSETS['4'] = { - '#': '£', - '@': '¾', - '[': 'ij', - '\\': '½', - ']': '|', - '{': '¨', - '|': 'f', - '}': '¼', - '~': '´' -}; - -/** - * Finnish character set - * ESC (C or ESC (5 - * Reference: http://vt100.net/docs/vt220-rm/table2-7.html - */ -CHARSETS['C'] = -CHARSETS['5'] = { - '[': 'Ä', - '\\': 'Ö', - ']': 'Å', - '^': 'Ü', - '`': 'é', - '{': 'ä', - '|': 'ö', - '}': 'å', - '~': 'ü' -}; - -/** - * French character set - * ESC (R - * Reference: http://vt100.net/docs/vt220-rm/table2-8.html - */ -CHARSETS['R'] = { - '#': '£', - '@': 'à', - '[': '°', - '\\': 'ç', - ']': '§', - '{': 'é', - '|': 'ù', - '}': 'è', - '~': '¨' -}; - -/** - * French Canadian character set - * ESC (Q - * Reference: http://vt100.net/docs/vt220-rm/table2-9.html - */ -CHARSETS['Q'] = { - '@': 'à', - '[': 'â', - '\\': 'ç', - ']': 'ê', - '^': 'î', - '`': 'ô', - '{': 'é', - '|': 'ù', - '}': 'è', - '~': 'û' -}; - -/** - * German character set - * ESC (K - * Reference: http://vt100.net/docs/vt220-rm/table2-10.html - */ -CHARSETS['K'] = { - '@': '§', - '[': 'Ä', - '\\': 'Ö', - ']': 'Ü', - '{': 'ä', - '|': 'ö', - '}': 'ü', - '~': 'ß' -}; - -/** - * Italian character set - * ESC (Y - * Reference: http://vt100.net/docs/vt220-rm/table2-11.html - */ -CHARSETS['Y'] = { - '#': '£', - '@': '§', - '[': '°', - '\\': 'ç', - ']': 'é', - '`': 'ù', - '{': 'à', - '|': 'ò', - '}': 'è', - '~': 'ì' -}; - -/** - * Norwegian/Danish character set - * ESC (E or ESC (6 - * Reference: http://vt100.net/docs/vt220-rm/table2-12.html - */ -CHARSETS['E'] = -CHARSETS['6'] = { - '@': 'Ä', - '[': 'Æ', - '\\': 'Ø', - ']': 'Å', - '^': 'Ü', - '`': 'ä', - '{': 'æ', - '|': 'ø', - '}': 'å', - '~': 'ü' -}; - -/** - * Spanish character set - * ESC (Z - * Reference: http://vt100.net/docs/vt220-rm/table2-13.html - */ -CHARSETS['Z'] = { - '#': '£', - '@': '§', - '[': '¡', - '\\': 'Ñ', - ']': '¿', - '{': '°', - '|': 'ñ', - '}': 'ç' -}; - -/** - * Swedish character set - * ESC (H or ESC (7 - * Reference: http://vt100.net/docs/vt220-rm/table2-14.html - */ -CHARSETS['H'] = -CHARSETS['7'] = { - '@': 'É', - '[': 'Ä', - '\\': 'Ö', - ']': 'Å', - '^': 'Ü', - '`': 'é', - '{': 'ä', - '|': 'ö', - '}': 'å', - '~': 'ü' -}; - -/** - * Swiss character set - * ESC (= - * Reference: http://vt100.net/docs/vt220-rm/table2-15.html - */ -CHARSETS['='] = { - '#': 'ù', - '@': 'à', - '[': 'é', - '\\': 'ç', - ']': 'ê', - '^': 'î', - // eslint-disable-next-line @typescript-eslint/naming-convention - '_': 'è', - '`': 'ô', - '{': 'ä', - '|': 'ö', - '}': 'ü', - '~': 'û' -}; diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/data/EscapeSequences.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/data/EscapeSequences.ts deleted file mode 100755 index e35f01dd0..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/data/EscapeSequences.ts +++ /dev/null @@ -1,150 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -/** - * C0 control codes - * See = https://en.wikipedia.org/wiki/C0_and_C1_control_codes - */ -export namespace C0 { - /** Null (Caret = ^@, C = \0) */ - export const NUL = '\x00'; - /** Start of Heading (Caret = ^A) */ - export const SOH = '\x01'; - /** Start of Text (Caret = ^B) */ - export const STX = '\x02'; - /** End of Text (Caret = ^C) */ - export const ETX = '\x03'; - /** End of Transmission (Caret = ^D) */ - export const EOT = '\x04'; - /** Enquiry (Caret = ^E) */ - export const ENQ = '\x05'; - /** Acknowledge (Caret = ^F) */ - export const ACK = '\x06'; - /** Bell (Caret = ^G, C = \a) */ - export const BEL = '\x07'; - /** Backspace (Caret = ^H, C = \b) */ - export const BS = '\x08'; - /** Character Tabulation, Horizontal Tabulation (Caret = ^I, C = \t) */ - export const HT = '\x09'; - /** Line Feed (Caret = ^J, C = \n) */ - export const LF = '\x0a'; - /** Line Tabulation, Vertical Tabulation (Caret = ^K, C = \v) */ - export const VT = '\x0b'; - /** Form Feed (Caret = ^L, C = \f) */ - export const FF = '\x0c'; - /** Carriage Return (Caret = ^M, C = \r) */ - export const CR = '\x0d'; - /** Shift Out (Caret = ^N) */ - export const SO = '\x0e'; - /** Shift In (Caret = ^O) */ - export const SI = '\x0f'; - /** Data Link Escape (Caret = ^P) */ - export const DLE = '\x10'; - /** Device Control One (XON) (Caret = ^Q) */ - export const DC1 = '\x11'; - /** Device Control Two (Caret = ^R) */ - export const DC2 = '\x12'; - /** Device Control Three (XOFF) (Caret = ^S) */ - export const DC3 = '\x13'; - /** Device Control Four (Caret = ^T) */ - export const DC4 = '\x14'; - /** Negative Acknowledge (Caret = ^U) */ - export const NAK = '\x15'; - /** Synchronous Idle (Caret = ^V) */ - export const SYN = '\x16'; - /** End of Transmission Block (Caret = ^W) */ - export const ETB = '\x17'; - /** Cancel (Caret = ^X) */ - export const CAN = '\x18'; - /** End of Medium (Caret = ^Y) */ - export const EM = '\x19'; - /** Substitute (Caret = ^Z) */ - export const SUB = '\x1a'; - /** Escape (Caret = ^[, C = \e) */ - export const ESC = '\x1b'; - /** File Separator (Caret = ^\) */ - export const FS = '\x1c'; - /** Group Separator (Caret = ^]) */ - export const GS = '\x1d'; - /** Record Separator (Caret = ^^) */ - export const RS = '\x1e'; - /** Unit Separator (Caret = ^_) */ - export const US = '\x1f'; - /** Space */ - export const SP = '\x20'; - /** Delete (Caret = ^?) */ - export const DEL = '\x7f'; -} - -/** - * C1 control codes - * See = https://en.wikipedia.org/wiki/C0_and_C1_control_codes - */ -export namespace C1 { - /** padding character */ - export const PAD = '\x80'; - /** High Octet Preset */ - export const HOP = '\x81'; - /** Break Permitted Here */ - export const BPH = '\x82'; - /** No Break Here */ - export const NBH = '\x83'; - /** Index */ - export const IND = '\x84'; - /** Next Line */ - export const NEL = '\x85'; - /** Start of Selected Area */ - export const SSA = '\x86'; - /** End of Selected Area */ - export const ESA = '\x87'; - /** Horizontal Tabulation Set */ - export const HTS = '\x88'; - /** Horizontal Tabulation With Justification */ - export const HTJ = '\x89'; - /** Vertical Tabulation Set */ - export const VTS = '\x8a'; - /** Partial Line Down */ - export const PLD = '\x8b'; - /** Partial Line Up */ - export const PLU = '\x8c'; - /** Reverse Index */ - export const RI = '\x8d'; - /** Single-Shift 2 */ - export const SS2 = '\x8e'; - /** Single-Shift 3 */ - export const SS3 = '\x8f'; - /** Device Control String */ - export const DCS = '\x90'; - /** Private Use 1 */ - export const PU1 = '\x91'; - /** Private Use 2 */ - export const PU2 = '\x92'; - /** Set Transmit State */ - export const STS = '\x93'; - /** Destructive backspace, intended to eliminate ambiguity about meaning of BS. */ - export const CCH = '\x94'; - /** Message Waiting */ - export const MW = '\x95'; - /** Start of Protected Area */ - export const SPA = '\x96'; - /** End of Protected Area */ - export const EPA = '\x97'; - /** Start of String */ - export const SOS = '\x98'; - /** Single Graphic Character Introducer */ - export const SGCI = '\x99'; - /** Single Character Introducer */ - export const SCI = '\x9a'; - /** Control Sequence Introducer */ - export const CSI = '\x9b'; - /** String Terminator */ - export const ST = '\x9c'; - /** Operating System Command */ - export const OSC = '\x9d'; - /** Privacy Message */ - export const PM = '\x9e'; - /** Application Program Command */ - export const APC = '\x9f'; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/Keyboard.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/Keyboard.ts deleted file mode 100755 index 20a28f61d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/Keyboard.ts +++ /dev/null @@ -1,375 +0,0 @@ -/** - * Copyright (c) 2014 The xterm.js authors. All rights reserved. - * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License) - * @license MIT - */ - -import { IKeyboardEvent, IKeyboardResult, KeyboardResultType } from 'common/Types'; -import { C0 } from 'common/data/EscapeSequences'; - -// reg + shift key mappings for digits and special chars -const KEYCODE_KEY_MAPPINGS: { [key: number]: [string, string]} = { - // digits 0-9 - 48: ['0', ')'], - 49: ['1', '!'], - 50: ['2', '@'], - 51: ['3', '#'], - 52: ['4', '$'], - 53: ['5', '%'], - 54: ['6', '^'], - 55: ['7', '&'], - 56: ['8', '*'], - 57: ['9', '('], - - // special chars - 186: [';', ':'], - 187: ['=', '+'], - 188: [',', '<'], - 189: ['-', '_'], - 190: ['.', '>'], - 191: ['/', '?'], - 192: ['`', '~'], - 219: ['[', '{'], - 220: ['\\', '|'], - 221: [']', '}'], - 222: ['\'', '"'] -}; - -export function evaluateKeyboardEvent( - ev: IKeyboardEvent, - applicationCursorMode: boolean, - isMac: boolean, - macOptionIsMeta: boolean -): IKeyboardResult { - const result: IKeyboardResult = { - type: KeyboardResultType.SEND_KEY, - // Whether to cancel event propagation (NOTE: this may not be needed since the event is - // canceled at the end of keyDown - cancel: false, - // The new key even to emit - key: undefined - }; - const modifiers = (ev.shiftKey ? 1 : 0) | (ev.altKey ? 2 : 0) | (ev.ctrlKey ? 4 : 0) | (ev.metaKey ? 8 : 0); - switch (ev.keyCode) { - case 0: - if (ev.key === 'UIKeyInputUpArrow') { - if (applicationCursorMode) { - result.key = C0.ESC + 'OA'; - } else { - result.key = C0.ESC + '[A'; - } - } - else if (ev.key === 'UIKeyInputLeftArrow') { - if (applicationCursorMode) { - result.key = C0.ESC + 'OD'; - } else { - result.key = C0.ESC + '[D'; - } - } - else if (ev.key === 'UIKeyInputRightArrow') { - if (applicationCursorMode) { - result.key = C0.ESC + 'OC'; - } else { - result.key = C0.ESC + '[C'; - } - } - else if (ev.key === 'UIKeyInputDownArrow') { - if (applicationCursorMode) { - result.key = C0.ESC + 'OB'; - } else { - result.key = C0.ESC + '[B'; - } - } - break; - case 8: - // backspace - if (ev.shiftKey) { - result.key = C0.BS; // ^H - break; - } else if (ev.altKey) { - result.key = C0.ESC + C0.DEL; // \e ^? - break; - } - result.key = C0.DEL; // ^? - break; - case 9: - // tab - if (ev.shiftKey) { - result.key = C0.ESC + '[Z'; - break; - } - result.key = C0.HT; - result.cancel = true; - break; - case 13: - // return/enter - result.key = ev.altKey ? C0.ESC + C0.CR : C0.CR; - result.cancel = true; - break; - case 27: - // escape - result.key = C0.ESC; - if (ev.altKey) { - result.key = C0.ESC + C0.ESC; - } - result.cancel = true; - break; - case 37: - // left-arrow - if (ev.metaKey) { - break; - } - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'D'; - // HACK: Make Alt + left-arrow behave like Ctrl + left-arrow: move one word backwards - // http://unix.stackexchange.com/a/108106 - // macOS uses different escape sequences than linux - if (result.key === C0.ESC + '[1;3D') { - result.key = C0.ESC + (isMac ? 'b' : '[1;5D'); - } - } else if (applicationCursorMode) { - result.key = C0.ESC + 'OD'; - } else { - result.key = C0.ESC + '[D'; - } - break; - case 39: - // right-arrow - if (ev.metaKey) { - break; - } - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'C'; - // HACK: Make Alt + right-arrow behave like Ctrl + right-arrow: move one word forward - // http://unix.stackexchange.com/a/108106 - // macOS uses different escape sequences than linux - if (result.key === C0.ESC + '[1;3C') { - result.key = C0.ESC + (isMac ? 'f' : '[1;5C'); - } - } else if (applicationCursorMode) { - result.key = C0.ESC + 'OC'; - } else { - result.key = C0.ESC + '[C'; - } - break; - case 38: - // up-arrow - if (ev.metaKey) { - break; - } - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'A'; - // HACK: Make Alt + up-arrow behave like Ctrl + up-arrow - // http://unix.stackexchange.com/a/108106 - // macOS uses different escape sequences than linux - if (!isMac && result.key === C0.ESC + '[1;3A') { - result.key = C0.ESC + '[1;5A'; - } - } else if (applicationCursorMode) { - result.key = C0.ESC + 'OA'; - } else { - result.key = C0.ESC + '[A'; - } - break; - case 40: - // down-arrow - if (ev.metaKey) { - break; - } - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'B'; - // HACK: Make Alt + down-arrow behave like Ctrl + down-arrow - // http://unix.stackexchange.com/a/108106 - // macOS uses different escape sequences than linux - if (!isMac && result.key === C0.ESC + '[1;3B') { - result.key = C0.ESC + '[1;5B'; - } - } else if (applicationCursorMode) { - result.key = C0.ESC + 'OB'; - } else { - result.key = C0.ESC + '[B'; - } - break; - case 45: - // insert - if (!ev.shiftKey && !ev.ctrlKey) { - // or + are used to - // copy-paste on some systems. - result.key = C0.ESC + '[2~'; - } - break; - case 46: - // delete - if (modifiers) { - result.key = C0.ESC + '[3;' + (modifiers + 1) + '~'; - } else { - result.key = C0.ESC + '[3~'; - } - break; - case 36: - // home - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'H'; - } else if (applicationCursorMode) { - result.key = C0.ESC + 'OH'; - } else { - result.key = C0.ESC + '[H'; - } - break; - case 35: - // end - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'F'; - } else if (applicationCursorMode) { - result.key = C0.ESC + 'OF'; - } else { - result.key = C0.ESC + '[F'; - } - break; - case 33: - // page up - if (ev.shiftKey) { - result.type = KeyboardResultType.PAGE_UP; - } else { - result.key = C0.ESC + '[5~'; - } - break; - case 34: - // page down - if (ev.shiftKey) { - result.type = KeyboardResultType.PAGE_DOWN; - } else { - result.key = C0.ESC + '[6~'; - } - break; - case 112: - // F1-F12 - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'P'; - } else { - result.key = C0.ESC + 'OP'; - } - break; - case 113: - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'Q'; - } else { - result.key = C0.ESC + 'OQ'; - } - break; - case 114: - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'R'; - } else { - result.key = C0.ESC + 'OR'; - } - break; - case 115: - if (modifiers) { - result.key = C0.ESC + '[1;' + (modifiers + 1) + 'S'; - } else { - result.key = C0.ESC + 'OS'; - } - break; - case 116: - if (modifiers) { - result.key = C0.ESC + '[15;' + (modifiers + 1) + '~'; - } else { - result.key = C0.ESC + '[15~'; - } - break; - case 117: - if (modifiers) { - result.key = C0.ESC + '[17;' + (modifiers + 1) + '~'; - } else { - result.key = C0.ESC + '[17~'; - } - break; - case 118: - if (modifiers) { - result.key = C0.ESC + '[18;' + (modifiers + 1) + '~'; - } else { - result.key = C0.ESC + '[18~'; - } - break; - case 119: - if (modifiers) { - result.key = C0.ESC + '[19;' + (modifiers + 1) + '~'; - } else { - result.key = C0.ESC + '[19~'; - } - break; - case 120: - if (modifiers) { - result.key = C0.ESC + '[20;' + (modifiers + 1) + '~'; - } else { - result.key = C0.ESC + '[20~'; - } - break; - case 121: - if (modifiers) { - result.key = C0.ESC + '[21;' + (modifiers + 1) + '~'; - } else { - result.key = C0.ESC + '[21~'; - } - break; - case 122: - if (modifiers) { - result.key = C0.ESC + '[23;' + (modifiers + 1) + '~'; - } else { - result.key = C0.ESC + '[23~'; - } - break; - case 123: - if (modifiers) { - result.key = C0.ESC + '[24;' + (modifiers + 1) + '~'; - } else { - result.key = C0.ESC + '[24~'; - } - break; - default: - // a-z and space - if (ev.ctrlKey && !ev.shiftKey && !ev.altKey && !ev.metaKey) { - if (ev.keyCode >= 65 && ev.keyCode <= 90) { - result.key = String.fromCharCode(ev.keyCode - 64); - } else if (ev.keyCode === 32) { - result.key = C0.NUL; - } else if (ev.keyCode >= 51 && ev.keyCode <= 55) { - // escape, file sep, group sep, record sep, unit sep - result.key = String.fromCharCode(ev.keyCode - 51 + 27); - } else if (ev.keyCode === 56) { - result.key = C0.DEL; - } else if (ev.keyCode === 219) { - result.key = C0.ESC; - } else if (ev.keyCode === 220) { - result.key = C0.FS; - } else if (ev.keyCode === 221) { - result.key = C0.GS; - } - } else if ((!isMac || macOptionIsMeta) && ev.altKey && !ev.metaKey) { - // On macOS this is a third level shift when !macOptionIsMeta. Use instead. - const keyMapping = KEYCODE_KEY_MAPPINGS[ev.keyCode]; - const key = keyMapping && keyMapping[!ev.shiftKey ? 0 : 1]; - if (key) { - result.key = C0.ESC + key; - } else if (ev.keyCode >= 65 && ev.keyCode <= 90) { - const keyCode = ev.ctrlKey ? ev.keyCode - 64 : ev.keyCode + 32; - result.key = C0.ESC + String.fromCharCode(keyCode); - } - } else if (isMac && !ev.altKey && !ev.ctrlKey && !ev.shiftKey && ev.metaKey) { - if (ev.keyCode === 65) { // cmd + a - result.type = KeyboardResultType.SELECT_ALL; - } - } else if (ev.key && !ev.ctrlKey && !ev.altKey && !ev.metaKey && ev.keyCode >= 48 && ev.key.length === 1) { - // Include only keys that that result in a _single_ character; don't include num lock, volume up, etc. - result.key = ev.key; - } else if (ev.key && ev.ctrlKey) { - if (ev.key === '_') { // ^_ - result.key = C0.US; - } - } - break; - } - - return result; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/TextDecoder.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/TextDecoder.ts deleted file mode 100755 index 715e91976..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/TextDecoder.ts +++ /dev/null @@ -1,346 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -/** - * Polyfill - Convert UTF32 codepoint into JS string. - * Note: The built-in String.fromCodePoint happens to be much slower - * due to additional sanity checks. We can avoid them since - * we always operate on legal UTF32 (granted by the input decoders) - * and use this faster version instead. - */ -export function stringFromCodePoint(codePoint: number): string { - if (codePoint > 0xFFFF) { - codePoint -= 0x10000; - return String.fromCharCode((codePoint >> 10) + 0xD800) + String.fromCharCode((codePoint % 0x400) + 0xDC00); - } - return String.fromCharCode(codePoint); -} - -/** - * Convert UTF32 char codes into JS string. - * Basically the same as `stringFromCodePoint` but for multiple codepoints - * in a loop (which is a lot faster). - */ -export function utf32ToString(data: Uint32Array, start: number = 0, end: number = data.length): string { - let result = ''; - for (let i = start; i < end; ++i) { - let codepoint = data[i]; - if (codepoint > 0xFFFF) { - // JS strings are encoded as UTF16, thus a non BMP codepoint gets converted into a surrogate pair - // conversion rules: - // - subtract 0x10000 from code point, leaving a 20 bit number - // - add high 10 bits to 0xD800 --> first surrogate - // - add low 10 bits to 0xDC00 --> second surrogate - codepoint -= 0x10000; - result += String.fromCharCode((codepoint >> 10) + 0xD800) + String.fromCharCode((codepoint % 0x400) + 0xDC00); - } else { - result += String.fromCharCode(codepoint); - } - } - return result; -} - -/** - * StringToUtf32 - decodes UTF16 sequences into UTF32 codepoints. - * To keep the decoder in line with JS strings it handles single surrogates as UCS2. - */ -export class StringToUtf32 { - private _interim: number = 0; - - /** - * Clears interim and resets decoder to clean state. - */ - public clear(): void { - this._interim = 0; - } - - /** - * Decode JS string to UTF32 codepoints. - * The methods assumes stream input and will store partly transmitted - * surrogate pairs and decode them with the next data chunk. - * Note: The method does no bound checks for target, therefore make sure - * the provided input data does not exceed the size of `target`. - * Returns the number of written codepoints in `target`. - */ - public decode(input: string, target: Uint32Array): number { - const length = input.length; - - if (!length) { - return 0; - } - - let size = 0; - let startPos = 0; - - // handle leftover surrogate high - if (this._interim) { - const second = input.charCodeAt(startPos++); - if (0xDC00 <= second && second <= 0xDFFF) { - target[size++] = (this._interim - 0xD800) * 0x400 + second - 0xDC00 + 0x10000; - } else { - // illegal codepoint (USC2 handling) - target[size++] = this._interim; - target[size++] = second; - } - this._interim = 0; - } - - for (let i = startPos; i < length; ++i) { - const code = input.charCodeAt(i); - // surrogate pair first - if (0xD800 <= code && code <= 0xDBFF) { - if (++i >= length) { - this._interim = code; - return size; - } - const second = input.charCodeAt(i); - if (0xDC00 <= second && second <= 0xDFFF) { - target[size++] = (code - 0xD800) * 0x400 + second - 0xDC00 + 0x10000; - } else { - // illegal codepoint (USC2 handling) - target[size++] = code; - target[size++] = second; - } - continue; - } - if (code === 0xFEFF) { - // BOM - continue; - } - target[size++] = code; - } - return size; - } -} - -/** - * Utf8Decoder - decodes UTF8 byte sequences into UTF32 codepoints. - */ -export class Utf8ToUtf32 { - public interim: Uint8Array = new Uint8Array(3); - - /** - * Clears interim bytes and resets decoder to clean state. - */ - public clear(): void { - this.interim.fill(0); - } - - /** - * Decodes UTF8 byte sequences in `input` to UTF32 codepoints in `target`. - * The methods assumes stream input and will store partly transmitted bytes - * and decode them with the next data chunk. - * Note: The method does no bound checks for target, therefore make sure - * the provided data chunk does not exceed the size of `target`. - * Returns the number of written codepoints in `target`. - */ - public decode(input: Uint8Array, target: Uint32Array): number { - const length = input.length; - - if (!length) { - return 0; - } - - let size = 0; - let byte1: number; - let byte2: number; - let byte3: number; - let byte4: number; - let codepoint = 0; - let startPos = 0; - - // handle leftover bytes - if (this.interim[0]) { - let discardInterim = false; - let cp = this.interim[0]; - cp &= ((((cp & 0xE0) === 0xC0)) ? 0x1F : (((cp & 0xF0) === 0xE0)) ? 0x0F : 0x07); - let pos = 0; - let tmp: number; - while ((tmp = this.interim[++pos] & 0x3F) && pos < 4) { - cp <<= 6; - cp |= tmp; - } - // missing bytes - read ahead from input - const type = (((this.interim[0] & 0xE0) === 0xC0)) ? 2 : (((this.interim[0] & 0xF0) === 0xE0)) ? 3 : 4; - const missing = type - pos; - while (startPos < missing) { - if (startPos >= length) { - return 0; - } - tmp = input[startPos++]; - if ((tmp & 0xC0) !== 0x80) { - // wrong continuation, discard interim bytes completely - startPos--; - discardInterim = true; - break; - } else { - // need to save so we can continue short inputs in next call - this.interim[pos++] = tmp; - cp <<= 6; - cp |= tmp & 0x3F; - } - } - if (!discardInterim) { - // final test is type dependent - if (type === 2) { - if (cp < 0x80) { - // wrong starter byte - startPos--; - } else { - target[size++] = cp; - } - } else if (type === 3) { - if (cp < 0x0800 || (cp >= 0xD800 && cp <= 0xDFFF) || cp === 0xFEFF) { - // illegal codepoint or BOM - } else { - target[size++] = cp; - } - } else { - if (cp < 0x010000 || cp > 0x10FFFF) { - // illegal codepoint - } else { - target[size++] = cp; - } - } - } - this.interim.fill(0); - } - - // loop through input - const fourStop = length - 4; - let i = startPos; - while (i < length) { - /** - * ASCII shortcut with loop unrolled to 4 consecutive ASCII chars. - * This is a compromise between speed gain for ASCII - * and penalty for non ASCII: - * For best ASCII performance the char should be stored directly into target, - * but even a single attempt to write to target and compare afterwards - * penalizes non ASCII really bad (-50%), thus we load the char into byteX first, - * which reduces ASCII performance by ~15%. - * This trial for ASCII reduces non ASCII performance by ~10% which seems acceptible - * compared to the gains. - * Note that this optimization only takes place for 4 consecutive ASCII chars, - * for any shorter it bails out. Worst case - all 4 bytes being read but - * thrown away due to the last being a non ASCII char (-10% performance). - */ - while (i < fourStop - && !((byte1 = input[i]) & 0x80) - && !((byte2 = input[i + 1]) & 0x80) - && !((byte3 = input[i + 2]) & 0x80) - && !((byte4 = input[i + 3]) & 0x80)) - { - target[size++] = byte1; - target[size++] = byte2; - target[size++] = byte3; - target[size++] = byte4; - i += 4; - } - - // reread byte1 - byte1 = input[i++]; - - // 1 byte - if (byte1 < 0x80) { - target[size++] = byte1; - - // 2 bytes - } else if ((byte1 & 0xE0) === 0xC0) { - if (i >= length) { - this.interim[0] = byte1; - return size; - } - byte2 = input[i++]; - if ((byte2 & 0xC0) !== 0x80) { - // wrong continuation - i--; - continue; - } - codepoint = (byte1 & 0x1F) << 6 | (byte2 & 0x3F); - if (codepoint < 0x80) { - // wrong starter byte - i--; - continue; - } - target[size++] = codepoint; - - // 3 bytes - } else if ((byte1 & 0xF0) === 0xE0) { - if (i >= length) { - this.interim[0] = byte1; - return size; - } - byte2 = input[i++]; - if ((byte2 & 0xC0) !== 0x80) { - // wrong continuation - i--; - continue; - } - if (i >= length) { - this.interim[0] = byte1; - this.interim[1] = byte2; - return size; - } - byte3 = input[i++]; - if ((byte3 & 0xC0) !== 0x80) { - // wrong continuation - i--; - continue; - } - codepoint = (byte1 & 0x0F) << 12 | (byte2 & 0x3F) << 6 | (byte3 & 0x3F); - if (codepoint < 0x0800 || (codepoint >= 0xD800 && codepoint <= 0xDFFF) || codepoint === 0xFEFF) { - // illegal codepoint or BOM, no i-- here - continue; - } - target[size++] = codepoint; - - // 4 bytes - } else if ((byte1 & 0xF8) === 0xF0) { - if (i >= length) { - this.interim[0] = byte1; - return size; - } - byte2 = input[i++]; - if ((byte2 & 0xC0) !== 0x80) { - // wrong continuation - i--; - continue; - } - if (i >= length) { - this.interim[0] = byte1; - this.interim[1] = byte2; - return size; - } - byte3 = input[i++]; - if ((byte3 & 0xC0) !== 0x80) { - // wrong continuation - i--; - continue; - } - if (i >= length) { - this.interim[0] = byte1; - this.interim[1] = byte2; - this.interim[2] = byte3; - return size; - } - byte4 = input[i++]; - if ((byte4 & 0xC0) !== 0x80) { - // wrong continuation - i--; - continue; - } - codepoint = (byte1 & 0x07) << 18 | (byte2 & 0x3F) << 12 | (byte3 & 0x3F) << 6 | (byte4 & 0x3F); - if (codepoint < 0x010000 || codepoint > 0x10FFFF) { - // illegal codepoint, no i-- here - continue; - } - target[size++] = codepoint; - } else { - // illegal byte, just skip - } - } - return size; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/UnicodeV6.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/UnicodeV6.ts deleted file mode 100755 index b30820306..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/UnicodeV6.ts +++ /dev/null @@ -1,133 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ -import { IUnicodeVersionProvider } from 'common/services/Services'; -import { fill } from 'common/TypedArrayUtils'; - -type CharWidth = 0 | 1 | 2; - -const BMP_COMBINING = [ - [0x0300, 0x036F], [0x0483, 0x0486], [0x0488, 0x0489], - [0x0591, 0x05BD], [0x05BF, 0x05BF], [0x05C1, 0x05C2], - [0x05C4, 0x05C5], [0x05C7, 0x05C7], [0x0600, 0x0603], - [0x0610, 0x0615], [0x064B, 0x065E], [0x0670, 0x0670], - [0x06D6, 0x06E4], [0x06E7, 0x06E8], [0x06EA, 0x06ED], - [0x070F, 0x070F], [0x0711, 0x0711], [0x0730, 0x074A], - [0x07A6, 0x07B0], [0x07EB, 0x07F3], [0x0901, 0x0902], - [0x093C, 0x093C], [0x0941, 0x0948], [0x094D, 0x094D], - [0x0951, 0x0954], [0x0962, 0x0963], [0x0981, 0x0981], - [0x09BC, 0x09BC], [0x09C1, 0x09C4], [0x09CD, 0x09CD], - [0x09E2, 0x09E3], [0x0A01, 0x0A02], [0x0A3C, 0x0A3C], - [0x0A41, 0x0A42], [0x0A47, 0x0A48], [0x0A4B, 0x0A4D], - [0x0A70, 0x0A71], [0x0A81, 0x0A82], [0x0ABC, 0x0ABC], - [0x0AC1, 0x0AC5], [0x0AC7, 0x0AC8], [0x0ACD, 0x0ACD], - [0x0AE2, 0x0AE3], [0x0B01, 0x0B01], [0x0B3C, 0x0B3C], - [0x0B3F, 0x0B3F], [0x0B41, 0x0B43], [0x0B4D, 0x0B4D], - [0x0B56, 0x0B56], [0x0B82, 0x0B82], [0x0BC0, 0x0BC0], - [0x0BCD, 0x0BCD], [0x0C3E, 0x0C40], [0x0C46, 0x0C48], - [0x0C4A, 0x0C4D], [0x0C55, 0x0C56], [0x0CBC, 0x0CBC], - [0x0CBF, 0x0CBF], [0x0CC6, 0x0CC6], [0x0CCC, 0x0CCD], - [0x0CE2, 0x0CE3], [0x0D41, 0x0D43], [0x0D4D, 0x0D4D], - [0x0DCA, 0x0DCA], [0x0DD2, 0x0DD4], [0x0DD6, 0x0DD6], - [0x0E31, 0x0E31], [0x0E34, 0x0E3A], [0x0E47, 0x0E4E], - [0x0EB1, 0x0EB1], [0x0EB4, 0x0EB9], [0x0EBB, 0x0EBC], - [0x0EC8, 0x0ECD], [0x0F18, 0x0F19], [0x0F35, 0x0F35], - [0x0F37, 0x0F37], [0x0F39, 0x0F39], [0x0F71, 0x0F7E], - [0x0F80, 0x0F84], [0x0F86, 0x0F87], [0x0F90, 0x0F97], - [0x0F99, 0x0FBC], [0x0FC6, 0x0FC6], [0x102D, 0x1030], - [0x1032, 0x1032], [0x1036, 0x1037], [0x1039, 0x1039], - [0x1058, 0x1059], [0x1160, 0x11FF], [0x135F, 0x135F], - [0x1712, 0x1714], [0x1732, 0x1734], [0x1752, 0x1753], - [0x1772, 0x1773], [0x17B4, 0x17B5], [0x17B7, 0x17BD], - [0x17C6, 0x17C6], [0x17C9, 0x17D3], [0x17DD, 0x17DD], - [0x180B, 0x180D], [0x18A9, 0x18A9], [0x1920, 0x1922], - [0x1927, 0x1928], [0x1932, 0x1932], [0x1939, 0x193B], - [0x1A17, 0x1A18], [0x1B00, 0x1B03], [0x1B34, 0x1B34], - [0x1B36, 0x1B3A], [0x1B3C, 0x1B3C], [0x1B42, 0x1B42], - [0x1B6B, 0x1B73], [0x1DC0, 0x1DCA], [0x1DFE, 0x1DFF], - [0x200B, 0x200F], [0x202A, 0x202E], [0x2060, 0x2063], - [0x206A, 0x206F], [0x20D0, 0x20EF], [0x302A, 0x302F], - [0x3099, 0x309A], [0xA806, 0xA806], [0xA80B, 0xA80B], - [0xA825, 0xA826], [0xFB1E, 0xFB1E], [0xFE00, 0xFE0F], - [0xFE20, 0xFE23], [0xFEFF, 0xFEFF], [0xFFF9, 0xFFFB] -]; -const HIGH_COMBINING = [ - [0x10A01, 0x10A03], [0x10A05, 0x10A06], [0x10A0C, 0x10A0F], - [0x10A38, 0x10A3A], [0x10A3F, 0x10A3F], [0x1D167, 0x1D169], - [0x1D173, 0x1D182], [0x1D185, 0x1D18B], [0x1D1AA, 0x1D1AD], - [0x1D242, 0x1D244], [0xE0001, 0xE0001], [0xE0020, 0xE007F], - [0xE0100, 0xE01EF] -]; - -// BMP lookup table, lazy initialized during first addon loading -let table: Uint8Array; - -function bisearch(ucs: number, data: number[][]): boolean { - let min = 0; - let max = data.length - 1; - let mid; - if (ucs < data[0][0] || ucs > data[max][1]) { - return false; - } - while (max >= min) { - mid = (min + max) >> 1; - if (ucs > data[mid][1]) { - min = mid + 1; - } else if (ucs < data[mid][0]) { - max = mid - 1; - } else { - return true; - } - } - return false; -} - -export class UnicodeV6 implements IUnicodeVersionProvider { - public readonly version = '6'; - - constructor() { - // init lookup table once - if (!table) { - table = new Uint8Array(65536); - fill(table, 1); - table[0] = 0; - // control chars - fill(table, 0, 1, 32); - fill(table, 0, 0x7f, 0xa0); - - // apply wide char rules first - // wide chars - fill(table, 2, 0x1100, 0x1160); - table[0x2329] = 2; - table[0x232a] = 2; - fill(table, 2, 0x2e80, 0xa4d0); - table[0x303f] = 1; // wrongly in last line - - fill(table, 2, 0xac00, 0xd7a4); - fill(table, 2, 0xf900, 0xfb00); - fill(table, 2, 0xfe10, 0xfe1a); - fill(table, 2, 0xfe30, 0xfe70); - fill(table, 2, 0xff00, 0xff61); - fill(table, 2, 0xffe0, 0xffe7); - - // apply combining last to ensure we overwrite - // wrongly wide set chars: - // the original algo evals combining first and falls - // through to wide check so we simply do here the opposite - // combining 0 - for (let r = 0; r < BMP_COMBINING.length; ++r) { - fill(table, 0, BMP_COMBINING[r][0], BMP_COMBINING[r][1] + 1); - } - } - } - - public wcwidth(num: number): CharWidth { - if (num < 32) return 0; - if (num < 127) return 1; - if (num < 65536) return table[num] as CharWidth; - if (bisearch(num, HIGH_COMBINING)) return 0; - if ((num >= 0x20000 && num <= 0x2fffd) || (num >= 0x30000 && num <= 0x3fffd)) return 2; - return 1; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/WriteBuffer.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/WriteBuffer.ts deleted file mode 100755 index c7d824585..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/input/WriteBuffer.ts +++ /dev/null @@ -1,110 +0,0 @@ - -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -declare const setTimeout: (handler: () => void, timeout?: number) => void; - -/** - * Safety watermark to avoid memory exhaustion and browser engine crash on fast data input. - * Enable flow control to avoid this limit and make sure that your backend correctly - * propagates this to the underlying pty. (see docs for further instructions) - * Since this limit is meant as a safety parachute to prevent browser crashs, - * it is set to a very high number. Typically xterm.js gets unresponsive with - * a 100 times lower number (>500 kB). - */ -const DISCARD_WATERMARK = 50000000; // ~50 MB - -/** - * The max number of ms to spend on writes before allowing the renderer to - * catch up with a 0ms setTimeout. A value of < 33 to keep us close to - * 30fps, and a value of < 16 to try to run at 60fps. Of course, the real FPS - * depends on the time it takes for the renderer to draw the frame. - */ -const WRITE_TIMEOUT_MS = 12; - -/** - * Threshold of max held chunks in the write buffer, that were already processed. - * This is a tradeoff between extensive write buffer shifts (bad runtime) and high - * memory consumption by data thats not used anymore. - */ -const WRITE_BUFFER_LENGTH_THRESHOLD = 50; - -export class WriteBuffer { - private _writeBuffer: (string | Uint8Array)[] = []; - private _callbacks: ((() => void) | undefined)[] = []; - private _pendingData = 0; - private _bufferOffset = 0; - - constructor(private _action: (data: string | Uint8Array) => void) { } - - public writeSync(data: string | Uint8Array): void { - // force sync processing on pending data chunks to avoid in-band data scrambling - // does the same as innerWrite but without event loop - if (this._writeBuffer.length) { - for (let i = this._bufferOffset; i < this._writeBuffer.length; ++i) { - const data = this._writeBuffer[i]; - const cb = this._callbacks[i]; - this._action(data); - if (cb) cb(); - } - // reset all to avoid reprocessing of chunks with scheduled innerWrite call - this._writeBuffer = []; - this._callbacks = []; - this._pendingData = 0; - // stop scheduled innerWrite by offset > length condition - this._bufferOffset = 0x7FFFFFFF; - } - // handle current data chunk - this._action(data); - } - - public write(data: string | Uint8Array, callback?: () => void): void { - if (this._pendingData > DISCARD_WATERMARK) { - throw new Error('write data discarded, use flow control to avoid losing data'); - } - - // schedule chunk processing for next event loop run - if (!this._writeBuffer.length) { - this._bufferOffset = 0; - setTimeout(() => this._innerWrite()); - } - - this._pendingData += data.length; - this._writeBuffer.push(data); - this._callbacks.push(callback); - } - - protected _innerWrite(): void { - const startTime = Date.now(); - while (this._writeBuffer.length > this._bufferOffset) { - const data = this._writeBuffer[this._bufferOffset]; - const cb = this._callbacks[this._bufferOffset]; - this._bufferOffset++; - - this._action(data); - this._pendingData -= data.length; - if (cb) cb(); - - if (Date.now() - startTime >= WRITE_TIMEOUT_MS) { - break; - } - } - if (this._writeBuffer.length > this._bufferOffset) { - // Allow renderer to catch up before processing the next batch - // trim already processed chunks if we are above threshold - if (this._bufferOffset > WRITE_BUFFER_LENGTH_THRESHOLD) { - this._writeBuffer = this._writeBuffer.slice(this._bufferOffset); - this._callbacks = this._callbacks.slice(this._bufferOffset); - this._bufferOffset = 0; - } - setTimeout(() => this._innerWrite(), 0); - } else { - this._writeBuffer = []; - this._callbacks = []; - this._pendingData = 0; - this._bufferOffset = 0; - } - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/Constants.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/Constants.ts deleted file mode 100755 index 85156c3eb..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/Constants.ts +++ /dev/null @@ -1,58 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -/** - * Internal states of EscapeSequenceParser. - */ -export const enum ParserState { - GROUND = 0, - ESCAPE = 1, - ESCAPE_INTERMEDIATE = 2, - CSI_ENTRY = 3, - CSI_PARAM = 4, - CSI_INTERMEDIATE = 5, - CSI_IGNORE = 6, - SOS_PM_APC_STRING = 7, - OSC_STRING = 8, - DCS_ENTRY = 9, - DCS_PARAM = 10, - DCS_IGNORE = 11, - DCS_INTERMEDIATE = 12, - DCS_PASSTHROUGH = 13 -} - -/** -* Internal actions of EscapeSequenceParser. -*/ -export const enum ParserAction { - IGNORE = 0, - ERROR = 1, - PRINT = 2, - EXECUTE = 3, - OSC_START = 4, - OSC_PUT = 5, - OSC_END = 6, - CSI_DISPATCH = 7, - PARAM = 8, - COLLECT = 9, - ESC_DISPATCH = 10, - CLEAR = 11, - DCS_HOOK = 12, - DCS_PUT = 13, - DCS_UNHOOK = 14 -} - -/** - * Internal states of OscParser. - */ -export const enum OscState { - START = 0, - ID = 1, - PAYLOAD = 2, - ABORT = 3 -} - -// payload limit for OSC and DCS -export const PAYLOAD_LIMIT = 10000000; diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/DcsParser.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/DcsParser.ts deleted file mode 100755 index 2fa289921..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/DcsParser.ts +++ /dev/null @@ -1,151 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IDisposable } from 'common/Types'; -import { IDcsHandler, IParams, IHandlerCollection, IDcsParser, DcsFallbackHandlerType } from 'common/parser/Types'; -import { utf32ToString } from 'common/input/TextDecoder'; -import { Params } from 'common/parser/Params'; -import { PAYLOAD_LIMIT } from 'common/parser/Constants'; - -const EMPTY_HANDLERS: IDcsHandler[] = []; - -export class DcsParser implements IDcsParser { - private _handlers: IHandlerCollection = Object.create(null); - private _active: IDcsHandler[] = EMPTY_HANDLERS; - private _ident: number = 0; - private _handlerFb: DcsFallbackHandlerType = () => {}; - - public dispose(): void { - this._handlers = Object.create(null); - this._handlerFb = () => {}; - this._active = EMPTY_HANDLERS; - } - - public registerHandler(ident: number, handler: IDcsHandler): IDisposable { - if (this._handlers[ident] === undefined) { - this._handlers[ident] = []; - } - const handlerList = this._handlers[ident]; - handlerList.push(handler); - return { - dispose: () => { - const handlerIndex = handlerList.indexOf(handler); - if (handlerIndex !== -1) { - handlerList.splice(handlerIndex, 1); - } - } - }; - } - - public clearHandler(ident: number): void { - if (this._handlers[ident]) delete this._handlers[ident]; - } - - public setHandlerFallback(handler: DcsFallbackHandlerType): void { - this._handlerFb = handler; - } - - public reset(): void { - if (this._active.length) { - this.unhook(false); - } - this._active = EMPTY_HANDLERS; - this._ident = 0; - } - - public hook(ident: number, params: IParams): void { - // always reset leftover handlers - this.reset(); - this._ident = ident; - this._active = this._handlers[ident] || EMPTY_HANDLERS; - if (!this._active.length) { - this._handlerFb(this._ident, 'HOOK', params); - } else { - for (let j = this._active.length - 1; j >= 0; j--) { - this._active[j].hook(params); - } - } - } - - public put(data: Uint32Array, start: number, end: number): void { - if (!this._active.length) { - this._handlerFb(this._ident, 'PUT', utf32ToString(data, start, end)); - } else { - for (let j = this._active.length - 1; j >= 0; j--) { - this._active[j].put(data, start, end); - } - } - } - - public unhook(success: boolean): void { - if (!this._active.length) { - this._handlerFb(this._ident, 'UNHOOK', success); - } else { - let j = this._active.length - 1; - for (; j >= 0; j--) { - if (this._active[j].unhook(success)) { - break; - } - } - j--; - // cleanup left over handlers - for (; j >= 0; j--) { - this._active[j].unhook(false); - } - } - this._active = EMPTY_HANDLERS; - this._ident = 0; - } -} - -// predefine empty params as [0] (ZDM) -const EMPTY_PARAMS = new Params(); -EMPTY_PARAMS.addParam(0); - -/** - * Convenient class to create a DCS handler from a single callback function. - * Note: The payload is currently limited to 50 MB (hardcoded). - */ -export class DcsHandler implements IDcsHandler { - private _data = ''; - private _params: IParams = EMPTY_PARAMS; - private _hitLimit: boolean = false; - - constructor(private _handler: (data: string, params: IParams) => boolean) {} - - public hook(params: IParams): void { - // since we need to preserve params until `unhook`, we have to clone it - // (only borrowed from parser and spans multiple parser states) - // perf optimization: - // clone only, if we have non empty params, otherwise stick with default - this._params = (params.length > 1 || params.params[0]) ? params.clone() : EMPTY_PARAMS; - this._data = ''; - this._hitLimit = false; - } - - public put(data: Uint32Array, start: number, end: number): void { - if (this._hitLimit) { - return; - } - this._data += utf32ToString(data, start, end); - if (this._data.length > PAYLOAD_LIMIT) { - this._data = ''; - this._hitLimit = true; - } - } - - public unhook(success: boolean): boolean { - let ret = false; - if (this._hitLimit) { - ret = false; - } else if (success) { - ret = this._handler(this._data, this._params); - } - this._params = EMPTY_PARAMS; - this._data = ''; - this._hitLimit = false; - return ret; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/EscapeSequenceParser.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/EscapeSequenceParser.ts deleted file mode 100755 index 9a403feb1..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/EscapeSequenceParser.ts +++ /dev/null @@ -1,626 +0,0 @@ -/** - * Copyright (c) 2018 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IParsingState, IDcsHandler, IEscapeSequenceParser, IParams, IOscHandler, IHandlerCollection, CsiHandlerType, OscFallbackHandlerType, IOscParser, EscHandlerType, IDcsParser, DcsFallbackHandlerType, IFunctionIdentifier, ExecuteFallbackHandlerType, CsiFallbackHandlerType, EscFallbackHandlerType, PrintHandlerType, PrintFallbackHandlerType, ExecuteHandlerType } from 'common/parser/Types'; -import { ParserState, ParserAction } from 'common/parser/Constants'; -import { Disposable } from 'common/Lifecycle'; -import { IDisposable } from 'common/Types'; -import { fill } from 'common/TypedArrayUtils'; -import { Params } from 'common/parser/Params'; -import { OscParser } from 'common/parser/OscParser'; -import { DcsParser } from 'common/parser/DcsParser'; - -/** - * Table values are generated like this: - * index: currentState << TableValue.INDEX_STATE_SHIFT | charCode - * value: action << TableValue.TRANSITION_ACTION_SHIFT | nextState - */ -const enum TableAccess { - TRANSITION_ACTION_SHIFT = 4, - TRANSITION_STATE_MASK = 15, - INDEX_STATE_SHIFT = 8 -} - -/** - * Transition table for EscapeSequenceParser. - */ -export class TransitionTable { - public table: Uint8Array; - - constructor(length: number) { - this.table = new Uint8Array(length); - } - - /** - * Set default transition. - * @param action default action - * @param next default next state - */ - public setDefault(action: ParserAction, next: ParserState): void { - fill(this.table, action << TableAccess.TRANSITION_ACTION_SHIFT | next); - } - - /** - * Add a transition to the transition table. - * @param code input character code - * @param state current parser state - * @param action parser action to be done - * @param next next parser state - */ - public add(code: number, state: ParserState, action: ParserAction, next: ParserState): void { - this.table[state << TableAccess.INDEX_STATE_SHIFT | code] = action << TableAccess.TRANSITION_ACTION_SHIFT | next; - } - - /** - * Add transitions for multiple input character codes. - * @param codes input character code array - * @param state current parser state - * @param action parser action to be done - * @param next next parser state - */ - public addMany(codes: number[], state: ParserState, action: ParserAction, next: ParserState): void { - for (let i = 0; i < codes.length; i++) { - this.table[state << TableAccess.INDEX_STATE_SHIFT | codes[i]] = action << TableAccess.TRANSITION_ACTION_SHIFT | next; - } - } -} - - -// Pseudo-character placeholder for printable non-ascii characters (unicode). -const NON_ASCII_PRINTABLE = 0xA0; - - -/** - * VT500 compatible transition table. - * Taken from https://vt100.net/emu/dec_ansi_parser. - */ -export const VT500_TRANSITION_TABLE = (function (): TransitionTable { - const table: TransitionTable = new TransitionTable(4095); - - // range macro for byte - const BYTE_VALUES = 256; - const blueprint = Array.apply(null, Array(BYTE_VALUES)).map((unused: any, i: number) => i); - const r = (start: number, end: number): number[] => blueprint.slice(start, end); - - // Default definitions. - const PRINTABLES = r(0x20, 0x7f); // 0x20 (SP) included, 0x7F (DEL) excluded - const EXECUTABLES = r(0x00, 0x18); - EXECUTABLES.push(0x19); - EXECUTABLES.push.apply(EXECUTABLES, r(0x1c, 0x20)); - - const states: number[] = r(ParserState.GROUND, ParserState.DCS_PASSTHROUGH + 1); - let state: any; - - // set default transition - table.setDefault(ParserAction.ERROR, ParserState.GROUND); - // printables - table.addMany(PRINTABLES, ParserState.GROUND, ParserAction.PRINT, ParserState.GROUND); - // global anywhere rules - for (state in states) { - table.addMany([0x18, 0x1a, 0x99, 0x9a], state, ParserAction.EXECUTE, ParserState.GROUND); - table.addMany(r(0x80, 0x90), state, ParserAction.EXECUTE, ParserState.GROUND); - table.addMany(r(0x90, 0x98), state, ParserAction.EXECUTE, ParserState.GROUND); - table.add(0x9c, state, ParserAction.IGNORE, ParserState.GROUND); // ST as terminator - table.add(0x1b, state, ParserAction.CLEAR, ParserState.ESCAPE); // ESC - table.add(0x9d, state, ParserAction.OSC_START, ParserState.OSC_STRING); // OSC - table.addMany([0x98, 0x9e, 0x9f], state, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING); - table.add(0x9b, state, ParserAction.CLEAR, ParserState.CSI_ENTRY); // CSI - table.add(0x90, state, ParserAction.CLEAR, ParserState.DCS_ENTRY); // DCS - } - // rules for executables and 7f - table.addMany(EXECUTABLES, ParserState.GROUND, ParserAction.EXECUTE, ParserState.GROUND); - table.addMany(EXECUTABLES, ParserState.ESCAPE, ParserAction.EXECUTE, ParserState.ESCAPE); - table.add(0x7f, ParserState.ESCAPE, ParserAction.IGNORE, ParserState.ESCAPE); - table.addMany(EXECUTABLES, ParserState.OSC_STRING, ParserAction.IGNORE, ParserState.OSC_STRING); - table.addMany(EXECUTABLES, ParserState.CSI_ENTRY, ParserAction.EXECUTE, ParserState.CSI_ENTRY); - table.add(0x7f, ParserState.CSI_ENTRY, ParserAction.IGNORE, ParserState.CSI_ENTRY); - table.addMany(EXECUTABLES, ParserState.CSI_PARAM, ParserAction.EXECUTE, ParserState.CSI_PARAM); - table.add(0x7f, ParserState.CSI_PARAM, ParserAction.IGNORE, ParserState.CSI_PARAM); - table.addMany(EXECUTABLES, ParserState.CSI_IGNORE, ParserAction.EXECUTE, ParserState.CSI_IGNORE); - table.addMany(EXECUTABLES, ParserState.CSI_INTERMEDIATE, ParserAction.EXECUTE, ParserState.CSI_INTERMEDIATE); - table.add(0x7f, ParserState.CSI_INTERMEDIATE, ParserAction.IGNORE, ParserState.CSI_INTERMEDIATE); - table.addMany(EXECUTABLES, ParserState.ESCAPE_INTERMEDIATE, ParserAction.EXECUTE, ParserState.ESCAPE_INTERMEDIATE); - table.add(0x7f, ParserState.ESCAPE_INTERMEDIATE, ParserAction.IGNORE, ParserState.ESCAPE_INTERMEDIATE); - // osc - table.add(0x5d, ParserState.ESCAPE, ParserAction.OSC_START, ParserState.OSC_STRING); - table.addMany(PRINTABLES, ParserState.OSC_STRING, ParserAction.OSC_PUT, ParserState.OSC_STRING); - table.add(0x7f, ParserState.OSC_STRING, ParserAction.OSC_PUT, ParserState.OSC_STRING); - table.addMany([0x9c, 0x1b, 0x18, 0x1a, 0x07], ParserState.OSC_STRING, ParserAction.OSC_END, ParserState.GROUND); - table.addMany(r(0x1c, 0x20), ParserState.OSC_STRING, ParserAction.IGNORE, ParserState.OSC_STRING); - // sos/pm/apc does nothing - table.addMany([0x58, 0x5e, 0x5f], ParserState.ESCAPE, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING); - table.addMany(PRINTABLES, ParserState.SOS_PM_APC_STRING, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING); - table.addMany(EXECUTABLES, ParserState.SOS_PM_APC_STRING, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING); - table.add(0x9c, ParserState.SOS_PM_APC_STRING, ParserAction.IGNORE, ParserState.GROUND); - table.add(0x7f, ParserState.SOS_PM_APC_STRING, ParserAction.IGNORE, ParserState.SOS_PM_APC_STRING); - // csi entries - table.add(0x5b, ParserState.ESCAPE, ParserAction.CLEAR, ParserState.CSI_ENTRY); - table.addMany(r(0x40, 0x7f), ParserState.CSI_ENTRY, ParserAction.CSI_DISPATCH, ParserState.GROUND); - table.addMany(r(0x30, 0x3c), ParserState.CSI_ENTRY, ParserAction.PARAM, ParserState.CSI_PARAM); - table.addMany([0x3c, 0x3d, 0x3e, 0x3f], ParserState.CSI_ENTRY, ParserAction.COLLECT, ParserState.CSI_PARAM); - table.addMany(r(0x30, 0x3c), ParserState.CSI_PARAM, ParserAction.PARAM, ParserState.CSI_PARAM); - table.addMany(r(0x40, 0x7f), ParserState.CSI_PARAM, ParserAction.CSI_DISPATCH, ParserState.GROUND); - table.addMany([0x3c, 0x3d, 0x3e, 0x3f], ParserState.CSI_PARAM, ParserAction.IGNORE, ParserState.CSI_IGNORE); - table.addMany(r(0x20, 0x40), ParserState.CSI_IGNORE, ParserAction.IGNORE, ParserState.CSI_IGNORE); - table.add(0x7f, ParserState.CSI_IGNORE, ParserAction.IGNORE, ParserState.CSI_IGNORE); - table.addMany(r(0x40, 0x7f), ParserState.CSI_IGNORE, ParserAction.IGNORE, ParserState.GROUND); - table.addMany(r(0x20, 0x30), ParserState.CSI_ENTRY, ParserAction.COLLECT, ParserState.CSI_INTERMEDIATE); - table.addMany(r(0x20, 0x30), ParserState.CSI_INTERMEDIATE, ParserAction.COLLECT, ParserState.CSI_INTERMEDIATE); - table.addMany(r(0x30, 0x40), ParserState.CSI_INTERMEDIATE, ParserAction.IGNORE, ParserState.CSI_IGNORE); - table.addMany(r(0x40, 0x7f), ParserState.CSI_INTERMEDIATE, ParserAction.CSI_DISPATCH, ParserState.GROUND); - table.addMany(r(0x20, 0x30), ParserState.CSI_PARAM, ParserAction.COLLECT, ParserState.CSI_INTERMEDIATE); - // esc_intermediate - table.addMany(r(0x20, 0x30), ParserState.ESCAPE, ParserAction.COLLECT, ParserState.ESCAPE_INTERMEDIATE); - table.addMany(r(0x20, 0x30), ParserState.ESCAPE_INTERMEDIATE, ParserAction.COLLECT, ParserState.ESCAPE_INTERMEDIATE); - table.addMany(r(0x30, 0x7f), ParserState.ESCAPE_INTERMEDIATE, ParserAction.ESC_DISPATCH, ParserState.GROUND); - table.addMany(r(0x30, 0x50), ParserState.ESCAPE, ParserAction.ESC_DISPATCH, ParserState.GROUND); - table.addMany(r(0x51, 0x58), ParserState.ESCAPE, ParserAction.ESC_DISPATCH, ParserState.GROUND); - table.addMany([0x59, 0x5a, 0x5c], ParserState.ESCAPE, ParserAction.ESC_DISPATCH, ParserState.GROUND); - table.addMany(r(0x60, 0x7f), ParserState.ESCAPE, ParserAction.ESC_DISPATCH, ParserState.GROUND); - // dcs entry - table.add(0x50, ParserState.ESCAPE, ParserAction.CLEAR, ParserState.DCS_ENTRY); - table.addMany(EXECUTABLES, ParserState.DCS_ENTRY, ParserAction.IGNORE, ParserState.DCS_ENTRY); - table.add(0x7f, ParserState.DCS_ENTRY, ParserAction.IGNORE, ParserState.DCS_ENTRY); - table.addMany(r(0x1c, 0x20), ParserState.DCS_ENTRY, ParserAction.IGNORE, ParserState.DCS_ENTRY); - table.addMany(r(0x20, 0x30), ParserState.DCS_ENTRY, ParserAction.COLLECT, ParserState.DCS_INTERMEDIATE); - table.addMany(r(0x30, 0x3c), ParserState.DCS_ENTRY, ParserAction.PARAM, ParserState.DCS_PARAM); - table.addMany([0x3c, 0x3d, 0x3e, 0x3f], ParserState.DCS_ENTRY, ParserAction.COLLECT, ParserState.DCS_PARAM); - table.addMany(EXECUTABLES, ParserState.DCS_IGNORE, ParserAction.IGNORE, ParserState.DCS_IGNORE); - table.addMany(r(0x20, 0x80), ParserState.DCS_IGNORE, ParserAction.IGNORE, ParserState.DCS_IGNORE); - table.addMany(r(0x1c, 0x20), ParserState.DCS_IGNORE, ParserAction.IGNORE, ParserState.DCS_IGNORE); - table.addMany(EXECUTABLES, ParserState.DCS_PARAM, ParserAction.IGNORE, ParserState.DCS_PARAM); - table.add(0x7f, ParserState.DCS_PARAM, ParserAction.IGNORE, ParserState.DCS_PARAM); - table.addMany(r(0x1c, 0x20), ParserState.DCS_PARAM, ParserAction.IGNORE, ParserState.DCS_PARAM); - table.addMany(r(0x30, 0x3c), ParserState.DCS_PARAM, ParserAction.PARAM, ParserState.DCS_PARAM); - table.addMany([0x3c, 0x3d, 0x3e, 0x3f], ParserState.DCS_PARAM, ParserAction.IGNORE, ParserState.DCS_IGNORE); - table.addMany(r(0x20, 0x30), ParserState.DCS_PARAM, ParserAction.COLLECT, ParserState.DCS_INTERMEDIATE); - table.addMany(EXECUTABLES, ParserState.DCS_INTERMEDIATE, ParserAction.IGNORE, ParserState.DCS_INTERMEDIATE); - table.add(0x7f, ParserState.DCS_INTERMEDIATE, ParserAction.IGNORE, ParserState.DCS_INTERMEDIATE); - table.addMany(r(0x1c, 0x20), ParserState.DCS_INTERMEDIATE, ParserAction.IGNORE, ParserState.DCS_INTERMEDIATE); - table.addMany(r(0x20, 0x30), ParserState.DCS_INTERMEDIATE, ParserAction.COLLECT, ParserState.DCS_INTERMEDIATE); - table.addMany(r(0x30, 0x40), ParserState.DCS_INTERMEDIATE, ParserAction.IGNORE, ParserState.DCS_IGNORE); - table.addMany(r(0x40, 0x7f), ParserState.DCS_INTERMEDIATE, ParserAction.DCS_HOOK, ParserState.DCS_PASSTHROUGH); - table.addMany(r(0x40, 0x7f), ParserState.DCS_PARAM, ParserAction.DCS_HOOK, ParserState.DCS_PASSTHROUGH); - table.addMany(r(0x40, 0x7f), ParserState.DCS_ENTRY, ParserAction.DCS_HOOK, ParserState.DCS_PASSTHROUGH); - table.addMany(EXECUTABLES, ParserState.DCS_PASSTHROUGH, ParserAction.DCS_PUT, ParserState.DCS_PASSTHROUGH); - table.addMany(PRINTABLES, ParserState.DCS_PASSTHROUGH, ParserAction.DCS_PUT, ParserState.DCS_PASSTHROUGH); - table.add(0x7f, ParserState.DCS_PASSTHROUGH, ParserAction.IGNORE, ParserState.DCS_PASSTHROUGH); - table.addMany([0x1b, 0x9c, 0x18, 0x1a], ParserState.DCS_PASSTHROUGH, ParserAction.DCS_UNHOOK, ParserState.GROUND); - // special handling of unicode chars - table.add(NON_ASCII_PRINTABLE, ParserState.GROUND, ParserAction.PRINT, ParserState.GROUND); - table.add(NON_ASCII_PRINTABLE, ParserState.OSC_STRING, ParserAction.OSC_PUT, ParserState.OSC_STRING); - table.add(NON_ASCII_PRINTABLE, ParserState.CSI_IGNORE, ParserAction.IGNORE, ParserState.CSI_IGNORE); - table.add(NON_ASCII_PRINTABLE, ParserState.DCS_IGNORE, ParserAction.IGNORE, ParserState.DCS_IGNORE); - table.add(NON_ASCII_PRINTABLE, ParserState.DCS_PASSTHROUGH, ParserAction.DCS_PUT, ParserState.DCS_PASSTHROUGH); - return table; -})(); - - -/** - * EscapeSequenceParser. - * This class implements the ANSI/DEC compatible parser described by - * Paul Williams (https://vt100.net/emu/dec_ansi_parser). - * - * To implement custom ANSI compliant escape sequences it is not needed to - * alter this parser, instead consider registering a custom handler. - * For non ANSI compliant sequences change the transition table with - * the optional `transitions` constructor argument and - * reimplement the `parse` method. - * - * This parser is currently hardcoded to operate in ZDM (Zero Default Mode) - * as suggested by the original parser, thus empty parameters are set to 0. - * This this is not in line with the latest ECMA-48 specification - * (ZDM was part of the early specs and got completely removed later on). - * - * Other than the original parser from vt100.net this parser supports - * sub parameters in digital parameters separated by colons. Empty sub parameters - * are set to -1 (no ZDM for sub parameters). - * - * About prefix and intermediate bytes: - * This parser follows the assumptions of the vt100.net parser with these restrictions: - * - only one prefix byte is allowed as first parameter byte, byte range 0x3c .. 0x3f - * - max. two intermediates are respected, byte range 0x20 .. 0x2f - * Note that this is not in line with ECMA-48 which does not limit either of those. - * Furthermore ECMA-48 allows the prefix byte range at any param byte position. Currently - * there are no known sequences that follow the broader definition of the specification. - * - * TODO: implement error recovery hook via error handler return values - */ -export class EscapeSequenceParser extends Disposable implements IEscapeSequenceParser { - public initialState: number; - public currentState: number; - public precedingCodepoint: number; - - // buffers over several parse calls - protected _params: Params; - protected _collect: number; - - // handler lookup containers - protected _printHandler: PrintHandlerType; - protected _executeHandlers: {[flag: number]: ExecuteHandlerType}; - protected _csiHandlers: IHandlerCollection; - protected _escHandlers: IHandlerCollection; - protected _oscParser: IOscParser; - protected _dcsParser: IDcsParser; - protected _errorHandler: (state: IParsingState) => IParsingState; - - // fallback handlers - protected _printHandlerFb: PrintFallbackHandlerType; - protected _executeHandlerFb: ExecuteFallbackHandlerType; - protected _csiHandlerFb: CsiFallbackHandlerType; - protected _escHandlerFb: EscFallbackHandlerType; - protected _errorHandlerFb: (state: IParsingState) => IParsingState; - - constructor( - protected readonly _transitions: TransitionTable = VT500_TRANSITION_TABLE - ) { - super(); - - this.initialState = ParserState.GROUND; - this.currentState = this.initialState; - this._params = new Params(); // defaults to 32 storable params/subparams - this._params.addParam(0); // ZDM - this._collect = 0; - this.precedingCodepoint = 0; - - // set default fallback handlers and handler lookup containers - this._printHandlerFb = (data, start, end): void => { }; - this._executeHandlerFb = (code: number): void => { }; - this._csiHandlerFb = (ident: number, params: IParams): void => { }; - this._escHandlerFb = (ident: number): void => { }; - this._errorHandlerFb = (state: IParsingState): IParsingState => state; - this._printHandler = this._printHandlerFb; - this._executeHandlers = Object.create(null); - this._csiHandlers = Object.create(null); - this._escHandlers = Object.create(null); - this._oscParser = new OscParser(); - this._dcsParser = new DcsParser(); - this._errorHandler = this._errorHandlerFb; - - // swallow 7bit ST (ESC+\) - this.registerEscHandler({final: '\\'}, () => true); - } - - protected _identifier(id: IFunctionIdentifier, finalRange: number[] = [0x40, 0x7e]): number { - let res = 0; - if (id.prefix) { - if (id.prefix.length > 1) { - throw new Error('only one byte as prefix supported'); - } - res = id.prefix.charCodeAt(0); - if (res && 0x3c > res || res > 0x3f) { - throw new Error('prefix must be in range 0x3c .. 0x3f'); - } - } - if (id.intermediates) { - if (id.intermediates.length > 2) { - throw new Error('only two bytes as intermediates are supported'); - } - for (let i = 0; i < id.intermediates.length; ++i) { - const intermediate = id.intermediates.charCodeAt(i); - if (0x20 > intermediate || intermediate > 0x2f) { - throw new Error('intermediate must be in range 0x20 .. 0x2f'); - } - res <<= 8; - res |= intermediate; - } - } - if (id.final.length !== 1) { - throw new Error('final must be a single byte'); - } - const finalCode = id.final.charCodeAt(0); - if (finalRange[0] > finalCode || finalCode > finalRange[1]) { - throw new Error(`final must be in range ${finalRange[0]} .. ${finalRange[1]}`); - } - res <<= 8; - res |= finalCode; - - return res; - } - - public identToString(ident: number): string { - const res: string[] = []; - while (ident) { - res.push(String.fromCharCode(ident & 0xFF)); - ident >>= 8; - } - return res.reverse().join(''); - } - - public dispose(): void { - this._csiHandlers = Object.create(null); - this._executeHandlers = Object.create(null); - this._escHandlers = Object.create(null); - this._oscParser.dispose(); - this._dcsParser.dispose(); - } - - public setPrintHandler(handler: PrintHandlerType): void { - this._printHandler = handler; - } - public clearPrintHandler(): void { - this._printHandler = this._printHandlerFb; - } - - public registerEscHandler(id: IFunctionIdentifier, handler: EscHandlerType): IDisposable { - const ident = this._identifier(id, [0x30, 0x7e]); - if (this._escHandlers[ident] === undefined) { - this._escHandlers[ident] = []; - } - const handlerList = this._escHandlers[ident]; - handlerList.push(handler); - return { - dispose: () => { - const handlerIndex = handlerList.indexOf(handler); - if (handlerIndex !== -1) { - handlerList.splice(handlerIndex, 1); - } - } - }; - } - public clearEscHandler(id: IFunctionIdentifier): void { - if (this._escHandlers[this._identifier(id, [0x30, 0x7e])]) delete this._escHandlers[this._identifier(id, [0x30, 0x7e])]; - } - public setEscHandlerFallback(handler: EscFallbackHandlerType): void { - this._escHandlerFb = handler; - } - - public setExecuteHandler(flag: string, handler: ExecuteHandlerType): void { - this._executeHandlers[flag.charCodeAt(0)] = handler; - } - public clearExecuteHandler(flag: string): void { - if (this._executeHandlers[flag.charCodeAt(0)]) delete this._executeHandlers[flag.charCodeAt(0)]; - } - public setExecuteHandlerFallback(handler: ExecuteFallbackHandlerType): void { - this._executeHandlerFb = handler; - } - - public registerCsiHandler(id: IFunctionIdentifier, handler: CsiHandlerType): IDisposable { - const ident = this._identifier(id); - if (this._csiHandlers[ident] === undefined) { - this._csiHandlers[ident] = []; - } - const handlerList = this._csiHandlers[ident]; - handlerList.push(handler); - return { - dispose: () => { - const handlerIndex = handlerList.indexOf(handler); - if (handlerIndex !== -1) { - handlerList.splice(handlerIndex, 1); - } - } - }; - } - public clearCsiHandler(id: IFunctionIdentifier): void { - if (this._csiHandlers[this._identifier(id)]) delete this._csiHandlers[this._identifier(id)]; - } - public setCsiHandlerFallback(callback: (ident: number, params: IParams) => void): void { - this._csiHandlerFb = callback; - } - - public registerDcsHandler(id: IFunctionIdentifier, handler: IDcsHandler): IDisposable { - return this._dcsParser.registerHandler(this._identifier(id), handler); - } - public clearDcsHandler(id: IFunctionIdentifier): void { - this._dcsParser.clearHandler(this._identifier(id)); - } - public setDcsHandlerFallback(handler: DcsFallbackHandlerType): void { - this._dcsParser.setHandlerFallback(handler); - } - - public registerOscHandler(ident: number, handler: IOscHandler): IDisposable { - return this._oscParser.registerHandler(ident, handler); - } - public clearOscHandler(ident: number): void { - this._oscParser.clearHandler(ident); - } - public setOscHandlerFallback(handler: OscFallbackHandlerType): void { - this._oscParser.setHandlerFallback(handler); - } - - public setErrorHandler(callback: (state: IParsingState) => IParsingState): void { - this._errorHandler = callback; - } - public clearErrorHandler(): void { - this._errorHandler = this._errorHandlerFb; - } - - public reset(): void { - this.currentState = this.initialState; - this._oscParser.reset(); - this._dcsParser.reset(); - this._params.reset(); - this._params.addParam(0); // ZDM - this._collect = 0; - this.precedingCodepoint = 0; - } - - - - /** - * Parse UTF32 codepoints in `data` up to `length`. - * - * Note: For several actions with high data load the parsing is optimized - * by using local read ahead loops with hardcoded conditions to - * avoid costly table lookups. Make sure that any change of table values - * will be reflected in the loop conditions as well and vice versa. - * Affected states/actions: - * - GROUND:PRINT - * - CSI_PARAM:PARAM - * - DCS_PARAM:PARAM - * - OSC_STRING:OSC_PUT - * - DCS_PASSTHROUGH:DCS_PUT - */ - public parse(data: Uint32Array, length: number): void { - let code = 0; - let transition = 0; - let currentState = this.currentState; - const osc = this._oscParser; - const dcs = this._dcsParser; - let collect = this._collect; - const params = this._params; - const table: Uint8Array = this._transitions.table; - - // process input string - for (let i = 0; i < length; ++i) { - code = data[i]; - - // normal transition & action lookup - transition = table[currentState << TableAccess.INDEX_STATE_SHIFT | (code < 0xa0 ? code : NON_ASCII_PRINTABLE)]; - switch (transition >> TableAccess.TRANSITION_ACTION_SHIFT) { - case ParserAction.PRINT: - // read ahead with loop unrolling - // Note: 0x20 (SP) is included, 0x7F (DEL) is excluded - for (let j = i + 1; ; ++j) { - if (j >= length || (code = data[j]) < 0x20 || (code > 0x7e && code < NON_ASCII_PRINTABLE)) { - this._printHandler(data, i, j); - i = j - 1; - break; - } - if (++j >= length || (code = data[j]) < 0x20 || (code > 0x7e && code < NON_ASCII_PRINTABLE)) { - this._printHandler(data, i, j); - i = j - 1; - break; - } - if (++j >= length || (code = data[j]) < 0x20 || (code > 0x7e && code < NON_ASCII_PRINTABLE)) { - this._printHandler(data, i, j); - i = j - 1; - break; - } - if (++j >= length || (code = data[j]) < 0x20 || (code > 0x7e && code < NON_ASCII_PRINTABLE)) { - this._printHandler(data, i, j); - i = j - 1; - break; - } - } - break; - case ParserAction.EXECUTE: - if (this._executeHandlers[code]) this._executeHandlers[code](); - else this._executeHandlerFb(code); - this.precedingCodepoint = 0; - break; - case ParserAction.IGNORE: - break; - case ParserAction.ERROR: - const inject: IParsingState = this._errorHandler( - { - position: i, - code, - currentState, - collect, - params, - abort: false - }); - if (inject.abort) return; - // inject values: currently not implemented - break; - case ParserAction.CSI_DISPATCH: - // Trigger CSI Handler - const handlers = this._csiHandlers[collect << 8 | code]; - let j = handlers ? handlers.length - 1 : -1; - for (; j >= 0; j--) { - // true means success and to stop bubbling - if (handlers[j](params)) { - break; - } - } - if (j < 0) { - this._csiHandlerFb(collect << 8 | code, params); - } - this.precedingCodepoint = 0; - break; - case ParserAction.PARAM: - // inner loop: digits (0x30 - 0x39) and ; (0x3b) and : (0x3a) - do { - switch (code) { - case 0x3b: - params.addParam(0); // ZDM - break; - case 0x3a: - params.addSubParam(-1); - break; - default: // 0x30 - 0x39 - params.addDigit(code - 48); - } - } while (++i < length && (code = data[i]) > 0x2f && code < 0x3c); - i--; - break; - case ParserAction.COLLECT: - collect <<= 8; - collect |= code; - break; - case ParserAction.ESC_DISPATCH: - const handlersEsc = this._escHandlers[collect << 8 | code]; - let jj = handlersEsc ? handlersEsc.length - 1 : -1; - for (; jj >= 0; jj--) { - // true means success and to stop bubbling - if (handlersEsc[jj]()) { - break; - } - } - if (jj < 0) { - this._escHandlerFb(collect << 8 | code); - } - this.precedingCodepoint = 0; - break; - case ParserAction.CLEAR: - params.reset(); - params.addParam(0); // ZDM - collect = 0; - break; - case ParserAction.DCS_HOOK: - dcs.hook(collect << 8 | code, params); - break; - case ParserAction.DCS_PUT: - // inner loop - exit DCS_PUT: 0x18, 0x1a, 0x1b, 0x7f, 0x80 - 0x9f - // unhook triggered by: 0x1b, 0x9c (success) and 0x18, 0x1a (abort) - for (let j = i + 1; ; ++j) { - if (j >= length || (code = data[j]) === 0x18 || code === 0x1a || code === 0x1b || (code > 0x7f && code < NON_ASCII_PRINTABLE)) { - dcs.put(data, i, j); - i = j - 1; - break; - } - } - break; - case ParserAction.DCS_UNHOOK: - dcs.unhook(code !== 0x18 && code !== 0x1a); - if (code === 0x1b) transition |= ParserState.ESCAPE; - params.reset(); - params.addParam(0); // ZDM - collect = 0; - this.precedingCodepoint = 0; - break; - case ParserAction.OSC_START: - osc.start(); - break; - case ParserAction.OSC_PUT: - // inner loop: 0x20 (SP) included, 0x7F (DEL) included - for (let j = i + 1; ; j++) { - if (j >= length || (code = data[j]) < 0x20 || (code > 0x7f && code < NON_ASCII_PRINTABLE)) { - osc.put(data, i, j); - i = j - 1; - break; - } - } - break; - case ParserAction.OSC_END: - osc.end(code !== 0x18 && code !== 0x1a); - if (code === 0x1b) transition |= ParserState.ESCAPE; - params.reset(); - params.addParam(0); // ZDM - collect = 0; - this.precedingCodepoint = 0; - break; - } - currentState = transition & TableAccess.TRANSITION_STATE_MASK; - } - - // save collected intermediates - this._collect = collect; - - // save state - this.currentState = currentState; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/OscParser.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/OscParser.ts deleted file mode 100755 index e7edac663..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/OscParser.ts +++ /dev/null @@ -1,202 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IOscHandler, IHandlerCollection, OscFallbackHandlerType, IOscParser } from 'common/parser/Types'; -import { OscState, PAYLOAD_LIMIT } from 'common/parser/Constants'; -import { utf32ToString } from 'common/input/TextDecoder'; -import { IDisposable } from 'common/Types'; - -const EMPTY_HANDLERS: IOscHandler[] = []; - -export class OscParser implements IOscParser { - private _state = OscState.START; - private _active = EMPTY_HANDLERS; - private _id = -1; - private _handlers: IHandlerCollection = Object.create(null); - private _handlerFb: OscFallbackHandlerType = () => { }; - - public registerHandler(ident: number, handler: IOscHandler): IDisposable { - if (this._handlers[ident] === undefined) { - this._handlers[ident] = []; - } - const handlerList = this._handlers[ident]; - handlerList.push(handler); - return { - dispose: () => { - const handlerIndex = handlerList.indexOf(handler); - if (handlerIndex !== -1) { - handlerList.splice(handlerIndex, 1); - } - } - }; - } - public clearHandler(ident: number): void { - if (this._handlers[ident]) delete this._handlers[ident]; - } - public setHandlerFallback(handler: OscFallbackHandlerType): void { - this._handlerFb = handler; - } - - public dispose(): void { - this._handlers = Object.create(null); - this._handlerFb = () => {}; - this._active = EMPTY_HANDLERS; - } - - public reset(): void { - // cleanup handlers if payload was already sent - if (this._state === OscState.PAYLOAD) { - this.end(false); - } - this._active = EMPTY_HANDLERS; - this._id = -1; - this._state = OscState.START; - } - - private _start(): void { - this._active = this._handlers[this._id] || EMPTY_HANDLERS; - if (!this._active.length) { - this._handlerFb(this._id, 'START'); - } else { - for (let j = this._active.length - 1; j >= 0; j--) { - this._active[j].start(); - } - } - } - - private _put(data: Uint32Array, start: number, end: number): void { - if (!this._active.length) { - this._handlerFb(this._id, 'PUT', utf32ToString(data, start, end)); - } else { - for (let j = this._active.length - 1; j >= 0; j--) { - this._active[j].put(data, start, end); - } - } - } - - private _end(success: boolean): void { - // other than the old code we always have to call .end - // to keep the bubbling we use `success` to indicate - // whether a handler should execute - if (!this._active.length) { - this._handlerFb(this._id, 'END', success); - } else { - let j = this._active.length - 1; - for (; j >= 0; j--) { - if (this._active[j].end(success)) { - break; - } - } - j--; - // cleanup left over handlers - for (; j >= 0; j--) { - this._active[j].end(false); - } - } - } - - public start(): void { - // always reset leftover handlers - this.reset(); - this._state = OscState.ID; - } - - /** - * Put data to current OSC command. - * Expects the identifier of the OSC command in the form - * OSC id ; payload ST/BEL - * Payload chunks are not further processed and get - * directly passed to the handlers. - */ - public put(data: Uint32Array, start: number, end: number): void { - if (this._state === OscState.ABORT) { - return; - } - if (this._state === OscState.ID) { - while (start < end) { - const code = data[start++]; - if (code === 0x3b) { - this._state = OscState.PAYLOAD; - this._start(); - break; - } - if (code < 0x30 || 0x39 < code) { - this._state = OscState.ABORT; - return; - } - if (this._id === -1) { - this._id = 0; - } - this._id = this._id * 10 + code - 48; - } - } - if (this._state === OscState.PAYLOAD && end - start > 0) { - this._put(data, start, end); - } - } - - /** - * Indicates end of an OSC command. - * Whether the OSC got aborted or finished normally - * is indicated by `success`. - */ - public end(success: boolean): void { - if (this._state === OscState.START) { - return; - } - // do nothing if command was faulty - if (this._state !== OscState.ABORT) { - // if we are still in ID state and get an early end - // means that the command has no payload thus we still have - // to announce START and send END right after - if (this._state === OscState.ID) { - this._start(); - } - this._end(success); - } - this._active = EMPTY_HANDLERS; - this._id = -1; - this._state = OscState.START; - } -} - -/** - * Convenient class to allow attaching string based handler functions - * as OSC handlers. - */ -export class OscHandler implements IOscHandler { - private _data = ''; - private _hitLimit: boolean = false; - - constructor(private _handler: (data: string) => boolean) {} - - public start(): void { - this._data = ''; - this._hitLimit = false; - } - - public put(data: Uint32Array, start: number, end: number): void { - if (this._hitLimit) { - return; - } - this._data += utf32ToString(data, start, end); - if (this._data.length > PAYLOAD_LIMIT) { - this._data = ''; - this._hitLimit = true; - } - } - - public end(success: boolean): boolean { - let ret = false; - if (this._hitLimit) { - ret = false; - } else if (success) { - ret = this._handler(this._data); - } - this._data = ''; - this._hitLimit = false; - return ret; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/Params.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/Params.ts deleted file mode 100755 index 47ee129d4..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/Params.ts +++ /dev/null @@ -1,229 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ -import { IParams, ParamsArray } from 'common/parser/Types'; - -// max value supported for a single param/subparam (clamped to positive int32 range) -const MAX_VALUE = 0x7FFFFFFF; -// max allowed subparams for a single sequence (hardcoded limitation) -const MAX_SUBPARAMS = 256; - -/** - * Params storage class. - * This type is used by the parser to accumulate sequence parameters and sub parameters - * and transmit them to the input handler actions. - * - * NOTES: - * - params object for action handlers is borrowed, use `.toArray` or `.clone` to get a copy - * - never read beyond `params.length - 1` (likely to contain arbitrary data) - * - `.getSubParams` returns a borrowed typed array, use `.getSubParamsAll` for cloned sub params - * - hardcoded limitations: - * - max. value for a single (sub) param is 2^31 - 1 (greater values are clamped to that) - * - max. 256 sub params possible - * - negative values are not allowed beside -1 (placeholder for default value) - * - * About ZDM (Zero Default Mode): - * ZDM is not orchestrated by this class. If the parser is in ZDM, - * it should add 0 for empty params, otherwise -1. This does not apply - * to subparams, empty subparams should always be added with -1. - */ -export class Params implements IParams { - // params store and length - public params: Int32Array; - public length: number; - - // sub params store and length - protected _subParams: Int32Array; - protected _subParamsLength: number; - - // sub params offsets from param: param idx --> [start, end] offset - private _subParamsIdx: Uint16Array; - private _rejectDigits: boolean; - private _rejectSubDigits: boolean; - private _digitIsSub: boolean; - - /** - * Create a `Params` type from JS array representation. - */ - public static fromArray(values: ParamsArray): Params { - const params = new Params(); - if (!values.length) { - return params; - } - // skip leading sub params - for (let i = (values[0] instanceof Array) ? 1 : 0; i < values.length; ++i) { - const value = values[i]; - if (value instanceof Array) { - for (let k = 0; k < value.length; ++k) { - params.addSubParam(value[k]); - } - } else { - params.addParam(value); - } - } - return params; - } - - /** - * @param maxLength max length of storable parameters - * @param maxSubParamsLength max length of storable sub parameters - */ - constructor(public maxLength: number = 32, public maxSubParamsLength: number = 32) { - if (maxSubParamsLength > MAX_SUBPARAMS) { - throw new Error('maxSubParamsLength must not be greater than 256'); - } - this.params = new Int32Array(maxLength); - this.length = 0; - this._subParams = new Int32Array(maxSubParamsLength); - this._subParamsLength = 0; - this._subParamsIdx = new Uint16Array(maxLength); - this._rejectDigits = false; - this._rejectSubDigits = false; - this._digitIsSub = false; - } - - /** - * Clone object. - */ - public clone(): Params { - const newParams = new Params(this.maxLength, this.maxSubParamsLength); - newParams.params.set(this.params); - newParams.length = this.length; - newParams._subParams.set(this._subParams); - newParams._subParamsLength = this._subParamsLength; - newParams._subParamsIdx.set(this._subParamsIdx); - newParams._rejectDigits = this._rejectDigits; - newParams._rejectSubDigits = this._rejectSubDigits; - newParams._digitIsSub = this._digitIsSub; - return newParams; - } - - /** - * Get a JS array representation of the current parameters and sub parameters. - * The array is structured as follows: - * sequence: "1;2:3:4;5::6" - * array : [1, 2, [3, 4], 5, [-1, 6]] - */ - public toArray(): ParamsArray { - const res: ParamsArray = []; - for (let i = 0; i < this.length; ++i) { - res.push(this.params[i]); - const start = this._subParamsIdx[i] >> 8; - const end = this._subParamsIdx[i] & 0xFF; - if (end - start > 0) { - res.push(Array.prototype.slice.call(this._subParams, start, end)); - } - } - return res; - } - - /** - * Reset to initial empty state. - */ - public reset(): void { - this.length = 0; - this._subParamsLength = 0; - this._rejectDigits = false; - this._rejectSubDigits = false; - this._digitIsSub = false; - } - - /** - * Add a parameter value. - * `Params` only stores up to `maxLength` parameters, any later - * parameter will be ignored. - * Note: VT devices only stored up to 16 values, xterm seems to - * store up to 30. - */ - public addParam(value: number): void { - this._digitIsSub = false; - if (this.length >= this.maxLength) { - this._rejectDigits = true; - return; - } - if (value < -1) { - throw new Error('values lesser than -1 are not allowed'); - } - this._subParamsIdx[this.length] = this._subParamsLength << 8 | this._subParamsLength; - this.params[this.length++] = value > MAX_VALUE ? MAX_VALUE : value; - } - - /** - * Add a sub parameter value. - * The sub parameter is automatically associated with the last parameter value. - * Thus it is not possible to add a subparameter without any parameter added yet. - * `Params` only stores up to `subParamsLength` sub parameters, any later - * sub parameter will be ignored. - */ - public addSubParam(value: number): void { - this._digitIsSub = true; - if (!this.length) { - return; - } - if (this._rejectDigits || this._subParamsLength >= this.maxSubParamsLength) { - this._rejectSubDigits = true; - return; - } - if (value < -1) { - throw new Error('values lesser than -1 are not allowed'); - } - this._subParams[this._subParamsLength++] = value > MAX_VALUE ? MAX_VALUE : value; - this._subParamsIdx[this.length - 1]++; - } - - /** - * Whether parameter at index `idx` has sub parameters. - */ - public hasSubParams(idx: number): boolean { - return ((this._subParamsIdx[idx] & 0xFF) - (this._subParamsIdx[idx] >> 8) > 0); - } - - /** - * Return sub parameters for parameter at index `idx`. - * Note: The values are borrowed, thus you need to copy - * the values if you need to hold them in nonlocal scope. - */ - public getSubParams(idx: number): Int32Array | null { - const start = this._subParamsIdx[idx] >> 8; - const end = this._subParamsIdx[idx] & 0xFF; - if (end - start > 0) { - return this._subParams.subarray(start, end); - } - return null; - } - - /** - * Return all sub parameters as {idx: subparams} mapping. - * Note: The values are not borrowed. - */ - public getSubParamsAll(): {[idx: number]: Int32Array} { - const result: {[idx: number]: Int32Array} = {}; - for (let i = 0; i < this.length; ++i) { - const start = this._subParamsIdx[i] >> 8; - const end = this._subParamsIdx[i] & 0xFF; - if (end - start > 0) { - result[i] = this._subParams.slice(start, end); - } - } - return result; - } - - /** - * Add a single digit value to current parameter. - * This is used by the parser to account digits on a char by char basis. - */ - public addDigit(value: number): void { - let length; - if (this._rejectDigits - || !(length = this._digitIsSub ? this._subParamsLength : this.length) - || (this._digitIsSub && this._rejectSubDigits) - ) { - return; - } - - const store = this._digitIsSub ? this._subParams : this.params; - const cur = store[length - 1]; - store[length - 1] = ~cur ? Math.min(cur * 10 + value, MAX_VALUE) : value; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/Types.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/Types.d.ts deleted file mode 100755 index b325d0252..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/parser/Types.d.ts +++ /dev/null @@ -1,239 +0,0 @@ -/** - * Copyright (c) 2017 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IDisposable } from 'common/Types'; -import { ParserState } from 'common/parser/Constants'; - -/** sequence params serialized to js arrays */ -export type ParamsArray = (number | number[])[]; - -/** Params constructor type. */ -export interface IParamsConstructor { - new(maxLength: number, maxSubParamsLength: number): IParams; - - /** create params from ParamsArray */ - fromArray(values: ParamsArray): IParams; -} - -/** Interface of Params storage class. */ -export interface IParams { - /** from ctor */ - maxLength: number; - maxSubParamsLength: number; - - /** param values and its length */ - params: Int32Array; - length: number; - - /** methods */ - clone(): IParams; - toArray(): ParamsArray; - reset(): void; - addParam(value: number): void; - addSubParam(value: number): void; - hasSubParams(idx: number): boolean; - getSubParams(idx: number): Int32Array | null; - getSubParamsAll(): {[idx: number]: Int32Array}; -} - -/** - * Internal state of EscapeSequenceParser. - * Used as argument of the error handler to allow - * introspection at runtime on parse errors. - * Return it with altered values to recover from - * faulty states (not yet supported). - * Set `abort` to `true` to abort the current parsing. - */ -export interface IParsingState { - // position in parse string - position: number; - // actual character code - code: number; - // current parser state - currentState: ParserState; - // collect buffer with intermediate characters - collect: number; - // params buffer - params: IParams; - // should abort (default: false) - abort: boolean; -} - -/** - * Command handler interfaces. - */ - -/** - * CSI handler types. - * Note: `params` is borrowed. - */ -export type CsiHandlerType = (params: IParams) => boolean; -export type CsiFallbackHandlerType = (ident: number, params: IParams) => void; - -/** - * DCS handler types. - */ -export interface IDcsHandler { - /** - * Called when a DCS command starts. - * Prepare needed data structures here. - * Note: `params` is borrowed. - */ - hook(params: IParams): void; - /** - * Incoming payload chunk. - * Note: `params` is borrowed. - */ - put(data: Uint32Array, start: number, end: number): void; - /** - * End of DCS command. `success` indicates whether the - * command finished normally or got aborted, thus final - * execution of the command should depend on `success`. - * To save memory also cleanup data structures here. - */ - unhook(success: boolean): boolean; -} -export type DcsFallbackHandlerType = (ident: number, action: 'HOOK' | 'PUT' | 'UNHOOK', payload?: any) => void; - -/** - * ESC handler types. - */ -export type EscHandlerType = () => boolean; -export type EscFallbackHandlerType = (identifier: number) => void; - -/** - * EXECUTE handler types. - */ -export type ExecuteHandlerType = () => boolean; -export type ExecuteFallbackHandlerType = (ident: number) => void; - -/** - * OSC handler types. - */ -export interface IOscHandler { - /** - * Announces start of this OSC command. - * Prepare needed data structures here. - */ - start(): void; - /** - * Incoming data chunk. - * Note: Data is borrowed. - */ - put(data: Uint32Array, start: number, end: number): void; - /** - * End of OSC command. `success` indicates whether the - * command finished normally or got aborted, thus final - * execution of the command should depend on `success`. - * To save memory also cleanup data structures here. - */ - end(success: boolean): boolean; -} -export type OscFallbackHandlerType = (ident: number, action: 'START' | 'PUT' | 'END', payload?: any) => void; - -/** - * PRINT handler types. - */ -export type PrintHandlerType = (data: Uint32Array, start: number, end: number) => void; -export type PrintFallbackHandlerType = PrintHandlerType; - - -/** -* EscapeSequenceParser interface. -*/ -export interface IEscapeSequenceParser extends IDisposable { - /** - * Preceding codepoint to get REP working correctly. - * This must be set by the print handler as last action. - * It gets reset by the parser for any valid sequence beside REP itself. - */ - precedingCodepoint: number; - - /** - * Reset the parser to its initial state (handlers are kept). - */ - reset(): void; - - /** - * Parse UTF32 codepoints in `data` up to `length`. - * @param data The data to parse. - */ - parse(data: Uint32Array, length: number): void; - - /** - * Get string from numercial function identifier `ident`. - * Useful in fallback handlers which expose the low level - * numcerical function identifier for debugging purposes. - * Note: A full back translation to `IFunctionIdentifier` - * is not implemented. - */ - identToString(ident: number): string; - - setPrintHandler(handler: PrintHandlerType): void; - clearPrintHandler(): void; - - registerEscHandler(id: IFunctionIdentifier, handler: EscHandlerType): IDisposable; - clearEscHandler(id: IFunctionIdentifier): void; - setEscHandlerFallback(handler: EscFallbackHandlerType): void; - - setExecuteHandler(flag: string, handler: ExecuteHandlerType): void; - clearExecuteHandler(flag: string): void; - setExecuteHandlerFallback(handler: ExecuteFallbackHandlerType): void; - - registerCsiHandler(id: IFunctionIdentifier, handler: CsiHandlerType): IDisposable; - clearCsiHandler(id: IFunctionIdentifier): void; - setCsiHandlerFallback(callback: CsiFallbackHandlerType): void; - - registerDcsHandler(id: IFunctionIdentifier, handler: IDcsHandler): IDisposable; - clearDcsHandler(id: IFunctionIdentifier): void; - setDcsHandlerFallback(handler: DcsFallbackHandlerType): void; - - registerOscHandler(ident: number, handler: IOscHandler): IDisposable; - clearOscHandler(ident: number): void; - setOscHandlerFallback(handler: OscFallbackHandlerType): void; - - setErrorHandler(handler: (state: IParsingState) => IParsingState): void; - clearErrorHandler(): void; -} - -/** - * Subparser interfaces. - * The subparsers are instantiated in `EscapeSequenceParser` and - * called during `EscapeSequenceParser.parse`. - */ -export interface ISubParser extends IDisposable { - reset(): void; - registerHandler(ident: number, handler: T): IDisposable; - clearHandler(ident: number): void; - setHandlerFallback(handler: U): void; - put(data: Uint32Array, start: number, end: number): void; -} - -export interface IOscParser extends ISubParser { - start(): void; - end(success: boolean): void; -} - -export interface IDcsParser extends ISubParser { - hook(ident: number, params: IParams): void; - unhook(success: boolean): void; -} - -/** - * Interface to denote a specific ESC, CSI or DCS handler slot. - * The values are used to create an integer respresentation during handler - * regristation before passed to the subparsers as `ident`. - * The integer translation is made to allow a faster handler access - * in `EscapeSequenceParser.parse`. - */ -export interface IFunctionIdentifier { - prefix?: string; - intermediates?: string; - final: string; -} - -export interface IHandlerCollection { - [key: string]: T[]; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/BufferService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/BufferService.ts deleted file mode 100755 index 47e547290..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/BufferService.ts +++ /dev/null @@ -1,55 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IBufferService, IOptionsService } from 'common/services/Services'; -import { BufferSet } from 'common/buffer/BufferSet'; -import { IBufferSet, IBuffer } from 'common/buffer/Types'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { Disposable } from 'common/Lifecycle'; - -export const MINIMUM_COLS = 2; // Less than 2 can mess with wide chars -export const MINIMUM_ROWS = 1; - -export class BufferService extends Disposable implements IBufferService { - public serviceBrand: any; - - public cols: number; - public rows: number; - public buffers: IBufferSet; - /** Whether the user is scrolling (locks the scroll position) */ - public isUserScrolling: boolean = false; - - private _onResize = new EventEmitter<{ cols: number, rows: number }>(); - public get onResize(): IEvent<{ cols: number, rows: number }> { return this._onResize.event; } - - public get buffer(): IBuffer { return this.buffers.active; } - - constructor( - @IOptionsService private _optionsService: IOptionsService - ) { - super(); - this.cols = Math.max(_optionsService.options.cols, MINIMUM_COLS); - this.rows = Math.max(_optionsService.options.rows, MINIMUM_ROWS); - this.buffers = new BufferSet(_optionsService, this); - } - - public dispose(): void { - super.dispose(); - this.buffers.dispose(); - } - - public resize(cols: number, rows: number): void { - this.cols = cols; - this.rows = rows; - this.buffers.resize(cols, rows); - this.buffers.setupTabStops(this.cols); - this._onResize.fire({ cols, rows }); - } - - public reset(): void { - this.buffers.reset(); - this.isUserScrolling = false; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/CharsetService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/CharsetService.ts deleted file mode 100755 index c5381065a..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/CharsetService.ts +++ /dev/null @@ -1,34 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ICharsetService } from 'common/services/Services'; -import { ICharset } from 'common/Types'; - -export class CharsetService implements ICharsetService { - public serviceBrand: any; - - public charset: ICharset | undefined; - public glevel: number = 0; - - private _charsets: (ICharset | undefined)[] = []; - - public reset(): void { - this.charset = undefined; - this._charsets = []; - this.glevel = 0; - } - - public setgLevel(g: number): void { - this.glevel = g; - this.charset = this._charsets[g]; - } - - public setgCharset(g: number, charset: ICharset | undefined): void { - this._charsets[g] = charset; - if (this.glevel === g) { - this.charset = charset; - } - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/CoreMouseService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/CoreMouseService.ts deleted file mode 100755 index 0b0dc366f..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/CoreMouseService.ts +++ /dev/null @@ -1,309 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ -import { IBufferService, ICoreService, ICoreMouseService } from 'common/services/Services'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { ICoreMouseProtocol, ICoreMouseEvent, CoreMouseEncoding, CoreMouseEventType, CoreMouseButton, CoreMouseAction } from 'common/Types'; - -/** - * Supported default protocols. - */ -const DEFAULT_PROTOCOLS: {[key: string]: ICoreMouseProtocol} = { - /** - * NONE - * Events: none - * Modifiers: none - */ - NONE: { - events: CoreMouseEventType.NONE, - restrict: () => false - }, - /** - * X10 - * Events: mousedown - * Modifiers: none - */ - X10: { - events: CoreMouseEventType.DOWN, - restrict: (e: ICoreMouseEvent) => { - // no wheel, no move, no up - if (e.button === CoreMouseButton.WHEEL || e.action !== CoreMouseAction.DOWN) { - return false; - } - // no modifiers - e.ctrl = false; - e.alt = false; - e.shift = false; - return true; - } - }, - /** - * VT200 - * Events: mousedown / mouseup / wheel - * Modifiers: all - */ - VT200: { - events: CoreMouseEventType.DOWN | CoreMouseEventType.UP | CoreMouseEventType.WHEEL, - restrict: (e: ICoreMouseEvent) => { - // no move - if (e.action === CoreMouseAction.MOVE) { - return false; - } - return true; - } - }, - /** - * DRAG - * Events: mousedown / mouseup / wheel / mousedrag - * Modifiers: all - */ - DRAG: { - events: CoreMouseEventType.DOWN | CoreMouseEventType.UP | CoreMouseEventType.WHEEL | CoreMouseEventType.DRAG, - restrict: (e: ICoreMouseEvent) => { - // no move without button - if (e.action === CoreMouseAction.MOVE && e.button === CoreMouseButton.NONE) { - return false; - } - return true; - } - }, - /** - * ANY - * Events: all mouse related events - * Modifiers: all - */ - ANY: { - events: - CoreMouseEventType.DOWN | CoreMouseEventType.UP | CoreMouseEventType.WHEEL - | CoreMouseEventType.DRAG | CoreMouseEventType.MOVE, - restrict: (e: ICoreMouseEvent) => true - } -}; - -const enum Modifiers { - SHIFT = 4, - ALT = 8, - CTRL = 16 -} - -// helper for default encoders to generate the event code. -function eventCode(e: ICoreMouseEvent, isSGR: boolean): number { - let code = (e.ctrl ? Modifiers.CTRL : 0) | (e.shift ? Modifiers.SHIFT : 0) | (e.alt ? Modifiers.ALT : 0); - if (e.button === CoreMouseButton.WHEEL) { - code |= 64; - code |= e.action; - } else { - code |= e.button & 3; - if (e.button & 4) { - code |= 64; - } - if (e.button & 8) { - code |= 128; - } - if (e.action === CoreMouseAction.MOVE) { - code |= CoreMouseAction.MOVE; - } else if (e.action === CoreMouseAction.UP && !isSGR) { - // special case - only SGR can report button on release - // all others have to go with NONE - code |= CoreMouseButton.NONE; - } - } - return code; -} - -const S = String.fromCharCode; - -/** - * Supported default encodings. - */ -const DEFAULT_ENCODINGS: {[key: string]: CoreMouseEncoding} = { - /** - * DEFAULT - CSI M Pb Px Py - * Single byte encoding for coords and event code. - * Can encode values up to 223 (1-based). - */ - DEFAULT: (e: ICoreMouseEvent) => { - const params = [eventCode(e, false) + 32, e.col + 32, e.row + 32]; - // supress mouse report if we exceed addressible range - // Note this is handled differently by emulators - // - xterm: sends 0;0 coords instead - // - vte, konsole: no report - if (params[0] > 255 || params[1] > 255 || params[2] > 255) { - return ''; - } - return `\x1b[M${S(params[0])}${S(params[1])}${S(params[2])}`; - }, - /** - * SGR - CSI < Pb ; Px ; Py M|m - * No encoding limitation. - * Can report button on release and works with a well formed sequence. - */ - SGR: (e: ICoreMouseEvent) => { - const final = (e.action === CoreMouseAction.UP && e.button !== CoreMouseButton.WHEEL) ? 'm' : 'M'; - return `\x1b[<${eventCode(e, true)};${e.col};${e.row}${final}`; - } -}; - -/** - * CoreMouseService - * - * Provides mouse tracking reports with different protocols and encodings. - * - protocols: NONE (default), X10, VT200, DRAG, ANY - * - encodings: DEFAULT, SGR (UTF8, URXVT removed in #2507) - * - * Custom protocols/encodings can be added by `addProtocol` / `addEncoding`. - * To activate a protocol/encoding, set `activeProtocol` / `activeEncoding`. - * Switching a protocol will send a notification event `onProtocolChange` - * with a list of needed events to track. - * - * The service handles the mouse tracking state and decides whether to send - * a tracking report to the backend based on protocol and encoding limitations. - * To send a mouse event call `triggerMouseEvent`. - */ -export class CoreMouseService implements ICoreMouseService { - private _protocols: {[name: string]: ICoreMouseProtocol} = {}; - private _encodings: {[name: string]: CoreMouseEncoding} = {}; - private _activeProtocol: string = ''; - private _activeEncoding: string = ''; - private _onProtocolChange = new EventEmitter(); - private _lastEvent: ICoreMouseEvent | null = null; - - constructor( - @IBufferService private readonly _bufferService: IBufferService, - @ICoreService private readonly _coreService: ICoreService - ) { - // register default protocols and encodings - for (const name of Object.keys(DEFAULT_PROTOCOLS)) this.addProtocol(name, DEFAULT_PROTOCOLS[name]); - for (const name of Object.keys(DEFAULT_ENCODINGS)) this.addEncoding(name, DEFAULT_ENCODINGS[name]); - // call reset to set defaults - this.reset(); - } - - public addProtocol(name: string, protocol: ICoreMouseProtocol): void { - this._protocols[name] = protocol; - } - - public addEncoding(name: string, encoding: CoreMouseEncoding): void { - this._encodings[name] = encoding; - } - - public get activeProtocol(): string { - return this._activeProtocol; - } - - public get areMouseEventsActive(): boolean { - return this._protocols[this._activeProtocol].events !== 0; - } - - public set activeProtocol(name: string) { - if (!this._protocols[name]) { - throw new Error(`unknown protocol "${name}"`); - } - this._activeProtocol = name; - this._onProtocolChange.fire(this._protocols[name].events); - } - - public get activeEncoding(): string { - return this._activeEncoding; - } - - public set activeEncoding(name: string) { - if (!this._encodings[name]) { - throw new Error(`unknown encoding "${name}"`); - } - this._activeEncoding = name; - } - - public reset(): void { - this.activeProtocol = 'NONE'; - this.activeEncoding = 'DEFAULT'; - this._lastEvent = null; - } - - /** - * Event to announce changes in mouse tracking. - */ - public get onProtocolChange(): IEvent { - return this._onProtocolChange.event; - } - - /** - * Triggers a mouse event to be sent. - * - * Returns true if the event passed all protocol restrictions and a report - * was sent, otherwise false. The return value may be used to decide whether - * the default event action in the bowser component should be omitted. - * - * Note: The method will change values of the given event object - * to fullfill protocol and encoding restrictions. - */ - public triggerMouseEvent(e: ICoreMouseEvent): boolean { - // range check for col/row - if (e.col < 0 || e.col >= this._bufferService.cols - || e.row < 0 || e.row >= this._bufferService.rows) { - return false; - } - - // filter nonsense combinations of button + action - if (e.button === CoreMouseButton.WHEEL && e.action === CoreMouseAction.MOVE) { - return false; - } - if (e.button === CoreMouseButton.NONE && e.action !== CoreMouseAction.MOVE) { - return false; - } - if (e.button !== CoreMouseButton.WHEEL && (e.action === CoreMouseAction.LEFT || e.action === CoreMouseAction.RIGHT)) { - return false; - } - - // report 1-based coords - e.col++; - e.row++; - - // debounce move at grid level - if (e.action === CoreMouseAction.MOVE && this._lastEvent && this._compareEvents(this._lastEvent, e)) { - return false; - } - - // apply protocol restrictions - if (!this._protocols[this._activeProtocol].restrict(e)) { - return false; - } - - // encode report and send - const report = this._encodings[this._activeEncoding](e); - if (report) { - // always send DEFAULT as binary data - if (this._activeEncoding === 'DEFAULT') { - this._coreService.triggerBinaryEvent(report); - } else { - this._coreService.triggerDataEvent(report, true); - } - } - - this._lastEvent = e; - - return true; - } - - public explainEvents(events: CoreMouseEventType): {[event: string]: boolean} { - return { - down: !!(events & CoreMouseEventType.DOWN), - up: !!(events & CoreMouseEventType.UP), - drag: !!(events & CoreMouseEventType.DRAG), - move: !!(events & CoreMouseEventType.MOVE), - wheel: !!(events & CoreMouseEventType.WHEEL) - }; - } - - private _compareEvents(e1: ICoreMouseEvent, e2: ICoreMouseEvent): boolean { - if (e1.col !== e2.col) return false; - if (e1.row !== e2.row) return false; - if (e1.button !== e2.button) return false; - if (e1.action !== e2.action) return false; - if (e1.ctrl !== e2.ctrl) return false; - if (e1.alt !== e2.alt) return false; - if (e1.shift !== e2.shift) return false; - return true; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/CoreService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/CoreService.ts deleted file mode 100755 index 43b89a9cc..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/CoreService.ts +++ /dev/null @@ -1,92 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ICoreService, ILogService, IOptionsService, IBufferService } from 'common/services/Services'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { IDecPrivateModes, IModes } from 'common/Types'; -import { clone } from 'common/Clone'; -import { Disposable } from 'common/Lifecycle'; - -const DEFAULT_MODES: IModes = Object.freeze({ - insertMode: false -}); - -const DEFAULT_DEC_PRIVATE_MODES: IDecPrivateModes = Object.freeze({ - applicationCursorKeys: false, - applicationKeypad: false, - bracketedPasteMode: false, - origin: false, - reverseWraparound: false, - sendFocus: false, - wraparound: true // defaults: xterm - true, vt100 - false -}); - -export class CoreService extends Disposable implements ICoreService { - public serviceBrand: any; - - public isCursorInitialized: boolean = false; - public isCursorHidden: boolean = false; - public modes: IModes; - public decPrivateModes: IDecPrivateModes; - - // Circular dependency, this must be unset or memory will leak after Terminal.dispose - private _scrollToBottom: (() => void) | undefined; - - private _onData = this.register(new EventEmitter()); - public get onData(): IEvent { return this._onData.event; } - private _onUserInput = this.register(new EventEmitter()); - public get onUserInput(): IEvent { return this._onUserInput.event; } - private _onBinary = this.register(new EventEmitter()); - public get onBinary(): IEvent { return this._onBinary.event; } - - constructor( - // TODO: Move this into a service - scrollToBottom: () => void, - @IBufferService private readonly _bufferService: IBufferService, - @ILogService private readonly _logService: ILogService, - @IOptionsService private readonly _optionsService: IOptionsService - ) { - super(); - this._scrollToBottom = scrollToBottom; - this.register({ dispose: () => this._scrollToBottom = undefined }); - this.modes = clone(DEFAULT_MODES); - this.decPrivateModes = clone(DEFAULT_DEC_PRIVATE_MODES); - } - - public reset(): void { - this.modes = clone(DEFAULT_MODES); - this.decPrivateModes = clone(DEFAULT_DEC_PRIVATE_MODES); - } - - public triggerDataEvent(data: string, wasUserInput: boolean = false): void { - // Prevents all events to pty process if stdin is disabled - if (this._optionsService.options.disableStdin) { - return; - } - - // Input is being sent to the terminal, the terminal should focus the prompt. - const buffer = this._bufferService.buffer; - if (buffer.ybase !== buffer.ydisp) { - this._scrollToBottom!(); - } - - // Fire onUserInput so listeners can react as well (eg. clear selection) - if (wasUserInput) { - this._onUserInput.fire(); - } - - // Fire onData API - this._logService.debug(`sending data "${data}"`, () => data.split('').map(e => e.charCodeAt(0))); - this._onData.fire(data); - } - - public triggerBinaryEvent(data: string): void { - if (this._optionsService.options.disableStdin) { - return; - } - this._logService.debug(`sending binary "${data}"`, () => data.split('').map(e => e.charCodeAt(0))); - this._onBinary.fire(data); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/DirtyRowService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/DirtyRowService.ts deleted file mode 100755 index 1c43b67ef..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/DirtyRowService.ts +++ /dev/null @@ -1,53 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IBufferService, IDirtyRowService } from 'common/services/Services'; - -export class DirtyRowService implements IDirtyRowService { - public serviceBrand: any; - - private _start!: number; - private _end!: number; - - public get start(): number { return this._start; } - public get end(): number { return this._end; } - - constructor( - @IBufferService private readonly _bufferService: IBufferService - ) { - this.clearRange(); - } - - public clearRange(): void { - this._start = this._bufferService.buffer.y; - this._end = this._bufferService.buffer.y; - } - - public markDirty(y: number): void { - if (y < this._start) { - this._start = y; - } else if (y > this._end) { - this._end = y; - } - } - - public markRangeDirty(y1: number, y2: number): void { - if (y1 > y2) { - const temp = y1; - y1 = y2; - y2 = temp; - } - if (y1 < this._start) { - this._start = y1; - } - if (y2 > this._end) { - this._end = y2; - } - } - - public markAllDirty(): void { - this.markRangeDirty(0, this._bufferService.rows - 1); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/InstantiationService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/InstantiationService.ts deleted file mode 100755 index e5727fa6d..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/InstantiationService.ts +++ /dev/null @@ -1,81 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - * - * This was heavily inspired from microsoft/vscode's dependency injection system (MIT). - */ -/*--------------------------------------------------------------------------------------------- - * Copyright (c) Microsoft Corporation. All rights reserved. - * Licensed under the MIT License. See License.txt in the project root for license information. - *--------------------------------------------------------------------------------------------*/ - -import { IInstantiationService, IServiceIdentifier } from 'common/services/Services'; -import { getServiceDependencies } from 'common/services/ServiceRegistry'; - -export class ServiceCollection { - - private _entries = new Map, any>(); - - constructor(...entries: [IServiceIdentifier, any][]) { - for (const [id, service] of entries) { - this.set(id, service); - } - } - - public set(id: IServiceIdentifier, instance: T): T { - const result = this._entries.get(id); - this._entries.set(id, instance); - return result; - } - - public forEach(callback: (id: IServiceIdentifier, instance: any) => any): void { - this._entries.forEach((value, key) => callback(key, value)); - } - - public has(id: IServiceIdentifier): boolean { - return this._entries.has(id); - } - - public get(id: IServiceIdentifier): T | undefined { - return this._entries.get(id); - } -} - -export class InstantiationService implements IInstantiationService { - private readonly _services: ServiceCollection = new ServiceCollection(); - - constructor() { - this._services.set(IInstantiationService, this); - } - - public setService(id: IServiceIdentifier, instance: T): void { - this._services.set(id, instance); - } - - public getService(id: IServiceIdentifier): T | undefined { - return this._services.get(id); - } - - public createInstance(ctor: any, ...args: any[]): T { - const serviceDependencies = getServiceDependencies(ctor).sort((a, b) => a.index - b.index); - - const serviceArgs: any[] = []; - for (const dependency of serviceDependencies) { - const service = this._services.get(dependency.id); - if (!service) { - throw new Error(`[createInstance] ${ctor.name} depends on UNKNOWN service ${dependency.id}.`); - } - serviceArgs.push(service); - } - - const firstServiceArgPos = serviceDependencies.length > 0 ? serviceDependencies[0].index : args.length; - - // check for argument mismatches, adjust static args if needed - if (args.length !== firstServiceArgPos) { - throw new Error(`[createInstance] First service dependency of ${ctor.name} at position ${firstServiceArgPos + 1} conflicts with ${args.length} static arguments`); - } - - // now create the instance - return new ctor(...[...args, ...serviceArgs]); - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/LogService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/LogService.ts deleted file mode 100755 index 3c0ccaf14..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/LogService.ts +++ /dev/null @@ -1,97 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { ILogService, IOptionsService } from 'common/services/Services'; - -type LogType = (message?: any, ...optionalParams: any[]) => void; - -interface IConsole { - log: LogType; - error: LogType; - info: LogType; - trace: LogType; - warn: LogType; -} - -// console is available on both node.js and browser contexts but the common -// module doesn't depend on them so we need to explicitly declare it. -declare const console: IConsole; - - -export enum LogLevel { - DEBUG = 0, - INFO = 1, - WARN = 2, - ERROR = 3, - OFF = 4 -} - -const optionsKeyToLogLevel: { [key: string]: LogLevel } = { - debug: LogLevel.DEBUG, - info: LogLevel.INFO, - warn: LogLevel.WARN, - error: LogLevel.ERROR, - off: LogLevel.OFF -}; - -const LOG_PREFIX = 'xterm.js: '; - -export class LogService implements ILogService { - public serviceBrand: any; - - private _logLevel!: LogLevel; - - constructor( - @IOptionsService private readonly _optionsService: IOptionsService - ) { - this._updateLogLevel(); - this._optionsService.onOptionChange(key => { - if (key === 'logLevel') { - this._updateLogLevel(); - } - }); - } - - private _updateLogLevel(): void { - this._logLevel = optionsKeyToLogLevel[this._optionsService.options.logLevel]; - } - - private _evalLazyOptionalParams(optionalParams: any[]): void { - for (let i = 0; i < optionalParams.length; i++) { - if (typeof optionalParams[i] === 'function') { - optionalParams[i] = optionalParams[i](); - } - } - } - - private _log(type: LogType, message: string, optionalParams: any[]): void { - this._evalLazyOptionalParams(optionalParams); - type.call(console, LOG_PREFIX + message, ...optionalParams); - } - - public debug(message: string, ...optionalParams: any[]): void { - if (this._logLevel <= LogLevel.DEBUG) { - this._log(console.log, message, optionalParams); - } - } - - public info(message: string, ...optionalParams: any[]): void { - if (this._logLevel <= LogLevel.INFO) { - this._log(console.info, message, optionalParams); - } - } - - public warn(message: string, ...optionalParams: any[]): void { - if (this._logLevel <= LogLevel.WARN) { - this._log(console.warn, message, optionalParams); - } - } - - public error(message: string, ...optionalParams: any[]): void { - if (this._logLevel <= LogLevel.ERROR) { - this._log(console.error, message, optionalParams); - } - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/OptionsService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/OptionsService.ts deleted file mode 100755 index b7a1c58e0..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/OptionsService.ts +++ /dev/null @@ -1,162 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IOptionsService, ITerminalOptions, IPartialTerminalOptions, FontWeight } from 'common/services/Services'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { isMac } from 'common/Platform'; -import { clone } from 'common/Clone'; - -// Source: https://freesound.org/people/altemark/sounds/45759/ -// This sound is released under the Creative Commons Attribution 3.0 Unported -// (CC BY 3.0) license. It was created by 'altemark'. No modifications have been -// made, apart from the conversion to base64. -export const DEFAULT_BELL_SOUND = 'data:audio/mp3;base64,SUQzBAAAAAAAI1RTU0UAAAAPAAADTGF2ZjU4LjMyLjEwNAAAAAAAAAAAAAAA//tQxAADB8AhSmxhIIEVCSiJrDCQBTcu3UrAIwUdkRgQbFAZC1CQEwTJ9mjRvBA4UOLD8nKVOWfh+UlK3z/177OXrfOdKl7pyn3Xf//WreyTRUoAWgBgkOAGbZHBgG1OF6zM82DWbZaUmMBptgQhGjsyYqc9ae9XFz280948NMBWInljyzsNRFLPWdnZGWrddDsjK1unuSrVN9jJsK8KuQtQCtMBjCEtImISdNKJOopIpBFpNSMbIHCSRpRR5iakjTiyzLhchUUBwCgyKiweBv/7UsQbg8isVNoMPMjAAAA0gAAABEVFGmgqK////9bP/6XCykxBTUUzLjEwMKqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq'; - -// TODO: Freeze? -export const DEFAULT_OPTIONS: ITerminalOptions = Object.freeze({ - cols: 80, - rows: 24, - cursorBlink: false, - cursorStyle: 'block', - cursorWidth: 1, - bellSound: DEFAULT_BELL_SOUND, - bellStyle: 'none', - drawBoldTextInBrightColors: true, - fastScrollModifier: 'alt', - fastScrollSensitivity: 5, - fontFamily: 'courier-new, courier, monospace', - fontSize: 15, - fontWeight: 'normal', - fontWeightBold: 'bold', - lineHeight: 1.0, - linkTooltipHoverDuration: 500, - letterSpacing: 0, - logLevel: 'info', - scrollback: 1000, - scrollSensitivity: 1, - screenReaderMode: false, - macOptionIsMeta: false, - macOptionClickForcesSelection: false, - minimumContrastRatio: 1, - disableStdin: false, - allowProposedApi: true, - allowTransparency: false, - tabStopWidth: 8, - theme: {}, - rightClickSelectsWord: isMac, - rendererType: 'canvas', - windowOptions: {}, - windowsMode: false, - wordSeparator: ' ()[]{}\',"`', - altClickMovesCursor: true, - convertEol: false, - termName: 'xterm', - cancelEvents: false -}); - -const FONT_WEIGHT_OPTIONS: Extract[] = ['normal', 'bold', '100', '200', '300', '400', '500', '600', '700', '800', '900']; - -/** - * The set of options that only have an effect when set in the Terminal constructor. - */ -const CONSTRUCTOR_ONLY_OPTIONS = ['cols', 'rows']; - -export class OptionsService implements IOptionsService { - public serviceBrand: any; - - public options: ITerminalOptions; - - private _onOptionChange = new EventEmitter(); - public get onOptionChange(): IEvent { return this._onOptionChange.event; } - - constructor(options: IPartialTerminalOptions) { - this.options = clone(DEFAULT_OPTIONS); - for (const k of Object.keys(options)) { - if (k in this.options) { - try { - const newValue = options[k as keyof IPartialTerminalOptions] as any; - this.options[k] = this._sanitizeAndValidateOption(k, newValue); - } catch (e) { - console.error(e); - } - } - } - } - - public setOption(key: string, value: any): void { - if (!(key in DEFAULT_OPTIONS)) { - throw new Error('No option with key "' + key + '"'); - } - if (CONSTRUCTOR_ONLY_OPTIONS.includes(key)) { - throw new Error(`Option "${key}" can only be set in the constructor`); - } - if (this.options[key] === value) { - return; - } - - value = this._sanitizeAndValidateOption(key, value); - - // Don't fire an option change event if they didn't change - if (this.options[key] === value) { - return; - } - - this.options[key] = value; - this._onOptionChange.fire(key); - } - - private _sanitizeAndValidateOption(key: string, value: any): any { - switch (key) { - case 'bellStyle': - case 'cursorStyle': - case 'rendererType': - case 'wordSeparator': - if (!value) { - value = DEFAULT_OPTIONS[key]; - } - break; - case 'fontWeight': - case 'fontWeightBold': - if (typeof value === 'number' && 1 <= value && value <= 1000) { - // already valid numeric value - break; - } - value = FONT_WEIGHT_OPTIONS.includes(value) ? value : DEFAULT_OPTIONS[key]; - break; - case 'cursorWidth': - value = Math.floor(value); - // Fall through for bounds check - case 'lineHeight': - case 'tabStopWidth': - if (value < 1) { - throw new Error(`${key} cannot be less than 1, value: ${value}`); - } - break; - case 'minimumContrastRatio': - value = Math.max(1, Math.min(21, Math.round(value * 10) / 10)); - break; - case 'scrollback': - value = Math.min(value, 4294967295); - if (value < 0) { - throw new Error(`${key} cannot be less than 0, value: ${value}`); - } - break; - case 'fastScrollSensitivity': - case 'scrollSensitivity': - if (value <= 0) { - throw new Error(`${key} cannot be less than or equal to 0, value: ${value}`); - } - break; - } - return value; - } - - public getOption(key: string): any { - if (!(key in DEFAULT_OPTIONS)) { - throw new Error(`No option with key "${key}"`); - } - return this.options[key]; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/ServiceRegistry.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/ServiceRegistry.ts deleted file mode 100755 index 6510fb8e0..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/ServiceRegistry.ts +++ /dev/null @@ -1,49 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - * - * This was heavily inspired from microsoft/vscode's dependency injection system (MIT). - */ -/*--------------------------------------------------------------------------------------------- - * Copyright (c) Microsoft Corporation. All rights reserved. - * Licensed under the MIT License. See License.txt in the project root for license information. - *--------------------------------------------------------------------------------------------*/ - -import { IServiceIdentifier } from 'common/services/Services'; - -const DI_TARGET = 'di$target'; -const DI_DEPENDENCIES = 'di$dependencies'; - -export const serviceRegistry: Map> = new Map(); - -export function getServiceDependencies(ctor: any): { id: IServiceIdentifier, index: number, optional: boolean }[] { - return ctor[DI_DEPENDENCIES] || []; -} - -export function createDecorator(id: string): IServiceIdentifier { - if (serviceRegistry.has(id)) { - return serviceRegistry.get(id)!; - } - - const decorator: any = function (target: Function, key: string, index: number): any { - if (arguments.length !== 3) { - throw new Error('@IServiceName-decorator can only be used to decorate a parameter'); - } - - storeServiceDependency(decorator, target, index); - }; - - decorator.toString = () => id; - - serviceRegistry.set(id, decorator); - return decorator; -} - -function storeServiceDependency(id: Function, target: Function, index: number): void { - if ((target as any)[DI_TARGET] === target) { - (target as any)[DI_DEPENDENCIES].push({ id, index }); - } else { - (target as any)[DI_DEPENDENCIES] = [{ id, index }]; - (target as any)[DI_TARGET] = target; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/Services.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/Services.ts deleted file mode 100755 index c733e73e1..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/Services.ts +++ /dev/null @@ -1,310 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ - -import { IEvent } from 'common/EventEmitter'; -import { IBuffer, IBufferSet } from 'common/buffer/Types'; -import { IDecPrivateModes, ICoreMouseEvent, CoreMouseEncoding, ICoreMouseProtocol, CoreMouseEventType, ICharset, IWindowOptions, IModes } from 'common/Types'; -import { createDecorator } from 'common/services/ServiceRegistry'; - -export const IBufferService = createDecorator('BufferService'); -export interface IBufferService { - serviceBrand: undefined; - - readonly cols: number; - readonly rows: number; - readonly buffer: IBuffer; - readonly buffers: IBufferSet; - isUserScrolling: boolean; - - onResize: IEvent<{ cols: number, rows: number }>; - - resize(cols: number, rows: number): void; - reset(): void; -} - -export const ICoreMouseService = createDecorator('CoreMouseService'); -export interface ICoreMouseService { - activeProtocol: string; - activeEncoding: string; - areMouseEventsActive: boolean; - addProtocol(name: string, protocol: ICoreMouseProtocol): void; - addEncoding(name: string, encoding: CoreMouseEncoding): void; - reset(): void; - - /** - * Triggers a mouse event to be sent. - * - * Returns true if the event passed all protocol restrictions and a report - * was sent, otherwise false. The return value may be used to decide whether - * the default event action in the bowser component should be omitted. - * - * Note: The method will change values of the given event object - * to fullfill protocol and encoding restrictions. - */ - triggerMouseEvent(event: ICoreMouseEvent): boolean; - - /** - * Event to announce changes in mouse tracking. - */ - onProtocolChange: IEvent; - - /** - * Human readable version of mouse events. - */ - explainEvents(events: CoreMouseEventType): { [event: string]: boolean }; -} - -export const ICoreService = createDecorator('CoreService'); -export interface ICoreService { - serviceBrand: undefined; - - /** - * Initially the cursor will not be visible until the first time the terminal - * is focused. - */ - isCursorInitialized: boolean; - isCursorHidden: boolean; - - readonly modes: IModes; - readonly decPrivateModes: IDecPrivateModes; - - readonly onData: IEvent; - readonly onUserInput: IEvent; - readonly onBinary: IEvent; - - reset(): void; - - /** - * Triggers the onData event in the public API. - * @param data The data that is being emitted. - * @param wasFromUser Whether the data originated from the user (as opposed to - * resulting from parsing incoming data). When true this will also: - * - Scroll to the bottom of the buffer.s - * - Fire the `onUserInput` event (so selection can be cleared). - */ - triggerDataEvent(data: string, wasUserInput?: boolean): void; - - /** - * Triggers the onBinary event in the public API. - * @param data The data that is being emitted. - */ - triggerBinaryEvent(data: string): void; -} - -export const ICharsetService = createDecorator('CharsetService'); -export interface ICharsetService { - serviceBrand: undefined; - - charset: ICharset | undefined; - readonly glevel: number; - - reset(): void; - - /** - * Set the G level of the terminal. - * @param g - */ - setgLevel(g: number): void; - - /** - * Set the charset for the given G level of the terminal. - * @param g - * @param charset - */ - setgCharset(g: number, charset: ICharset | undefined): void; -} - -export const IDirtyRowService = createDecorator('DirtyRowService'); -export interface IDirtyRowService { - serviceBrand: undefined; - - readonly start: number; - readonly end: number; - - clearRange(): void; - markDirty(y: number): void; - markRangeDirty(y1: number, y2: number): void; - markAllDirty(): void; -} - -export interface IServiceIdentifier { - (...args: any[]): void; - type: T; -} - -export interface IBrandedService { - serviceBrand: undefined; -} - -type GetLeadingNonServiceArgs = - Args extends [...IBrandedService[]] ? [] - : Args extends [infer A1, ...IBrandedService[]] ? [A1] - : Args extends [infer A1, infer A2, ...IBrandedService[]] ? [A1, A2] - : Args extends [infer A1, infer A2, infer A3, ...IBrandedService[]] ? [A1, A2, A3] - : Args extends [infer A1, infer A2, infer A3, infer A4, ...IBrandedService[]] ? [A1, A2, A3, A4] - : Args extends [infer A1, infer A2, infer A3, infer A4, infer A5, ...IBrandedService[]] ? [A1, A2, A3, A4, A5] - : Args extends [infer A1, infer A2, infer A3, infer A4, infer A5, infer A6, ...IBrandedService[]] ? [A1, A2, A3, A4, A5, A6] - : Args extends [infer A1, infer A2, infer A3, infer A4, infer A5, infer A6, infer A7, ...IBrandedService[]] ? [A1, A2, A3, A4, A5, A6, A7] - : Args extends [infer A1, infer A2, infer A3, infer A4, infer A5, infer A6, infer A7, infer A8, ...IBrandedService[]] ? [A1, A2, A3, A4, A5, A6, A7, A8] - : never; - -export const IInstantiationService = createDecorator('InstantiationService'); -export interface IInstantiationService { - setService(id: IServiceIdentifier, instance: T): void; - getService(id: IServiceIdentifier): T | undefined; - createInstance any, R extends InstanceType>(t: Ctor, ...args: GetLeadingNonServiceArgs>): R; -} - -export const ILogService = createDecorator('LogService'); -export interface ILogService { - serviceBrand: undefined; - - debug(message: any, ...optionalParams: any[]): void; - info(message: any, ...optionalParams: any[]): void; - warn(message: any, ...optionalParams: any[]): void; - error(message: any, ...optionalParams: any[]): void; -} - -export const IOptionsService = createDecorator('OptionsService'); -export interface IOptionsService { - serviceBrand: undefined; - - readonly options: ITerminalOptions; - - readonly onOptionChange: IEvent; - - setOption(key: string, value: T): void; - getOption(key: string): T | undefined; -} - -export type FontWeight = 'normal' | 'bold' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900' | number; -export type LogLevel = 'debug' | 'info' | 'warn' | 'error' | 'off'; -export type RendererType = 'dom' | 'canvas'; - -export interface IPartialTerminalOptions { - altClickMovesCursor?: boolean; - allowTransparency?: boolean; - bellSound?: string; - bellStyle?: 'none' | 'sound' /* | 'visual' | 'both' */; - cols?: number; - cursorBlink?: boolean; - cursorStyle?: 'block' | 'underline' | 'bar'; - cursorWidth?: number; - disableStdin?: boolean; - drawBoldTextInBrightColors?: boolean; - fastScrollModifier?: 'alt' | 'ctrl' | 'shift'; - fastScrollSensitivity?: number; - fontSize?: number; - fontFamily?: string; - fontWeight?: FontWeight; - fontWeightBold?: FontWeight; - letterSpacing?: number; - lineHeight?: number; - logLevel?: LogLevel; - macOptionIsMeta?: boolean; - macOptionClickForcesSelection?: boolean; - rendererType?: RendererType; - rightClickSelectsWord?: boolean; - rows?: number; - screenReaderMode?: boolean; - scrollback?: number; - scrollSensitivity?: number; - tabStopWidth?: number; - theme?: ITheme; - windowsMode?: boolean; - wordSeparator?: string; - windowOptions?: IWindowOptions; -} - -export interface ITerminalOptions { - allowProposedApi: boolean; - allowTransparency: boolean; - altClickMovesCursor: boolean; - bellSound: string; - bellStyle: 'none' | 'sound' /* | 'visual' | 'both' */; - cols: number; - cursorBlink: boolean; - cursorStyle: 'block' | 'underline' | 'bar'; - cursorWidth: number; - disableStdin: boolean; - drawBoldTextInBrightColors: boolean; - fastScrollModifier: 'alt' | 'ctrl' | 'shift' | undefined; - fastScrollSensitivity: number; - fontSize: number; - fontFamily: string; - fontWeight: FontWeight; - fontWeightBold: FontWeight; - letterSpacing: number; - lineHeight: number; - linkTooltipHoverDuration: number; - logLevel: LogLevel; - macOptionIsMeta: boolean; - macOptionClickForcesSelection: boolean; - minimumContrastRatio: number; - rendererType: RendererType; - rightClickSelectsWord: boolean; - rows: number; - screenReaderMode: boolean; - scrollback: number; - scrollSensitivity: number; - tabStopWidth: number; - theme: ITheme; - windowsMode: boolean; - windowOptions: IWindowOptions; - wordSeparator: string; - - [key: string]: any; - cancelEvents: boolean; - convertEol: boolean; - termName: string; -} - -export interface ITheme { - foreground?: string; - background?: string; - cursor?: string; - cursorAccent?: string; - selection?: string; - black?: string; - red?: string; - green?: string; - yellow?: string; - blue?: string; - magenta?: string; - cyan?: string; - white?: string; - brightBlack?: string; - brightRed?: string; - brightGreen?: string; - brightYellow?: string; - brightBlue?: string; - brightMagenta?: string; - brightCyan?: string; - brightWhite?: string; -} - -export const IUnicodeService = createDecorator('UnicodeService'); -export interface IUnicodeService { - serviceBrand: undefined; - /** Register an Unicode version provider. */ - register(provider: IUnicodeVersionProvider): void; - /** Registered Unicode versions. */ - readonly versions: string[]; - /** Currently active version. */ - activeVersion: string; - /** Event triggered, when activate version changed. */ - readonly onChange: IEvent; - - /** - * Unicode version dependent - */ - wcwidth(codepoint: number): number; - getStringCellWidth(s: string): number; -} - -export interface IUnicodeVersionProvider { - readonly version: string; - wcwidth(ucs: number): 0 | 1 | 2; -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/UnicodeService.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/UnicodeService.ts deleted file mode 100755 index e96b75793..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/services/UnicodeService.ts +++ /dev/null @@ -1,82 +0,0 @@ -/** - * Copyright (c) 2019 The xterm.js authors. All rights reserved. - * @license MIT - */ -import { IUnicodeService, IUnicodeVersionProvider } from 'common/services/Services'; -import { EventEmitter, IEvent } from 'common/EventEmitter'; -import { UnicodeV6 } from 'common/input/UnicodeV6'; - - -export class UnicodeService implements IUnicodeService { - public serviceBrand: any; - - private _providers: {[key: string]: IUnicodeVersionProvider} = Object.create(null); - private _active: string = ''; - private _activeProvider: IUnicodeVersionProvider; - private _onChange = new EventEmitter(); - public get onChange(): IEvent { return this._onChange.event; } - - constructor() { - const defaultProvider = new UnicodeV6(); - this.register(defaultProvider); - this._active = defaultProvider.version; - this._activeProvider = defaultProvider; - } - - public get versions(): string[] { - return Object.keys(this._providers); - } - - public get activeVersion(): string { - return this._active; - } - - public set activeVersion(version: string) { - if (!this._providers[version]) { - throw new Error(`unknown Unicode version "${version}"`); - } - this._active = version; - this._activeProvider = this._providers[version]; - this._onChange.fire(version); - } - - public register(provider: IUnicodeVersionProvider): void { - this._providers[provider.version] = provider; - } - - /** - * Unicode version dependent interface. - */ - public wcwidth(num: number): number { - return this._activeProvider.wcwidth(num); - } - - public getStringCellWidth(s: string): number { - let result = 0; - const length = s.length; - for (let i = 0; i < length; ++i) { - let code = s.charCodeAt(i); - // surrogate pair first - if (0xD800 <= code && code <= 0xDBFF) { - if (++i >= length) { - // this should not happen with strings retrieved from - // Buffer.translateToString as it converts from UTF-32 - // and therefore always should contain the second part - // for any other string we still have to handle it somehow: - // simply treat the lonely surrogate first as a single char (UCS-2 behavior) - return result + this.wcwidth(code); - } - const second = s.charCodeAt(i); - // convert surrogate pair to high codepoint only for valid second part (UTF-16) - // otherwise treat them independently (UCS-2 behavior) - if (0xDC00 <= second && second <= 0xDFFF) { - code = (code - 0xD800) * 0x400 + second - 0xDC00 + 0x10000; - } else { - result += this.wcwidth(second); - } - } - result += this.wcwidth(code); - } - return result; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/tsconfig.json b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/tsconfig.json deleted file mode 100755 index b8baa6c09..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/common/tsconfig.json +++ /dev/null @@ -1,18 +0,0 @@ -{ - "extends": "../tsconfig-library-base", - "compilerOptions": { - "lib": [ - "es2015", - "es2016.Array.Include" - ], - "outDir": "../../out", - "types": [ - "../../node_modules/@types/mocha" - ], - "baseUrl": ".." - }, - "include": [ - "./**/*", - "../../typings/xterm.d.ts" - ] -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/tsconfig-base.json b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/tsconfig-base.json deleted file mode 100755 index 0cd951a70..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/tsconfig-base.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "compilerOptions": { - "target": "es5", - "lib": [ "es5" ], - "rootDir": ".", - - "sourceMap": true, - "removeComments": true, - "pretty": true, - - "incremental": true, - "experimentalDecorators": true - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/tsconfig-library-base.json b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/tsconfig-library-base.json deleted file mode 100755 index e08695d75..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/src/tsconfig-library-base.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "extends": "./tsconfig-base.json", - "compilerOptions": { - "composite": true, - "strict": true, - "declarationMap": true, - "experimentalDecorators": true - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/tsconfig.all.json b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/tsconfig.all.json deleted file mode 100755 index 009cd498b..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/tsconfig.all.json +++ /dev/null @@ -1,17 +0,0 @@ -{ - "files": [], - "include": [], - "references": [ - { "path": "./src/browser" }, - { "path": "./test/api" }, - { "path": "./test/benchmark" }, - { "path": "./addons/xterm-addon-attach" }, - { "path": "./addons/xterm-addon-fit" }, - { "path": "./addons/xterm-addon-ligatures" }, - { "path": "./addons/xterm-addon-search" }, - { "path": "./addons/xterm-addon-serialize" }, - { "path": "./addons/xterm-addon-unicode11" }, - { "path": "./addons/xterm-addon-web-links" }, - { "path": "./addons/xterm-addon-webgl" } - ] -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/typings/xterm.d.ts b/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/typings/xterm.d.ts deleted file mode 100755 index d860ddfa7..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/node_modules/xterm/typings/xterm.d.ts +++ /dev/null @@ -1,1606 +0,0 @@ -/** - * @license MIT - * - * This contains the type declarations for the xterm.js library. Note that - * some interfaces differ between this file and the actual implementation in - * src/, that's because this file declares the *public* API which is intended - * to be stable and consumed by external programs. - */ - -/// - -declare module 'xterm' { - /** - * A string or number representing text font weight. - */ - export type FontWeight = 'normal' | 'bold' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900' | number; - - /** - * A string representing log level. - */ - export type LogLevel = 'debug' | 'info' | 'warn' | 'error' | 'off'; - - /** - * A string representing a renderer type. - */ - export type RendererType = 'dom' | 'canvas'; - - /** - * An object containing start up options for the terminal. - */ - export interface ITerminalOptions { - /** - * Whether to allow the use of proposed API. When false, any usage of APIs - * marked as experimental/proposed will throw an error. This defaults to - * true currently, but will change to false in v5.0. - */ - allowProposedApi?: boolean; - - /** - * Whether background should support non-opaque color. It must be set before - * executing the `Terminal.open()` method and can't be changed later without - * executing it again. Note that enabling this can negatively impact - * performance. - */ - allowTransparency?: boolean; - - /** - * If enabled, alt + click will move the prompt cursor to position - * underneath the mouse. The default is true. - */ - altClickMovesCursor?: boolean; - - /** - * A data uri of the sound to use for the bell when `bellStyle = 'sound'`. - */ - bellSound?: string; - - /** - * The type of the bell notification the terminal will use. - */ - bellStyle?: 'none' | 'sound'; - - /** - * When enabled the cursor will be set to the beginning of the next line - * with every new line. This is equivalent to sending '\r\n' for each '\n'. - * Normally the termios settings of the underlying PTY deals with the - * translation of '\n' to '\r\n' and this setting should not be used. If you - * deal with data from a non-PTY related source, this settings might be - * useful. - */ - convertEol?: boolean; - - /** - * The number of columns in the terminal. - */ - cols?: number; - - /** - * Whether the cursor blinks. - */ - cursorBlink?: boolean; - - /** - * The style of the cursor. - */ - cursorStyle?: 'block' | 'underline' | 'bar'; - - /** - * The width of the cursor in CSS pixels when `cursorStyle` is set to 'bar'. - */ - cursorWidth?: number; - - /** - * Whether input should be disabled. - */ - disableStdin?: boolean; - - /** - * Whether to draw bold text in bright colors. The default is true. - */ - drawBoldTextInBrightColors?: boolean; - - /** - * The modifier key hold to multiply scroll speed. - */ - fastScrollModifier?: 'alt' | 'ctrl' | 'shift' | undefined; - - /** - * The scroll speed multiplier used for fast scrolling. - */ - fastScrollSensitivity?: number; - - /** - * The font size used to render text. - */ - fontSize?: number; - - /** - * The font family used to render text. - */ - fontFamily?: string; - - /** - * The font weight used to render non-bold text. - */ - fontWeight?: FontWeight; - - /** - * The font weight used to render bold text. - */ - fontWeightBold?: FontWeight; - - /** - * The spacing in whole pixels between characters. - */ - letterSpacing?: number; - - /** - * The line height used to render text. - */ - lineHeight?: number; - - /** - * The duration in milliseconds before link tooltip events fire when - * hovering on a link. - * @deprecated This will be removed when the link matcher API is removed. - */ - linkTooltipHoverDuration?: number; - - /** - * What log level to use, this will log for all levels below and including - * what is set: - * - * 1. debug - * 2. info (default) - * 3. warn - * 4. error - * 5. off - */ - logLevel?: LogLevel; - - /** - * Whether to treat option as the meta key. - */ - macOptionIsMeta?: boolean; - - /** - * Whether holding a modifier key will force normal selection behavior, - * regardless of whether the terminal is in mouse events mode. This will - * also prevent mouse events from being emitted by the terminal. For - * example, this allows you to use xterm.js' regular selection inside tmux - * with mouse mode enabled. - */ - macOptionClickForcesSelection?: boolean; - - /** - * The minimum contrast ratio for text in the terminal, setting this will - * change the foreground color dynamically depending on whether the contrast - * ratio is met. Example values: - * - * - 1: The default, do nothing. - * - 4.5: Minimum for WCAG AA compliance. - * - 7: Minimum for WCAG AAA compliance. - * - 21: White on black or black on white. - */ - minimumContrastRatio?: number; - - /** - * The type of renderer to use, this allows using the fallback DOM renderer - * when canvas is too slow for the environment. The following features do - * not work when the DOM renderer is used: - * - * - Letter spacing - * - Cursor blink - */ - rendererType?: RendererType; - - /** - * Whether to select the word under the cursor on right click, this is - * standard behavior in a lot of macOS applications. - */ - rightClickSelectsWord?: boolean; - - /** - * The number of rows in the terminal. - */ - rows?: number; - - /** - * Whether screen reader support is enabled. When on this will expose - * supporting elements in the DOM to support NVDA on Windows and VoiceOver - * on macOS. - */ - screenReaderMode?: boolean; - - /** - * The amount of scrollback in the terminal. Scrollback is the amount of - * rows that are retained when lines are scrolled beyond the initial - * viewport. - */ - scrollback?: number; - - /** - * The scrolling speed multiplier used for adjusting normal scrolling speed. - */ - scrollSensitivity?: number; - - /** - * The size of tab stops in the terminal. - */ - tabStopWidth?: number; - - /** - * The color theme of the terminal. - */ - theme?: ITheme; - - /** - * Whether "Windows mode" is enabled. Because Windows backends winpty and - * conpty operate by doing line wrapping on their side, xterm.js does not - * have access to wrapped lines. When Windows mode is enabled the following - * changes will be in effect: - * - * - Reflow is disabled. - * - Lines are assumed to be wrapped if the last character of the line is - * not whitespace. - */ - windowsMode?: boolean; - - /** - * A string containing all characters that are considered word separated by the - * double click to select work logic. - */ - wordSeparator?: string; - - /** - * Enable various window manipulation and report features. - * All features are disabled by default for security reasons. - */ - windowOptions?: IWindowOptions; - } - - /** - * Contains colors to theme the terminal with. - */ - export interface ITheme { - /** The default foreground color */ - foreground?: string; - /** The default background color */ - background?: string; - /** The cursor color */ - cursor?: string; - /** The accent color of the cursor (fg color for a block cursor) */ - cursorAccent?: string; - /** The selection background color (can be transparent) */ - selection?: string; - /** ANSI black (eg. `\x1b[30m`) */ - black?: string; - /** ANSI red (eg. `\x1b[31m`) */ - red?: string; - /** ANSI green (eg. `\x1b[32m`) */ - green?: string; - /** ANSI yellow (eg. `\x1b[33m`) */ - yellow?: string; - /** ANSI blue (eg. `\x1b[34m`) */ - blue?: string; - /** ANSI magenta (eg. `\x1b[35m`) */ - magenta?: string; - /** ANSI cyan (eg. `\x1b[36m`) */ - cyan?: string; - /** ANSI white (eg. `\x1b[37m`) */ - white?: string; - /** ANSI bright black (eg. `\x1b[1;30m`) */ - brightBlack?: string; - /** ANSI bright red (eg. `\x1b[1;31m`) */ - brightRed?: string; - /** ANSI bright green (eg. `\x1b[1;32m`) */ - brightGreen?: string; - /** ANSI bright yellow (eg. `\x1b[1;33m`) */ - brightYellow?: string; - /** ANSI bright blue (eg. `\x1b[1;34m`) */ - brightBlue?: string; - /** ANSI bright magenta (eg. `\x1b[1;35m`) */ - brightMagenta?: string; - /** ANSI bright cyan (eg. `\x1b[1;36m`) */ - brightCyan?: string; - /** ANSI bright white (eg. `\x1b[1;37m`) */ - brightWhite?: string; - } - - /** - * An object containing options for a link matcher. - */ - export interface ILinkMatcherOptions { - /** - * The index of the link from the regex.match(text) call. This defaults to 0 - * (for regular expressions without capture groups). - */ - matchIndex?: number; - - /** - * A callback that validates whether to create an individual link, pass - * whether the link is valid to the callback. - */ - validationCallback?: (uri: string, callback: (isValid: boolean) => void) => void; - - /** - * A callback that fires when the mouse hovers over a link for a period of - * time (defined by {@link ITerminalOptions.linkTooltipHoverDuration}). - */ - tooltipCallback?: (event: MouseEvent, uri: string, location: IViewportRange) => boolean | void; - - /** - * A callback that fires when the mouse leaves a link. Note that this can - * happen even when tooltipCallback hasn't fired for the link yet. - */ - leaveCallback?: () => void; - - /** - * The priority of the link matcher, this defines the order in which the - * link matcher is evaluated relative to others, from highest to lowest. The - * default value is 0. - */ - priority?: number; - - /** - * A callback that fires when the mousedown and click events occur that - * determines whether a link will be activated upon click. This enables - * only activating a link when a certain modifier is held down, if not the - * mouse event will continue propagation (eg. double click to select word). - */ - willLinkActivate?: (event: MouseEvent, uri: string) => boolean; - } - - /** - * An object that can be disposed via a dispose function. - */ - export interface IDisposable { - dispose(): void; - } - - /** - * An event that can be listened to. - * @returns an `IDisposable` to stop listening. - */ - export interface IEvent { - (listener: (arg1: T, arg2: U) => any): IDisposable; - } - - /** - * Represents a specific line in the terminal that is tracked when scrollback - * is trimmed and lines are added or removed. This is a single line that may - * be part of a larger wrapped line. - */ - export interface IMarker extends IDisposable { - /** - * A unique identifier for this marker. - */ - readonly id: number; - - /** - * Whether this marker is disposed. - */ - readonly isDisposed: boolean; - - /** - * The actual line index in the buffer at this point in time. This is set to - * -1 if the marker has been disposed. - */ - readonly line: number; - - /** - * Event listener to get notified when the marker gets disposed. Automatic disposal - * might happen for a marker, that got invalidated by scrolling out or removal of - * a line from the buffer. - */ - onDispose: IEvent; - } - - /** - * The set of localizable strings. - */ - export interface ILocalizableStrings { - /** - * The aria label for the underlying input textarea for the terminal. - */ - promptLabel: string; - - /** - * Announcement for when line reading is suppressed due to too many lines - * being printed to the terminal when `screenReaderMode` is enabled. - */ - tooMuchOutput: string; - } - - /** - * Enable various window manipulation and report features (CSI Ps ; Ps ; Ps t). - * - * Most settings have no default implementation, as they heavily rely on - * the embedding environment. - * - * To implement a feature, create a custom CSI hook like this: - * ```ts - * term.parser.addCsiHandler({final: 't'}, params => { - * const ps = params[0]; - * switch (ps) { - * case XY: - * ... // your implementation for option XY - * return true; // signal Ps=XY was handled - * } - * return false; // any Ps that was not handled - * }); - * ``` - * - * Note on security: - * Most features are meant to deal with some information of the host machine - * where the terminal runs on. This is seen as a security risk possibly leaking - * sensitive data of the host to the program in the terminal. Therefore all options - * (even those without a default implementation) are guarded by the boolean flag - * and disabled by default. - */ - export interface IWindowOptions { - /** - * Ps=1 De-iconify window. - * No default implementation. - */ - restoreWin?: boolean; - /** - * Ps=2 Iconify window. - * No default implementation. - */ - minimizeWin?: boolean; - /** - * Ps=3 ; x ; y - * Move window to [x, y]. - * No default implementation. - */ - setWinPosition?: boolean; - /** - * Ps = 4 ; height ; width - * Resize the window to given `height` and `width` in pixels. - * Omitted parameters should reuse the current height or width. - * Zero parameters should use the display's height or width. - * No default implementation. - */ - setWinSizePixels?: boolean; - /** - * Ps=5 Raise the window to the front of the stacking order. - * No default implementation. - */ - raiseWin?: boolean; - /** - * Ps=6 Lower the xterm window to the bottom of the stacking order. - * No default implementation. - */ - lowerWin?: boolean; - /** Ps=7 Refresh the window. */ - refreshWin?: boolean; - /** - * Ps = 8 ; height ; width - * Resize the text area to given height and width in characters. - * Omitted parameters should reuse the current height or width. - * Zero parameters use the display's height or width. - * No default implementation. - */ - setWinSizeChars?: boolean; - /** - * Ps=9 ; 0 Restore maximized window. - * Ps=9 ; 1 Maximize window (i.e., resize to screen size). - * Ps=9 ; 2 Maximize window vertically. - * Ps=9 ; 3 Maximize window horizontally. - * No default implementation. - */ - maximizeWin?: boolean; - /** - * Ps=10 ; 0 Undo full-screen mode. - * Ps=10 ; 1 Change to full-screen. - * Ps=10 ; 2 Toggle full-screen. - * No default implementation. - */ - fullscreenWin?: boolean; - /** Ps=11 Report xterm window state. - * If the xterm window is non-iconified, it returns "CSI 1 t". - * If the xterm window is iconified, it returns "CSI 2 t". - * No default implementation. - */ - getWinState?: boolean; - /** - * Ps=13 Report xterm window position. Result is "CSI 3 ; x ; y t". - * Ps=13 ; 2 Report xterm text-area position. Result is "CSI 3 ; x ; y t". - * No default implementation. - */ - getWinPosition?: boolean; - /** - * Ps=14 Report xterm text area size in pixels. Result is "CSI 4 ; height ; width t". - * Ps=14 ; 2 Report xterm window size in pixels. Result is "CSI 4 ; height ; width t". - * Has a default implementation. - */ - getWinSizePixels?: boolean; - /** - * Ps=15 Report size of the screen in pixels. Result is "CSI 5 ; height ; width t". - * No default implementation. - */ - getScreenSizePixels?: boolean; - /** - * Ps=16 Report xterm character cell size in pixels. Result is "CSI 6 ; height ; width t". - * Has a default implementation. - */ - getCellSizePixels?: boolean; - /** - * Ps=18 Report the size of the text area in characters. Result is "CSI 8 ; height ; width t". - * Has a default implementation. - */ - getWinSizeChars?: boolean; - /** - * Ps=19 Report the size of the screen in characters. Result is "CSI 9 ; height ; width t". - * No default implementation. - */ - getScreenSizeChars?: boolean; - /** - * Ps=20 Report xterm window's icon label. Result is "OSC L label ST". - * No default implementation. - */ - getIconTitle?: boolean; - /** - * Ps=21 Report xterm window's title. Result is "OSC l label ST". - * No default implementation. - */ - getWinTitle?: boolean; - /** - * Ps=22 ; 0 Save xterm icon and window title on stack. - * Ps=22 ; 1 Save xterm icon title on stack. - * Ps=22 ; 2 Save xterm window title on stack. - * All variants have a default implementation. - */ - pushTitle?: boolean; - /** - * Ps=23 ; 0 Restore xterm icon and window title from stack. - * Ps=23 ; 1 Restore xterm icon title from stack. - * Ps=23 ; 2 Restore xterm window title from stack. - * All variants have a default implementation. - */ - popTitle?: boolean; - /** - * Ps>=24 Resize to Ps lines (DECSLPP). - * DECSLPP is not implemented. This settings is also used to - * enable / disable DECCOLM (earlier variant of DECSLPP). - */ - setWinLines?: boolean; - } - - /** - * The class that represents an xterm.js terminal. - */ - export class Terminal implements IDisposable { - /** - * The element containing the terminal. - */ - readonly element: HTMLElement | undefined; - - /** - * The textarea that accepts input for the terminal. - */ - readonly textarea: HTMLTextAreaElement | undefined; - - /** - * The number of rows in the terminal's viewport. Use - * `ITerminalOptions.rows` to set this in the constructor and - * `Terminal.resize` for when the terminal exists. - */ - readonly rows: number; - - /** - * The number of columns in the terminal's viewport. Use - * `ITerminalOptions.cols` to set this in the constructor and - * `Terminal.resize` for when the terminal exists. - */ - readonly cols: number; - - /** - * (EXPERIMENTAL) The terminal's current buffer, this might be either the - * normal buffer or the alt buffer depending on what's running in the - * terminal. - */ - readonly buffer: IBufferNamespace; - - /** - * (EXPERIMENTAL) Get all markers registered against the buffer. If the alt - * buffer is active this will always return []. - */ - readonly markers: ReadonlyArray; - - /** - * (EXPERIMENTAL) Get the parser interface to register - * custom escape sequence handlers. - */ - readonly parser: IParser; - - /** - * (EXPERIMENTAL) Get the Unicode handling interface - * to register and switch Unicode version. - */ - readonly unicode: IUnicodeHandling; - - /** - * Natural language strings that can be localized. - */ - static strings: ILocalizableStrings; - - /** - * Creates a new `Terminal` object. - * - * @param options An object containing a set of options. - */ - constructor(options?: ITerminalOptions); - - /** - * Adds an event listener for when a binary event fires. This is used to - * enable non UTF-8 conformant binary messages to be sent to the backend. - * Currently this is only used for a certain type of mouse reports that - * happen to be not UTF-8 compatible. - * The event value is a JS string, pass it to the underlying pty as - * binary data, e.g. `pty.write(Buffer.from(data, 'binary'))`. - * @returns an `IDisposable` to stop listening. - */ - onBinary: IEvent; - - /** - * Adds an event listener for the cursor moves. - * @returns an `IDisposable` to stop listening. - */ - onCursorMove: IEvent; - - /** - * Adds an event listener for when a data event fires. This happens for - * example when the user types or pastes into the terminal. The event value - * is whatever `string` results, in a typical setup, this should be passed - * on to the backing pty. - * @returns an `IDisposable` to stop listening. - */ - onData: IEvent; - - /** - * Adds an event listener for when a key is pressed. The event value contains the - * string that will be sent in the data event as well as the DOM event that - * triggered it. - * @returns an `IDisposable` to stop listening. - */ - onKey: IEvent<{ key: string, domEvent: KeyboardEvent }>; - - /** - * Adds an event listener for when a line feed is added. - * @returns an `IDisposable` to stop listening. - */ - onLineFeed: IEvent; - - /** - * Adds an event listener for when a scroll occurs. The event value is the - * new position of the viewport. - * @returns an `IDisposable` to stop listening. - */ - onScroll: IEvent; - - /** - * Adds an event listener for when a selection change occurs. - * @returns an `IDisposable` to stop listening. - */ - onSelectionChange: IEvent; - - /** - * Adds an event listener for when rows are rendered. The event value - * contains the start row and end rows of the rendered area (ranges from `0` - * to `Terminal.rows - 1`). - * @returns an `IDisposable` to stop listening. - */ - onRender: IEvent<{ start: number, end: number }>; - - /** - * Adds an event listener for when the terminal is resized. The event value - * contains the new size. - * @returns an `IDisposable` to stop listening. - */ - onResize: IEvent<{ cols: number, rows: number }>; - - /** - * Adds an event listener for when an OSC 0 or OSC 2 title change occurs. - * The event value is the new title. - * @returns an `IDisposable` to stop listening. - */ - onTitleChange: IEvent; - - /** - * Unfocus the terminal. - */ - blur(): void; - - /** - * Focus the terminal. - */ - focus(): void; - - /** - * Resizes the terminal. It's best practice to debounce calls to resize, - * this will help ensure that the pty can respond to the resize event - * before another one occurs. - * @param x The number of columns to resize to. - * @param y The number of rows to resize to. - */ - resize(columns: number, rows: number): void; - - /** - * Opens the terminal within an element. - * @param parent The element to create the terminal within. This element - * must be visible (have dimensions) when `open` is called as several DOM- - * based measurements need to be performed when this function is called. - */ - open(parent: HTMLElement): void; - - /** - * Attaches a custom key event handler which is run before keys are - * processed, giving consumers of xterm.js ultimate control as to what keys - * should be processed by the terminal and what keys should not. - * @param customKeyEventHandler The custom KeyboardEvent handler to attach. - * This is a function that takes a KeyboardEvent, allowing consumers to stop - * propagation and/or prevent the default action. The function returns - * whether the event should be processed by xterm.js. - */ - attachCustomKeyEventHandler(customKeyEventHandler: (event: KeyboardEvent) => boolean): void; - - /** - * (EXPERIMENTAL) Registers a link matcher, allowing custom link patterns to - * be matched and handled. - * @deprecated The link matcher API is now deprecated in favor of the link - * provider API, see `registerLinkProvider`. - * @param regex The regular expression to search for, specifically this - * searches the textContent of the rows. You will want to use \s to match a - * space ' ' character for example. - * @param handler The callback when the link is called. - * @param options Options for the link matcher. - * @return The ID of the new matcher, this can be used to deregister. - */ - registerLinkMatcher(regex: RegExp, handler: (event: MouseEvent, uri: string) => void, options?: ILinkMatcherOptions): number; - - /** - * (EXPERIMENTAL) Deregisters a link matcher if it has been registered. - * @deprecated The link matcher API is now deprecated in favor of the link - * provider API, see `registerLinkProvider`. - * @param matcherId The link matcher's ID (returned after register) - */ - deregisterLinkMatcher(matcherId: number): void; - - /** - * (EXPERIMENTAL) Registers a link provider, allowing a custom parser to - * be used to match and handle links. Multiple link providers can be used, - * they will be asked in the order in which they are registered. - * @param linkProvider The link provider to use to detect links. - */ - registerLinkProvider(linkProvider: ILinkProvider): IDisposable; - - /** - * (EXPERIMENTAL) Registers a character joiner, allowing custom sequences of - * characters to be rendered as a single unit. This is useful in particular - * for rendering ligatures and graphemes, among other things. - * - * Each registered character joiner is called with a string of text - * representing a portion of a line in the terminal that can be rendered as - * a single unit. The joiner must return a sorted array, where each entry is - * itself an array of length two, containing the start (inclusive) and end - * (exclusive) index of a substring of the input that should be rendered as - * a single unit. When multiple joiners are provided, the results of each - * are collected. If there are any overlapping substrings between them, they - * are combined into one larger unit that is drawn together. - * - * All character joiners that are registered get called every time a line is - * rendered in the terminal, so it is essential for the handler function to - * run as quickly as possible to avoid slowdowns when rendering. Similarly, - * joiners should strive to return the smallest possible substrings to - * render together, since they aren't drawn as optimally as individual - * characters. - * - * NOTE: character joiners are only used by the canvas renderer. - * - * @param handler The function that determines character joins. It is called - * with a string of text that is eligible for joining and returns an array - * where each entry is an array containing the start (inclusive) and end - * (exclusive) indexes of ranges that should be rendered as a single unit. - * @return The ID of the new joiner, this can be used to deregister - */ - registerCharacterJoiner(handler: (text: string) => [number, number][]): number; - - /** - * (EXPERIMENTAL) Deregisters the character joiner if one was registered. - * NOTE: character joiners are only used by the canvas renderer. - * @param joinerId The character joiner's ID (returned after register) - */ - deregisterCharacterJoiner(joinerId: number): void; - - /** - * (EXPERIMENTAL) Adds a marker to the normal buffer and returns it. If the - * alt buffer is active, undefined is returned. - * @param cursorYOffset The y position offset of the marker from the cursor. - * @returns The new marker or undefined. - */ - registerMarker(cursorYOffset: number): IMarker | undefined; - - /** - * @deprecated use `registerMarker` instead. - */ - addMarker(cursorYOffset: number): IMarker | undefined; - - /** - * Gets whether the terminal has an active selection. - */ - hasSelection(): boolean; - - /** - * Gets the terminal's current selection, this is useful for implementing - * copy behavior outside of xterm.js. - */ - getSelection(): string; - - /** - * Gets the selection position or undefined if there is no selection. - */ - getSelectionPosition(): ISelectionPosition | undefined; - - /** - * Clears the current terminal selection. - */ - clearSelection(): void; - - /** - * Selects text within the terminal. - * @param column The column the selection starts at. - * @param row The row the selection starts at. - * @param length The length of the selection. - */ - select(column: number, row: number, length: number): void; - - /** - * Selects all text within the terminal. - */ - selectAll(): void; - - /** - * Selects text in the buffer between 2 lines. - * @param start The 0-based line index to select from (inclusive). - * @param end The 0-based line index to select to (inclusive). - */ - selectLines(start: number, end: number): void; - - /* - * Disposes of the terminal, detaching it from the DOM and removing any - * active listeners. - */ - dispose(): void; - - /** - * Scroll the display of the terminal - * @param amount The number of lines to scroll down (negative scroll up). - */ - scrollLines(amount: number): void; - - /** - * Scroll the display of the terminal by a number of pages. - * @param pageCount The number of pages to scroll (negative scrolls up). - */ - scrollPages(pageCount: number): void; - - /** - * Scrolls the display of the terminal to the top. - */ - scrollToTop(): void; - - /** - * Scrolls the display of the terminal to the bottom. - */ - scrollToBottom(): void; - - /** - * Scrolls to a line within the buffer. - * @param line The 0-based line index to scroll to. - */ - scrollToLine(line: number): void; - - /** - * Clear the entire buffer, making the prompt line the new first line. - */ - clear(): void; - - /** - * Write data to the terminal. - * @param data The data to write to the terminal. This can either be raw - * bytes given as Uint8Array from the pty or a string. Raw bytes will always - * be treated as UTF-8 encoded, string data as UTF-16. - * @param callback Optional callback that fires when the data was processed - * by the parser. - */ - write(data: string | Uint8Array, callback?: () => void): void; - - /** - * Writes data to the terminal, followed by a break line character (\n). - * @param data The data to write to the terminal. This can either be raw - * bytes given as Uint8Array from the pty or a string. Raw bytes will always - * be treated as UTF-8 encoded, string data as UTF-16. - * @param callback Optional callback that fires when the data was processed - * by the parser. - */ - writeln(data: string | Uint8Array, callback?: () => void): void; - - /** - * Write UTF8 data to the terminal. - * @param data The data to write to the terminal. - * @param callback Optional callback when data was processed. - * @deprecated use `write` instead - */ - writeUtf8(data: Uint8Array, callback?: () => void): void; - - /** - * Writes text to the terminal, performing the necessary transformations for pasted text. - * @param data The text to write to the terminal. - */ - paste(data: string): void; - - /** - * Retrieves an option's value from the terminal. - * @param key The option key. - */ - getOption(key: 'bellSound' | 'bellStyle' | 'cursorStyle' | 'fontFamily' | 'logLevel' | 'rendererType' | 'termName' | 'wordSeparator'): string; - /** - * Retrieves an option's value from the terminal. - * @param key The option key. - */ - getOption(key: 'allowTransparency' | 'cancelEvents' | 'convertEol' | 'cursorBlink' | 'disableStdin' | 'macOptionIsMeta' | 'rightClickSelectsWord' | 'popOnBell' | 'visualBell' | 'windowsMode'): boolean; - /** - * Retrieves an option's value from the terminal. - * @param key The option key. - */ - getOption(key: 'cols' | 'fontSize' | 'letterSpacing' | 'lineHeight' | 'rows' | 'tabStopWidth' | 'scrollback'): number; - /** - * Retrieves an option's value from the terminal. - * @param key The option key. - */ - getOption(key: 'fontWeight' | 'fontWeightBold'): FontWeight; - /** - * Retrieves an option's value from the terminal. - * @param key The option key. - */ - getOption(key: string): any; - - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: 'fontFamily' | 'termName' | 'bellSound' | 'wordSeparator', value: string): void; - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: 'fontWeight' | 'fontWeightBold', value: null | 'normal' | 'bold' | '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900' | number): void; - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: 'logLevel', value: LogLevel): void; - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: 'bellStyle', value: null | 'none' | 'visual' | 'sound' | 'both'): void; - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: 'cursorStyle', value: null | 'block' | 'underline' | 'bar'): void; - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: 'allowTransparency' | 'cancelEvents' | 'convertEol' | 'cursorBlink' | 'disableStdin' | 'macOptionIsMeta' | 'popOnBell' | 'rightClickSelectsWord' | 'visualBell' | 'windowsMode', value: boolean): void; - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: 'fontSize' | 'letterSpacing' | 'lineHeight' | 'tabStopWidth' | 'scrollback', value: number): void; - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: 'theme', value: ITheme): void; - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: 'cols' | 'rows', value: number): void; - /** - * Sets an option on the terminal. - * @param key The option key. - * @param value The option value. - */ - setOption(key: string, value: any): void; - - /** - * Tells the renderer to refresh terminal content between two rows - * (inclusive) at the next opportunity. - * @param start The row to start from (between 0 and this.rows - 1). - * @param end The row to end at (between start and this.rows - 1). - */ - refresh(start: number, end: number): void; - - /** - * Perform a full reset (RIS, aka '\x1bc'). - */ - reset(): void; - - /** - * Loads an addon into this instance of xterm.js. - * @param addon The addon to load. - */ - loadAddon(addon: ITerminalAddon): void; - } - - /** - * An addon that can provide additional functionality to the terminal. - */ - export interface ITerminalAddon extends IDisposable { - /** - * This is called when the addon is activated. - */ - activate(terminal: Terminal): void; - } - - /** - * An object representing a selection within the terminal. - */ - interface ISelectionPosition { - /** - * The start column of the selection. - */ - startColumn: number; - - /** - * The start row of the selection. - */ - startRow: number; - - /** - * The end column of the selection. - */ - endColumn: number; - - /** - * The end row of the selection. - */ - endRow: number; - } - - /** - * An object representing a range within the viewport of the terminal. - */ - export interface IViewportRange { - /** - * The start of the range. - */ - start: IViewportRangePosition; - - /** - * The end of the range. - */ - end: IViewportRangePosition; - } - - /** - * An object representing a cell position within the viewport of the terminal. - */ - interface IViewportRangePosition { - /** - * The x position of the cell. This is a 0-based index that refers to the - * space in between columns, not the column itself. Index 0 refers to the - * left side of the viewport, index `Terminal.cols` refers to the right side - * of the viewport. This can be thought of as how a cursor is positioned in - * a text editor. - */ - x: number; - - /** - * The y position of the cell. This is a 0-based index that refers to a - * specific row. - */ - y: number; - } - - /** - * A custom link provider. - */ - interface ILinkProvider { - /** - * Provides a link a buffer position - * @param bufferLineNumber The y position of the buffer to check for links - * within. - * @param callback The callback to be fired when ready with the resulting - * link(s) for the line or `undefined`. - */ - provideLinks(bufferLineNumber: number, callback: (links: ILink[] | undefined) => void): void; - } - - /** - * A link within the terminal. - */ - interface ILink { - /** - * The buffer range of the link. - */ - range: IBufferRange; - - /** - * The text of the link. - */ - text: string; - - /** - * What link decorations to show when hovering the link, this property is tracked and changes - * made after the link is provided will trigger changes. If not set, all decroations will be - * enabled. - */ - decorations?: ILinkDecorations; - - /** - * Calls when the link is activated. - * @param event The mouse event triggering the callback. - * @param text The text of the link. - */ - activate(event: MouseEvent, text: string): void; - - /** - * Called when the mouse hovers the link. To use this to create a DOM-based hover tooltip, - * create the hover element within `Terminal.element` and add the `xterm-hover` class to it, - * that will cause mouse events to not fall through and activate other links. - * @param event The mouse event triggering the callback. - * @param text The text of the link. - */ - hover?(event: MouseEvent, text: string): void; - - /** - * Called when the mouse leaves the link. - * @param event The mouse event triggering the callback. - * @param text The text of the link. - */ - leave?(event: MouseEvent, text: string): void; - - /** - * Called when the link is released and no longer used by xterm.js. - */ - dispose?(): void; - } - - /** - * A set of decorations that can be applied to links. - */ - interface ILinkDecorations { - /** - * Whether the cursor is set to pointer. - */ - pointerCursor: boolean; - - /** - * Whether the underline is visible - */ - underline: boolean; - } - - /** - * A range within a buffer. - */ - interface IBufferRange { - /** - * The start position of the range. - */ - start: IBufferCellPosition; - - /** - * The end position of the range. - */ - end: IBufferCellPosition; - } - - /** - * A position within a buffer. - */ - interface IBufferCellPosition { - /** - * The x position within the buffer. - */ - x: number; - - /** - * The y position within the buffer. - */ - y: number; - } - - /** - * Represents a terminal buffer. - */ - interface IBuffer { - /** - * The type of the buffer. - */ - readonly type: 'normal' | 'alternate'; - - /** - * The y position of the cursor. This ranges between `0` (when the - * cursor is at baseY) and `Terminal.rows - 1` (when the cursor is on the - * last row). - */ - readonly cursorY: number; - - /** - * The x position of the cursor. This ranges between `0` (left side) and - * `Terminal.cols` (after last cell of the row). - */ - readonly cursorX: number; - - /** - * The line within the buffer where the top of the viewport is. - */ - readonly viewportY: number; - - /** - * The line within the buffer where the top of the bottom page is (when - * fully scrolled down). - */ - readonly baseY: number; - - /** - * The amount of lines in the buffer. - */ - readonly length: number; - - /** - * Gets a line from the buffer, or undefined if the line index does not - * exist. - * - * Note that the result of this function should be used immediately after - * calling as when the terminal updates it could lead to unexpected - * behavior. - * - * @param y The line index to get. - */ - getLine(y: number): IBufferLine | undefined; - - /** - * Creates an empty cell object suitable as a cell reference in - * `line.getCell(x, cell)`. Use this to avoid costly recreation of - * cell objects when dealing with tons of cells. - */ - getNullCell(): IBufferCell; - } - - /** - * Represents the terminal's set of buffers. - */ - interface IBufferNamespace { - /** - * The active buffer, this will either be the normal or alternate buffers. - */ - readonly active: IBuffer; - - /** - * The normal buffer. - */ - readonly normal: IBuffer; - - /** - * The alternate buffer, this becomes the active buffer when an application - * enters this mode via DECSET (`CSI ? 4 7 h`) - */ - readonly alternate: IBuffer; - - /** - * Adds an event listener for when the active buffer changes. - * @returns an `IDisposable` to stop listening. - */ - onBufferChange: IEvent; - } - - /** - * Represents a line in the terminal's buffer. - */ - interface IBufferLine { - /** - * Whether the line is wrapped from the previous line. - */ - readonly isWrapped: boolean; - - /** - * The length of the line, all call to getCell beyond the length will result - * in `undefined`. - */ - readonly length: number; - - /** - * Gets a cell from the line, or undefined if the line index does not exist. - * - * Note that the result of this function should be used immediately after - * calling as when the terminal updates it could lead to unexpected - * behavior. - * - * @param x The character index to get. - * @param cell Optional cell object to load data into for performance - * reasons. This is mainly useful when every cell in the buffer is being - * looped over to avoid creating new objects for every cell. - */ - getCell(x: number, cell?: IBufferCell): IBufferCell | undefined; - - /** - * Gets the line as a string. Note that this is gets only the string for the - * line, not taking isWrapped into account. - * - * @param trimRight Whether to trim any whitespace at the right of the line. - * @param startColumn The column to start from (inclusive). - * @param endColumn The column to end at (exclusive). - */ - translateToString(trimRight?: boolean, startColumn?: number, endColumn?: number): string; - } - - /** - * Represents a single cell in the terminal's buffer. - */ - interface IBufferCell { - /** - * The width of the character. Some examples: - * - * - `1` for most cells. - * - `2` for wide character like CJK glyphs. - * - `0` for cells immediately following cells with a width of `2`. - */ - getWidth(): number; - - /** - * The character(s) within the cell. Examples of what this can contain: - * - * - A normal width character - * - A wide character (eg. CJK) - * - An emoji - */ - getChars(): string; - - /** - * Gets the UTF32 codepoint of single characters, if content is a combined - * string it returns the codepoint of the last character in the string. - */ - getCode(): number; - - /** - * Gets the number representation of the foreground color mode, this can be - * used to perform quick comparisons of 2 cells to see if they're the same. - * Use `isFgRGB`, `isFgPalette` and `isFgDefault` to check what color mode - * a cell is. - */ - getFgColorMode(): number; - - /** - * Gets the number representation of the background color mode, this can be - * used to perform quick comparisons of 2 cells to see if they're the same. - * Use `isBgRGB`, `isBgPalette` and `isBgDefault` to check what color mode - * a cell is. - */ - getBgColorMode(): number; - - /** - * Gets a cell's foreground color number, this differs depending on what the - * color mode of the cell is: - * - * - Default: This should be 0, representing the default foreground color - * (CSI 39 m). - * - Palette: This is a number from 0 to 255 of ANSI colors (CSI 3(0-7) m, - * CSI 9(0-7) m, CSI 38 ; 5 ; 0-255 m). - * - RGB: A hex value representing a 'true color': 0xRRGGBB. - * (CSI 3 8 ; 2 ; Pi ; Pr ; Pg ; Pb) - */ - getFgColor(): number; - - /** - * Gets a cell's background color number, this differs depending on what the - * color mode of the cell is: - * - * - Default: This should be 0, representing the default background color - * (CSI 49 m). - * - Palette: This is a number from 0 to 255 of ANSI colors - * (CSI 4(0-7) m, CSI 10(0-7) m, CSI 48 ; 5 ; 0-255 m). - * - RGB: A hex value representing a 'true color': 0xRRGGBB - * (CSI 4 8 ; 2 ; Pi ; Pr ; Pg ; Pb) - */ - getBgColor(): number; - - /** Whether the cell has the bold attribute (CSI 1 m). */ - isBold(): number; - /** Whether the cell has the inverse attribute (CSI 3 m). */ - isItalic(): number; - /** Whether the cell has the inverse attribute (CSI 2 m). */ - isDim(): number; - /** Whether the cell has the underline attribute (CSI 4 m). */ - isUnderline(): number; - /** Whether the cell has the inverse attribute (CSI 5 m). */ - isBlink(): number; - /** Whether the cell has the inverse attribute (CSI 7 m). */ - isInverse(): number; - /** Whether the cell has the inverse attribute (CSI 8 m). */ - isInvisible(): number; - - /** Whether the cell is using the RGB foreground color mode. */ - isFgRGB(): boolean; - /** Whether the cell is using the RGB background color mode. */ - isBgRGB(): boolean; - /** Whether the cell is using the palette foreground color mode. */ - isFgPalette(): boolean; - /** Whether the cell is using the palette background color mode. */ - isBgPalette(): boolean; - /** Whether the cell is using the default foreground color mode. */ - isFgDefault(): boolean; - /** Whether the cell is using the default background color mode. */ - isBgDefault(): boolean; - - /** Whether the cell has the default attribute (no color or style). */ - isAttributeDefault(): boolean; - } - - /** - * Data type to register a CSI, DCS or ESC callback in the parser - * in the form: - * ESC I..I F - * CSI Prefix P..P I..I F - * DCS Prefix P..P I..I F data_bytes ST - * - * with these rules/restrictions: - * - prefix can only be used with CSI and DCS - * - only one leading prefix byte is recognized by the parser - * before any other parameter bytes (P..P) - * - intermediate bytes are recognized up to 2 - * - * For custom sequences make sure to read ECMA-48 and the resources at - * vt100.net to not clash with existing sequences or reserved address space. - * General recommendations: - * - use private address space (see ECMA-48) - * - use max one intermediate byte (technically not limited by the spec, - * in practice there are no sequences with more than one intermediate byte, - * thus parsers might get confused with more intermediates) - * - test against other common emulators to check whether they escape/ignore - * the sequence correctly - * - * Notes: OSC command registration is handled differently (see addOscHandler) - * APC, PM or SOS is currently not supported. - */ - export interface IFunctionIdentifier { - /** - * Optional prefix byte, must be in range \x3c .. \x3f. - * Usable in CSI and DCS. - */ - prefix?: string; - /** - * Optional intermediate bytes, must be in range \x20 .. \x2f. - * Usable in CSI, DCS and ESC. - */ - intermediates?: string; - /** - * Final byte, must be in range \x40 .. \x7e for CSI and DCS, - * \x30 .. \x7e for ESC. - */ - final: string; - } - - /** - * Allows hooking into the parser for custom handling of escape sequences. - */ - export interface IParser { - /** - * Adds a handler for CSI escape sequences. - * @param id Specifies the function identifier under which the callback - * gets registered, e.g. {final: 'm'} for SGR. - * @param callback The function to handle the sequence. The callback is - * called with the numerical params. If the sequence has subparams the - * array will contain subarrays with their numercial values. - * Return true if the sequence was handled; false if we should try - * a previous handler (set by addCsiHandler or setCsiHandler). - * The most recently added handler is tried first. - * @return An IDisposable you can call to remove this handler. - */ - registerCsiHandler(id: IFunctionIdentifier, callback: (params: (number | number[])[]) => boolean): IDisposable; - - /** - * Adds a handler for DCS escape sequences. - * @param id Specifies the function identifier under which the callback - * gets registered, e.g. {intermediates: '$' final: 'q'} for DECRQSS. - * @param callback The function to handle the sequence. Note that the - * function will only be called once if the sequence finished sucessfully. - * There is currently no way to intercept smaller data chunks, data chunks - * will be stored up until the sequence is finished. Since DCS sequences - * are not limited by the amount of data this might impose a problem for - * big payloads. Currently xterm.js limits DCS payload to 10 MB - * which should give enough room for most use cases. - * The function gets the payload and numerical parameters as arguments. - * Return true if the sequence was handled; false if we should try - * a previous handler (set by addDcsHandler or setDcsHandler). - * The most recently added handler is tried first. - * @return An IDisposable you can call to remove this handler. - */ - registerDcsHandler(id: IFunctionIdentifier, callback: (data: string, param: (number | number[])[]) => boolean): IDisposable; - - /** - * Adds a handler for ESC escape sequences. - * @param id Specifies the function identifier under which the callback - * gets registered, e.g. {intermediates: '%' final: 'G'} for - * default charset selection. - * @param callback The function to handle the sequence. - * Return true if the sequence was handled; false if we should try - * a previous handler (set by addEscHandler or setEscHandler). - * The most recently added handler is tried first. - * @return An IDisposable you can call to remove this handler. - */ - registerEscHandler(id: IFunctionIdentifier, handler: () => boolean): IDisposable; - - /** - * Adds a handler for OSC escape sequences. - * @param ident The number (first parameter) of the sequence. - * @param callback The function to handle the sequence. Note that the - * function will only be called once if the sequence finished sucessfully. - * There is currently no way to intercept smaller data chunks, data chunks - * will be stored up until the sequence is finished. Since OSC sequences - * are not limited by the amount of data this might impose a problem for - * big payloads. Currently xterm.js limits OSC payload to 10 MB - * which should give enough room for most use cases. - * The callback is called with OSC data string. - * Return true if the sequence was handled; false if we should try - * a previous handler (set by addOscHandler or setOscHandler). - * The most recently added handler is tried first. - * @return An IDisposable you can call to remove this handler. - */ - registerOscHandler(ident: number, callback: (data: string) => boolean): IDisposable; - } - - /** - * (EXPERIMENTAL) Unicode version provider. - * Used to register custom Unicode versions with `Terminal.unicode.register`. - */ - export interface IUnicodeVersionProvider { - /** - * String indicating the Unicode version provided. - */ - readonly version: string; - - /** - * Unicode version dependent wcwidth implementation. - */ - wcwidth(codepoint: number): 0 | 1 | 2; - } - - /** - * (EXPERIMENTAL) Unicode handling interface. - */ - export interface IUnicodeHandling { - /** - * Register a custom Unicode version provider. - */ - register(provider: IUnicodeVersionProvider): void; - - /** - * Registered Unicode versions. - */ - readonly versions: ReadonlyArray; - - /** - * Getter/setter for active Unicode version. - */ - activeVersion: string; - } -} diff --git a/rawTopoFile/topoviewer/html-static/js/cloudshell/terminal.js b/rawTopoFile/topoviewer/html-static/js/cloudshell/terminal.js deleted file mode 100644 index d39b2c372..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cloudshell/terminal.js +++ /dev/null @@ -1,94 +0,0 @@ -(function() { - // Function to get query parameters - var urlParam = function(name, w) { - w = w || window; - var rx = new RegExp('[\&|\?]' + name + '=([^\&\#]+)'), - val = w.location.search.match(rx); - return !val ? '' : val[1]; - }; - - // Retrieve the RouterID query parameter - var routerId = urlParam('RouterID'); - console.log(routerId); - - // Process the routerId string - var split1 = routerId.toString().split("?"); - console.log(split1[1].split("=")[1]) - - document.title = `TopoViewer::${split1[0]}`; - - - // Initialize the terminal with the desired options - var terminal = new Terminal({ - screenKeys: true, - useStyle: true, - cursorBlink: true, - fullscreenWin: true, - maximizeWin: true, - screenReaderMode: true, - cols: 128, - }); - - // Open the terminal in the specified HTML element - terminal.open(document.getElementById("terminal")); - - // Determine the WebSocket protocol based on the page's protocol - var protocol = (location.protocol === "https:") ? "wss://" : "ws://"; - var url = protocol + location.host + "/xterm.js"; - var ws = new WebSocket(url); - - console.log(ws); - - // Load necessary addons - var attachAddon = new AttachAddon.AttachAddon(ws); - var fitAddon = new FitAddon.FitAddon(); - var webLinksAddon = new WebLinksAddon.WebLinksAddon(); - var unicode11Addon = new Unicode11Addon.Unicode11Addon(); - var serializeAddon = new SerializeAddon.SerializeAddon(); - - terminal.loadAddon(fitAddon); - terminal.loadAddon(webLinksAddon); - terminal.loadAddon(unicode11Addon); - terminal.loadAddon(serializeAddon); - - // Define WebSocket event handlers - ws.onclose = function(event) { - console.log(event); - terminal.write('\r\n\nconnection has been terminated from the server-side (hit refresh to restart)\n'); - }; - - ws.onopen = function() { - terminal.loadAddon(attachAddon); - terminal._initialized = true; - terminal.focus(); - setTimeout(function() { - fitAddon.fit(); - }); - // Uncomment the following lines if needed to send commands to the WebSocket - ws.send("ssh -q -o StrictHostKeyChecking=no admin@" + routerId.toString().split("?")[0]); - - terminal.onResize(function(event) { - var rows = event.rows; - var cols = event.cols; - var size = JSON.stringify({ - cols: cols, - rows: rows + 1 - }); - var send = new TextEncoder().encode("\x01" + size); - console.log('resizing to', size); - - - ws.send(send); - fitAddon.fit(); // this code indeedd - }); - - terminal.onTitleChange(function(event) { - console.log(event); - }); - - // Fit the terminal to the window size when the window is resized - window.onresize = function() { - fitAddon.fit(); - }; - }; -})(); \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/common.js b/rawTopoFile/topoviewer/html-static/js/common.js deleted file mode 100644 index 234288a40..000000000 --- a/rawTopoFile/topoviewer/html-static/js/common.js +++ /dev/null @@ -1,243 +0,0 @@ - - // reusable commonn functions - - async function callGoFunction(goFunctionName, arg01, arg02, arg03) { - console.log(`callGoFunction Called with ${goFunctionName}`); - console.log(`Parameter01: ${arg01}`); - console.log(`Parameter02: ${arg02}`); - - const data = { - param1: arg01, - param2: arg02, - param3: arg03 // Add param3 if needed - }; - - try { - const response = await fetch(goFunctionName, { - method: "POST", - headers: { - "Content-Type": "application/json", - }, - body: JSON.stringify(data), - }); - - if (!response.ok) { - throw new Error("Network response was not ok"); - } - - const responseData = await response.json(); - return responseData; - } catch (error) { - console.error("Error:", error); - throw error; - } - } - - - async function getEnvironments(event) { - try { - const environments = await sendRequestToEndpointGet("/get-environments"); - - // Handle the response data - if (environments && typeof environments === 'object' && Object.keys(environments).length > 0) { - console.log("Valid non-empty JSON response received:", environments); - return environments - - } else { - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - console.error("Error occurred:", error); - // Handle errors as needed - } - } - - async function postPythonAction(event, commandList) { - try { - showLoadingSpinnerGlobal() - const pythonActionRespons = await sendRequestToEndpointPost("/python-action" ,commandList); - - // Handle the response data - if (pythonActionRespons && typeof pythonActionRespons === 'object' && Object.keys(pythonActionRespons).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", pythonActionRespons); - return pythonActionRespons - } else { - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - hideLoadingSpinnerGlobal(); - console.error("Error occurred:", error); - // Handle errors as needed - } - } - - // Function to find a cytoJson element from cytoTopologyJson from getEnvironments() by id and retrieve its attributes - function findCytoElementById(jsonArray, id) { - const cytoElement = jsonArray.find(obj => obj.data.id === id); - if (cytoElement) { - return cytoElement; - } else { - return null; // Handle case where person with given name is not found - } - } - - // Function to find a cytoJson element from cytoTopologyJson from getEnvironments() by name and retrieve its attributes - function findCytoElementByName(jsonArray, name) { - const cytoElement = jsonArray.find(obj => obj.data.name === name); - if (cytoElement) { - return cytoElement; - } else { - return null; // Handle case where person with given name is not found - } - } - - // Function to find a cytoJson element from cytoTopologyJson from getEnvironments() by longname and retrieve its attributes - function findCytoElementByLongname(jsonArray, longname) { - const cytoElement = jsonArray.find(obj => obj.data && obj.data.extraData && obj.data.extraData.longname === longname); - if (cytoElement) { - return cytoElement; - } else { - return null; // Handle case where element with given longname is not found - } - } - - - // argsList is list - async function sendRequestToEndpointPost(endpointName, argsList = []) { - console.log(`callGoFunction Called with ${endpointName}`); - console.log(`Parameters:`, argsList); - - const data = {}; - argsList.forEach((arg, index) => { - data[`param${index + 1}`] = arg; - }); - - try { - const response = await fetch(endpointName, { - method: "POST", - headers: { - "Content-Type": "application/json", - }, - body: JSON.stringify(data), - }); - - if (!response.ok) { - throw new Error("Network response was not ok"); - } - - const responseData = await response.json(); - return responseData; - } catch (error) { - console.error("Error:", error); - throw error; - } - } - async function sendRequestToEndpointGet(endpointName, argsList = []) { - console.log(`callGoFunction Called with ${endpointName}`); - console.log(`Parameters:`, argsList); - - // Construct the query string from argsList - const params = new URLSearchParams(); - argsList.forEach((arg, index) => { - params.append(`param${index + 1}`, arg); - }); - - try { - const response = await fetch(endpointName, { - method: "GET", - headers: { - "Content-Type": "application/json", - }, - }); - - console.log(response) - - if (!response.ok) { - throw new Error("Network response was not ok"); - } - - const responseData = await response.json(); - return responseData; - } catch (error) { - console.error("Error:", error); - throw error; - } - } - - async function sendRequestToEndpointGetV2(endpointName, argsList = []) { - console.log(`callGoFunction Called with ${endpointName}`); - console.log(`Parameters:`, argsList); - - // Construct the query string from argsList - const params = new URLSearchParams(); - argsList.forEach((arg, index) => { - params.append(`param${index + 1}`, arg); - }); - - const urlWithParams = `${endpointName}?${params.toString()}`; - - try { - const response = await fetch(urlWithParams, { - method: "GET", - headers: { - "Content-Type": "application/json", - }, - }); - - - if (!response.ok) { - throw new Error("Network response was not ok"); - } - - const responseData = await response.json(); - - console.log(responseData); - - return responseData; - } catch (error) { - console.error("Error:", error); - throw error; - } - } - - // Function to detect light or dark mode - function detectColorScheme() { - // Check if the browser supports the prefers-color-scheme media feature - if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) { - // Dark mode is enabled - applyTheme('dark'); - - return 'dark'; - } else if (window.matchMedia && window.matchMedia('(prefers-color-scheme: light)').matches) { - // Light mode is enabled - applyTheme('light'); - - return 'light'; - } else { - // No preference or the browser does not support this media feature - applyTheme('light'); - - return 'no-preference'; - } - } - - function applyTheme(theme) { - document.getElementById('root').setAttribute(`data-theme`, `${theme}`); - console.log(document.getElementById('root').getAttribute(`data-theme`)) - } - - - function showLoadingSpinnerGlobal() { - document.getElementById('loading-spinner-global') - .style.display = 'block'; - document.getElementById('loading-spinner-global') - .style.zIndex = '9999'; - document.getElementById('panel-backup-restore') - .style.zIndex = '9998'; - } - - function hideLoadingSpinnerGlobal() { - document.getElementById('loading-spinner-global') - .style.display = 'none'; - } \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cytoscape/cyto-3-24.js b/rawTopoFile/topoviewer/html-static/js/cytoscape/cyto-3-24.js deleted file mode 100755 index 18191eafa..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cytoscape/cyto-3-24.js +++ /dev/null @@ -1,32 +0,0 @@ -/** - * Copyright (c) 2016-2023, The Cytoscape Consortium. - * - * Permission is hereby granted, free of charge, to any person obtaining a copy of - * this software and associated documentation files (the “Software”), to deal in - * the Software without restriction, including without limitation the rights to - * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies - * of the Software, and to permit persons to whom the Software is furnished to do - * so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in all - * copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE - * SOFTWARE. - */ - -!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e="undefined"!=typeof globalThis?globalThis:e||self).cytoscape=t()}(this,(function(){"use strict";function e(t){return(e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(t)}function t(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function n(e,t){for(var n=0;ne.length)&&(t=e.length);for(var n=0,r=new Array(t);nt?1:0},I=null!=Object.assign?Object.assign.bind(Object):function(e){for(var t=arguments,n=1;n255)return;t.push(Math.floor(a))}var o=r[1]||r[2]||r[3],s=r[1]&&r[2]&&r[3];if(o&&!s)return;var l=n[4];if(void 0!==l){if((l=parseFloat(l))<0||l>1)return;t.push(l)}}return t}(e)||function(e){var t,n,r,i,a,o,s,l;function u(e,t,n){return n<0&&(n+=1),n>1&&(n-=1),n<1/6?e+6*(t-e)*n:n<.5?t:n<2/3?e+(t-e)*(2/3-n)*6:e}var c=new RegExp("^hsl[a]?\\(((?:[-+]?(?:(?:\\d+|\\d*\\.\\d+)(?:[Ee][+-]?\\d+)?)))\\s*,\\s*((?:[-+]?(?:(?:\\d+|\\d*\\.\\d+)(?:[Ee][+-]?\\d+)?))[%])\\s*,\\s*((?:[-+]?(?:(?:\\d+|\\d*\\.\\d+)(?:[Ee][+-]?\\d+)?))[%])(?:\\s*,\\s*((?:[-+]?(?:(?:\\d+|\\d*\\.\\d+)(?:[Ee][+-]?\\d+)?))))?\\)$").exec(e);if(c){if((n=parseInt(c[1]))<0?n=(360- -1*n%360)%360:n>360&&(n%=360),n/=360,(r=parseFloat(c[2]))<0||r>100)return;if(r/=100,(i=parseFloat(c[3]))<0||i>100)return;if(i/=100,void 0!==(a=c[4])&&((a=parseFloat(a))<0||a>1))return;if(0===r)o=s=l=Math.round(255*i);else{var d=i<.5?i*(1+r):i+r-i*r,h=2*i-d;o=Math.round(255*u(h,d,n+1/3)),s=Math.round(255*u(h,d,n)),l=Math.round(255*u(h,d,n-1/3))}t=[o,s,l,a]}return t}(e)},L={transparent:[0,0,0,0],aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],grey:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]},O=function(e){for(var t=e.map,n=e.keys,r=n.length,i=0;i=t||n<0||d&&e-u>=a}function v(){var e=X();if(g(e))return y(e);s=setTimeout(v,function(e){var n=t-(e-l);return d?pe(n,a-(e-u)):n}(e))}function y(e){return s=void 0,h&&r?p(e):(r=i=void 0,o)}function m(){var e=X(),n=g(e);if(r=arguments,i=this,l=e,n){if(void 0===s)return f(l);if(d)return clearTimeout(s),s=setTimeout(v,t),p(l)}return void 0===s&&(s=setTimeout(v,t)),o}return t=de(t)||0,V(n)&&(c=!!n.leading,a=(d="maxWait"in n)?he(de(n.maxWait)||0,t):a,h="trailing"in n?!!n.trailing:h),m.cancel=function(){void 0!==s&&clearTimeout(s),u=0,r=l=i=s=void 0},m.flush=function(){return void 0===s?o:y(X())},m},ge=s?s.performance:null,ve=ge&&ge.now?function(){return ge.now()}:function(){return Date.now()},ye=function(){if(s){if(s.requestAnimationFrame)return function(e){s.requestAnimationFrame(e)};if(s.mozRequestAnimationFrame)return function(e){s.mozRequestAnimationFrame(e)};if(s.webkitRequestAnimationFrame)return function(e){s.webkitRequestAnimationFrame(e)};if(s.msRequestAnimationFrame)return function(e){s.msRequestAnimationFrame(e)}}return function(e){e&&setTimeout((function(){e(ve())}),1e3/60)}}(),me=function(e){return ye(e)},be=ve,xe=65599,we=function(e){for(var t,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:9261,r=n;!(t=e.next()).done;)r=r*xe+t.value|0;return r},Ee=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:9261;return t*xe+e|0},ke=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:5381;return(t<<5)+t+e|0},Ce=function(e){return 2097152*e[0]+e[1]},Se=function(e,t){return[Ee(e[0],t[0]),ke(e[1],t[1])]},Pe=function(e,t){var n={value:0,done:!1},r=0,i=e.length;return we({next:function(){return r=0&&(e[r]!==t||(e.splice(r,1),!n));r--);},He=function(e){e.splice(0,e.length)},Ke=function(e,t,n){return n&&(t=M(n,t)),e[t]},Ge=function(e,t,n,r){n&&(t=M(n,t)),e[t]=r},Ue="undefined"!=typeof Map?Map:function(){function e(){t(this,e),this._obj={}}return r(e,[{key:"set",value:function(e,t){return this._obj[e]=t,this}},{key:"delete",value:function(e){return this._obj[e]=void 0,this}},{key:"clear",value:function(){this._obj={}}},{key:"has",value:function(e){return void 0!==this._obj[e]}},{key:"get",value:function(e){return this._obj[e]}}]),e}(),Ze=function(){function e(n){if(t(this,e),this._obj=Object.create(null),this.size=0,null!=n){var r;r=null!=n.instanceString&&n.instanceString()===this.instanceString()?n.toArray():n;for(var i=0;i2&&void 0!==arguments[2])||arguments[2];if(void 0!==e&&void 0!==t&&k(e)){var r=t.group;if(null==r&&(r=t.data&&null!=t.data.source&&null!=t.data.target?"edges":"nodes"),"nodes"===r||"edges"===r){this.length=1,this[0]=this;var i=this._private={cy:e,single:!0,data:t.data||{},position:t.position||{x:0,y:0},autoWidth:void 0,autoHeight:void 0,autoPadding:void 0,compoundBoundsClean:!1,listeners:[],group:r,style:{},rstyle:{},styleCxts:[],styleKeys:{},removed:!0,selected:!!t.selected,selectable:void 0===t.selectable||!!t.selectable,locked:!!t.locked,grabbed:!1,grabbable:void 0===t.grabbable||!!t.grabbable,pannable:void 0===t.pannable?"edges"===r:!!t.pannable,active:!1,classes:new $e,animation:{current:[],queue:[]},rscratch:{},scratch:t.scratch||{},edges:[],children:[],parent:t.parent&&t.parent.isNode()?t.parent:null,traversalCache:{},backgrounding:!1,bbCache:null,bbCacheShift:{x:0,y:0},bodyBounds:null,overlayBounds:null,labelBounds:{all:null,source:null,target:null,main:null},arrowBounds:{source:null,target:null,"mid-source":null,"mid-target":null}};if(null==i.position.x&&(i.position.x=0),null==i.position.y&&(i.position.y=0),t.renderedPosition){var a=t.renderedPosition,o=e.pan(),s=e.zoom();i.position={x:(a.x-o.x)/s,y:(a.y-o.y)/s}}var l=[];v(t.classes)?l=t.classes:f(t.classes)&&(l=t.classes.split(/\s+/));for(var u=0,c=l.length;ut?1:0},u=function(e,t,i,a,o){var s;if(null==i&&(i=0),null==o&&(o=n),i<0)throw new Error("lo must be non-negative");for(null==a&&(a=e.length);in;0<=n?t++:t--)u.push(t);return u}.apply(this).reverse()).length;ag;0<=g?++h:--h)v.push(a(e,r));return v},f=function(e,t,r,i){var a,o,s;for(null==i&&(i=n),a=e[r];r>t&&i(a,o=e[s=r-1>>1])<0;)e[r]=o,r=s;return e[r]=a},g=function(e,t,r){var i,a,o,s,l;for(null==r&&(r=n),a=e.length,l=t,o=e[t],i=2*t+1;i0;){var k=b.pop(),C=v(k),S=k.id();if(d[S]=C,C!==1/0)for(var P=k.neighborhood().intersect(p),D=0;D0)for(n.unshift(t);c[i];){var a=c[i];n.unshift(a.edge),n.unshift(a.node),i=(r=a.node).id()}return o.spawn(n)}}}},it={kruskal:function(e){e=e||function(e){return 1};for(var t=this.byGroup(),n=t.nodes,r=t.edges,i=n.length,a=new Array(i),o=n,s=function(e){for(var t=0;t0;){if(l=g.pop(),u=l.id(),v.delete(u),w++,u===d){for(var E=[],k=i,C=d,S=m[C];E.unshift(k),null!=S&&E.unshift(S),null!=(k=y[C]);)S=m[C=k.id()];return{found:!0,distance:h[u],path:this.spawn(E),steps:w}}f[u]=!0;for(var P=l._private.edges,D=0;DD&&(p[P]=D,m[P]=S,b[P]=w),!i){var T=S*u+C;!i&&p[T]>D&&(p[T]=D,m[T]=C,b[T]=w)}}}for(var _=0;_1&&void 0!==arguments[1]?arguments[1]:a,r=b(e),i=[],o=r;;){if(null==o)return t.spawn();var l=m(o),u=l.edge,c=l.pred;if(i.unshift(o[0]),o.same(n)&&i.length>0)break;null!=u&&i.unshift(u),o=c}return s.spawn(i)},hasNegativeWeightCycle:g,negativeWeightCycles:v}}},dt=Math.sqrt(2),ht=function(e,t,n){0===n.length&&Oe("Karger-Stein must be run on a connected (sub)graph");for(var r=n[e],i=r[1],a=r[2],o=t[i],s=t[a],l=n,u=l.length-1;u>=0;u--){var c=l[u],d=c[1],h=c[2];(t[d]===o&&t[h]===s||t[d]===s&&t[h]===o)&&l.splice(u,1)}for(var p=0;pr;){var i=Math.floor(Math.random()*t.length);t=ht(i,e,t),n--}return t},ft={kargerStein:function(){var e=this,t=this.byGroup(),n=t.nodes,r=t.edges;r.unmergeBy((function(e){return e.isLoop()}));var i=n.length,a=r.length,o=Math.ceil(Math.pow(Math.log(i)/Math.LN2,2)),s=Math.floor(i/dt);if(!(i<2)){for(var l=[],u=0;u0?1:e<0?-1:0},wt=function(e,t){return Math.sqrt(Et(e,t))},Et=function(e,t){var n=t.x-e.x,r=t.y-e.y;return n*n+r*r},kt=function(e){for(var t=e.length,n=0,r=0;r=e.x1&&e.y2>=e.y1)return{x1:e.x1,y1:e.y1,x2:e.x2,y2:e.y2,w:e.x2-e.x1,h:e.y2-e.y1};if(null!=e.w&&null!=e.h&&e.w>=0&&e.h>=0)return{x1:e.x1,y1:e.y1,x2:e.x1+e.w,y2:e.y1+e.h,w:e.w,h:e.h}}},Tt=function(e,t,n){e.x1=Math.min(e.x1,t),e.x2=Math.max(e.x2,t),e.w=e.x2-e.x1,e.y1=Math.min(e.y1,n),e.y2=Math.max(e.y2,n),e.h=e.y2-e.y1},_t=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;return e.x1-=t,e.x2+=t,e.y1-=t,e.y2+=t,e.w=e.x2-e.x1,e.h=e.y2-e.y1,e},Mt=function(e){var t,n,r,i,o=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[0];if(1===o.length)t=n=r=i=o[0];else if(2===o.length)t=r=o[0],i=n=o[1];else if(4===o.length){var s=a(o,4);t=s[0],n=s[1],r=s[2],i=s[3]}return e.x1-=i,e.x2+=n,e.y1-=t,e.y2+=r,e.w=e.x2-e.x1,e.h=e.y2-e.y1,e},Bt=function(e,t){e.x1=t.x1,e.y1=t.y1,e.x2=t.x2,e.y2=t.y2,e.w=e.x2-e.x1,e.h=e.y2-e.y1},Nt=function(e,t){return!(e.x1>t.x2)&&(!(t.x1>e.x2)&&(!(e.x2t.y2)&&!(t.y1>e.y2)))))))},zt=function(e,t,n){return e.x1<=t&&t<=e.x2&&e.y1<=n&&n<=e.y2},It=function(e,t){return zt(e,t.x1,t.y1)&&zt(e,t.x2,t.y2)},At=function(e,t,n,r,i,a,o){var s,l=Jt(i,a),u=i/2,c=a/2,d=r-c-o;if((s=Kt(e,t,n,r,n-u+l-o,d,n+u-l+o,d,!1)).length>0)return s;var h=n+u+o;if((s=Kt(e,t,n,r,h,r-c+l-o,h,r+c-l+o,!1)).length>0)return s;var p=r+c+o;if((s=Kt(e,t,n,r,n-u+l-o,p,n+u-l+o,p,!1)).length>0)return s;var f,g=n-u-o;if((s=Kt(e,t,n,r,g,r-c+l-o,g,r+c-l+o,!1)).length>0)return s;var v=n-u+l,y=r-c+l;if((f=Wt(e,t,n,r,v,y,l+o)).length>0&&f[0]<=v&&f[1]<=y)return[f[0],f[1]];var m=n+u-l,b=r-c+l;if((f=Wt(e,t,n,r,m,b,l+o)).length>0&&f[0]>=m&&f[1]<=b)return[f[0],f[1]];var x=n+u-l,w=r+c-l;if((f=Wt(e,t,n,r,x,w,l+o)).length>0&&f[0]>=x&&f[1]>=w)return[f[0],f[1]];var E=n-u+l,k=r+c-l;return(f=Wt(e,t,n,r,E,k,l+o)).length>0&&f[0]<=E&&f[1]>=k?[f[0],f[1]]:[]},Lt=function(e,t,n,r,i,a,o){var s=o,l=Math.min(n,i),u=Math.max(n,i),c=Math.min(r,a),d=Math.max(r,a);return l-s<=e&&e<=u+s&&c-s<=t&&t<=d+s},Ot=function(e,t,n,r,i,a,o,s,l){var u=Math.min(n,o,i)-l,c=Math.max(n,o,i)+l,d=Math.min(r,s,a)-l,h=Math.max(r,s,a)+l;return!(ec||th)},Rt=function(e,t,n,r,i,a,o,s){var l=[];!function(e,t,n,r,i){var a,o,s,l,u,c,d,h;0===e&&(e=1e-5),s=-27*(r/=e)+(t/=e)*(9*(n/=e)-t*t*2),a=(o=(3*n-t*t)/9)*o*o+(s/=54)*s,i[1]=0,d=t/3,a>0?(u=(u=s+Math.sqrt(a))<0?-Math.pow(-u,1/3):Math.pow(u,1/3),c=(c=s-Math.sqrt(a))<0?-Math.pow(-c,1/3):Math.pow(c,1/3),i[0]=-d+u+c,d+=(u+c)/2,i[4]=i[2]=-d,d=Math.sqrt(3)*(-c+u)/2,i[3]=d,i[5]=-d):(i[5]=i[3]=0,0===a?(h=s<0?-Math.pow(-s,1/3):Math.pow(s,1/3),i[0]=2*h-d,i[4]=i[2]=-(h+d)):(l=(o=-o)*o*o,l=Math.acos(s/Math.sqrt(l)),h=2*Math.sqrt(o),i[0]=-d+h*Math.cos(l/3),i[2]=-d+h*Math.cos((l+2*Math.PI)/3),i[4]=-d+h*Math.cos((l+4*Math.PI)/3)))}(1*n*n-4*n*i+2*n*o+4*i*i-4*i*o+o*o+r*r-4*r*a+2*r*s+4*a*a-4*a*s+s*s,9*n*i-3*n*n-3*n*o-6*i*i+3*i*o+9*r*a-3*r*r-3*r*s-6*a*a+3*a*s,3*n*n-6*n*i+n*o-n*e+2*i*i+2*i*e-o*e+3*r*r-6*r*a+r*s-r*t+2*a*a+2*a*t-s*t,1*n*i-n*n+n*e-i*e+r*a-r*r+r*t-a*t,l);for(var u=[],c=0;c<6;c+=2)Math.abs(l[c+1])<1e-7&&l[c]>=0&&l[c]<=1&&u.push(l[c]);u.push(1),u.push(0);for(var d,h,p,f=-1,g=0;g=0?pl?(e-i)*(e-i)+(t-a)*(t-a):u-d},Ft=function(e,t,n){for(var r,i,a,o,s=0,l=0;l=e&&e>=a||r<=e&&e<=a))continue;(e-r)/(a-r)*(o-i)+i>t&&s++}return s%2!=0},jt=function(e,t,n,r,i,a,o,s,l){var u,c=new Array(n.length);null!=s[0]?(u=Math.atan(s[1]/s[0]),s[0]<0?u+=Math.PI/2:u=-u-Math.PI/2):u=s;for(var d,h=Math.cos(-u),p=Math.sin(-u),f=0;f0){var g=Yt(c,-l);d=qt(g)}else d=c;return Ft(e,t,d)},qt=function(e){for(var t,n,r,i,a,o,s,l,u=new Array(e.length/2),c=0;c=0&&f<=1&&v.push(f),g>=0&&g<=1&&v.push(g),0===v.length)return[];var y=v[0]*s[0]+e,m=v[0]*s[1]+t;return v.length>1?v[0]==v[1]?[y,m]:[y,m,v[1]*s[0]+e,v[1]*s[1]+t]:[y,m]},Ht=function(e,t,n){return t<=e&&e<=n||n<=e&&e<=t?e:e<=t&&t<=n||n<=t&&t<=e?t:n},Kt=function(e,t,n,r,i,a,o,s,l){var u=e-i,c=n-e,d=o-i,h=t-a,p=r-t,f=s-a,g=d*h-f*u,v=c*h-p*u,y=f*c-d*p;if(0!==y){var m=g/y,b=v/y;return-.001<=m&&m<=1.001&&-.001<=b&&b<=1.001||l?[e+m*c,t+m*p]:[]}return 0===g||0===v?Ht(e,n,o)===o?[o,s]:Ht(e,n,i)===i?[i,a]:Ht(i,o,n)===n?[n,r]:[]:[]},Gt=function(e,t,n,r,i,a,o,s){var l,u,c,d,h,p,f=[],g=new Array(n.length),v=!0;if(null==a&&(v=!1),v){for(var y=0;y0){var m=Yt(g,-s);u=qt(m)}else u=g}else u=n;for(var b=0;bu&&(u=t)},d=function(e){return l[e]},h=0;h0?b.edgesTo(m)[0]:m.edgesTo(b)[0];var w=r(x);m=m.id(),h[m]>h[v]+w&&(h[m]=h[v]+w,p.nodes.indexOf(m)<0?p.push(m):p.updateItem(m),u[m]=0,l[m]=[]),h[m]==h[v]+w&&(u[m]=u[m]+u[v],l[m].push(v))}else for(var E=0;E0;){for(var P=n.pop(),D=0;D0&&o.push(n[s]);0!==o.length&&i.push(r.collection(o))}return i}(c,l,t,r);return b=function(e){for(var t=0;t5&&void 0!==arguments[5]?arguments[5]:wn,o=r,s=0;s=2?Dn(e,t,n,0,Cn,Sn):Dn(e,t,n,0,kn)},squaredEuclidean:function(e,t,n){return Dn(e,t,n,0,Cn)},manhattan:function(e,t,n){return Dn(e,t,n,0,kn)},max:function(e,t,n){return Dn(e,t,n,-1/0,Pn)}};function _n(e,t,n,r,i,a){var o;return o=g(e)?e:Tn[e]||Tn.euclidean,0===t&&g(e)?o(i,a):o(t,n,r,i,a)}Tn["squared-euclidean"]=Tn.squaredEuclidean,Tn.squaredeuclidean=Tn.squaredEuclidean;var Mn=Xe({k:2,m:2,sensitivityThreshold:1e-4,distance:"euclidean",maxIterations:10,attributes:[],testMode:!1,testCentroids:null}),Bn=function(e){return Mn(e)},Nn=function(e,t,n,r,i){var a="kMedoids"!==i?function(e){return n[e]}:function(e){return r[e](n)},o=n,s=t;return _n(e,r.length,a,(function(e){return r[e](t)}),o,s)},zn=function(e,t,n){for(var r=n.length,i=new Array(r),a=new Array(r),o=new Array(t),s=null,l=0;ln)return!1}return!0},On=function(e,t,n){for(var r=0;ri&&(i=t[l][u],a=u);o[a].push(e[l])}for(var c=0;c=i.threshold||"dendrogram"===i.mode&&1===e.length)return!1;var p,f=t[o],g=t[r[o]];p="dendrogram"===i.mode?{left:f,right:g,key:f.key}:{value:f.value.concat(g.value),key:f.key},e[f.index]=p,e.splice(g.index,1),t[f.key]=p;for(var v=0;vn[g.key][y.key]&&(a=n[g.key][y.key])):"max"===i.linkage?(a=n[f.key][y.key],n[f.key][y.key]1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:e.length,r=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],i=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],a=!(arguments.length>5&&void 0!==arguments[5])||arguments[5];r?e=e.slice(t,n):(n0&&e.splice(0,t));for(var o=0,s=e.length-1;s>=0;s--){var l=e[s];a?isFinite(l)||(e[s]=-1/0,o++):e.splice(s,1)}i&&e.sort((function(e,t){return e-t}));var u=e.length,c=Math.floor(u/2);return u%2!=0?e[c+1+o]:(e[c-1+o]+e[c+o])/2}(e):"mean"===t?function(e){for(var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:e.length,r=0,i=0,a=t;a1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:e.length,r=1/0,i=t;i1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:e.length,r=-1/0,i=t;io&&(a=l,o=t[i*e+l])}a>0&&r.push(a)}for(var u=0;u=D?(T=D,D=M,_=B):M>T&&(T=M);for(var N=0;N0?1:0;C[k%u.minIterations*t+R]=V,O+=V}if(O>0&&(k>=u.minIterations-1||k==u.maxIterations-1)){for(var F=0,j=0;j0&&r.push(i);return r}(t,a,o),X=function(e,t,n){for(var r=Jn(e,t,n),i=0;il&&(s=u,l=c)}n[i]=a[s]}return r=Jn(e,t,n)}(t,r,Y),W={},H=0;H1)}}));var l=Object.keys(t).filter((function(e){return t[e].cutVertex})).map((function(t){return e.getElementById(t)}));return{cut:e.spawn(l),components:i}},ir=function(){var e=this,t={},n=0,r=[],i=[],a=e.spawn(e);return e.forEach((function(o){if(o.isNode()){var s=o.id();s in t||function o(s){if(i.push(s),t[s]={index:n,low:n++,explored:!1},e.getElementById(s).connectedEdges().intersection(e).forEach((function(e){var n=e.target().id();n!==s&&(n in t||o(n),t[n].explored||(t[s].low=Math.min(t[s].low,t[n].low)))})),t[s].index===t[s].low){for(var l=e.spawn();;){var u=i.pop();if(l.merge(e.getElementById(u)),t[u].low=t[s].index,t[u].explored=!0,u===s)break}var c=l.edgesWith(l),d=l.merge(c);r.push(d),a=a.difference(d)}}(s)}})),{cut:a,components:r}},ar={};[et,rt,it,ot,lt,ct,ft,rn,on,ln,cn,xn,Yn,Un,tr,{hierholzer:function(e){if(!y(e)){var t=arguments;e={root:t[0],directed:t[1]}}var n,r,i,a=nr(e),o=a.root,s=a.directed,l=this,u=!1;o&&(i=f(o)?this.filter(o)[0].id():o[0].id());var c={},d={};s?l.forEach((function(e){var t=e.id();if(e.isNode()){var i=e.indegree(!0),a=e.outdegree(!0),o=i-a,s=a-i;1==o?n?u=!0:n=t:1==s?r?u=!0:r=t:(s>1||o>1)&&(u=!0),c[t]=[],e.outgoers().forEach((function(e){e.isEdge()&&c[t].push(e.id())}))}else d[t]=[void 0,e.target().id()]})):l.forEach((function(e){var t=e.id();e.isNode()?(e.degree(!0)%2&&(n?r?u=!0:r=t:n=t),c[t]=[],e.connectedEdges().forEach((function(e){return c[t].push(e.id())}))):d[t]=[e.source().id(),e.target().id()]}));var h={found:!1,trail:void 0};if(u)return h;if(r&&n)if(s){if(i&&r!=i)return h;i=r}else{if(i&&r!=i&&n!=i)return h;i||(i=r)}else i||(i=l[0].id());var p=function(e){for(var t,n,r,i=e,a=[e];c[i].length;)t=c[i].shift(),n=d[t][0],i!=(r=d[t][1])?(c[r]=c[r].filter((function(e){return e!=t})),i=r):s||i==n||(c[n]=c[n].filter((function(e){return e!=t})),i=n),a.unshift(t),a.unshift(i);return a},g=[],v=[];for(v=p(i);1!=v.length;)0==c[v[0]].length?(g.unshift(l.getElementById(v.shift())),g.unshift(l.getElementById(v.shift()))):v=p(v.shift()).concat(v);for(var m in g.unshift(l.getElementById(v.shift())),c)if(c[m].length)return h;return h.found=!0,h.trail=this.spawn(g,!0),h}},{hopcroftTarjanBiconnected:rr,htbc:rr,htb:rr,hopcroftTarjanBiconnectedComponents:rr},{tarjanStronglyConnected:ir,tsc:ir,tscc:ir,tarjanStronglyConnectedComponents:ir}].forEach((function(e){I(ar,e)})); -/*! - Embeddable Minimum Strictly-Compliant Promises/A+ 1.1.1 Thenable - Copyright (c) 2013-2014 Ralf S. Engelschall (http://engelschall.com) - Licensed under The MIT License (http://opensource.org/licenses/MIT) - */ -var or=function e(t){if(!(this instanceof e))return new e(t);this.id="Thenable/1.0.7",this.state=0,this.fulfillValue=void 0,this.rejectReason=void 0,this.onFulfilled=[],this.onRejected=[],this.proxy={then:this.then.bind(this)},"function"==typeof t&&t.call(this,this.fulfill.bind(this),this.reject.bind(this))};or.prototype={fulfill:function(e){return sr(this,1,"fulfillValue",e)},reject:function(e){return sr(this,2,"rejectReason",e)},then:function(e,t){var n=new or;return this.onFulfilled.push(cr(e,n,"fulfill")),this.onRejected.push(cr(t,n,"reject")),lr(this),n.proxy}};var sr=function(e,t,n,r){return 0===e.state&&(e.state=t,e[n]=r,lr(e)),e},lr=function(e){1===e.state?ur(e,"onFulfilled",e.fulfillValue):2===e.state&&ur(e,"onRejected",e.rejectReason)},ur=function(e,t,n){if(0!==e[t].length){var r=e[t];e[t]=[];var i=function(){for(var e=0;e0:void 0}},clearQueue:function(){return function(){var e=void 0!==this.length?this:[this];if(!(this._private.cy||this).styleEnabled())return this;for(var t=0;t-1};var Jr=function(e,t){var n=this.__data__,r=Gr(n,e);return r<0?(++this.size,n.push([e,t])):n[r][1]=t,this};function ei(e){var t=-1,n=null==e?0:e.length;for(this.clear();++t-1&&e%1==0&&e0&&this.spawn(n).updateStyle().emit("class"),this},addClass:function(e){return this.toggleClass(e,!0)},hasClass:function(e){var t=this[0];return null!=t&&t._private.classes.has(e)},toggleClass:function(e,t){v(e)||(e=e.match(/\S+/g)||[]);for(var n=void 0===t,r=[],i=0,a=this.length;i0&&this.spawn(r).updateStyle().emit("class"),this},removeClass:function(e){return this.toggleClass(e,!1)},flashClass:function(e,t){var n=this;if(null==t)t=250;else if(0===t)return n;return n.addClass(e),setTimeout((function(){n.removeClass(e)}),t),n}};Ri.className=Ri.classNames=Ri.classes;var Vi={metaChar:"[\\!\\\"\\#\\$\\%\\&\\'\\(\\)\\*\\+\\,\\.\\/\\:\\;\\<\\=\\>\\?\\@\\[\\]\\^\\`\\{\\|\\}\\~]",comparatorOp:"=|\\!=|>|>=|<|<=|\\$=|\\^=|\\*=",boolOp:"\\?|\\!|\\^",string:"\"(?:\\\\\"|[^\"])*\"|'(?:\\\\'|[^'])*'",number:N,meta:"degree|indegree|outdegree",separator:"\\s*,\\s*",descendant:"\\s+",child:"\\s+>\\s+",subject:"\\$",group:"node|edge|\\*",directedEdge:"\\s+->\\s+",undirectedEdge:"\\s+<->\\s+"};Vi.variable="(?:[\\w-.]|(?:\\\\"+Vi.metaChar+"))+",Vi.className="(?:[\\w-]|(?:\\\\"+Vi.metaChar+"))+",Vi.value=Vi.string+"|"+Vi.number,Vi.id=Vi.variable,function(){var e,t,n;for(e=Vi.comparatorOp.split("|"),n=0;n=0||"="!==t&&(Vi.comparatorOp+="|\\!"+t)}();var Fi=0,ji=1,qi=2,Yi=3,Xi=4,Wi=5,Hi=6,Ki=7,Gi=8,Ui=9,Zi=10,$i=11,Qi=12,Ji=13,ea=14,ta=15,na=16,ra=17,ia=18,aa=19,oa=20,sa=[{selector:":selected",matches:function(e){return e.selected()}},{selector:":unselected",matches:function(e){return!e.selected()}},{selector:":selectable",matches:function(e){return e.selectable()}},{selector:":unselectable",matches:function(e){return!e.selectable()}},{selector:":locked",matches:function(e){return e.locked()}},{selector:":unlocked",matches:function(e){return!e.locked()}},{selector:":visible",matches:function(e){return e.visible()}},{selector:":hidden",matches:function(e){return!e.visible()}},{selector:":transparent",matches:function(e){return e.transparent()}},{selector:":grabbed",matches:function(e){return e.grabbed()}},{selector:":free",matches:function(e){return!e.grabbed()}},{selector:":removed",matches:function(e){return e.removed()}},{selector:":inside",matches:function(e){return!e.removed()}},{selector:":grabbable",matches:function(e){return e.grabbable()}},{selector:":ungrabbable",matches:function(e){return!e.grabbable()}},{selector:":animated",matches:function(e){return e.animated()}},{selector:":unanimated",matches:function(e){return!e.animated()}},{selector:":parent",matches:function(e){return e.isParent()}},{selector:":childless",matches:function(e){return e.isChildless()}},{selector:":child",matches:function(e){return e.isChild()}},{selector:":orphan",matches:function(e){return e.isOrphan()}},{selector:":nonorphan",matches:function(e){return e.isChild()}},{selector:":compound",matches:function(e){return e.isNode()?e.isParent():e.source().isParent()||e.target().isParent()}},{selector:":loop",matches:function(e){return e.isLoop()}},{selector:":simple",matches:function(e){return e.isSimple()}},{selector:":active",matches:function(e){return e.active()}},{selector:":inactive",matches:function(e){return!e.active()}},{selector:":backgrounding",matches:function(e){return e.backgrounding()}},{selector:":nonbackgrounding",matches:function(e){return!e.backgrounding()}}].sort((function(e,t){return function(e,t){return-1*z(e,t)}(e.selector,t.selector)})),la=function(){for(var e,t={},n=0;n0&&l.edgeCount>0)return Ve("The selector `"+e+"` is invalid because it uses both a compound selector and an edge selector"),!1;if(l.edgeCount>1)return Ve("The selector `"+e+"` is invalid because it uses multiple edge selectors"),!1;1===l.edgeCount&&Ve("The selector `"+e+"` is deprecated. Edge selectors do not take effect on changes to source and target nodes after an edge is added, for performance reasons. Use a class or data selector on edges instead, updating the class or data of an edge when your app detects a change in source or target nodes.")}return!0},toString:function(){if(null!=this.toStringCache)return this.toStringCache;for(var e=function(e){return null==e?"":e},t=function(t){return f(t)?'"'+t+'"':e(t)},n=function(e){return" "+e+" "},r=function(r,a){var o=r.type,s=r.value;switch(o){case Fi:var l=e(s);return l.substring(0,l.length-1);case Yi:var u=r.field,c=r.operator;return"["+u+n(e(c))+t(s)+"]";case Wi:var d=r.operator,h=r.field;return"["+e(d)+h+"]";case Xi:return"["+r.field+"]";case Hi:var p=r.operator;return"[["+r.field+n(e(p))+t(s)+"]]";case Ki:return s;case Gi:return"#"+s;case Ui:return"."+s;case ra:case ta:return i(r.parent,a)+n(">")+i(r.child,a);case ia:case na:return i(r.ancestor,a)+" "+i(r.descendant,a);case aa:var f=i(r.left,a),g=i(r.subject,a),v=i(r.right,a);return f+(f.length>0?" ":"")+g+v;case oa:return""}},i=function(e,t){return e.checks.reduce((function(n,i,a){return n+(t===e&&0===a?"$":"")+r(i,t)}),"")},a="",o=0;o1&&o=0&&(t=t.replace("!",""),c=!0),t.indexOf("@")>=0&&(t=t.replace("@",""),u=!0),(o||l||u)&&(i=o||s?""+e:"",a=""+n),u&&(e=i=i.toLowerCase(),n=a=a.toLowerCase()),t){case"*=":r=i.indexOf(a)>=0;break;case"$=":r=i.indexOf(a,i.length-a.length)>=0;break;case"^=":r=0===i.indexOf(a);break;case"=":r=e===n;break;case">":d=!0,r=e>n;break;case">=":d=!0,r=e>=n;break;case"<":d=!0,r=e0;){var u=i.shift();t(u),a.add(u.id()),o&&r(i,a,u)}return e}function Da(e,t,n){if(n.isParent())for(var r=n._private.children,i=0;i1&&void 0!==arguments[1])||arguments[1];return Pa(this,e,t,Da)},Sa.forEachUp=function(e){var t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return Pa(this,e,t,Ta)},Sa.forEachUpAndDown=function(e){var t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return Pa(this,e,t,_a)},Sa.ancestors=Sa.parents,(Ea=ka={data:Li.data({field:"data",bindingEvent:"data",allowBinding:!0,allowSetting:!0,settingEvent:"data",settingTriggersEvent:!0,triggerFnName:"trigger",allowGetting:!0,immutableKeys:{id:!0,source:!0,target:!0,parent:!0},updateStyle:!0}),removeData:Li.removeData({field:"data",event:"data",triggerFnName:"trigger",triggerEvent:!0,immutableKeys:{id:!0,source:!0,target:!0,parent:!0},updateStyle:!0}),scratch:Li.data({field:"scratch",bindingEvent:"scratch",allowBinding:!0,allowSetting:!0,settingEvent:"scratch",settingTriggersEvent:!0,triggerFnName:"trigger",allowGetting:!0,updateStyle:!0}),removeScratch:Li.removeData({field:"scratch",event:"scratch",triggerFnName:"trigger",triggerEvent:!0,updateStyle:!0}),rscratch:Li.data({field:"rscratch",allowBinding:!1,allowSetting:!0,settingTriggersEvent:!1,allowGetting:!0}),removeRscratch:Li.removeData({field:"rscratch",triggerEvent:!1}),id:function(){var e=this[0];if(e)return e._private.data.id}}).attr=Ea.data,Ea.removeAttr=Ea.removeData;var Ma,Ba,Na=ka,za={};function Ia(e){return function(t){if(void 0===t&&(t=!0),0!==this.length&&this.isNode()&&!this.removed()){for(var n=0,r=this[0],i=r._private.edges,a=0;at})),minIndegree:Aa("indegree",(function(e,t){return et})),minOutdegree:Aa("outdegree",(function(e,t){return et}))}),I(za,{totalDegree:function(e){for(var t=0,n=this.nodes(),r=0;r0,c=u;u&&(l=l[0]);var d=c?l.position():{x:0,y:0};return i={x:s.x-d.x,y:s.y-d.y},void 0===e?i:i[e]}for(var h=0;h0,m=v;v&&(g=g[0]);var b=m?g.position():{x:0,y:0};void 0!==t?p.position(e,t+b[e]):void 0!==i&&p.position({x:i.x+b.x,y:i.y+b.y})}}else if(!a)return;return this}}).modelPosition=Ma.point=Ma.position,Ma.modelPositions=Ma.points=Ma.positions,Ma.renderedPoint=Ma.renderedPosition,Ma.relativePoint=Ma.relativePosition;var Ra,Va,Fa=Ba;Ra=Va={},Va.renderedBoundingBox=function(e){var t=this.boundingBox(e),n=this.cy(),r=n.zoom(),i=n.pan(),a=t.x1*r+i.x,o=t.x2*r+i.x,s=t.y1*r+i.y,l=t.y2*r+i.y;return{x1:a,x2:o,y1:s,y2:l,w:o-a,h:l-s}},Va.dirtyCompoundBoundsCache=function(){var e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],t=this.cy();return t.styleEnabled()&&t.hasCompoundNodes()?(this.forEachUp((function(t){if(t.isParent()){var n=t._private;n.compoundBoundsClean=!1,n.bbCache=null,e||t.emitAndNotify("bounds")}})),this):this},Va.updateCompoundBounds=function(){var e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],t=this.cy();if(!t.styleEnabled()||!t.hasCompoundNodes())return this;if(!e&&t.batching())return this;function n(e){if(e.isParent()){var t=e._private,n=e.children(),r="include"===e.pstyle("compound-sizing-wrt-labels").value,i={width:{val:e.pstyle("min-width").pfValue,left:e.pstyle("min-width-bias-left"),right:e.pstyle("min-width-bias-right")},height:{val:e.pstyle("min-height").pfValue,top:e.pstyle("min-height-bias-top"),bottom:e.pstyle("min-height-bias-bottom")}},a=n.boundingBox({includeLabels:r,includeOverlays:!1,useCache:!1}),o=t.position;0!==a.w&&0!==a.h||((a={w:e.pstyle("width").pfValue,h:e.pstyle("height").pfValue}).x1=o.x-a.w/2,a.x2=o.x+a.w/2,a.y1=o.y-a.h/2,a.y2=o.y+a.h/2);var s=i.width.left.value;"px"===i.width.left.units&&i.width.val>0&&(s=100*s/i.width.val);var l=i.width.right.value;"px"===i.width.right.units&&i.width.val>0&&(l=100*l/i.width.val);var u=i.height.top.value;"px"===i.height.top.units&&i.height.val>0&&(u=100*u/i.height.val);var c=i.height.bottom.value;"px"===i.height.bottom.units&&i.height.val>0&&(c=100*c/i.height.val);var d=y(i.width.val-a.w,s,l),h=d.biasDiff,p=d.biasComplementDiff,f=y(i.height.val-a.h,u,c),g=f.biasDiff,v=f.biasComplementDiff;t.autoPadding=function(e,t,n,r){if("%"!==n.units)return"px"===n.units?n.pfValue:0;switch(r){case"width":return e>0?n.pfValue*e:0;case"height":return t>0?n.pfValue*t:0;case"average":return e>0&&t>0?n.pfValue*(e+t)/2:0;case"min":return e>0&&t>0?e>t?n.pfValue*t:n.pfValue*e:0;case"max":return e>0&&t>0?e>t?n.pfValue*e:n.pfValue*t:0;default:return 0}}(a.w,a.h,e.pstyle("padding"),e.pstyle("padding-relative-to").value),t.autoWidth=Math.max(a.w,i.width.val),o.x=(-h+a.x1+a.x2+p)/2,t.autoHeight=Math.max(a.h,i.height.val),o.y=(-g+a.y1+a.y2+v)/2}function y(e,t,n){var r=0,i=0,a=t+n;return e>0&&a>0&&(r=t/a*e,i=n/a*e),{biasDiff:r,biasComplementDiff:i}}}for(var r=0;re.x2?r:e.x2,e.y1=ne.y2?i:e.y2,e.w=e.x2-e.x1,e.h=e.y2-e.y1)},Ya=function(e,t){return null==t?e:qa(e,t.x1,t.y1,t.x2,t.y2)},Xa=function(e,t,n){return Ke(e,t,n)},Wa=function(e,t,n){if(!t.cy().headless()){var r,i,a=t._private,o=a.rstyle,s=o.arrowWidth/2;if("none"!==t.pstyle(n+"-arrow-shape").value){"source"===n?(r=o.srcX,i=o.srcY):"target"===n?(r=o.tgtX,i=o.tgtY):(r=o.midX,i=o.midY);var l=a.arrowBounds=a.arrowBounds||{},u=l[n]=l[n]||{};u.x1=r-s,u.y1=i-s,u.x2=r+s,u.y2=i+s,u.w=u.x2-u.x1,u.h=u.y2-u.y1,_t(u,1),qa(e,u.x1,u.y1,u.x2,u.y2)}}},Ha=function(e,t,n){if(!t.cy().headless()){var r;r=n?n+"-":"";var i=t._private,a=i.rstyle;if(t.pstyle(r+"label").strValue){var o,s,l,u,c=t.pstyle("text-halign"),d=t.pstyle("text-valign"),h=Xa(a,"labelWidth",n),p=Xa(a,"labelHeight",n),f=Xa(a,"labelX",n),g=Xa(a,"labelY",n),v=t.pstyle(r+"text-margin-x").pfValue,y=t.pstyle(r+"text-margin-y").pfValue,m=t.isEdge(),b=t.pstyle(r+"text-rotation"),x=t.pstyle("text-outline-width").pfValue,w=t.pstyle("text-border-width").pfValue/2,E=t.pstyle("text-background-padding").pfValue,k=p,C=h,S=C/2,P=k/2;if(m)o=f-S,s=f+S,l=g-P,u=g+P;else{switch(c.value){case"left":o=f-C,s=f;break;case"center":o=f-S,s=f+S;break;case"right":o=f,s=f+C}switch(d.value){case"top":l=g-k,u=g;break;case"center":l=g-P,u=g+P;break;case"bottom":l=g,u=g+k}}o+=v-Math.max(x,w)-E-2,s+=v+Math.max(x,w)+E+2,l+=y-Math.max(x,w)-E-2,u+=y+Math.max(x,w)+E+2;var D=n||"main",T=i.labelBounds,_=T[D]=T[D]||{};_.x1=o,_.y1=l,_.x2=s,_.y2=u,_.w=s-o,_.h=u-l;var M=m&&"autorotate"===b.strValue,B=null!=b.pfValue&&0!==b.pfValue;if(M||B){var N=M?Xa(i.rstyle,"labelAngle",n):b.pfValue,z=Math.cos(N),I=Math.sin(N),A=(o+s)/2,L=(l+u)/2;if(!m){switch(c.value){case"left":A=s;break;case"right":A=o}switch(d.value){case"top":L=u;break;case"bottom":L=l}}var O=function(e,t){return{x:(e-=A)*z-(t-=L)*I+A,y:e*I+t*z+L}},R=O(o,l),V=O(o,u),F=O(s,l),j=O(s,u);o=Math.min(R.x,V.x,F.x,j.x),s=Math.max(R.x,V.x,F.x,j.x),l=Math.min(R.y,V.y,F.y,j.y),u=Math.max(R.y,V.y,F.y,j.y)}var q=D+"Rot",Y=T[q]=T[q]||{};Y.x1=o,Y.y1=l,Y.x2=s,Y.y2=u,Y.w=s-o,Y.h=u-l,qa(e,o,l,s,u),qa(i.labelBounds.all,o,l,s,u)}return e}},Ka=function(e){var t=0,n=function(e){return(e?1:0)<(r=T[1].x)){var _=n;n=r,r=_}if(i>(a=T[1].y)){var M=i;i=a,a=M}qa(h,n-k,i-k,r+k,a+k)}}else if("bezier"===D||"unbundled-bezier"===D||"segments"===D||"taxi"===D){var B;switch(D){case"bezier":case"unbundled-bezier":B=v.bezierPts;break;case"segments":case"taxi":B=v.linePts}if(null!=B)for(var N=0;N(r=A.x)){var L=n;n=r,r=L}if((i=I.y)>(a=A.y)){var O=i;i=a,a=O}qa(h,n-=k,i-=k,r+=k,a+=k)}if(c&&t.includeEdges&&g&&(Wa(h,e,"mid-source"),Wa(h,e,"mid-target"),Wa(h,e,"source"),Wa(h,e,"target")),c)if("yes"===e.pstyle("ghost").value){var R=e.pstyle("ghost-offset-x").pfValue,V=e.pstyle("ghost-offset-y").pfValue;qa(h,h.x1+R,h.y1+V,h.x2+R,h.y2+V)}var F=p.bodyBounds=p.bodyBounds||{};Bt(F,h),Mt(F,y),_t(F,1),c&&(n=h.x1,r=h.x2,i=h.y1,a=h.y2,qa(h,n-E,i-E,r+E,a+E));var j=p.overlayBounds=p.overlayBounds||{};Bt(j,h),Mt(j,y),_t(j,1);var q=p.labelBounds=p.labelBounds||{};null!=q.all?((l=q.all).x1=1/0,l.y1=1/0,l.x2=-1/0,l.y2=-1/0,l.w=0,l.h=0):q.all=Dt(),c&&t.includeLabels&&(t.includeMainLabels&&Ha(h,e,null),g&&(t.includeSourceLabels&&Ha(h,e,"source"),t.includeTargetLabels&&Ha(h,e,"target")))}return h.x1=ja(h.x1),h.y1=ja(h.y1),h.x2=ja(h.x2),h.y2=ja(h.y2),h.w=ja(h.x2-h.x1),h.h=ja(h.y2-h.y1),h.w>0&&h.h>0&&b&&(Mt(h,y),_t(h,1)),h}(e,Za),r.bbCache=n,r.bbCachePosKey=o):n=r.bbCache,!a){var c=e.isNode();n=Dt(),(t.includeNodes&&c||t.includeEdges&&!c)&&(t.includeOverlays?Ya(n,r.overlayBounds):Ya(n,r.bodyBounds)),t.includeLabels&&(t.includeMainLabels&&(!i||t.includeSourceLabels&&t.includeTargetLabels)?Ya(n,r.labelBounds.all):(t.includeMainLabels&&Ya(n,r.labelBounds.mainRot),t.includeSourceLabels&&Ya(n,r.labelBounds.sourceRot),t.includeTargetLabels&&Ya(n,r.labelBounds.targetRot))),n.w=n.x2-n.x1,n.h=n.y2-n.y1}return n},Za={includeNodes:!0,includeEdges:!0,includeLabels:!0,includeMainLabels:!0,includeSourceLabels:!0,includeTargetLabels:!0,includeOverlays:!0,includeUnderlays:!0,useCache:!0},$a=Ka(Za),Qa=Xe(Za);Va.boundingBox=function(e){var t;if(1!==this.length||null==this[0]._private.bbCache||this[0]._private.styleDirty||void 0!==e&&void 0!==e.useCache&&!0!==e.useCache){t=Dt();var n=Qa(e=e||Za);if(this.cy().styleEnabled())for(var r=0;r0&&void 0!==arguments[0]?arguments[0]:fo,t=arguments.length>1?arguments[1]:void 0,n=0;n=0;s--)o(s);return this},vo.removeAllListeners=function(){return this.removeListener("*")},vo.emit=vo.trigger=function(e,t,n){var r=this.listeners,i=r.length;return this.emitting++,v(t)||(t=[t]),bo(this,(function(e,a){null!=n&&(r=[{event:a.event,type:a.type,namespace:a.namespace,callback:n}],i=r.length);for(var o=function(n){var i=r[n];if(i.type===a.type&&(!i.namespace||i.namespace===a.namespace||".*"===i.namespace)&&e.eventMatches(e.context,i,a)){var o=[a];null!=t&&function(e,t){for(var n=0;n1&&!r){var i=this.length-1,a=this[i],o=a._private.data.id;this[i]=void 0,this[e]=a,n.set(o,{ele:a,index:e})}return this.length--,this},unmergeOne:function(e){e=e[0];var t=this._private,n=e._private.data.id,r=t.map.get(n);if(!r)return this;var i=r.index;return this.unmergeAt(i),this},unmerge:function(e){var t=this._private.cy;if(!e)return this;if(e&&f(e)){var n=e;e=t.mutableElements().filter(n)}for(var r=0;r=0;t--){e(this[t])&&this.unmergeAt(t)}return this},map:function(e,t){for(var n=[],r=0;rr&&(r=o,n=a)}return{value:r,ele:n}},min:function(e,t){for(var n,r=1/0,i=0;i=0&&i1&&void 0!==arguments[1])||arguments[1],n=this[0],r=n.cy();if(r.styleEnabled()&&n){this.cleanStyle();var i=n._private.style[e];return null!=i?i:t?r.style().getDefaultProperty(e):null}},numericStyle:function(e){var t=this[0];if(t.cy().styleEnabled()&&t){var n=t.pstyle(e);return void 0!==n.pfValue?n.pfValue:n.value}},numericStyleUnits:function(e){var t=this[0];if(t.cy().styleEnabled())return t?t.pstyle(e).units:void 0},renderedStyle:function(e){var t=this.cy();if(!t.styleEnabled())return this;var n=this[0];return n?t.style().getRenderedStyle(n,e):void 0},style:function(e,t){var n=this.cy();if(!n.styleEnabled())return this;var r=n.style();if(y(e)){var i=e;r.applyBypass(this,i,!1),this.emitAndNotify("style")}else if(f(e)){if(void 0===t){var a=this[0];return a?r.getStylePropertyValue(a,e):void 0}r.applyBypass(this,e,t,!1),this.emitAndNotify("style")}else if(void 0===e){var o=this[0];return o?r.getRawStyle(o):void 0}return this},removeStyle:function(e){var t=this.cy();if(!t.styleEnabled())return this;var n=t.style();if(void 0===e)for(var r=0;r0&&t.push(c[0]),t.push(s[0])}return this.spawn(t,!0).filter(e)}),"neighborhood"),closedNeighborhood:function(e){return this.neighborhood().add(this).filter(e)},openNeighborhood:function(e){return this.neighborhood(e)}}),Yo.neighbourhood=Yo.neighborhood,Yo.closedNeighbourhood=Yo.closedNeighborhood,Yo.openNeighbourhood=Yo.openNeighborhood,I(Yo,{source:Ca((function(e){var t,n=this[0];return n&&(t=n._private.source||n.cy().collection()),t&&e?t.filter(e):t}),"source"),target:Ca((function(e){var t,n=this[0];return n&&(t=n._private.target||n.cy().collection()),t&&e?t.filter(e):t}),"target"),sources:Ko({attr:"source"}),targets:Ko({attr:"target"})}),I(Yo,{edgesWith:Ca(Go(),"edgesWith"),edgesTo:Ca(Go({thisIsSrc:!0}),"edgesTo")}),I(Yo,{connectedEdges:Ca((function(e){for(var t=[],n=0;n0);return a},component:function(){var e=this[0];return e.cy().mutableElements().components(e)[0]}}),Yo.componentsOf=Yo.components;var Zo=function(e,t){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2],r=arguments.length>3&&void 0!==arguments[3]&&arguments[3];if(void 0!==e){var i=new Ue,a=!1;if(t){if(t.length>0&&y(t[0])&&!w(t[0])){a=!0;for(var o=[],s=new $e,l=0,u=t.length;l0&&void 0!==arguments[0])||arguments[0],r=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=this,a=i.cy(),o=a._private,s=[],l=[],u=0,c=i.length;u0){for(var R=e.length===i.length?i:new Zo(a,e),V=0;V0&&void 0!==arguments[0])||arguments[0],t=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],n=this,r=[],i={},a=n._private.cy;function o(e){for(var t=e._private.edges,n=0;n0&&(e?D.emitAndNotify("remove"):t&&D.emit("remove"));for(var T=0;T1e-4&&Math.abs(s.v)>1e-4;);return a?function(e){return u[e*(u.length-1)|0]}:c}}(),es=function(e,t,n,r){var i=function(e,t,n,r){var i=4,a=.001,o=1e-7,s=10,l=11,u=1/(l-1),c="undefined"!=typeof Float32Array;if(4!==arguments.length)return!1;for(var d=0;d<4;++d)if("number"!=typeof arguments[d]||isNaN(arguments[d])||!isFinite(arguments[d]))return!1;e=Math.min(e,1),n=Math.min(n,1),e=Math.max(e,0),n=Math.max(n,0);var h=c?new Float32Array(l):new Array(l);function p(e,t){return 1-3*t+3*e}function f(e,t){return 3*t-6*e}function g(e){return 3*e}function v(e,t,n){return((p(t,n)*e+f(t,n))*e+g(t))*e}function y(e,t,n){return 3*p(t,n)*e*e+2*f(t,n)*e+g(t)}function m(t,r){for(var a=0;a0?i=l:r=l}while(Math.abs(a)>o&&++u=a?m(t,s):0===c?s:x(t,r,r+u)}var E=!1;function k(){E=!0,e===t&&n===r||b()}var C=function(i){return E||k(),e===t&&n===r?i:0===i?0:1===i?1:v(w(i),t,r)};C.getControlPoints=function(){return[{x:e,y:t},{x:n,y:r}]};var S="generateBezier("+[e,t,n,r]+")";return C.toString=function(){return S},C}(e,t,n,r);return function(e,t,n){return e+(t-e)*i(n)}},ts={linear:function(e,t,n){return e+(t-e)*n},ease:es(.25,.1,.25,1),"ease-in":es(.42,0,1,1),"ease-out":es(0,0,.58,1),"ease-in-out":es(.42,0,.58,1),"ease-in-sine":es(.47,0,.745,.715),"ease-out-sine":es(.39,.575,.565,1),"ease-in-out-sine":es(.445,.05,.55,.95),"ease-in-quad":es(.55,.085,.68,.53),"ease-out-quad":es(.25,.46,.45,.94),"ease-in-out-quad":es(.455,.03,.515,.955),"ease-in-cubic":es(.55,.055,.675,.19),"ease-out-cubic":es(.215,.61,.355,1),"ease-in-out-cubic":es(.645,.045,.355,1),"ease-in-quart":es(.895,.03,.685,.22),"ease-out-quart":es(.165,.84,.44,1),"ease-in-out-quart":es(.77,0,.175,1),"ease-in-quint":es(.755,.05,.855,.06),"ease-out-quint":es(.23,1,.32,1),"ease-in-out-quint":es(.86,0,.07,1),"ease-in-expo":es(.95,.05,.795,.035),"ease-out-expo":es(.19,1,.22,1),"ease-in-out-expo":es(1,0,0,1),"ease-in-circ":es(.6,.04,.98,.335),"ease-out-circ":es(.075,.82,.165,1),"ease-in-out-circ":es(.785,.135,.15,.86),spring:function(e,t,n){if(0===n)return ts.linear;var r=Jo(e,t,n);return function(e,t,n){return e+(t-e)*r(n)}},"cubic-bezier":es};function ns(e,t,n,r,i){if(1===r)return n;if(t===n)return n;var a=i(t,n,r);return null==e||((e.roundValue||e.color)&&(a=Math.round(a)),void 0!==e.min&&(a=Math.max(a,e.min)),void 0!==e.max&&(a=Math.min(a,e.max))),a}function rs(e,t){return null!=e.pfValue||null!=e.value?null==e.pfValue||null!=t&&"%"===t.type.units?e.value:e.pfValue:e}function is(e,t,n,r,i){var a=null!=i?i.type:null;n<0?n=0:n>1&&(n=1);var o=rs(e,i),s=rs(t,i);if(m(o)&&m(s))return ns(a,o,s,n,r);if(v(o)&&v(s)){for(var l=[],u=0;u0?("spring"===d&&h.push(o.duration),o.easingImpl=ts[d].apply(null,h)):o.easingImpl=ts[d]}var p,g=o.easingImpl;if(p=0===o.duration?1:(n-l)/o.duration,o.applying&&(p=o.progress),p<0?p=0:p>1&&(p=1),null==o.delay){var v=o.startPosition,y=o.position;if(y&&i&&!e.locked()){var m={};os(v.x,y.x)&&(m.x=is(v.x,y.x,p,g)),os(v.y,y.y)&&(m.y=is(v.y,y.y,p,g)),e.position(m)}var b=o.startPan,x=o.pan,w=a.pan,E=null!=x&&r;E&&(os(b.x,x.x)&&(w.x=is(b.x,x.x,p,g)),os(b.y,x.y)&&(w.y=is(b.y,x.y,p,g)),e.emit("pan"));var k=o.startZoom,C=o.zoom,S=null!=C&&r;S&&(os(k,C)&&(a.zoom=Pt(a.minZoom,is(k,C,p,g),a.maxZoom)),e.emit("zoom")),(E||S)&&e.emit("viewport");var P=o.style;if(P&&P.length>0&&i){for(var D=0;D=0;t--){(0,e[t])()}e.splice(0,e.length)},c=a.length-1;c>=0;c--){var d=a[c],h=d._private;h.stopped?(a.splice(c,1),h.hooked=!1,h.playing=!1,h.started=!1,u(h.frames)):(h.playing||h.applying)&&(h.playing&&h.applying&&(h.applying=!1),h.started||ss(0,d,e),as(t,d,e,n),h.applying&&(h.applying=!1),u(h.frames),null!=h.step&&h.step(e),d.completed()&&(a.splice(c,1),h.hooked=!1,h.playing=!1,h.started=!1,u(h.completes)),s=!0)}return n||0!==a.length||0!==o.length||r.push(t),s}for(var a=!1,o=0;o0?t.notify("draw",n):t.notify("draw")),n.unmerge(r),t.emit("step")}var us={animate:Li.animate(),animation:Li.animation(),animated:Li.animated(),clearQueue:Li.clearQueue(),delay:Li.delay(),delayAnimation:Li.delayAnimation(),stop:Li.stop(),addToAnimationPool:function(e){this.styleEnabled()&&this._private.aniEles.merge(e)},stopAnimationLoop:function(){this._private.animationsRunning=!1},startAnimationLoop:function(){var e=this;if(e._private.animationsRunning=!0,e.styleEnabled()){var t=e.renderer();t&&t.beforeRender?t.beforeRender((function(t,n){ls(n,e)}),t.beforeRenderPriorities.animations):function t(){e._private.animationsRunning&&me((function(n){ls(n,e),t()}))}()}}},cs={qualifierCompare:function(e,t){return null==e||null==t?null==e&&null==t:e.sameText(t)},eventMatches:function(e,t,n){var r=t.qualifier;return null==r||e!==n.target&&w(n.target)&&r.matches(n.target)},addEventFields:function(e,t){t.cy=e,t.target=e},callbackContext:function(e,t,n){return null!=t.qualifier?n.target:e}},ds=function(e){return f(e)?new ba(e):e},hs={createEmitter:function(){var e=this._private;return e.emitter||(e.emitter=new go(cs,this)),this},emitter:function(){return this._private.emitter},on:function(e,t,n){return this.emitter().on(e,ds(t),n),this},removeListener:function(e,t,n){return this.emitter().removeListener(e,ds(t),n),this},removeAllListeners:function(){return this.emitter().removeAllListeners(),this},one:function(e,t,n){return this.emitter().one(e,ds(t),n),this},once:function(e,t,n){return this.emitter().one(e,ds(t),n),this},emit:function(e,t){return this.emitter().emit(e,t),this},emitAndNotify:function(e,t){return this.emit(e),this.notify(e,t),this}};Li.eventAliasesOn(hs);var ps={png:function(e){return e=e||{},this._private.renderer.png(e)},jpg:function(e){var t=this._private.renderer;return(e=e||{}).bg=e.bg||"#fff",t.jpg(e)}};ps.jpeg=ps.jpg;var fs={layout:function(e){if(null!=e)if(null!=e.name){var t=e.name,n=this.extension("layout",t);if(null!=n){var r;r=f(e.eles)?this.$(e.eles):null!=e.eles?e.eles:this.$();var i=new n(I({},e,{cy:this,eles:r}));return i}Oe("No such layout `"+t+"` found. Did you forget to import it and `cytoscape.use()` it?")}else Oe("A `name` must be specified to make a layout");else Oe("Layout options must be specified to make a layout")}};fs.createLayout=fs.makeLayout=fs.layout;var gs={notify:function(e,t){var n=this._private;if(this.batching()){n.batchNotifications=n.batchNotifications||{};var r=n.batchNotifications[e]=n.batchNotifications[e]||this.collection();null!=t&&r.merge(t)}else if(n.notificationsEnabled){var i=this.renderer();!this.destroyed()&&i&&i.notify(e,t)}},notifications:function(e){var t=this._private;return void 0===e?t.notificationsEnabled:(t.notificationsEnabled=!!e,this)},noNotifications:function(e){this.notifications(!1),e(),this.notifications(!0)},batching:function(){return this._private.batchCount>0},startBatch:function(){var e=this._private;return null==e.batchCount&&(e.batchCount=0),0===e.batchCount&&(e.batchStyleEles=this.collection(),e.batchNotifications={}),e.batchCount++,this},endBatch:function(){var e=this._private;if(0===e.batchCount)return this;if(e.batchCount--,0===e.batchCount){e.batchStyleEles.updateStyle();var t=this.renderer();Object.keys(e.batchNotifications).forEach((function(n){var r=e.batchNotifications[n];r.empty()?t.notify(n):t.notify(n,r)}))}return this},batch:function(e){return this.startBatch(),e(),this.endBatch(),this},batchData:function(e){var t=this;return this.batch((function(){for(var n=Object.keys(e),r=0;r0;)e.removeChild(e.childNodes[0]);this._private.renderer=null,this.mutableElements().forEach((function(e){var t=e._private;t.rscratch={},t.rstyle={},t.animation.current=[],t.animation.queue=[]}))},onRender:function(e){return this.on("render",e)},offRender:function(e){return this.off("render",e)}};ys.invalidateDimensions=ys.resize;var ms={collection:function(e,t){return f(e)?this.$(e):x(e)?e.collection():v(e)?(t||(t={}),new Zo(this,e,t.unique,t.removed)):new Zo(this)},nodes:function(e){var t=this.$((function(e){return e.isNode()}));return e?t.filter(e):t},edges:function(e){var t=this.$((function(e){return e.isEdge()}));return e?t.filter(e):t},$:function(e){var t=this._private.elements;return e?t.filter(e):t.spawnSelf()},mutableElements:function(){return this._private.elements}};ms.elements=ms.filter=ms.$;var bs={};bs.apply=function(e){for(var t=this._private.cy.collection(),n=0;n0;if(d||c&&h){var p=void 0;d&&h||d?p=l.properties:h&&(p=l.mappedProperties);for(var f=0;f1&&(g=1),s.color){var w=i.valueMin[0],E=i.valueMax[0],k=i.valueMin[1],C=i.valueMax[1],S=i.valueMin[2],P=i.valueMax[2],D=null==i.valueMin[3]?1:i.valueMin[3],T=null==i.valueMax[3]?1:i.valueMax[3],_=[Math.round(w+(E-w)*g),Math.round(k+(C-k)*g),Math.round(S+(P-S)*g),Math.round(D+(T-D)*g)];n={bypass:i.bypass,name:i.name,value:_,strValue:"rgb("+_[0]+", "+_[1]+", "+_[2]+")"}}else{if(!s.number)return!1;var M=i.valueMin+(i.valueMax-i.valueMin)*g;n=this.parse(i.name,M,i.bypass,"mapping")}if(!n)return f(),!1;n.mapping=i,i=n;break;case o.data:for(var B=i.field.split("."),N=d.data,z=0;z0&&a>0){for(var s={},l=!1,u=0;u0?e.delayAnimation(o).play().promise().then(t):t()})).then((function(){return e.animation({style:s,duration:a,easing:e.pstyle("transition-timing-function").value,queue:!1}).play().promise()})).then((function(){n.removeBypasses(e,i),e.emitAndNotify("style"),r.transitioning=!1}))}else r.transitioning&&(this.removeBypasses(e,i),e.emitAndNotify("style"),r.transitioning=!1)},bs.checkTrigger=function(e,t,n,r,i,a){var o=this.properties[t],s=i(o);null!=s&&s(n,r)&&a(o)},bs.checkZOrderTrigger=function(e,t,n,r){var i=this;this.checkTrigger(e,t,n,r,(function(e){return e.triggersZOrder}),(function(){i._private.cy.notify("zorder",e)}))},bs.checkBoundsTrigger=function(e,t,n,r){this.checkTrigger(e,t,n,r,(function(e){return e.triggersBounds}),(function(i){e.dirtyCompoundBoundsCache(),e.dirtyBoundingBoxCache(),!i.triggersBoundsOfParallelBeziers||("curve-style"!==t||"bezier"!==n&&"bezier"!==r)&&("display"!==t||"none"!==n&&"none"!==r)||e.parallelEdges().forEach((function(e){e.isBundledBezier()&&e.dirtyBoundingBoxCache()}))}))},bs.checkTriggers=function(e,t,n,r){e.dirtyStyleCache(),this.checkZOrderTrigger(e,t,n,r),this.checkBoundsTrigger(e,t,n,r)};var xs={applyBypass:function(e,t,n,r){var i=[];if("*"===t||"**"===t){if(void 0!==n)for(var a=0;at.length?i.substr(t.length):""}function o(){n=n.length>r.length?n.substr(r.length):""}for(i=i.replace(/[/][*](\s|.)+?[*][/]/g,"");;){if(i.match(/^\s*$/))break;var s=i.match(/^\s*((?:.|\s)+?)\s*\{((?:.|\s)+?)\}/);if(!s){Ve("Halting stylesheet parsing: String stylesheet contains more to parse but no selector and block found in: "+i);break}t=s[0];var l=s[1];if("core"!==l)if(new ba(l).invalid){Ve("Skipping parsing of block: Invalid selector found in string stylesheet: "+l),a();continue}var u=s[2],c=!1;n=u;for(var d=[];;){if(n.match(/^\s*$/))break;var h=n.match(/^\s*(.+?)\s*:\s*(.+?)(?:\s*;|\s*$)/);if(!h){Ve("Skipping parsing of block: Invalid formatting of style property and value definitions found in:"+u),c=!0;break}r=h[0];var p=h[1],f=h[2];if(this.properties[p])this.parse(p,f)?(d.push({name:p,val:f}),o()):(Ve("Skipping property: Invalid property definition in: "+r),o());else Ve("Skipping property: Invalid property name in: "+r),o()}if(c){a();break}this.selector(l);for(var g=0;g=7&&"d"===t[0]&&(l=new RegExp(o.data.regex).exec(t))){if(n)return!1;var d=o.data;return{name:e,value:l,strValue:""+t,mapped:d,field:l[1],bypass:n}}if(t.length>=10&&"m"===t[0]&&(u=new RegExp(o.mapData.regex).exec(t))){if(n)return!1;if(c.multiple)return!1;var h=o.mapData;if(!c.color&&!c.number)return!1;var p=this.parse(e,u[4]);if(!p||p.mapped)return!1;var y=this.parse(e,u[5]);if(!y||y.mapped)return!1;if(p.pfValue===y.pfValue||p.strValue===y.strValue)return Ve("`"+e+": "+t+"` is not a valid mapper because the output range is zero; converting to `"+e+": "+p.strValue+"`"),this.parse(e,p.strValue);if(c.color){var b=p.value,x=y.value;if(!(b[0]!==x[0]||b[1]!==x[1]||b[2]!==x[2]||b[3]!==x[3]&&(null!=b[3]&&1!==b[3]||null!=x[3]&&1!==x[3])))return!1}return{name:e,value:u,strValue:""+t,mapped:h,field:u[1],fieldMin:parseFloat(u[2]),fieldMax:parseFloat(u[3]),valueMin:p.value,valueMax:y.value,bypass:n}}}if(c.multiple&&"multiple"!==r){var w;if(w=s?t.split(/\s+/):v(t)?t:[t],c.evenMultiple&&w.length%2!=0)return null;for(var E=[],k=[],C=[],S="",P=!1,D=0;D0?" ":"")+_.strValue}return c.validate&&!c.validate(E,k)?null:c.singleEnum&&P?1===E.length&&f(E[0])?{name:e,value:E[0],strValue:E[0],bypass:n}:null:{name:e,value:E,pfValue:C,strValue:S,bypass:n,units:k}}var M,B,z=function(){for(var r=0;rc.max||c.strictMax&&t===c.max))return null;var V={name:e,value:t,strValue:""+t+(I||""),units:I,bypass:n};return c.unitless||"px"!==I&&"em"!==I?V.pfValue=t:V.pfValue="px"!==I&&I?this.getEmSizeInPixels()*t:t,"ms"!==I&&"s"!==I||(V.pfValue="ms"===I?t:1e3*t),"deg"!==I&&"rad"!==I||(V.pfValue="rad"===I?t:(M=t,Math.PI*M/180)),"%"===I&&(V.pfValue=t/100),V}if(c.propList){var F=[],j=""+t;if("none"===j);else{for(var q=j.split(/\s*,\s*|\s+/),Y=0;Y0&&l>0&&!isNaN(n.w)&&!isNaN(n.h)&&n.w>0&&n.h>0)return{zoom:o=(o=(o=Math.min((s-2*t)/n.w,(l-2*t)/n.h))>this._private.maxZoom?this._private.maxZoom:o)=n.minZoom&&(n.maxZoom=t),this},minZoom:function(e){return void 0===e?this._private.minZoom:this.zoomRange({min:e})},maxZoom:function(e){return void 0===e?this._private.maxZoom:this.zoomRange({max:e})},getZoomedViewport:function(e){var t,n,r=this._private,i=r.pan,a=r.zoom,o=!1;if(r.zoomingEnabled||(o=!0),m(e)?n=e:y(e)&&(n=e.level,null!=e.position?t=gt(e.position,a,i):null!=e.renderedPosition&&(t=e.renderedPosition),null==t||r.panningEnabled||(o=!0)),n=(n=n>r.maxZoom?r.maxZoom:n)t.maxZoom||!t.zoomingEnabled?a=!0:(t.zoom=s,i.push("zoom"))}if(r&&(!a||!e.cancelOnFailedZoom)&&t.panningEnabled){var l=e.pan;m(l.x)&&(t.pan.x=l.x,o=!1),m(l.y)&&(t.pan.y=l.y,o=!1),o||i.push("pan")}return i.length>0&&(i.push("viewport"),this.emit(i.join(" ")),this.notify("viewport")),this},center:function(e){var t=this.getCenterPan(e);return t&&(this._private.pan=t,this.emit("pan viewport"),this.notify("viewport")),this},getCenterPan:function(e,t){if(this._private.panningEnabled){if(f(e)){var n=e;e=this.mutableElements().filter(n)}else x(e)||(e=this.mutableElements());if(0!==e.length){var r=e.boundingBox(),i=this.width(),a=this.height();return{x:(i-(t=void 0===t?this._private.zoom:t)*(r.x1+r.x2))/2,y:(a-t*(r.y1+r.y2))/2}}}},reset:function(){return this._private.panningEnabled&&this._private.zoomingEnabled?(this.viewport({pan:{x:0,y:0},zoom:1}),this):this},invalidateSize:function(){this._private.sizeCache=null},size:function(){var e,t,n=this._private,r=n.container;return n.sizeCache=n.sizeCache||(r?(e=s.getComputedStyle(r),t=function(t){return parseFloat(e.getPropertyValue(t))},{width:r.clientWidth-t("padding-left")-t("padding-right"),height:r.clientHeight-t("padding-top")-t("padding-bottom")}):{width:1,height:1})},width:function(){return this.size().width},height:function(){return this.size().height},extent:function(){var e=this._private.pan,t=this._private.zoom,n=this.renderedExtent(),r={x1:(n.x1-e.x)/t,x2:(n.x2-e.x)/t,y1:(n.y1-e.y)/t,y2:(n.y2-e.y)/t};return r.w=r.x2-r.x1,r.h=r.y2-r.y1,r},renderedExtent:function(){var e=this.width(),t=this.height();return{x1:0,y1:0,x2:e,y2:t,w:e,h:t}},multiClickDebounceTime:function(e){return e?(this._private.multiClickDebounceTime=e,this):this._private.multiClickDebounceTime}};Ms.centre=Ms.center,Ms.autolockNodes=Ms.autolock,Ms.autoungrabifyNodes=Ms.autoungrabify;var Bs={data:Li.data({field:"data",bindingEvent:"data",allowBinding:!0,allowSetting:!0,settingEvent:"data",settingTriggersEvent:!0,triggerFnName:"trigger",allowGetting:!0,updateStyle:!0}),removeData:Li.removeData({field:"data",event:"data",triggerFnName:"trigger",triggerEvent:!0,updateStyle:!0}),scratch:Li.data({field:"scratch",bindingEvent:"scratch",allowBinding:!0,allowSetting:!0,settingEvent:"scratch",settingTriggersEvent:!0,triggerFnName:"trigger",allowGetting:!0,updateStyle:!0}),removeScratch:Li.removeData({field:"scratch",event:"scratch",triggerFnName:"trigger",triggerEvent:!0,updateStyle:!0})};Bs.attr=Bs.data,Bs.removeAttr=Bs.removeData;var Ns=function(e){var t=this,n=(e=I({},e)).container;n&&!b(n)&&b(n[0])&&(n=n[0]);var r=n?n._cyreg:null;(r=r||{})&&r.cy&&(r.cy.destroy(),r={});var i=r.readies=r.readies||[];n&&(n._cyreg=r),r.cy=t;var a=void 0!==s&&void 0!==n&&!e.headless,o=e;o.layout=I({name:a?"grid":"null"},o.layout),o.renderer=I({name:a?"canvas":"null"},o.renderer);var l=function(e,t,n){return void 0!==t?t:void 0!==n?n:e},u=this._private={container:n,ready:!1,options:o,elements:new Zo(this),listeners:[],aniEles:new Zo(this),data:o.data||{},scratch:{},layout:null,renderer:null,destroyed:!1,notificationsEnabled:!0,minZoom:1e-50,maxZoom:1e50,zoomingEnabled:l(!0,o.zoomingEnabled),userZoomingEnabled:l(!0,o.userZoomingEnabled),panningEnabled:l(!0,o.panningEnabled),userPanningEnabled:l(!0,o.userPanningEnabled),boxSelectionEnabled:l(!0,o.boxSelectionEnabled),autolock:l(!1,o.autolock,o.autolockNodes),autoungrabify:l(!1,o.autoungrabify,o.autoungrabifyNodes),autounselectify:l(!1,o.autounselectify),styleEnabled:void 0===o.styleEnabled?a:o.styleEnabled,zoom:m(o.zoom)?o.zoom:1,pan:{x:y(o.pan)&&m(o.pan.x)?o.pan.x:0,y:y(o.pan)&&m(o.pan.y)?o.pan.y:0},animation:{current:[],queue:[]},hasCompoundNodes:!1,multiClickDebounceTime:l(250,o.multiClickDebounceTime)};this.createEmitter(),this.selectionType(o.selectionType),this.zoomRange({min:o.minZoom,max:o.maxZoom});u.styleEnabled&&t.setStyle([]);var c=I({},o,o.renderer);t.initRenderer(c);!function(e,t){if(e.some(P))return hr.all(e).then(t);t(e)}([o.style,o.elements],(function(e){var n=e[0],a=e[1];u.styleEnabled&&t.style().append(n),function(e,n,r){t.notifications(!1);var i=t.mutableElements();i.length>0&&i.remove(),null!=e&&(y(e)||v(e))&&t.add(e),t.one("layoutready",(function(e){t.notifications(!0),t.emit(e),t.one("load",n),t.emitAndNotify("load")})).one("layoutstop",(function(){t.one("done",r),t.emit("done")}));var a=I({},t._private.options.layout);a.eles=t.elements(),t.layout(a).run()}(a,(function(){t.startAnimationLoop(),u.ready=!0,g(o.ready)&&t.on("ready",o.ready);for(var e=0;e0,u=Dt(n.boundingBox?n.boundingBox:{x1:0,y1:0,w:r.width(),h:r.height()});if(x(n.roots))e=n.roots;else if(v(n.roots)){for(var c=[],d=0;d0;){var N=_.shift(),I=T(N,M);if(I)N.outgoers().filter((function(e){return e.isNode()&&i.has(e)})).forEach(B);else if(null===I){Ve("Detected double maximal shift for node `"+N.id()+"`. Bailing maximal adjustment due to cycle. Use `options.maximal: true` only on DAGs.");break}}}D();var A=0;if(n.avoidOverlap)for(var L=0;L0&&b[0].length<=3?l/2:0),d=2*Math.PI/b[r].length*i;return 0===r&&1===b[0].length&&(c=1),{x:G+c*Math.cos(d),y:U+c*Math.sin(d)}}return{x:G+(i+1-(a+1)/2)*o,y:(r+1)*s}})),this};var Vs={fit:!0,padding:30,boundingBox:void 0,avoidOverlap:!0,nodeDimensionsIncludeLabels:!1,spacingFactor:void 0,radius:void 0,startAngle:1.5*Math.PI,sweep:void 0,clockwise:!0,sort:void 0,animate:!1,animationDuration:500,animationEasing:void 0,animateFilter:function(e,t){return!0},ready:void 0,stop:void 0,transform:function(e,t){return t}};function Fs(e){this.options=I({},Vs,e)}Fs.prototype.run=function(){var e=this.options,t=e,n=e.cy,r=t.eles,i=void 0!==t.counterclockwise?!t.counterclockwise:t.clockwise,a=r.nodes().not(":parent");t.sort&&(a=a.sort(t.sort));for(var o,s=Dt(t.boundingBox?t.boundingBox:{x1:0,y1:0,w:n.width(),h:n.height()}),l=s.x1+s.w/2,u=s.y1+s.h/2,c=(void 0===t.sweep?2*Math.PI-2*Math.PI/a.length:t.sweep)/Math.max(1,a.length-1),d=0,h=0;h1&&t.avoidOverlap){d*=1.75;var v=Math.cos(c)-Math.cos(0),y=Math.sin(c)-Math.sin(0),b=Math.sqrt(d*d/(v*v+y*y));o=Math.max(b,o)}return r.nodes().layoutPositions(this,t,(function(e,n){var r=t.startAngle+n*c*(i?1:-1),a=o*Math.cos(r),s=o*Math.sin(r);return{x:l+a,y:u+s}})),this};var js,qs={fit:!0,padding:30,startAngle:1.5*Math.PI,sweep:void 0,clockwise:!0,equidistant:!1,minNodeSpacing:10,boundingBox:void 0,avoidOverlap:!0,nodeDimensionsIncludeLabels:!1,height:void 0,width:void 0,spacingFactor:void 0,concentric:function(e){return e.degree()},levelWidth:function(e){return e.maxDegree()/4},animate:!1,animationDuration:500,animationEasing:void 0,animateFilter:function(e,t){return!0},ready:void 0,stop:void 0,transform:function(e,t){return t}};function Ys(e){this.options=I({},qs,e)}Ys.prototype.run=function(){for(var e=this.options,t=e,n=void 0!==t.counterclockwise?!t.counterclockwise:t.clockwise,r=e.cy,i=t.eles,a=i.nodes().not(":parent"),o=Dt(t.boundingBox?t.boundingBox:{x1:0,y1:0,w:r.width(),h:r.height()}),s=o.x1+o.w/2,l=o.y1+o.h/2,u=[],c=0,d=0;d0)Math.abs(m[0].value-x.value)>=v&&(m=[],y.push(m));m.push(x)}var w=c+t.minNodeSpacing;if(!t.avoidOverlap){var E=y.length>0&&y[0].length>1,k=(Math.min(o.w,o.h)/2-w)/(y.length+E?1:0);w=Math.min(w,k)}for(var C=0,S=0;S1&&t.avoidOverlap){var _=Math.cos(T)-Math.cos(0),M=Math.sin(T)-Math.sin(0),B=Math.sqrt(w*w/(_*_+M*M));C=Math.max(B,C)}P.r=C,C+=w}if(t.equidistant){for(var N=0,z=0,I=0;I=e.numIter)&&(Qs(r,e),r.temperature=r.temperature*e.coolingFactor,!(r.temperature=e.animationThreshold&&a(),me(t)):(cl(r,e),s())}()}else{for(;u;)u=o(l),l++;cl(r,e),s()}return this},Ws.prototype.stop=function(){return this.stopped=!0,this.thread&&this.thread.stop(),this.emit("layoutstop"),this},Ws.prototype.destroy=function(){return this.thread&&this.thread.stop(),this};var Hs=function(e,t,n){for(var r=n.eles.edges(),i=n.eles.nodes(),a={isCompound:e.hasCompoundNodes(),layoutNodes:[],idToIndex:{},nodeSize:i.size(),graphSet:[],indexToGraph:[],layoutEdges:[],edgeSize:r.size(),temperature:n.initialTemp,clientWidth:e.width(),clientHeight:e.width(),boundingBox:Dt(n.boundingBox?n.boundingBox:{x1:0,y1:0,w:e.width(),h:e.height()})},o=n.eles.components(),s={},l=0;l0){a.graphSet.push(w);for(l=0;lr.count?0:r.graph},Gs=function e(t,n,r,i){var a=i.graphSet[r];if(-10)var s=(u=r.nodeOverlap*o)*i/(g=Math.sqrt(i*i+a*a)),l=u*a/g;else{var u,c=rl(e,i,a),d=rl(t,-1*i,-1*a),h=d.x-c.x,p=d.y-c.y,f=h*h+p*p,g=Math.sqrt(f);s=(u=(e.nodeRepulsion+t.nodeRepulsion)/f)*h/g,l=u*p/g}e.isLocked||(e.offsetX-=s,e.offsetY-=l),t.isLocked||(t.offsetX+=s,t.offsetY+=l)}},nl=function(e,t,n,r){if(n>0)var i=e.maxX-t.minX;else i=t.maxX-e.minX;if(r>0)var a=e.maxY-t.minY;else a=t.maxY-e.minY;return i>=0&&a>=0?Math.sqrt(i*i+a*a):0},rl=function(e,t,n){var r=e.positionX,i=e.positionY,a=e.height||1,o=e.width||1,s=n/t,l=a/o,u={};return 0===t&&0n?(u.x=r,u.y=i+a/2,u):0t&&-1*l<=s&&s<=l?(u.x=r-o/2,u.y=i-o*n/2/t,u):0=l)?(u.x=r+a*t/2/n,u.y=i+a/2,u):0>n&&(s<=-1*l||s>=l)?(u.x=r-a*t/2/n,u.y=i-a/2,u):u},il=function(e,t){for(var n=0;n1){var f=t.gravity*d/p,g=t.gravity*h/p;c.offsetX+=f,c.offsetY+=g}}}}},ol=function(e,t){var n=[],r=0,i=-1;for(n.push.apply(n,e.graphSet[0]),i+=e.graphSet[0].length;r<=i;){var a=n[r++],o=e.idToIndex[a],s=e.layoutNodes[o],l=s.children;if(0n)var i={x:n*e/r,y:n*t/r};else i={x:e,y:t};return i},ul=function e(t,n){var r=t.parentId;if(null!=r){var i=n.layoutNodes[n.idToIndex[r]],a=!1;return(null==i.maxX||t.maxX+i.padRight>i.maxX)&&(i.maxX=t.maxX+i.padRight,a=!0),(null==i.minX||t.minX-i.padLefti.maxY)&&(i.maxY=t.maxY+i.padBottom,a=!0),(null==i.minY||t.minY-i.padTopf&&(d+=p+t.componentSpacing,c=0,h=0,p=0)}}},dl={fit:!0,padding:30,boundingBox:void 0,avoidOverlap:!0,avoidOverlapPadding:10,nodeDimensionsIncludeLabels:!1,spacingFactor:void 0,condense:!1,rows:void 0,cols:void 0,position:function(e){},sort:void 0,animate:!1,animationDuration:500,animationEasing:void 0,animateFilter:function(e,t){return!0},ready:void 0,stop:void 0,transform:function(e,t){return t}};function hl(e){this.options=I({},dl,e)}hl.prototype.run=function(){var e=this.options,t=e,n=e.cy,r=t.eles,i=r.nodes().not(":parent");t.sort&&(i=i.sort(t.sort));var a=Dt(t.boundingBox?t.boundingBox:{x1:0,y1:0,w:n.width(),h:n.height()});if(0===a.h||0===a.w)r.nodes().layoutPositions(this,t,(function(e){return{x:a.x1,y:a.y1}}));else{var o=i.size(),s=Math.sqrt(o*a.h/a.w),l=Math.round(s),u=Math.round(a.w/a.h*s),c=function(e){if(null==e)return Math.min(l,u);Math.min(l,u)==l?l=e:u=e},d=function(e){if(null==e)return Math.max(l,u);Math.max(l,u)==l?l=e:u=e},h=t.rows,p=null!=t.cols?t.cols:t.columns;if(null!=h&&null!=p)l=h,u=p;else if(null!=h&&null==p)l=h,u=Math.ceil(o/l);else if(null==h&&null!=p)u=p,l=Math.ceil(o/u);else if(u*l>o){var f=c(),g=d();(f-1)*g>=o?c(f-1):(g-1)*f>=o&&d(g-1)}else for(;u*l=o?d(y+1):c(v+1)}var m=a.w/u,b=a.h/l;if(t.condense&&(m=0,b=0),t.avoidOverlap)for(var x=0;x=u&&(B=0,M++)},z={},I=0;I(r=Vt(e,t,x[w],x[w+1],x[w+2],x[w+3])))return v(n,r),!0}else if("bezier"===a.edgeType||"multibezier"===a.edgeType||"self"===a.edgeType||"compound"===a.edgeType)for(x=a.allpts,w=0;w+5(r=Rt(e,t,x[w],x[w+1],x[w+2],x[w+3],x[w+4],x[w+5])))return v(n,r),!0;m=m||i.source,b=b||i.target;var E=o.getArrowWidth(l,c),k=[{name:"source",x:a.arrowStartX,y:a.arrowStartY,angle:a.srcArrowAngle},{name:"target",x:a.arrowEndX,y:a.arrowEndY,angle:a.tgtArrowAngle},{name:"mid-source",x:a.midX,y:a.midY,angle:a.midsrcArrowAngle},{name:"mid-target",x:a.midX,y:a.midY,angle:a.midtgtArrowAngle}];for(w=0;w0&&(y(m),y(b))}function b(e,t,n){return Ke(e,t,n)}function x(n,r){var i,a=n._private,o=f;i=r?r+"-":"",n.boundingBox();var s=a.labelBounds[r||"main"],l=n.pstyle(i+"label").value;if("yes"===n.pstyle("text-events").strValue&&l){var u=b(a.rscratch,"labelX",r),c=b(a.rscratch,"labelY",r),d=b(a.rscratch,"labelAngle",r),h=n.pstyle(i+"text-margin-x").pfValue,p=n.pstyle(i+"text-margin-y").pfValue,g=s.x1-o-h,y=s.x2+o-h,m=s.y1-o-p,x=s.y2+o-p;if(d){var w=Math.cos(d),E=Math.sin(d),k=function(e,t){return{x:(e-=u)*w-(t-=c)*E+u,y:e*E+t*w+c}},C=k(g,m),S=k(g,x),P=k(y,m),D=k(y,x),T=[C.x+h,C.y+p,P.x+h,P.y+p,D.x+h,D.y+p,S.x+h,S.y+p];if(Ft(e,t,T))return v(n),!0}else if(zt(s,e,t))return v(n),!0}}n&&(l=l.interactive);for(var w=l.length-1;w>=0;w--){var E=l[w];E.isNode()?y(E)||x(E):m(E)||x(E)||x(E,"source")||x(E,"target")}return u},getAllInBox:function(e,t,n,r){for(var i,a,o=this.getCachedZSortedEles().interactive,s=[],l=Math.min(e,n),u=Math.max(e,n),c=Math.min(t,r),d=Math.max(t,r),h=Dt({x1:e=l,y1:t=c,x2:n=u,y2:r=d}),p=0;p0?Math.max(e-t,0):Math.min(e+t,0)},w=x(m,v),E=x(b,y),k=!1;"auto"===c?u=Math.abs(w)>Math.abs(E)?"horizontal":"vertical":"upward"===c||"downward"===c?(u="vertical",k=!0):"leftward"!==c&&"rightward"!==c||(u="horizontal",k=!0);var C,S="vertical"===u,P=S?E:w,D=S?b:m,T=xt(D),_=!1;(k&&(h||f)||!("downward"===c&&D<0||"upward"===c&&D>0||"leftward"===c&&D>0||"rightward"===c&&D<0)||(P=(T*=-1)*Math.abs(P),_=!0),h)?C=(p<0?1+p:p)*P:C=(p<0?P:0)+p*T;var M=function(e){return Math.abs(e)=Math.abs(P)},B=M(C),N=M(Math.abs(P)-Math.abs(C));if((B||N)&&!_)if(S){var z=Math.abs(D)<=a/2,I=Math.abs(m)<=o/2;if(z){var A=(r.x1+r.x2)/2,L=r.y1,O=r.y2;n.segpts=[A,L,A,O]}else if(I){var R=(r.y1+r.y2)/2,V=r.x1,F=r.x2;n.segpts=[V,R,F,R]}else n.segpts=[r.x1,r.y2]}else{var j=Math.abs(D)<=i/2,q=Math.abs(b)<=s/2;if(j){var Y=(r.y1+r.y2)/2,X=r.x1,W=r.x2;n.segpts=[X,Y,W,Y]}else if(q){var H=(r.x1+r.x2)/2,K=r.y1,G=r.y2;n.segpts=[H,K,H,G]}else n.segpts=[r.x2,r.y1]}else if(S){var U=r.y1+C+(l?a/2*T:0),Z=r.x1,$=r.x2;n.segpts=[Z,U,$,U]}else{var Q=r.x1+C+(l?i/2*T:0),J=r.y1,ee=r.y2;n.segpts=[Q,J,Q,ee]}},Pl.tryToCorrectInvalidPoints=function(e,t){var n=e._private.rscratch;if("bezier"===n.edgeType){var r=t.srcPos,i=t.tgtPos,a=t.srcW,o=t.srcH,s=t.tgtW,l=t.tgtH,u=t.srcShape,c=t.tgtShape,d=!m(n.startX)||!m(n.startY),h=!m(n.arrowStartX)||!m(n.arrowStartY),p=!m(n.endX)||!m(n.endY),f=!m(n.arrowEndX)||!m(n.arrowEndY),g=3*(this.getArrowWidth(e.pstyle("width").pfValue,e.pstyle("arrow-scale").value)*this.arrowShapeWidth),v=wt({x:n.ctrlpts[0],y:n.ctrlpts[1]},{x:n.startX,y:n.startY}),y=vh.poolIndex()){var p=d;d=h,h=p}var f=s.srcPos=d.position(),g=s.tgtPos=h.position(),v=s.srcW=d.outerWidth(),y=s.srcH=d.outerHeight(),b=s.tgtW=h.outerWidth(),x=s.tgtH=h.outerHeight(),w=s.srcShape=n.nodeShapes[t.getNodeShape(d)],E=s.tgtShape=n.nodeShapes[t.getNodeShape(h)];s.dirCounts={north:0,west:0,south:0,east:0,northwest:0,southwest:0,northeast:0,southeast:0};for(var k=0;k0){var q=u,Y=Et(q,yt(t)),X=Et(q,yt(j)),W=Y;if(X2)Et(q,{x:j[2],y:j[3]})0){var ie=c,ae=Et(ie,yt(t)),oe=Et(ie,yt(re)),se=ae;if(oe2)Et(ie,{x:re[2],y:re[3]})=c||b){d={cp:v,segment:m};break}}if(d)break}var x=d.cp,w=d.segment,E=(c-p)/w.length,k=w.t1-w.t0,C=u?w.t0+k*E:w.t1-k*E;C=Pt(0,C,1),t=St(x.p0,x.p1,x.p2,C),l=function(e,t,n,r){var i=Pt(0,r-.001,1),a=Pt(0,r+.001,1),o=St(e,t,n,i),s=St(e,t,n,a);return zl(o,s)}(x.p0,x.p1,x.p2,C);break;case"straight":case"segments":case"haystack":for(var S,P,D,T,_=0,M=r.allpts.length,B=0;B+3=c));B+=2);var N=(c-P)/S;N=Pt(0,N,1),t=function(e,t,n,r){var i=t.x-e.x,a=t.y-e.y,o=wt(e,t),s=i/o,l=a/o;return n=null==n?0:n,r=null!=r?r:n*o,{x:e.x+s*r,y:e.y+l*r}}(D,T,N),l=zl(D,T)}o("labelX",s,t.x),o("labelY",s,t.y),o("labelAutoAngle",s,l)}};l("source"),l("target"),this.applyLabelDimensions(e)}},Bl.applyLabelDimensions=function(e){this.applyPrefixedLabelDimensions(e),e.isEdge()&&(this.applyPrefixedLabelDimensions(e,"source"),this.applyPrefixedLabelDimensions(e,"target"))},Bl.applyPrefixedLabelDimensions=function(e,t){var n=e._private,r=this.getLabelText(e,t),i=this.calculateLabelDimensions(e,r),a=e.pstyle("line-height").pfValue,o=e.pstyle("text-wrap").strValue,s=Ke(n.rscratch,"labelWrapCachedLines",t)||[],l="wrap"!==o?1:Math.max(s.length,1),u=i.height/l,c=u*a,d=i.width,h=i.height+(l-1)*(a-1)*u;Ge(n.rstyle,"labelWidth",t,d),Ge(n.rscratch,"labelWidth",t,d),Ge(n.rstyle,"labelHeight",t,h),Ge(n.rscratch,"labelHeight",t,h),Ge(n.rscratch,"labelLineHeight",t,c)},Bl.getLabelText=function(e,t){var n=e._private,r=t?t+"-":"",i=e.pstyle(r+"label").strValue,a=e.pstyle("text-transform").value,o=function(e,r){return r?(Ge(n.rscratch,e,t,r),r):Ke(n.rscratch,e,t)};if(!i)return"";"none"==a||("uppercase"==a?i=i.toUpperCase():"lowercase"==a&&(i=i.toLowerCase()));var s=e.pstyle("text-wrap").value;if("wrap"===s){var l=o("labelKey");if(null!=l&&o("labelWrapKey")===l)return o("labelWrapCachedText");for(var u=i.split("\n"),c=e.pstyle("text-max-width").pfValue,d="anywhere"===e.pstyle("text-overflow-wrap").value,h=[],p=/[\s\u200b]+/,f=d?"":" ",g=0;gc){for(var b=v.split(p),x="",w=0;wC)break;S+=i[D],D===i.length-1&&(P=!0)}return P||(S+="…"),S}return i},Bl.getLabelJustification=function(e){var t=e.pstyle("text-justification").strValue,n=e.pstyle("text-halign").strValue;if("auto"!==t)return t;if(!e.isNode())return"center";switch(n){case"left":return"right";case"right":return"left";default:return"center"}},Bl.calculateLabelDimensions=function(e,t){var n=Pe(t,e._private.labelDimsKey),r=this.labelDimCache||(this.labelDimCache=[]),i=r[n];if(null!=i)return i;var a=e.pstyle("font-style").strValue,o=e.pstyle("font-size").pfValue,s=e.pstyle("font-family").strValue,l=e.pstyle("font-weight").strValue,u=this.labelCalcCanvas,c=this.labelCalcCanvasContext;if(!u){u=this.labelCalcCanvas=document.createElement("canvas"),c=this.labelCalcCanvasContext=u.getContext("2d");var d=u.style;d.position="absolute",d.left="-9999px",d.top="-9999px",d.zIndex="-1",d.visibility="hidden",d.pointerEvents="none"}c.font="".concat(a," ").concat(l," ").concat(o,"px ").concat(s);for(var h=0,p=0,f=t.split("\n"),g=0;g1&&void 0!==arguments[1])||arguments[1];if(t.merge(e),n)for(var r=0;r=e.desktopTapThreshold2}var D=r(t);v&&(e.hoverData.tapholdCancelled=!0);a=!0,n(g,["mousemove","vmousemove","tapdrag"],t,{x:d[0],y:d[1]});var T=function(){e.data.bgActivePosistion=void 0,e.hoverData.selecting||o.emit({originalEvent:t,type:"boxstart",position:{x:d[0],y:d[1]}}),f[4]=1,e.hoverData.selecting=!0,e.redrawHint("select",!0),e.redraw()};if(3===e.hoverData.which){if(v){var _={originalEvent:t,type:"cxtdrag",position:{x:d[0],y:d[1]}};b?b.emit(_):o.emit(_),e.hoverData.cxtDragged=!0,e.hoverData.cxtOver&&g===e.hoverData.cxtOver||(e.hoverData.cxtOver&&e.hoverData.cxtOver.emit({originalEvent:t,type:"cxtdragout",position:{x:d[0],y:d[1]}}),e.hoverData.cxtOver=g,g&&g.emit({originalEvent:t,type:"cxtdragover",position:{x:d[0],y:d[1]}}))}}else if(e.hoverData.dragging){if(a=!0,o.panningEnabled()&&o.userPanningEnabled()){var M;if(e.hoverData.justStartedPan){var B=e.hoverData.mdownPos;M={x:(d[0]-B[0])*s,y:(d[1]-B[1])*s},e.hoverData.justStartedPan=!1}else M={x:x[0]*s,y:x[1]*s};o.panBy(M),o.emit("dragpan"),e.hoverData.dragged=!0}d=e.projectIntoViewport(t.clientX,t.clientY)}else if(1!=f[4]||null!=b&&!b.pannable()){if(b&&b.pannable()&&b.active()&&b.unactivate(),b&&b.grabbed()||g==y||(y&&n(y,["mouseout","tapdragout"],t,{x:d[0],y:d[1]}),g&&n(g,["mouseover","tapdragover"],t,{x:d[0],y:d[1]}),e.hoverData.last=g),b)if(v){if(o.boxSelectionEnabled()&&D)b&&b.grabbed()&&(c(E),b.emit("freeon"),E.emit("free"),e.dragData.didDrag&&(b.emit("dragfreeon"),E.emit("dragfree"))),T();else if(b&&b.grabbed()&&e.nodeIsDraggable(b)){var N=!e.dragData.didDrag;N&&e.redrawHint("eles",!0),e.dragData.didDrag=!0,e.hoverData.draggingEles||l(E,{inDragLayer:!0});var z={x:0,y:0};if(m(x[0])&&m(x[1])&&(z.x+=x[0],z.y+=x[1],N)){var I=e.hoverData.dragDelta;I&&m(I[0])&&m(I[1])&&(z.x+=I[0],z.y+=I[1])}e.hoverData.draggingEles=!0,E.silentShift(z).emit("position drag"),e.redrawHint("drag",!0),e.redraw()}}else!function(){var t=e.hoverData.dragDelta=e.hoverData.dragDelta||[];0===t.length?(t.push(x[0]),t.push(x[1])):(t[0]+=x[0],t[1]+=x[1])}();a=!0}else if(v){if(e.hoverData.dragging||!o.boxSelectionEnabled()||!D&&o.panningEnabled()&&o.userPanningEnabled()){if(!e.hoverData.selecting&&o.panningEnabled()&&o.userPanningEnabled()){i(b,e.hoverData.downs)&&(e.hoverData.dragging=!0,e.hoverData.justStartedPan=!0,f[4]=0,e.data.bgActivePosistion=yt(h),e.redrawHint("select",!0),e.redraw())}}else T();b&&b.pannable()&&b.active()&&b.unactivate()}return f[2]=d[0],f[3]=d[1],a?(t.stopPropagation&&t.stopPropagation(),t.preventDefault&&t.preventDefault(),!1):void 0}}),!1),e.registerBinding(window,"mouseup",(function(i){if(e.hoverData.capture){e.hoverData.capture=!1;var a=e.cy,o=e.projectIntoViewport(i.clientX,i.clientY),s=e.selection,l=e.findNearestElement(o[0],o[1],!0,!1),u=e.dragData.possibleDragElements,d=e.hoverData.down,h=r(i);if(e.data.bgActivePosistion&&(e.redrawHint("select",!0),e.redraw()),e.hoverData.tapholdCancelled=!0,e.data.bgActivePosistion=void 0,d&&d.unactivate(),3===e.hoverData.which){var p={originalEvent:i,type:"cxttapend",position:{x:o[0],y:o[1]}};if(d?d.emit(p):a.emit(p),!e.hoverData.cxtDragged){var f={originalEvent:i,type:"cxttap",position:{x:o[0],y:o[1]}};d?d.emit(f):a.emit(f)}e.hoverData.cxtDragged=!1,e.hoverData.which=null}else if(1===e.hoverData.which){if(n(l,["mouseup","tapend","vmouseup"],i,{x:o[0],y:o[1]}),e.dragData.didDrag||e.hoverData.dragged||e.hoverData.selecting||e.hoverData.isOverThresholdDrag||(n(d,["click","tap","vclick"],i,{x:o[0],y:o[1]}),b=!1,i.timeStamp-x<=a.multiClickDebounceTime()?(y&&clearTimeout(y),b=!0,x=null,n(d,["dblclick","dbltap","vdblclick"],i,{x:o[0],y:o[1]})):(y=setTimeout((function(){b||n(d,["oneclick","onetap","voneclick"],i,{x:o[0],y:o[1]})}),a.multiClickDebounceTime()),x=i.timeStamp)),null!=d||e.dragData.didDrag||e.hoverData.selecting||e.hoverData.dragged||r(i)||(a.$(t).unselect(["tapunselect"]),u.length>0&&e.redrawHint("eles",!0),e.dragData.possibleDragElements=u=a.collection()),l!=d||e.dragData.didDrag||e.hoverData.selecting||null!=l&&l._private.selectable&&(e.hoverData.dragging||("additive"===a.selectionType()||h?l.selected()?l.unselect(["tapunselect"]):l.select(["tapselect"]):h||(a.$(t).unmerge(l).unselect(["tapunselect"]),l.select(["tapselect"]))),e.redrawHint("eles",!0)),e.hoverData.selecting){var g=a.collection(e.getAllInBox(s[0],s[1],s[2],s[3]));e.redrawHint("select",!0),g.length>0&&e.redrawHint("eles",!0),a.emit({type:"boxend",originalEvent:i,position:{x:o[0],y:o[1]}});var v=function(e){return e.selectable()&&!e.selected()};"additive"===a.selectionType()||h||a.$(t).unmerge(g).unselect(),g.emit("box").stdFilter(v).select().emit("boxselect"),e.redraw()}if(e.hoverData.dragging&&(e.hoverData.dragging=!1,e.redrawHint("select",!0),e.redrawHint("eles",!0),e.redraw()),!s[4]){e.redrawHint("drag",!0),e.redrawHint("eles",!0);var m=d&&d.grabbed();c(u),m&&(d.emit("freeon"),u.emit("free"),e.dragData.didDrag&&(d.emit("dragfreeon"),u.emit("dragfree")))}}s[4]=0,e.hoverData.down=null,e.hoverData.cxtStarted=!1,e.hoverData.draggingEles=!1,e.hoverData.selecting=!1,e.hoverData.isOverThresholdDrag=!1,e.dragData.didDrag=!1,e.hoverData.dragged=!1,e.hoverData.dragDelta=[],e.hoverData.mdownPos=null,e.hoverData.mdownGPos=null}}),!1);var E,k,C,S,P,D,T,_,M,B,N,z,I,A=function(t){if(!e.scrollingPage){var n=e.cy,r=n.zoom(),i=n.pan(),a=e.projectIntoViewport(t.clientX,t.clientY),o=[a[0]*r+i.x,a[1]*r+i.y];if(e.hoverData.draggingEles||e.hoverData.dragging||e.hoverData.cxtStarted||0!==e.selection[4])t.preventDefault();else if(n.panningEnabled()&&n.userPanningEnabled()&&n.zoomingEnabled()&&n.userZoomingEnabled()){var s;t.preventDefault(),e.data.wheelZooming=!0,clearTimeout(e.data.wheelTimeout),e.data.wheelTimeout=setTimeout((function(){e.data.wheelZooming=!1,e.redrawHint("eles",!0),e.redraw()}),150),s=null!=t.deltaY?t.deltaY/-250:null!=t.wheelDeltaY?t.wheelDeltaY/1e3:t.wheelDelta/1e3,s*=e.wheelSensitivity,1===t.deltaMode&&(s*=33);var l=n.zoom()*Math.pow(10,s);"gesturechange"===t.type&&(l=e.gestureStartZoom*t.scale),n.zoom({level:l,renderedPosition:{x:o[0],y:o[1]}}),n.emit("gesturechange"===t.type?"pinchzoom":"scrollzoom")}}};e.registerBinding(e.container,"wheel",A,!0),e.registerBinding(window,"scroll",(function(t){e.scrollingPage=!0,clearTimeout(e.scrollingPageTimeout),e.scrollingPageTimeout=setTimeout((function(){e.scrollingPage=!1}),250)}),!0),e.registerBinding(e.container,"gesturestart",(function(t){e.gestureStartZoom=e.cy.zoom(),e.hasTouchStarted||t.preventDefault()}),!0),e.registerBinding(e.container,"gesturechange",(function(t){e.hasTouchStarted||A(t)}),!0),e.registerBinding(e.container,"mouseout",(function(t){var n=e.projectIntoViewport(t.clientX,t.clientY);e.cy.emit({originalEvent:t,type:"mouseout",position:{x:n[0],y:n[1]}})}),!1),e.registerBinding(e.container,"mouseover",(function(t){var n=e.projectIntoViewport(t.clientX,t.clientY);e.cy.emit({originalEvent:t,type:"mouseover",position:{x:n[0],y:n[1]}})}),!1);var L,O,R,V,F,j,q,Y=function(e,t,n,r){return Math.sqrt((n-e)*(n-e)+(r-t)*(r-t))},X=function(e,t,n,r){return(n-e)*(n-e)+(r-t)*(r-t)};if(e.registerBinding(e.container,"touchstart",L=function(t){if(e.hasTouchStarted=!0,w(t)){h(),e.touchData.capture=!0,e.data.bgActivePosistion=void 0;var r=e.cy,i=e.touchData.now,a=e.touchData.earlier;if(t.touches[0]){var s=e.projectIntoViewport(t.touches[0].clientX,t.touches[0].clientY);i[0]=s[0],i[1]=s[1]}if(t.touches[1]){s=e.projectIntoViewport(t.touches[1].clientX,t.touches[1].clientY);i[2]=s[0],i[3]=s[1]}if(t.touches[2]){s=e.projectIntoViewport(t.touches[2].clientX,t.touches[2].clientY);i[4]=s[0],i[5]=s[1]}if(t.touches[1]){e.touchData.singleTouchMoved=!0,c(e.dragData.touchDragEles);var d=e.findContainerClientCoords();M=d[0],B=d[1],N=d[2],z=d[3],E=t.touches[0].clientX-M,k=t.touches[0].clientY-B,C=t.touches[1].clientX-M,S=t.touches[1].clientY-B,I=0<=E&&E<=N&&0<=C&&C<=N&&0<=k&&k<=z&&0<=S&&S<=z;var p=r.pan(),f=r.zoom();P=Y(E,k,C,S),D=X(E,k,C,S),_=[((T=[(E+C)/2,(k+S)/2])[0]-p.x)/f,(T[1]-p.y)/f];if(D<4e4&&!t.touches[2]){var g=e.findNearestElement(i[0],i[1],!0,!0),v=e.findNearestElement(i[2],i[3],!0,!0);return g&&g.isNode()?(g.activate().emit({originalEvent:t,type:"cxttapstart",position:{x:i[0],y:i[1]}}),e.touchData.start=g):v&&v.isNode()?(v.activate().emit({originalEvent:t,type:"cxttapstart",position:{x:i[0],y:i[1]}}),e.touchData.start=v):r.emit({originalEvent:t,type:"cxttapstart",position:{x:i[0],y:i[1]}}),e.touchData.start&&(e.touchData.start._private.grabbed=!1),e.touchData.cxt=!0,e.touchData.cxtDragged=!1,e.data.bgActivePosistion=void 0,void e.redraw()}}if(t.touches[2])r.boxSelectionEnabled()&&t.preventDefault();else if(t.touches[1]);else if(t.touches[0]){var y=e.findNearestElements(i[0],i[1],!0,!0),m=y[0];if(null!=m&&(m.activate(),e.touchData.start=m,e.touchData.starts=y,e.nodeIsGrabbable(m))){var b=e.dragData.touchDragEles=r.collection(),x=null;e.redrawHint("eles",!0),e.redrawHint("drag",!0),m.selected()?(x=r.$((function(t){return t.selected()&&e.nodeIsGrabbable(t)})),l(x,{addToList:b})):u(m,{addToList:b}),o(m);var A=function(e){return{originalEvent:t,type:e,position:{x:i[0],y:i[1]}}};m.emit(A("grabon")),x?x.forEach((function(e){e.emit(A("grab"))})):m.emit(A("grab"))}n(m,["touchstart","tapstart","vmousedown"],t,{x:i[0],y:i[1]}),null==m&&(e.data.bgActivePosistion={x:s[0],y:s[1]},e.redrawHint("select",!0),e.redraw()),e.touchData.singleTouchMoved=!1,e.touchData.singleTouchStartTime=+new Date,clearTimeout(e.touchData.tapholdTimeout),e.touchData.tapholdTimeout=setTimeout((function(){!1!==e.touchData.singleTouchMoved||e.pinching||e.touchData.selecting||n(e.touchData.start,["taphold"],t,{x:i[0],y:i[1]})}),e.tapholdDuration)}if(t.touches.length>=1){for(var L=e.touchData.startPosition=[],O=0;O=e.touchTapThreshold2}if(r&&e.touchData.cxt){t.preventDefault();var T=t.touches[0].clientX-M,N=t.touches[0].clientY-B,z=t.touches[1].clientX-M,A=t.touches[1].clientY-B,L=X(T,N,z,A);if(L/D>=2.25||L>=22500){e.touchData.cxt=!1,e.data.bgActivePosistion=void 0,e.redrawHint("select",!0);var O={originalEvent:t,type:"cxttapend",position:{x:s[0],y:s[1]}};e.touchData.start?(e.touchData.start.unactivate().emit(O),e.touchData.start=null):o.emit(O)}}if(r&&e.touchData.cxt){O={originalEvent:t,type:"cxtdrag",position:{x:s[0],y:s[1]}};e.data.bgActivePosistion=void 0,e.redrawHint("select",!0),e.touchData.start?e.touchData.start.emit(O):o.emit(O),e.touchData.start&&(e.touchData.start._private.grabbed=!1),e.touchData.cxtDragged=!0;var R=e.findNearestElement(s[0],s[1],!0,!0);e.touchData.cxtOver&&R===e.touchData.cxtOver||(e.touchData.cxtOver&&e.touchData.cxtOver.emit({originalEvent:t,type:"cxtdragout",position:{x:s[0],y:s[1]}}),e.touchData.cxtOver=R,R&&R.emit({originalEvent:t,type:"cxtdragover",position:{x:s[0],y:s[1]}}))}else if(r&&t.touches[2]&&o.boxSelectionEnabled())t.preventDefault(),e.data.bgActivePosistion=void 0,this.lastThreeTouch=+new Date,e.touchData.selecting||o.emit({originalEvent:t,type:"boxstart",position:{x:s[0],y:s[1]}}),e.touchData.selecting=!0,e.touchData.didSelect=!0,a[4]=1,a&&0!==a.length&&void 0!==a[0]?(a[2]=(s[0]+s[2]+s[4])/3,a[3]=(s[1]+s[3]+s[5])/3):(a[0]=(s[0]+s[2]+s[4])/3,a[1]=(s[1]+s[3]+s[5])/3,a[2]=(s[0]+s[2]+s[4])/3+1,a[3]=(s[1]+s[3]+s[5])/3+1),e.redrawHint("select",!0),e.redraw();else if(r&&t.touches[1]&&!e.touchData.didSelect&&o.zoomingEnabled()&&o.panningEnabled()&&o.userZoomingEnabled()&&o.userPanningEnabled()){if(t.preventDefault(),e.data.bgActivePosistion=void 0,e.redrawHint("select",!0),ee=e.dragData.touchDragEles){e.redrawHint("drag",!0);for(var V=0;V0&&!e.hoverData.draggingEles&&!e.swipePanning&&null!=e.data.bgActivePosistion&&(e.data.bgActivePosistion=void 0,e.redrawHint("select",!0),e.redraw())}},!1),e.registerBinding(window,"touchcancel",R=function(t){var n=e.touchData.start;e.touchData.capture=!1,n&&n.unactivate()}),e.registerBinding(window,"touchend",V=function(r){var i=e.touchData.start;if(e.touchData.capture){0===r.touches.length&&(e.touchData.capture=!1),r.preventDefault();var a=e.selection;e.swipePanning=!1,e.hoverData.draggingEles=!1;var o,s=e.cy,l=s.zoom(),u=e.touchData.now,d=e.touchData.earlier;if(r.touches[0]){var h=e.projectIntoViewport(r.touches[0].clientX,r.touches[0].clientY);u[0]=h[0],u[1]=h[1]}if(r.touches[1]){h=e.projectIntoViewport(r.touches[1].clientX,r.touches[1].clientY);u[2]=h[0],u[3]=h[1]}if(r.touches[2]){h=e.projectIntoViewport(r.touches[2].clientX,r.touches[2].clientY);u[4]=h[0],u[5]=h[1]}if(i&&i.unactivate(),e.touchData.cxt){if(o={originalEvent:r,type:"cxttapend",position:{x:u[0],y:u[1]}},i?i.emit(o):s.emit(o),!e.touchData.cxtDragged){var p={originalEvent:r,type:"cxttap",position:{x:u[0],y:u[1]}};i?i.emit(p):s.emit(p)}return e.touchData.start&&(e.touchData.start._private.grabbed=!1),e.touchData.cxt=!1,e.touchData.start=null,void e.redraw()}if(!r.touches[2]&&s.boxSelectionEnabled()&&e.touchData.selecting){e.touchData.selecting=!1;var f=s.collection(e.getAllInBox(a[0],a[1],a[2],a[3]));a[0]=void 0,a[1]=void 0,a[2]=void 0,a[3]=void 0,a[4]=0,e.redrawHint("select",!0),s.emit({type:"boxend",originalEvent:r,position:{x:u[0],y:u[1]}});f.emit("box").stdFilter((function(e){return e.selectable()&&!e.selected()})).select().emit("boxselect"),f.nonempty()&&e.redrawHint("eles",!0),e.redraw()}if(null!=i&&i.unactivate(),r.touches[2])e.data.bgActivePosistion=void 0,e.redrawHint("select",!0);else if(r.touches[1]);else if(r.touches[0]);else if(!r.touches[0]){e.data.bgActivePosistion=void 0,e.redrawHint("select",!0);var g=e.dragData.touchDragEles;if(null!=i){var v=i._private.grabbed;c(g),e.redrawHint("drag",!0),e.redrawHint("eles",!0),v&&(i.emit("freeon"),g.emit("free"),e.dragData.didDrag&&(i.emit("dragfreeon"),g.emit("dragfree"))),n(i,["touchend","tapend","vmouseup","tapdragout"],r,{x:u[0],y:u[1]}),i.unactivate(),e.touchData.start=null}else{var y=e.findNearestElement(u[0],u[1],!0,!0);n(y,["touchend","tapend","vmouseup","tapdragout"],r,{x:u[0],y:u[1]})}var m=e.touchData.startPosition[0]-u[0],b=m*m,x=e.touchData.startPosition[1]-u[1],w=(b+x*x)*l*l;e.touchData.singleTouchMoved||(i||s.$(":selected").unselect(["tapunselect"]),n(i,["tap","vclick"],r,{x:u[0],y:u[1]}),F=!1,r.timeStamp-q<=s.multiClickDebounceTime()?(j&&clearTimeout(j),F=!0,q=null,n(i,["dbltap","vdblclick"],r,{x:u[0],y:u[1]})):(j=setTimeout((function(){F||n(i,["onetap","voneclick"],r,{x:u[0],y:u[1]})}),s.multiClickDebounceTime()),q=r.timeStamp)),null!=i&&!e.dragData.didDrag&&i._private.selectable&&w2){for(var T=[u[0],u[1]],_=Math.pow(T[0]-e,2)+Math.pow(T[1]-t,2),M=1;M0)return g[0]}return null},h=Object.keys(c),p=0;p0?l:At(i,a,e,t,n,r,o)},checkPoint:function(e,t,n,r,i,a,o){var s=Jt(r,i),l=2*s;if(jt(e,t,this.points,a,o,r,i-l,[0,-1],n))return!0;if(jt(e,t,this.points,a,o,r-l,i,[0,-1],n))return!0;var u=r/2+2*n,c=i/2+2*n;return!!Ft(e,t,[a-u,o-c,a-u,o,a+u,o,a+u,o-c])||(!!Xt(e,t,l,l,a+r/2-s,o+i/2-s,n)||!!Xt(e,t,l,l,a-r/2+s,o+i/2-s,n))}}},jl.registerNodeShapes=function(){var e=this.nodeShapes={},t=this;this.generateEllipse(),this.generatePolygon("triangle",Zt(3,0)),this.generateRoundPolygon("round-triangle",Zt(3,0)),this.generatePolygon("rectangle",Zt(4,0)),e.square=e.rectangle,this.generateRoundRectangle(),this.generateCutRectangle(),this.generateBarrel(),this.generateBottomRoundrectangle();var n=[0,1,1,0,0,-1,-1,0];this.generatePolygon("diamond",n),this.generateRoundPolygon("round-diamond",n),this.generatePolygon("pentagon",Zt(5,0)),this.generateRoundPolygon("round-pentagon",Zt(5,0)),this.generatePolygon("hexagon",Zt(6,0)),this.generateRoundPolygon("round-hexagon",Zt(6,0)),this.generatePolygon("heptagon",Zt(7,0)),this.generateRoundPolygon("round-heptagon",Zt(7,0)),this.generatePolygon("octagon",Zt(8,0)),this.generateRoundPolygon("round-octagon",Zt(8,0));var r=new Array(20),i=Qt(5,0),a=Qt(5,Math.PI/5),o=.5*(3-Math.sqrt(5));o*=1.57;for(var s=0;s=e.deqFastCost*g)break}else if(i){if(p>=e.deqCost*l||p>=e.deqAvgCost*s)break}else if(f>=e.deqNoDrawCost*(1e3/60))break;var v=e.deq(t,d,c);if(!(v.length>0))break;for(var y=0;y0&&(e.onDeqd(t,u),!i&&e.shouldRedraw(t,u,d,c)&&r())}),i(t))}}},Kl=function(){function e(n){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:Ie;t(this,e),this.idsByKey=new Ue,this.keyForId=new Ue,this.cachesByLvl=new Ue,this.lvls=[],this.getKey=n,this.doesEleInvalidateKey=r}return r(e,[{key:"getIdsFor",value:function(e){null==e&&Oe("Can not get id list for null key");var t=this.idsByKey,n=this.idsByKey.get(e);return n||(n=new $e,t.set(e,n)),n}},{key:"addIdForKey",value:function(e,t){null!=e&&this.getIdsFor(e).add(t)}},{key:"deleteIdForKey",value:function(e,t){null!=e&&this.getIdsFor(e).delete(t)}},{key:"getNumberOfIdsForKey",value:function(e){return null==e?0:this.getIdsFor(e).size}},{key:"updateKeyMappingFor",value:function(e){var t=e.id(),n=this.keyForId.get(t),r=this.getKey(e);this.deleteIdForKey(n,t),this.addIdForKey(r,t),this.keyForId.set(t,r)}},{key:"deleteKeyMappingFor",value:function(e){var t=e.id(),n=this.keyForId.get(t);this.deleteIdForKey(n,t),this.keyForId.delete(t)}},{key:"keyHasChangedFor",value:function(e){var t=e.id();return this.keyForId.get(t)!==this.getKey(e)}},{key:"isInvalid",value:function(e){return this.keyHasChangedFor(e)||this.doesEleInvalidateKey(e)}},{key:"getCachesAt",value:function(e){var t=this.cachesByLvl,n=this.lvls,r=t.get(e);return r||(r=new Ue,t.set(e,r),n.push(e)),r}},{key:"getCache",value:function(e,t){return this.getCachesAt(t).get(e)}},{key:"get",value:function(e,t){var n=this.getKey(e),r=this.getCache(n,t);return null!=r&&this.updateKeyMappingFor(e),r}},{key:"getForCachedKey",value:function(e,t){var n=this.keyForId.get(e.id());return this.getCache(n,t)}},{key:"hasCache",value:function(e,t){return this.getCachesAt(t).has(e)}},{key:"has",value:function(e,t){var n=this.getKey(e);return this.hasCache(n,t)}},{key:"setCache",value:function(e,t,n){n.key=e,this.getCachesAt(t).set(e,n)}},{key:"set",value:function(e,t,n){var r=this.getKey(e);this.setCache(r,t,n),this.updateKeyMappingFor(e)}},{key:"deleteCache",value:function(e,t){this.getCachesAt(t).delete(e)}},{key:"delete",value:function(e,t){var n=this.getKey(e);this.deleteCache(n,t)}},{key:"invalidateKey",value:function(e){var t=this;this.lvls.forEach((function(n){return t.deleteCache(e,n)}))}},{key:"invalidate",value:function(e){var t=e.id(),n=this.keyForId.get(t);this.deleteKeyMappingFor(e);var r=this.doesEleInvalidateKey(e);return r&&this.invalidateKey(n),r||0===this.getNumberOfIdsForKey(n)}}]),e}(),Gl={dequeue:"dequeue",downscale:"downscale",highQuality:"highQuality"},Ul=Xe({getKey:null,doesEleInvalidateKey:Ie,drawElement:null,getBoundingBox:null,getRotationPoint:null,getRotationOffset:null,isVisible:ze,allowEdgeTxrCaching:!0,allowParentTxrCaching:!0}),Zl=function(e,t){this.renderer=e,this.onDequeues=[];var n=Ul(t);I(this,n),this.lookup=new Kl(n.getKey,n.doesEleInvalidateKey),this.setupDequeueing()},$l=Zl.prototype;$l.reasons=Gl,$l.getTextureQueue=function(e){return this.eleImgCaches=this.eleImgCaches||{},this.eleImgCaches[e]=this.eleImgCaches[e]||[]},$l.getRetiredTextureQueue=function(e){var t=this.eleImgCaches.retired=this.eleImgCaches.retired||{};return t[e]=t[e]||[]},$l.getElementQueue=function(){return this.eleCacheQueue=this.eleCacheQueue||new tt((function(e,t){return t.reqs-e.reqs}))},$l.getElementKeyToQueue=function(){return this.eleKeyToCacheQueue=this.eleKeyToCacheQueue||{}},$l.getElement=function(e,t,n,r,i){var a=this,o=this.renderer,s=o.cy.zoom(),l=this.lookup;if(!t||0===t.w||0===t.h||isNaN(t.w)||isNaN(t.h)||!e.visible()||e.removed())return null;if(!a.allowEdgeTxrCaching&&e.isEdge()||!a.allowParentTxrCaching&&e.isParent())return null;if(null==r&&(r=Math.ceil(bt(s*n))),r<-4)r=-4;else if(s>=7.99||r>3)return null;var u=Math.pow(2,r),c=t.h*u,d=t.w*u,h=o.eleTextBiggerThanMin(e,u);if(!this.isVisible(e,h))return null;var p,f=l.get(e,r);if(f&&f.invalidated&&(f.invalidated=!1,f.texture.invalidatedWidth-=f.width),f)return f;if(p=c<=25?25:c<=50?50:50*Math.ceil(c/50),c>1024||d>1024)return null;var g=a.getTextureQueue(p),v=g[g.length-2],y=function(){return a.recycleTexture(p,d)||a.addTexture(p,d)};v||(v=g[g.length-1]),v||(v=y()),v.width-v.usedWidthr;D--)S=a.getElement(e,t,n,D,Gl.downscale);P()}else{var T;if(!x&&!w&&!E)for(var _=r-1;_>=-4;_--){var M=l.get(e,_);if(M){T=M;break}}if(b(T))return a.queueElement(e,r),T;v.context.translate(v.usedWidth,0),v.context.scale(u,u),this.drawElement(v.context,e,t,h,!1),v.context.scale(1/u,1/u),v.context.translate(-v.usedWidth,0)}return f={x:v.usedWidth,texture:v,level:r,scale:u,width:d,height:c,scaledLabelShown:h},v.usedWidth+=Math.ceil(d+8),v.eleCaches.push(f),l.set(e,r,f),a.checkTextureFullness(v),f},$l.invalidateElements=function(e){for(var t=0;t=.2*e.width&&this.retireTexture(e)},$l.checkTextureFullness=function(e){var t=this.getTextureQueue(e.height);e.usedWidth/e.width>.8&&e.fullnessChecks>=10?We(t,e):e.fullnessChecks++},$l.retireTexture=function(e){var t=e.height,n=this.getTextureQueue(t),r=this.lookup;We(n,e),e.retired=!0;for(var i=e.eleCaches,a=0;a=t)return a.retired=!1,a.usedWidth=0,a.invalidatedWidth=0,a.fullnessChecks=0,He(a.eleCaches),a.context.setTransform(1,0,0,1,0,0),a.context.clearRect(0,0,a.width,a.height),We(r,a),n.push(a),a}},$l.queueElement=function(e,t){var n=this.getElementQueue(),r=this.getElementKeyToQueue(),i=this.getKey(e),a=r[i];if(a)a.level=Math.max(a.level,t),a.eles.merge(e),a.reqs++,n.updateItem(a);else{var o={eles:e.spawn().merge(e),level:t,reqs:1,key:i};n.push(o),r[i]=o}},$l.dequeue=function(e){for(var t=this.getElementQueue(),n=this.getElementKeyToQueue(),r=[],i=this.lookup,a=0;a<1&&t.size()>0;a++){var o=t.pop(),s=o.key,l=o.eles[0],u=i.hasCache(l,o.level);if(n[s]=null,!u){r.push(o);var c=this.getBoundingBox(l);this.getElement(l,c,e,o.level,Gl.dequeue)}}return r},$l.removeFromQueue=function(e){var t=this.getElementQueue(),n=this.getElementKeyToQueue(),r=this.getKey(e),i=n[r];null!=i&&(1===i.eles.length?(i.reqs=Ne,t.updateItem(i),t.pop(),n[r]=null):i.eles.unmerge(e))},$l.onDequeue=function(e){this.onDequeues.push(e)},$l.offDequeue=function(e){We(this.onDequeues,e)},$l.setupDequeueing=Hl({deqRedrawThreshold:100,deqCost:.15,deqAvgCost:.1,deqNoDrawCost:.9,deqFastCost:.9,deq:function(e,t,n){return e.dequeue(t,n)},onDeqd:function(e,t){for(var n=0;n=3.99||n>2)return null;r.validateLayersElesOrdering(n,e);var o,s,l=r.layersByLevel,u=Math.pow(2,n),c=l[n]=l[n]||[];if(r.levelIsComplete(n,e))return c;!function(){var t=function(t){if(r.validateLayersElesOrdering(t,e),r.levelIsComplete(t,e))return s=l[t],!0},i=function(e){if(!s)for(var r=n+e;-4<=r&&r<=2&&!t(r);r+=e);};i(1),i(-1);for(var a=c.length-1;a>=0;a--){var o=c[a];o.invalid&&We(c,o)}}();var d=function(t){var i=(t=t||{}).after;if(function(){if(!o){o=Dt();for(var t=0;t16e6)return null;var a=r.makeLayer(o,n);if(null!=i){var s=c.indexOf(i)+1;c.splice(s,0,a)}else(void 0===t.insert||t.insert)&&c.unshift(a);return a};if(r.skipping&&!a)return null;for(var h=null,p=e.length/1,f=!a,g=0;g=p||!It(h.bb,v.boundingBox()))&&!(h=d({insert:!0,after:h})))return null;s||f?r.queueLayer(h,v):r.drawEleInLayer(h,v,n,t),h.eles.push(v),m[n]=h}}return s||(f?null:c)},Jl.getEleLevelForLayerLevel=function(e,t){return e},Jl.drawEleInLayer=function(e,t,n,r){var i=this.renderer,a=e.context,o=t.boundingBox();0!==o.w&&0!==o.h&&t.visible()&&(n=this.getEleLevelForLayerLevel(n,r),i.setImgSmoothing(a,!1),i.drawCachedElement(a,t,null,null,n,!0),i.setImgSmoothing(a,!0))},Jl.levelIsComplete=function(e,t){var n=this.layersByLevel[e];if(!n||0===n.length)return!1;for(var r=0,i=0;i0)return!1;if(a.invalid)return!1;r+=a.eles.length}return r===t.length},Jl.validateLayersElesOrdering=function(e,t){var n=this.layersByLevel[e];if(n)for(var r=0;r0){e=!0;break}}return e},Jl.invalidateElements=function(e){var t=this;0!==e.length&&(t.lastInvalidationTime=be(),0!==e.length&&t.haveLayers()&&t.updateElementsInLayers(e,(function(e,n,r){t.invalidateLayer(e)})))},Jl.invalidateLayer=function(e){if(this.lastInvalidationTime=be(),!e.invalid){var t=e.level,n=e.eles,r=this.layersByLevel[t];We(r,e),e.elesQueue=[],e.invalid=!0,e.replacement&&(e.replacement.invalid=!0);for(var i=0;i3&&void 0!==arguments[3])||arguments[3],i=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],a=!(arguments.length>5&&void 0!==arguments[5])||arguments[5],o=this,s=t._private.rscratch;if((!a||t.visible())&&!s.badLine&&null!=s.allpts&&!isNaN(s.allpts[0])){var l;n&&(l=n,e.translate(-l.x1,-l.y1));var u=a?t.pstyle("opacity").value:1,c=a?t.pstyle("line-opacity").value:1,d=t.pstyle("curve-style").value,h=t.pstyle("line-style").value,p=t.pstyle("width").pfValue,f=t.pstyle("line-cap").value,g=u*c,v=u*c,y=function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:g;"straight-triangle"===d?(o.eleStrokeStyle(e,t,n),o.drawEdgeTrianglePath(t,e,s.allpts)):(e.lineWidth=p,e.lineCap=f,o.eleStrokeStyle(e,t,n),o.drawEdgePath(t,e,s.allpts,h),e.lineCap="butt")},m=function(){i&&o.drawEdgeOverlay(e,t)},b=function(){i&&o.drawEdgeUnderlay(e,t)},x=function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:v;o.drawArrowheads(e,t,n)},w=function(){o.drawElementText(e,t,null,r)};e.lineJoin="round";var E="yes"===t.pstyle("ghost").value;if(E){var k=t.pstyle("ghost-offset-x").pfValue,C=t.pstyle("ghost-offset-y").pfValue,S=t.pstyle("ghost-opacity").value,P=g*S;e.translate(k,C),y(P),x(P),e.translate(-k,-C)}b(),y(),x(),m(),w(),n&&e.translate(l.x1,l.y1)}}},yu=function(e){if(!["overlay","underlay"].includes(e))throw new Error("Invalid state");return function(t,n){if(n.visible()){var r=n.pstyle("".concat(e,"-opacity")).value;if(0!==r){var i=this,a=i.usePaths(),o=n._private.rscratch,s=2*n.pstyle("".concat(e,"-padding")).pfValue,l=n.pstyle("".concat(e,"-color")).value;t.lineWidth=s,"self"!==o.edgeType||a?t.lineCap="round":t.lineCap="butt",i.colorStrokeStyle(t,l[0],l[1],l[2],r),i.drawEdgePath(n,t,o.allpts,"solid")}}}};vu.drawEdgeOverlay=yu("overlay"),vu.drawEdgeUnderlay=yu("underlay"),vu.drawEdgePath=function(e,t,n,r){var i,a=e._private.rscratch,o=t,s=!1,l=this.usePaths(),u=e.pstyle("line-dash-pattern").pfValue,c=e.pstyle("line-dash-offset").pfValue;if(l){var d=n.join("$");a.pathCacheKey&&a.pathCacheKey===d?(i=t=a.pathCache,s=!0):(i=t=new Path2D,a.pathCacheKey=d,a.pathCache=i)}if(o.setLineDash)switch(r){case"dotted":o.setLineDash([1,1]);break;case"dashed":o.setLineDash(u),o.lineDashOffset=c;break;case"solid":o.setLineDash([])}if(!s&&!a.badLine)switch(t.beginPath&&t.beginPath(),t.moveTo(n[0],n[1]),a.edgeType){case"bezier":case"self":case"compound":case"multibezier":for(var h=2;h+35&&void 0!==arguments[5]?arguments[5]:5;e.beginPath(),e.moveTo(t+a,n),e.lineTo(t+r-a,n),e.quadraticCurveTo(t+r,n,t+r,n+a),e.lineTo(t+r,n+i-a),e.quadraticCurveTo(t+r,n+i,t+r-a,n+i),e.lineTo(t+a,n+i),e.quadraticCurveTo(t,n+i,t,n+i-a),e.lineTo(t,n+a),e.quadraticCurveTo(t,n,t+a,n),e.closePath(),e.fill()}bu.eleTextBiggerThanMin=function(e,t){if(!t){var n=e.cy().zoom(),r=this.getPixelRatio(),i=Math.ceil(bt(n*r));t=Math.pow(2,i)}return!(e.pstyle("font-size").pfValue*t5&&void 0!==arguments[5])||arguments[5],o=this;if(null==r){if(a&&!o.eleTextBiggerThanMin(t))return}else if(!1===r)return;if(t.isNode()){var s=t.pstyle("label");if(!s||!s.value)return;var l=o.getLabelJustification(t);e.textAlign=l,e.textBaseline="bottom"}else{var u=t.element()._private.rscratch.badLine,c=t.pstyle("label"),d=t.pstyle("source-label"),h=t.pstyle("target-label");if(u||(!c||!c.value)&&(!d||!d.value)&&(!h||!h.value))return;e.textAlign="center",e.textBaseline="bottom"}var p,f=!n;n&&(p=n,e.translate(-p.x1,-p.y1)),null==i?(o.drawText(e,t,null,f,a),t.isEdge()&&(o.drawText(e,t,"source",f,a),o.drawText(e,t,"target",f,a))):o.drawText(e,t,i,f,a),n&&e.translate(p.x1,p.y1)},bu.getFontCache=function(e){var t;this.fontCaches=this.fontCaches||[];for(var n=0;n2&&void 0!==arguments[2])||arguments[2],r=t.pstyle("font-style").strValue,i=t.pstyle("font-size").pfValue+"px",a=t.pstyle("font-family").strValue,o=t.pstyle("font-weight").strValue,s=n?t.effectiveOpacity()*t.pstyle("text-opacity").value:1,l=t.pstyle("text-outline-opacity").value*s,u=t.pstyle("color").value,c=t.pstyle("text-outline-color").value;e.font=r+" "+o+" "+i+" "+a,e.lineJoin="round",this.colorFillStyle(e,u[0],u[1],u[2],s),this.colorStrokeStyle(e,c[0],c[1],c[2],l)},bu.getTextAngle=function(e,t){var n=e._private.rscratch,r=t?t+"-":"",i=e.pstyle(r+"text-rotation"),a=Ke(n,"labelAngle",t);return"autorotate"===i.strValue?e.isEdge()?a:0:"none"===i.strValue?0:i.pfValue},bu.drawText=function(e,t,n){var r=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],i=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],a=t._private,o=a.rscratch,s=i?t.effectiveOpacity():1;if(!i||0!==s&&0!==t.pstyle("text-opacity").value){"main"===n&&(n=null);var l,u,c=Ke(o,"labelX",n),d=Ke(o,"labelY",n),h=this.getLabelText(t,n);if(null!=h&&""!==h&&!isNaN(c)&&!isNaN(d)){this.setupTextStyle(e,t,i);var p,f=n?n+"-":"",g=Ke(o,"labelWidth",n),v=Ke(o,"labelHeight",n),y=t.pstyle(f+"text-margin-x").pfValue,m=t.pstyle(f+"text-margin-y").pfValue,b=t.isEdge(),x=t.pstyle("text-halign").value,w=t.pstyle("text-valign").value;switch(b&&(x="center",w="center"),c+=y,d+=m,0!==(p=r?this.getTextAngle(t,n):0)&&(l=c,u=d,e.translate(l,u),e.rotate(p),c=0,d=0),w){case"top":break;case"center":d+=v/2;break;case"bottom":d+=v}var E=t.pstyle("text-background-opacity").value,k=t.pstyle("text-border-opacity").value,C=t.pstyle("text-border-width").pfValue,S=t.pstyle("text-background-padding").pfValue;if(E>0||C>0&&k>0){var P=c-S;switch(x){case"left":P-=g;break;case"center":P-=g/2}var D=d-v-S,T=g+2*S,_=v+2*S;if(E>0){var M=e.fillStyle,B=t.pstyle("text-background-color").value;e.fillStyle="rgba("+B[0]+","+B[1]+","+B[2]+","+E*s+")";var N=t.pstyle("text-background-shape").strValue;0===N.indexOf("round")?xu(e,P,D,T,_,2):e.fillRect(P,D,T,_),e.fillStyle=M}if(C>0&&k>0){var z=e.strokeStyle,I=e.lineWidth,A=t.pstyle("text-border-color").value,L=t.pstyle("text-border-style").value;if(e.strokeStyle="rgba("+A[0]+","+A[1]+","+A[2]+","+k*s+")",e.lineWidth=C,e.setLineDash)switch(L){case"dotted":e.setLineDash([1,1]);break;case"dashed":e.setLineDash([4,2]);break;case"double":e.lineWidth=C/4,e.setLineDash([]);break;case"solid":e.setLineDash([])}if(e.strokeRect(P,D,T,_),"double"===L){var O=C/2;e.strokeRect(P+O,D+O,T-2*O,_-2*O)}e.setLineDash&&e.setLineDash([]),e.lineWidth=I,e.strokeStyle=z}}var R=2*t.pstyle("text-outline-width").pfValue;if(R>0&&(e.lineWidth=R),"wrap"===t.pstyle("text-wrap").value){var V=Ke(o,"labelWrapCachedLines",n),F=Ke(o,"labelLineHeight",n),j=g/2,q=this.getLabelJustification(t);switch("auto"===q||("left"===x?"left"===q?c+=-g:"center"===q&&(c+=-j):"center"===x?"left"===q?c+=-j:"right"===q&&(c+=j):"right"===x&&("center"===q?c+=j:"right"===q&&(c+=g))),w){case"top":d-=(V.length-1)*F;break;case"center":case"bottom":d-=(V.length-1)*F}for(var Y=0;Y0&&e.strokeText(V[Y],c,d),e.fillText(V[Y],c,d),d+=F}else R>0&&e.strokeText(h,c,d),e.fillText(h,c,d);0!==p&&(e.rotate(-p),e.translate(-l,-u))}}};var wu={drawNode:function(e,t,n){var r,i,a=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],o=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],s=!(arguments.length>5&&void 0!==arguments[5])||arguments[5],l=this,u=t._private,c=u.rscratch,d=t.position();if(m(d.x)&&m(d.y)&&(!s||t.visible())){var h,p,f=s?t.effectiveOpacity():1,g=l.usePaths(),v=!1,y=t.padding();r=t.width()+2*y,i=t.height()+2*y,n&&(p=n,e.translate(-p.x1,-p.y1));for(var b=t.pstyle("background-image"),x=b.value,w=new Array(x.length),E=new Array(x.length),k=0,C=0;C0&&void 0!==arguments[0]?arguments[0]:M;l.eleFillStyle(e,t,n)},A=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:z;l.colorStrokeStyle(e,B[0],B[1],B[2],t)},L=t.pstyle("shape").strValue,O=t.pstyle("shape-polygon-points").pfValue;if(g){e.translate(d.x,d.y);var R=l.nodePathCache=l.nodePathCache||[],V=De("polygon"===L?L+","+O.join(","):L,""+i,""+r),F=R[V];null!=F?(h=F,v=!0,c.pathCache=h):(h=new Path2D,R[V]=c.pathCache=h)}var j=function(){if(!v){var n=d;g&&(n={x:0,y:0}),l.nodeShapes[l.getNodeShape(t)].draw(h||e,n.x,n.y,r,i)}g?e.fill(h):e.fill()},q=function(){for(var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:f,r=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=u.backgrounding,a=0,o=0;o0&&void 0!==arguments[0]&&arguments[0],a=arguments.length>1&&void 0!==arguments[1]?arguments[1]:f;l.hasPie(t)&&(l.drawPie(e,t,a),n&&(g||l.nodeShapes[l.getNodeShape(t)].draw(e,d.x,d.y,r,i)))},X=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:f,n=(T>0?T:-T)*t,r=T>0?0:255;0!==T&&(l.colorFillStyle(e,r,r,r,n),g?e.fill(h):e.fill())},W=function(){if(_>0){if(e.lineWidth=_,e.lineCap="butt",e.setLineDash)switch(N){case"dotted":e.setLineDash([1,1]);break;case"dashed":e.setLineDash([4,2]);break;case"solid":case"double":e.setLineDash([])}if(g?e.stroke(h):e.stroke(),"double"===N){e.lineWidth=_/3;var t=e.globalCompositeOperation;e.globalCompositeOperation="destination-out",g?e.stroke(h):e.stroke(),e.globalCompositeOperation=t}e.setLineDash&&e.setLineDash([])}},H=function(){o&&l.drawNodeOverlay(e,t,d,r,i)},K=function(){o&&l.drawNodeUnderlay(e,t,d,r,i)},G=function(){l.drawElementText(e,t,null,a)},U="yes"===t.pstyle("ghost").value;if(U){var Z=t.pstyle("ghost-offset-x").pfValue,$=t.pstyle("ghost-offset-y").pfValue,Q=t.pstyle("ghost-opacity").value,J=Q*f;e.translate(Z,$),I(Q*M),j(),q(J,!0),A(Q*z),W(),Y(0!==T||0!==_),q(J,!1),X(J),e.translate(-Z,-$)}g&&e.translate(-d.x,-d.y),K(),g&&e.translate(d.x,d.y),I(),j(),q(f,!0),A(),W(),Y(0!==T||0!==_),q(f,!1),X(),g&&e.translate(-d.x,-d.y),G(),H(),n&&e.translate(p.x1,p.y1)}}},Eu=function(e){if(!["overlay","underlay"].includes(e))throw new Error("Invalid state");return function(t,n,r,i,a){if(n.visible()){var o=n.pstyle("".concat(e,"-padding")).pfValue,s=n.pstyle("".concat(e,"-opacity")).value,l=n.pstyle("".concat(e,"-color")).value,u=n.pstyle("".concat(e,"-shape")).value;if(s>0){if(r=r||n.position(),null==i||null==a){var c=n.padding();i=n.width()+2*c,a=n.height()+2*c}this.colorFillStyle(t,l[0],l[1],l[2],s),this.nodeShapes[u].draw(t,r.x,r.y,i+2*o,a+2*o),t.fill()}}}};wu.drawNodeOverlay=Eu("overlay"),wu.drawNodeUnderlay=Eu("underlay"),wu.hasPie=function(e){return(e=e[0])._private.hasPie},wu.drawPie=function(e,t,n,r){t=t[0],r=r||t.position();var i=t.cy().style(),a=t.pstyle("pie-size"),o=r.x,s=r.y,l=t.width(),u=t.height(),c=Math.min(l,u)/2,d=0;this.usePaths()&&(o=0,s=0),"%"===a.units?c*=a.pfValue:void 0!==a.pfValue&&(c=a.pfValue/2);for(var h=1;h<=i.pieBackgroundN;h++){var p=t.pstyle("pie-"+h+"-background-size").value,f=t.pstyle("pie-"+h+"-background-color").value,g=t.pstyle("pie-"+h+"-background-opacity").value*n,v=p/100;v+d>1&&(v=1-d);var y=1.5*Math.PI+2*Math.PI*d,m=y+2*Math.PI*v;0===p||d>=1||d+v>1||(e.beginPath(),e.moveTo(o,s),e.arc(o,s,c,y,m),e.closePath(),this.colorFillStyle(e,f[0],f[1],f[2],g),e.fill(),d+=v)}};var ku={};ku.getPixelRatio=function(){var e=this.data.contexts[0];if(null!=this.forcedPixelRatio)return this.forcedPixelRatio;var t=e.backingStorePixelRatio||e.webkitBackingStorePixelRatio||e.mozBackingStorePixelRatio||e.msBackingStorePixelRatio||e.oBackingStorePixelRatio||e.backingStorePixelRatio||1;return(window.devicePixelRatio||1)/t},ku.paintCache=function(e){for(var t,n=this.paintCaches=this.paintCaches||[],r=!0,i=0;io.minMbLowQualFrames&&(o.motionBlurPxRatio=o.mbPxRBlurry)),o.clearingMotionBlur&&(o.motionBlurPxRatio=1),o.textureDrawLastFrame&&!d&&(c[o.NODE]=!0,c[o.SELECT_BOX]=!0);var m=l.style(),b=l.zoom(),x=void 0!==i?i:b,w=l.pan(),E={x:w.x,y:w.y},k={zoom:b,pan:{x:w.x,y:w.y}},C=o.prevViewport;void 0===C||k.zoom!==C.zoom||k.pan.x!==C.pan.x||k.pan.y!==C.pan.y||g&&!f||(o.motionBlurPxRatio=1),a&&(E=a),x*=s,E.x*=s,E.y*=s;var S=o.getCachedZSortedEles();function P(e,t,n,r,i){var a=e.globalCompositeOperation;e.globalCompositeOperation="destination-out",o.colorFillStyle(e,255,255,255,o.motionBlurTransparency),e.fillRect(t,n,r,i),e.globalCompositeOperation=a}function D(e,r){var s,l,c,d;o.clearingMotionBlur||e!==u.bufferContexts[o.MOTIONBLUR_BUFFER_NODE]&&e!==u.bufferContexts[o.MOTIONBLUR_BUFFER_DRAG]?(s=E,l=x,c=o.canvasWidth,d=o.canvasHeight):(s={x:w.x*p,y:w.y*p},l=b*p,c=o.canvasWidth*p,d=o.canvasHeight*p),e.setTransform(1,0,0,1,0,0),"motionBlur"===r?P(e,0,0,c,d):t||void 0!==r&&!r||e.clearRect(0,0,c,d),n||(e.translate(s.x,s.y),e.scale(l,l)),a&&e.translate(a.x,a.y),i&&e.scale(i,i)}if(d||(o.textureDrawLastFrame=!1),d){if(o.textureDrawLastFrame=!0,!o.textureCache){o.textureCache={},o.textureCache.bb=l.mutableElements().boundingBox(),o.textureCache.texture=o.data.bufferCanvases[o.TEXTURE_BUFFER];var T=o.data.bufferContexts[o.TEXTURE_BUFFER];T.setTransform(1,0,0,1,0,0),T.clearRect(0,0,o.canvasWidth*o.textureMult,o.canvasHeight*o.textureMult),o.render({forcedContext:T,drawOnlyNodeLayer:!0,forcedPxRatio:s*o.textureMult}),(k=o.textureCache.viewport={zoom:l.zoom(),pan:l.pan(),width:o.canvasWidth,height:o.canvasHeight}).mpan={x:(0-k.pan.x)/k.zoom,y:(0-k.pan.y)/k.zoom}}c[o.DRAG]=!1,c[o.NODE]=!1;var _=u.contexts[o.NODE],M=o.textureCache.texture;k=o.textureCache.viewport;_.setTransform(1,0,0,1,0,0),h?P(_,0,0,k.width,k.height):_.clearRect(0,0,k.width,k.height);var B=m.core("outside-texture-bg-color").value,N=m.core("outside-texture-bg-opacity").value;o.colorFillStyle(_,B[0],B[1],B[2],N),_.fillRect(0,0,k.width,k.height);b=l.zoom();D(_,!1),_.clearRect(k.mpan.x,k.mpan.y,k.width/k.zoom/s,k.height/k.zoom/s),_.drawImage(M,k.mpan.x,k.mpan.y,k.width/k.zoom/s,k.height/k.zoom/s)}else o.textureOnViewport&&!t&&(o.textureCache=null);var z=l.extent(),I=o.pinching||o.hoverData.dragging||o.swipePanning||o.data.wheelZooming||o.hoverData.draggingEles||o.cy.animated(),A=o.hideEdgesOnViewport&&I,L=[];if(L[o.NODE]=!c[o.NODE]&&h&&!o.clearedForMotionBlur[o.NODE]||o.clearingMotionBlur,L[o.NODE]&&(o.clearedForMotionBlur[o.NODE]=!0),L[o.DRAG]=!c[o.DRAG]&&h&&!o.clearedForMotionBlur[o.DRAG]||o.clearingMotionBlur,L[o.DRAG]&&(o.clearedForMotionBlur[o.DRAG]=!0),c[o.NODE]||n||r||L[o.NODE]){var O=h&&!L[o.NODE]&&1!==p;D(_=t||(O?o.data.bufferContexts[o.MOTIONBLUR_BUFFER_NODE]:u.contexts[o.NODE]),h&&!O?"motionBlur":void 0),A?o.drawCachedNodes(_,S.nondrag,s,z):o.drawLayeredElements(_,S.nondrag,s,z),o.debug&&o.drawDebugPoints(_,S.nondrag),n||h||(c[o.NODE]=!1)}if(!r&&(c[o.DRAG]||n||L[o.DRAG])){O=h&&!L[o.DRAG]&&1!==p;D(_=t||(O?o.data.bufferContexts[o.MOTIONBLUR_BUFFER_DRAG]:u.contexts[o.DRAG]),h&&!O?"motionBlur":void 0),A?o.drawCachedNodes(_,S.drag,s,z):o.drawCachedElements(_,S.drag,s,z),o.debug&&o.drawDebugPoints(_,S.drag),n||h||(c[o.DRAG]=!1)}if(o.showFps||!r&&c[o.SELECT_BOX]&&!n){if(D(_=t||u.contexts[o.SELECT_BOX]),1==o.selection[4]&&(o.hoverData.selecting||o.touchData.selecting)){b=o.cy.zoom();var R=m.core("selection-box-border-width").value/b;_.lineWidth=R,_.fillStyle="rgba("+m.core("selection-box-color").value[0]+","+m.core("selection-box-color").value[1]+","+m.core("selection-box-color").value[2]+","+m.core("selection-box-opacity").value+")",_.fillRect(o.selection[0],o.selection[1],o.selection[2]-o.selection[0],o.selection[3]-o.selection[1]),R>0&&(_.strokeStyle="rgba("+m.core("selection-box-border-color").value[0]+","+m.core("selection-box-border-color").value[1]+","+m.core("selection-box-border-color").value[2]+","+m.core("selection-box-opacity").value+")",_.strokeRect(o.selection[0],o.selection[1],o.selection[2]-o.selection[0],o.selection[3]-o.selection[1]))}if(u.bgActivePosistion&&!o.hoverData.selecting){b=o.cy.zoom();var V=u.bgActivePosistion;_.fillStyle="rgba("+m.core("active-bg-color").value[0]+","+m.core("active-bg-color").value[1]+","+m.core("active-bg-color").value[2]+","+m.core("active-bg-opacity").value+")",_.beginPath(),_.arc(V.x,V.y,m.core("active-bg-size").pfValue/b,0,2*Math.PI),_.fill()}var F=o.lastRedrawTime;if(o.showFps&&F){F=Math.round(F);var j=Math.round(1e3/F);_.setTransform(1,0,0,1,0,0),_.fillStyle="rgba(255, 0, 0, 0.75)",_.strokeStyle="rgba(255, 0, 0, 0.75)",_.lineWidth=1,_.fillText("1 frame = "+F+" ms = "+j+" fps",0,20);_.strokeRect(0,30,250,20),_.fillRect(0,30,250*Math.min(j/60,1),20)}n||(c[o.SELECT_BOX]=!1)}if(h&&1!==p){var q=u.contexts[o.NODE],Y=o.data.bufferCanvases[o.MOTIONBLUR_BUFFER_NODE],X=u.contexts[o.DRAG],W=o.data.bufferCanvases[o.MOTIONBLUR_BUFFER_DRAG],H=function(e,t,n){e.setTransform(1,0,0,1,0,0),n||!y?e.clearRect(0,0,o.canvasWidth,o.canvasHeight):P(e,0,0,o.canvasWidth,o.canvasHeight);var r=p;e.drawImage(t,0,0,o.canvasWidth*r,o.canvasHeight*r,0,0,o.canvasWidth,o.canvasHeight)};(c[o.NODE]||L[o.NODE])&&(H(q,Y,L[o.NODE]),c[o.NODE]=!1),(c[o.DRAG]||L[o.DRAG])&&(H(X,W,L[o.DRAG]),c[o.DRAG]=!1)}o.prevViewport=k,o.clearingMotionBlur&&(o.clearingMotionBlur=!1,o.motionBlurCleared=!0,o.motionBlur=!0),h&&(o.motionBlurTimeout=setTimeout((function(){o.motionBlurTimeout=null,o.clearedForMotionBlur[o.NODE]=!1,o.clearedForMotionBlur[o.DRAG]=!1,o.motionBlur=!1,o.clearingMotionBlur=!d,o.mbFrames=0,c[o.NODE]=!0,c[o.DRAG]=!0,o.redraw()}),100)),t||l.emit("render")};for(var Cu={drawPolygonPath:function(e,t,n,r,i,a){var o=r/2,s=i/2;e.beginPath&&e.beginPath(),e.moveTo(t+o*a[0],n+s*a[1]);for(var l=1;l0&&a>0){h.clearRect(0,0,i,a),h.globalCompositeOperation="source-over";var p=this.getCachedZSortedEles();if(e.full)h.translate(-n.x1*l,-n.y1*l),h.scale(l,l),this.drawElements(h,p),h.scale(1/l,1/l),h.translate(n.x1*l,n.y1*l);else{var f=t.pan(),g={x:f.x*l,y:f.y*l};l*=t.zoom(),h.translate(g.x,g.y),h.scale(l,l),this.drawElements(h,p),h.scale(1/l,1/l),h.translate(-g.x,-g.y)}e.bg&&(h.globalCompositeOperation="destination-over",h.fillStyle=e.bg,h.rect(0,0,i,a),h.fill())}return d},Bu.png=function(e){return zu(e,this.bufferCanvasImage(e),"image/png")},Bu.jpg=function(e){return zu(e,this.bufferCanvasImage(e),"image/jpeg")};var Iu={nodeShapeImpl:function(e,t,n,r,i,a,o){switch(e){case"ellipse":return this.drawEllipsePath(t,n,r,i,a);case"polygon":return this.drawPolygonPath(t,n,r,i,a,o);case"round-polygon":return this.drawRoundPolygonPath(t,n,r,i,a,o);case"roundrectangle":case"round-rectangle":return this.drawRoundRectanglePath(t,n,r,i,a);case"cutrectangle":case"cut-rectangle":return this.drawCutRectanglePath(t,n,r,i,a);case"bottomroundrectangle":case"bottom-round-rectangle":return this.drawBottomRoundRectanglePath(t,n,r,i,a);case"barrel":return this.drawBarrelPath(t,n,r,i,a)}}},Au=Ou,Lu=Ou.prototype;function Ou(e){var t=this;t.data={canvases:new Array(Lu.CANVAS_LAYERS),contexts:new Array(Lu.CANVAS_LAYERS),canvasNeedsRedraw:new Array(Lu.CANVAS_LAYERS),bufferCanvases:new Array(Lu.BUFFER_COUNT),bufferContexts:new Array(Lu.CANVAS_LAYERS)};t.data.canvasContainer=document.createElement("div");var n=t.data.canvasContainer.style;t.data.canvasContainer.style["-webkit-tap-highlight-color"]="rgba(0,0,0,0)",n.position="relative",n.zIndex="0",n.overflow="hidden";var r=e.cy.container();r.appendChild(t.data.canvasContainer),r.style["-webkit-tap-highlight-color"]="rgba(0,0,0,0)";var i={"-webkit-user-select":"none","-moz-user-select":"-moz-none","user-select":"none","-webkit-tap-highlight-color":"rgba(0,0,0,0)","outline-style":"none"};l&&l.userAgent.match(/msie|trident|edge/i)&&(i["-ms-touch-action"]="none",i["touch-action"]="none");for(var a=0;a=0; --s) { - var n = n_stack[s] - if(d_stack[s] <= 0) { - n_stack[s] = new RBNode(n._color, n.key, n.value, n_stack[s+1], n.right, n._count+1) - } else { - n_stack[s] = new RBNode(n._color, n.key, n.value, n.left, n_stack[s+1], n._count+1) - } - } - //Rebalance tree using rotations - //console.log("start insert", key, d_stack) - for(var s=n_stack.length-1; s>1; --s) { - var p = n_stack[s-1] - var n = n_stack[s] - if(p._color === BLACK || n._color === BLACK) { - break - } - var pp = n_stack[s-2] - if(pp.left === p) { - if(p.left === n) { - var y = pp.right - if(y && y._color === RED) { - //console.log("LLr") - p._color = BLACK - pp.right = repaint(BLACK, y) - pp._color = RED - s -= 1 - } else { - //console.log("LLb") - pp._color = RED - pp.left = p.right - p._color = BLACK - p.right = pp - n_stack[s-2] = p - n_stack[s-1] = n - recount(pp) - recount(p) - if(s >= 3) { - var ppp = n_stack[s-3] - if(ppp.left === pp) { - ppp.left = p - } else { - ppp.right = p - } - } - break - } - } else { - var y = pp.right - if(y && y._color === RED) { - //console.log("LRr") - p._color = BLACK - pp.right = repaint(BLACK, y) - pp._color = RED - s -= 1 - } else { - //console.log("LRb") - p.right = n.left - pp._color = RED - pp.left = n.right - n._color = BLACK - n.left = p - n.right = pp - n_stack[s-2] = n - n_stack[s-1] = p - recount(pp) - recount(p) - recount(n) - if(s >= 3) { - var ppp = n_stack[s-3] - if(ppp.left === pp) { - ppp.left = n - } else { - ppp.right = n - } - } - break - } - } - } else { - if(p.right === n) { - var y = pp.left - if(y && y._color === RED) { - //console.log("RRr", y.key) - p._color = BLACK - pp.left = repaint(BLACK, y) - pp._color = RED - s -= 1 - } else { - //console.log("RRb") - pp._color = RED - pp.right = p.left - p._color = BLACK - p.left = pp - n_stack[s-2] = p - n_stack[s-1] = n - recount(pp) - recount(p) - if(s >= 3) { - var ppp = n_stack[s-3] - if(ppp.right === pp) { - ppp.right = p - } else { - ppp.left = p - } - } - break - } - } else { - var y = pp.left - if(y && y._color === RED) { - //console.log("RLr") - p._color = BLACK - pp.left = repaint(BLACK, y) - pp._color = RED - s -= 1 - } else { - //console.log("RLb") - p.left = n.right - pp._color = RED - pp.right = n.left - n._color = BLACK - n.right = p - n.left = pp - n_stack[s-2] = n - n_stack[s-1] = p - recount(pp) - recount(p) - recount(n) - if(s >= 3) { - var ppp = n_stack[s-3] - if(ppp.right === pp) { - ppp.right = n - } else { - ppp.left = n - } - } - break - } - } - } - } - //Return new tree - n_stack[0]._color = BLACK - return new RedBlackTree(cmp, n_stack[0]) - } - - - //Visit all nodes inorder - function doVisitFull(visit, node) { - if(node.left) { - var v = doVisitFull(visit, node.left) - if(v) { return v } - } - var v = visit(node.key, node.value) - if(v) { return v } - if(node.right) { - return doVisitFull(visit, node.right) - } - } - - //Visit half nodes in order - function doVisitHalf(lo, compare, visit, node) { - var l = compare(lo, node.key) - if(l <= 0) { - if(node.left) { - var v = doVisitHalf(lo, compare, visit, node.left) - if(v) { return v } - } - var v = visit(node.key, node.value) - if(v) { return v } - } - if(node.right) { - return doVisitHalf(lo, compare, visit, node.right) - } - } - - //Visit all nodes within a range - function doVisit(lo, hi, compare, visit, node) { - var l = compare(lo, node.key) - var h = compare(hi, node.key) - var v - if(l <= 0) { - if(node.left) { - v = doVisit(lo, hi, compare, visit, node.left) - if(v) { return v } - } - if(h > 0) { - v = visit(node.key, node.value) - if(v) { return v } - } - } - if(h > 0 && node.right) { - return doVisit(lo, hi, compare, visit, node.right) - } - } - - - proto.forEach = function rbTreeForEach(visit, lo, hi) { - if(!this.root) { - return - } - switch(arguments.length) { - case 1: - return doVisitFull(visit, this.root) - break - - case 2: - return doVisitHalf(lo, this._compare, visit, this.root) - break - - case 3: - if(this._compare(lo, hi) >= 0) { - return - } - return doVisit(lo, hi, this._compare, visit, this.root) - break - } - } - - //First item in list - Object.defineProperty(proto, "begin", { - get: function() { - var stack = [] - var n = this.root - while(n) { - stack.push(n) - n = n.left - } - return new RedBlackTreeIterator(this, stack) - } - }) - - //Last item in list - Object.defineProperty(proto, "end", { - get: function() { - var stack = [] - var n = this.root - while(n) { - stack.push(n) - n = n.right - } - return new RedBlackTreeIterator(this, stack) - } - }) - - //Find the ith item in the tree - proto.at = function(idx) { - if(idx < 0) { - return new RedBlackTreeIterator(this, []) - } - var n = this.root - var stack = [] - while(true) { - stack.push(n) - if(n.left) { - if(idx < n.left._count) { - n = n.left - continue - } - idx -= n.left._count - } - if(!idx) { - return new RedBlackTreeIterator(this, stack) - } - idx -= 1 - if(n.right) { - if(idx >= n.right._count) { - break - } - n = n.right - } else { - break - } - } - return new RedBlackTreeIterator(this, []) - } - - proto.ge = function(key) { - var cmp = this._compare - var n = this.root - var stack = [] - var last_ptr = 0 - while(n) { - var d = cmp(key, n.key) - stack.push(n) - if(d <= 0) { - last_ptr = stack.length - } - if(d <= 0) { - n = n.left - } else { - n = n.right - } - } - stack.length = last_ptr - return new RedBlackTreeIterator(this, stack) - } - - proto.gt = function(key) { - var cmp = this._compare - var n = this.root - var stack = [] - var last_ptr = 0 - while(n) { - var d = cmp(key, n.key) - stack.push(n) - if(d < 0) { - last_ptr = stack.length - } - if(d < 0) { - n = n.left - } else { - n = n.right - } - } - stack.length = last_ptr - return new RedBlackTreeIterator(this, stack) - } - - proto.lt = function(key) { - var cmp = this._compare - var n = this.root - var stack = [] - var last_ptr = 0 - while(n) { - var d = cmp(key, n.key) - stack.push(n) - if(d > 0) { - last_ptr = stack.length - } - if(d <= 0) { - n = n.left - } else { - n = n.right - } - } - stack.length = last_ptr - return new RedBlackTreeIterator(this, stack) - } - - proto.le = function(key) { - var cmp = this._compare - var n = this.root - var stack = [] - var last_ptr = 0 - while(n) { - var d = cmp(key, n.key) - stack.push(n) - if(d >= 0) { - last_ptr = stack.length - } - if(d < 0) { - n = n.left - } else { - n = n.right - } - } - stack.length = last_ptr - return new RedBlackTreeIterator(this, stack) - } - - //Finds the item with key if it exists - proto.find = function(key) { - var cmp = this._compare - var n = this.root - var stack = [] - while(n) { - var d = cmp(key, n.key) - stack.push(n) - if(d === 0) { - return new RedBlackTreeIterator(this, stack) - } - if(d <= 0) { - n = n.left - } else { - n = n.right - } - } - return new RedBlackTreeIterator(this, []) - } - - //Removes item with key from tree - proto.remove = function(key) { - var iter = this.find(key) - if(iter) { - return iter.remove() - } - return this - } - - //Returns the item at `key` - proto.get = function(key) { - var cmp = this._compare - var n = this.root - while(n) { - var d = cmp(key, n.key) - if(d === 0) { - return n.value - } - if(d <= 0) { - n = n.left - } else { - n = n.right - } - } - return - } - - //Iterator for red black tree - function RedBlackTreeIterator(tree, stack) { - this.tree = tree - this._stack = stack - } - - var iproto = RedBlackTreeIterator.prototype - - //Test if iterator is valid - Object.defineProperty(iproto, "valid", { - get: function() { - return this._stack.length > 0 - } - }) - - //Node of the iterator - Object.defineProperty(iproto, "node", { - get: function() { - if(this._stack.length > 0) { - return this._stack[this._stack.length-1] - } - return null - }, - enumerable: true - }) - - //Makes a copy of an iterator - iproto.clone = function() { - return new RedBlackTreeIterator(this.tree, this._stack.slice()) - } - - //Swaps two nodes - function swapNode(n, v) { - n.key = v.key - n.value = v.value - n.left = v.left - n.right = v.right - n._color = v._color - n._count = v._count - } - - //Fix up a double black node in a tree - function fixDoubleBlack(stack) { - var n, p, s, z - for(var i=stack.length-1; i>=0; --i) { - n = stack[i] - if(i === 0) { - n._color = BLACK - return - } - //console.log("visit node:", n.key, i, stack[i].key, stack[i-1].key) - p = stack[i-1] - if(p.left === n) { - //console.log("left child") - s = p.right - if(s.right && s.right._color === RED) { - //console.log("case 1: right sibling child red") - s = p.right = cloneNode(s) - z = s.right = cloneNode(s.right) - p.right = s.left - s.left = p - s.right = z - s._color = p._color - n._color = BLACK - p._color = BLACK - z._color = BLACK - recount(p) - recount(s) - if(i > 1) { - var pp = stack[i-2] - if(pp.left === p) { - pp.left = s - } else { - pp.right = s - } - } - stack[i-1] = s - return - } else if(s.left && s.left._color === RED) { - //console.log("case 1: left sibling child red") - s = p.right = cloneNode(s) - z = s.left = cloneNode(s.left) - p.right = z.left - s.left = z.right - z.left = p - z.right = s - z._color = p._color - p._color = BLACK - s._color = BLACK - n._color = BLACK - recount(p) - recount(s) - recount(z) - if(i > 1) { - var pp = stack[i-2] - if(pp.left === p) { - pp.left = z - } else { - pp.right = z - } - } - stack[i-1] = z - return - } - if(s._color === BLACK) { - if(p._color === RED) { - //console.log("case 2: black sibling, red parent", p.right.value) - p._color = BLACK - p.right = repaint(RED, s) - return - } else { - //console.log("case 2: black sibling, black parent", p.right.value) - p.right = repaint(RED, s) - continue - } - } else { - //console.log("case 3: red sibling") - s = cloneNode(s) - p.right = s.left - s.left = p - s._color = p._color - p._color = RED - recount(p) - recount(s) - if(i > 1) { - var pp = stack[i-2] - if(pp.left === p) { - pp.left = s - } else { - pp.right = s - } - } - stack[i-1] = s - stack[i] = p - if(i+1 < stack.length) { - stack[i+1] = n - } else { - stack.push(n) - } - i = i+2 - } - } else { - //console.log("right child") - s = p.left - if(s.left && s.left._color === RED) { - //console.log("case 1: left sibling child red", p.value, p._color) - s = p.left = cloneNode(s) - z = s.left = cloneNode(s.left) - p.left = s.right - s.right = p - s.left = z - s._color = p._color - n._color = BLACK - p._color = BLACK - z._color = BLACK - recount(p) - recount(s) - if(i > 1) { - var pp = stack[i-2] - if(pp.right === p) { - pp.right = s - } else { - pp.left = s - } - } - stack[i-1] = s - return - } else if(s.right && s.right._color === RED) { - //console.log("case 1: right sibling child red") - s = p.left = cloneNode(s) - z = s.right = cloneNode(s.right) - p.left = z.right - s.right = z.left - z.right = p - z.left = s - z._color = p._color - p._color = BLACK - s._color = BLACK - n._color = BLACK - recount(p) - recount(s) - recount(z) - if(i > 1) { - var pp = stack[i-2] - if(pp.right === p) { - pp.right = z - } else { - pp.left = z - } - } - stack[i-1] = z - return - } - if(s._color === BLACK) { - if(p._color === RED) { - //console.log("case 2: black sibling, red parent") - p._color = BLACK - p.left = repaint(RED, s) - return - } else { - //console.log("case 2: black sibling, black parent") - p.left = repaint(RED, s) - continue - } - } else { - //console.log("case 3: red sibling") - s = cloneNode(s) - p.left = s.right - s.right = p - s._color = p._color - p._color = RED - recount(p) - recount(s) - if(i > 1) { - var pp = stack[i-2] - if(pp.right === p) { - pp.right = s - } else { - pp.left = s - } - } - stack[i-1] = s - stack[i] = p - if(i+1 < stack.length) { - stack[i+1] = n - } else { - stack.push(n) - } - i = i+2 - } - } - } - } - - //Removes item at iterator from tree - iproto.remove = function() { - var stack = this._stack - if(stack.length === 0) { - return this.tree - } - //First copy path to node - var cstack = new Array(stack.length) - var n = stack[stack.length-1] - cstack[cstack.length-1] = new RBNode(n._color, n.key, n.value, n.left, n.right, n._count) - for(var i=stack.length-2; i>=0; --i) { - var n = stack[i] - if(n.left === stack[i+1]) { - cstack[i] = new RBNode(n._color, n.key, n.value, cstack[i+1], n.right, n._count) - } else { - cstack[i] = new RBNode(n._color, n.key, n.value, n.left, cstack[i+1], n._count) - } - } - - //Get node - n = cstack[cstack.length-1] - //console.log("start remove: ", n.value) - - //If not leaf, then swap with previous node - if(n.left && n.right) { - //console.log("moving to leaf") - - //First walk to previous leaf - var split = cstack.length - n = n.left - while(n.right) { - cstack.push(n) - n = n.right - } - //Copy path to leaf - var v = cstack[split-1] - cstack.push(new RBNode(n._color, v.key, v.value, n.left, n.right, n._count)) - cstack[split-1].key = n.key - cstack[split-1].value = n.value - - //Fix up stack - for(var i=cstack.length-2; i>=split; --i) { - n = cstack[i] - cstack[i] = new RBNode(n._color, n.key, n.value, n.left, cstack[i+1], n._count) - } - cstack[split-1].left = cstack[split] - } - //console.log("stack=", cstack.map(function(v) { return v.value })) - - //Remove leaf node - n = cstack[cstack.length-1] - if(n._color === RED) { - //Easy case: removing red leaf - //console.log("RED leaf") - var p = cstack[cstack.length-2] - if(p.left === n) { - p.left = null - } else if(p.right === n) { - p.right = null - } - cstack.pop() - for(var i=0; i 0) { - return this._stack[this._stack.length-1].key - } - return - }, - enumerable: true - }) - - //Returns value - Object.defineProperty(iproto, "value", { - get: function() { - if(this._stack.length > 0) { - return this._stack[this._stack.length-1].value - } - return - }, - enumerable: true - }) - - - //Returns the position of this iterator in the sorted list - Object.defineProperty(iproto, "index", { - get: function() { - var idx = 0 - var stack = this._stack - if(stack.length === 0) { - var r = this.tree.root - if(r) { - return r._count - } - return 0 - } else if(stack[stack.length-1].left) { - idx = stack[stack.length-1].left._count - } - for(var s=stack.length-2; s>=0; --s) { - if(stack[s+1] === stack[s].right) { - ++idx - if(stack[s].left) { - idx += stack[s].left._count - } - } - } - return idx - }, - enumerable: true - }) - - //Advances iterator to next element in list - iproto.next = function() { - var stack = this._stack - if(stack.length === 0) { - return - } - var n = stack[stack.length-1] - if(n.right) { - n = n.right - while(n) { - stack.push(n) - n = n.left - } - } else { - stack.pop() - while(stack.length > 0 && stack[stack.length-1].right === n) { - n = stack[stack.length-1] - stack.pop() - } - } - } - - //Checks if iterator is at end of tree - Object.defineProperty(iproto, "hasNext", { - get: function() { - var stack = this._stack - if(stack.length === 0) { - return false - } - if(stack[stack.length-1].right) { - return true - } - for(var s=stack.length-1; s>0; --s) { - if(stack[s-1].left === stack[s]) { - return true - } - } - return false - } - }) - - //Update value - iproto.update = function(value) { - var stack = this._stack - if(stack.length === 0) { - throw new Error("Can't update empty node!") - } - var cstack = new Array(stack.length) - var n = stack[stack.length-1] - cstack[cstack.length-1] = new RBNode(n._color, n.key, value, n.left, n.right, n._count) - for(var i=stack.length-2; i>=0; --i) { - n = stack[i] - if(n.left === stack[i+1]) { - cstack[i] = new RBNode(n._color, n.key, n.value, cstack[i+1], n.right, n._count) - } else { - cstack[i] = new RBNode(n._color, n.key, n.value, n.left, cstack[i+1], n._count) - } - } - return new RedBlackTree(this.tree._compare, cstack[0]) - } - - //Moves iterator backward one element - iproto.prev = function() { - var stack = this._stack - if(stack.length === 0) { - return - } - var n = stack[stack.length-1] - if(n.left) { - n = n.left - while(n) { - stack.push(n) - n = n.right - } - } else { - stack.pop() - while(stack.length > 0 && stack[stack.length-1].left === n) { - n = stack[stack.length-1] - stack.pop() - } - } - } - - //Checks if iterator is at start of tree - Object.defineProperty(iproto, "hasPrev", { - get: function() { - var stack = this._stack - if(stack.length === 0) { - return false - } - if(stack[stack.length-1].left) { - return true - } - for(var s=stack.length-1; s>0; --s) { - if(stack[s-1].right === stack[s]) { - return true - } - } - return false - } - }) - - //Default comparison function - function defaultCompare(a, b) { - if(a < b) { - return -1 - } - if(a > b) { - return 1 - } - return 0 - } - - //Build a tree - function createRBTree(compare) { - return new RedBlackTree(compare || defaultCompare, null) - } - },{}],2:[function(require,module,exports){ - module.exports = function (cytoscape, cy, apiRegistered) { - - // Needed because parent nodes cannot be moved in Cytoscape.js < v3.2 - function moveTopDown(node, dx, dy) { - var nodes = node.union(node.descendants()); - - nodes.filter(":childless").positions(function (node, i) { - if(typeof node === "number") { - node = i; - } - var pos = node.position(); - return { - x: pos.x + dx, - y: pos.y + dy - }; - }); - } - - function getTopMostNodes(nodes) { - var nodesMap = {}; - for (var i = 0; i < nodes.length; i++) { - nodesMap[nodes[i].id()] = true; - } - var roots = nodes.filter(function (ele, i) { - if(typeof ele === "number") { - ele = i; - } - - var parent = ele.parent()[0]; - while(parent != null){ - if(nodesMap[parent.id()]){ - return false; - } - parent = parent.parent()[0]; - } - return true; - }); - - return roots; - } - - - // If extension api functions are not registed to cytoscape yet register them here. - // Note that ideally these functions should not be directly registered to core from cytoscape.js - // extensions - if ( !apiRegistered ) { - - cytoscape( "collection", "align", function (horizontal, vertical, alignTo) { - - var eles = getTopMostNodes(this.nodes(":visible")); - - var modelNode = alignTo ? alignTo : eles[0]; - - eles = eles.not(modelNode); - - horizontal = horizontal ? horizontal : "none"; - vertical = vertical ? vertical : "none"; - - - // 0 for center - var xFactor = 0; - var yFactor = 0; - - if (vertical == "left") - xFactor = -1; - else if (vertical == "right") - xFactor = 1; - - if (horizontal == "top") - yFactor = -1; - else if (horizontal == "bottom") - yFactor = 1; - - - for (var i = 0; i < eles.length; i++) { - var node = eles[i]; - var oldPos = Object.assign({}, node.position()); - var newPos = Object.assign({}, node.position()); - - if (vertical != "none") - newPos.x = modelNode.position("x") + xFactor * (modelNode.outerWidth() - node.outerWidth()) / 2; - - - if (horizontal != "none") - newPos.y = modelNode.position("y") + yFactor * (modelNode.outerHeight() - node.outerHeight()) / 2; - - moveTopDown(node, newPos.x - oldPos.x, newPos.y - oldPos.y); - } - - return this; - }); - - } - - - if (cy.undoRedo) { - function getNodePositions() { - var positionsAndSizes = {}; - var nodes = cy.nodes(); - - for (var i = 0; i < nodes.length; i++) { - var ele = nodes[i]; - positionsAndSizes[ele.id()] = { - x: ele.position("x"), - y: ele.position("y") - }; - } - - return positionsAndSizes; - } - - function returnToPositions(nodesData) { - var currentPositions = {}; - cy.nodes().not(":parent").positions(function (ele, i) { - if(typeof ele === "number") { - ele = i; - } - currentPositions[ele.id()] = { - x: ele.position("x"), - y: ele.position("y") - }; - var data = nodesData[ele.id()]; - return { - x: data.x, - y: data.y - }; - }); - - return currentPositions - } - - var ur = cy.undoRedo(null, true); - - ur.action("align", function (args) { - - var nodesData; - if (args.firstTime){ - nodesData = getNodePositions(); - args.nodes.align(args.horizontal, args.vertical, args.alignTo); - } - else - nodesData = returnToPositions(args); - - return nodesData; - - }, function (nodesData) { - return returnToPositions(nodesData); - }); - - } - - - - }; - - },{}],3:[function(require,module,exports){ - - var debounce = (function(){ - /** - * lodash 3.1.1 (Custom Build) - * Build: `lodash modern modularize exports="npm" -o ./` - * Copyright 2012-2015 The Dojo Foundation - * Based on Underscore.js 1.8.3 - * Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors - * Available under MIT license - */ - /** Used as the `TypeError` message for "Functions" methods. */ - var FUNC_ERROR_TEXT = 'Expected a function'; - - /* Native method references for those with the same name as other `lodash` methods. */ - var nativeMax = Math.max, - nativeNow = Date.now; - - /** - * Gets the number of milliseconds that have elapsed since the Unix epoch - * (1 January 1970 00:00:00 UTC). - * - * @static - * @memberOf _ - * @category Date - * @example - * - * _.defer(function(stamp) { - * console.log(_.now() - stamp); - * }, _.now()); - * // => logs the number of milliseconds it took for the deferred function to be invoked - */ - var now = nativeNow || function() { - return new Date().getTime(); - }; - - /** - * Creates a debounced function that delays invoking `func` until after `wait` - * milliseconds have elapsed since the last time the debounced function was - * invoked. The debounced function comes with a `cancel` method to cancel - * delayed invocations. Provide an options object to indicate that `func` - * should be invoked on the leading and/or trailing edge of the `wait` timeout. - * Subsequent calls to the debounced function return the result of the last - * `func` invocation. - * - * **Note:** If `leading` and `trailing` options are `true`, `func` is invoked - * on the trailing edge of the timeout only if the the debounced function is - * invoked more than once during the `wait` timeout. - * - * See [David Corbacho's article](http://drupalmotion.com/article/debounce-and-throttle-visual-explanation) - * for details over the differences between `_.debounce` and `_.throttle`. - * - * @static - * @memberOf _ - * @category Function - * @param {Function} func The function to debounce. - * @param {number} [wait=0] The number of milliseconds to delay. - * @param {Object} [options] The options object. - * @param {boolean} [options.leading=false] Specify invoking on the leading - * edge of the timeout. - * @param {number} [options.maxWait] The maximum time `func` is allowed to be - * delayed before it's invoked. - * @param {boolean} [options.trailing=true] Specify invoking on the trailing - * edge of the timeout. - * @returns {Function} Returns the new debounced function. - * @example - * - * // avoid costly calculations while the window size is in flux - * jQuery(window).on('resize', _.debounce(calculateLayout, 150)); - * - * // invoke `sendMail` when the click event is fired, debouncing subsequent calls - * jQuery('#postbox').on('click', _.debounce(sendMail, 300, { - * 'leading': true, - * 'trailing': false - * })); - * - * // ensure `batchLog` is invoked once after 1 second of debounced calls - * var source = new EventSource('/stream'); - * jQuery(source).on('message', _.debounce(batchLog, 250, { - * 'maxWait': 1000 - * })); - * - * // cancel a debounced call - * var todoChanges = _.debounce(batchLog, 1000); - * Object.observe(models.todo, todoChanges); - * - * Object.observe(models, function(changes) { - * if (_.find(changes, { 'user': 'todo', 'type': 'delete'})) { - * todoChanges.cancel(); - * } - * }, ['delete']); - * - * // ...at some point `models.todo` is changed - * models.todo.completed = true; - * - * // ...before 1 second has passed `models.todo` is deleted - * // which cancels the debounced `todoChanges` call - * delete models.todo; - */ - function debounce(func, wait, options) { - var args, - maxTimeoutId, - result, - stamp, - thisArg, - timeoutId, - trailingCall, - lastCalled = 0, - maxWait = false, - trailing = true; - - if (typeof func != 'function') { - throw new TypeError(FUNC_ERROR_TEXT); - } - wait = wait < 0 ? 0 : (+wait || 0); - if (options === true) { - var leading = true; - trailing = false; - } else if (isObject(options)) { - leading = !!options.leading; - maxWait = 'maxWait' in options && nativeMax(+options.maxWait || 0, wait); - trailing = 'trailing' in options ? !!options.trailing : trailing; - } - - function cancel() { - if (timeoutId) { - clearTimeout(timeoutId); - } - if (maxTimeoutId) { - clearTimeout(maxTimeoutId); - } - lastCalled = 0; - maxTimeoutId = timeoutId = trailingCall = undefined; - } - - function complete(isCalled, id) { - if (id) { - clearTimeout(id); - } - maxTimeoutId = timeoutId = trailingCall = undefined; - if (isCalled) { - lastCalled = now(); - result = func.apply(thisArg, args); - if (!timeoutId && !maxTimeoutId) { - args = thisArg = undefined; - } - } - } - - function delayed() { - var remaining = wait - (now() - stamp); - if (remaining <= 0 || remaining > wait) { - complete(trailingCall, maxTimeoutId); - } else { - timeoutId = setTimeout(delayed, remaining); - } - } - - function maxDelayed() { - complete(trailing, timeoutId); - } - - function debounced() { - args = arguments; - stamp = now(); - thisArg = this; - trailingCall = trailing && (timeoutId || !leading); - - if (maxWait === false) { - var leadingCall = leading && !timeoutId; - } else { - if (!maxTimeoutId && !leading) { - lastCalled = stamp; - } - var remaining = maxWait - (stamp - lastCalled), - isCalled = remaining <= 0 || remaining > maxWait; - - if (isCalled) { - if (maxTimeoutId) { - maxTimeoutId = clearTimeout(maxTimeoutId); - } - lastCalled = stamp; - result = func.apply(thisArg, args); - } - else if (!maxTimeoutId) { - maxTimeoutId = setTimeout(maxDelayed, remaining); - } - } - if (isCalled && timeoutId) { - timeoutId = clearTimeout(timeoutId); - } - else if (!timeoutId && wait !== maxWait) { - timeoutId = setTimeout(delayed, wait); - } - if (leadingCall) { - isCalled = true; - result = func.apply(thisArg, args); - } - if (isCalled && !timeoutId && !maxTimeoutId) { - args = thisArg = undefined; - } - return result; - } - debounced.cancel = cancel; - return debounced; - } - - /** - * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. - * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) - * - * @static - * @memberOf _ - * @category Lang - * @param {*} value The value to check. - * @returns {boolean} Returns `true` if `value` is an object, else `false`. - * @example - * - * _.isObject({}); - * // => true - * - * _.isObject([1, 2, 3]); - * // => true - * - * _.isObject(1); - * // => false - */ - function isObject(value) { - // Avoid a V8 JIT bug in Chrome 19-20. - // See https://code.google.com/p/v8/issues/detail?id=2291 for more details. - var type = typeof value; - return !!value && (type == 'object' || type == 'function'); - } - - return debounce; - - })(); - - module.exports = debounce; - },{}],4:[function(require,module,exports){ - module.exports = function (opts, cy, debounce) { - - var options = opts; - - var changeOptions = function (opts) { - options = opts; - }; - - var offset = function(elt) { - var rect = elt.getBoundingClientRect(); - - return { - top: rect.top + document.documentElement.scrollTop, - left: rect.left + document.documentElement.scrollLeft - } - }; - - var $canvas = document.createElement('canvas'); - var $container = cy.container(); - var ctx = $canvas.getContext( '2d' ); - $container.appendChild( $canvas ); - - var resetCanvas = function () { - $canvas.height = 0; - $canvas.width = 0; - $canvas.style.position = 'absolute'; - $canvas.style.top = 0; - $canvas.style.left = 0; - $canvas.style.zIndex = options.gridStackOrder; - }; - - resetCanvas(); - - var drawGrid = function() { - var zoom = cy.zoom(); - var canvasWidth = cy.width(); - var canvasHeight = cy.height(); - var increment = options.gridSpacing*zoom; - var pan = cy.pan(); - var initialValueX = pan.x%increment; - var initialValueY = pan.y%increment; - - ctx.strokeStyle = options.gridColor; - ctx.lineWidth = options.lineWidth; - - var data = '\t\n\ - \n\ - \n\ - \n\ - \n\ - \n\ - \n\ - \n\ - \n\ - \n\ - \n\ - \n'; - - var img = new Image(); - data = encodeURIComponent(data); - - img.onload = function () { - clearDrawing(); - ctx.drawImage(img, 0, 0); - }; - - img.src = "data:image/svg+xml," + data; - }; - - var clearDrawing = function() { - var width = cy.width(); - var height = cy.height(); - - ctx.clearRect( 0, 0, width, height ); - }; - - var resizeCanvas = debounce(function() { - $canvas.height = cy.height(); - $canvas.width = cy.width(); - $canvas.style.position = 'absolute'; - $canvas.style.top = 0; - $canvas.style.left = 0; - $canvas.style.zIndex = options.gridStackOrder; - - setTimeout( function() { - $canvas.height = cy.height(); - $canvas.width = cy.width(); - - var canvasBb = offset($canvas); - var containerBb = offset($container); - $canvas.style.top = -(canvasBb.top - containerBb.top); - $canvas.style.left = -(canvasBb.left - containerBb.left); - drawGrid(); - }, 0 ); - - }, 250); - - - - - return { - initCanvas: resizeCanvas, - resizeCanvas: resizeCanvas, - resetCanvas: resetCanvas, - clearCanvas: clearDrawing, - drawGrid: drawGrid, - changeOptions: changeOptions, - sizeCanvas: drawGrid - }; - }; - - },{}],5:[function(require,module,exports){ - module.exports = function (cy, snap, resize, snapToGridDuringDrag, drawGrid, guidelines, parentPadding, opts) { - - var feature = function (func) { - return function (enable) { - func(enable); - }; - }; - - var controller = { - snapToGridDuringDrag: new feature(setDiscreteDrag), - resize: new feature(setResize), - snapToGridOnRelease: new feature(setSnapToGrid), - drawGrid: new feature(setDrawGrid), - guidelines: new feature(setGuidelines), - parentPadding: new feature(setParentPadding) - }; - - function applyToCyTarget(func, allowParent) { - return function (e) { - var cyTarget = e.target || e.cyTarget; - if (!cyTarget.is(":parent") || allowParent) - func(cyTarget); - } - } - - function applyToAllNodesButNoParent(func) { - return function () { - cy.nodes().not(":parent").each(function (ele, i) { - if(typeof ele === "number") { - ele = i; - } - - func(ele); - }); - }; - } - function applyToAllNodes(func) { - return function () { - cy.nodes().each(function (ele, i) { - if(typeof ele === "number") { - ele = i; - } - - func(ele); - }); - }; - } - - function eventStatus(enable) { - return enable ? "on" : "off"; - } - - - // Discrete Drag - function setDiscreteDrag(enable) { - cy[eventStatus(enable)]("tapstart", "node", snapToGridDuringDrag.onTapStartNode); - } - - // Resize - var resizeAllNodes = applyToAllNodesButNoParent(resize.resizeNode); - var resizeNode = applyToCyTarget(resize.resizeNode); - var recoverAllNodeDimensions = applyToAllNodesButNoParent(resize.recoverNodeDimensions); - - function setResize(enable) { - cy[eventStatus(enable)]("ready", resizeAllNodes); - // cy[eventStatus(enable)]("style", "node", resizeNode); - enable ? resizeAllNodes() : recoverAllNodeDimensions(); - } - - // Snap To Grid - var snapAllNodes = applyToAllNodes(snap.snapNodesTopDown); - var recoverSnapAllNodes = applyToAllNodes(snap.recoverSnapNode); - var snapCyTarget = applyToCyTarget(snap.snapNode, true); - - function setSnapToGrid(enable) { - cy[eventStatus(enable)]("add", "node", snapCyTarget); - cy[eventStatus(enable)]("ready", snapAllNodes); - - cy[eventStatus(enable)]("free", "node", snap.onFreeNode); - - if (enable) { - snapAllNodes(); - } else { - recoverSnapAllNodes(); - } - } - - // Draw Grid - var drawGridOnZoom = function () { - if (currentOptions.zoomDash) drawGrid.drawGrid() - }; - var drawGridOnPan = function () { - if (currentOptions.panGrid) drawGrid.drawGrid() - }; - - function setDrawGrid(enable) { - cy[eventStatus(enable)]('zoom', drawGridOnZoom); - cy[eventStatus(enable)]('pan', drawGridOnPan); - - if (enable) { - drawGrid.initCanvas(); - cy.on('resize', drawGrid.resizeCanvas); - } else { - drawGrid.clearCanvas(); - drawGrid.resetCanvas(); - cy.off('resize', drawGrid.resizeCanvas); - } - } - - // Guidelines - var activeTopMostNodes = null; - var guidelinesGrabHandler = function(e){ - var cyTarget = e.target || e.cyTarget; - var nodes = cyTarget.selected() ? e.cy.$(":selected") : cyTarget; - activeTopMostNodes = guidelines.getTopMostNodes(nodes.nodes()); - guidelines.lines.init(activeTopMostNodes); - } - var guidelinesDragHandler = function(e){ - if (this.id() == activeTopMostNodes.id()){ - guidelines.lines.update(activeTopMostNodes); - - if (currentOptions.snapToAlignmentLocationDuringDrag) - guidelines.lines.snapToAlignmentLocation(activeTopMostNodes); - } - }; - var guidelinesFreeHandler = function(e){ - if (currentOptions.snapToAlignmentLocationOnRelease) - guidelines.lines.snapToAlignmentLocation(activeTopMostNodes); - - guidelines.lines.destroy(); - activeTopMostNodes = null; - }; - var guidelinesWindowResizeHandler = function(e){ - guidelines.lines.resize(); - }; - var guidelinesTapHandler = function(e){ - guidelines.getMousePos(e); - }; - var guidelinesPanHandler = function(e){ - if (activeTopMostNodes){ - guidelines.setMousePos(cy.pan()); - guidelines.lines.init(activeTopMostNodes); - } - } - function setGuidelines(enable) { - if (enable){ - guidelines.resizeCanvas(); - cy.on("tapstart", "node", guidelinesTapHandler); - cy.on("grab", guidelinesGrabHandler); - cy.on("pan", guidelinesPanHandler); - cy.on("drag", "node", guidelinesDragHandler); - cy.on("free", guidelinesFreeHandler); - window.addEventListener('resize', guidelinesWindowResizeHandler); - } - else{ - cy.off("tapstart", "node", guidelinesTapHandler); - cy.off("grab", guidelinesGrabHandler); - cy.off("pan", guidelinesPanHandler); - cy.off("drag", "node", guidelinesDragHandler); - cy.off("free", guidelinesFreeHandler); - guidelines.resetCanvas(); - window.removeEventListener('resize', guidelinesWindowResizeHandler); - } - } - - // Parent Padding - var setAllParentPaddings = function (enable) { - parentPadding.setPaddingOfParent(cy.nodes(":parent"), enable); - }; - var enableParentPadding = function (node) { - parentPadding.setPaddingOfParent(node, true); - }; - - - function setParentPadding(enable) { - - setAllParentPaddings(enable); - - cy[eventStatus(enable)]('ready', setAllParentPaddings); - cy[eventStatus(enable)]("add", "node:parent", applyToCyTarget(enableParentPadding, true)); - } - - // Sync with options: Enables/disables changed via options. - var latestOptions = {}; - var currentOptions; - - var specialOpts = { - drawGrid: ["gridSpacing", "zoomDash", "panGrid", "gridStackOrder", "gridColor", "lineWidth", "lineDash"], - guidelines: ["gridSpacing", "guidelinesStackOrder", "guidelinesTolerance", "guidelinesStyle", "distributionGuidelines", "range", "minDistRange", "geometricGuidelineRange"], - resize: ["gridSpacing"], - parentPadding: ["gridSpacing", "parentSpacing"], - snapToGridOnRelease: ["gridSpacing", "snapToGridCenter"] - }; - - function syncWithOptions(options) { - currentOptions = Object.extend({}, options); - options.guidelines = options.initPosAlignment || options.distributionGuidelines || options.geometricGuideline; - for (var key in options) - if (latestOptions[key] != options[key]) - if (controller.hasOwnProperty(key)) { - controller[key](options[key]); - } else { - for (var optsKey in specialOpts) { - var opts = specialOpts[optsKey]; - if (opts.indexOf(key) >= 0) { - if(optsKey == "drawGrid") { - drawGrid.changeOptions(options); - if (options.drawGrid) - drawGrid.resizeCanvas(); - } - - if (optsKey == "snapToGridOnRelease"){ - snap.changeOptions(options); - if (options.snapToGridOnRelease) - snapAllNodes(); - } - - if(optsKey == "guidelines") - guidelines.changeOptions(options); - - if (optsKey == "resize") { - resize.changeOptions(options); - if (options.resize) - resizeAllNodes(); - } - - if (optsKey == "parentPadding") - parentPadding.changeOptions(options); - - - } - } - } - latestOptions = Object.extend({}, latestOptions, options); - } - - return { - init: syncWithOptions, - syncWithOptions: syncWithOptions - }; - - }; - - },{}],6:[function(require,module,exports){ - /** - * Deep copy or merge objects - replacement for jQuery deep extend - * Taken from http://youmightnotneedjquery.com/#deep_extend - * and bug related to deep copy of Arrays is fixed. - * Usage:Object.extend({}, objA, objB) - */ - - Object.extend = function(out) { - out = out || {}; - - for (var i = 1; i < arguments.length; i++) { - var obj = arguments[i]; - - if (!obj) - continue; - - for (var key in obj) { - if (obj.hasOwnProperty(key)) { - if (Array.isArray(obj[key])) { - out[key] = obj[key].slice(); - } else if (typeof obj[key] === 'object') { - out[key] = Object.extend(out[key], obj[key]); - } else { - out[key] = obj[key]; - } - } - } - } - - return out; - }; - - },{}],7:[function(require,module,exports){ - module.exports = function (opts, cy, debounce) { - - - var RBTree = require("functional-red-black-tree"); - - var options = opts; - - var changeOptions = function (opts) { - options = opts; - - // RBTree always returns null, when low == high - // to avoid this: - if (options.guidelinesTolerance == 0) - options.guidelinesTolerance = 0.001; - }; - - var offset = function(elt) { - var rect = elt.getBoundingClientRect(); - - return { - top: rect.top + document.documentElement.scrollTop, - left: rect.left + document.documentElement.scrollLeft - } - }; - - var getCyScratch = function () { - var sc = cy.scratch("_guidelines"); - if (!sc) - sc = cy.scratch("_guidelines", {}); - - return sc; - }; - - /* Resize canvas */ - var resizeCanvas = debounce(function () { - clearDrawing(); - $canvas.height = cy.height(); - $canvas.width = cy.width(); - $canvas.style.position = 'absolute'; - $canvas.style.top = 0; - $canvas.style.left = 0; - $canvas.style.zIndex = options.guidelinesStackOrder; - - setTimeout(function () { - - $canvas.height = cy.height(); - $canvas.width = cy.width(); - - var canvasBb = offset($canvas); - var containerBb = offset($container); - $canvas.style.top = -(canvasBb.top - containerBb.top); - $canvas.style.left = -(canvasBb.left - containerBb.left); - }, 0); - }, 250); - - /* Clear canvas */ - var clearDrawing = function () { - var width = cy.width(); - var height = cy.height(); - ctx.clearRect(0, 0, width, height); - }; - - /* Create a canvas */ - var $canvas = document.createElement('canvas'); - var $container = cy.container(); - var ctx = $canvas.getContext('2d'); - $container.appendChild( $canvas ); - - var resetCanvas = function () { - $canvas.height = 0; - $canvas.width = 0; - $canvas.style.position = 'absolute'; - $canvas.style.top = 0; - $canvas.style.left = 0; - $canvas.style.zIndex = options.guidelinesStackOrder; - }; - - resetCanvas(); - - /* Global variables */ - var VTree = null; - var HTree = null; - var nodeInitPos; - var excludedNodes; - var lines = {}; - var panInitPos = {}; - var alignedLocations = {"h" : null, "v" : null}; - - /** - * Get positions of sides of a node - * @param node : a node - * @return : object of positions - */ - lines.getDims = function (node) { - var pos = node.renderedPosition(); - var width = node.renderedWidth(); - var height = node.renderedHeight(); - var padding = { - left: Number(node.renderedStyle("padding-left").replace("px", "")), - right: Number(node.renderedStyle("padding-right").replace("px", "")), - top: Number(node.renderedStyle("padding-top").replace("px", "")), - bottom: Number(node.renderedStyle("padding-bottom").replace("px", "")) - }; - - return { - horizontal: { - center: (pos.x), - left: Math.round(pos.x - (padding.left + width / 2)), - right: Math.round(pos.x + (padding.right + width / 2)) - }, - vertical: { - center: (pos.y), - top: Math.round(pos.y - (padding.top + height / 2)), - bottom: Math.round(pos.y + (padding.bottom + height / 2)) - } - }; - }; - - /** - * Initialize trees and initial position of node - * @param activeNodes : top most active nodes - */ - lines.init = function (activeNodes) { - VTree = RBTree(); - HTree = RBTree(); - // TODO: seperate initialization of nodeInitPos - // not necessary to init trees when geometric and distribution alignments are disabled, - // but reference guideline is enables - if (!nodeInitPos){ - panInitPos.x = cy.pan("x"); panInitPos.y = cy.pan("y"); - nodeInitPos = activeNodes.renderedPosition(); - } - - var nodes = cy.nodes(":visible"); - excludedNodes = activeNodes.union(activeNodes.ancestors()); - excludedNodes = excludedNodes.union(activeNodes.descendants()); - nodes.not(excludedNodes).each(function (node, i) { - if(typeof node === "number") { - node = i; - } - var dims = lines.getDims(node); - - ["left", "center", "right"].forEach(function (val) { - var hKey = dims.horizontal[val]; - if (HTree.get(hKey)) - HTree.get(hKey).push(node); - else - HTree = HTree.insert(hKey, [node]); - }); - - ["top", "center", "bottom"].forEach(function (val) { - var vKey = dims.vertical[val]; - if (VTree.get(vKey)) - VTree.get(vKey).push(node); - else - VTree = VTree.insert(vKey, [node]); - }); - - }); - ctx.lineWidth=options.lineWidth; - lines.update(activeNodes); - }; - - /* Destroy gobal variables */ - lines.destroy = function () { - lines.clear(); - VTree = null; HTree = null; - nodeInitPos = null; - mouseInitPos = {}; - alignedLocations = {"h" : null, "v" : null}; - if (nodeToAlign){ - nodeToAlign.unlock(); - nodeToAlign = undefined; - } - }; - - lines.clear = clearDrawing; - - /** - * Draw straight line - * @param from : initial position - * @param to : final position - * @param color : color of the line - * @param lineStyle : whether line is solid or dashed - */ - lines.drawLine = function (from, to, color, lineStyle) { - ctx.setLineDash(lineStyle); - ctx.beginPath(); - ctx.moveTo(from.x, from.y); - ctx.lineTo(to.x, to.y); - ctx.strokeStyle = color; - ctx.stroke(); - }; - - /** - * Draw an arrow - * @param position : position of the arrow - * @param type : type/directşon of the arrow - */ - lines.drawArrow = function(position, type){ - if (type == "right"){ - // right arrow - ctx.setLineDash([]); - ctx.beginPath(); - ctx.moveTo(position.x-5, position.y-5); - ctx.lineTo(position.x, position.y); - ctx.lineTo(position.x-5, position.y+5); - ctx.stroke(); - } - else if (type == "left"){ - // left arrow - ctx.setLineDash([]); - ctx.beginPath(); - ctx.moveTo(position.x+5, position.y-5); - ctx.lineTo(position.x, position.y); - ctx.lineTo(position.x+5, position.y+5); - ctx.stroke(); - } - else if (type == "top"){ - // up arrow - ctx.setLineDash([]); - ctx.beginPath(); - ctx.moveTo(position.x-5, position.y+5); - ctx.lineTo(position.x, position.y); - ctx.lineTo(position.x+5, position.y+5); - ctx.stroke(); - } - else if (type == "bottom"){ - // down arrow - ctx.setLineDash([]); - ctx.beginPath(); - ctx.moveTo(position.x-5, position.y-5); - ctx.lineTo(position.x, position.y); - ctx.lineTo(position.x+5, position.y-5); - ctx.stroke(); - } - - } - - /** - * Draw a cross - x - * @param position : position of the cross - */ - lines.drawCross = function(position){ - ctx.setLineDash([]); - ctx.beginPath(); - ctx.moveTo(position.x - 5, position.y + 5); - ctx.lineTo(position.x + 5, position.y - 5); - ctx.moveTo(position.x - 5, position.y - 5); - ctx.lineTo(position.x + 5, position.y + 5); - ctx.stroke(); - }; - - /** - * Calculate the amount of offset for distribution guidelines - * @param nodes - list of nodes - * @param type - horizontal or vertical - */ - var calculateOffset = function(nodes, type){ - var minNode = nodes[0], min = lines.getDims(minNode)[type]["center"]; - var maxNode = nodes[0], max = lines.getDims(maxNode)[type]["center"]; - - for (var i = 0; i < nodes.length; i++){ - var node = nodes[i]; - if (lines.getDims(node)[type]["center"] < min){ - min = lines.getDims(node)[type]["center"]; minNode = node; - } - if (lines.getDims(node)[type]["center"] > max){ - max = lines.getDims(node)[type]["center"]; maxNode = node; - } - } - - if (type == "horizontal") - var offset = (min + max) / 2 < lines.getDims(nodes[1])[type]["center"] ? max + (0.5*maxNode.width() + options.guidelinesStyle.distGuidelineOffset)*cy.zoom() : min - (0.5*minNode.width() + options.guidelinesStyle.distGuidelineOffset)*cy.zoom(); - else - var offset = (min + max) / 2 < lines.getDims(nodes[1])[type]["center"] ? max + (0.5*maxNode.height() + options.guidelinesStyle.distGuidelineOffset)*cy.zoom() : min - (0.5*minNode.height() + options.guidelinesStyle.distGuidelineOffset)*cy.zoom(); - - return offset; - } - /** Guidelines for horizontally distributed alignment - * @param: node the node to be aligned - */ - lines.horizontalDistribution = function(node){ - // variables - var leftNode = null, rightNode = null; - var nodeDim = lines.getDims(node); - var Xcenter = nodeDim["horizontal"]["center"]; - var Ycenter = nodeDim["vertical"]["center"]; - // Find nodes in range and check if they align - HTree.forEach(function(key, nodes){ - - for (var i = 0; i < nodes.length; i++){ - var left = nodes[i]; - var leftDim = lines.getDims(left); - if (Math.abs(leftDim["vertical"]["center"] - nodeDim["vertical"]["center"]) < options.guidelinesStyle.range*cy.zoom()){ - if ((leftDim["horizontal"]["right"]) == key && - nodeDim["horizontal"]["left"] - leftDim["horizontal"]["right"] > options.guidelinesStyle.minDistRange){ - var ripo = Math.round(2*Xcenter)-key; - HTree.forEach(function($, rightNodes){ - for (var j = 0; j < rightNodes.length; j++){ - var right = rightNodes[j]; - if (Math.abs(lines.getDims(right)["vertical"]["center"] - Ycenter) < options.guidelinesStyle.range*cy.zoom()){ - if (Math.abs(ripo - lines.getDims(right)["horizontal"]["left"]) < 2*options.guidelinesTolerance){ - leftNode = left; rightNode = right; - } - } - } - }, ripo - options.guidelinesTolerance, ripo + options.guidelinesTolerance); - } - } - } - }, Xcenter - options.guidelinesStyle.range*cy.zoom(), Xcenter); - - // Draw the lines - if (leftNode){ - alignedLocations.hd = Xcenter - (lines.getDims(rightNode)["horizontal"]["left"] + lines.getDims(leftNode)["horizontal"]["right"]) / 2.0; - if (!options.geometricGuideline || alignedLocations.h == null || Math.abs(alignedLocations.h) > Math.abs(alignedLocations.hd)){ - alignedLocations.h = alignedLocations.hd; - } - var offset = calculateOffset([leftNode, node, rightNode], "vertical"); - - lines.drawLine({ - x: lines.getDims(leftNode)["horizontal"]["right"], - y: offset - }, { - x: nodeDim["horizontal"]["left"], - y: offset - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawLine({ - x: lines.getDims(rightNode)["horizontal"]["left"], - y: offset - }, { - x: nodeDim["horizontal"]["right"], - y: offset - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawLine({ - x: lines.getDims(leftNode)["horizontal"]["right"], - y: offset - }, { - x: lines.getDims(leftNode)["horizontal"]["right"], - y: lines.getDims(leftNode)["vertical"]["center"] - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawLine({ - x: lines.getDims(rightNode)["horizontal"]["left"], - y: offset - }, { - x: lines.getDims(rightNode)["horizontal"]["left"], - y: lines.getDims(rightNode)["vertical"]["center"] - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawLine({ - x: nodeDim["horizontal"]["left"], - y: offset - }, { - x: nodeDim["horizontal"]["left"], - y: Ycenter - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawLine({ - x: nodeDim["horizontal"]["right"], - y: offset - }, { - x: nodeDim["horizontal"]["right"], - y: Ycenter - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawArrow({ - x: lines.getDims(leftNode)["horizontal"]["right"], - y: offset}, "left"); - - lines.drawArrow({ - x: nodeDim["horizontal"]["left"], - y: offset}, "right"); - - lines.drawArrow({ - x: nodeDim["horizontal"]["right"], - y: offset}, "left"); - - lines.drawArrow({ - x: lines.getDims(rightNode)["horizontal"]["left"], - y: offset}, "right"); - - } - else{ - var state = lines.horizontalDistributionNext(node,"left" ); - - if (!state) - lines.horizontalDistributionNext(node,"right" ); - } - } - - /** Guidelines for horizontally distributed alignment - * @param: node the node to be aligned - */ - lines.verticalDistribution = function(node){ - // variables - var belowNode = null, aboveNode = null; - var nodeDim = lines.getDims(node); - var Xcenter = nodeDim["horizontal"]["center"]; - var Ycenter = nodeDim["vertical"]["center"]; - // Find nodes in range and check if they align - VTree.forEach(function(key, nodes){ - - for (var i = 0; i < nodes.length; i++){ - var below = nodes[i]; - var belowDim = lines.getDims(below); - if (Math.abs(belowDim["horizontal"]["center"] - nodeDim["horizontal"]["center"]) < options.guidelinesStyle.range*cy.zoom()){ - if (belowDim["vertical"]["bottom"] == key && - nodeDim["vertical"]["top"] - belowDim["vertical"]["bottom"] > options.guidelinesStyle.minDistRange){ - var abpo = Math.round((2*Ycenter)-key); - VTree.forEach(function($, aboveNodes){ - //if (aboveNodes){ - for (var j = 0; j < aboveNodes.length; j++){ - var above = aboveNodes[j]; - if (Math.abs(lines.getDims(above)["horizontal"]["center"] - Xcenter) < options.guidelinesStyle.range*cy.zoom()){ - if (Math.abs(abpo - lines.getDims(above)["vertical"]["top"]) < 2*options.guidelinesTolerance){ - belowNode = below; aboveNode = above; - } - } - } - //} - }, abpo - options.guidelinesTolerance, abpo + options.guidelinesTolerance); - } - } - } - }, Ycenter - options.guidelinesStyle.range*cy.zoom(), Ycenter); - - if (belowNode){ - alignedLocations.vd = Ycenter - (lines.getDims(belowNode)["vertical"]["bottom"] + lines.getDims(aboveNode)["vertical"]["top"]) / 2.0; - if (!options.geometricGuideline || alignedLocations.v == null || Math.abs(alignedLocations.v) > Math.abs(alignedLocations.vd)){ - alignedLocations.v = alignedLocations.vd; - } - var offset = calculateOffset([belowNode, node, aboveNode], "horizontal"); - lines.drawLine({ - y: lines.getDims(belowNode)["vertical"]["bottom"],//renderedPosition("x"), - x: offset - }, { - y: nodeDim["vertical"]["top"], - x: offset - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - y: lines.getDims(aboveNode)["vertical"]["top"],//renderedPosition("x"), - x: offset - }, { - y: nodeDim["vertical"]["bottom"], - x: offset - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - y: lines.getDims(belowNode)["vertical"]["bottom"],//renderedPosition("x"), - x: offset - }, { - y: lines.getDims(belowNode)["vertical"]["bottom"], - x: lines.getDims(belowNode)["horizontal"]["center"] - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - y: lines.getDims(aboveNode)["vertical"]["top"],//renderedPosition("x"), - x: offset - }, { - y: lines.getDims(aboveNode)["vertical"]["top"], - x: lines.getDims(aboveNode)["horizontal"]["center"] - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - y: nodeDim["vertical"]["bottom"],//renderedPosition("x"), - x: offset - }, { - y: nodeDim["vertical"]["bottom"],//renderedPosition("x"), - x: Xcenter - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - y: nodeDim["vertical"]["top"],//renderedPosition("x"), - x: offset - }, { - y: nodeDim["vertical"]["top"],//renderedPosition("x"), - x: Xcenter - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawArrow({ - x: offset, - y: lines.getDims(belowNode)["vertical"]["bottom"]}, "top"); - - lines.drawArrow({ - x: offset, - y: nodeDim["vertical"]["top"]}, "bottom"); - - lines.drawArrow({ - x: offset, - y: lines.getDims(aboveNode)["vertical"]["top"]}, "bottom"); - - lines.drawArrow({ - x: offset, - y: nodeDim["vertical"]["bottom"]}, "top"); - } - else{ - var state = lines.verticalDistributionNext(node,"below" ); - - if (!state) - lines.verticalDistributionNext(node,"above" ); - } - } - - /** - * Find geometric alignment lines and draw them - * @param type: horizontal or vertical - * @param node: the node to be aligned - */ - lines.searchForLine = function (type, node) { - - // variables - var position, target, center, axis, otherAxis, Tree, closestKey; - var dims = lines.getDims(node)[type]; - var targetKey = Number.MAX_SAFE_INTEGER; - - // initialize Tree - if ( type == "horizontal"){ - Tree = HTree; - axis = "y"; - otherAxis = "x"; - alignedLocations.h = null; - } else{ - Tree = VTree; - axis = "x"; - otherAxis = "y"; - alignedLocations.v = null; - } - - center = node.renderedPosition(axis); - // check if node aligned in any dimension: - // {center, left, right} or {center, top, bottom} - for (var dimKey in dims) { - position = dims[dimKey]; - - // find the closest alignment in range of tolerance - Tree.forEach(function (exKey, nodes) { - for (var i = 0; i < nodes.length; i++){ - var n = nodes[i]; - if (options.centerToEdgeAlignment || (dimKey != "center" && n.renderedPosition(otherAxis) != exKey) || (dimKey == "center" && n.renderedPosition(otherAxis) == exKey)){ - var dif = Math.abs(center - n.renderedPosition(axis)); - if ( dif < targetKey && dif < options.guidelinesStyle.geometricGuidelineRange*cy.zoom()){ - target = n; - targetKey = dif; - closestKey = exKey; - } - } - } - }, position - Number(options.guidelinesTolerance), position + Number(options.guidelinesTolerance)); - - // if alignment found, draw lines and break - if (target) { - targetKey = lines.getDims(node)[type][dimKey]; - - // Draw horizontal or vertical alignment line - if (type == "horizontal") { - alignedLocations.h = targetKey - closestKey; - lines.drawLine({ - x: targetKey, - y: node.renderedPosition("y") - }, { - x: targetKey, - y: target.renderedPosition("y") - }, options.guidelinesStyle.strokeStyle, options.guidelinesStyle.lineDash); - } else { - alignedLocations.v = targetKey - closestKey; - lines.drawLine({ - x: node.renderedPosition("x"), - y: targetKey - }, { - x: target.renderedPosition("x"), - y: targetKey - }, options.guidelinesStyle.strokeStyle, options.guidelinesStyle.lineDash); - } - break; - } - } - }; - - lines.horizontalDistributionNext = function(node, type){ - - // variables - var leftNode = null, rightNode = null; - var nodeDim = lines.getDims(node); - var Xcenter = nodeDim["horizontal"]["center"]; - var Ycenter = nodeDim["vertical"]["center"]; - var side = "right", otherSide = "left"; - var lowerBound = Xcenter; - if (type == "left"){ - side = "left"; otherSide = "right"; - var lowerBound = Xcenter - options.guidelinesStyle.range*cy.zoom(); - } - - var compare = { - "left": function (x, y) { return y - x > options.guidelinesStyle.minDistRange}, - "right": function (x, y) { return x - y > options.guidelinesStyle.minDistRange} - } - - // Find nodes in range and check if they align - HTree.forEach(function(key, nodes){ - for (var i = 0; i < nodes.length; i++){ - var left = nodes[i]; - var leftDim = lines.getDims(left); - if (Math.abs(leftDim["vertical"]["center"] - nodeDim["vertical"]["center"]) < options.guidelinesStyle.range*cy.zoom()){ - if ((leftDim["horizontal"][otherSide]) == key && - compare[type](leftDim["horizontal"][otherSide], nodeDim["horizontal"][side])){ - var ll = leftDim["horizontal"][side]-(nodeDim["horizontal"][side] - key); - HTree.forEach(function($, rightNodes){ - for (var j = 0; j < rightNodes.length; j++){ - var right = rightNodes[j]; - if (Math.abs(lines.getDims(right)["vertical"]["center"] - Ycenter) < options.guidelinesStyle.range*cy.zoom()){ - if (Math.abs(ll - lines.getDims(right)["horizontal"][otherSide]) < 2*options.guidelinesTolerance){ - leftNode = left; rightNode = right; - } - } - } - }, ll - options.guidelinesTolerance, ll + options.guidelinesTolerance); - } - } - } - }, lowerBound, lowerBound + options.guidelinesStyle.range*cy.zoom()); - - // Draw the lines - if (leftNode){ - alignedLocations.hd =(lines.getDims(node)["horizontal"][side] - lines.getDims(leftNode)["horizontal"][otherSide]) - (lines.getDims(leftNode)["horizontal"][side] - lines.getDims(rightNode)["horizontal"][otherSide]); - if (!options.geometricGuideline || alignedLocations.h == null || Math.abs(alignedLocations.h) > Math.abs(alignedLocations.hd)){ - alignedLocations.h = alignedLocations.hd; - } - - lines.drawDH(node, leftNode, rightNode, type); - return true; - } - else if (!options.geometricGuideline){ - alignedLocations.h = null; - } - return false; - - } - - lines.drawDH = function(node, leftNode, rightNode, type){ - var Ycenter = lines.getDims(node)["vertical"]["center"]; - var side = "right", otherSide = "left"; - if (type == "left"){ - side = "left"; otherSide = "right"; - } - var offset = calculateOffset([leftNode, node, rightNode], "vertical"); - - lines.drawLine({ - x: lines.getDims(leftNode)["horizontal"][otherSide], - y: offset - }, { - x: lines.getDims(node)["horizontal"][side], - y: offset - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawLine({ - x: lines.getDims(node)["horizontal"][side], - y: offset - }, { - x: lines.getDims(node)["horizontal"][side], - y: Ycenter,//lines.getDims(leftNode)["vertical"]["center"] - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawLine({ - x: lines.getDims(rightNode)["horizontal"][otherSide], - y: offset - }, { - x: lines.getDims(leftNode)["horizontal"][side], - y: offset - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - lines.drawLine({ - x: lines.getDims(rightNode)["horizontal"][otherSide], - y: offset - }, { - x: lines.getDims(rightNode)["horizontal"][otherSide], - y: lines.getDims(rightNode)["vertical"]["center"] - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawLine({ - x: lines.getDims(leftNode)["horizontal"][otherSide], - y: offset - }, { - x: lines.getDims(leftNode)["horizontal"][otherSide], - y: lines.getDims(leftNode)["vertical"]["center"] - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - lines.drawLine({ - x: lines.getDims(leftNode)["horizontal"][side], - y: offset - }, { - x: lines.getDims(leftNode)["horizontal"][side], - y: lines.getDims(leftNode)["vertical"]["center"] - }, options.guidelinesStyle.horizontalDistColor, options.guidelinesStyle.horizontalDistLine); - - - lines.drawArrow({ - x: lines.getDims(node)["horizontal"][side], - y: offset}, otherSide); - - lines.drawArrow({ - x: lines.getDims(leftNode)["horizontal"][otherSide], - y: offset}, side); - - lines.drawArrow({ - x: lines.getDims(leftNode)["horizontal"][side], - y: offset}, otherSide); - - lines.drawArrow({ - x: lines.getDims(rightNode)["horizontal"][otherSide], - y: offset}, side); - - } - - lines.verticalDistributionNext = function(node, type){ - // variables - var belowNode = null, aboveNode = null; - var nodeDim = lines.getDims(node); - var Xcenter = nodeDim["horizontal"]["center"]; - var Ycenter = nodeDim["vertical"]["center"]; - var side = "top", otherSide = "bottom"; - var lowerBound = Ycenter - options.guidelinesStyle.range*cy.zoom(); - if (type == "above"){ - side = "bottom"; otherSide = "top"; - lowerBound = Ycenter; - } - - var compare = { - "below": function (x, y) { return y - x > options.guidelinesStyle.minDistRange}, - "above": function (x, y) { return x - y > options.guidelinesStyle.minDistRange} - } - // Find nodes in range and check if they align - VTree.forEach(function(key, nodes){ - for (var i = 0; i < nodes.length; i++){ - var below = nodes[i]; - var belowDim = lines.getDims(below); - if (Math.abs(belowDim["horizontal"]["center"] - nodeDim["horizontal"]["center"]) < options.guidelinesStyle.range*cy.zoom()){ - if (belowDim["vertical"][otherSide] == key && - compare[type](belowDim["vertical"][otherSide], nodeDim["vertical"][side])){ - var ll = belowDim["vertical"][side]-(nodeDim["vertical"][side]-key); - VTree.forEach(function($, aboveNodes){ - for (var j = 0; j < aboveNodes.length; j++){ - var above = aboveNodes[j]; - if (Math.abs(lines.getDims(above)["horizontal"]["center"] - Xcenter) < options.guidelinesStyle.range*cy.zoom()){ - if (Math.abs(ll - lines.getDims(above)["vertical"][otherSide]) < 2*options.guidelinesTolerance){ - belowNode = below; aboveNode = above; - } - } - } - }, ll - options.guidelinesTolerance, ll + options.guidelinesTolerance); - } - } - } - }, lowerBound, lowerBound+options.guidelinesStyle.range*cy.zoom()); - - if (belowNode){ - alignedLocations.vd =(lines.getDims(node)["vertical"][side] - lines.getDims(belowNode)["vertical"][otherSide]) - (lines.getDims(belowNode)["vertical"][side] - lines.getDims(aboveNode)["vertical"][otherSide]); - if (!options.geometricGuideline || alignedLocations.v == null || Math.abs(alignedLocations.v) > Math.abs(alignedLocations.vd)){ - alignedLocations.v = alignedLocations.vd; - } - lines.drawDV(node, belowNode, aboveNode, type); - return true; - } - else if (!options.geometricGuideline){ - alignedLocations.v = null; - } - return false; - } - - - - lines.drawDV = function(node, belowNode, aboveNode, type){ - var nodeDim = lines.getDims(node); - var Xcenter = nodeDim["horizontal"]["center"]; - var side = "top", otherSide = "bottom"; - if (type == "above"){ - side = "bottom"; otherSide = "top"; - } - - var offset = calculateOffset([belowNode, node, aboveNode], "horizontal"); - lines.drawLine({ - x: offset, - y: nodeDim["vertical"][side] - }, { - x: offset, - y: lines.getDims(belowNode)["vertical"][otherSide] - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - x: offset, - y: lines.getDims(belowNode)["vertical"][side] - }, { - x: offset, - y: lines.getDims(aboveNode)["vertical"][otherSide] - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - x: Xcenter, - y: nodeDim["vertical"][side] - }, { - x: offset, - y: nodeDim["vertical"][side] - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - x: lines.getDims(belowNode)["horizontal"]["center"], - y: lines.getDims(belowNode)["vertical"][otherSide] - }, { - x: offset, - y: lines.getDims(belowNode)["vertical"][otherSide] - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - x: lines.getDims(belowNode)["horizontal"]["center"], - y: lines.getDims(belowNode)["vertical"][side] - }, { - x: offset, - y: lines.getDims(belowNode)["vertical"][side] - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawLine({ - x: offset,//lines.getDims(aboveNode)["horizontal"]["center"], - y: lines.getDims(aboveNode)["vertical"][otherSide] - }, { - x: lines.getDims(aboveNode)["horizontal"]["center"], - y: lines.getDims(aboveNode)["vertical"][otherSide] - }, options.guidelinesStyle.verticalDistColor, options.guidelinesStyle.verticalDistLine); - - lines.drawArrow({ - x: offset, - y: nodeDim["vertical"][side]}, otherSide); - - lines.drawArrow({ - x: offset, - y: lines.getDims(belowNode)["vertical"][otherSide]}, side); - - lines.drawArrow({ - x: offset, - y: lines.getDims(belowNode)["vertical"][side]}, otherSide); - - lines.drawArrow({ - x: offset, - y: lines.getDims(aboveNode)["vertical"][otherSide]}, side); - - } - lines.update = function (activeNodes) { - lines.clear(); - - if (options.initPosAlignment){ - mouseLine(activeNodes); - } - - activeNodes.each(function (node, i) { - if(typeof node === "number") { - node = i; - } - if (options.geometricGuideline){ - lines.searchForLine("horizontal", node); - lines.searchForLine("vertical", node); - } - - if (options.distributionGuidelines){ - lines.horizontalDistribution(node); - lines.verticalDistribution(node); - } - }); - - }; - - lines.resize = function () { - resizeCanvas(); - }; - - function getTopMostNodes(nodes) { - var nodesMap = {}; - - for (var i = 0; i < nodes.length; i++) { - nodesMap[nodes[i].id()] = true; - } - - var roots = nodes.filter(function (ele, i) { - if(typeof ele === "number") { - ele = i; - } - - var parent = ele.parent()[0]; - while (parent != null) { - if (nodesMap[parent.id()]) { - return false; - } - parent = parent.parent()[0]; - } - return true; - }); - - return roots; - } - - var mouseInitPos = {}; - var mouseRelativePos = {}; - var getMousePos = function(e){ - mouseInitPos = e.renderedPosition || e.cyRenderedPosition; - mouseRelativePos.x = mouseInitPos.x; - mouseRelativePos.y = mouseInitPos.y; - } - var setMousePos = function(panCurrPos){ - mouseRelativePos.x += (panCurrPos.x - panInitPos.x); - mouseRelativePos.y += (panCurrPos.y - panInitPos.y); - panInitPos.x = panCurrPos.x; panInitPos.y = panCurrPos.y; - }; - var mouseLine = function(node){ - var nodeCurrentPos = node.renderedPosition(); - if (Math.abs(nodeInitPos.y - nodeCurrentPos.y) < options.guidelinesTolerance){ - lines.drawLine({ - "x" : mouseRelativePos.x, - "y" : mouseInitPos.y - }, { - "x" : nodeCurrentPos.x, - "y" : mouseInitPos.y - }, options.guidelinesStyle.initPosAlignmentColor, options.guidelinesStyle.initPosAlignmentLine); - if (mouseInitPos.y == mouseRelativePos.y){ - lines.drawCross(mouseRelativePos); - } - else{ - lines.drawCross(mouseInitPos); - } - } - else if (Math.abs(nodeInitPos.x - nodeCurrentPos.x) < options.guidelinesTolerance){ - lines.drawLine({ - "x" : mouseInitPos.x, - "y" : mouseRelativePos.y - }, { - "x" : mouseInitPos.x, - "y" : nodeCurrentPos.y - }, options.guidelinesStyle.initPosAlignmentColor, options.guidelinesStyle.initPosAlignmentLine); - if (mouseInitPos.x == mouseRelativePos.x){ - lines.drawCross(mouseRelativePos); - } - else{ - lines.drawCross(mouseInitPos); - } - } - } - - function moveNodes(positionDiff, nodes) { - // Get the descendants of top most nodes. Note that node.position() can move just the simple nodes. - var topMostNodes = getTopMostNodes(nodes); - var nodesToMove = topMostNodes.union(topMostNodes.descendants()); - - nodesToMove.filter(":childless").forEach(function(node, i) { - if(typeof node === "number") { - node = i; - } - var newPos = {x: positionDiff.x + node.renderedPosition("x"), - y: positionDiff.y + node.renderedPosition("y")}; - - node.renderedPosition(newPos); - }); - } - - var tappedNode; - cy.on("tapstart", "node", function(){tappedNode = this}); - - var currMousePos, oldMousePos = {"x": 0, "y": 0}; - cy.on("mousemove", function(e){ - currMousePos = e.renderedPosition || e.cyRenderedPosition; - if (nodeToAlign) - nodeToAlign.each(function (node, i){ - if(typeof node === "number") { - node = i; - } - if (node.locked() && (Math.abs(currMousePos.x - oldMousePos.x) > 2*options.guidelinesTolerance - || Math.abs(currMousePos.y - oldMousePos.y) > 2*options.guidelinesTolerance)){ - - node.unlock(); - var diff = {}; - diff.x = currMousePos.x - tappedNode.renderedPosition("x"); - diff.y = currMousePos.y - tappedNode.renderedPosition("y");; - moveNodes(diff, node); - }; - }); - - }); - var nodeToAlign; - lines.snapToAlignmentLocation = function(activeNodes){ - nodeToAlign = activeNodes; - activeNodes.each(function (node, i){ - if(typeof node === "number") { - node = i; - } - var newPos = node.renderedPosition(); - if (alignedLocations.h){ - oldMousePos = currMousePos; - newPos.x -= alignedLocations.h; - node.renderedPosition(newPos); - } - if (alignedLocations.v){ - oldMousePos = currMousePos; - newPos.y -= alignedLocations.v; - node.renderedPosition(newPos); - }; - if (alignedLocations.v || alignedLocations.h){ - alignedLocations.h = null; - alignedLocations.v = null; - nodeToAlign.lock(); - } - }); - lines.update(activeNodes); - } - - return { - changeOptions: changeOptions, - lines: lines, - getTopMostNodes: getTopMostNodes, - getMousePos: getMousePos, - setMousePos: setMousePos, - resizeCanvas: resizeCanvas, - resetCanvas: resetCanvas, - } - }; - - },{"functional-red-black-tree":1}],8:[function(require,module,exports){ - ;(function(){ 'use strict'; - - // registers the extension on a cytoscape lib ref - var register = function(cytoscape){ - - if(!cytoscape){ return; } // can't register if cytoscape unspecified - require("./extend"); - - // flag that indicates if extension api functions are registed to cytoscape - // note that ideally these functions should not be directly registered to core from cytoscape.js - // extensions - var apiRegistered = false; - - var defaults = { - // On/Off Modules - /* From the following four snap options, at most one should be true at a given time */ - snapToGridOnRelease: true, // Snap to grid on release - snapToGridDuringDrag: false, // Snap to grid during drag - snapToAlignmentLocationOnRelease: false, // Snap to alignment location on release - snapToAlignmentLocationDuringDrag: false, // Snap to alignment location during drag - distributionGuidelines: false, //Distribution guidelines - geometricGuideline: false, // Geometric guidelines - initPosAlignment: false, // Guideline to initial mouse position - centerToEdgeAlignment: false, // Center tı edge alignment - resize: false, // Adjust node sizes to cell sizes - parentPadding: false, // Adjust parent sizes to cell sizes by padding - drawGrid: true, // Draw grid background - - // General - gridSpacing: 20, // Distance between the lines of the grid. - snapToGridCenter: true, // Snaps nodes to center of gridlines. When false, snaps to gridlines themselves. - zoomDash: true, // Determines whether the size of the dashes should change when the drawing is zoomed in and out if grid is drawn. - panGrid: false, // Determines whether the grid should move then the user moves the graph if grid is drawn. - gridStackOrder: -1, // Namely z-index - gridColor: '#dedede', // Color of grid lines - lineWidth: 1.0, // Width of grid lines - guidelinesStackOrder: 4, // z-index of guidelines - guidelinesTolerance: 2.00, // Tolerance distance for rendered positions of nodes' interaction. - guidelinesStyle: { // Set ctx properties of line. Properties are here: - strokeStyle: "#8b7d6b", // color of geometric guidelines - geometricGuidelineRange: 400, // range of geometric guidelines - range: 100, // max range of distribution guidelines - minDistRange: 10, // min range for distribution guidelines - distGuidelineOffset: 10, // shift amount of distribution guidelines - horizontalDistColor: "#ff0000", // color of horizontal distribution alignment - verticalDistColor: "#00ff00", // color of vertical distribution alignment - initPosAlignmentColor: "#0000ff", // color of alignment to initial location - lineDash: [0, 0], // line style of geometric guidelines - horizontalDistLine: [0, 0], // line style of horizontal distribıtion guidelines - verticalDistLine: [0, 0], // line style of vertical distribıtion guidelines - initPosAlignmentLine: [0, 0], // line style of alignment to initial mouse position - }, - - // Parent Padding - parentSpacing: -1 // -1 to set paddings of parents to gridSpacing - }; - var _snapOnRelease = require("./snap_on_release"); - var _snapToGridDuringDrag = require("./snap_during_drag"); - var _drawGrid = require("./draw_grid"); - var _resize = require("./resize"); - var _eventsController = require("./events_controller"); - var _guidelines = require("./guidelines"); - var _parentPadding = require("./parentPadding"); - var _alignment = require("./alignment"); - var debounce = require("./debounce"); - - function getScratch(cy) { - if (!cy.scratch("_gridGuide")) { - cy.scratch("_gridGuide", { }); - } - - return cy.scratch("_gridGuide"); - } - - cytoscape( 'core', 'gridGuide', function(opts){ - var cy = this; - - // access the scratch pad for cy - var scratchPad = getScratch(cy); - - // extend the already existing options for the instance or the default options - var options = Object.extend({}, scratchPad.options || defaults, opts); - - // reset the options for the instance - scratchPad.options = options; - - if (!scratchPad.initialized) { - - var snap, resize, snapToGridDuringDrag, drawGrid, eventsController, guidelines, parentPadding, alignment; - - snap = _snapOnRelease(cy, options.gridSpacing, options.snapToGridCenter); - resize = _resize(options.gridSpacing); - snapToGridDuringDrag = _snapToGridDuringDrag(cy, snap); - drawGrid = _drawGrid(options, cy, debounce); - guidelines = _guidelines(options, cy, debounce); - parentPadding = _parentPadding(options, cy); - - eventsController = _eventsController(cy, snap, resize, snapToGridDuringDrag, drawGrid, guidelines, parentPadding, options); - - alignment = _alignment(cytoscape, cy, apiRegistered); - - // mark that api functions are registered to cytoscape - apiRegistered = true; - - eventsController.init(options); - - // init params in scratchPad - scratchPad.initialized = true; - scratchPad.eventsController = eventsController; - } - else { - var eventsController = scratchPad.eventsController; - eventsController.syncWithOptions(options); - } - - return this; // chainability - } ) ; - - }; - - if( typeof module !== 'undefined' && module.exports ){ // expose as a commonjs module - module.exports = register; - } - - if( typeof define !== 'undefined' && define.amd ){ // expose as an amd/requirejs module - define('cytoscape-grid-guide', function(){ - return register; - }); - } - - if( typeof cytoscape !== 'undefined' ){ // expose to global cytoscape (i.e. window.cytoscape) - register( cytoscape ); - } - - })(); - - },{"./alignment":2,"./debounce":3,"./draw_grid":4,"./events_controller":5,"./extend":6,"./guidelines":7,"./parentPadding":9,"./resize":10,"./snap_during_drag":11,"./snap_on_release":12}],9:[function(require,module,exports){ - module.exports = function (opts, cy) { - - var options = opts; - var ppClass = "_gridParentPadding"; - var padding; - - function initPadding() { - cy.style() - .selector('.' + ppClass) - .style("compound-sizing-wrt-labels", "exclude") - .style("padding-left", padding) - .style("padding-right", padding) - .style("padding-top", padding) - .style("padding-bottom", padding) - .update(); - - } - - function changeOptions(opts) { - options = opts; - padding = options.parentSpacing < 0 ? options.gridSpacing : options.parentSpacing; - initPadding(); - } - - function setPaddingOfParent(node, enable) { - if (enable) - node.addClass(ppClass); - else - node.removeClass(ppClass); - } - - return { - changeOptions: changeOptions, - setPaddingOfParent: setPaddingOfParent - }; - }; - },{}],10:[function(require,module,exports){ - module.exports = function (gridSpacing) { - - - var changeOptions = function (opts) { - gridSpacing = Number(opts.gridSpacing); - }; - - var getScratch = function (node) { - if (!node.scratch("_gridGuide")) - node.scratch("_gridGuide", {}); - - return node.scratch("_gridGuide"); - }; - - function resizeNode(node) { - var width = node.width(); - var height = node.height(); - - var newWidth = Math.round((width - gridSpacing) / (gridSpacing * 2)) * (gridSpacing * 2); - var newHeight = Math.round((height - gridSpacing) / (gridSpacing * 2)) * (gridSpacing * 2); - newWidth = newWidth > 0 ? newWidth + gridSpacing : gridSpacing; - newHeight = newHeight > 0 ? newHeight + gridSpacing : gridSpacing; - - if (width != newWidth || height != newHeight) { - node.style({ - "width": newWidth, - "height": newHeight - }); - getScratch(node).resize = { - oldWidth: width, - oldHeight: height - }; - } - } - - function recoverNodeDimensions(node) { - var oldSizes = getScratch(node).resize; - if (oldSizes) - node.style({ - "width": oldSizes.oldWidth, - "height": oldSizes.oldHeight - }); - - - } - - - return { - resizeNode: resizeNode, - recoverNodeDimensions: recoverNodeDimensions, - changeOptions: changeOptions - }; - - }; - },{}],11:[function(require,module,exports){ - module.exports = function (cy, snap) { - - var snapToGridDuringDrag = {}; - - var attachedNode; - var draggedNodes; - - var startPos; - var endPos; - - snapToGridDuringDrag.onTapStartNode = function (e) { - // If user intends to do box selection, then return. Related issue #28 - if (e.originalEvent.altKey || e.originalEvent.ctrlKey - || e.originalEvent.metaKey || e.originalEvent.shiftKey){ - return; - } - - var cyTarget = e.target || e.cyTarget; - if (cyTarget.selected()) - draggedNodes = e.cy.$(":selected"); - else - draggedNodes = cyTarget; - - startPos = e.position || e.cyPosition; - - if (cyTarget.grabbable() && !cyTarget.locked()){ - attachedNode = cyTarget; - attachedNode.lock(); - //attachedNode.trigger("grab"); - cy.on("tapdrag", onTapDrag); - cy.on("tapend", onTapEndNode); - } - }; - - var onTapEndNode = function (e) { - //attachedNode.trigger("free"); - cy.off("tapdrag", onTapDrag); - cy.off("tapend", onTapEndNode); - attachedNode.unlock(); - e.preventDefault(); - }; - - var getDist = function () { - return { - x: endPos.x - startPos.x, - y: endPos.y - startPos.y - } - }; - - var onTapDrag = function (e) { - - var nodePos = attachedNode.position(); - endPos = e.position || e.cyPosition; - endPos = snap.snapPos(endPos); - var dist = getDist(); - if (dist.x != 0 || dist.y != 0) { - attachedNode.unlock(); - var nodes = draggedNodes.union(draggedNodes.descendants()); - - nodes.filter(":childless").positions(function (node, i) { - if(typeof node === "number") { - node = i; - } - var pos = node.position(); - return snap.snapPos({ - x: pos.x + dist.x, - y: pos.y + dist.y - }); - }); - - startPos = endPos; - attachedNode.lock(); - attachedNode.trigger("drag"); - } - - }; - - return snapToGridDuringDrag; - - - }; - - },{}],12:[function(require,module,exports){ - module.exports = function (cy, gridSpacing, gridSpacingOffset) { - - var snap = { }; - - snap.changeOptions = function (opts) { - gridSpacing = opts.gridSpacing; - gridSpacingOffset = opts.snapToGridCenter ? 0.5 : 0; - }; - - var getScratch = function (node) { - if (!node.scratch("_gridGuide")) - node.scratch("_gridGuide", {}); - - return node.scratch("_gridGuide"); - }; - - snap.snapPos = function (pos) { - var xPosition = gridSpacingOffset ? Math.floor(pos.x / gridSpacing) : Math.round(pos.x / gridSpacing); - var yPosition = gridSpacingOffset ? Math.floor(pos.y / gridSpacing) : Math.round(pos.y / gridSpacing); - var newPos = { - x: (xPosition + gridSpacingOffset) * gridSpacing, - y: (yPosition + gridSpacingOffset) * gridSpacing - }; - - return newPos; - }; - - snap.snapNode = function (node) { - - var pos = node.position(); - var newPos = snap.snapPos(pos); - - node.position(newPos); - }; - - snap.snapNodesTopDown = function (nodes) { - // getTOpMostNodes -> nodes - cy.startBatch(); - nodes.union(nodes.descendants()).filter(":childless").positions(function (node, i) { - if(typeof node === "number") { - node = i; - } - var pos = node.position(); - return snap.snapPos(pos); - }); - cy.endBatch(); - }; - - snap.onFreeNode = function (e) { - var nodes; - var cyTarget = e.target || e.cyTarget; - if (cyTarget.selected()) - nodes = e.cy.$(":selected"); - else - nodes = cyTarget; - - snap.snapNodesTopDown(nodes); - - }; - - - snap.recoverSnapNode = function (node) { - var snapScratch = getScratch(node).snap; - if (snapScratch) { - node.position(snapScratch.oldPos); - } - }; - - return snap; - - - - - - }; - - },{}]},{},[8]); - \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/cytoscape/libs/jszip.min.js b/rawTopoFile/topoviewer/html-static/js/cytoscape/libs/jszip.min.js deleted file mode 100755 index ff4cfd5e8..000000000 --- a/rawTopoFile/topoviewer/html-static/js/cytoscape/libs/jszip.min.js +++ /dev/null @@ -1,13 +0,0 @@ -/*! - -JSZip v3.10.1 - A JavaScript class for generating and reading zip files - - -(c) 2009-2016 Stuart Knightley -Dual licenced under the MIT license or GPLv3. See https://raw.github.com/Stuk/jszip/main/LICENSE.markdown. - -JSZip uses the library pako released under the MIT license : -https://github.com/nodeca/pako/blob/main/LICENSE -*/ - -!function(e){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{("undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this).JSZip=e()}}(function(){return function s(a,o,h){function u(r,e){if(!o[r]){if(!a[r]){var t="function"==typeof require&&require;if(!e&&t)return t(r,!0);if(l)return l(r,!0);var n=new Error("Cannot find module '"+r+"'");throw n.code="MODULE_NOT_FOUND",n}var i=o[r]={exports:{}};a[r][0].call(i.exports,function(e){var t=a[r][1][e];return u(t||e)},i,i.exports,s,a,o,h)}return o[r].exports}for(var l="function"==typeof require&&require,e=0;e>2,s=(3&t)<<4|r>>4,a=1>6:64,o=2>4,r=(15&i)<<4|(s=p.indexOf(e.charAt(o++)))>>2,n=(3&s)<<6|(a=p.indexOf(e.charAt(o++))),l[h++]=t,64!==s&&(l[h++]=r),64!==a&&(l[h++]=n);return l}},{"./support":30,"./utils":32}],2:[function(e,t,r){"use strict";var n=e("./external"),i=e("./stream/DataWorker"),s=e("./stream/Crc32Probe"),a=e("./stream/DataLengthProbe");function o(e,t,r,n,i){this.compressedSize=e,this.uncompressedSize=t,this.crc32=r,this.compression=n,this.compressedContent=i}o.prototype={getContentWorker:function(){var e=new i(n.Promise.resolve(this.compressedContent)).pipe(this.compression.uncompressWorker()).pipe(new a("data_length")),t=this;return e.on("end",function(){if(this.streamInfo.data_length!==t.uncompressedSize)throw new Error("Bug : uncompressed data size mismatch")}),e},getCompressedWorker:function(){return new i(n.Promise.resolve(this.compressedContent)).withStreamInfo("compressedSize",this.compressedSize).withStreamInfo("uncompressedSize",this.uncompressedSize).withStreamInfo("crc32",this.crc32).withStreamInfo("compression",this.compression)}},o.createWorkerFrom=function(e,t,r){return e.pipe(new s).pipe(new a("uncompressedSize")).pipe(t.compressWorker(r)).pipe(new a("compressedSize")).withStreamInfo("compression",t)},t.exports=o},{"./external":6,"./stream/Crc32Probe":25,"./stream/DataLengthProbe":26,"./stream/DataWorker":27}],3:[function(e,t,r){"use strict";var n=e("./stream/GenericWorker");r.STORE={magic:"\0\0",compressWorker:function(){return new n("STORE compression")},uncompressWorker:function(){return new n("STORE decompression")}},r.DEFLATE=e("./flate")},{"./flate":7,"./stream/GenericWorker":28}],4:[function(e,t,r){"use strict";var n=e("./utils");var o=function(){for(var e,t=[],r=0;r<256;r++){e=r;for(var n=0;n<8;n++)e=1&e?3988292384^e>>>1:e>>>1;t[r]=e}return t}();t.exports=function(e,t){return void 0!==e&&e.length?"string"!==n.getTypeOf(e)?function(e,t,r,n){var i=o,s=n+r;e^=-1;for(var a=n;a>>8^i[255&(e^t[a])];return-1^e}(0|t,e,e.length,0):function(e,t,r,n){var i=o,s=n+r;e^=-1;for(var a=n;a>>8^i[255&(e^t.charCodeAt(a))];return-1^e}(0|t,e,e.length,0):0}},{"./utils":32}],5:[function(e,t,r){"use strict";r.base64=!1,r.binary=!1,r.dir=!1,r.createFolders=!0,r.date=null,r.compression=null,r.compressionOptions=null,r.comment=null,r.unixPermissions=null,r.dosPermissions=null},{}],6:[function(e,t,r){"use strict";var n=null;n="undefined"!=typeof Promise?Promise:e("lie"),t.exports={Promise:n}},{lie:37}],7:[function(e,t,r){"use strict";var n="undefined"!=typeof Uint8Array&&"undefined"!=typeof Uint16Array&&"undefined"!=typeof Uint32Array,i=e("pako"),s=e("./utils"),a=e("./stream/GenericWorker"),o=n?"uint8array":"array";function h(e,t){a.call(this,"FlateWorker/"+e),this._pako=null,this._pakoAction=e,this._pakoOptions=t,this.meta={}}r.magic="\b\0",s.inherits(h,a),h.prototype.processChunk=function(e){this.meta=e.meta,null===this._pako&&this._createPako(),this._pako.push(s.transformTo(o,e.data),!1)},h.prototype.flush=function(){a.prototype.flush.call(this),null===this._pako&&this._createPako(),this._pako.push([],!0)},h.prototype.cleanUp=function(){a.prototype.cleanUp.call(this),this._pako=null},h.prototype._createPako=function(){this._pako=new i[this._pakoAction]({raw:!0,level:this._pakoOptions.level||-1});var t=this;this._pako.onData=function(e){t.push({data:e,meta:t.meta})}},r.compressWorker=function(e){return new h("Deflate",e)},r.uncompressWorker=function(){return new h("Inflate",{})}},{"./stream/GenericWorker":28,"./utils":32,pako:38}],8:[function(e,t,r){"use strict";function A(e,t){var r,n="";for(r=0;r>>=8;return n}function n(e,t,r,n,i,s){var a,o,h=e.file,u=e.compression,l=s!==O.utf8encode,f=I.transformTo("string",s(h.name)),c=I.transformTo("string",O.utf8encode(h.name)),d=h.comment,p=I.transformTo("string",s(d)),m=I.transformTo("string",O.utf8encode(d)),_=c.length!==h.name.length,g=m.length!==d.length,b="",v="",y="",w=h.dir,k=h.date,x={crc32:0,compressedSize:0,uncompressedSize:0};t&&!r||(x.crc32=e.crc32,x.compressedSize=e.compressedSize,x.uncompressedSize=e.uncompressedSize);var S=0;t&&(S|=8),l||!_&&!g||(S|=2048);var z=0,C=0;w&&(z|=16),"UNIX"===i?(C=798,z|=function(e,t){var r=e;return e||(r=t?16893:33204),(65535&r)<<16}(h.unixPermissions,w)):(C=20,z|=function(e){return 63&(e||0)}(h.dosPermissions)),a=k.getUTCHours(),a<<=6,a|=k.getUTCMinutes(),a<<=5,a|=k.getUTCSeconds()/2,o=k.getUTCFullYear()-1980,o<<=4,o|=k.getUTCMonth()+1,o<<=5,o|=k.getUTCDate(),_&&(v=A(1,1)+A(B(f),4)+c,b+="up"+A(v.length,2)+v),g&&(y=A(1,1)+A(B(p),4)+m,b+="uc"+A(y.length,2)+y);var E="";return E+="\n\0",E+=A(S,2),E+=u.magic,E+=A(a,2),E+=A(o,2),E+=A(x.crc32,4),E+=A(x.compressedSize,4),E+=A(x.uncompressedSize,4),E+=A(f.length,2),E+=A(b.length,2),{fileRecord:R.LOCAL_FILE_HEADER+E+f+b,dirRecord:R.CENTRAL_FILE_HEADER+A(C,2)+E+A(p.length,2)+"\0\0\0\0"+A(z,4)+A(n,4)+f+b+p}}var I=e("../utils"),i=e("../stream/GenericWorker"),O=e("../utf8"),B=e("../crc32"),R=e("../signature");function s(e,t,r,n){i.call(this,"ZipFileWorker"),this.bytesWritten=0,this.zipComment=t,this.zipPlatform=r,this.encodeFileName=n,this.streamFiles=e,this.accumulate=!1,this.contentBuffer=[],this.dirRecords=[],this.currentSourceOffset=0,this.entriesCount=0,this.currentFile=null,this._sources=[]}I.inherits(s,i),s.prototype.push=function(e){var t=e.meta.percent||0,r=this.entriesCount,n=this._sources.length;this.accumulate?this.contentBuffer.push(e):(this.bytesWritten+=e.data.length,i.prototype.push.call(this,{data:e.data,meta:{currentFile:this.currentFile,percent:r?(t+100*(r-n-1))/r:100}}))},s.prototype.openedSource=function(e){this.currentSourceOffset=this.bytesWritten,this.currentFile=e.file.name;var t=this.streamFiles&&!e.file.dir;if(t){var r=n(e,t,!1,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);this.push({data:r.fileRecord,meta:{percent:0}})}else this.accumulate=!0},s.prototype.closedSource=function(e){this.accumulate=!1;var t=this.streamFiles&&!e.file.dir,r=n(e,t,!0,this.currentSourceOffset,this.zipPlatform,this.encodeFileName);if(this.dirRecords.push(r.dirRecord),t)this.push({data:function(e){return R.DATA_DESCRIPTOR+A(e.crc32,4)+A(e.compressedSize,4)+A(e.uncompressedSize,4)}(e),meta:{percent:100}});else for(this.push({data:r.fileRecord,meta:{percent:0}});this.contentBuffer.length;)this.push(this.contentBuffer.shift());this.currentFile=null},s.prototype.flush=function(){for(var e=this.bytesWritten,t=0;t=this.index;t--)r=(r<<8)+this.byteAt(t);return this.index+=e,r},readString:function(e){return n.transformTo("string",this.readData(e))},readData:function(){},lastIndexOfSignature:function(){},readAndCheckSignature:function(){},readDate:function(){var e=this.readInt(4);return new Date(Date.UTC(1980+(e>>25&127),(e>>21&15)-1,e>>16&31,e>>11&31,e>>5&63,(31&e)<<1))}},t.exports=i},{"../utils":32}],19:[function(e,t,r){"use strict";var n=e("./Uint8ArrayReader");function i(e){n.call(this,e)}e("../utils").inherits(i,n),i.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=i},{"../utils":32,"./Uint8ArrayReader":21}],20:[function(e,t,r){"use strict";var n=e("./DataReader");function i(e){n.call(this,e)}e("../utils").inherits(i,n),i.prototype.byteAt=function(e){return this.data.charCodeAt(this.zero+e)},i.prototype.lastIndexOfSignature=function(e){return this.data.lastIndexOf(e)-this.zero},i.prototype.readAndCheckSignature=function(e){return e===this.readData(4)},i.prototype.readData=function(e){this.checkOffset(e);var t=this.data.slice(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=i},{"../utils":32,"./DataReader":18}],21:[function(e,t,r){"use strict";var n=e("./ArrayReader");function i(e){n.call(this,e)}e("../utils").inherits(i,n),i.prototype.readData=function(e){if(this.checkOffset(e),0===e)return new Uint8Array(0);var t=this.data.subarray(this.zero+this.index,this.zero+this.index+e);return this.index+=e,t},t.exports=i},{"../utils":32,"./ArrayReader":17}],22:[function(e,t,r){"use strict";var n=e("../utils"),i=e("../support"),s=e("./ArrayReader"),a=e("./StringReader"),o=e("./NodeBufferReader"),h=e("./Uint8ArrayReader");t.exports=function(e){var t=n.getTypeOf(e);return n.checkSupport(t),"string"!==t||i.uint8array?"nodebuffer"===t?new o(e):i.uint8array?new h(n.transformTo("uint8array",e)):new s(n.transformTo("array",e)):new a(e)}},{"../support":30,"../utils":32,"./ArrayReader":17,"./NodeBufferReader":19,"./StringReader":20,"./Uint8ArrayReader":21}],23:[function(e,t,r){"use strict";r.LOCAL_FILE_HEADER="PK",r.CENTRAL_FILE_HEADER="PK",r.CENTRAL_DIRECTORY_END="PK",r.ZIP64_CENTRAL_DIRECTORY_LOCATOR="PK",r.ZIP64_CENTRAL_DIRECTORY_END="PK",r.DATA_DESCRIPTOR="PK\b"},{}],24:[function(e,t,r){"use strict";var n=e("./GenericWorker"),i=e("../utils");function s(e){n.call(this,"ConvertWorker to "+e),this.destType=e}i.inherits(s,n),s.prototype.processChunk=function(e){this.push({data:i.transformTo(this.destType,e.data),meta:e.meta})},t.exports=s},{"../utils":32,"./GenericWorker":28}],25:[function(e,t,r){"use strict";var n=e("./GenericWorker"),i=e("../crc32");function s(){n.call(this,"Crc32Probe"),this.withStreamInfo("crc32",0)}e("../utils").inherits(s,n),s.prototype.processChunk=function(e){this.streamInfo.crc32=i(e.data,this.streamInfo.crc32||0),this.push(e)},t.exports=s},{"../crc32":4,"../utils":32,"./GenericWorker":28}],26:[function(e,t,r){"use strict";var n=e("../utils"),i=e("./GenericWorker");function s(e){i.call(this,"DataLengthProbe for "+e),this.propName=e,this.withStreamInfo(e,0)}n.inherits(s,i),s.prototype.processChunk=function(e){if(e){var t=this.streamInfo[this.propName]||0;this.streamInfo[this.propName]=t+e.data.length}i.prototype.processChunk.call(this,e)},t.exports=s},{"../utils":32,"./GenericWorker":28}],27:[function(e,t,r){"use strict";var n=e("../utils"),i=e("./GenericWorker");function s(e){i.call(this,"DataWorker");var t=this;this.dataIsReady=!1,this.index=0,this.max=0,this.data=null,this.type="",this._tickScheduled=!1,e.then(function(e){t.dataIsReady=!0,t.data=e,t.max=e&&e.length||0,t.type=n.getTypeOf(e),t.isPaused||t._tickAndRepeat()},function(e){t.error(e)})}n.inherits(s,i),s.prototype.cleanUp=function(){i.prototype.cleanUp.call(this),this.data=null},s.prototype.resume=function(){return!!i.prototype.resume.call(this)&&(!this._tickScheduled&&this.dataIsReady&&(this._tickScheduled=!0,n.delay(this._tickAndRepeat,[],this)),!0)},s.prototype._tickAndRepeat=function(){this._tickScheduled=!1,this.isPaused||this.isFinished||(this._tick(),this.isFinished||(n.delay(this._tickAndRepeat,[],this),this._tickScheduled=!0))},s.prototype._tick=function(){if(this.isPaused||this.isFinished)return!1;var e=null,t=Math.min(this.max,this.index+16384);if(this.index>=this.max)return this.end();switch(this.type){case"string":e=this.data.substring(this.index,t);break;case"uint8array":e=this.data.subarray(this.index,t);break;case"array":case"nodebuffer":e=this.data.slice(this.index,t)}return this.index=t,this.push({data:e,meta:{percent:this.max?this.index/this.max*100:0}})},t.exports=s},{"../utils":32,"./GenericWorker":28}],28:[function(e,t,r){"use strict";function n(e){this.name=e||"default",this.streamInfo={},this.generatedError=null,this.extraStreamInfo={},this.isPaused=!0,this.isFinished=!1,this.isLocked=!1,this._listeners={data:[],end:[],error:[]},this.previous=null}n.prototype={push:function(e){this.emit("data",e)},end:function(){if(this.isFinished)return!1;this.flush();try{this.emit("end"),this.cleanUp(),this.isFinished=!0}catch(e){this.emit("error",e)}return!0},error:function(e){return!this.isFinished&&(this.isPaused?this.generatedError=e:(this.isFinished=!0,this.emit("error",e),this.previous&&this.previous.error(e),this.cleanUp()),!0)},on:function(e,t){return this._listeners[e].push(t),this},cleanUp:function(){this.streamInfo=this.generatedError=this.extraStreamInfo=null,this._listeners=[]},emit:function(e,t){if(this._listeners[e])for(var r=0;r "+e:e}},t.exports=n},{}],29:[function(e,t,r){"use strict";var h=e("../utils"),i=e("./ConvertWorker"),s=e("./GenericWorker"),u=e("../base64"),n=e("../support"),a=e("../external"),o=null;if(n.nodestream)try{o=e("../nodejs/NodejsStreamOutputAdapter")}catch(e){}function l(e,o){return new a.Promise(function(t,r){var n=[],i=e._internalType,s=e._outputType,a=e._mimeType;e.on("data",function(e,t){n.push(e),o&&o(t)}).on("error",function(e){n=[],r(e)}).on("end",function(){try{var e=function(e,t,r){switch(e){case"blob":return h.newBlob(h.transformTo("arraybuffer",t),r);case"base64":return u.encode(t);default:return h.transformTo(e,t)}}(s,function(e,t){var r,n=0,i=null,s=0;for(r=0;r>>6:(r<65536?t[s++]=224|r>>>12:(t[s++]=240|r>>>18,t[s++]=128|r>>>12&63),t[s++]=128|r>>>6&63),t[s++]=128|63&r);return t}(e)},s.utf8decode=function(e){return h.nodebuffer?o.transformTo("nodebuffer",e).toString("utf-8"):function(e){var t,r,n,i,s=e.length,a=new Array(2*s);for(t=r=0;t>10&1023,a[r++]=56320|1023&n)}return a.length!==r&&(a.subarray?a=a.subarray(0,r):a.length=r),o.applyFromCharCode(a)}(e=o.transformTo(h.uint8array?"uint8array":"array",e))},o.inherits(a,n),a.prototype.processChunk=function(e){var t=o.transformTo(h.uint8array?"uint8array":"array",e.data);if(this.leftOver&&this.leftOver.length){if(h.uint8array){var r=t;(t=new Uint8Array(r.length+this.leftOver.length)).set(this.leftOver,0),t.set(r,this.leftOver.length)}else t=this.leftOver.concat(t);this.leftOver=null}var n=function(e,t){var r;for((t=t||e.length)>e.length&&(t=e.length),r=t-1;0<=r&&128==(192&e[r]);)r--;return r<0?t:0===r?t:r+u[e[r]]>t?r:t}(t),i=t;n!==t.length&&(h.uint8array?(i=t.subarray(0,n),this.leftOver=t.subarray(n,t.length)):(i=t.slice(0,n),this.leftOver=t.slice(n,t.length))),this.push({data:s.utf8decode(i),meta:e.meta})},a.prototype.flush=function(){this.leftOver&&this.leftOver.length&&(this.push({data:s.utf8decode(this.leftOver),meta:{}}),this.leftOver=null)},s.Utf8DecodeWorker=a,o.inherits(l,n),l.prototype.processChunk=function(e){this.push({data:s.utf8encode(e.data),meta:e.meta})},s.Utf8EncodeWorker=l},{"./nodejsUtils":14,"./stream/GenericWorker":28,"./support":30,"./utils":32}],32:[function(e,t,a){"use strict";var o=e("./support"),h=e("./base64"),r=e("./nodejsUtils"),u=e("./external");function n(e){return e}function l(e,t){for(var r=0;r>8;this.dir=!!(16&this.externalFileAttributes),0==e&&(this.dosPermissions=63&this.externalFileAttributes),3==e&&(this.unixPermissions=this.externalFileAttributes>>16&65535),this.dir||"/"!==this.fileNameStr.slice(-1)||(this.dir=!0)},parseZIP64ExtraField:function(){if(this.extraFields[1]){var e=n(this.extraFields[1].value);this.uncompressedSize===s.MAX_VALUE_32BITS&&(this.uncompressedSize=e.readInt(8)),this.compressedSize===s.MAX_VALUE_32BITS&&(this.compressedSize=e.readInt(8)),this.localHeaderOffset===s.MAX_VALUE_32BITS&&(this.localHeaderOffset=e.readInt(8)),this.diskNumberStart===s.MAX_VALUE_32BITS&&(this.diskNumberStart=e.readInt(4))}},readExtraFields:function(e){var t,r,n,i=e.index+this.extraFieldsLength;for(this.extraFields||(this.extraFields={});e.index+4>>6:(r<65536?t[s++]=224|r>>>12:(t[s++]=240|r>>>18,t[s++]=128|r>>>12&63),t[s++]=128|r>>>6&63),t[s++]=128|63&r);return t},r.buf2binstring=function(e){return l(e,e.length)},r.binstring2buf=function(e){for(var t=new h.Buf8(e.length),r=0,n=t.length;r>10&1023,o[n++]=56320|1023&i)}return l(o,n)},r.utf8border=function(e,t){var r;for((t=t||e.length)>e.length&&(t=e.length),r=t-1;0<=r&&128==(192&e[r]);)r--;return r<0?t:0===r?t:r+u[e[r]]>t?r:t}},{"./common":41}],43:[function(e,t,r){"use strict";t.exports=function(e,t,r,n){for(var i=65535&e|0,s=e>>>16&65535|0,a=0;0!==r;){for(r-=a=2e3>>1:e>>>1;t[r]=e}return t}();t.exports=function(e,t,r,n){var i=o,s=n+r;e^=-1;for(var a=n;a>>8^i[255&(e^t[a])];return-1^e}},{}],46:[function(e,t,r){"use strict";var h,c=e("../utils/common"),u=e("./trees"),d=e("./adler32"),p=e("./crc32"),n=e("./messages"),l=0,f=4,m=0,_=-2,g=-1,b=4,i=2,v=8,y=9,s=286,a=30,o=19,w=2*s+1,k=15,x=3,S=258,z=S+x+1,C=42,E=113,A=1,I=2,O=3,B=4;function R(e,t){return e.msg=n[t],t}function T(e){return(e<<1)-(4e.avail_out&&(r=e.avail_out),0!==r&&(c.arraySet(e.output,t.pending_buf,t.pending_out,r,e.next_out),e.next_out+=r,t.pending_out+=r,e.total_out+=r,e.avail_out-=r,t.pending-=r,0===t.pending&&(t.pending_out=0))}function N(e,t){u._tr_flush_block(e,0<=e.block_start?e.block_start:-1,e.strstart-e.block_start,t),e.block_start=e.strstart,F(e.strm)}function U(e,t){e.pending_buf[e.pending++]=t}function P(e,t){e.pending_buf[e.pending++]=t>>>8&255,e.pending_buf[e.pending++]=255&t}function L(e,t){var r,n,i=e.max_chain_length,s=e.strstart,a=e.prev_length,o=e.nice_match,h=e.strstart>e.w_size-z?e.strstart-(e.w_size-z):0,u=e.window,l=e.w_mask,f=e.prev,c=e.strstart+S,d=u[s+a-1],p=u[s+a];e.prev_length>=e.good_match&&(i>>=2),o>e.lookahead&&(o=e.lookahead);do{if(u[(r=t)+a]===p&&u[r+a-1]===d&&u[r]===u[s]&&u[++r]===u[s+1]){s+=2,r++;do{}while(u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&u[++s]===u[++r]&&sh&&0!=--i);return a<=e.lookahead?a:e.lookahead}function j(e){var t,r,n,i,s,a,o,h,u,l,f=e.w_size;do{if(i=e.window_size-e.lookahead-e.strstart,e.strstart>=f+(f-z)){for(c.arraySet(e.window,e.window,f,f,0),e.match_start-=f,e.strstart-=f,e.block_start-=f,t=r=e.hash_size;n=e.head[--t],e.head[t]=f<=n?n-f:0,--r;);for(t=r=f;n=e.prev[--t],e.prev[t]=f<=n?n-f:0,--r;);i+=f}if(0===e.strm.avail_in)break;if(a=e.strm,o=e.window,h=e.strstart+e.lookahead,u=i,l=void 0,l=a.avail_in,u=x)for(s=e.strstart-e.insert,e.ins_h=e.window[s],e.ins_h=(e.ins_h<=x&&(e.ins_h=(e.ins_h<=x)if(n=u._tr_tally(e,e.strstart-e.match_start,e.match_length-x),e.lookahead-=e.match_length,e.match_length<=e.max_lazy_match&&e.lookahead>=x){for(e.match_length--;e.strstart++,e.ins_h=(e.ins_h<=x&&(e.ins_h=(e.ins_h<=x&&e.match_length<=e.prev_length){for(i=e.strstart+e.lookahead-x,n=u._tr_tally(e,e.strstart-1-e.prev_match,e.prev_length-x),e.lookahead-=e.prev_length-1,e.prev_length-=2;++e.strstart<=i&&(e.ins_h=(e.ins_h<e.pending_buf_size-5&&(r=e.pending_buf_size-5);;){if(e.lookahead<=1){if(j(e),0===e.lookahead&&t===l)return A;if(0===e.lookahead)break}e.strstart+=e.lookahead,e.lookahead=0;var n=e.block_start+r;if((0===e.strstart||e.strstart>=n)&&(e.lookahead=e.strstart-n,e.strstart=n,N(e,!1),0===e.strm.avail_out))return A;if(e.strstart-e.block_start>=e.w_size-z&&(N(e,!1),0===e.strm.avail_out))return A}return e.insert=0,t===f?(N(e,!0),0===e.strm.avail_out?O:B):(e.strstart>e.block_start&&(N(e,!1),e.strm.avail_out),A)}),new M(4,4,8,4,Z),new M(4,5,16,8,Z),new M(4,6,32,32,Z),new M(4,4,16,16,W),new M(8,16,32,32,W),new M(8,16,128,128,W),new M(8,32,128,256,W),new M(32,128,258,1024,W),new M(32,258,258,4096,W)],r.deflateInit=function(e,t){return Y(e,t,v,15,8,0)},r.deflateInit2=Y,r.deflateReset=K,r.deflateResetKeep=G,r.deflateSetHeader=function(e,t){return e&&e.state?2!==e.state.wrap?_:(e.state.gzhead=t,m):_},r.deflate=function(e,t){var r,n,i,s;if(!e||!e.state||5>8&255),U(n,n.gzhead.time>>16&255),U(n,n.gzhead.time>>24&255),U(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),U(n,255&n.gzhead.os),n.gzhead.extra&&n.gzhead.extra.length&&(U(n,255&n.gzhead.extra.length),U(n,n.gzhead.extra.length>>8&255)),n.gzhead.hcrc&&(e.adler=p(e.adler,n.pending_buf,n.pending,0)),n.gzindex=0,n.status=69):(U(n,0),U(n,0),U(n,0),U(n,0),U(n,0),U(n,9===n.level?2:2<=n.strategy||n.level<2?4:0),U(n,3),n.status=E);else{var a=v+(n.w_bits-8<<4)<<8;a|=(2<=n.strategy||n.level<2?0:n.level<6?1:6===n.level?2:3)<<6,0!==n.strstart&&(a|=32),a+=31-a%31,n.status=E,P(n,a),0!==n.strstart&&(P(n,e.adler>>>16),P(n,65535&e.adler)),e.adler=1}if(69===n.status)if(n.gzhead.extra){for(i=n.pending;n.gzindex<(65535&n.gzhead.extra.length)&&(n.pending!==n.pending_buf_size||(n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),F(e),i=n.pending,n.pending!==n.pending_buf_size));)U(n,255&n.gzhead.extra[n.gzindex]),n.gzindex++;n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),n.gzindex===n.gzhead.extra.length&&(n.gzindex=0,n.status=73)}else n.status=73;if(73===n.status)if(n.gzhead.name){i=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),F(e),i=n.pending,n.pending===n.pending_buf_size)){s=1;break}s=n.gzindexi&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),0===s&&(n.gzindex=0,n.status=91)}else n.status=91;if(91===n.status)if(n.gzhead.comment){i=n.pending;do{if(n.pending===n.pending_buf_size&&(n.gzhead.hcrc&&n.pending>i&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),F(e),i=n.pending,n.pending===n.pending_buf_size)){s=1;break}s=n.gzindexi&&(e.adler=p(e.adler,n.pending_buf,n.pending-i,i)),0===s&&(n.status=103)}else n.status=103;if(103===n.status&&(n.gzhead.hcrc?(n.pending+2>n.pending_buf_size&&F(e),n.pending+2<=n.pending_buf_size&&(U(n,255&e.adler),U(n,e.adler>>8&255),e.adler=0,n.status=E)):n.status=E),0!==n.pending){if(F(e),0===e.avail_out)return n.last_flush=-1,m}else if(0===e.avail_in&&T(t)<=T(r)&&t!==f)return R(e,-5);if(666===n.status&&0!==e.avail_in)return R(e,-5);if(0!==e.avail_in||0!==n.lookahead||t!==l&&666!==n.status){var o=2===n.strategy?function(e,t){for(var r;;){if(0===e.lookahead&&(j(e),0===e.lookahead)){if(t===l)return A;break}if(e.match_length=0,r=u._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++,r&&(N(e,!1),0===e.strm.avail_out))return A}return e.insert=0,t===f?(N(e,!0),0===e.strm.avail_out?O:B):e.last_lit&&(N(e,!1),0===e.strm.avail_out)?A:I}(n,t):3===n.strategy?function(e,t){for(var r,n,i,s,a=e.window;;){if(e.lookahead<=S){if(j(e),e.lookahead<=S&&t===l)return A;if(0===e.lookahead)break}if(e.match_length=0,e.lookahead>=x&&0e.lookahead&&(e.match_length=e.lookahead)}if(e.match_length>=x?(r=u._tr_tally(e,1,e.match_length-x),e.lookahead-=e.match_length,e.strstart+=e.match_length,e.match_length=0):(r=u._tr_tally(e,0,e.window[e.strstart]),e.lookahead--,e.strstart++),r&&(N(e,!1),0===e.strm.avail_out))return A}return e.insert=0,t===f?(N(e,!0),0===e.strm.avail_out?O:B):e.last_lit&&(N(e,!1),0===e.strm.avail_out)?A:I}(n,t):h[n.level].func(n,t);if(o!==O&&o!==B||(n.status=666),o===A||o===O)return 0===e.avail_out&&(n.last_flush=-1),m;if(o===I&&(1===t?u._tr_align(n):5!==t&&(u._tr_stored_block(n,0,0,!1),3===t&&(D(n.head),0===n.lookahead&&(n.strstart=0,n.block_start=0,n.insert=0))),F(e),0===e.avail_out))return n.last_flush=-1,m}return t!==f?m:n.wrap<=0?1:(2===n.wrap?(U(n,255&e.adler),U(n,e.adler>>8&255),U(n,e.adler>>16&255),U(n,e.adler>>24&255),U(n,255&e.total_in),U(n,e.total_in>>8&255),U(n,e.total_in>>16&255),U(n,e.total_in>>24&255)):(P(n,e.adler>>>16),P(n,65535&e.adler)),F(e),0=r.w_size&&(0===s&&(D(r.head),r.strstart=0,r.block_start=0,r.insert=0),u=new c.Buf8(r.w_size),c.arraySet(u,t,l-r.w_size,r.w_size,0),t=u,l=r.w_size),a=e.avail_in,o=e.next_in,h=e.input,e.avail_in=l,e.next_in=0,e.input=t,j(r);r.lookahead>=x;){for(n=r.strstart,i=r.lookahead-(x-1);r.ins_h=(r.ins_h<>>=y=v>>>24,p-=y,0===(y=v>>>16&255))C[s++]=65535&v;else{if(!(16&y)){if(0==(64&y)){v=m[(65535&v)+(d&(1<>>=y,p-=y),p<15&&(d+=z[n++]<>>=y=v>>>24,p-=y,!(16&(y=v>>>16&255))){if(0==(64&y)){v=_[(65535&v)+(d&(1<>>=y,p-=y,(y=s-a)>3,d&=(1<<(p-=w<<3))-1,e.next_in=n,e.next_out=s,e.avail_in=n>>24&255)+(e>>>8&65280)+((65280&e)<<8)+((255&e)<<24)}function s(){this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,this.flags=0,this.dmax=0,this.check=0,this.total=0,this.head=null,this.wbits=0,this.wsize=0,this.whave=0,this.wnext=0,this.window=null,this.hold=0,this.bits=0,this.length=0,this.offset=0,this.extra=0,this.lencode=null,this.distcode=null,this.lenbits=0,this.distbits=0,this.ncode=0,this.nlen=0,this.ndist=0,this.have=0,this.next=null,this.lens=new I.Buf16(320),this.work=new I.Buf16(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}function a(e){var t;return e&&e.state?(t=e.state,e.total_in=e.total_out=t.total=0,e.msg="",t.wrap&&(e.adler=1&t.wrap),t.mode=P,t.last=0,t.havedict=0,t.dmax=32768,t.head=null,t.hold=0,t.bits=0,t.lencode=t.lendyn=new I.Buf32(n),t.distcode=t.distdyn=new I.Buf32(i),t.sane=1,t.back=-1,N):U}function o(e){var t;return e&&e.state?((t=e.state).wsize=0,t.whave=0,t.wnext=0,a(e)):U}function h(e,t){var r,n;return e&&e.state?(n=e.state,t<0?(r=0,t=-t):(r=1+(t>>4),t<48&&(t&=15)),t&&(t<8||15=s.wsize?(I.arraySet(s.window,t,r-s.wsize,s.wsize,0),s.wnext=0,s.whave=s.wsize):(n<(i=s.wsize-s.wnext)&&(i=n),I.arraySet(s.window,t,r-n,i,s.wnext),(n-=i)?(I.arraySet(s.window,t,r-n,n,0),s.wnext=n,s.whave=s.wsize):(s.wnext+=i,s.wnext===s.wsize&&(s.wnext=0),s.whave>>8&255,r.check=B(r.check,E,2,0),l=u=0,r.mode=2;break}if(r.flags=0,r.head&&(r.head.done=!1),!(1&r.wrap)||(((255&u)<<8)+(u>>8))%31){e.msg="incorrect header check",r.mode=30;break}if(8!=(15&u)){e.msg="unknown compression method",r.mode=30;break}if(l-=4,k=8+(15&(u>>>=4)),0===r.wbits)r.wbits=k;else if(k>r.wbits){e.msg="invalid window size",r.mode=30;break}r.dmax=1<>8&1),512&r.flags&&(E[0]=255&u,E[1]=u>>>8&255,r.check=B(r.check,E,2,0)),l=u=0,r.mode=3;case 3:for(;l<32;){if(0===o)break e;o--,u+=n[s++]<>>8&255,E[2]=u>>>16&255,E[3]=u>>>24&255,r.check=B(r.check,E,4,0)),l=u=0,r.mode=4;case 4:for(;l<16;){if(0===o)break e;o--,u+=n[s++]<>8),512&r.flags&&(E[0]=255&u,E[1]=u>>>8&255,r.check=B(r.check,E,2,0)),l=u=0,r.mode=5;case 5:if(1024&r.flags){for(;l<16;){if(0===o)break e;o--,u+=n[s++]<>>8&255,r.check=B(r.check,E,2,0)),l=u=0}else r.head&&(r.head.extra=null);r.mode=6;case 6:if(1024&r.flags&&(o<(d=r.length)&&(d=o),d&&(r.head&&(k=r.head.extra_len-r.length,r.head.extra||(r.head.extra=new Array(r.head.extra_len)),I.arraySet(r.head.extra,n,s,d,k)),512&r.flags&&(r.check=B(r.check,n,d,s)),o-=d,s+=d,r.length-=d),r.length))break e;r.length=0,r.mode=7;case 7:if(2048&r.flags){if(0===o)break e;for(d=0;k=n[s+d++],r.head&&k&&r.length<65536&&(r.head.name+=String.fromCharCode(k)),k&&d>9&1,r.head.done=!0),e.adler=r.check=0,r.mode=12;break;case 10:for(;l<32;){if(0===o)break e;o--,u+=n[s++]<>>=7&l,l-=7&l,r.mode=27;break}for(;l<3;){if(0===o)break e;o--,u+=n[s++]<>>=1)){case 0:r.mode=14;break;case 1:if(j(r),r.mode=20,6!==t)break;u>>>=2,l-=2;break e;case 2:r.mode=17;break;case 3:e.msg="invalid block type",r.mode=30}u>>>=2,l-=2;break;case 14:for(u>>>=7&l,l-=7&l;l<32;){if(0===o)break e;o--,u+=n[s++]<>>16^65535)){e.msg="invalid stored block lengths",r.mode=30;break}if(r.length=65535&u,l=u=0,r.mode=15,6===t)break e;case 15:r.mode=16;case 16:if(d=r.length){if(o>>=5,l-=5,r.ndist=1+(31&u),u>>>=5,l-=5,r.ncode=4+(15&u),u>>>=4,l-=4,286>>=3,l-=3}for(;r.have<19;)r.lens[A[r.have++]]=0;if(r.lencode=r.lendyn,r.lenbits=7,S={bits:r.lenbits},x=T(0,r.lens,0,19,r.lencode,0,r.work,S),r.lenbits=S.bits,x){e.msg="invalid code lengths set",r.mode=30;break}r.have=0,r.mode=19;case 19:for(;r.have>>16&255,b=65535&C,!((_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>>=_,l-=_,r.lens[r.have++]=b;else{if(16===b){for(z=_+2;l>>=_,l-=_,0===r.have){e.msg="invalid bit length repeat",r.mode=30;break}k=r.lens[r.have-1],d=3+(3&u),u>>>=2,l-=2}else if(17===b){for(z=_+3;l>>=_)),u>>>=3,l-=3}else{for(z=_+7;l>>=_)),u>>>=7,l-=7}if(r.have+d>r.nlen+r.ndist){e.msg="invalid bit length repeat",r.mode=30;break}for(;d--;)r.lens[r.have++]=k}}if(30===r.mode)break;if(0===r.lens[256]){e.msg="invalid code -- missing end-of-block",r.mode=30;break}if(r.lenbits=9,S={bits:r.lenbits},x=T(D,r.lens,0,r.nlen,r.lencode,0,r.work,S),r.lenbits=S.bits,x){e.msg="invalid literal/lengths set",r.mode=30;break}if(r.distbits=6,r.distcode=r.distdyn,S={bits:r.distbits},x=T(F,r.lens,r.nlen,r.ndist,r.distcode,0,r.work,S),r.distbits=S.bits,x){e.msg="invalid distances set",r.mode=30;break}if(r.mode=20,6===t)break e;case 20:r.mode=21;case 21:if(6<=o&&258<=h){e.next_out=a,e.avail_out=h,e.next_in=s,e.avail_in=o,r.hold=u,r.bits=l,R(e,c),a=e.next_out,i=e.output,h=e.avail_out,s=e.next_in,n=e.input,o=e.avail_in,u=r.hold,l=r.bits,12===r.mode&&(r.back=-1);break}for(r.back=0;g=(C=r.lencode[u&(1<>>16&255,b=65535&C,!((_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>v)])>>>16&255,b=65535&C,!(v+(_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>>=v,l-=v,r.back+=v}if(u>>>=_,l-=_,r.back+=_,r.length=b,0===g){r.mode=26;break}if(32&g){r.back=-1,r.mode=12;break}if(64&g){e.msg="invalid literal/length code",r.mode=30;break}r.extra=15&g,r.mode=22;case 22:if(r.extra){for(z=r.extra;l>>=r.extra,l-=r.extra,r.back+=r.extra}r.was=r.length,r.mode=23;case 23:for(;g=(C=r.distcode[u&(1<>>16&255,b=65535&C,!((_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>v)])>>>16&255,b=65535&C,!(v+(_=C>>>24)<=l);){if(0===o)break e;o--,u+=n[s++]<>>=v,l-=v,r.back+=v}if(u>>>=_,l-=_,r.back+=_,64&g){e.msg="invalid distance code",r.mode=30;break}r.offset=b,r.extra=15&g,r.mode=24;case 24:if(r.extra){for(z=r.extra;l>>=r.extra,l-=r.extra,r.back+=r.extra}if(r.offset>r.dmax){e.msg="invalid distance too far back",r.mode=30;break}r.mode=25;case 25:if(0===h)break e;if(d=c-h,r.offset>d){if((d=r.offset-d)>r.whave&&r.sane){e.msg="invalid distance too far back",r.mode=30;break}p=d>r.wnext?(d-=r.wnext,r.wsize-d):r.wnext-d,d>r.length&&(d=r.length),m=r.window}else m=i,p=a-r.offset,d=r.length;for(hd?(m=R[T+a[v]],A[I+a[v]]):(m=96,0),h=1<>S)+(u-=h)]=p<<24|m<<16|_|0,0!==u;);for(h=1<>=1;if(0!==h?(E&=h-1,E+=h):E=0,v++,0==--O[b]){if(b===w)break;b=t[r+a[v]]}if(k>>7)]}function U(e,t){e.pending_buf[e.pending++]=255&t,e.pending_buf[e.pending++]=t>>>8&255}function P(e,t,r){e.bi_valid>d-r?(e.bi_buf|=t<>d-e.bi_valid,e.bi_valid+=r-d):(e.bi_buf|=t<>>=1,r<<=1,0<--t;);return r>>>1}function Z(e,t,r){var n,i,s=new Array(g+1),a=0;for(n=1;n<=g;n++)s[n]=a=a+r[n-1]<<1;for(i=0;i<=t;i++){var o=e[2*i+1];0!==o&&(e[2*i]=j(s[o]++,o))}}function W(e){var t;for(t=0;t>1;1<=r;r--)G(e,s,r);for(i=h;r=e.heap[1],e.heap[1]=e.heap[e.heap_len--],G(e,s,1),n=e.heap[1],e.heap[--e.heap_max]=r,e.heap[--e.heap_max]=n,s[2*i]=s[2*r]+s[2*n],e.depth[i]=(e.depth[r]>=e.depth[n]?e.depth[r]:e.depth[n])+1,s[2*r+1]=s[2*n+1]=i,e.heap[1]=i++,G(e,s,1),2<=e.heap_len;);e.heap[--e.heap_max]=e.heap[1],function(e,t){var r,n,i,s,a,o,h=t.dyn_tree,u=t.max_code,l=t.stat_desc.static_tree,f=t.stat_desc.has_stree,c=t.stat_desc.extra_bits,d=t.stat_desc.extra_base,p=t.stat_desc.max_length,m=0;for(s=0;s<=g;s++)e.bl_count[s]=0;for(h[2*e.heap[e.heap_max]+1]=0,r=e.heap_max+1;r<_;r++)p<(s=h[2*h[2*(n=e.heap[r])+1]+1]+1)&&(s=p,m++),h[2*n+1]=s,u>=7;n>>=1)if(1&r&&0!==e.dyn_ltree[2*t])return o;if(0!==e.dyn_ltree[18]||0!==e.dyn_ltree[20]||0!==e.dyn_ltree[26])return h;for(t=32;t>>3,(s=e.static_len+3+7>>>3)<=i&&(i=s)):i=s=r+5,r+4<=i&&-1!==t?J(e,t,r,n):4===e.strategy||s===i?(P(e,2+(n?1:0),3),K(e,z,C)):(P(e,4+(n?1:0),3),function(e,t,r,n){var i;for(P(e,t-257,5),P(e,r-1,5),P(e,n-4,4),i=0;i>>8&255,e.pending_buf[e.d_buf+2*e.last_lit+1]=255&t,e.pending_buf[e.l_buf+e.last_lit]=255&r,e.last_lit++,0===t?e.dyn_ltree[2*r]++:(e.matches++,t--,e.dyn_ltree[2*(A[r]+u+1)]++,e.dyn_dtree[2*N(t)]++),e.last_lit===e.lit_bufsize-1},r._tr_align=function(e){P(e,2,3),L(e,m,z),function(e){16===e.bi_valid?(U(e,e.bi_buf),e.bi_buf=0,e.bi_valid=0):8<=e.bi_valid&&(e.pending_buf[e.pending++]=255&e.bi_buf,e.bi_buf>>=8,e.bi_valid-=8)}(e)}},{"../utils/common":41}],53:[function(e,t,r){"use strict";t.exports=function(){this.input=null,this.next_in=0,this.avail_in=0,this.total_in=0,this.output=null,this.next_out=0,this.avail_out=0,this.total_out=0,this.msg="",this.state=null,this.data_type=2,this.adler=0}},{}],54:[function(e,t,r){(function(e){!function(r,n){"use strict";if(!r.setImmediate){var i,s,t,a,o=1,h={},u=!1,l=r.document,e=Object.getPrototypeOf&&Object.getPrototypeOf(r);e=e&&e.setTimeout?e:r,i="[object process]"==={}.toString.call(r.process)?function(e){process.nextTick(function(){c(e)})}:function(){if(r.postMessage&&!r.importScripts){var e=!0,t=r.onmessage;return r.onmessage=function(){e=!1},r.postMessage("","*"),r.onmessage=t,e}}()?(a="setImmediate$"+Math.random()+"$",r.addEventListener?r.addEventListener("message",d,!1):r.attachEvent("onmessage",d),function(e){r.postMessage(a+e,"*")}):r.MessageChannel?((t=new MessageChannel).port1.onmessage=function(e){c(e.data)},function(e){t.port2.postMessage(e)}):l&&"onreadystatechange"in l.createElement("script")?(s=l.documentElement,function(e){var t=l.createElement("script");t.onreadystatechange=function(){c(e),t.onreadystatechange=null,s.removeChild(t),t=null},s.appendChild(t)}):function(e){setTimeout(c,0,e)},e.setImmediate=function(e){"function"!=typeof e&&(e=new Function(""+e));for(var t=new Array(arguments.length-1),r=0;rt&&!o||!u||r&&!i&&f||e&&f)return 1;if(n=n&&9<=n&&13>=n||32==n||160==n||5760==n||6158==n||8192<=n&&(8202>=n||8232==n||8233==n||8239==n||8287==n||12288==n||65279==n); - }function v(n,t){for(var r=-1,e=n.length,u=-1,o=[];++r=F&&gu&&lu?new Dn(t):null,c=t.length;a&&(i=Mn,f=false,t=a);n:for(;++oi(t,a,0)&&u.push(a);return u}function at(n,t){var r=true;return Su(n,function(n,e,u){return r=!!t(n,e,u)}),r}function ct(n,t,r,e){var u=e,o=u;return Su(n,function(n,i,f){i=+t(n,i,f),(r(i,u)||i===e&&i===o)&&(u=i, - o=n)}),o}function lt(n,t){var r=[];return Su(n,function(n,e,u){t(n,e,u)&&r.push(n)}),r}function st(n,t,r,e){var u;return r(n,function(n,r,o){return t(n,r,o)?(u=e?r:n,false):void 0}),u}function pt(n,t,r,e){e||(e=[]);for(var u=-1,o=n.length;++ut&&(t=-t>u?0:u+t),r=r===w||r>u?u:+r||0,0>r&&(r+=u),u=t>r?0:r-t>>>0,t>>>=0,r=Be(u);++e=c)break n;o=e[o],u*="asc"===o||true===o?1:-1;break n}u=t.b-r.b}return u})}function $t(n,t){ - var r=0;return Su(n,function(n,e,u){r+=+t(n,e,u)||0}),r}function St(n,t){var e=-1,u=xr(),o=n.length,i=u==r,f=i&&o>=F,a=f&&gu&&lu?new Dn(void 0):null,c=[];a?(u=Mn,i=false):(f=false,a=t?[]:c);n:for(;++eu(a,s,0)&&((t||f)&&a.push(s),c.push(l))}return c}function Ft(n,t){for(var r=-1,e=t.length,u=Be(e);++r>>1,i=n[o];(r?i<=t:iu?w:o,u=1);++e=F)return t.plant(e).value();for(var u=0,n=r?o[u].apply(this,n):e;++uarguments.length;return typeof e=="function"&&o===w&&Oo(r)?n(r,e,u,i):Ot(r,wr(e,o,4),u,i,t)}}function sr(n,t,r,e,u,o,i,f,a,c){function l(){for(var m=arguments.length,b=m,j=Be(m);b--;)j[b]=arguments[b];if(e&&(j=Mt(j,e,u)),o&&(j=qt(j,o,i)),_||y){var b=l.placeholder,k=v(j,b),m=m-k.length;if(mt?0:t)):[]}function Pr(n,t,r){var e=n?n.length:0;return e?((r?Ur(n,t,r):null==t)&&(t=1),t=e-(+t||0),Et(n,0,0>t?0:t)):[]}function Kr(n){return n?n[0]:w}function Vr(n,t,e){var u=n?n.length:0;if(!u)return-1;if(typeof e=="number")e=0>e?bu(u+e,0):e;else if(e)return e=Lt(n,t), - er?bu(u+r,0):r||0,typeof n=="string"||!Oo(n)&&be(n)?r<=u&&-1t?0:+t||0,e);++r=n&&(t=w),r}}function ae(n,t,r){function e(t,r){r&&iu(r),a=p=h=w,t&&(_=ho(),c=n.apply(s,f),p||a||(f=s=w))}function u(){var n=t-(ho()-l);0>=n||n>t?e(h,a):p=su(u,n)}function o(){e(g,p); - }function i(){if(f=arguments,l=ho(),s=this,h=g&&(p||!y),false===v)var r=y&&!p;else{a||y||(_=l);var e=v-(l-_),i=0>=e||e>v;i?(a&&(a=iu(a)),_=l,c=n.apply(s,f)):a||(a=su(o,e))}return i&&p?p=iu(p):p||t===v||(p=su(u,t)),r&&(i=true,c=n.apply(s,f)),!i||p||a||(f=s=w),c}var f,a,c,l,s,p,h,_=0,v=false,g=true;if(typeof n!="function")throw new Ge(L);if(t=0>t?0:+t||0,true===r)var y=true,g=false;else ge(r)&&(y=!!r.leading,v="maxWait"in r&&bu(+r.maxWait||0,t),g="trailing"in r?!!r.trailing:g);return i.cancel=function(){p&&iu(p),a&&iu(a), - _=0,a=p=h=w},i}function ce(n,t){function r(){var e=arguments,u=t?t.apply(this,e):e[0],o=r.cache;return o.has(u)?o.get(u):(e=n.apply(this,e),r.cache=o.set(u,e),e)}if(typeof n!="function"||t&&typeof t!="function")throw new Ge(L);return r.cache=new ce.Cache,r}function le(n,t){if(typeof n!="function")throw new Ge(L);return t=bu(t===w?n.length-1:+t||0,0),function(){for(var r=arguments,e=-1,u=bu(r.length-t,0),o=Be(u);++et}function pe(n){return h(n)&&Er(n)&&nu.call(n,"callee")&&!cu.call(n,"callee")}function he(n,t,r,e){return e=(r=typeof r=="function"?Bt(r,e,3):w)?r(n,t):w,e===w?dt(n,t,r):!!e}function _e(n){return h(n)&&typeof n.message=="string"&&ru.call(n)==P}function ve(n){return ge(n)&&ru.call(n)==K}function ge(n){var t=typeof n;return!!n&&("object"==t||"function"==t)}function ye(n){ - return null==n?false:ve(n)?uu.test(Qe.call(n)):h(n)&&Rn.test(n)}function de(n){return typeof n=="number"||h(n)&&ru.call(n)==V}function me(n){var t;if(!h(n)||ru.call(n)!=Z||pe(n)||!(nu.call(n,"constructor")||(t=n.constructor,typeof t!="function"||t instanceof t)))return false;var r;return ht(n,function(n,t){r=t}),r===w||nu.call(n,r)}function we(n){return ge(n)&&ru.call(n)==Y}function be(n){return typeof n=="string"||h(n)&&ru.call(n)==G}function xe(n){return h(n)&&Sr(n.length)&&!!Sn[ru.call(n)]}function Ae(n,t){ - return nt||!n||!mu(t))return r;do t%2&&(r+=n),t=yu(t/2),n+=n;while(t);return r}function We(n,t,r){var e=n;return(n=u(n))?(r?Ur(e,t,r):null==t)?n.slice(g(n),y(n)+1):(t+="",n.slice(o(n,t),i(n,t)+1)):n}function $e(n,t,r){return r&&Ur(n,t,r)&&(t=w),n=u(n),n.match(t||Wn)||[]}function Se(n,t,r){return r&&Ur(n,t,r)&&(t=w),h(n)?Ne(n):ut(n,t)}function Fe(n){ - return n}function Ne(n){return bt(ot(n,true))}function Te(n,t,r){if(null==r){var e=ge(t),u=e?zo(t):w;((u=u&&u.length?gt(t,u):w)?u.length:e)||(u=false,r=t,t=n,n=this)}u||(u=gt(t,zo(t)));var o=true,e=-1,i=ve(n),f=u.length;false===r?o=false:ge(r)&&"chain"in r&&(o=r.chain);for(;++e=$)return r}else n=0;return Lu(r,e)}}(),Mu=le(function(n,t){ - return h(n)&&Er(n)?ft(n,pt(t,false,true)):[]}),qu=tr(),Pu=tr(true),Ku=le(function(n){for(var t=n.length,e=t,u=Be(l),o=xr(),i=o==r,f=[];e--;){var a=n[e]=Er(a=n[e])?a:[];u[e]=i&&120<=a.length&&gu&&lu?new Dn(e&&a):null}var i=n[0],c=-1,l=i?i.length:0,s=u[0];n:for(;++c(s?Mn(s,a):o(f,a,0))){for(e=t;--e;){var p=u[e];if(0>(p?Mn(p,a):o(n[e],a,0)))continue n}s&&s.push(a),f.push(a)}return f}),Vu=le(function(t,r){r=pt(r);var e=rt(t,r);return It(t,r.sort(n)),e}),Zu=vr(),Yu=vr(true),Gu=le(function(n){return St(pt(n,false,true)); - }),Ju=le(function(n,t){return Er(n)?ft(n,t):[]}),Xu=le(Jr),Hu=le(function(n){var t=n.length,r=2--n?t.apply(this,arguments):void 0}},Nn.ary=function(n,t,r){return r&&Ur(n,t,r)&&(t=w),t=n&&null==t?n.length:bu(+t||0,0),gr(n,E,w,w,w,w,t)},Nn.assign=Co,Nn.at=no,Nn.before=fe,Nn.bind=_o,Nn.bindAll=vo,Nn.bindKey=go,Nn.callback=Se,Nn.chain=Qr,Nn.chunk=function(n,t,r){t=(r?Ur(n,t,r):null==t)?1:bu(yu(t)||1,1),r=0;for(var e=n?n.length:0,u=-1,o=Be(vu(e/t));rr&&(r=-r>u?0:u+r),e=e===w||e>u?u:+e||0,0>e&&(e+=u),u=r>e?0:e>>>0,r>>>=0;rt?0:t)):[]},Nn.takeRight=function(n,t,r){var e=n?n.length:0;return e?((r?Ur(n,t,r):null==t)&&(t=1),t=e-(+t||0),Et(n,0>t?0:t)):[]},Nn.takeRightWhile=function(n,t,r){ - return n&&n.length?Nt(n,wr(t,r,3),false,true):[]},Nn.takeWhile=function(n,t,r){return n&&n.length?Nt(n,wr(t,r,3)):[]},Nn.tap=function(n,t,r){return t.call(r,n),n},Nn.throttle=function(n,t,r){var e=true,u=true;if(typeof n!="function")throw new Ge(L);return false===r?e=false:ge(r)&&(e="leading"in r?!!r.leading:e,u="trailing"in r?!!r.trailing:u),ae(n,t,{leading:e,maxWait:+t,trailing:u})},Nn.thru=ne,Nn.times=function(n,t,r){if(n=yu(n),1>n||!mu(n))return[];var e=-1,u=Be(xu(n,4294967295));for(t=Bt(t,r,1);++ee?u[e]=t(e):t(e); - return u},Nn.toArray=je,Nn.toPlainObject=ke,Nn.transform=function(n,t,r,e){var u=Oo(n)||xe(n);return t=wr(t,e,4),null==r&&(u||ge(n)?(e=n.constructor,r=u?Oo(n)?new e:[]:$u(ve(e)?e.prototype:w)):r={}),(u?Pn:_t)(n,function(n,e,u){return t(r,n,e,u)}),r},Nn.union=Gu,Nn.uniq=Gr,Nn.unzip=Jr,Nn.unzipWith=Xr,Nn.values=Ee,Nn.valuesIn=function(n){return Ft(n,Re(n))},Nn.where=function(n,t){return re(n,bt(t))},Nn.without=Ju,Nn.wrap=function(n,t){return t=null==t?Fe:t,gr(t,R,w,[n],[])},Nn.xor=function(){for(var n=-1,t=arguments.length;++nr?0:+r||0,e),r-=t.length,0<=r&&n.indexOf(t,r)==r},Nn.escape=function(n){return(n=u(n))&&hn.test(n)?n.replace(sn,c):n},Nn.escapeRegExp=function(n){return(n=u(n))&&bn.test(n)?n.replace(wn,l):n||"(?:)"},Nn.every=te,Nn.find=ro,Nn.findIndex=qu,Nn.findKey=$o,Nn.findLast=eo, - Nn.findLastIndex=Pu,Nn.findLastKey=So,Nn.findWhere=function(n,t){return ro(n,bt(t))},Nn.first=Kr,Nn.floor=ni,Nn.get=function(n,t,r){return n=null==n?w:yt(n,Dr(t),t+""),n===w?r:n},Nn.gt=se,Nn.gte=function(n,t){return n>=t},Nn.has=function(n,t){if(null==n)return false;var r=nu.call(n,t);if(!r&&!Wr(t)){if(t=Dr(t),n=1==t.length?n:yt(n,Et(t,0,-1)),null==n)return false;t=Zr(t),r=nu.call(n,t)}return r||Sr(n.length)&&Cr(t,n.length)&&(Oo(n)||pe(n))},Nn.identity=Fe,Nn.includes=ee,Nn.indexOf=Vr,Nn.inRange=function(n,t,r){ - return t=+t||0,r===w?(r=t,t=0):r=+r||0,n>=xu(t,r)&&nr?bu(e+r,0):xu(r||0,e-1))+1;else if(r)return u=Lt(n,t,true)-1,n=n[u],(t===t?t===n:n!==n)?u:-1; - if(t!==t)return p(n,u,true);for(;u--;)if(n[u]===t)return u;return-1},Nn.lt=Ae,Nn.lte=function(n,t){return n<=t},Nn.max=ti,Nn.min=ri,Nn.noConflict=function(){return Zn._=eu,this},Nn.noop=Le,Nn.now=ho,Nn.pad=function(n,t,r){n=u(n),t=+t;var e=n.length;return er?0:+r||0,n.length),n.lastIndexOf(t,r)==r},Nn.sum=function(n,t,r){if(r&&Ur(n,t,r)&&(t=w),t=wr(t,r,3),1==t.length){n=Oo(n)?n:zr(n),r=n.length;for(var e=0;r--;)e+=+t(n[r])||0;n=e}else n=$t(n,t);return n},Nn.template=function(n,t,r){var e=Nn.templateSettings;r&&Ur(n,t,r)&&(t=r=w),n=u(n),t=nt(tt({},r||t),e,Qn),r=nt(tt({},t.imports),e.imports,Qn); - var o,i,f=zo(r),a=Ft(r,f),c=0;r=t.interpolate||Cn;var l="__p+='";r=Ze((t.escape||Cn).source+"|"+r.source+"|"+(r===gn?jn:Cn).source+"|"+(t.evaluate||Cn).source+"|$","g");var p="sourceURL"in t?"//# sourceURL="+t.sourceURL+"\n":"";if(n.replace(r,function(t,r,e,u,f,a){return e||(e=u),l+=n.slice(c,a).replace(Un,s),r&&(o=true,l+="'+__e("+r+")+'"),f&&(i=true,l+="';"+f+";\n__p+='"),e&&(l+="'+((__t=("+e+"))==null?'':__t)+'"),c=a+t.length,t}),l+="';",(t=t.variable)||(l="with(obj){"+l+"}"),l=(i?l.replace(fn,""):l).replace(an,"$1").replace(cn,"$1;"), - l="function("+(t||"obj")+"){"+(t?"":"obj||(obj={});")+"var __t,__p=''"+(o?",__e=_.escape":"")+(i?",__j=Array.prototype.join;function print(){__p+=__j.call(arguments,'')}":";")+l+"return __p}",t=Jo(function(){return qe(f,p+"return "+l).apply(w,a)}),t.source=l,_e(t))throw t;return t},Nn.trim=We,Nn.trimLeft=function(n,t,r){var e=n;return(n=u(n))?n.slice((r?Ur(e,t,r):null==t)?g(n):o(n,t+"")):n},Nn.trimRight=function(n,t,r){var e=n;return(n=u(n))?(r?Ur(e,t,r):null==t)?n.slice(0,y(n)+1):n.slice(0,i(n,t+"")+1):n; - },Nn.trunc=function(n,t,r){r&&Ur(n,t,r)&&(t=w);var e=U;if(r=W,null!=t)if(ge(t)){var o="separator"in t?t.separator:o,e="length"in t?+t.length||0:e;r="omission"in t?u(t.omission):r}else e=+t||0;if(n=u(n),e>=n.length)return n;if(e-=r.length,1>e)return r;if(t=n.slice(0,e),null==o)return t+r;if(we(o)){if(n.slice(e).search(o)){var i,f=n.slice(0,e);for(o.global||(o=Ze(o.source,(kn.exec(o)||"")+"g")),o.lastIndex=0;n=o.exec(f);)i=n.index;t=t.slice(0,null==i?e:i)}}else n.indexOf(o,e)!=e&&(o=t.lastIndexOf(o), - -1u.__dir__?"Right":"")}),u},zn.prototype[n+"Right"]=function(t){return this.reverse()[n](t).reverse()}}),Pn(["filter","map","takeWhile"],function(n,t){ - var r=t+1,e=r!=T;zn.prototype[n]=function(n,t){var u=this.clone();return u.__iteratees__.push({iteratee:wr(n,t,1),type:r}),u.__filtered__=u.__filtered__||e,u}}),Pn(["first","last"],function(n,t){var r="take"+(t?"Right":"");zn.prototype[n]=function(){return this[r](1).value()[0]}}),Pn(["initial","rest"],function(n,t){var r="drop"+(t?"":"Right");zn.prototype[n]=function(){return this.__filtered__?new zn(this):this[r](1)}}),Pn(["pluck","where"],function(n,t){var r=t?"filter":"map",e=t?bt:ze;zn.prototype[n]=function(n){ - return this[r](e(n))}}),zn.prototype.compact=function(){return this.filter(Fe)},zn.prototype.reject=function(n,t){return n=wr(n,t,1),this.filter(function(t){return!n(t)})},zn.prototype.slice=function(n,t){n=null==n?0:+n||0;var r=this;return r.__filtered__&&(0t)?new zn(r):(0>n?r=r.takeRight(-n):n&&(r=r.drop(n)),t!==w&&(t=+t||0,r=0>t?r.dropRight(-t):r.take(t-n)),r)},zn.prototype.takeRightWhile=function(n,t){return this.reverse().takeWhile(n,t).reverse()},zn.prototype.toArray=function(){return this.take(Ru); - },_t(zn.prototype,function(n,t){var r=/^(?:filter|map|reject)|While$/.test(t),e=/^(?:first|last)$/.test(t),u=Nn[e?"take"+("last"==t?"Right":""):t];u&&(Nn.prototype[t]=function(){function t(n){return e&&i?u(n,1)[0]:u.apply(w,Jn([n],o))}var o=e?[1]:arguments,i=this.__chain__,f=this.__wrapped__,a=!!this.__actions__.length,c=f instanceof zn,l=o[0],s=c||Oo(f);return s&&r&&typeof l=="function"&&1!=l.length&&(c=s=false),l={func:ne,args:[t],thisArg:w},a=c&&!a,e&&!i?a?(f=f.clone(),f.__actions__.push(l),n.call(f)):u.call(w,this.value())[0]:!e&&s?(f=a?f:new zn(this), - f=n.apply(f,o),f.__actions__.push(l),new Ln(f,i)):this.thru(t)})}),Pn("join pop push replace shift sort splice split unshift".split(" "),function(n){var t=(/^(?:replace|split)$/.test(n)?He:Je)[n],r=/^(?:push|sort|unshift)$/.test(n)?"tap":"thru",e=/^(?:join|pop|replace|shift)$/.test(n);Nn.prototype[n]=function(){var n=arguments;return e&&!this.__chain__?t.apply(this.value(),n):this[r](function(r){return t.apply(r,n)})}}),_t(zn.prototype,function(n,t){var r=Nn[t];if(r){var e=r.name;(Wu[e]||(Wu[e]=[])).push({ - name:t,func:r})}}),Wu[sr(w,A).name]=[{name:"wrapper",func:w}],zn.prototype.clone=function(){var n=new zn(this.__wrapped__);return n.__actions__=qn(this.__actions__),n.__dir__=this.__dir__,n.__filtered__=this.__filtered__,n.__iteratees__=qn(this.__iteratees__),n.__takeCount__=this.__takeCount__,n.__views__=qn(this.__views__),n},zn.prototype.reverse=function(){if(this.__filtered__){var n=new zn(this);n.__dir__=-1,n.__filtered__=true}else n=this.clone(),n.__dir__*=-1;return n},zn.prototype.value=function(){ - var n,t=this.__wrapped__.value(),r=this.__dir__,e=Oo(t),u=0>r,o=e?t.length:0;n=o;for(var i=this.__views__,f=0,a=-1,c=i.length;++ar.__dir__?n:n.reverse()}var t=this.__wrapped__; - if(t instanceof zn){var r=t;return this.__actions__.length&&(r=new zn(this)),r=r.reverse(),r.__actions__.push({func:ne,args:[n],thisArg:w}),new Ln(r,this.__chain__)}return this.thru(n)},Nn.prototype.toString=function(){return this.value()+""},Nn.prototype.run=Nn.prototype.toJSON=Nn.prototype.valueOf=Nn.prototype.value=function(){return Tt(this.__wrapped__,this.__actions__)},Nn.prototype.collect=Nn.prototype.map,Nn.prototype.head=Nn.prototype.first,Nn.prototype.select=Nn.prototype.filter,Nn.prototype.tail=Nn.prototype.rest, - Nn}var w,b="3.10.0",x=1,A=2,j=4,k=8,I=16,R=32,O=64,E=128,C=256,U=30,W="...",$=150,S=16,F=200,N=1,T=2,L="Expected a function",z="__lodash_placeholder__",B="[object Arguments]",D="[object Array]",M="[object Boolean]",q="[object Date]",P="[object Error]",K="[object Function]",V="[object Number]",Z="[object Object]",Y="[object RegExp]",G="[object String]",J="[object ArrayBuffer]",X="[object Float32Array]",H="[object Float64Array]",Q="[object Int8Array]",nn="[object Int16Array]",tn="[object Int32Array]",rn="[object Uint8Array]",en="[object Uint8ClampedArray]",un="[object Uint16Array]",on="[object Uint32Array]",fn=/\b__p\+='';/g,an=/\b(__p\+=)''\+/g,cn=/(__e\(.*?\)|\b__t\))\+'';/g,ln=/&(?:amp|lt|gt|quot|#39|#96);/g,sn=/[&<>"'`]/g,pn=RegExp(ln.source),hn=RegExp(sn.source),_n=/<%-([\s\S]+?)%>/g,vn=/<%([\s\S]+?)%>/g,gn=/<%=([\s\S]+?)%>/g,yn=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\n\\]|\\.)*?\1)\]/,dn=/^\w*$/,mn=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\n\\]|\\.)*?)\2)\]/g,wn=/^[:!,]|[\\^$.*+?()[\]{}|\/]|(^[0-9a-fA-Fnrtuvx])|([\n\r\u2028\u2029])/g,bn=RegExp(wn.source),xn=/[\u0300-\u036f\ufe20-\ufe23]/g,An=/\\(\\)?/g,jn=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g,kn=/\w*$/,In=/^0[xX]/,Rn=/^\[object .+?Constructor\]$/,On=/^\d+$/,En=/[\xc0-\xd6\xd8-\xde\xdf-\xf6\xf8-\xff]/g,Cn=/($^)/,Un=/['\n\r\u2028\u2029\\]/g,Wn=RegExp("[A-Z\\xc0-\\xd6\\xd8-\\xde]+(?=[A-Z\\xc0-\\xd6\\xd8-\\xde][a-z\\xdf-\\xf6\\xf8-\\xff]+)|[A-Z\\xc0-\\xd6\\xd8-\\xde]?[a-z\\xdf-\\xf6\\xf8-\\xff]+|[A-Z\\xc0-\\xd6\\xd8-\\xde]+|[0-9]+","g"),$n="Array ArrayBuffer Date Error Float32Array Float64Array Function Int8Array Int16Array Int32Array Math Number Object RegExp Set String _ clearTimeout isFinite parseFloat parseInt setTimeout TypeError Uint8Array Uint8ClampedArray Uint16Array Uint32Array WeakMap".split(" "),Sn={}; - Sn[X]=Sn[H]=Sn[Q]=Sn[nn]=Sn[tn]=Sn[rn]=Sn[en]=Sn[un]=Sn[on]=true,Sn[B]=Sn[D]=Sn[J]=Sn[M]=Sn[q]=Sn[P]=Sn[K]=Sn["[object Map]"]=Sn[V]=Sn[Z]=Sn[Y]=Sn["[object Set]"]=Sn[G]=Sn["[object WeakMap]"]=false;var Fn={};Fn[B]=Fn[D]=Fn[J]=Fn[M]=Fn[q]=Fn[X]=Fn[H]=Fn[Q]=Fn[nn]=Fn[tn]=Fn[V]=Fn[Z]=Fn[Y]=Fn[G]=Fn[rn]=Fn[en]=Fn[un]=Fn[on]=true,Fn[P]=Fn[K]=Fn["[object Map]"]=Fn["[object Set]"]=Fn["[object WeakMap]"]=false;var Nn={"\xc0":"A","\xc1":"A","\xc2":"A","\xc3":"A","\xc4":"A","\xc5":"A","\xe0":"a","\xe1":"a","\xe2":"a", - "\xe3":"a","\xe4":"a","\xe5":"a","\xc7":"C","\xe7":"c","\xd0":"D","\xf0":"d","\xc8":"E","\xc9":"E","\xca":"E","\xcb":"E","\xe8":"e","\xe9":"e","\xea":"e","\xeb":"e","\xcc":"I","\xcd":"I","\xce":"I","\xcf":"I","\xec":"i","\xed":"i","\xee":"i","\xef":"i","\xd1":"N","\xf1":"n","\xd2":"O","\xd3":"O","\xd4":"O","\xd5":"O","\xd6":"O","\xd8":"O","\xf2":"o","\xf3":"o","\xf4":"o","\xf5":"o","\xf6":"o","\xf8":"o","\xd9":"U","\xda":"U","\xdb":"U","\xdc":"U","\xf9":"u","\xfa":"u","\xfb":"u","\xfc":"u","\xdd":"Y", - "\xfd":"y","\xff":"y","\xc6":"Ae","\xe6":"ae","\xde":"Th","\xfe":"th","\xdf":"ss"},Tn={"&":"&","<":"<",">":">",'"':""","'":"'","`":"`"},Ln={"&":"&","<":"<",">":">",""":'"',"'":"'","`":"`"},zn={"function":true,object:true},Bn={0:"x30",1:"x31",2:"x32",3:"x33",4:"x34",5:"x35",6:"x36",7:"x37",8:"x38",9:"x39",A:"x41",B:"x42",C:"x43",D:"x44",E:"x45",F:"x46",a:"x61",b:"x62",c:"x63",d:"x64",e:"x65",f:"x66",n:"x6e",r:"x72",t:"x74",u:"x75",v:"x76",x:"x78"},Dn={"\\":"\\", - "'":"'","\n":"n","\r":"r","\u2028":"u2028","\u2029":"u2029"},Mn=zn[typeof exports]&&exports&&!exports.nodeType&&exports,qn=zn[typeof module]&&module&&!module.nodeType&&module,Pn=zn[typeof self]&&self&&self.Object&&self,Kn=zn[typeof window]&&window&&window.Object&&window,Vn=qn&&qn.exports===Mn&&Mn,Zn=Mn&&qn&&typeof global=="object"&&global&&global.Object&&global||Kn!==(this&&this.window)&&Kn||Pn||this,Yn=m();typeof define=="function"&&typeof define.amd=="object"&&define.amd?(Zn._=Yn, define(function(){ - return Yn})):Mn&&qn?Vn?(qn.exports=Yn)._=Yn:Mn._=Yn:Zn._=Yn}).call(this); \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/index copy.js b/rawTopoFile/topoviewer/html-static/js/index copy.js deleted file mode 100644 index ba8364ead..000000000 --- a/rawTopoFile/topoviewer/html-static/js/index copy.js +++ /dev/null @@ -1,2443 +0,0 @@ -// Initialize a state variable to track the element's presence -var isPanel01Cy = false; -var nodeClicked = false; -var edgeClicked = false; - -var cy - -var globalSelectedNode -var globalSelectedEdge - -var linkEndpointVisibility = true; -var nodeContainerStatusVisibility = false; - - -var globalShellUrl = "/js/cloudshell" - -var labName -var deploymentType - -document.addEventListener("DOMContentLoaded", async function() { - - detectColorScheme() - - await changeTitle() - - - // Reusable function to initialize a WebSocket connection - function initializeWebSocket(url, onMessageCallback) { - const protocol = location.protocol === "https:" ? "wss://" : "ws://"; - const socket = new WebSocket(protocol + location.host + url); - - socket.onopen = () => { - console.log(`Successfully connected WebSocket to ${url}`); - if (socket.readyState === WebSocket.OPEN) { - socket.send(`Hi From the WebSocketClient-${url}`); - } - }; - - socket.onclose = (event) => { - console.log(`Socket to ${url} closed: `, event); - socket.send("Client Closed!"); - }; - - socket.onerror = (error) => { - console.log(`Socket to ${url} error: `, error); - }; - - socket.onmessage = onMessageCallback; - - return socket; - } - - - // WebSocket for uptime - // WebSocket for uptime - const socketUptime = initializeWebSocket("/uptime", async (msgUptime) => { - environments = await getEnvironments(); - labName = environments["clab-name"] - deploymentType = environments["deploymentType"] - - console.log("initializeWebSocket - getEnvironments", environments) - console.log("initializeWebSocket - labName", environments["clab-name"]) - - const string01 = "Containerlab Topology: " + labName; - const string02 = " ::: Uptime: " + msgUptime.data; - - const ClabSubtitle = document.getElementById("ClabSubtitle"); - const messageBody = string01 + string02; - - ClabSubtitle.innerText = messageBody; - console.log(ClabSubtitle.innerText); - }); - - // WebSocket for ContainerNodeStatus - const socketContainerNodeStatusInitial = initializeWebSocket( - "/containerNodeStatus", - (msgContainerNodeStatus) => { - try { - const { - Names, - Status, - State - } = JSON.parse(msgContainerNodeStatus.data); - setNodeContainerStatus(Names, Status); - console.log(JSON.parse(msgContainerNodeStatus.data)); - - setNodeDataWithContainerAttribute(Names, Status, State); - } catch (error) { - console.error("Error parsing JSON:", error); - } - }, - ); - - //- Instantiate Cytoscape.js - cy = cytoscape({ - container: document.getElementById("cy"), - elements: [], - style: [{ - selector: "node", - style: { - "background-color": "#3498db", - label: "data(label)", - }, - }, ], - }); - - - loadCytoStyle(); - - function loadCytoStyle() { - - // detect light or dark mode - const colorScheme = detectColorScheme(); - console.log('The user prefers:', colorScheme); - - //- Load and apply Cytoscape styles from cy-style.json using fetch - if (colorScheme == "light") { - fetch("css/cy-style.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } else if (colorScheme == "dark") { - fetch("css/cy-style-dark.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } - } - - // Enable grid guide extension - cy.gridGuide({ - // On/Off Modules - - snapToGridOnRelease: true, - snapToGridDuringDrag: false, - snapToAlignmentLocationOnRelease: true, - snapToAlignmentLocationDuringDrag: false, - distributionGuidelines: false, - geometricGuideline: false, - initPosAlignment: false, - centerToEdgeAlignment: false, - resize: false, - parentPadding: false, - drawGrid: false, - - // General - gridSpacing: 10, - snapToGridCenter: true, - - // Draw Grid - zoomDash: true, - panGrid: true, - gridStackOrder: -1, - gridColor: '#dedede', - lineWidth: 1.0, - - // Guidelines - guidelinesStackOrder: 4, - guidelinesTolerance: 2.00, - guidelinesStyle: { - strokeStyle: "#8b7d6b", - geometricGuidelineRange: 400, - range: 100, - minDistRange: 10, - distGuidelineOffset: 10, - horizontalDistColor: "#ff0000", - verticalDistColor: "#00ff00", - initPosAlignmentColor: "#0000ff", - lineDash: [0, 0], - horizontalDistLine: [0, 0], - verticalDistLine: [0, 0], - initPosAlignmentLine: [0, 0], - }, - - // Parent Padding - parentSpacing: -1 - }); - - // Fetch and load element data from a JSON file - // fetch("dataCytoMarshall-" + labName + ".json") - fetch("dataCytoMarshall.json") - - .then((response) => response.json()) - .then((elements) => { - // Add the elements to the Cytoscape instance - // Add the elements to the Cytoscape instance - cy.add(elements); - //- run layout - //- run layout - // const layout = cy.layout({ - // name: "cola", - // nodeGap: 5, - // edgeLength: 100, - // animate: true, - // randomize: false, - // maxSimulationTime: 1500, - // }); - // layout.run(); - - // Dynamically create clusters for CISE layout - // var clustersMap = {}; - // cy.nodes().filter('[parent != "newGroup"]').forEach(function (node) { - // var parent = node.data('parent'); - // if (!clustersMap[parent]) { - // clustersMap[parent] = []; - // } - // clustersMap[parent].push(node.id()); - // }); - // var clusters = Object.values(clustersMap); - - // // Apply CISE layout to existing nodes - // var ciseLayout = cy.layout({ - // name: 'cise', - // clusters: clusters, - // animate: "end", - // padding: 20, - // nodeSeparation: 10, - // idealInterClusterEdgeLengthCoefficient: 1.4, - // allowNodesInsideCircle: false, - // maxRatioOfNodesInsideCircle: 0.1, - // nodeRepulsion: 4500 - // }); - // ciseLayout.run() - // Apply force-directed layout (cose) to new nodes - var coseLayout = cy.layout({ - name: 'cose', - animate: "end", - padding: 20, - nodeOverlap: 10, - idealEdgeLength: 50, - edgeElasticity: 100, - nodeRepulsion: 40, - numIter: 100, - initialTemp: 200, - coolingFactor: 0.95, - gravity: 2.2 - }); - - coseLayout.run(); - - // remove node topoviewer - topoViewerNode = cy.filter('node[name = "topoviewer"]'); - topoViewerNode.remove(); - }) - .catch((error) => { - console.error("Error loading graph data:", error); - }); - - // Instantiate hover text element - const hoverText = document.createElement("box"); - hoverText.classList.add( - "hover-text", - "is-hidden", - "box", - "has-text-weight-normal", - "is-warning", - "is-smallest", - ); - hoverText.textContent = "Launch CloudShell."; - document.body.appendChild(hoverText); - - //- Toggle the Panel(s) when clicking on the cy container - //- Toggle the Panel(s) when clicking on the cy container - document.getElementById("cy").addEventListener("click", function(event) { - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - - loadCytoStyle(); - - if (!nodeClicked && !edgeClicked) { - if (!isPanel01Cy) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - var ViewPortDrawerElements = - document.getElementsByClassName("ViewPortDrawer"); - var ViewPortDrawerArray = Array.from(ViewPortDrawerElements); - ViewPortDrawerArray.forEach(function(element) { - element.style.display = "none"; - }); - - } else { - removeElementById("Panel-01"); - appendMessage(`"try to remove panel01-Cy"`); - } - } - nodeClicked = false; - edgeClicked = false; - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - }); - - // Click event listener for nodes - // Click event listener for nodes - cy.on("click", "node", function(event) { - // This code will be executed when you click on a node - // This code will be executed when you click on a node - const node = event.target; - nodeClicked = true; - - if (!node.isParent()) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - console.log(node) - console.log(node.data("containerDockerExtraAttribute").status) - console.log(node.data("extraData")) - - if (document.getElementById("panel-node").style.display === "none") { - document.getElementById("panel-node").style.display = "block"; - } else { - document.getElementById("panel-node").style.display = "none"; - } - - document.getElementById("panel-node-name").textContent = node.data("extraData").longname - document.getElementById("panel-node-status").textContent = node.data("containerDockerExtraAttribute").status - document.getElementById("panel-node-kind").textContent = node.data("extraData").kind - document.getElementById("panel-node-image").textContent = node.data("extraData").image - document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss - document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn - document.getElementById("panel-node-group").textContent = node.data("extraData").group - document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") - - // set selected node-long-name to global variable - globalSelectedNode = node.data("extraData").longname - console.log("internal: ", globalSelectedNode) - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - } - }); - - // Click event listener for edges - // Click event listener for edges - cy.on("click", "edge", async function(event) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - // This code will be executed when you click on a node - // You can add logic specific to nodes here - const clickedEdge = event.target; - const defaultEdgeColor = "#969799"; - edgeClicked = true; - - console.log(defaultEdgeColor); - - // Change the color of the clicked edge (for example, to red) - clickedEdge.style("line-color", "#0043BF"); - - // Revert the color of other edges that were not clicked (e.g., back to their default color) - cy.edges().forEach(function(edge) { - if (edge !== clickedEdge) { - edge.style("line-color", defaultEdgeColor); - } - }); - - - - - document.getElementById("panel-link").style.display = "none"; - - if (document.getElementById("panel-link").style.display === "none") { - document.getElementById("panel-link").style.display = "block"; - } else { - document.getElementById("panel-link").style.display = "none"; - } - - document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` - - document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` - - document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` - - - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API - clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] - clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) - - if (clabSourceLinkImpairmentClabData && typeof clabSourceLinkImpairmentClabData === 'object' && Object.keys(clabSourceLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabSourceLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabSourceLinkImpairmentClabData returnd data", clabSourceLinkImpairmentClabData["return data"]["delay"]); - - if (clabSourceLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-a-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-delay").value = clabSourceLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-a-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-jitter").value = clabSourceLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-a-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-rate").value = clabSourceLinkImpairmentClabData["return data"]["rate"] - } - - if (clabSourceLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-a-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-loss").value = clabSourceLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // setting default impairment endpoint-b values by getting the data from clab via /clab-link-impairment GET API - clabTargetLinkArgsList = [`${clickedEdge.data("extraData").clabTargetLongName}`,`${clickedEdge.data("extraData").clabTargetPort}`] - clabTargetLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabTargetLinkArgsList) - - if (clabTargetLinkImpairmentClabData && typeof clabTargetLinkImpairmentClabData === 'object' && Object.keys(clabTargetLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabTargetLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabTargetLinkImpairmentClabData returnd data", clabTargetLinkImpairmentClabData["return data"]["delay"]); - - if (clabTargetLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-b-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-delay").value = clabTargetLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-b-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-jitter").value = clabTargetLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-b-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-rate").value = clabTargetLinkImpairmentClabData["return data"]["rate"] - } - - if (clabTargetLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-b-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-loss").value = clabTargetLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // set selected edge-id to global variable - globalSelectedEdge = clickedEdge.data("id") - - appendMessage(`"edgeClicked: " ${edgeClicked}`); - }); - - - - - function generateNodesEvent(event) { - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - console.log("generateNodesButton clicked"); - const numNodes = document.getElementById("generateNodesInput").value; - console.log(numNodes); - //- Check if the number of node is empty - //- Check if the number of node is empty - if (numNodes === null) { - //- if node number empty do nothing - //- if node number empty do nothing - return; - } - const numNodesToGenerate = parseInt(numNodes, 10); - //- Check if the number of node is positive - //- Check if the number of node is positive - if (isNaN(numNodesToGenerate) || numNodesToGenerate <= 0) { - //- Invalid input - //- Invalid input - appendMessage( - "Error:" + "Bro, you gotta enter a valid positive number, come on!", - ); - return; - } - //- Generate nodes with random positions - //- Generate nodes with random positions - for (let i = 0; i < numNodesToGenerate; i++) { - const nodeName = `node-${i + 1}`; - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - }, - position: { - x: Math.random() * 400, - y: Math.random() * 400, - }, - }; - //-cy.add(newNode); - //-cy.add(newNode); - try { - cy.add(newNode); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred:" + error); - } - } - //- Generate random edges between nodes - //- Generate random edges between nodes - for (let i = 0; i < numNodesToGenerate; i++) { - const sourceNode = `node-${i + 1}`; - const targetNode = `node-${Math.floor(Math.random() * numNodesToGenerate) + 1}`; - if (sourceNode !== targetNode) { - const newEdge = { - group: "edges", - data: { - id: "from-" + sourceNode + "-to-" + targetNode, - name: "from-" + sourceNode + "-to-" + targetNode, - source: sourceNode, - target: targetNode, - }, - }; - try { - cy.add(newEdge); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred::" + error); - } - } - } - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //-//- Append a notification message to the textarea - //-//- Append a notification message to the textarea - console.log( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - appendMessage( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - } - - function spawnNodeEvent(event) { - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - const nodeName = document.getElementById("nodeName").value; - console.log(nodeName); - //- Check if a node name is empty - //- Check if a node name is empty - if (nodeName == "") { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Enter node name."); - return; - } - //- Check if a node with the same name already exists - //- Check if a node with the same name already exists - if (cy.$(`node[id = "${nodeName}"]`).length > 0) { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Node with this name already exists."); - return; - } - //- Create a new node element - //- Create a new node element - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - label: nodeName, - }, - }; - //- Add the new node to Cytoscape.js - //- Add the new node to Cytoscape.js - cy.add(newNode); - //- Randomize the positions and center the graph - //- Randomize the positions and center the graph - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //- Append a notification message to the textarea - //- Append a notification message to the textarea - console.log("Info: " + `Nice! Node "${nodeName}" added successfully.`); - appendMessage("Info: " + `Nice! Node "${nodeName}" added successfully.`); - } - - function nodeFindEvent(event) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById("nodeFindInput").value; - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } - } - - function zoomToFitDrawer() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); - } - - function pathFinderDijkstraEvent(event) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "pathFinderSourceNodeInput", - ).value; - const targetNodeId = document.getElementById( - "pathFinderTargetNodeInput", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } - } - - function setNodeContainerStatus(containerNodeName, containerNodeStatus) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - - // Find the corresponding status nodes based on node ID - // Find the corresponding status nodes based on node ID - var statusGreenNode = cy.$(`node[name="${nodeId}-statusGreen"]`); - var statusOrangeNode = cy.$(`node[name="${nodeId}-statusOrange"]`); - var statusRedNode = cy.$(`node[name="${nodeId}-statusRed"]`); - - if (statusGreenNode.length === 0 || statusRedNode.length === 0) { - // If status nodes are not found, skip this node - return; - } - - // Update positions of status nodes relative to the node - var nodePosition = node.position(); - var offset = { - x: -4, - y: -10 - }; - var statusGreenNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - var statusRedNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - - // Check if the nodeContainerStatusVisibility is true - if (nodeContainerStatusVisibility) { - // Check if the containerNodeName includes nodeId and containerNodeStatus includes 'healthy' - if ( - containerNodeName.includes(nodeId) && - (containerNodeStatus.includes("Up") || - containerNodeStatus.includes("healthy")) - ) { - statusGreenNode.show(); - statusRedNode.hide(); - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("(health: starting)") - ) { - statusGreenNode.hide(); - statusOrangeNode.show(); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("Exited") - ) { - statusGreenNode.hide(); - statusRedNode.show(); - } - } else { - statusGreenNode.hide(); - statusRedNode.hide(); - } - - statusGreenNode.position(statusGreenNodePosition); - statusRedNode.position(statusRedNodePosition); - }); - } - - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - if (containerNodeName.includes(nodeId)) { - var containerDockerExtraAttributeData = { - state: state, - status: status, - }; - - node.data( - "containerDockerExtraAttribute", - containerDockerExtraAttributeData, - ); - } - }); - } - - // - // End of JS Functions Event Handling section - // End of JS Functions Event Handling section - // - - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - - - //- Function to get the default node style from cy-style.json - //- Function to get the default node style from cy-style.json - async function getDefaultNodeStyle(node) { - try { - //- Fetch the cy-style.json file - //- Fetch the cy-style.json file - const response = await fetch("cy-style.json"); - //- Check if the response is successful (status code 200) - //- Check if the response is successful (status code 200) - if (!response.ok) { - throw new Error( - `Failed to fetch cy-style.json (${response.status} ${response.statusText})`, - ); - } - //- Parse the JSON response - //- Parse the JSON response - const styleData = await response.json(); - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - const defaultNodeStyle = styleData[0].style; - return defaultNodeStyle; - } catch (error) { - console.error("Error loading cy-style.json:", error); - appendMessage(`Error loading cy-style.json: ${error}`); - //- Return a default style in case of an error - //- Return a default style in case of an error - return { - "background-color": "blue", - "border-color": "gray", - "border-width": "1px", - }; - } - } - - ///-logMessagesPanel Function to add a click event listener to the copy button - ///-logMessagesPanel Function to add a click event listener to the copy button - const copyButton = document.getElementById("copyToClipboardButton"); - copyButton.className = "button is-smallest-element"; - copyButton.addEventListener("click", copyToClipboard); - - /// logMessagesPanel Function to copy textarea content to clipboard - /// logMessagesPanel Function to copy textarea content to clipboard - function copyToClipboard() { - const textarea = document.getElementById("notificationTextarea"); - textarea.select(); - document.execCommand("copy"); - } - - - - // function closePanelEvent(event, panel) { - // panel.style.display = "block"; - // console.log(panel.style.display); - // panel.style.display = "none"; - // } - - function createModal(modalId, modalContent) { - // Create the modal - // Create the modal - const htmlContent = ` - - `; - - const modalDiv = document.createElement("div"); - modalDiv.innerHTML = htmlContent; - modalDiv.id = "modalDivExportViewport"; - - document.body.appendChild(modalDiv); - const modalBackground = document.getElementById( - `${modalId}-modalBackgroundId`, - ); - - modalBackground.addEventListener("click", function() { - const modal = modalBackground.parentNode; - modal.classList.remove("is-active"); - }); - } - - function showModalCaptureViewport(modalId) { - const modalContentSaveViewport = ` - - `; - - // Instantiate modal - // Instantiate modal - createModal("modalSaveViewport", modalContentSaveViewport); - - // create event listener - // create event listener - const performActionButton = document.getElementById("performActionButton"); - performActionButton.addEventListener("click", function() { - const checkboxName = "checkboxSaveViewPort"; - const checkboxes = document.querySelectorAll( - `input[type="checkbox"][name="${checkboxName}"]`, - ); - const selectedOptions = []; - - checkboxes.forEach(function(checkbox) { - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - }); - - // show modal - // show modal - modal = document.getElementById(modalId); - modal.classList.add("is-active"); - } - - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // -}); - -// aarafat-tag: -//// REFACTOR START -//// to-do: -//// - re-create about-panel -//// - re-create log-messages -//// - re-create viewport - -async function initEnv() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - deploymentType = await environments["deployment-type"] - - console.log("Lab-Name: ", labName) - console.log("DeploymentType: ", deploymentType) - return environments, labName - } - -async function changeTitle() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - - console.log("changeTitle() - labName: ", labName) - document.title = `TopoViewer::${labName}`; -} - -async function sshWebBased(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - - console.log("sshWebBased: ", `${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`) - - window.open(`${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`); - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - -async function sshCliCommandCopy(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - clabServerAddress = environments["clab-server-address"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - clabUser = routerData["data"]["extraData"]["clabServerUsername"] - - sshCopyString = `ssh -t ${clabUser}@${clabServerAddress} "ssh admin@${routerName}"` - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(sshCopyString).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = sshCopyString; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - - - -async function linkImpairmentClab(event, impairDirection) { - console.log("linkImpairmentClab - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - var deploymentType = environments["deployment-type"] - var command - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkImpairment- edgeData: ", edgeData) - console.log("linkImpairment- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (impairDirection == "a-to-b") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-a-delay").value - jitterValue = document.getElementById("panel-link-endpoint-a-jitter").value - rateValue = document.getElementById("panel-link-endpoint-a-rate").value - lossValue = document.getElementById("panel-link-endpoint-a-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - - - } else if (impairDirection == "b-to-a") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-b-delay").value - jitterValue = document.getElementById("panel-link-endpoint-b-jitter").value - rateValue = document.getElementById("panel-link-endpoint-b-rate").value - lossValue = document.getElementById("panel-link-endpoint-b-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - - -async function linkWireshark(event, option, endpoint) { - console.log("linkWireshark - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkWireshark - environments: ", environments) - - var deploymentType = environments["deployment-type"] - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkWireshark- edgeData: ", edgeData) - console.log("linkWireshark- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (option == "app") { - if (endpoint == "source") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabSourceLongName}?${clabSourcePort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - - } else if (endpoint == "target") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabTargetLongName}?${clabTargetPort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - } - - window.open(wiresharkHref); - - } else if (option == "copy") { - if (endpoint == "source") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } - } else if (endpoint == "target") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } - } - - console.log("linkWireshark- wiresharkSShCommand: ", wiresharkSshCommand) - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(wiresharkSshCommand).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = wiresharkSshCommand; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - -async function showPanelLogMessages(event) { - document.getElementById("panel-log-messages").style.display = "block"; -} - -///-logMessagesPanel Function to add a click event listener to the close button -document.getElementById("panel-log-messages-close-button").addEventListener("click", () => { - document.getElementById("panel-log-messages").style.display = "none"; -}); - -async function showPanelTopoViewerClient(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - clabServerAddress = environments["clab-server-address"] - clabServerPort = environments["clab-server-port"] - - hrefWindows = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-windows/ClabCapture.app.zip` - hrefMac = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-mac/ClabCapture.app.zip` - - document.getElementById("panel-topoviewer-helper").style.display = "block"; - - const htmlContent = ` -
Wireshark Capture
-

- Please download the following helper app: -

- -

- TopoViewer offers a remote capture feature for intercepting ContainerLab node endpoints. - For the best experience, it's recommended to have both TopoViewer and its helper app installed on client-side. - With the TopoViewer helper app, you can effortlessly automate the launch of Wireshark's GUI. -

-

- Alternatively, if you don't have the helper app, you can simply copy and paste an SSH command to initiate Wireshark manually. - This setup provides flexibility in how you utilize this feature.
-

- `; - document.getElementById("panel-topoviewer-helper-content").innerHTML = htmlContent; -} - -async function showPanelAbout(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - topoViewerVersion = environments["topoviewer-version"] - - document.getElementById("panel-topoviewer-about").style.display = "block"; - - const htmlContent = ` -
-
Version: ${topoViewerVersion}
- -

- Designed and developed by Asad Arafat
-

-

- Special Thanks: -

    -
  • Siva Sivakumar - For pioneering the integration of Bulma CSS, significantly enhancing TopoViewer design and usability.
  • -
  • Gatot Susilo - For seamlessly incorporating TopoViewer into the Komodo2 tool, bridging functionality with innovation.
  • -
  • Gusman Dharma Putra - For his invaluable contribution in integrating TopoViewer into Komodo2, enriching its capabilities.
  • -
  • Sven Wisotzky - For offering insightful feedback that led to significant full stack optimizations.
  • -
-

- - -
- `; - document.getElementById("panel-topoviewer-about-content").innerHTML = htmlContent; -} - -async function sidebarButtonFitScreen(event) { - - // --sidebar-button-background-color-default: rgba(54,58, 69, 1); - // --sidebar-button-background-color-active: rgba(76, 82, 97, 1); - - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - const sidebarButtonColorDefault = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-default'); - const sidebarButtonColorActive = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-active'); - - drawer = document.getElementById("drawer") - if (drawer.style.display === 'block') { - drawer.style.display = 'none'; - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - sidebarButtonFitScreen.style.background = sidebarButtonColorDefault.trim(); - sidebarButtonFitScreen.style.border = sidebarButtonColorActive.trim(); - } else { - drawer.style.display = 'block'; - var sidebarButtons = document.getElementsByClassName("is-sidebar"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < sidebarButtons.length; i++) { - sidebarButtons[i].style.background = sidebarButtonColorDefault.trim(); - sidebarButtons[i].style.border = sidebarButtonColorDefault.trim(); - } - sidebarButtonFitScreen.style.background = sidebarButtonColorActive.trim(); - } - -} - -async function getActualNodesEndpoints(event) { - try { - bulmaToast.toast({ - message: `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - appendMessage( - `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - ); - - showLoadingSpinnerGlobal() - const CyTopoJson = await sendRequestToEndpointGet("/actual-nodes-endpoints", argsList = []) - location.reload(true); - - // Handle the response data - if (CyTopoJson && typeof CyTopoJson === 'object' && Object.keys(CyTopoJson).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", CyTopoJson); - - hideLoadingSpinnerGlobal(); - - - - return CyTopoJson - - } else { - - hideLoadingSpinnerGlobal(); - - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - hideLoadingSpinnerGlobal(); - console.error("Error occurred:", error); - // Handle errors as needed - } -} - -function viewportButtonsZoomToFit() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); -} - -function viewportButtonsLayoutAlgo() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - viewportDrawerLayout = document.getElementById("viewport-drawer-layout") - viewportDrawerLayout.style.display = "block" -} - - - - -async function layoutAlgoChange(event) { - - try { - console.log("layoutAlgoChange clicked"); - - var selectElement = document.getElementById("select-layout-algo"); - var selectedOption = selectElement.value; - - if (selectedOption === "Force Directed") { - console.log("Force Directed algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-force-directed") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-force-directed-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-force-directed")) - console.log(document.getElementById("viewport-drawer-force-directed-reset-start")) - - } else if (selectedOption === "Vertical") { - console.log("Vertical algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-vertical") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-vertical-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-vertical")) - console.log(document.getElementById("viewport-drawer-dc-vertical-reset-start")) - - } else if (selectedOption === "Horizontal") { - console.log("Horizontal algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-horizontal") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-horizontal-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-horizontal")) - console.log(document.getElementById("viewport-drawer-dc-horizontal-reset-start")) - } - - }catch (error) { - console.error("Error occurred:", error); - // Handle errors as needed - } -} - - -function viewportButtonsTopologyOverview() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyOverview clicked") - viewportDrawerLayout = document.getElementById("viewport-drawer-topology-overview") - viewportDrawerLayout.style.display = "block" - - viewportDrawerLayoutContent = document.getElementById("viewport-drawer-topology-overview-content") - viewportDrawerLayoutContent.style.display = "block" -} - -function viewportButtonsTopologyCapture() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyCapture clicked") - - viewportDrawerCapture = document.getElementById("viewport-drawer-capture-sceenshoot") - viewportDrawerCapture.style.display = "block" - - viewportDrawerCaptureContent = document.getElementById("viewport-drawer-capture-sceenshoot-content") - viewportDrawerCaptureContent.style.display = "block" -} - -function viewportButtonsLabelEndpoint() { - if (linkEndpointVisibility) { - cy.edges().forEach(function(edge) { - // edge.style("source-label", "."); - // edge.style("target-label", "."); - edge.style("text-opacity", 0); - edge.style("text-background-opacity", 0); - - - linkEndpointVisibility = false; - }); - } else { - cy.edges().forEach(function(edge) { - edge.style("text-opacity", 1); - edge.style("text-background-opacity", 0.7); - linkEndpointVisibility = true; - }); - } -} - -function viewportButtonContainerStatusVisibility() { - if (nodeContainerStatusVisibility) { - nodeContainerStatusVisibility = false; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `Alright, mission control, we're standing down. 🛑🔍 Container status probing aborted. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - nodeContainerStatusVisibility = true; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `🕵️‍♂️ Bro, we're currently on a mission to probe that container status! Stay tuned for the results. 🔍🚀👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } -} - - -function viewportDrawerLayoutForceDirected() { - edgeLengthSlider = document.getElementById("force-directed-slider-link-lenght"); - nodeGapSlider = document.getElementById("force-directed-slider-node-gap"); - - const edgeLengthValue = parseFloat(edgeLengthSlider.value); - const nodeGapValue = parseFloat(nodeGapSlider.value); - - console.log("edgeLengthValue", edgeLengthValue); - console.log("nodeGapValue", nodeGapValue); - - cy.layout( - { - fit: true, - name: "cola", - animate: true, - randomize: false, - maxSimulationTime: 400, - edgeLength: function(e) { - return edgeLengthValue / e.data("weight"); - }, - nodeGap: function(e) { - return nodeGapValue / e.data("weight"); - }, - }) - .run(); -} - -function viewportDrawerLayoutVertical() { - nodevGap = document.getElementById("vertical-layout-slider-node-v-gap"); - groupvGap = document.getElementById("vertical-layout-slider-group-v-gap"); - - const nodevGapValue = parseFloat(nodevGap.value); - const groupvGapValue = parseFloat(groupvGap.value); - - console.log("nodevGapValue", nodevGapValue); - console.log("groupvGapValue", groupvGapValue); - - const xOffset = parseFloat(nodevGapValue); - const yOffset = parseFloat(groupvGapValue); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numRows = 1; - - const cellWidth = node.width() / children.length; - // const xOffset = 5 - - children.forEach(function(child, index) { - // Position children in rows - const xPos = index * (cellWidth + xOffset); - const yPos = 0; - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxWidth = 0; - var centerX = 0; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const width = node.width(); - if (width > maxWidth) { - maxWidth = width; - console.log("ParentMaxWidth: ", maxWidth); - } - } - }); - - const divisionFactor = maxWidth / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let yPos = 0; - // const yOffset = 50; - // const yOffset = 50; - - // Position parent nodes vertically and center them horizontally - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const xPos = centerX - parent.width() / divisionFactor; - // to the left compared to the center of the widest parent node. - parent.position({ - x: xPos, - y: yPos - }); - yPos += yOffset; - }); - cy.fit(); - }, delay); -} - -function viewportDrawerLayoutHorizontal() { - nodehGap = document.getElementById("horizontal-layout-slider-node-h-gap"); - grouphGap = document.getElementById("horizontal-layout-slider-group-h-gap"); - - const horizontalNodeGap = parseFloat(nodehGap.value); - const horizontalGroupGap = parseFloat(grouphGap.value); - - console.log("nodevGapValue", horizontalNodeGap); - console.log("groupvGapValue", horizontalGroupGap); - - const yOffset = parseFloat(horizontalNodeGap); - const xOffset = parseFloat(horizontalGroupGap); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numColumns = 1; - const cellHeight = node.height() / children.length; - // const yOffset = 5; - - children.forEach(function(child, index) { - // Position children in columns - const xPos = 0; - const yPos = index * (cellHeight + yOffset); - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxHeight = 0; - var centerX = cy.width() / 2; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const height = node.height(); - if (height > maxHeight) { - maxHeight = height; - console.log("ParentMaxHeight: ", maxHeight); - } - } - }); - - const divisionFactor = maxHeight / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let xPos = 0; - // const xOffset = 50; - - // Position parent nodes horizontally and center them vertically - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const yPos = centerY - parent.height() / divisionFactor; - parent.position({ - x: xPos, - y: yPos - }); - xPos -= xOffset; - }); - - cy.fit(); - }, delay); - -} - - -function viewportDrawerCaptureButton() { - - console.log ("viewportDrawerCaptureButton() - clicked") - - - - - // Get all checkbox inputs within the specific div - const checkboxes = document.querySelectorAll('#viewport-drawer-capture-sceenshoot-content .checkbox-input'); - - // Initialize an array to store the values of checked checkboxes - const selectedOptions = []; - - // Iterate through the NodeList of checkboxes - checkboxes.forEach((checkbox) => { - // If the checkbox is checked, push its value to the array - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - console.log ("viewportDrawerCaptureButton() - ", selectedOptions) - - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - -} - -async function captureAndSaveViewportAsDrawIo(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - const drawIoWidht = canvasElement.width / 10; - const drawIoHeight = canvasElement.height / 10; - const drawIoaAspectRatio = drawIoWidht / drawIoHeight; - - const mxGraphHeader = ` - - - `; - - const mxGraphFooter = ` - `; - - const mxCells = []; - - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - function createMxCellForNode(node, imageURL) { - if (node.isParent()) { - return ` - - - `; - } else if ( - !node.data("id").includes("statusGreen") && - !node.data("id").includes("statusRed") - ) { - return ` - - - `; - } - } - - cy.nodes().forEach(function(node) { - let imageURL; - switch (node.data("topoViewerRole")) { - case "pe": - imageURL = `http://${location.host}/images/clab-pe-light-blue.png`; - break; - case "controller": - imageURL = - `http://${location.host}/images/clab-controller-light-blue.png`; - break; - case "pon": - imageURL = `http://${location.host}/images/clab-pon-dark-blue.png`; - break; - case "dcgw": - imageURL = `http://${location.host}/images/clab-dcgw-dark-blue.png`; - break; - case "leaf": - imageURL = `http://${location.host}/images/clab-leaf-light-blue.png`; - break; - case "spine": - imageURL = `http://${location.host}/images/clab-spine-dark-blue.png`; - break; - case "super-spine": - imageURL = `http://${location.host}/images/clab-spine-light-blue.png`; - break; - } - mxCells.push(createMxCellForNode(node, imageURL)); - }); - - cy.edges().forEach(function(edge) { - mxCells.push(` - - - - - - - - - - - - - - `); - }); - - // Combine all parts and create XML - const mxGraphXML = mxGraphHeader + mxCells.join("") + mxGraphFooter; - - // Create a Blob from the XML - const blob = new Blob([mxGraphXML], { - type: "application/xml", - }); - - // Create a URL for the Blob - const url = window.URL.createObjectURL(blob); - - // Create a download link and trigger a click event - const a = document.createElement("a"); - a.style.display = "none"; - a.href = url; - a.download = "filename.drawio"; - document.body.appendChild(a); - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - a.click(); - - // Clean up by revoking the URL and removing the download link - window.URL.revokeObjectURL(url); - document.body.removeChild(a); -} -async function captureAndSaveViewportAsPng(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - - const zoomScaleFactor = 1; - - // Check if the canvas element exists and is an HTMLCanvasElement - // Check if the canvas element exists and is an HTMLCanvasElement - if (canvasElement instanceof HTMLCanvasElement) { - // Calculate the new canvas dimensions based on the high resolution factor - // Calculate the new canvas dimensions based on the high resolution factor - const newWidth = canvasElement.width * zoomScaleFactor; - const newHeight = canvasElement.height * zoomScaleFactor; - - // Create a new canvas element with the increased dimensions - // Create a new canvas element with the increased dimensions - const newCanvas = document.createElement("canvas"); - newCanvas.width = newWidth; - newCanvas.height = newHeight; - const newCanvasContext = newCanvas.getContext("2d"); - - // Scale the canvas content to the new dimensions - // Scale the canvas content to the new dimensions - newCanvasContext.scale(zoomScaleFactor, zoomScaleFactor); - - // Fill the new canvas with a white background - // Fill the new canvas with a white background - newCanvasContext.fillStyle = "white"; - newCanvasContext.fillRect(0, 0, newWidth, newHeight); - - // Draw the original canvas content on the new canvas - // Draw the original canvas content on the new canvas - newCanvasContext.drawImage(canvasElement, 0, 0); - - // Convert the new canvas to a data URL with a white background - // Convert the new canvas to a data URL with a white background - const dataUrl = newCanvas.toDataURL("image/png"); - - // Create an anchor element to trigger the download - // Create an anchor element to trigger the download - const link = document.createElement("a"); - link.href = dataUrl; - link.download = "cytoscape-viewport.png"; - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - // Simulate a click to trigger the download - link.click(); - } else { - console.error( - "Canvas element for layer2-node is not found or is not a valid HTML canvas element.", - ); - } -} - - - -// aarafat-tag: -//// REFACTOR END - -// logMessagesPanel manager -///-logMessagesPanel Function to append message function -function appendMessage(message) { - // const textarea = document.getElementById('notificationTextarea'); - const textarea = document.getElementById("notificationTextarea"); - - // Get the current date and time - const timestamp = new Date().toLocaleString(); - - textarea.value += `[${timestamp}] ${message}\n`; - textarea.scrollTop = textarea.scrollHeight; -} - -function nodeFindDrawer(cy) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById( - "panelBlock-viewportButtons-buttonfindNode-divPanelBlock-columnContainerlabelFindNodeNodeName-panelContentlabelFindNodeNodeName-columnsPanelContentlabelFindNodeNodeName-labelColumnlabelFindNodeNodeName-inputColumnlabelFindNodeNodeName-labellabelFindNodeNodeName", - ).value; - - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } -} - -function pathFinderDijkstraDrawer(cy) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteSource-panelContentlabelFindRouteSource-columnsPanelContentlabelFindRouteSource-labelColumnlabelFindRouteSource-inputColumnlabelFindRouteSource-labellabelFindRouteSource", - ).value; - const targetNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteTarget-panelContentlabelFindRouteTarget-columnsPanelContentlabelFindRouteTarget-labelColumnlabelFindRouteTarget-inputColumnlabelFindRouteTarget-labellabelFindRouteTarget", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } -} - -// sleep funtion -function sleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); -} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/index.cise.bak b/rawTopoFile/topoviewer/html-static/js/index.cise.bak deleted file mode 100644 index ba8364ead..000000000 --- a/rawTopoFile/topoviewer/html-static/js/index.cise.bak +++ /dev/null @@ -1,2443 +0,0 @@ -// Initialize a state variable to track the element's presence -var isPanel01Cy = false; -var nodeClicked = false; -var edgeClicked = false; - -var cy - -var globalSelectedNode -var globalSelectedEdge - -var linkEndpointVisibility = true; -var nodeContainerStatusVisibility = false; - - -var globalShellUrl = "/js/cloudshell" - -var labName -var deploymentType - -document.addEventListener("DOMContentLoaded", async function() { - - detectColorScheme() - - await changeTitle() - - - // Reusable function to initialize a WebSocket connection - function initializeWebSocket(url, onMessageCallback) { - const protocol = location.protocol === "https:" ? "wss://" : "ws://"; - const socket = new WebSocket(protocol + location.host + url); - - socket.onopen = () => { - console.log(`Successfully connected WebSocket to ${url}`); - if (socket.readyState === WebSocket.OPEN) { - socket.send(`Hi From the WebSocketClient-${url}`); - } - }; - - socket.onclose = (event) => { - console.log(`Socket to ${url} closed: `, event); - socket.send("Client Closed!"); - }; - - socket.onerror = (error) => { - console.log(`Socket to ${url} error: `, error); - }; - - socket.onmessage = onMessageCallback; - - return socket; - } - - - // WebSocket for uptime - // WebSocket for uptime - const socketUptime = initializeWebSocket("/uptime", async (msgUptime) => { - environments = await getEnvironments(); - labName = environments["clab-name"] - deploymentType = environments["deploymentType"] - - console.log("initializeWebSocket - getEnvironments", environments) - console.log("initializeWebSocket - labName", environments["clab-name"]) - - const string01 = "Containerlab Topology: " + labName; - const string02 = " ::: Uptime: " + msgUptime.data; - - const ClabSubtitle = document.getElementById("ClabSubtitle"); - const messageBody = string01 + string02; - - ClabSubtitle.innerText = messageBody; - console.log(ClabSubtitle.innerText); - }); - - // WebSocket for ContainerNodeStatus - const socketContainerNodeStatusInitial = initializeWebSocket( - "/containerNodeStatus", - (msgContainerNodeStatus) => { - try { - const { - Names, - Status, - State - } = JSON.parse(msgContainerNodeStatus.data); - setNodeContainerStatus(Names, Status); - console.log(JSON.parse(msgContainerNodeStatus.data)); - - setNodeDataWithContainerAttribute(Names, Status, State); - } catch (error) { - console.error("Error parsing JSON:", error); - } - }, - ); - - //- Instantiate Cytoscape.js - cy = cytoscape({ - container: document.getElementById("cy"), - elements: [], - style: [{ - selector: "node", - style: { - "background-color": "#3498db", - label: "data(label)", - }, - }, ], - }); - - - loadCytoStyle(); - - function loadCytoStyle() { - - // detect light or dark mode - const colorScheme = detectColorScheme(); - console.log('The user prefers:', colorScheme); - - //- Load and apply Cytoscape styles from cy-style.json using fetch - if (colorScheme == "light") { - fetch("css/cy-style.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } else if (colorScheme == "dark") { - fetch("css/cy-style-dark.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } - } - - // Enable grid guide extension - cy.gridGuide({ - // On/Off Modules - - snapToGridOnRelease: true, - snapToGridDuringDrag: false, - snapToAlignmentLocationOnRelease: true, - snapToAlignmentLocationDuringDrag: false, - distributionGuidelines: false, - geometricGuideline: false, - initPosAlignment: false, - centerToEdgeAlignment: false, - resize: false, - parentPadding: false, - drawGrid: false, - - // General - gridSpacing: 10, - snapToGridCenter: true, - - // Draw Grid - zoomDash: true, - panGrid: true, - gridStackOrder: -1, - gridColor: '#dedede', - lineWidth: 1.0, - - // Guidelines - guidelinesStackOrder: 4, - guidelinesTolerance: 2.00, - guidelinesStyle: { - strokeStyle: "#8b7d6b", - geometricGuidelineRange: 400, - range: 100, - minDistRange: 10, - distGuidelineOffset: 10, - horizontalDistColor: "#ff0000", - verticalDistColor: "#00ff00", - initPosAlignmentColor: "#0000ff", - lineDash: [0, 0], - horizontalDistLine: [0, 0], - verticalDistLine: [0, 0], - initPosAlignmentLine: [0, 0], - }, - - // Parent Padding - parentSpacing: -1 - }); - - // Fetch and load element data from a JSON file - // fetch("dataCytoMarshall-" + labName + ".json") - fetch("dataCytoMarshall.json") - - .then((response) => response.json()) - .then((elements) => { - // Add the elements to the Cytoscape instance - // Add the elements to the Cytoscape instance - cy.add(elements); - //- run layout - //- run layout - // const layout = cy.layout({ - // name: "cola", - // nodeGap: 5, - // edgeLength: 100, - // animate: true, - // randomize: false, - // maxSimulationTime: 1500, - // }); - // layout.run(); - - // Dynamically create clusters for CISE layout - // var clustersMap = {}; - // cy.nodes().filter('[parent != "newGroup"]').forEach(function (node) { - // var parent = node.data('parent'); - // if (!clustersMap[parent]) { - // clustersMap[parent] = []; - // } - // clustersMap[parent].push(node.id()); - // }); - // var clusters = Object.values(clustersMap); - - // // Apply CISE layout to existing nodes - // var ciseLayout = cy.layout({ - // name: 'cise', - // clusters: clusters, - // animate: "end", - // padding: 20, - // nodeSeparation: 10, - // idealInterClusterEdgeLengthCoefficient: 1.4, - // allowNodesInsideCircle: false, - // maxRatioOfNodesInsideCircle: 0.1, - // nodeRepulsion: 4500 - // }); - // ciseLayout.run() - // Apply force-directed layout (cose) to new nodes - var coseLayout = cy.layout({ - name: 'cose', - animate: "end", - padding: 20, - nodeOverlap: 10, - idealEdgeLength: 50, - edgeElasticity: 100, - nodeRepulsion: 40, - numIter: 100, - initialTemp: 200, - coolingFactor: 0.95, - gravity: 2.2 - }); - - coseLayout.run(); - - // remove node topoviewer - topoViewerNode = cy.filter('node[name = "topoviewer"]'); - topoViewerNode.remove(); - }) - .catch((error) => { - console.error("Error loading graph data:", error); - }); - - // Instantiate hover text element - const hoverText = document.createElement("box"); - hoverText.classList.add( - "hover-text", - "is-hidden", - "box", - "has-text-weight-normal", - "is-warning", - "is-smallest", - ); - hoverText.textContent = "Launch CloudShell."; - document.body.appendChild(hoverText); - - //- Toggle the Panel(s) when clicking on the cy container - //- Toggle the Panel(s) when clicking on the cy container - document.getElementById("cy").addEventListener("click", function(event) { - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - - loadCytoStyle(); - - if (!nodeClicked && !edgeClicked) { - if (!isPanel01Cy) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - var ViewPortDrawerElements = - document.getElementsByClassName("ViewPortDrawer"); - var ViewPortDrawerArray = Array.from(ViewPortDrawerElements); - ViewPortDrawerArray.forEach(function(element) { - element.style.display = "none"; - }); - - } else { - removeElementById("Panel-01"); - appendMessage(`"try to remove panel01-Cy"`); - } - } - nodeClicked = false; - edgeClicked = false; - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - }); - - // Click event listener for nodes - // Click event listener for nodes - cy.on("click", "node", function(event) { - // This code will be executed when you click on a node - // This code will be executed when you click on a node - const node = event.target; - nodeClicked = true; - - if (!node.isParent()) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - console.log(node) - console.log(node.data("containerDockerExtraAttribute").status) - console.log(node.data("extraData")) - - if (document.getElementById("panel-node").style.display === "none") { - document.getElementById("panel-node").style.display = "block"; - } else { - document.getElementById("panel-node").style.display = "none"; - } - - document.getElementById("panel-node-name").textContent = node.data("extraData").longname - document.getElementById("panel-node-status").textContent = node.data("containerDockerExtraAttribute").status - document.getElementById("panel-node-kind").textContent = node.data("extraData").kind - document.getElementById("panel-node-image").textContent = node.data("extraData").image - document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss - document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn - document.getElementById("panel-node-group").textContent = node.data("extraData").group - document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") - - // set selected node-long-name to global variable - globalSelectedNode = node.data("extraData").longname - console.log("internal: ", globalSelectedNode) - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - } - }); - - // Click event listener for edges - // Click event listener for edges - cy.on("click", "edge", async function(event) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - // This code will be executed when you click on a node - // You can add logic specific to nodes here - const clickedEdge = event.target; - const defaultEdgeColor = "#969799"; - edgeClicked = true; - - console.log(defaultEdgeColor); - - // Change the color of the clicked edge (for example, to red) - clickedEdge.style("line-color", "#0043BF"); - - // Revert the color of other edges that were not clicked (e.g., back to their default color) - cy.edges().forEach(function(edge) { - if (edge !== clickedEdge) { - edge.style("line-color", defaultEdgeColor); - } - }); - - - - - document.getElementById("panel-link").style.display = "none"; - - if (document.getElementById("panel-link").style.display === "none") { - document.getElementById("panel-link").style.display = "block"; - } else { - document.getElementById("panel-link").style.display = "none"; - } - - document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` - - document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` - - document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` - - - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API - clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] - clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) - - if (clabSourceLinkImpairmentClabData && typeof clabSourceLinkImpairmentClabData === 'object' && Object.keys(clabSourceLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabSourceLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabSourceLinkImpairmentClabData returnd data", clabSourceLinkImpairmentClabData["return data"]["delay"]); - - if (clabSourceLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-a-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-delay").value = clabSourceLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-a-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-jitter").value = clabSourceLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-a-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-rate").value = clabSourceLinkImpairmentClabData["return data"]["rate"] - } - - if (clabSourceLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-a-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-loss").value = clabSourceLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // setting default impairment endpoint-b values by getting the data from clab via /clab-link-impairment GET API - clabTargetLinkArgsList = [`${clickedEdge.data("extraData").clabTargetLongName}`,`${clickedEdge.data("extraData").clabTargetPort}`] - clabTargetLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabTargetLinkArgsList) - - if (clabTargetLinkImpairmentClabData && typeof clabTargetLinkImpairmentClabData === 'object' && Object.keys(clabTargetLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabTargetLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabTargetLinkImpairmentClabData returnd data", clabTargetLinkImpairmentClabData["return data"]["delay"]); - - if (clabTargetLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-b-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-delay").value = clabTargetLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-b-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-jitter").value = clabTargetLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-b-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-rate").value = clabTargetLinkImpairmentClabData["return data"]["rate"] - } - - if (clabTargetLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-b-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-loss").value = clabTargetLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // set selected edge-id to global variable - globalSelectedEdge = clickedEdge.data("id") - - appendMessage(`"edgeClicked: " ${edgeClicked}`); - }); - - - - - function generateNodesEvent(event) { - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - console.log("generateNodesButton clicked"); - const numNodes = document.getElementById("generateNodesInput").value; - console.log(numNodes); - //- Check if the number of node is empty - //- Check if the number of node is empty - if (numNodes === null) { - //- if node number empty do nothing - //- if node number empty do nothing - return; - } - const numNodesToGenerate = parseInt(numNodes, 10); - //- Check if the number of node is positive - //- Check if the number of node is positive - if (isNaN(numNodesToGenerate) || numNodesToGenerate <= 0) { - //- Invalid input - //- Invalid input - appendMessage( - "Error:" + "Bro, you gotta enter a valid positive number, come on!", - ); - return; - } - //- Generate nodes with random positions - //- Generate nodes with random positions - for (let i = 0; i < numNodesToGenerate; i++) { - const nodeName = `node-${i + 1}`; - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - }, - position: { - x: Math.random() * 400, - y: Math.random() * 400, - }, - }; - //-cy.add(newNode); - //-cy.add(newNode); - try { - cy.add(newNode); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred:" + error); - } - } - //- Generate random edges between nodes - //- Generate random edges between nodes - for (let i = 0; i < numNodesToGenerate; i++) { - const sourceNode = `node-${i + 1}`; - const targetNode = `node-${Math.floor(Math.random() * numNodesToGenerate) + 1}`; - if (sourceNode !== targetNode) { - const newEdge = { - group: "edges", - data: { - id: "from-" + sourceNode + "-to-" + targetNode, - name: "from-" + sourceNode + "-to-" + targetNode, - source: sourceNode, - target: targetNode, - }, - }; - try { - cy.add(newEdge); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred::" + error); - } - } - } - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //-//- Append a notification message to the textarea - //-//- Append a notification message to the textarea - console.log( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - appendMessage( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - } - - function spawnNodeEvent(event) { - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - const nodeName = document.getElementById("nodeName").value; - console.log(nodeName); - //- Check if a node name is empty - //- Check if a node name is empty - if (nodeName == "") { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Enter node name."); - return; - } - //- Check if a node with the same name already exists - //- Check if a node with the same name already exists - if (cy.$(`node[id = "${nodeName}"]`).length > 0) { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Node with this name already exists."); - return; - } - //- Create a new node element - //- Create a new node element - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - label: nodeName, - }, - }; - //- Add the new node to Cytoscape.js - //- Add the new node to Cytoscape.js - cy.add(newNode); - //- Randomize the positions and center the graph - //- Randomize the positions and center the graph - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //- Append a notification message to the textarea - //- Append a notification message to the textarea - console.log("Info: " + `Nice! Node "${nodeName}" added successfully.`); - appendMessage("Info: " + `Nice! Node "${nodeName}" added successfully.`); - } - - function nodeFindEvent(event) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById("nodeFindInput").value; - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } - } - - function zoomToFitDrawer() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); - } - - function pathFinderDijkstraEvent(event) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "pathFinderSourceNodeInput", - ).value; - const targetNodeId = document.getElementById( - "pathFinderTargetNodeInput", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } - } - - function setNodeContainerStatus(containerNodeName, containerNodeStatus) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - - // Find the corresponding status nodes based on node ID - // Find the corresponding status nodes based on node ID - var statusGreenNode = cy.$(`node[name="${nodeId}-statusGreen"]`); - var statusOrangeNode = cy.$(`node[name="${nodeId}-statusOrange"]`); - var statusRedNode = cy.$(`node[name="${nodeId}-statusRed"]`); - - if (statusGreenNode.length === 0 || statusRedNode.length === 0) { - // If status nodes are not found, skip this node - return; - } - - // Update positions of status nodes relative to the node - var nodePosition = node.position(); - var offset = { - x: -4, - y: -10 - }; - var statusGreenNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - var statusRedNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - - // Check if the nodeContainerStatusVisibility is true - if (nodeContainerStatusVisibility) { - // Check if the containerNodeName includes nodeId and containerNodeStatus includes 'healthy' - if ( - containerNodeName.includes(nodeId) && - (containerNodeStatus.includes("Up") || - containerNodeStatus.includes("healthy")) - ) { - statusGreenNode.show(); - statusRedNode.hide(); - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("(health: starting)") - ) { - statusGreenNode.hide(); - statusOrangeNode.show(); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("Exited") - ) { - statusGreenNode.hide(); - statusRedNode.show(); - } - } else { - statusGreenNode.hide(); - statusRedNode.hide(); - } - - statusGreenNode.position(statusGreenNodePosition); - statusRedNode.position(statusRedNodePosition); - }); - } - - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - if (containerNodeName.includes(nodeId)) { - var containerDockerExtraAttributeData = { - state: state, - status: status, - }; - - node.data( - "containerDockerExtraAttribute", - containerDockerExtraAttributeData, - ); - } - }); - } - - // - // End of JS Functions Event Handling section - // End of JS Functions Event Handling section - // - - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - - - //- Function to get the default node style from cy-style.json - //- Function to get the default node style from cy-style.json - async function getDefaultNodeStyle(node) { - try { - //- Fetch the cy-style.json file - //- Fetch the cy-style.json file - const response = await fetch("cy-style.json"); - //- Check if the response is successful (status code 200) - //- Check if the response is successful (status code 200) - if (!response.ok) { - throw new Error( - `Failed to fetch cy-style.json (${response.status} ${response.statusText})`, - ); - } - //- Parse the JSON response - //- Parse the JSON response - const styleData = await response.json(); - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - const defaultNodeStyle = styleData[0].style; - return defaultNodeStyle; - } catch (error) { - console.error("Error loading cy-style.json:", error); - appendMessage(`Error loading cy-style.json: ${error}`); - //- Return a default style in case of an error - //- Return a default style in case of an error - return { - "background-color": "blue", - "border-color": "gray", - "border-width": "1px", - }; - } - } - - ///-logMessagesPanel Function to add a click event listener to the copy button - ///-logMessagesPanel Function to add a click event listener to the copy button - const copyButton = document.getElementById("copyToClipboardButton"); - copyButton.className = "button is-smallest-element"; - copyButton.addEventListener("click", copyToClipboard); - - /// logMessagesPanel Function to copy textarea content to clipboard - /// logMessagesPanel Function to copy textarea content to clipboard - function copyToClipboard() { - const textarea = document.getElementById("notificationTextarea"); - textarea.select(); - document.execCommand("copy"); - } - - - - // function closePanelEvent(event, panel) { - // panel.style.display = "block"; - // console.log(panel.style.display); - // panel.style.display = "none"; - // } - - function createModal(modalId, modalContent) { - // Create the modal - // Create the modal - const htmlContent = ` - - `; - - const modalDiv = document.createElement("div"); - modalDiv.innerHTML = htmlContent; - modalDiv.id = "modalDivExportViewport"; - - document.body.appendChild(modalDiv); - const modalBackground = document.getElementById( - `${modalId}-modalBackgroundId`, - ); - - modalBackground.addEventListener("click", function() { - const modal = modalBackground.parentNode; - modal.classList.remove("is-active"); - }); - } - - function showModalCaptureViewport(modalId) { - const modalContentSaveViewport = ` - - `; - - // Instantiate modal - // Instantiate modal - createModal("modalSaveViewport", modalContentSaveViewport); - - // create event listener - // create event listener - const performActionButton = document.getElementById("performActionButton"); - performActionButton.addEventListener("click", function() { - const checkboxName = "checkboxSaveViewPort"; - const checkboxes = document.querySelectorAll( - `input[type="checkbox"][name="${checkboxName}"]`, - ); - const selectedOptions = []; - - checkboxes.forEach(function(checkbox) { - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - }); - - // show modal - // show modal - modal = document.getElementById(modalId); - modal.classList.add("is-active"); - } - - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // -}); - -// aarafat-tag: -//// REFACTOR START -//// to-do: -//// - re-create about-panel -//// - re-create log-messages -//// - re-create viewport - -async function initEnv() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - deploymentType = await environments["deployment-type"] - - console.log("Lab-Name: ", labName) - console.log("DeploymentType: ", deploymentType) - return environments, labName - } - -async function changeTitle() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - - console.log("changeTitle() - labName: ", labName) - document.title = `TopoViewer::${labName}`; -} - -async function sshWebBased(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - - console.log("sshWebBased: ", `${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`) - - window.open(`${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`); - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - -async function sshCliCommandCopy(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - clabServerAddress = environments["clab-server-address"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - clabUser = routerData["data"]["extraData"]["clabServerUsername"] - - sshCopyString = `ssh -t ${clabUser}@${clabServerAddress} "ssh admin@${routerName}"` - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(sshCopyString).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = sshCopyString; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - - - -async function linkImpairmentClab(event, impairDirection) { - console.log("linkImpairmentClab - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - var deploymentType = environments["deployment-type"] - var command - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkImpairment- edgeData: ", edgeData) - console.log("linkImpairment- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (impairDirection == "a-to-b") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-a-delay").value - jitterValue = document.getElementById("panel-link-endpoint-a-jitter").value - rateValue = document.getElementById("panel-link-endpoint-a-rate").value - lossValue = document.getElementById("panel-link-endpoint-a-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - - - } else if (impairDirection == "b-to-a") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-b-delay").value - jitterValue = document.getElementById("panel-link-endpoint-b-jitter").value - rateValue = document.getElementById("panel-link-endpoint-b-rate").value - lossValue = document.getElementById("panel-link-endpoint-b-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - - -async function linkWireshark(event, option, endpoint) { - console.log("linkWireshark - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkWireshark - environments: ", environments) - - var deploymentType = environments["deployment-type"] - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkWireshark- edgeData: ", edgeData) - console.log("linkWireshark- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (option == "app") { - if (endpoint == "source") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabSourceLongName}?${clabSourcePort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - - } else if (endpoint == "target") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabTargetLongName}?${clabTargetPort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - } - - window.open(wiresharkHref); - - } else if (option == "copy") { - if (endpoint == "source") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } - } else if (endpoint == "target") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } - } - - console.log("linkWireshark- wiresharkSShCommand: ", wiresharkSshCommand) - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(wiresharkSshCommand).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = wiresharkSshCommand; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - -async function showPanelLogMessages(event) { - document.getElementById("panel-log-messages").style.display = "block"; -} - -///-logMessagesPanel Function to add a click event listener to the close button -document.getElementById("panel-log-messages-close-button").addEventListener("click", () => { - document.getElementById("panel-log-messages").style.display = "none"; -}); - -async function showPanelTopoViewerClient(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - clabServerAddress = environments["clab-server-address"] - clabServerPort = environments["clab-server-port"] - - hrefWindows = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-windows/ClabCapture.app.zip` - hrefMac = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-mac/ClabCapture.app.zip` - - document.getElementById("panel-topoviewer-helper").style.display = "block"; - - const htmlContent = ` -
Wireshark Capture
-

- Please download the following helper app: -

- -

- TopoViewer offers a remote capture feature for intercepting ContainerLab node endpoints. - For the best experience, it's recommended to have both TopoViewer and its helper app installed on client-side. - With the TopoViewer helper app, you can effortlessly automate the launch of Wireshark's GUI. -

-

- Alternatively, if you don't have the helper app, you can simply copy and paste an SSH command to initiate Wireshark manually. - This setup provides flexibility in how you utilize this feature.
-

- `; - document.getElementById("panel-topoviewer-helper-content").innerHTML = htmlContent; -} - -async function showPanelAbout(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - topoViewerVersion = environments["topoviewer-version"] - - document.getElementById("panel-topoviewer-about").style.display = "block"; - - const htmlContent = ` -
-
Version: ${topoViewerVersion}
- -

- Designed and developed by Asad Arafat
-

-

- Special Thanks: -

    -
  • Siva Sivakumar - For pioneering the integration of Bulma CSS, significantly enhancing TopoViewer design and usability.
  • -
  • Gatot Susilo - For seamlessly incorporating TopoViewer into the Komodo2 tool, bridging functionality with innovation.
  • -
  • Gusman Dharma Putra - For his invaluable contribution in integrating TopoViewer into Komodo2, enriching its capabilities.
  • -
  • Sven Wisotzky - For offering insightful feedback that led to significant full stack optimizations.
  • -
-

- - -
- `; - document.getElementById("panel-topoviewer-about-content").innerHTML = htmlContent; -} - -async function sidebarButtonFitScreen(event) { - - // --sidebar-button-background-color-default: rgba(54,58, 69, 1); - // --sidebar-button-background-color-active: rgba(76, 82, 97, 1); - - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - const sidebarButtonColorDefault = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-default'); - const sidebarButtonColorActive = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-active'); - - drawer = document.getElementById("drawer") - if (drawer.style.display === 'block') { - drawer.style.display = 'none'; - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - sidebarButtonFitScreen.style.background = sidebarButtonColorDefault.trim(); - sidebarButtonFitScreen.style.border = sidebarButtonColorActive.trim(); - } else { - drawer.style.display = 'block'; - var sidebarButtons = document.getElementsByClassName("is-sidebar"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < sidebarButtons.length; i++) { - sidebarButtons[i].style.background = sidebarButtonColorDefault.trim(); - sidebarButtons[i].style.border = sidebarButtonColorDefault.trim(); - } - sidebarButtonFitScreen.style.background = sidebarButtonColorActive.trim(); - } - -} - -async function getActualNodesEndpoints(event) { - try { - bulmaToast.toast({ - message: `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - appendMessage( - `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - ); - - showLoadingSpinnerGlobal() - const CyTopoJson = await sendRequestToEndpointGet("/actual-nodes-endpoints", argsList = []) - location.reload(true); - - // Handle the response data - if (CyTopoJson && typeof CyTopoJson === 'object' && Object.keys(CyTopoJson).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", CyTopoJson); - - hideLoadingSpinnerGlobal(); - - - - return CyTopoJson - - } else { - - hideLoadingSpinnerGlobal(); - - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - hideLoadingSpinnerGlobal(); - console.error("Error occurred:", error); - // Handle errors as needed - } -} - -function viewportButtonsZoomToFit() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); -} - -function viewportButtonsLayoutAlgo() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - viewportDrawerLayout = document.getElementById("viewport-drawer-layout") - viewportDrawerLayout.style.display = "block" -} - - - - -async function layoutAlgoChange(event) { - - try { - console.log("layoutAlgoChange clicked"); - - var selectElement = document.getElementById("select-layout-algo"); - var selectedOption = selectElement.value; - - if (selectedOption === "Force Directed") { - console.log("Force Directed algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-force-directed") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-force-directed-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-force-directed")) - console.log(document.getElementById("viewport-drawer-force-directed-reset-start")) - - } else if (selectedOption === "Vertical") { - console.log("Vertical algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-vertical") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-vertical-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-vertical")) - console.log(document.getElementById("viewport-drawer-dc-vertical-reset-start")) - - } else if (selectedOption === "Horizontal") { - console.log("Horizontal algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-horizontal") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-horizontal-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-horizontal")) - console.log(document.getElementById("viewport-drawer-dc-horizontal-reset-start")) - } - - }catch (error) { - console.error("Error occurred:", error); - // Handle errors as needed - } -} - - -function viewportButtonsTopologyOverview() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyOverview clicked") - viewportDrawerLayout = document.getElementById("viewport-drawer-topology-overview") - viewportDrawerLayout.style.display = "block" - - viewportDrawerLayoutContent = document.getElementById("viewport-drawer-topology-overview-content") - viewportDrawerLayoutContent.style.display = "block" -} - -function viewportButtonsTopologyCapture() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyCapture clicked") - - viewportDrawerCapture = document.getElementById("viewport-drawer-capture-sceenshoot") - viewportDrawerCapture.style.display = "block" - - viewportDrawerCaptureContent = document.getElementById("viewport-drawer-capture-sceenshoot-content") - viewportDrawerCaptureContent.style.display = "block" -} - -function viewportButtonsLabelEndpoint() { - if (linkEndpointVisibility) { - cy.edges().forEach(function(edge) { - // edge.style("source-label", "."); - // edge.style("target-label", "."); - edge.style("text-opacity", 0); - edge.style("text-background-opacity", 0); - - - linkEndpointVisibility = false; - }); - } else { - cy.edges().forEach(function(edge) { - edge.style("text-opacity", 1); - edge.style("text-background-opacity", 0.7); - linkEndpointVisibility = true; - }); - } -} - -function viewportButtonContainerStatusVisibility() { - if (nodeContainerStatusVisibility) { - nodeContainerStatusVisibility = false; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `Alright, mission control, we're standing down. 🛑🔍 Container status probing aborted. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - nodeContainerStatusVisibility = true; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `🕵️‍♂️ Bro, we're currently on a mission to probe that container status! Stay tuned for the results. 🔍🚀👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } -} - - -function viewportDrawerLayoutForceDirected() { - edgeLengthSlider = document.getElementById("force-directed-slider-link-lenght"); - nodeGapSlider = document.getElementById("force-directed-slider-node-gap"); - - const edgeLengthValue = parseFloat(edgeLengthSlider.value); - const nodeGapValue = parseFloat(nodeGapSlider.value); - - console.log("edgeLengthValue", edgeLengthValue); - console.log("nodeGapValue", nodeGapValue); - - cy.layout( - { - fit: true, - name: "cola", - animate: true, - randomize: false, - maxSimulationTime: 400, - edgeLength: function(e) { - return edgeLengthValue / e.data("weight"); - }, - nodeGap: function(e) { - return nodeGapValue / e.data("weight"); - }, - }) - .run(); -} - -function viewportDrawerLayoutVertical() { - nodevGap = document.getElementById("vertical-layout-slider-node-v-gap"); - groupvGap = document.getElementById("vertical-layout-slider-group-v-gap"); - - const nodevGapValue = parseFloat(nodevGap.value); - const groupvGapValue = parseFloat(groupvGap.value); - - console.log("nodevGapValue", nodevGapValue); - console.log("groupvGapValue", groupvGapValue); - - const xOffset = parseFloat(nodevGapValue); - const yOffset = parseFloat(groupvGapValue); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numRows = 1; - - const cellWidth = node.width() / children.length; - // const xOffset = 5 - - children.forEach(function(child, index) { - // Position children in rows - const xPos = index * (cellWidth + xOffset); - const yPos = 0; - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxWidth = 0; - var centerX = 0; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const width = node.width(); - if (width > maxWidth) { - maxWidth = width; - console.log("ParentMaxWidth: ", maxWidth); - } - } - }); - - const divisionFactor = maxWidth / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let yPos = 0; - // const yOffset = 50; - // const yOffset = 50; - - // Position parent nodes vertically and center them horizontally - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const xPos = centerX - parent.width() / divisionFactor; - // to the left compared to the center of the widest parent node. - parent.position({ - x: xPos, - y: yPos - }); - yPos += yOffset; - }); - cy.fit(); - }, delay); -} - -function viewportDrawerLayoutHorizontal() { - nodehGap = document.getElementById("horizontal-layout-slider-node-h-gap"); - grouphGap = document.getElementById("horizontal-layout-slider-group-h-gap"); - - const horizontalNodeGap = parseFloat(nodehGap.value); - const horizontalGroupGap = parseFloat(grouphGap.value); - - console.log("nodevGapValue", horizontalNodeGap); - console.log("groupvGapValue", horizontalGroupGap); - - const yOffset = parseFloat(horizontalNodeGap); - const xOffset = parseFloat(horizontalGroupGap); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numColumns = 1; - const cellHeight = node.height() / children.length; - // const yOffset = 5; - - children.forEach(function(child, index) { - // Position children in columns - const xPos = 0; - const yPos = index * (cellHeight + yOffset); - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxHeight = 0; - var centerX = cy.width() / 2; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const height = node.height(); - if (height > maxHeight) { - maxHeight = height; - console.log("ParentMaxHeight: ", maxHeight); - } - } - }); - - const divisionFactor = maxHeight / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let xPos = 0; - // const xOffset = 50; - - // Position parent nodes horizontally and center them vertically - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const yPos = centerY - parent.height() / divisionFactor; - parent.position({ - x: xPos, - y: yPos - }); - xPos -= xOffset; - }); - - cy.fit(); - }, delay); - -} - - -function viewportDrawerCaptureButton() { - - console.log ("viewportDrawerCaptureButton() - clicked") - - - - - // Get all checkbox inputs within the specific div - const checkboxes = document.querySelectorAll('#viewport-drawer-capture-sceenshoot-content .checkbox-input'); - - // Initialize an array to store the values of checked checkboxes - const selectedOptions = []; - - // Iterate through the NodeList of checkboxes - checkboxes.forEach((checkbox) => { - // If the checkbox is checked, push its value to the array - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - console.log ("viewportDrawerCaptureButton() - ", selectedOptions) - - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - -} - -async function captureAndSaveViewportAsDrawIo(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - const drawIoWidht = canvasElement.width / 10; - const drawIoHeight = canvasElement.height / 10; - const drawIoaAspectRatio = drawIoWidht / drawIoHeight; - - const mxGraphHeader = ` - - - `; - - const mxGraphFooter = ` - `; - - const mxCells = []; - - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - function createMxCellForNode(node, imageURL) { - if (node.isParent()) { - return ` - - - `; - } else if ( - !node.data("id").includes("statusGreen") && - !node.data("id").includes("statusRed") - ) { - return ` - - - `; - } - } - - cy.nodes().forEach(function(node) { - let imageURL; - switch (node.data("topoViewerRole")) { - case "pe": - imageURL = `http://${location.host}/images/clab-pe-light-blue.png`; - break; - case "controller": - imageURL = - `http://${location.host}/images/clab-controller-light-blue.png`; - break; - case "pon": - imageURL = `http://${location.host}/images/clab-pon-dark-blue.png`; - break; - case "dcgw": - imageURL = `http://${location.host}/images/clab-dcgw-dark-blue.png`; - break; - case "leaf": - imageURL = `http://${location.host}/images/clab-leaf-light-blue.png`; - break; - case "spine": - imageURL = `http://${location.host}/images/clab-spine-dark-blue.png`; - break; - case "super-spine": - imageURL = `http://${location.host}/images/clab-spine-light-blue.png`; - break; - } - mxCells.push(createMxCellForNode(node, imageURL)); - }); - - cy.edges().forEach(function(edge) { - mxCells.push(` - - - - - - - - - - - - - - `); - }); - - // Combine all parts and create XML - const mxGraphXML = mxGraphHeader + mxCells.join("") + mxGraphFooter; - - // Create a Blob from the XML - const blob = new Blob([mxGraphXML], { - type: "application/xml", - }); - - // Create a URL for the Blob - const url = window.URL.createObjectURL(blob); - - // Create a download link and trigger a click event - const a = document.createElement("a"); - a.style.display = "none"; - a.href = url; - a.download = "filename.drawio"; - document.body.appendChild(a); - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - a.click(); - - // Clean up by revoking the URL and removing the download link - window.URL.revokeObjectURL(url); - document.body.removeChild(a); -} -async function captureAndSaveViewportAsPng(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - - const zoomScaleFactor = 1; - - // Check if the canvas element exists and is an HTMLCanvasElement - // Check if the canvas element exists and is an HTMLCanvasElement - if (canvasElement instanceof HTMLCanvasElement) { - // Calculate the new canvas dimensions based on the high resolution factor - // Calculate the new canvas dimensions based on the high resolution factor - const newWidth = canvasElement.width * zoomScaleFactor; - const newHeight = canvasElement.height * zoomScaleFactor; - - // Create a new canvas element with the increased dimensions - // Create a new canvas element with the increased dimensions - const newCanvas = document.createElement("canvas"); - newCanvas.width = newWidth; - newCanvas.height = newHeight; - const newCanvasContext = newCanvas.getContext("2d"); - - // Scale the canvas content to the new dimensions - // Scale the canvas content to the new dimensions - newCanvasContext.scale(zoomScaleFactor, zoomScaleFactor); - - // Fill the new canvas with a white background - // Fill the new canvas with a white background - newCanvasContext.fillStyle = "white"; - newCanvasContext.fillRect(0, 0, newWidth, newHeight); - - // Draw the original canvas content on the new canvas - // Draw the original canvas content on the new canvas - newCanvasContext.drawImage(canvasElement, 0, 0); - - // Convert the new canvas to a data URL with a white background - // Convert the new canvas to a data URL with a white background - const dataUrl = newCanvas.toDataURL("image/png"); - - // Create an anchor element to trigger the download - // Create an anchor element to trigger the download - const link = document.createElement("a"); - link.href = dataUrl; - link.download = "cytoscape-viewport.png"; - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - // Simulate a click to trigger the download - link.click(); - } else { - console.error( - "Canvas element for layer2-node is not found or is not a valid HTML canvas element.", - ); - } -} - - - -// aarafat-tag: -//// REFACTOR END - -// logMessagesPanel manager -///-logMessagesPanel Function to append message function -function appendMessage(message) { - // const textarea = document.getElementById('notificationTextarea'); - const textarea = document.getElementById("notificationTextarea"); - - // Get the current date and time - const timestamp = new Date().toLocaleString(); - - textarea.value += `[${timestamp}] ${message}\n`; - textarea.scrollTop = textarea.scrollHeight; -} - -function nodeFindDrawer(cy) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById( - "panelBlock-viewportButtons-buttonfindNode-divPanelBlock-columnContainerlabelFindNodeNodeName-panelContentlabelFindNodeNodeName-columnsPanelContentlabelFindNodeNodeName-labelColumnlabelFindNodeNodeName-inputColumnlabelFindNodeNodeName-labellabelFindNodeNodeName", - ).value; - - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } -} - -function pathFinderDijkstraDrawer(cy) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteSource-panelContentlabelFindRouteSource-columnsPanelContentlabelFindRouteSource-labelColumnlabelFindRouteSource-inputColumnlabelFindRouteSource-labellabelFindRouteSource", - ).value; - const targetNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteTarget-panelContentlabelFindRouteTarget-columnsPanelContentlabelFindRouteTarget-labelColumnlabelFindRouteTarget-inputColumnlabelFindRouteTarget-labellabelFindRouteTarget", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } -} - -// sleep funtion -function sleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); -} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/index.js b/rawTopoFile/topoviewer/html-static/js/index.js deleted file mode 100644 index 8e598e014..000000000 --- a/rawTopoFile/topoviewer/html-static/js/index.js +++ /dev/null @@ -1,2402 +0,0 @@ -// Initialize a state variable to track the element's presence -var isPanel01Cy = false; -var nodeClicked = false; -var edgeClicked = false; - -var cy - -var globalSelectedNode -var globalSelectedEdge - -var linkEndpointVisibility = true; -var nodeContainerStatusVisibility = false; - - -var globalShellUrl = "/js/cloudshell" - -var labName -var deploymentType - -document.addEventListener("DOMContentLoaded", async function() { - - detectColorScheme() - - await changeTitle() - - - // Reusable function to initialize a WebSocket connection - function initializeWebSocket(url, onMessageCallback) { - const protocol = location.protocol === "https:" ? "wss://" : "ws://"; - const socket = new WebSocket(protocol + location.host + url); - - socket.onopen = () => { - console.log(`Successfully connected WebSocket to ${url}`); - if (socket.readyState === WebSocket.OPEN) { - socket.send(`Hi From the WebSocketClient-${url}`); - } - }; - - socket.onclose = (event) => { - console.log(`Socket to ${url} closed: `, event); - socket.send("Client Closed!"); - }; - - socket.onerror = (error) => { - console.log(`Socket to ${url} error: `, error); - }; - - socket.onmessage = onMessageCallback; - - return socket; - } - - - // WebSocket for uptime - // WebSocket for uptime - const socketUptime = initializeWebSocket("/uptime", async (msgUptime) => { - environments = await getEnvironments(); - labName = environments["clab-name"] - deploymentType = environments["deploymentType"] - - console.log("initializeWebSocket - getEnvironments", environments) - console.log("initializeWebSocket - labName", environments["clab-name"]) - - const string01 = "Containerlab Topology: " + labName; - const string02 = " ::: Uptime: " + msgUptime.data; - - const ClabSubtitle = document.getElementById("ClabSubtitle"); - const messageBody = string01 + string02; - - ClabSubtitle.innerText = messageBody; - console.log(ClabSubtitle.innerText); - }); - - // WebSocket for ContainerNodeStatus - const socketContainerNodeStatusInitial = initializeWebSocket( - "/containerNodeStatus", - (msgContainerNodeStatus) => { - try { - const { - Names, - Status, - State - } = JSON.parse(msgContainerNodeStatus.data); - setNodeContainerStatus(Names, Status); - console.log(JSON.parse(msgContainerNodeStatus.data)); - - setNodeDataWithContainerAttribute(Names, Status, State); - } catch (error) { - console.error("Error parsing JSON:", error); - } - }, - ); - - //- Instantiate Cytoscape.js - cy = cytoscape({ - container: document.getElementById("cy"), - elements: [], - style: [{ - selector: "node", - style: { - "background-color": "#3498db", - label: "data(label)", - }, - }, ], - }); - - - loadCytoStyle(); - - function loadCytoStyle() { - - // detect light or dark mode - const colorScheme = detectColorScheme(); - console.log('The user prefers:', colorScheme); - - //- Load and apply Cytoscape styles from cy-style.json using fetch - if (colorScheme == "light") { - fetch("css/cy-style.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } else if (colorScheme == "dark") { - fetch("css/cy-style-dark.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } - } - - // Enable grid guide extension - cy.gridGuide({ - // On/Off Modules - - snapToGridOnRelease: true, - snapToGridDuringDrag: false, - snapToAlignmentLocationOnRelease: true, - snapToAlignmentLocationDuringDrag: false, - distributionGuidelines: false, - geometricGuideline: false, - initPosAlignment: false, - centerToEdgeAlignment: false, - resize: false, - parentPadding: false, - drawGrid: false, - - // General - gridSpacing: 10, - snapToGridCenter: true, - - // Draw Grid - zoomDash: true, - panGrid: true, - gridStackOrder: -1, - gridColor: '#dedede', - lineWidth: 1.0, - - // Guidelines - guidelinesStackOrder: 4, - guidelinesTolerance: 2.00, - guidelinesStyle: { - strokeStyle: "#8b7d6b", - geometricGuidelineRange: 400, - range: 100, - minDistRange: 10, - distGuidelineOffset: 10, - horizontalDistColor: "#ff0000", - verticalDistColor: "#00ff00", - initPosAlignmentColor: "#0000ff", - lineDash: [0, 0], - horizontalDistLine: [0, 0], - verticalDistLine: [0, 0], - initPosAlignmentLine: [0, 0], - }, - - // Parent Padding - parentSpacing: -1 - }); - - // Fetch and load element data from a JSON file - // fetch("dataCytoMarshall-" + labName + ".json") - fetch("dataCytoMarshall.json") - - .then((response) => response.json()) - .then((elements) => { - // Add the elements to the Cytoscape instance - // Add the elements to the Cytoscape instance - cy.add(elements); - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLength: 100, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - - // remove node topoviewer - topoViewerNode = cy.filter('node[name = "topoviewer"]'); - topoViewerNode.remove(); - }) - .catch((error) => { - console.error("Error loading graph data:", error); - }); - - // Instantiate hover text element - const hoverText = document.createElement("box"); - hoverText.classList.add( - "hover-text", - "is-hidden", - "box", - "has-text-weight-normal", - "is-warning", - "is-smallest", - ); - hoverText.textContent = "Launch CloudShell."; - document.body.appendChild(hoverText); - - //- Toggle the Panel(s) when clicking on the cy container - //- Toggle the Panel(s) when clicking on the cy container - document.getElementById("cy").addEventListener("click", function(event) { - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - - loadCytoStyle(); - - if (!nodeClicked && !edgeClicked) { - if (!isPanel01Cy) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - var ViewPortDrawerElements = - document.getElementsByClassName("ViewPortDrawer"); - var ViewPortDrawerArray = Array.from(ViewPortDrawerElements); - ViewPortDrawerArray.forEach(function(element) { - element.style.display = "none"; - }); - - } else { - removeElementById("Panel-01"); - appendMessage(`"try to remove panel01-Cy"`); - } - } - nodeClicked = false; - edgeClicked = false; - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - }); - - // Click event listener for nodes - // Click event listener for nodes - cy.on("click", "node", function(event) { - // This code will be executed when you click on a node - // This code will be executed when you click on a node - const node = event.target; - nodeClicked = true; - - if (!node.isParent()) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - console.log(node) - console.log(node.data("containerDockerExtraAttribute").status) - console.log(node.data("extraData")) - - if (document.getElementById("panel-node").style.display === "none") { - document.getElementById("panel-node").style.display = "block"; - } else { - document.getElementById("panel-node").style.display = "none"; - } - - document.getElementById("panel-node-name").textContent = node.data("extraData").longname - document.getElementById("panel-node-status").textContent = node.data("containerDockerExtraAttribute").status - document.getElementById("panel-node-kind").textContent = node.data("extraData").kind - document.getElementById("panel-node-image").textContent = node.data("extraData").image - document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss - document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn - document.getElementById("panel-node-group").textContent = node.data("extraData").group - document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") - - // set selected node-long-name to global variable - globalSelectedNode = node.data("extraData").longname - console.log("internal: ", globalSelectedNode) - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - } - }); - - // Click event listener for edges - // Click event listener for edges - cy.on("click", "edge", async function(event) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - // This code will be executed when you click on a node - // You can add logic specific to nodes here - const clickedEdge = event.target; - const defaultEdgeColor = "#969799"; - edgeClicked = true; - - console.log(defaultEdgeColor); - - // Change the color of the clicked edge (for example, to red) - clickedEdge.style("line-color", "#0043BF"); - - // Revert the color of other edges that were not clicked (e.g., back to their default color) - cy.edges().forEach(function(edge) { - if (edge !== clickedEdge) { - edge.style("line-color", defaultEdgeColor); - } - }); - - - - - document.getElementById("panel-link").style.display = "none"; - - if (document.getElementById("panel-link").style.display === "none") { - document.getElementById("panel-link").style.display = "block"; - } else { - document.getElementById("panel-link").style.display = "none"; - } - - document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` - - document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` - - document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` - - - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API - clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] - clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) - - if (clabSourceLinkImpairmentClabData && typeof clabSourceLinkImpairmentClabData === 'object' && Object.keys(clabSourceLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabSourceLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabSourceLinkImpairmentClabData returnd data", clabSourceLinkImpairmentClabData["return data"]["delay"]); - - if (clabSourceLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-a-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-delay").value = clabSourceLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-a-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-jitter").value = clabSourceLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-a-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-rate").value = clabSourceLinkImpairmentClabData["return data"]["rate"] - } - - if (clabSourceLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-a-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-loss").value = clabSourceLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // setting default impairment endpoint-b values by getting the data from clab via /clab-link-impairment GET API - clabTargetLinkArgsList = [`${clickedEdge.data("extraData").clabTargetLongName}`,`${clickedEdge.data("extraData").clabTargetPort}`] - clabTargetLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabTargetLinkArgsList) - - if (clabTargetLinkImpairmentClabData && typeof clabTargetLinkImpairmentClabData === 'object' && Object.keys(clabTargetLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabTargetLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabTargetLinkImpairmentClabData returnd data", clabTargetLinkImpairmentClabData["return data"]["delay"]); - - if (clabTargetLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-b-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-delay").value = clabTargetLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-b-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-jitter").value = clabTargetLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-b-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-rate").value = clabTargetLinkImpairmentClabData["return data"]["rate"] - } - - if (clabTargetLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-b-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-loss").value = clabTargetLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // set selected edge-id to global variable - globalSelectedEdge = clickedEdge.data("id") - - appendMessage(`"edgeClicked: " ${edgeClicked}`); - }); - - - - - function generateNodesEvent(event) { - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - console.log("generateNodesButton clicked"); - const numNodes = document.getElementById("generateNodesInput").value; - console.log(numNodes); - //- Check if the number of node is empty - //- Check if the number of node is empty - if (numNodes === null) { - //- if node number empty do nothing - //- if node number empty do nothing - return; - } - const numNodesToGenerate = parseInt(numNodes, 10); - //- Check if the number of node is positive - //- Check if the number of node is positive - if (isNaN(numNodesToGenerate) || numNodesToGenerate <= 0) { - //- Invalid input - //- Invalid input - appendMessage( - "Error:" + "Bro, you gotta enter a valid positive number, come on!", - ); - return; - } - //- Generate nodes with random positions - //- Generate nodes with random positions - for (let i = 0; i < numNodesToGenerate; i++) { - const nodeName = `node-${i + 1}`; - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - }, - position: { - x: Math.random() * 400, - y: Math.random() * 400, - }, - }; - //-cy.add(newNode); - //-cy.add(newNode); - try { - cy.add(newNode); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred:" + error); - } - } - //- Generate random edges between nodes - //- Generate random edges between nodes - for (let i = 0; i < numNodesToGenerate; i++) { - const sourceNode = `node-${i + 1}`; - const targetNode = `node-${Math.floor(Math.random() * numNodesToGenerate) + 1}`; - if (sourceNode !== targetNode) { - const newEdge = { - group: "edges", - data: { - id: "from-" + sourceNode + "-to-" + targetNode, - name: "from-" + sourceNode + "-to-" + targetNode, - source: sourceNode, - target: targetNode, - }, - }; - try { - cy.add(newEdge); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred::" + error); - } - } - } - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //-//- Append a notification message to the textarea - //-//- Append a notification message to the textarea - console.log( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - appendMessage( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - } - - function spawnNodeEvent(event) { - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - const nodeName = document.getElementById("nodeName").value; - console.log(nodeName); - //- Check if a node name is empty - //- Check if a node name is empty - if (nodeName == "") { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Enter node name."); - return; - } - //- Check if a node with the same name already exists - //- Check if a node with the same name already exists - if (cy.$(`node[id = "${nodeName}"]`).length > 0) { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Node with this name already exists."); - return; - } - //- Create a new node element - //- Create a new node element - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - label: nodeName, - }, - }; - //- Add the new node to Cytoscape.js - //- Add the new node to Cytoscape.js - cy.add(newNode); - //- Randomize the positions and center the graph - //- Randomize the positions and center the graph - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //- Append a notification message to the textarea - //- Append a notification message to the textarea - console.log("Info: " + `Nice! Node "${nodeName}" added successfully.`); - appendMessage("Info: " + `Nice! Node "${nodeName}" added successfully.`); - } - - function nodeFindEvent(event) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById("nodeFindInput").value; - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } - } - - function zoomToFitDrawer() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); - } - - function pathFinderDijkstraEvent(event) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "pathFinderSourceNodeInput", - ).value; - const targetNodeId = document.getElementById( - "pathFinderTargetNodeInput", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } - } - - function setNodeContainerStatus(containerNodeName, containerNodeStatus) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - - // Find the corresponding status nodes based on node ID - // Find the corresponding status nodes based on node ID - var statusGreenNode = cy.$(`node[name="${nodeId}-statusGreen"]`); - var statusOrangeNode = cy.$(`node[name="${nodeId}-statusOrange"]`); - var statusRedNode = cy.$(`node[name="${nodeId}-statusRed"]`); - - if (statusGreenNode.length === 0 || statusRedNode.length === 0) { - // If status nodes are not found, skip this node - return; - } - - // Update positions of status nodes relative to the node - var nodePosition = node.position(); - var offset = { - x: -4, - y: -10 - }; - var statusGreenNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - var statusRedNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - - // Check if the nodeContainerStatusVisibility is true - if (nodeContainerStatusVisibility) { - // Check if the containerNodeName includes nodeId and containerNodeStatus includes 'healthy' - if ( - containerNodeName.includes(nodeId) && - (containerNodeStatus.includes("Up") || - containerNodeStatus.includes("healthy")) - ) { - statusGreenNode.show(); - statusRedNode.hide(); - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("(health: starting)") - ) { - statusGreenNode.hide(); - statusOrangeNode.show(); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("Exited") - ) { - statusGreenNode.hide(); - statusRedNode.show(); - } - } else { - statusGreenNode.hide(); - statusRedNode.hide(); - } - - statusGreenNode.position(statusGreenNodePosition); - statusRedNode.position(statusRedNodePosition); - }); - } - - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - if (containerNodeName.includes(nodeId)) { - var containerDockerExtraAttributeData = { - state: state, - status: status, - }; - - node.data( - "containerDockerExtraAttribute", - containerDockerExtraAttributeData, - ); - } - }); - } - - // - // End of JS Functions Event Handling section - // End of JS Functions Event Handling section - // - - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - - - //- Function to get the default node style from cy-style.json - //- Function to get the default node style from cy-style.json - async function getDefaultNodeStyle(node) { - try { - //- Fetch the cy-style.json file - //- Fetch the cy-style.json file - const response = await fetch("cy-style.json"); - //- Check if the response is successful (status code 200) - //- Check if the response is successful (status code 200) - if (!response.ok) { - throw new Error( - `Failed to fetch cy-style.json (${response.status} ${response.statusText})`, - ); - } - //- Parse the JSON response - //- Parse the JSON response - const styleData = await response.json(); - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - const defaultNodeStyle = styleData[0].style; - return defaultNodeStyle; - } catch (error) { - console.error("Error loading cy-style.json:", error); - appendMessage(`Error loading cy-style.json: ${error}`); - //- Return a default style in case of an error - //- Return a default style in case of an error - return { - "background-color": "blue", - "border-color": "gray", - "border-width": "1px", - }; - } - } - - ///-logMessagesPanel Function to add a click event listener to the copy button - ///-logMessagesPanel Function to add a click event listener to the copy button - const copyButton = document.getElementById("copyToClipboardButton"); - copyButton.className = "button is-smallest-element"; - copyButton.addEventListener("click", copyToClipboard); - - /// logMessagesPanel Function to copy textarea content to clipboard - /// logMessagesPanel Function to copy textarea content to clipboard - function copyToClipboard() { - const textarea = document.getElementById("notificationTextarea"); - textarea.select(); - document.execCommand("copy"); - } - - - - // function closePanelEvent(event, panel) { - // panel.style.display = "block"; - // console.log(panel.style.display); - // panel.style.display = "none"; - // } - - function createModal(modalId, modalContent) { - // Create the modal - // Create the modal - const htmlContent = ` - - `; - - const modalDiv = document.createElement("div"); - modalDiv.innerHTML = htmlContent; - modalDiv.id = "modalDivExportViewport"; - - document.body.appendChild(modalDiv); - const modalBackground = document.getElementById( - `${modalId}-modalBackgroundId`, - ); - - modalBackground.addEventListener("click", function() { - const modal = modalBackground.parentNode; - modal.classList.remove("is-active"); - }); - } - - function showModalCaptureViewport(modalId) { - const modalContentSaveViewport = ` - - `; - - // Instantiate modal - // Instantiate modal - createModal("modalSaveViewport", modalContentSaveViewport); - - // create event listener - // create event listener - const performActionButton = document.getElementById("performActionButton"); - performActionButton.addEventListener("click", function() { - const checkboxName = "checkboxSaveViewPort"; - const checkboxes = document.querySelectorAll( - `input[type="checkbox"][name="${checkboxName}"]`, - ); - const selectedOptions = []; - - checkboxes.forEach(function(checkbox) { - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - }); - - // show modal - // show modal - modal = document.getElementById(modalId); - modal.classList.add("is-active"); - } - - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // -}); - -// aarafat-tag: -//// REFACTOR START -//// to-do: -//// - re-create about-panel -//// - re-create log-messages -//// - re-create viewport - -async function initEnv() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - deploymentType = await environments["deployment-type"] - - console.log("Lab-Name: ", labName) - console.log("DeploymentType: ", deploymentType) - return environments, labName - } - -async function changeTitle() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - - console.log("changeTitle() - labName: ", labName) - document.title = `TopoViewer::${labName}`; -} - -async function sshWebBased(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - - console.log("sshWebBased: ", `${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`) - - window.open(`${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`); - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - -async function sshCliCommandCopy(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - clabServerAddress = environments["clab-server-address"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - clabUser = routerData["data"]["extraData"]["clabServerUsername"] - - sshCopyString = `ssh -t ${clabUser}@${clabServerAddress} "ssh admin@${routerName}"` - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(sshCopyString).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = sshCopyString; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - - - -async function linkImpairmentClab(event, impairDirection) { - console.log("linkImpairmentClab - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - var deploymentType = environments["deployment-type"] - var command - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkImpairment- edgeData: ", edgeData) - console.log("linkImpairment- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (impairDirection == "a-to-b") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-a-delay").value - jitterValue = document.getElementById("panel-link-endpoint-a-jitter").value - rateValue = document.getElementById("panel-link-endpoint-a-rate").value - lossValue = document.getElementById("panel-link-endpoint-a-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - - - } else if (impairDirection == "b-to-a") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-b-delay").value - jitterValue = document.getElementById("panel-link-endpoint-b-jitter").value - rateValue = document.getElementById("panel-link-endpoint-b-rate").value - lossValue = document.getElementById("panel-link-endpoint-b-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - - -async function linkWireshark(event, option, endpoint) { - console.log("linkWireshark - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkWireshark - environments: ", environments) - - var deploymentType = environments["deployment-type"] - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkWireshark- edgeData: ", edgeData) - console.log("linkWireshark- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (option == "app") { - if (endpoint == "source") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabSourceLongName}?${clabSourcePort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - - } else if (endpoint == "target") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabTargetLongName}?${clabTargetPort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - } - - window.open(wiresharkHref); - - } else if (option == "copy") { - if (endpoint == "source") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } - } else if (endpoint == "target") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } - } - - console.log("linkWireshark- wiresharkSShCommand: ", wiresharkSshCommand) - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(wiresharkSshCommand).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = wiresharkSshCommand; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - -async function showPanelLogMessages(event) { - document.getElementById("panel-log-messages").style.display = "block"; -} - -///-logMessagesPanel Function to add a click event listener to the close button -document.getElementById("panel-log-messages-close-button").addEventListener("click", () => { - document.getElementById("panel-log-messages").style.display = "none"; -}); - -async function showPanelTopoViewerClient(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - clabServerAddress = environments["clab-server-address"] - clabServerPort = environments["clab-server-port"] - - hrefWindows = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-windows/ClabCapture.app.zip` - hrefMac = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-mac/ClabCapture.app.zip` - - document.getElementById("panel-topoviewer-helper").style.display = "block"; - - const htmlContent = ` -
Wireshark Capture
-

- Please download the following helper app: -

- -

- TopoViewer offers a remote capture feature for intercepting ContainerLab node endpoints. - For the best experience, it's recommended to have both TopoViewer and its helper app installed on client-side. - With the TopoViewer helper app, you can effortlessly automate the launch of Wireshark's GUI. -

-

- Alternatively, if you don't have the helper app, you can simply copy and paste an SSH command to initiate Wireshark manually. - This setup provides flexibility in how you utilize this feature.
-

- `; - document.getElementById("panel-topoviewer-helper-content").innerHTML = htmlContent; -} - -async function showPanelAbout(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - topoViewerVersion = environments["topoviewer-version"] - - document.getElementById("panel-topoviewer-about").style.display = "block"; - - const htmlContent = ` -
-
Version: ${topoViewerVersion}
- -

- Designed and developed by Asad Arafat
-

-

- Special Thanks: -

    -
  • Siva Sivakumar - For pioneering the integration of Bulma CSS, significantly enhancing TopoViewer design and usability.
  • -
  • Gatot Susilo - For seamlessly incorporating TopoViewer into the Komodo2 tool, bridging functionality with innovation.
  • -
  • Gusman Dharma Putra - For his invaluable contribution in integrating TopoViewer into Komodo2, enriching its capabilities.
  • -
  • Sven Wisotzky - For offering insightful feedback that led to significant full stack optimizations.
  • -
-

- - -
- `; - document.getElementById("panel-topoviewer-about-content").innerHTML = htmlContent; -} - -async function sidebarButtonFitScreen(event) { - - // --sidebar-button-background-color-default: rgba(54,58, 69, 1); - // --sidebar-button-background-color-active: rgba(76, 82, 97, 1); - - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - const sidebarButtonColorDefault = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-default'); - const sidebarButtonColorActive = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-active'); - - drawer = document.getElementById("drawer") - if (drawer.style.display === 'block') { - drawer.style.display = 'none'; - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - sidebarButtonFitScreen.style.background = sidebarButtonColorDefault.trim(); - sidebarButtonFitScreen.style.border = sidebarButtonColorActive.trim(); - } else { - drawer.style.display = 'block'; - var sidebarButtons = document.getElementsByClassName("is-sidebar"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < sidebarButtons.length; i++) { - sidebarButtons[i].style.background = sidebarButtonColorDefault.trim(); - sidebarButtons[i].style.border = sidebarButtonColorDefault.trim(); - } - sidebarButtonFitScreen.style.background = sidebarButtonColorActive.trim(); - } - -} - -async function getActualNodesEndpoints(event) { - try { - bulmaToast.toast({ - message: `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - appendMessage( - `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - ); - - showLoadingSpinnerGlobal() - const CyTopoJson = await sendRequestToEndpointGet("/actual-nodes-endpoints", argsList = []) - location.reload(true); - - // Handle the response data - if (CyTopoJson && typeof CyTopoJson === 'object' && Object.keys(CyTopoJson).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", CyTopoJson); - - hideLoadingSpinnerGlobal(); - - - - return CyTopoJson - - } else { - - hideLoadingSpinnerGlobal(); - - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - hideLoadingSpinnerGlobal(); - console.error("Error occurred:", error); - // Handle errors as needed - } -} - -function viewportButtonsZoomToFit() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); -} - -function viewportButtonsLayoutAlgo() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - viewportDrawerLayout = document.getElementById("viewport-drawer-layout") - viewportDrawerLayout.style.display = "block" -} - - - - -async function layoutAlgoChange(event) { - - try { - console.log("layoutAlgoChange clicked"); - - var selectElement = document.getElementById("select-layout-algo"); - var selectedOption = selectElement.value; - - if (selectedOption === "Force Directed") { - console.log("Force Directed algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-force-directed") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-force-directed-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-force-directed")) - console.log(document.getElementById("viewport-drawer-force-directed-reset-start")) - - } else if (selectedOption === "Vertical") { - console.log("Vertical algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-vertical") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-vertical-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-vertical")) - console.log(document.getElementById("viewport-drawer-dc-vertical-reset-start")) - - } else if (selectedOption === "Horizontal") { - console.log("Horizontal algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-horizontal") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-horizontal-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-horizontal")) - console.log(document.getElementById("viewport-drawer-dc-horizontal-reset-start")) - } - - }catch (error) { - console.error("Error occurred:", error); - // Handle errors as needed - } -} - - -function viewportButtonsTopologyOverview() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyOverview clicked") - viewportDrawerLayout = document.getElementById("viewport-drawer-topology-overview") - viewportDrawerLayout.style.display = "block" - - viewportDrawerLayoutContent = document.getElementById("viewport-drawer-topology-overview-content") - viewportDrawerLayoutContent.style.display = "block" -} - -function viewportButtonsTopologyCapture() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyCapture clicked") - - viewportDrawerCapture = document.getElementById("viewport-drawer-capture-sceenshoot") - viewportDrawerCapture.style.display = "block" - - viewportDrawerCaptureContent = document.getElementById("viewport-drawer-capture-sceenshoot-content") - viewportDrawerCaptureContent.style.display = "block" -} - -function viewportButtonsLabelEndpoint() { - if (linkEndpointVisibility) { - cy.edges().forEach(function(edge) { - // edge.style("source-label", "."); - // edge.style("target-label", "."); - edge.style("text-opacity", 0); - edge.style("text-background-opacity", 0); - - - linkEndpointVisibility = false; - }); - } else { - cy.edges().forEach(function(edge) { - edge.style("text-opacity", 1); - edge.style("text-background-opacity", 0.7); - linkEndpointVisibility = true; - }); - } -} - -function viewportButtonContainerStatusVisibility() { - if (nodeContainerStatusVisibility) { - nodeContainerStatusVisibility = false; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `Alright, mission control, we're standing down. 🛑🔍 Container status probing aborted. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - nodeContainerStatusVisibility = true; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `🕵️‍♂️ Bro, we're currently on a mission to probe that container status! Stay tuned for the results. 🔍🚀👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } -} - - -function viewportDrawerLayoutForceDirected() { - edgeLengthSlider = document.getElementById("force-directed-slider-link-lenght"); - nodeGapSlider = document.getElementById("force-directed-slider-node-gap"); - - const edgeLengthValue = parseFloat(edgeLengthSlider.value); - const nodeGapValue = parseFloat(nodeGapSlider.value); - - console.log("edgeLengthValue", edgeLengthValue); - console.log("nodeGapValue", nodeGapValue); - - cy.layout( - { - fit: true, - name: "cola", - animate: true, - randomize: false, - maxSimulationTime: 400, - edgeLength: function(e) { - return edgeLengthValue / e.data("weight"); - }, - nodeGap: function(e) { - return nodeGapValue / e.data("weight"); - }, - }) - .run(); -} - -function viewportDrawerLayoutVertical() { - nodevGap = document.getElementById("vertical-layout-slider-node-v-gap"); - groupvGap = document.getElementById("vertical-layout-slider-group-v-gap"); - - const nodevGapValue = parseFloat(nodevGap.value); - const groupvGapValue = parseFloat(groupvGap.value); - - console.log("nodevGapValue", nodevGapValue); - console.log("groupvGapValue", groupvGapValue); - - const xOffset = parseFloat(nodevGapValue); - const yOffset = parseFloat(groupvGapValue); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numRows = 1; - - const cellWidth = node.width() / children.length; - // const xOffset = 5 - - children.forEach(function(child, index) { - // Position children in rows - const xPos = index * (cellWidth + xOffset); - const yPos = 0; - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxWidth = 0; - var centerX = 0; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const width = node.width(); - if (width > maxWidth) { - maxWidth = width; - console.log("ParentMaxWidth: ", maxWidth); - } - } - }); - - const divisionFactor = maxWidth / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let yPos = 0; - // const yOffset = 50; - // const yOffset = 50; - - // Position parent nodes vertically and center them horizontally - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const xPos = centerX - parent.width() / divisionFactor; - // to the left compared to the center of the widest parent node. - parent.position({ - x: xPos, - y: yPos - }); - yPos += yOffset; - }); - cy.fit(); - }, delay); -} - -function viewportDrawerLayoutHorizontal() { - nodehGap = document.getElementById("horizontal-layout-slider-node-h-gap"); - grouphGap = document.getElementById("horizontal-layout-slider-group-h-gap"); - - const horizontalNodeGap = parseFloat(nodehGap.value); - const horizontalGroupGap = parseFloat(grouphGap.value); - - console.log("nodevGapValue", horizontalNodeGap); - console.log("groupvGapValue", horizontalGroupGap); - - const yOffset = parseFloat(horizontalNodeGap); - const xOffset = parseFloat(horizontalGroupGap); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numColumns = 1; - const cellHeight = node.height() / children.length; - // const yOffset = 5; - - children.forEach(function(child, index) { - // Position children in columns - const xPos = 0; - const yPos = index * (cellHeight + yOffset); - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxHeight = 0; - var centerX = cy.width() / 2; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const height = node.height(); - if (height > maxHeight) { - maxHeight = height; - console.log("ParentMaxHeight: ", maxHeight); - } - } - }); - - const divisionFactor = maxHeight / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let xPos = 0; - // const xOffset = 50; - - // Position parent nodes horizontally and center them vertically - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const yPos = centerY - parent.height() / divisionFactor; - parent.position({ - x: xPos, - y: yPos - }); - xPos -= xOffset; - }); - - cy.fit(); - }, delay); - -} - - -function viewportDrawerCaptureButton() { - - console.log ("viewportDrawerCaptureButton() - clicked") - - - - - // Get all checkbox inputs within the specific div - const checkboxes = document.querySelectorAll('#viewport-drawer-capture-sceenshoot-content .checkbox-input'); - - // Initialize an array to store the values of checked checkboxes - const selectedOptions = []; - - // Iterate through the NodeList of checkboxes - checkboxes.forEach((checkbox) => { - // If the checkbox is checked, push its value to the array - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - console.log ("viewportDrawerCaptureButton() - ", selectedOptions) - - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - -} - -async function captureAndSaveViewportAsDrawIo(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - const drawIoWidht = canvasElement.width / 10; - const drawIoHeight = canvasElement.height / 10; - const drawIoaAspectRatio = drawIoWidht / drawIoHeight; - - const mxGraphHeader = ` - - - `; - - const mxGraphFooter = ` - `; - - const mxCells = []; - - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - function createMxCellForNode(node, imageURL) { - if (node.isParent()) { - return ` - - - `; - } else if ( - !node.data("id").includes("statusGreen") && - !node.data("id").includes("statusRed") - ) { - return ` - - - `; - } - } - - cy.nodes().forEach(function(node) { - let imageURL; - switch (node.data("topoViewerRole")) { - case "pe": - imageURL = `http://${location.host}/images/clab-pe-light-blue.png`; - break; - case "controller": - imageURL = - `http://${location.host}/images/clab-controller-light-blue.png`; - break; - case "pon": - imageURL = `http://${location.host}/images/clab-pon-dark-blue.png`; - break; - case "dcgw": - imageURL = `http://${location.host}/images/clab-dcgw-dark-blue.png`; - break; - case "leaf": - imageURL = `http://${location.host}/images/clab-leaf-light-blue.png`; - break; - case "spine": - imageURL = `http://${location.host}/images/clab-spine-dark-blue.png`; - break; - case "super-spine": - imageURL = `http://${location.host}/images/clab-spine-light-blue.png`; - break; - } - mxCells.push(createMxCellForNode(node, imageURL)); - }); - - cy.edges().forEach(function(edge) { - mxCells.push(` - - - - - - - - - - - - - - `); - }); - - // Combine all parts and create XML - const mxGraphXML = mxGraphHeader + mxCells.join("") + mxGraphFooter; - - // Create a Blob from the XML - const blob = new Blob([mxGraphXML], { - type: "application/xml", - }); - - // Create a URL for the Blob - const url = window.URL.createObjectURL(blob); - - // Create a download link and trigger a click event - const a = document.createElement("a"); - a.style.display = "none"; - a.href = url; - a.download = "filename.drawio"; - document.body.appendChild(a); - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - a.click(); - - // Clean up by revoking the URL and removing the download link - window.URL.revokeObjectURL(url); - document.body.removeChild(a); -} -async function captureAndSaveViewportAsPng(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - - const zoomScaleFactor = 1; - - // Check if the canvas element exists and is an HTMLCanvasElement - // Check if the canvas element exists and is an HTMLCanvasElement - if (canvasElement instanceof HTMLCanvasElement) { - // Calculate the new canvas dimensions based on the high resolution factor - // Calculate the new canvas dimensions based on the high resolution factor - const newWidth = canvasElement.width * zoomScaleFactor; - const newHeight = canvasElement.height * zoomScaleFactor; - - // Create a new canvas element with the increased dimensions - // Create a new canvas element with the increased dimensions - const newCanvas = document.createElement("canvas"); - newCanvas.width = newWidth; - newCanvas.height = newHeight; - const newCanvasContext = newCanvas.getContext("2d"); - - // Scale the canvas content to the new dimensions - // Scale the canvas content to the new dimensions - newCanvasContext.scale(zoomScaleFactor, zoomScaleFactor); - - // Fill the new canvas with a white background - // Fill the new canvas with a white background - newCanvasContext.fillStyle = "white"; - newCanvasContext.fillRect(0, 0, newWidth, newHeight); - - // Draw the original canvas content on the new canvas - // Draw the original canvas content on the new canvas - newCanvasContext.drawImage(canvasElement, 0, 0); - - // Convert the new canvas to a data URL with a white background - // Convert the new canvas to a data URL with a white background - const dataUrl = newCanvas.toDataURL("image/png"); - - // Create an anchor element to trigger the download - // Create an anchor element to trigger the download - const link = document.createElement("a"); - link.href = dataUrl; - link.download = "cytoscape-viewport.png"; - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - // Simulate a click to trigger the download - link.click(); - } else { - console.error( - "Canvas element for layer2-node is not found or is not a valid HTML canvas element.", - ); - } -} - - - -// aarafat-tag: -//// REFACTOR END - -// logMessagesPanel manager -///-logMessagesPanel Function to append message function -function appendMessage(message) { - // const textarea = document.getElementById('notificationTextarea'); - const textarea = document.getElementById("notificationTextarea"); - - // Get the current date and time - const timestamp = new Date().toLocaleString(); - - textarea.value += `[${timestamp}] ${message}\n`; - textarea.scrollTop = textarea.scrollHeight; -} - -function nodeFindDrawer(cy) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById( - "panelBlock-viewportButtons-buttonfindNode-divPanelBlock-columnContainerlabelFindNodeNodeName-panelContentlabelFindNodeNodeName-columnsPanelContentlabelFindNodeNodeName-labelColumnlabelFindNodeNodeName-inputColumnlabelFindNodeNodeName-labellabelFindNodeNodeName", - ).value; - - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } -} - -function pathFinderDijkstraDrawer(cy) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteSource-panelContentlabelFindRouteSource-columnsPanelContentlabelFindRouteSource-labelColumnlabelFindRouteSource-inputColumnlabelFindRouteSource-labellabelFindRouteSource", - ).value; - const targetNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteTarget-panelContentlabelFindRouteTarget-columnsPanelContentlabelFindRouteTarget-labelColumnlabelFindRouteTarget-inputColumnlabelFindRouteTarget-labellabelFindRouteTarget", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } -} - -// sleep funtion -function sleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); -} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/js/index.js.bak b/rawTopoFile/topoviewer/html-static/js/index.js.bak deleted file mode 100644 index 8e598e014..000000000 --- a/rawTopoFile/topoviewer/html-static/js/index.js.bak +++ /dev/null @@ -1,2402 +0,0 @@ -// Initialize a state variable to track the element's presence -var isPanel01Cy = false; -var nodeClicked = false; -var edgeClicked = false; - -var cy - -var globalSelectedNode -var globalSelectedEdge - -var linkEndpointVisibility = true; -var nodeContainerStatusVisibility = false; - - -var globalShellUrl = "/js/cloudshell" - -var labName -var deploymentType - -document.addEventListener("DOMContentLoaded", async function() { - - detectColorScheme() - - await changeTitle() - - - // Reusable function to initialize a WebSocket connection - function initializeWebSocket(url, onMessageCallback) { - const protocol = location.protocol === "https:" ? "wss://" : "ws://"; - const socket = new WebSocket(protocol + location.host + url); - - socket.onopen = () => { - console.log(`Successfully connected WebSocket to ${url}`); - if (socket.readyState === WebSocket.OPEN) { - socket.send(`Hi From the WebSocketClient-${url}`); - } - }; - - socket.onclose = (event) => { - console.log(`Socket to ${url} closed: `, event); - socket.send("Client Closed!"); - }; - - socket.onerror = (error) => { - console.log(`Socket to ${url} error: `, error); - }; - - socket.onmessage = onMessageCallback; - - return socket; - } - - - // WebSocket for uptime - // WebSocket for uptime - const socketUptime = initializeWebSocket("/uptime", async (msgUptime) => { - environments = await getEnvironments(); - labName = environments["clab-name"] - deploymentType = environments["deploymentType"] - - console.log("initializeWebSocket - getEnvironments", environments) - console.log("initializeWebSocket - labName", environments["clab-name"]) - - const string01 = "Containerlab Topology: " + labName; - const string02 = " ::: Uptime: " + msgUptime.data; - - const ClabSubtitle = document.getElementById("ClabSubtitle"); - const messageBody = string01 + string02; - - ClabSubtitle.innerText = messageBody; - console.log(ClabSubtitle.innerText); - }); - - // WebSocket for ContainerNodeStatus - const socketContainerNodeStatusInitial = initializeWebSocket( - "/containerNodeStatus", - (msgContainerNodeStatus) => { - try { - const { - Names, - Status, - State - } = JSON.parse(msgContainerNodeStatus.data); - setNodeContainerStatus(Names, Status); - console.log(JSON.parse(msgContainerNodeStatus.data)); - - setNodeDataWithContainerAttribute(Names, Status, State); - } catch (error) { - console.error("Error parsing JSON:", error); - } - }, - ); - - //- Instantiate Cytoscape.js - cy = cytoscape({ - container: document.getElementById("cy"), - elements: [], - style: [{ - selector: "node", - style: { - "background-color": "#3498db", - label: "data(label)", - }, - }, ], - }); - - - loadCytoStyle(); - - function loadCytoStyle() { - - // detect light or dark mode - const colorScheme = detectColorScheme(); - console.log('The user prefers:', colorScheme); - - //- Load and apply Cytoscape styles from cy-style.json using fetch - if (colorScheme == "light") { - fetch("css/cy-style.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } else if (colorScheme == "dark") { - fetch("css/cy-style-dark.json") - .then((response) => response.json()) - .then((styles) => { - cy.style().fromJson(styles).update(); - }) - .catch((error) => { - console.error( - "Oops, we hit a snag! Couldnt load the cyto styles, bro.", - error, - ); - appendMessage( - `Oops, we hit a snag! Couldnt load the cyto styles, bro.: ${error}`, - ); - }); - } - } - - // Enable grid guide extension - cy.gridGuide({ - // On/Off Modules - - snapToGridOnRelease: true, - snapToGridDuringDrag: false, - snapToAlignmentLocationOnRelease: true, - snapToAlignmentLocationDuringDrag: false, - distributionGuidelines: false, - geometricGuideline: false, - initPosAlignment: false, - centerToEdgeAlignment: false, - resize: false, - parentPadding: false, - drawGrid: false, - - // General - gridSpacing: 10, - snapToGridCenter: true, - - // Draw Grid - zoomDash: true, - panGrid: true, - gridStackOrder: -1, - gridColor: '#dedede', - lineWidth: 1.0, - - // Guidelines - guidelinesStackOrder: 4, - guidelinesTolerance: 2.00, - guidelinesStyle: { - strokeStyle: "#8b7d6b", - geometricGuidelineRange: 400, - range: 100, - minDistRange: 10, - distGuidelineOffset: 10, - horizontalDistColor: "#ff0000", - verticalDistColor: "#00ff00", - initPosAlignmentColor: "#0000ff", - lineDash: [0, 0], - horizontalDistLine: [0, 0], - verticalDistLine: [0, 0], - initPosAlignmentLine: [0, 0], - }, - - // Parent Padding - parentSpacing: -1 - }); - - // Fetch and load element data from a JSON file - // fetch("dataCytoMarshall-" + labName + ".json") - fetch("dataCytoMarshall.json") - - .then((response) => response.json()) - .then((elements) => { - // Add the elements to the Cytoscape instance - // Add the elements to the Cytoscape instance - cy.add(elements); - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLength: 100, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - - // remove node topoviewer - topoViewerNode = cy.filter('node[name = "topoviewer"]'); - topoViewerNode.remove(); - }) - .catch((error) => { - console.error("Error loading graph data:", error); - }); - - // Instantiate hover text element - const hoverText = document.createElement("box"); - hoverText.classList.add( - "hover-text", - "is-hidden", - "box", - "has-text-weight-normal", - "is-warning", - "is-smallest", - ); - hoverText.textContent = "Launch CloudShell."; - document.body.appendChild(hoverText); - - //- Toggle the Panel(s) when clicking on the cy container - //- Toggle the Panel(s) when clicking on the cy container - document.getElementById("cy").addEventListener("click", function(event) { - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - //- This code will be executed when you click anywhere in the Cytoscape container - //- You can add logic specific to the container here - - loadCytoStyle(); - - if (!nodeClicked && !edgeClicked) { - if (!isPanel01Cy) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - // display none each ViewPortDrawer Element, the ViewPortDrawer is created during DOM loading and styled as display node initially - var ViewPortDrawerElements = - document.getElementsByClassName("ViewPortDrawer"); - var ViewPortDrawerArray = Array.from(ViewPortDrawerElements); - ViewPortDrawerArray.forEach(function(element) { - element.style.display = "none"; - }); - - } else { - removeElementById("Panel-01"); - appendMessage(`"try to remove panel01-Cy"`); - } - } - nodeClicked = false; - edgeClicked = false; - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - }); - - // Click event listener for nodes - // Click event listener for nodes - cy.on("click", "node", function(event) { - // This code will be executed when you click on a node - // This code will be executed when you click on a node - const node = event.target; - nodeClicked = true; - - if (!node.isParent()) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - console.log(node) - console.log(node.data("containerDockerExtraAttribute").status) - console.log(node.data("extraData")) - - if (document.getElementById("panel-node").style.display === "none") { - document.getElementById("panel-node").style.display = "block"; - } else { - document.getElementById("panel-node").style.display = "none"; - } - - document.getElementById("panel-node-name").textContent = node.data("extraData").longname - document.getElementById("panel-node-status").textContent = node.data("containerDockerExtraAttribute").status - document.getElementById("panel-node-kind").textContent = node.data("extraData").kind - document.getElementById("panel-node-image").textContent = node.data("extraData").image - document.getElementById("panel-node-mgmtipv4").textContent = node.data("extraData").mgmtIpv4Addresss - document.getElementById("panel-node-mgmtipv6").textContent = node.data("extraData").mgmtIpv6Addresss - document.getElementById("panel-node-fqdn").textContent = node.data("extraData").fqdn - document.getElementById("panel-node-group").textContent = node.data("extraData").group - document.getElementById("panel-node-topoviewerrole").textContent = node.data("topoViewerRole") - - // set selected node-long-name to global variable - globalSelectedNode = node.data("extraData").longname - console.log("internal: ", globalSelectedNode) - - appendMessage(`"isPanel01Cy-cy: " ${isPanel01Cy}`); - appendMessage(`"nodeClicked: " ${nodeClicked}`); - } - }); - - // Click event listener for edges - // Click event listener for edges - cy.on("click", "edge", async function(event) { - - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - // This code will be executed when you click on a node - // You can add logic specific to nodes here - const clickedEdge = event.target; - const defaultEdgeColor = "#969799"; - edgeClicked = true; - - console.log(defaultEdgeColor); - - // Change the color of the clicked edge (for example, to red) - clickedEdge.style("line-color", "#0043BF"); - - // Revert the color of other edges that were not clicked (e.g., back to their default color) - cy.edges().forEach(function(edge) { - if (edge !== clickedEdge) { - edge.style("line-color", defaultEdgeColor); - } - }); - - - - - document.getElementById("panel-link").style.display = "none"; - - if (document.getElementById("panel-link").style.display === "none") { - document.getElementById("panel-link").style.display = "block"; - } else { - document.getElementById("panel-link").style.display = "none"; - } - - document.getElementById("panel-link-name").textContent = `${clickedEdge.data("source")} --- ${clickedEdge.data("target")}` - - document.getElementById("panel-link-endpoint-a-name").textContent = `${clickedEdge.data("source")}` - document.getElementById("panel-link-endpoint-a-mac-address").textContent = `${clickedEdge.data("extraData").clabSourceMacAddress}` - - document.getElementById("panel-link-endpoint-b-name").textContent = `${clickedEdge.data("target")}` - document.getElementById("panel-link-endpoint-b-mac-address").textContent = `${clickedEdge.data("extraData").clabTargetMacAddress}` - - - // setting default impairment endpoint-a values by getting the data from clab via /clab-link-impairment GET API - clabSourceLinkArgsList = [`${clickedEdge.data("extraData").clabSourceLongName}`,`${clickedEdge.data("extraData").clabSourcePort}`] - clabSourceLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabSourceLinkArgsList) - - if (clabSourceLinkImpairmentClabData && typeof clabSourceLinkImpairmentClabData === 'object' && Object.keys(clabSourceLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabSourceLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabSourceLinkImpairmentClabData returnd data", clabSourceLinkImpairmentClabData["return data"]["delay"]); - - if (clabSourceLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-a-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-delay").value = clabSourceLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-a-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-jitter").value = clabSourceLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabSourceLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-a-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-rate").value = clabSourceLinkImpairmentClabData["return data"]["rate"] - } - - if (clabSourceLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-a-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-a-loss").value = clabSourceLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // setting default impairment endpoint-b values by getting the data from clab via /clab-link-impairment GET API - clabTargetLinkArgsList = [`${clickedEdge.data("extraData").clabTargetLongName}`,`${clickedEdge.data("extraData").clabTargetPort}`] - clabTargetLinkImpairmentClabData = await sendRequestToEndpointGetV2("/clab-link-impairment", clabTargetLinkArgsList) - - if (clabTargetLinkImpairmentClabData && typeof clabTargetLinkImpairmentClabData === 'object' && Object.keys(clabTargetLinkImpairmentClabData).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", clabTargetLinkImpairmentClabData); - console.log("Valid non-empty JSON response received: clabTargetLinkImpairmentClabData returnd data", clabTargetLinkImpairmentClabData["return data"]["delay"]); - - if (clabTargetLinkImpairmentClabData["return data"]["delay"] == "N/A") { - document.getElementById("panel-link-endpoint-b-delay").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-delay").value = clabTargetLinkImpairmentClabData["return data"]["delay"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["jitter"] == "N/A") { - document.getElementById("panel-link-endpoint-b-jitter").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-jitter").value = clabTargetLinkImpairmentClabData["return data"]["jitter"].replace(/ms$/, ''); - } - - if (clabTargetLinkImpairmentClabData["return data"]["rate"] == "N/A") { - document.getElementById("panel-link-endpoint-b-rate").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-rate").value = clabTargetLinkImpairmentClabData["return data"]["rate"] - } - - if (clabTargetLinkImpairmentClabData["return data"]["packet_loss"] == "N/A") { - document.getElementById("panel-link-endpoint-b-loss").value = '0' - }else { - document.getElementById("panel-link-endpoint-b-loss").value = clabTargetLinkImpairmentClabData["return data"]["packet_loss"].replace(/%$/, ''); - } - - - } else { - console.log("Empty or invalid JSON response received"); - } - - - - - // set selected edge-id to global variable - globalSelectedEdge = clickedEdge.data("id") - - appendMessage(`"edgeClicked: " ${edgeClicked}`); - }); - - - - - function generateNodesEvent(event) { - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - // Your event handling logic here - //- Add a click event listener to the 'Generate' button - //- Get the number of node from the input field - console.log("generateNodesButton clicked"); - const numNodes = document.getElementById("generateNodesInput").value; - console.log(numNodes); - //- Check if the number of node is empty - //- Check if the number of node is empty - if (numNodes === null) { - //- if node number empty do nothing - //- if node number empty do nothing - return; - } - const numNodesToGenerate = parseInt(numNodes, 10); - //- Check if the number of node is positive - //- Check if the number of node is positive - if (isNaN(numNodesToGenerate) || numNodesToGenerate <= 0) { - //- Invalid input - //- Invalid input - appendMessage( - "Error:" + "Bro, you gotta enter a valid positive number, come on!", - ); - return; - } - //- Generate nodes with random positions - //- Generate nodes with random positions - for (let i = 0; i < numNodesToGenerate; i++) { - const nodeName = `node-${i + 1}`; - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - }, - position: { - x: Math.random() * 400, - y: Math.random() * 400, - }, - }; - //-cy.add(newNode); - //-cy.add(newNode); - try { - cy.add(newNode); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred:" + error); - } - } - //- Generate random edges between nodes - //- Generate random edges between nodes - for (let i = 0; i < numNodesToGenerate; i++) { - const sourceNode = `node-${i + 1}`; - const targetNode = `node-${Math.floor(Math.random() * numNodesToGenerate) + 1}`; - if (sourceNode !== targetNode) { - const newEdge = { - group: "edges", - data: { - id: "from-" + sourceNode + "-to-" + targetNode, - name: "from-" + sourceNode + "-to-" + targetNode, - source: sourceNode, - target: targetNode, - }, - }; - try { - cy.add(newEdge); - //- throw new Error('This is an example exception'); - //- throw new Error('This is an example exception'); - } catch (error) { - //- Log the exception to the console - //- Log the exception to the console - console.error("An exception occurred:", error); - //- Log the exception to notification message to the textarea - //- Log the exception to notification message to the textarea - appendMessage("An exception occurred::" + error); - } - } - } - //- run layout - //- run layout - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //-//- Append a notification message to the textarea - //-//- Append a notification message to the textarea - console.log( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - appendMessage( - "Info: " + - `Boom! Just generated ${numNodesToGenerate} nodes with some random edges. That's how we roll!`, - ); - } - - function spawnNodeEvent(event) { - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - //- Add a click event listener to the 'Submit' button in the hidden form - //- Get the node name from the input field - const nodeName = document.getElementById("nodeName").value; - console.log(nodeName); - //- Check if a node name is empty - //- Check if a node name is empty - if (nodeName == "") { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Enter node name."); - return; - } - //- Check if a node with the same name already exists - //- Check if a node with the same name already exists - if (cy.$(`node[id = "${nodeName}"]`).length > 0) { - //- append message in textArea - //- append message in textArea - appendMessage("Error: Node with this name already exists."); - return; - } - //- Create a new node element - //- Create a new node element - const newNode = { - group: "nodes", - data: { - id: nodeName, - name: nodeName, - label: nodeName, - }, - }; - //- Add the new node to Cytoscape.js - //- Add the new node to Cytoscape.js - cy.add(newNode); - //- Randomize the positions and center the graph - //- Randomize the positions and center the graph - const layout = cy.layout({ - name: "cola", - nodeGap: 5, - edgeLengthVal: 45, - animate: true, - randomize: false, - maxSimulationTime: 1500, - }); - layout.run(); - //- Append a notification message to the textarea - //- Append a notification message to the textarea - console.log("Info: " + `Nice! Node "${nodeName}" added successfully.`); - appendMessage("Info: " + `Nice! Node "${nodeName}" added successfully.`); - } - - function nodeFindEvent(event) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById("nodeFindInput").value; - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } - } - - function zoomToFitDrawer() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); - } - - function pathFinderDijkstraEvent(event) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "pathFinderSourceNodeInput", - ).value; - const targetNodeId = document.getElementById( - "pathFinderTargetNodeInput", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - //// Apply a style to highlight the shortest path edges - // shortestPathEdges.style({ - // 'line-color': 'red', - // 'line-style': 'solid', - // }); - - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } - } - - function setNodeContainerStatus(containerNodeName, containerNodeStatus) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - - // Find the corresponding status nodes based on node ID - // Find the corresponding status nodes based on node ID - var statusGreenNode = cy.$(`node[name="${nodeId}-statusGreen"]`); - var statusOrangeNode = cy.$(`node[name="${nodeId}-statusOrange"]`); - var statusRedNode = cy.$(`node[name="${nodeId}-statusRed"]`); - - if (statusGreenNode.length === 0 || statusRedNode.length === 0) { - // If status nodes are not found, skip this node - return; - } - - // Update positions of status nodes relative to the node - var nodePosition = node.position(); - var offset = { - x: -4, - y: -10 - }; - var statusGreenNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - var statusRedNodePosition = { - x: nodePosition.x + offset.x, - y: nodePosition.y + offset.y, - }; - - // Check if the nodeContainerStatusVisibility is true - if (nodeContainerStatusVisibility) { - // Check if the containerNodeName includes nodeId and containerNodeStatus includes 'healthy' - if ( - containerNodeName.includes(nodeId) && - (containerNodeStatus.includes("Up") || - containerNodeStatus.includes("healthy")) - ) { - statusGreenNode.show(); - statusRedNode.hide(); - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("(health: starting)") - ) { - statusGreenNode.hide(); - statusOrangeNode.show(); - } else if ( - containerNodeName.includes(nodeId) && - containerNodeStatus.includes("Exited") - ) { - statusGreenNode.hide(); - statusRedNode.show(); - } - } else { - statusGreenNode.hide(); - statusRedNode.hide(); - } - - statusGreenNode.position(statusGreenNodePosition); - statusRedNode.position(statusRedNodePosition); - }); - } - - function setNodeDataWithContainerAttribute(containerNodeName, status, state) { - cy.nodes().forEach(function(node) { - var nodeId = node.data("id"); - if (containerNodeName.includes(nodeId)) { - var containerDockerExtraAttributeData = { - state: state, - status: status, - }; - - node.data( - "containerDockerExtraAttribute", - containerDockerExtraAttributeData, - ); - } - }); - } - - // - // End of JS Functions Event Handling section - // End of JS Functions Event Handling section - // - - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - // - // Start of JS Generic Functions - // Start of JS Generic Functions - // - - - //- Function to get the default node style from cy-style.json - //- Function to get the default node style from cy-style.json - async function getDefaultNodeStyle(node) { - try { - //- Fetch the cy-style.json file - //- Fetch the cy-style.json file - const response = await fetch("cy-style.json"); - //- Check if the response is successful (status code 200) - //- Check if the response is successful (status code 200) - if (!response.ok) { - throw new Error( - `Failed to fetch cy-style.json (${response.status} ${response.statusText})`, - ); - } - //- Parse the JSON response - //- Parse the JSON response - const styleData = await response.json(); - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - //- Extract the default node style from the loaded JSON - //- Adjust this based on your JSON structure - const defaultNodeStyle = styleData[0].style; - return defaultNodeStyle; - } catch (error) { - console.error("Error loading cy-style.json:", error); - appendMessage(`Error loading cy-style.json: ${error}`); - //- Return a default style in case of an error - //- Return a default style in case of an error - return { - "background-color": "blue", - "border-color": "gray", - "border-width": "1px", - }; - } - } - - ///-logMessagesPanel Function to add a click event listener to the copy button - ///-logMessagesPanel Function to add a click event listener to the copy button - const copyButton = document.getElementById("copyToClipboardButton"); - copyButton.className = "button is-smallest-element"; - copyButton.addEventListener("click", copyToClipboard); - - /// logMessagesPanel Function to copy textarea content to clipboard - /// logMessagesPanel Function to copy textarea content to clipboard - function copyToClipboard() { - const textarea = document.getElementById("notificationTextarea"); - textarea.select(); - document.execCommand("copy"); - } - - - - // function closePanelEvent(event, panel) { - // panel.style.display = "block"; - // console.log(panel.style.display); - // panel.style.display = "none"; - // } - - function createModal(modalId, modalContent) { - // Create the modal - // Create the modal - const htmlContent = ` - - `; - - const modalDiv = document.createElement("div"); - modalDiv.innerHTML = htmlContent; - modalDiv.id = "modalDivExportViewport"; - - document.body.appendChild(modalDiv); - const modalBackground = document.getElementById( - `${modalId}-modalBackgroundId`, - ); - - modalBackground.addEventListener("click", function() { - const modal = modalBackground.parentNode; - modal.classList.remove("is-active"); - }); - } - - function showModalCaptureViewport(modalId) { - const modalContentSaveViewport = ` - - `; - - // Instantiate modal - // Instantiate modal - createModal("modalSaveViewport", modalContentSaveViewport); - - // create event listener - // create event listener - const performActionButton = document.getElementById("performActionButton"); - performActionButton.addEventListener("click", function() { - const checkboxName = "checkboxSaveViewPort"; - const checkboxes = document.querySelectorAll( - `input[type="checkbox"][name="${checkboxName}"]`, - ); - const selectedOptions = []; - - checkboxes.forEach(function(checkbox) { - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - }); - - // show modal - // show modal - modal = document.getElementById(modalId); - modal.classList.add("is-active"); - } - - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // - // - // End of JS Generic Functions section - // End of JS Generic Functions section - // -}); - -// aarafat-tag: -//// REFACTOR START -//// to-do: -//// - re-create about-panel -//// - re-create log-messages -//// - re-create viewport - -async function initEnv() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - deploymentType = await environments["deployment-type"] - - console.log("Lab-Name: ", labName) - console.log("DeploymentType: ", deploymentType) - return environments, labName - } - -async function changeTitle() { - environments = await getEnvironments(); - labName = await environments["clab-name"] - - console.log("changeTitle() - labName: ", labName) - document.title = `TopoViewer::${labName}`; -} - -async function sshWebBased(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - - console.log("sshWebBased: ", `${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`) - - window.open(`${globalShellUrl}?RouterID=${routerData["data"]["extraData"]["mgmtIpv4Addresss"]}?RouterName=${routerName}`); - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - -async function sshCliCommandCopy(event) { - console.log("sshWebBased: ", globalSelectedNode) - var routerName = globalSelectedNode - try { - environments = await getEnvironments(event); - console.log("sshWebBased - environments: ", environments) - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - clabServerAddress = environments["clab-server-address"] - routerData = findCytoElementByLongname(cytoTopologyJson, routerName) - clabUser = routerData["data"]["extraData"]["clabServerUsername"] - - sshCopyString = `ssh -t ${clabUser}@${clabServerAddress} "ssh admin@${routerName}"` - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(sshCopyString).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = sshCopyString; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } catch (error) { - console.error('Error executing restore configuration:', error); - } -} - - - -async function linkImpairmentClab(event, impairDirection) { - console.log("linkImpairmentClab - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - var deploymentType = environments["deployment-type"] - var command - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkImpairment- edgeData: ", edgeData) - console.log("linkImpairment- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (impairDirection == "a-to-b") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-a-delay").value - jitterValue = document.getElementById("panel-link-endpoint-a-jitter").value - rateValue = document.getElementById("panel-link-endpoint-a-rate").value - lossValue = document.getElementById("panel-link-endpoint-a-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabSourceLongName} -i ${clabSourcePort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - - - } else if (impairDirection == "b-to-a") { - console.log("linkImpairment - impairDirection: ", impairDirection) - - delayValue = document.getElementById("panel-link-endpoint-b-delay").value - jitterValue = document.getElementById("panel-link-endpoint-b-jitter").value - rateValue = document.getElementById("panel-link-endpoint-b-rate").value - lossValue = document.getElementById("panel-link-endpoint-b-loss").value - - if (deploymentType == "container") { - command = `ssh ${clabUser}@${clabServerAddress} /usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } else if (deploymentType == "colocated") { - command = `/usr/bin/containerlab tools netem set -n ${clabTargetLongName} -i ${clabTargetPort} --delay ${delayValue}ms --jitter ${jitterValue}ms --rate ${rateValue} --loss ${lossValue}` - } - - console.log(`linkImpairment - deployment ${deploymentType}, command: ${command}`) - var postPayload = [] - postPayload[0] = command - await sendRequestToEndpointPost("/clab-link-impairment", postPayload) - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - - -async function linkWireshark(event, option, endpoint) { - console.log("linkWireshark - globalSelectedEdge: ", globalSelectedEdge) - var edgeId = globalSelectedEdge - try { - environments = await getEnvironments(event); - console.log("linkWireshark - environments: ", environments) - - var deploymentType = environments["deployment-type"] - - cytoTopologyJson = environments["EnvCyTopoJsonBytes"] - edgeData = findCytoElementById(cytoTopologyJson, edgeId) - - console.log("linkWireshark- edgeData: ", edgeData) - console.log("linkWireshark- edgeSource: ", edgeData["data"]["source"]) - - clabUser = edgeData["data"]["extraData"]["clabServerUsername"] - clabServerAddress = environments["clab-server-address"] - - clabSourceLongName = edgeData["data"]["extraData"]["clabSourceLongName"] - clabSourcePort = edgeData["data"]["extraData"]["clabSourcePort"] - - clabTargetLongName = edgeData["data"]["extraData"]["clabTargetLongName"] - clabTargetPort = edgeData["data"]["extraData"]["clabTargetPort"] - - if (option == "app") { - if (endpoint == "source") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabSourceLongName}?${clabSourcePort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - - } else if (endpoint == "target") { - wiresharkHref = `clab-capture://${clabUser}@${clabServerAddress}?${clabTargetLongName}?${clabTargetPort}` - console.log("linkWireshark- wiresharkHref: ", wiresharkHref) - } - - window.open(wiresharkHref); - - } else if (option == "copy") { - if (endpoint == "source") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabSourceLongName} tcpdump -U -nni ${clabSourcePort} -w -" | wireshark -k -i -` - } - } else if (endpoint == "target") { - if (deploymentType == "container") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } else if (deploymentType == "colocated") { - wiresharkSshCommand = `ssh ${clabUser}@${clabServerAddress} "sudo -S /sbin/ip netns exec ${clabTargetLongName} tcpdump -U -nni ${clabTargetPort} -w -" | wireshark -k -i -` - } - } - - console.log("linkWireshark- wiresharkSShCommand: ", wiresharkSshCommand) - - // Check if the clipboard API is available - if (navigator.clipboard && navigator.clipboard.writeText) { - navigator.clipboard.writeText(wiresharkSshCommand).then(function() { - alert('Text copied to clipboard'); - }).catch(function(error) { - console.error('Could not copy text: ', error); - }); - } else { - // Fallback method for older browsers - let textArea = document.createElement('textarea'); - textArea.value = wiresharkSshCommand; - document.body.appendChild(textArea); - textArea.focus(); - textArea.select(); - try { - document.execCommand('copy'); - alert('Text copied to clipboard'); - } catch (err) { - console.error('Fallback: Oops, unable to copy', err); - } - document.body.removeChild(textArea); - } - - } - - } catch (error) { - console.error('Error executing linkImpairment configuration:', error); - } -} - -async function showPanelLogMessages(event) { - document.getElementById("panel-log-messages").style.display = "block"; -} - -///-logMessagesPanel Function to add a click event listener to the close button -document.getElementById("panel-log-messages-close-button").addEventListener("click", () => { - document.getElementById("panel-log-messages").style.display = "none"; -}); - -async function showPanelTopoViewerClient(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - clabServerAddress = environments["clab-server-address"] - clabServerPort = environments["clab-server-port"] - - hrefWindows = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-windows/ClabCapture.app.zip` - hrefMac = `http://${clabServerAddress}:${clabServerPort}/clab-client/clab-client-mac/ClabCapture.app.zip` - - document.getElementById("panel-topoviewer-helper").style.display = "block"; - - const htmlContent = ` -
Wireshark Capture
-

- Please download the following helper app: -

- -

- TopoViewer offers a remote capture feature for intercepting ContainerLab node endpoints. - For the best experience, it's recommended to have both TopoViewer and its helper app installed on client-side. - With the TopoViewer helper app, you can effortlessly automate the launch of Wireshark's GUI. -

-

- Alternatively, if you don't have the helper app, you can simply copy and paste an SSH command to initiate Wireshark manually. - This setup provides flexibility in how you utilize this feature.
-

- `; - document.getElementById("panel-topoviewer-helper-content").innerHTML = htmlContent; -} - -async function showPanelAbout(event) { - // Remove all Overlayed Panel - // Get all elements with the class "panel-overlay" - var panelOverlays = document.getElementsByClassName("panel-overlay"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < panelOverlays.length; i++) { - panelOverlays[i].style.display = "none"; - } - - environments = await getEnvironments(event); - console.log("linkImpairment - environments: ", environments) - - topoViewerVersion = environments["topoviewer-version"] - - document.getElementById("panel-topoviewer-about").style.display = "block"; - - const htmlContent = ` -
-
Version: ${topoViewerVersion}
- -

- Designed and developed by Asad Arafat
-

-

- Special Thanks: -

    -
  • Siva Sivakumar - For pioneering the integration of Bulma CSS, significantly enhancing TopoViewer design and usability.
  • -
  • Gatot Susilo - For seamlessly incorporating TopoViewer into the Komodo2 tool, bridging functionality with innovation.
  • -
  • Gusman Dharma Putra - For his invaluable contribution in integrating TopoViewer into Komodo2, enriching its capabilities.
  • -
  • Sven Wisotzky - For offering insightful feedback that led to significant full stack optimizations.
  • -
-

- - -
- `; - document.getElementById("panel-topoviewer-about-content").innerHTML = htmlContent; -} - -async function sidebarButtonFitScreen(event) { - - // --sidebar-button-background-color-default: rgba(54,58, 69, 1); - // --sidebar-button-background-color-active: rgba(76, 82, 97, 1); - - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - const sidebarButtonColorDefault = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-default'); - const sidebarButtonColorActive = getComputedStyle(sidebarButtonFitScreen).getPropertyValue('--sidebar-button-background-color-active'); - - drawer = document.getElementById("drawer") - if (drawer.style.display === 'block') { - drawer.style.display = 'none'; - var sidebarButtonFitScreen = document.getElementById("sidebar-button-fit-screen") - sidebarButtonFitScreen.style.background = sidebarButtonColorDefault.trim(); - sidebarButtonFitScreen.style.border = sidebarButtonColorActive.trim(); - } else { - drawer.style.display = 'block'; - var sidebarButtons = document.getElementsByClassName("is-sidebar"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < sidebarButtons.length; i++) { - sidebarButtons[i].style.background = sidebarButtonColorDefault.trim(); - sidebarButtons[i].style.border = sidebarButtonColorDefault.trim(); - } - sidebarButtonFitScreen.style.background = sidebarButtonColorActive.trim(); - } - -} - -async function getActualNodesEndpoints(event) { - try { - bulmaToast.toast({ - message: `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - appendMessage( - `Getting Actual Nodes Endpoint Labels... Hold on..! 🚀💻`, - ); - - showLoadingSpinnerGlobal() - const CyTopoJson = await sendRequestToEndpointGet("/actual-nodes-endpoints", argsList = []) - location.reload(true); - - // Handle the response data - if (CyTopoJson && typeof CyTopoJson === 'object' && Object.keys(CyTopoJson).length > 0) { - hideLoadingSpinnerGlobal(); - console.log("Valid non-empty JSON response received:", CyTopoJson); - - hideLoadingSpinnerGlobal(); - - - - return CyTopoJson - - } else { - - hideLoadingSpinnerGlobal(); - - console.log("Empty or invalid JSON response received"); - } - } catch (error) { - hideLoadingSpinnerGlobal(); - console.error("Error occurred:", error); - // Handle errors as needed - } -} - -function viewportButtonsZoomToFit() { - const initialZoom = cy.zoom(); - appendMessage(`Bro, initial zoom level is "${initialZoom}".`); - //- Fit all nodes possible with padding - //- Fit all nodes possible with padding - cy.fit(); - const currentZoom = cy.zoom(); - appendMessage(`And now the zoom level is "${currentZoom}".`); -} - -function viewportButtonsLayoutAlgo() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - viewportDrawerLayout = document.getElementById("viewport-drawer-layout") - viewportDrawerLayout.style.display = "block" -} - - - - -async function layoutAlgoChange(event) { - - try { - console.log("layoutAlgoChange clicked"); - - var selectElement = document.getElementById("select-layout-algo"); - var selectedOption = selectElement.value; - - if (selectedOption === "Force Directed") { - console.log("Force Directed algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-force-directed") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-force-directed-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-force-directed")) - console.log(document.getElementById("viewport-drawer-force-directed-reset-start")) - - } else if (selectedOption === "Vertical") { - console.log("Vertical algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-vertical") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-vertical-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-vertical")) - console.log(document.getElementById("viewport-drawer-dc-vertical-reset-start")) - - } else if (selectedOption === "Horizontal") { - console.log("Horizontal algo selected"); - - var layoutAlgoPanels = document.getElementsByClassName("layout-algo"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < layoutAlgoPanels.length; i++) { - layoutAlgoPanels[i].style.display = "none"; - } - - viewportDrawerForceDirected = document.getElementById("viewport-drawer-dc-horizontal") - viewportDrawerForceDirected.style.display = "block" - - viewportDrawerForceDirectedResetStart = document.getElementById("viewport-drawer-dc-horizontal-reset-start") - viewportDrawerForceDirectedResetStart.style.display = "block" - - console.log(document.getElementById("viewport-drawer-dc-horizontal")) - console.log(document.getElementById("viewport-drawer-dc-horizontal-reset-start")) - } - - }catch (error) { - console.error("Error occurred:", error); - // Handle errors as needed - } -} - - -function viewportButtonsTopologyOverview() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyOverview clicked") - viewportDrawerLayout = document.getElementById("viewport-drawer-topology-overview") - viewportDrawerLayout.style.display = "block" - - viewportDrawerLayoutContent = document.getElementById("viewport-drawer-topology-overview-content") - viewportDrawerLayoutContent.style.display = "block" -} - -function viewportButtonsTopologyCapture() { - var viewportDrawer = document.getElementsByClassName("viewport-drawer"); - // Loop through each element and set its display to 'none' - for (var i = 0; i < viewportDrawer.length; i++) { - viewportDrawer[i].style.display = "none"; - } - - console.log("viewportButtonsTopologyCapture clicked") - - viewportDrawerCapture = document.getElementById("viewport-drawer-capture-sceenshoot") - viewportDrawerCapture.style.display = "block" - - viewportDrawerCaptureContent = document.getElementById("viewport-drawer-capture-sceenshoot-content") - viewportDrawerCaptureContent.style.display = "block" -} - -function viewportButtonsLabelEndpoint() { - if (linkEndpointVisibility) { - cy.edges().forEach(function(edge) { - // edge.style("source-label", "."); - // edge.style("target-label", "."); - edge.style("text-opacity", 0); - edge.style("text-background-opacity", 0); - - - linkEndpointVisibility = false; - }); - } else { - cy.edges().forEach(function(edge) { - edge.style("text-opacity", 1); - edge.style("text-background-opacity", 0.7); - linkEndpointVisibility = true; - }); - } -} - -function viewportButtonContainerStatusVisibility() { - if (nodeContainerStatusVisibility) { - nodeContainerStatusVisibility = false; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `Alright, mission control, we're standing down. 🛑🔍 Container status probing aborted. Stay chill, folks. 😎👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - nodeContainerStatusVisibility = true; - console.log( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - appendMessage( - "nodeContainerStatusVisibility: " + nodeContainerStatusVisibility, - ); - bulmaToast.toast({ - message: `🕵️‍♂️ Bro, we're currently on a mission to probe that container status! Stay tuned for the results. 🔍🚀👨‍💻`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } -} - - -function viewportDrawerLayoutForceDirected() { - edgeLengthSlider = document.getElementById("force-directed-slider-link-lenght"); - nodeGapSlider = document.getElementById("force-directed-slider-node-gap"); - - const edgeLengthValue = parseFloat(edgeLengthSlider.value); - const nodeGapValue = parseFloat(nodeGapSlider.value); - - console.log("edgeLengthValue", edgeLengthValue); - console.log("nodeGapValue", nodeGapValue); - - cy.layout( - { - fit: true, - name: "cola", - animate: true, - randomize: false, - maxSimulationTime: 400, - edgeLength: function(e) { - return edgeLengthValue / e.data("weight"); - }, - nodeGap: function(e) { - return nodeGapValue / e.data("weight"); - }, - }) - .run(); -} - -function viewportDrawerLayoutVertical() { - nodevGap = document.getElementById("vertical-layout-slider-node-v-gap"); - groupvGap = document.getElementById("vertical-layout-slider-group-v-gap"); - - const nodevGapValue = parseFloat(nodevGap.value); - const groupvGapValue = parseFloat(groupvGap.value); - - console.log("nodevGapValue", nodevGapValue); - console.log("groupvGapValue", groupvGapValue); - - const xOffset = parseFloat(nodevGapValue); - const yOffset = parseFloat(groupvGapValue); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numRows = 1; - - const cellWidth = node.width() / children.length; - // const xOffset = 5 - - children.forEach(function(child, index) { - // Position children in rows - const xPos = index * (cellWidth + xOffset); - const yPos = 0; - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxWidth = 0; - var centerX = 0; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const width = node.width(); - if (width > maxWidth) { - maxWidth = width; - console.log("ParentMaxWidth: ", maxWidth); - } - } - }); - - const divisionFactor = maxWidth / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let yPos = 0; - // const yOffset = 50; - // const yOffset = 50; - - // Position parent nodes vertically and center them horizontally - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const xPos = centerX - parent.width() / divisionFactor; - // to the left compared to the center of the widest parent node. - parent.position({ - x: xPos, - y: yPos - }); - yPos += yOffset; - }); - cy.fit(); - }, delay); -} - -function viewportDrawerLayoutHorizontal() { - nodehGap = document.getElementById("horizontal-layout-slider-node-h-gap"); - grouphGap = document.getElementById("horizontal-layout-slider-group-h-gap"); - - const horizontalNodeGap = parseFloat(nodehGap.value); - const horizontalGroupGap = parseFloat(grouphGap.value); - - console.log("nodevGapValue", horizontalNodeGap); - console.log("groupvGapValue", horizontalGroupGap); - - const yOffset = parseFloat(horizontalNodeGap); - const xOffset = parseFloat(horizontalGroupGap); - - console.log("yOffset", yOffset); - console.log("xOffset", xOffset); - - const delay = 100; - setTimeout(() => { - cy.nodes().forEach(function(node) { - if (node.isParent()) { - // For each parent node - const children = node.children(); - const numColumns = 1; - const cellHeight = node.height() / children.length; - // const yOffset = 5; - - children.forEach(function(child, index) { - // Position children in columns - const xPos = 0; - const yPos = index * (cellHeight + yOffset); - - // Set the position of each child node - child.position({ - x: xPos, - y: yPos - }); - }); - } - }); - - var parentCounts = {}; - var maxHeight = 0; - var centerX = cy.width() / 2; - var centerY = cy.height() / 2; - - // Count children of each parent node - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const childrenCount = node.children().length; - parentCounts[node.id()] = childrenCount; - } - }); - - cy.nodes().forEach(function(node) { - if (node.isParent()) { - const height = node.height(); - if (height > maxHeight) { - maxHeight = height; - console.log("ParentMaxHeight: ", maxHeight); - } - } - }); - - const divisionFactor = maxHeight / 2; - console.log("divisionFactor: ", divisionFactor); - - // Sort parent nodes by child count in ascending order - const sortedParents = Object.keys(parentCounts).sort( - (a, b) => parentCounts[a] - parentCounts[b], - ); - - let xPos = 0; - // const xOffset = 50; - - // Position parent nodes horizontally and center them vertically - sortedParents.forEach(function(parentId) { - const parent = cy.getElementById(parentId); - const yPos = centerY - parent.height() / divisionFactor; - parent.position({ - x: xPos, - y: yPos - }); - xPos -= xOffset; - }); - - cy.fit(); - }, delay); - -} - - -function viewportDrawerCaptureButton() { - - console.log ("viewportDrawerCaptureButton() - clicked") - - - - - // Get all checkbox inputs within the specific div - const checkboxes = document.querySelectorAll('#viewport-drawer-capture-sceenshoot-content .checkbox-input'); - - // Initialize an array to store the values of checked checkboxes - const selectedOptions = []; - - // Iterate through the NodeList of checkboxes - checkboxes.forEach((checkbox) => { - // If the checkbox is checked, push its value to the array - if (checkbox.checked) { - selectedOptions.push(checkbox.value); - } - }); - - console.log ("viewportDrawerCaptureButton() - ", selectedOptions) - - - if (selectedOptions.length === 0) { - bulmaToast.toast({ - message: `Hey there, please pick at least one option.😊👌`, - type: "is-warning is-size-6 p-3", - duration: 4000, - position: "top-center", - closeOnClick: true, - }); - } else { - // Perform your action based on the selected options - // Perform your action based on the selected options - if (selectedOptions.join(", ") == "option01") { - captureAndSaveViewportAsPng(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option02") { - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } else if (selectedOptions.join(", ") == "option01, option02") { - captureAndSaveViewportAsPng(cy); - sleep(5000); - captureAndSaveViewportAsDrawIo(cy); - modal.classList.remove("is-active"); - } - } - -} - -async function captureAndSaveViewportAsDrawIo(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - const drawIoWidht = canvasElement.width / 10; - const drawIoHeight = canvasElement.height / 10; - const drawIoaAspectRatio = drawIoWidht / drawIoHeight; - - const mxGraphHeader = ` - - - `; - - const mxGraphFooter = ` - `; - - const mxCells = []; - - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - // Iterate through nodes and edges - // Function to create mxCell XML for nodes - function createMxCellForNode(node, imageURL) { - if (node.isParent()) { - return ` - - - `; - } else if ( - !node.data("id").includes("statusGreen") && - !node.data("id").includes("statusRed") - ) { - return ` - - - `; - } - } - - cy.nodes().forEach(function(node) { - let imageURL; - switch (node.data("topoViewerRole")) { - case "pe": - imageURL = `http://${location.host}/images/clab-pe-light-blue.png`; - break; - case "controller": - imageURL = - `http://${location.host}/images/clab-controller-light-blue.png`; - break; - case "pon": - imageURL = `http://${location.host}/images/clab-pon-dark-blue.png`; - break; - case "dcgw": - imageURL = `http://${location.host}/images/clab-dcgw-dark-blue.png`; - break; - case "leaf": - imageURL = `http://${location.host}/images/clab-leaf-light-blue.png`; - break; - case "spine": - imageURL = `http://${location.host}/images/clab-spine-dark-blue.png`; - break; - case "super-spine": - imageURL = `http://${location.host}/images/clab-spine-light-blue.png`; - break; - } - mxCells.push(createMxCellForNode(node, imageURL)); - }); - - cy.edges().forEach(function(edge) { - mxCells.push(` - - - - - - - - - - - - - - `); - }); - - // Combine all parts and create XML - const mxGraphXML = mxGraphHeader + mxCells.join("") + mxGraphFooter; - - // Create a Blob from the XML - const blob = new Blob([mxGraphXML], { - type: "application/xml", - }); - - // Create a URL for the Blob - const url = window.URL.createObjectURL(blob); - - // Create a download link and trigger a click event - const a = document.createElement("a"); - a.style.display = "none"; - a.href = url; - a.download = "filename.drawio"; - document.body.appendChild(a); - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - a.click(); - - // Clean up by revoking the URL and removing the download link - window.URL.revokeObjectURL(url); - document.body.removeChild(a); -} -async function captureAndSaveViewportAsPng(cy) { - // Find the canvas element for layer2-node - // Find the canvas element for layer2-node - const canvasElement = document.querySelector( - '#cy canvas[data-id="layer2-node"]', - ); - - const zoomScaleFactor = 1; - - // Check if the canvas element exists and is an HTMLCanvasElement - // Check if the canvas element exists and is an HTMLCanvasElement - if (canvasElement instanceof HTMLCanvasElement) { - // Calculate the new canvas dimensions based on the high resolution factor - // Calculate the new canvas dimensions based on the high resolution factor - const newWidth = canvasElement.width * zoomScaleFactor; - const newHeight = canvasElement.height * zoomScaleFactor; - - // Create a new canvas element with the increased dimensions - // Create a new canvas element with the increased dimensions - const newCanvas = document.createElement("canvas"); - newCanvas.width = newWidth; - newCanvas.height = newHeight; - const newCanvasContext = newCanvas.getContext("2d"); - - // Scale the canvas content to the new dimensions - // Scale the canvas content to the new dimensions - newCanvasContext.scale(zoomScaleFactor, zoomScaleFactor); - - // Fill the new canvas with a white background - // Fill the new canvas with a white background - newCanvasContext.fillStyle = "white"; - newCanvasContext.fillRect(0, 0, newWidth, newHeight); - - // Draw the original canvas content on the new canvas - // Draw the original canvas content on the new canvas - newCanvasContext.drawImage(canvasElement, 0, 0); - - // Convert the new canvas to a data URL with a white background - // Convert the new canvas to a data URL with a white background - const dataUrl = newCanvas.toDataURL("image/png"); - - // Create an anchor element to trigger the download - // Create an anchor element to trigger the download - const link = document.createElement("a"); - link.href = dataUrl; - link.download = "cytoscape-viewport.png"; - - bulmaToast.toast({ - message: `Brace yourselves for a quick snapshot, folks! 📸 Capturing the viewport in 3... 2... 1... 🚀💥`, - type: "is-warning is-size-6 p-3", - duration: 2000, - position: "top-center", - closeOnClick: true, - }); - await sleep(2000); - // Simulate a click to trigger the download - // Simulate a click to trigger the download - link.click(); - } else { - console.error( - "Canvas element for layer2-node is not found or is not a valid HTML canvas element.", - ); - } -} - - - -// aarafat-tag: -//// REFACTOR END - -// logMessagesPanel manager -///-logMessagesPanel Function to append message function -function appendMessage(message) { - // const textarea = document.getElementById('notificationTextarea'); - const textarea = document.getElementById("notificationTextarea"); - - // Get the current date and time - const timestamp = new Date().toLocaleString(); - - textarea.value += `[${timestamp}] ${message}\n`; - textarea.scrollTop = textarea.scrollHeight; -} - -function nodeFindDrawer(cy) { - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - //- Get a reference to your Cytoscape instance (assuming it's named 'cy') - //- const cy = window.cy; //- Replace 'window.cy' with your actual Cytoscape instance - //- Find the node with the specified name - const nodeName = document.getElementById( - "panelBlock-viewportButtons-buttonfindNode-divPanelBlock-columnContainerlabelFindNodeNodeName-panelContentlabelFindNodeNodeName-columnsPanelContentlabelFindNodeNodeName-labelColumnlabelFindNodeNodeName-inputColumnlabelFindNodeNodeName-labellabelFindNodeNodeName", - ).value; - - const node = cy.$(`node[name = "${nodeName}"]`); - //- Check if the node exists - //- Check if the node exists - if (node.length > 0) { - // console - // console - console.log("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - appendMessage("Info: " + 'Sweet! Node "' + nodeName + '" is in the house.'); - //- Apply a highlight style to the node - //- Apply a highlight style to the node - node.style({ - "border-color": "red", - "border-width": "2px", - "background-color": "yellow", - }); - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: node.position("x"), - y: node.position("y"), - }, - renderedPosition: { - x: node.renderedPosition("x"), - y: node.renderedPosition("y"), - }, - }, - duration: 1500, - }); - } else { - console.error( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - appendMessage( - `Bro, I couldn't find a node named "${nodeName}". Try another one.`, - ); - } -} - -function pathFinderDijkstraDrawer(cy) { - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - // Usage example: - // highlightShortestPath('node-a', 'node-b'); // Replace with your source and target node IDs - //- Function to get the default node style from cy-style.json - //- weight: (edge) => 1, // You can adjust the weight function if needed - //- weight: (edge) => edge.data('distance') - - console.log("im triggered"); - - // Remove existing highlight from all edges - // Remove existing highlight from all edges - cy.edges().forEach((edge) => { - edge.removeClass("spf"); - }); - - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - // Get the node sourceNodeId from pathFinderSourceNodeInput and targetNodeId from pathFinderTargetNodeInput - const sourceNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteSource-panelContentlabelFindRouteSource-columnsPanelContentlabelFindRouteSource-labelColumnlabelFindRouteSource-inputColumnlabelFindRouteSource-labellabelFindRouteSource", - ).value; - const targetNodeId = document.getElementById( - "panelBlock-viewportButtons-buttonfindRoute-divPanelBlock-columnContainerlabelFindRouteTarget-panelContentlabelFindRouteTarget-columnsPanelContentlabelFindRouteTarget-labelColumnlabelFindRouteTarget-inputColumnlabelFindRouteTarget-labellabelFindRouteTarget", - ).value; - - // Assuming you have 'cy' as your Cytoscape instance - // Assuming you have 'cy' as your Cytoscape instance - const sourceNode = cy.$(`node[id="${sourceNodeId}"]`); - const targetNode = cy.$(`node[id="${targetNodeId}"]`); - - console.log( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - appendMessage( - "Info: " + - "Let's find the path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - "!", - ); - - // Check if both nodes exist - // Check if both nodes exist - if (sourceNode.length === 0 || targetNode.length === 0) { - console.error( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - appendMessage( - `Bro, couldn't find the source or target node you specified. Double-check the node names.`, - ); - return; - } - - // Get the Dijkstra result with the shortest path - // Get the Dijkstra result with the shortest path - const dijkstraResult = cy.elements().dijkstra({ - root: sourceNode, - weight: (edge) => 1, - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - // Use the custom weight attribute - // weight: edge => edge.data('customWeight'), - }); - // Get the shortest path from Dijkstra result - // Get the shortest path from Dijkstra result - const shortestPathEdges = dijkstraResult.pathTo(targetNode); - console.log(shortestPathEdges); - - // Check if there is a valid path (shortestPathEdges is not empty) - // Check if there is a valid path (shortestPathEdges is not empty) - if (shortestPathEdges.length > 1) { - // Highlight the shortest path - // Highlight the shortest path - shortestPathEdges.forEach((edge) => { - edge.addClass("spf"); - }); - - //- Zoom out on the node - //- Zoom out on the node - cy.fit(); - - //- Zoom in on the node - //- Zoom in on the node - cy.animate({ - zoom: { - level: 5, - position: { - x: sourceNode.position("x"), - y: sourceNode.position("y"), - }, - renderedPosition: { - x: sourceNode.renderedPosition("x"), - y: sourceNode.renderedPosition("y"), - }, - }, - duration: 1500, - }); - // throw log - // throw log - console.log( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found.", - ); - appendMessage( - "Info: " + - "Yo, check it out! Shorthest Path from-" + - sourceNodeId + - "-to-" + - targetNodeId + - " has been found, below is the path trace..", - ); - console.log(shortestPathEdges); - - shortestPathEdges.forEach((edge) => { - console.log("Edge ID:", edge.id()); - console.log("Source Node ID:", edge.source().id()); - console.log("Target Node ID:", edge.target().id()); - - edgeId = edge.id(); - sourceNodeId = edge.source().id(); - targetNodeId = edge.target().id(); - // You can access other properties of the edge, e.g., source, target, data, etc. - // You can access other properties of the edge, e.g., source, target, data, etc. - - appendMessage("Info: " + "Edge ID: " + edgeId); - appendMessage("Info: " + "Source Node ID: " + sourceNodeId); - appendMessage("Info: " + "Target Node ID: " + targetNodeId); - }); - } else { - console.error( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - appendMessage( - `Bro, there is no path from "${sourceNodeId}" to "${targetNodeId}".`, - ); - return; - } -} - -// sleep funtion -function sleep(ms) { - return new Promise((resolve) => setTimeout(resolve, ms)); -} \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/template/clab/button.html.tmpl b/rawTopoFile/topoviewer/html-static/template/clab/button.html.tmpl deleted file mode 100644 index 18f8a2181..000000000 --- a/rawTopoFile/topoviewer/html-static/template/clab/button.html.tmpl +++ /dev/null @@ -1,783 +0,0 @@ - - - - - - TopoViewer - - - - - - - - - - - -
-
- - - -
- -
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - diff --git a/rawTopoFile/topoviewer/html-static/template/clab/clab-cytoscape-export.tmpl b/rawTopoFile/topoviewer/html-static/template/clab/clab-cytoscape-export.tmpl deleted file mode 100755 index 1da6c19a2..000000000 --- a/rawTopoFile/topoviewer/html-static/template/clab/clab-cytoscape-export.tmpl +++ /dev/null @@ -1,70 +0,0 @@ -[ - {{- $i:=0 }}{{range $n, $c := .NodeConfigs}}{{if $i}}{{end}} - { - "data": { - "index": "{{$c.Index}}", - "id": "{{$c.ShortName}}", - "name": "{{$c.ShortName}}", - "longname": "{{$c.LongName}}", - "fqdn": "{{$c.Fqdn}}", - "clabGroup": "{{$c.Group}}", - "binds": "{{$c.Binds}}", - "labdir": "{{$c.LabDir}}", - "kind": "{{$c.Kind}}", - "image": "{{$c.Image}}", - "mgmt-net": "{{$c.MgmtNet}}", - "mgmt-intf": "{{$c.MgmtIntf}}", - "mgmt-ipv4-address": "{{$c.MgmtIPv4Address}}", - "mgmt-ipv4-prefix-length": {{$c.MgmtIPv4PrefixLength}}, - "mgmt-ipv6-address": "{{$c.MgmtIPv6Address}}", - "mgmt-ipv6-prefix-length": {{$c.MgmtIPv6PrefixLength}}, - "mac-address": "{{$c.MacAddress}}", - "labels": {{ToJSONPretty $c.Labels " " " "}} - }, - "position": { - "x": 0, - "y": 0 - }, - "removed": false, - "group": "nodes", - "selected": false, - "selectable": true, - "locked": false, - "grabbed": false, - "grabbable": true, - "classes": "" - }, - {{$i = add $i 1}}{{end}} - {{range $i, $l := .Clab.Links}}{{if $i}},{{end}} - { - "data": { - "id": "{{ $l.A.Node.ShortName }}::{{ $l.A.EndpointName }}<-->{{ $l.B.Node.ShortName }}::{{ $l.B.EndpointName }}", - "source": "{{ $l.A.Node.ShortName }}", - "target": "{{ $l.B.Node.ShortName }}", - "weight": "1", - "name": " "{{ $l.A.Node.ShortName }}::{{ $l.A.EndpointName }}<-->{{ $l.B.Node.ShortName }}::{{ $l.B.EndpointName }}", - "parent": "", - "kind": "", - "sourceEndpoint": "{{ $l.A.EndpointName }}", - "targetEndpoint": "{{ $l.B.EndpointName }}", - "sourceMac": "{{ $l.A.MAC }}", - "targetMac": "{{ $l.B.MAC }}", - "endpoint": { - "sourceEndpoint": "{{ $l.A.EndpointName }}", - "targetEndpoint": "{{ $l.B.EndpointName }}" - } - }, - "position": { - "x": 0, - "y": 0 - }, - "removed": false, - "group": "edges", - "selected": false, - "selectable": true, - "locked": false, - "grabbed": false, - "grabbable": true, - "classes": "" - }{{end}} -] \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/template/clab/cy-style-dark.tmpl b/rawTopoFile/topoviewer/html-static/template/clab/cy-style-dark.tmpl deleted file mode 100644 index f4928a583..000000000 --- a/rawTopoFile/topoviewer/html-static/template/clab/cy-style-dark.tmpl +++ /dev/null @@ -1,259 +0,0 @@ -[ - { - "selector": "core", - "style": { - "selection-box-color": "#AAD8FF", - "selection-box-border-color": "#8BB0D0", - "selection-box-opacity": "0.5" - } - }, - { - "selector": "node", - "style": { - "shape": "rectangle", - "width": "10", - "height": "10", - "content": "data(name)", - "label": "data(name)", - "font-size": "7px", - "text-valign": "bottom", - "text-halign": "center", - "background-color": "#8F96AC", - - "min-zoomed-font-size": "7px", - "color": "#F5F5F5", - "text-outline-color": "#3C3E41", - - "text-outline-width": "0.3px", - "overlay-padding": "0.3px", - "z-index": "10" - } - }, - { - "selector": "node[?attr]", - "style": { - "shape": "rectangle", - "background-color": "#aaa", - "text-outline-color": "#aaa", - "width": "10px", - "height": "10x", - "font-size": "8px", - "z-index": "1" - } - }, - { - "selector": "node[?query]", - "style": {"background-clip": "none", "background-fit": "contain"} - }, - { - "selector": "node:parent", - "style": { - "shape": "rectangle", - "border-width": "0.5px", - "border-color": "#DDDDDD", - "background-color": "#d9d9d9", - "background-opacity": "0.2", - "color": "#EBECF0", - "text-outline-color": "#000000", - "width": "3px", - "height": "3x", - "font-size": "8px", - "z-index": "1" - } - }, - { - "selector": "node:selected", - "style": { - "border-width": "1.5px", - "border-color": "#282828", - "border-opacity": "0.5", - "background-color": "#77828C", - "text-outline-color": "#282828" - } - }, - { - "selector": "node[name*=\"statusGreen\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#F5F5F5", - "border-width": "0.5", - "border-color": "#00A500" - } - }, - { - "selector": "node[name*=\"statusRed\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#FD1C03", - "border-width": "0.5", - "border-color": "#AD0000" - } - }, - { - "selector": "node[topoViewerRole=\"pe\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"p\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"controller\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-controller-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"pon\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-pon-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"dcgw\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-dcgw-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"leaf\"]", - "style": { - "background-image": "images/clab-leaf-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"rgw\"]", - "style": { - "background-image": "images/clab-rgw-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"super-spine\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-spine-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"spine\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-spine-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"server\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-server-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"bridge\"]", - "style": { - "width": "8", - "height": "8", - "background-image": "images/clab-bridge-light-grey.png", - "background-fit": "cover" - } - }, - { - "selector": "edge", - "style": { - "targetArrowShape": "none", - "source-text-offset": 13, - "target-text-offset": 13, - "font-size": "7px", - "source-label": "data(sourceEndpoint)", - "target-label": "data(targetEndpoint)", - "arrow-scale": "0.5", - "color": "#CACBCC", - "text-outline-width": "0.3px", - - "text-outline-color": "#3C3E41", - - - "curve-style": "bezier", - "opacity": "1", - "line-color": "#969799", - "width": "1.5", - "overlay-padding": "2px" - } - }, - { - "selector": ".edgeEndpointLabel", - "style": { - "source-label": "data(sourceEndpoint)", - "target-label": "data(targetEndpoint)" - } - }, - {"selector": "node.unhighlighted", "style": {"opacity": "0.2"}}, - {"selector": "edge.unhighlighted", "style": {"opacity": "0.05"}}, - {"selector": ".highlighted", "style": {"z-index": "999999"}}, - { - "selector": "node.highlighted", - "style": { - "border-width": "7px", - "border-color": "#282828", - "border-opacity": "0.5", - "background-color": "#282828", - "text-outline-color": "#282828" - } - }, - {"selector": "edge.filtered", "style": {"opacity": "0"}}, - - {"selector": ".spf", "style": - {"opacity": "1", - "line-color": "#FF0000", - "line-style": "solid" - } - }, - - - {"selector": "edge[group=\"coexp\"]", "style": {"line-color": "#d0b7d5"}}, - {"selector": "edge[group=\"coloc\"]", "style": {"line-color": "#a0b3dc"}}, - {"selector": "edge[group=\"gi\"]", "style": {"line-color": "#90e190"}}, - {"selector": "edge[group=\"path\"]", "style": {"line-color": "#9bd8de"}}, - {"selector": "edge[group=\"pi\"]", "style": {"line-color": "#eaa2a2"}}, - {"selector": "edge[group=\"predict\"]", "style": {"line-color": "#f6c384"}}, - {"selector": "edge[group=\"spd\"]", "style": {"line-color": "#dad4a2"}}, - {"selector": "edge[group=\"spd_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"user\"]", "style": {"line-color": "#f0ec86"}} -] \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/template/clab/cy-style.tmpl b/rawTopoFile/topoviewer/html-static/template/clab/cy-style.tmpl deleted file mode 100755 index 7f3df4a56..000000000 --- a/rawTopoFile/topoviewer/html-static/template/clab/cy-style.tmpl +++ /dev/null @@ -1,249 +0,0 @@ -[ - { - "selector": "core", - "style": { - "selection-box-color": "#AAD8FF", - "selection-box-border-color": "#8BB0D0", - "selection-box-opacity": "0.5" - } - }, - { - "selector": "node", - "style": { - "shape": "rectangle", - "width": "10", - "height": "10", - "content": "data(name)", - "label": "data(name)", - "font-size": "6px", - "text-valign": "bottom", - "text-halign": "center", - "background-color": "#8F96AC", - "text-outline-color": "#F2F2F2", - "text-outline-width": "0.3px", - "color": "#353535", - "overlay-padding": "0.3px", - "z-index": "10" - } - }, - { - "selector": "node[?attr]", - "style": { - "shape": "rectangle", - "background-color": "#aaa", - "text-outline-color": "#aaa", - "width": "10px", - "height": "10x", - "font-size": "8px", - "z-index": "1" - } - }, - { - "selector": "node[?query]", - "style": {"background-clip": "none", "background-fit": "contain"} - }, - { - "selector": "node:parent", - "style": { - "shape": "rectangle", - "border-width": "0.5px", - "border-color": "#DDDDDD", - "background-color": "#d9d9d9", - "background-opacity": "0.2", - "text-outline-color": "#F2F2F2", - "width": "3px", - "height": "3x", - "font-size": "5px", - "z-index": "1" - } - }, - { - "selector": "node:selected", - "style": { - "border-width": "1.5px", - "border-color": "#F2F2F2", - "border-opacity": "0.5", - "background-color": "#77828C", - "text-outline-color": "#F2F2F2" - } - }, - { - "selector": "node[name*=\"statusGreen\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#0FFF50", - "border-width": "0.5", - "border-color": "#00A500" - } - }, - { - "selector": "node[name*=\"statusRed\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#FD1C03", - "border-width": "0.5", - "border-color": "#AD0000" - } - }, - { - "selector": "node[topoViewerRole=\"pe\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"p\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"controller\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-controller-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"pon\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-pon-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"dcgw\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-dcgw-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"leaf\"]", - "style": { - "background-image": "images/clab-leaf-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"rgw\"]", - "style": { - "background-image": "images/clab-rgw-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"super-spine\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-spine-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"spine\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-spine-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"server\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-server-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoViewerRole=\"bridge\"]", - "style": { - "width": "8", - "height": "8", - "background-image": "images/clab-bridge-light-grey.png", - "background-fit": "cover" - } - }, - { - "selector": "edge", - "style": { - "targetArrowShape": "none", - "source-text-offset": 10, - "target-text-offset": 10, - "font-size": "5px", - "source-label": "data(sourceEndpoint)", - "target-label": "data(targetEndpoint)", - "arrow-scale": "0.5", - "curve-style": "bezier", - "opacity": "0.5", - "line-color": "#B1BCC8", - "width": "1.5", - "overlay-padding": "2px" - } - }, - { - "selector": ".edgeEndpointLabel", - "style": { - "source-label": "data(sourceEndpoint)", - "target-label": "data(targetEndpoint)" - } - }, - {"selector": "node.unhighlighted", "style": {"opacity": "0.2"}}, - {"selector": "edge.unhighlighted", "style": {"opacity": "0.05"}}, - {"selector": ".highlighted", "style": {"z-index": "999999"}}, - { - "selector": "node.highlighted", - "style": { - "border-width": "6px", - "border-color": "#F2F2F2", - "border-opacity": "0.5", - "background-color": "#F2F2F2", - "text-outline-color": "#F2F2F2" - } - }, - {"selector": "edge.filtered", "style": {"opacity": "0"}}, - - {"selector": ".spf", "style": - {"opacity": "1", - "line-color": "#FF0000", - "line-style": "solid" - } - }, - - - {"selector": "edge[group=\"coexp\"]", "style": {"line-color": "#d0b7d5"}}, - {"selector": "edge[group=\"coloc\"]", "style": {"line-color": "#a0b3dc"}}, - {"selector": "edge[group=\"gi\"]", "style": {"line-color": "#90e190"}}, - {"selector": "edge[group=\"path\"]", "style": {"line-color": "#9bd8de"}}, - {"selector": "edge[group=\"pi\"]", "style": {"line-color": "#eaa2a2"}}, - {"selector": "edge[group=\"predict\"]", "style": {"line-color": "#f6c384"}}, - {"selector": "edge[group=\"spd\"]", "style": {"line-color": "#dad4a2"}}, - {"selector": "edge[group=\"spd_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"user\"]", "style": {"line-color": "#f0ec86"}} -] \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/template/clab/index.html.tmpl b/rawTopoFile/topoviewer/html-static/template/clab/index.html.tmpl deleted file mode 100755 index be76caada..000000000 --- a/rawTopoFile/topoviewer/html-static/template/clab/index.html.tmpl +++ /dev/null @@ -1,783 +0,0 @@ - - - - - - TopoViewer - - - - - - - - - - - -
-
- - - -
- -
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - diff --git a/rawTopoFile/topoviewer/html-static/template/clab/resources.tmpl b/rawTopoFile/topoviewer/html-static/template/clab/resources.tmpl deleted file mode 100644 index 98bc644f1..000000000 --- a/rawTopoFile/topoviewer/html-static/template/clab/resources.tmpl +++ /dev/null @@ -1,167 +0,0 @@ - - - - - - System Usage Chart - - - -

System Usage

- - -
- - - diff --git a/rawTopoFile/topoviewer/html-static/template/clab/websocket-index.tmpl b/rawTopoFile/topoviewer/html-static/template/clab/websocket-index.tmpl deleted file mode 100755 index 8761e6959..000000000 --- a/rawTopoFile/topoviewer/html-static/template/clab/websocket-index.tmpl +++ /dev/null @@ -1,39 +0,0 @@ - - - - - - - Go WebSocket Tutorial - - -

Hello World

- - - - \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/template/nsp/cloudshell-index.tmpl b/rawTopoFile/topoviewer/html-static/template/nsp/cloudshell-index.tmpl deleted file mode 100755 index 7a7cb9736..000000000 --- a/rawTopoFile/topoviewer/html-static/template/nsp/cloudshell-index.tmpl +++ /dev/null @@ -1,54 +0,0 @@ - - - - - - - - - - - - - - - - -
- - - - diff --git a/rawTopoFile/topoviewer/html-static/template/nsp/cloudshell-terminal-js.tmpl b/rawTopoFile/topoviewer/html-static/template/nsp/cloudshell-terminal-js.tmpl deleted file mode 100755 index 4633a4bfb..000000000 --- a/rawTopoFile/topoviewer/html-static/template/nsp/cloudshell-terminal-js.tmpl +++ /dev/null @@ -1,74 +0,0 @@ -( - function() { - // get querry parameter - var urlParam = function(name, w){ - w = w || window; - var rx = new RegExp('[\&|\?]'+name+'=([^\&\#]+)'), - val = w.location.search.match(rx); - return !val ? '':val[1]; - } - var routerId = urlParam('RouterID'); - console.log(routerId) - - var split1 = routerId.toString() - split1 = split1.split("?") - console.log(split1) - - document.title = split1[1].split("=")[1]; - - var terminal = new Terminal({ - screenKeys: true, - useStyle: true, - cursorBlink: true, - fullscreenWin: true, - maximizeWin: true, - screenReaderMode: true, - cols: 128, - }); - terminal.open(document.getElementById("terminal")); - var protocol = (location.protocol === "https:") ? "wss://" : "ws://"; - var url = protocol + location.host + "/xterm.js" - var ws = new WebSocket(url); - - console.log(ws); - - var attachAddon = new AttachAddon.AttachAddon(ws); - var fitAddon = new FitAddon.FitAddon(); - terminal.loadAddon(fitAddon); - var webLinksAddon = new WebLinksAddon.WebLinksAddon(); - terminal.loadAddon(webLinksAddon); - var unicode11Addon = new Unicode11Addon.Unicode11Addon(); - terminal.loadAddon(unicode11Addon); - var serializeAddon = new SerializeAddon.SerializeAddon(); - terminal.loadAddon(serializeAddon); - ws.onclose = function(event) { - console.log(event); - terminal.write('\r\n\nconnection has been terminated from the server-side (hit refresh to restart)\n') - }; - ws.onopen = function() { - terminal.loadAddon(attachAddon); - terminal._initialized = true; - terminal.focus(); - setTimeout(function() {fitAddon.fit()}); - terminal.onResize(function(event) { - var rows = event.rows; - var cols = event.cols; - var size = JSON.stringify({cols: cols, rows: rows + 1}); - var send = new TextEncoder().encode("\x01" + size); - console.log('resizing to', size); - - ws.send("ssh admin@" + routerId.toString().split("?")[0]) - // ws.send(send); - - - }); - terminal.onTitleChange(function(event) { - console.log(event); - }); - window.onresize = function() { - fitAddon.fit(); - }; - }; -}) - -(); diff --git a/rawTopoFile/topoviewer/html-static/template/nsp/cy-style.tmpl b/rawTopoFile/topoviewer/html-static/template/nsp/cy-style.tmpl deleted file mode 100755 index 1db4d4c0e..000000000 --- a/rawTopoFile/topoviewer/html-static/template/nsp/cy-style.tmpl +++ /dev/null @@ -1,314 +0,0 @@ -[ - { - "selector": "core", - "style": { - "selection-box-color": "#AAD8FF", - "selection-box-border-color": "#8BB0D0", - "selection-box-opacity": "0.5" - } - }, - { - "selector": "node", - "style": { - "shape": "ellipse", - "width": "10", - "height": "10", - "content": "data(name)", - "label": "data(name)", - "font-size": "4px", - "text-valign": "bottom", - "text-halign": "center", - "background-color": "#8F96AC", - "text-outline-color": "#F2F2F2", - "text-outline-width": "0.3px", - "color": "#353535", - "overlay-padding": "0.3px", - "z-index": "10" - } - }, - { - "selector": "node[?attr]", - "style": { - "shape": "rectangle", - "background-color": "#aaa", - "text-outline-color": "#aaa", - "width": "10px", - "height": "10x", - "font-size": "8px", - "z-index": "1" - } - }, - { - "selector": "node[?query]", - "style": {"background-clip": "none", "background-fit": "contain"} - }, - { - "selector": "node:parent", - "style": { - "shape": "rectangle", - "border-width": "0.5px", - "border-color": "#DDDDDD", - "background-color": "#d9d9d9", - "background-opacity": "0.2", - "text-outline-color": "#F2F2F2", - "width": "3px", - "height": "3x", - "font-size": "5px", - "z-index": "1" - } - }, - { - "selector": "node[id=\"ietf-l2-topology\"]", - "style": { - "shape": "rectangle", - "border-width": "0.5px", - "border-color": "#afeac7", - "background-color": "#c3efd5", - "background-opacity": "0.2", - "text-outline-color": "#F2F2F2", - "width": "3px", - "height": "3x", - "font-size": "5px", - "z-index": "1" - } - }, - { - "selector": "node:selected", - "style": { - "border-width": "1.5px", - "border-color": "#F2F2F2", - "border-opacity": "0.5", - "background-color": "#77828C", - "text-outline-color": "#F2F2F2" - } - }, - { - "selector": "node[name*=\"statusGreen\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#0FFF50", - "border-width": "0.5", - "border-color": "#00A500" - } - }, - { - "selector": "node[name*=\"statusRed\"]", - "style": { - "display": "none", - "shape": "ellipse", - "label": " ", - "width": "4", - "height": "4", - "background-color": "#FD1C03", - "border-width": "0.5", - "border-color": "#AD0000" - } - }, - { - "selector": "node[kind=\"layer2Node\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[kind=\"layer3Node\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-dark-grey.png", - "background-fit": "cover" - } - }, - { - "selector": "node[kind=\"LayerTransportTunnelNode\"]", - "style": { - "width": "14", - "height": "14", - "text-valign": "top", - "background-image": "images/clab-pe-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoviewerRole=\"pe\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-pe-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoviewerRole=\"controller\"]", - "style": { - "width": "14", - "height": "14", - "background-image": "images/clab-controller-light-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoviewerRole=\"pon\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-pon-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoviewerRole=\"dcgw\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-dcgw-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoviewerRole=\"leaf\"]", - "style": { - "background-image": "images/clab-leaf-dark-grey.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoviewerRole=\"rgw\"]", - "style": { - "background-image": "images/clab-rgw-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoviewerRole=\"spine\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-spine-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoviewerRole=\"server\"]", - "style": { - "width": "12", - "height": "12", - "background-image": "images/clab-server-dark-blue.png", - "background-fit": "cover" - } - }, - { - "selector": "node[topoviewerRole=\"bridge\"]", - "style": { - "width": "8", - "height": "8", - "background-image": "images/clab-bridge-light-grey.png", - "background-fit": "cover" - } - }, - { - "selector": "edge", - "style": { - "targetArrowShape": "none", - "source-text-offset": 10, - "target-text-offset": 10, - "font-size": "3.5px", - "arrow-scale": "0.5", - "curve-style": "bezier", - "opacity": "0.5", - "line-color": "#B1BCC8", - "width": "1.5", - "overlay-padding": "2px", - "z-index": 2 - } - }, - { - "selector": "edge[kind=\"MultiLayerLink\"]", - "style": { - "targetArrowShape": "none", - "source-text-offset": 10, - "target-text-offset": 10, - "font-size": "3.5px", - "arrow-scale": "0.5", - "curve-style": "straight", - "opacity": "0.5", - "line-style": "dotted", - "line-color": "#A6A6A6", - "width": "1.5", - "overlay-padding": "2px", - "z-index": 1 - } - }, - { - "selector": "edge[kind=\"LayerTransportTunnelLink\"]", - "style": { - "source-text-offset": 10, - "target-text-offset": 10, - "font-size": "3.5px", - "target-arrow-shape": "triangle", - "target-arrow-color": "data(extraData.color)", - "arrow-scale": "0.5", - "curve-style": "bezier", - "opacity": "1", - "line-style": "dotted", - "line-color": "data(extraData.color)", - "width": "1.5", - "overlay-padding": "2px" - } - }, - { - "selector": "edge[kind=\"layer2Link\"]", - "style": { - "source-text-offset": 10, - "target-text-offset": 10, - "font-size": "3.5px", - "target-arrow-shape": "node", - "target-arrow-color": "#7D33F2", - "arrow-scale": "0.5", - "curve-style": "bezier", - "opacity": "0.1", - "line-style": "solid", - "width": "1.5", - "overlay-padding": "2px" - } - }, - { - "selector": ".edgeEndpointLabel", - "style": { - "source-label": "data(sourceEndpoint)", - "target-label": "data(targetEndpoint)" - } - }, - {"selector": "node.unhighlighted", "style": {"opacity": "0.2"}}, - {"selector": "edge.unhighlighted", "style": {"opacity": "0.05"}}, - {"selector": ".highlighted", "style": {"z-index": "999999"}}, - { - "selector": "node.highlighted", - "style": { - "border-width": "6px", - "border-color": "#F2F2F2", - "border-opacity": "0.5", - "background-color": "#F2F2F2", - "text-outline-color": "#F2F2F2" - } - }, - {"selector": "edge.filtered", "style": {"opacity": "0"}}, - {"selector": "edge[group=\"coexp\"]", "style": {"line-color": "#d0b7d5"}}, - {"selector": "edge[group=\"coloc\"]", "style": {"line-color": "#a0b3dc"}}, - {"selector": "edge[group=\"gi\"]", "style": {"line-color": "#90e190"}}, - {"selector": "edge[group=\"path\"]", "style": {"line-color": "#9bd8de"}}, - {"selector": "edge[group=\"pi\"]", "style": {"line-color": "#eaa2a2"}}, - {"selector": "edge[group=\"predict\"]", "style": {"line-color": "#f6c384"}}, - {"selector": "edge[group=\"spd\"]", "style": {"line-color": "#dad4a2"}}, - {"selector": "edge[group=\"spd_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"reg_attr\"]", "style": {"line-color": "#D0D0D0"}}, - {"selector": "edge[group=\"user\"]", "style": {"line-color": "#f0ec86"}} -] \ No newline at end of file diff --git a/rawTopoFile/topoviewer/html-static/template/nsp/index.tmpl b/rawTopoFile/topoviewer/html-static/template/nsp/index.tmpl deleted file mode 100755 index d7e94adce..000000000 --- a/rawTopoFile/topoviewer/html-static/template/nsp/index.tmpl +++ /dev/null @@ -1,920 +0,0 @@ - - - - - - - Topology Viewer - - - - - - - - - - - - - - - - - - - - - - -
- - - - \ No newline at end of file diff --git a/rawTopoFile/topoviewer/local-bind/entrypoint.sh b/rawTopoFile/topoviewer/local-bind/entrypoint.sh deleted file mode 100755 index d088b2a5a..000000000 --- a/rawTopoFile/topoviewer/local-bind/entrypoint.sh +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/bash -/opt/topoviewer/topoviewer clab --allowed-hostnames $ALLOWED_HOSTNAME --clab-user $CLAB_USER --clab-pass $CLAB_PASS --server-port $SERVER_PORT --topology-file-yaml local-bind/topo-file.yaml & \ No newline at end of file diff --git a/rawTopoFile/topoviewer/local-bind/topo-file.json b/rawTopoFile/topoviewer/local-bind/topo-file.json deleted file mode 100644 index 53bc15c2c..000000000 --- a/rawTopoFile/topoviewer/local-bind/topo-file.json +++ /dev/null @@ -1,382 +0,0 @@ -{ - "name": "demo", - "type": "clab", - "clab": { - "config": { - "prefix": "clab", - "mgmt": { - "network": "clab", - "bridge": "br-0e52e9f1330e", - "ipv4-subnet": "172.20.20.0/24", - "ipv4-gw": "172.20.20.1", - "ipv6-subnet": "3fff:172:20:20::/64", - "ipv6-gw": "3fff:172:20:20::1", - "mtu": 1500, - "external-access": true - } - } - }, - "nodes": { - "Leaf-01": { - "index": "0", - "shortname": "Leaf-01", - "longname": "clab-demo-Leaf-01", - "fqdn": "Leaf-01.demo.io", - "group": "Data Center Leaf", - "labdir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Leaf-01", - "kind": "srl", - "image": "ghcr.io/nokia/srlinux", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.5", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "3fff:172:20:20::5", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "1a:35:00:00:00:00", - "labels": { - "clab-mgmt-net-bridge": "br-0e52e9f1330e", - "clab-node-group": "Data Center Leaf", - "clab-node-kind": "srl", - "clab-node-lab-dir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Leaf-01", - "clab-node-name": "Leaf-01", - "clab-node-type": "ixrd2l", - "clab-owner": "asad", - "clab-topo-file": "/var/asad/topoViewer/rawTopoFile/topo-clab-demo.yaml", - "containerlab": "demo", - "topoViewer-role": "leaf" - }, - "port-bindings": [ - ] - }, - "Leaf-02": { - "index": "1", - "shortname": "Leaf-02", - "longname": "clab-demo-Leaf-02", - "fqdn": "Leaf-02.demo.io", - "group": "Data Center Leaf", - "labdir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Leaf-02", - "kind": "srl", - "image": "ghcr.io/nokia/srlinux", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.6", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "3fff:172:20:20::6", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "1a:60:01:00:00:00", - "labels": { - "clab-mgmt-net-bridge": "br-0e52e9f1330e", - "clab-node-group": "Data Center Leaf", - "clab-node-kind": "srl", - "clab-node-lab-dir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Leaf-02", - "clab-node-name": "Leaf-02", - "clab-node-type": "ixrd2l", - "clab-owner": "asad", - "clab-topo-file": "/var/asad/topoViewer/rawTopoFile/topo-clab-demo.yaml", - "containerlab": "demo", - "topoViewer-role": "leaf" - }, - "port-bindings": [ - ] - }, - "Leaf-03": { - "index": "2", - "shortname": "Leaf-03", - "longname": "clab-demo-Leaf-03", - "fqdn": "Leaf-03.demo.io", - "group": "Data Center Leaf", - "labdir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Leaf-03", - "kind": "srl", - "image": "ghcr.io/nokia/srlinux", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.8", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "3fff:172:20:20::8", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "1a:23:02:00:00:00", - "labels": { - "clab-mgmt-net-bridge": "br-0e52e9f1330e", - "clab-node-group": "Data Center Leaf", - "clab-node-kind": "srl", - "clab-node-lab-dir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Leaf-03", - "clab-node-name": "Leaf-03", - "clab-node-type": "ixrd2l", - "clab-owner": "asad", - "clab-topo-file": "/var/asad/topoViewer/rawTopoFile/topo-clab-demo.yaml", - "containerlab": "demo", - "topoViewer-role": "leaf" - }, - "port-bindings": [ - ] - }, - "Leaf-04": { - "index": "3", - "shortname": "Leaf-04", - "longname": "clab-demo-Leaf-04", - "fqdn": "Leaf-04.demo.io", - "group": "Data Center Leaf", - "labdir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Leaf-04", - "kind": "srl", - "image": "ghcr.io/nokia/srlinux", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.7", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "3fff:172:20:20::7", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "1a:3a:03:00:00:00", - "labels": { - "clab-mgmt-net-bridge": "br-0e52e9f1330e", - "clab-node-group": "Data Center Leaf", - "clab-node-kind": "srl", - "clab-node-lab-dir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Leaf-04", - "clab-node-name": "Leaf-04", - "clab-node-type": "ixrd2l", - "clab-owner": "asad", - "clab-topo-file": "/var/asad/topoViewer/rawTopoFile/topo-clab-demo.yaml", - "containerlab": "demo", - "topoViewer-role": "leaf" - }, - "port-bindings": [ - ] - }, - "Spine-01": { - "index": "4", - "shortname": "Spine-01", - "longname": "clab-demo-Spine-01", - "fqdn": "Spine-01.demo.io", - "group": "Data Center Spine", - "labdir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Spine-01", - "kind": "srl", - "image": "ghcr.io/nokia/srlinux", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.3", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "3fff:172:20:20::3", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "1a:e0:04:00:00:00", - "labels": { - "clab-mgmt-net-bridge": "br-0e52e9f1330e", - "clab-node-group": "Data Center Spine", - "clab-node-kind": "srl", - "clab-node-lab-dir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Spine-01", - "clab-node-name": "Spine-01", - "clab-node-type": "ixrd2l", - "clab-owner": "asad", - "clab-topo-file": "/var/asad/topoViewer/rawTopoFile/topo-clab-demo.yaml", - "containerlab": "demo", - "topoViewer-role": "spine" - }, - "port-bindings": [ - ] - }, - "Spine-02": { - "index": "5", - "shortname": "Spine-02", - "longname": "clab-demo-Spine-02", - "fqdn": "Spine-02.demo.io", - "group": "Data Center Spine", - "labdir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Spine-02", - "kind": "srl", - "image": "ghcr.io/nokia/srlinux", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.4", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "3fff:172:20:20::4", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "1a:1f:05:00:00:00", - "labels": { - "clab-mgmt-net-bridge": "br-0e52e9f1330e", - "clab-node-group": "Data Center Spine", - "clab-node-kind": "srl", - "clab-node-lab-dir": "/var/asad/topoViewer/rawTopoFile/clab-demo/Spine-02", - "clab-node-name": "Spine-02", - "clab-node-type": "ixrd2l", - "clab-owner": "asad", - "clab-topo-file": "/var/asad/topoViewer/rawTopoFile/topo-clab-demo.yaml", - "containerlab": "demo", - "topoViewer-role": "spine" - }, - "port-bindings": [ - ] - }, - "topoviewer": { - "index": "6", - "shortname": "topoviewer", - "longname": "clab-demo-topoviewer", - "fqdn": "topoviewer.demo.io", - "group": "", - "labdir": "/var/asad/topoViewer/rawTopoFile/clab-demo/topoviewer", - "kind": "linux", - "image": "ghcr.io/asadarafat/topoviewer:nightly-24.10.26b", - "mgmt-net": "", - "mgmt-intf": "", - "mgmt-ipv4-address": "172.20.20.9", - "mgmt-ipv4-prefix-length": 24, - "mgmt-ipv6-address": "3fff:172:20:20::9", - "mgmt-ipv6-prefix-length": 64, - "mac-address": "", - "labels": { - "clab-mgmt-net-bridge": "br-0e52e9f1330e", - "clab-node-group": "", - "clab-node-kind": "linux", - "clab-node-lab-dir": "/var/asad/topoViewer/rawTopoFile/clab-demo/topoviewer", - "clab-node-name": "topoviewer", - "clab-node-type": "", - "clab-owner": "asad", - "clab-topo-file": "/var/asad/topoViewer/rawTopoFile/topo-clab-demo.yaml", - "containerlab": "demo", - "topoviewer-role": "controller" - }, - "port-bindings": [ - { - "host-ip": "", - "host-port": 0, - "port": 22, - "protocol": "tcp" - }, - { - "host-ip": "", - "host-port": 0, - "port": 514, - "protocol": "tcp" - }, - { - "host-ip": "", - "host-port": 0, - "port": 8080, - "protocol": "tcp" - }, - { - "host-ip": "0.0.0.0", - "host-port": 8088, - "port": 8088, - "protocol": "tcp" - }, - { - "host-ip": "::", - "host-port": 8088, - "port": 8088, - "protocol": "tcp" - } - ] - } - }, - "links": [ - { - "a": { - "node": "Spine-01", - "interface": "e1-1", - "mac": "aa:c1:ab:8a:04:a4", - "peer": "z" - }, - "z": { - "node": "Leaf-01", - "interface": "e1-1", - "mac": "aa:c1:ab:6c:a6:df", - "peer": "a" - } - }, - { - "a": { - "node": "Spine-01", - "interface": "e1-2", - "mac": "aa:c1:ab:48:df:31", - "peer": "z" - }, - "z": { - "node": "Leaf-02", - "interface": "e1-1", - "mac": "aa:c1:ab:5a:54:21", - "peer": "a" - } - }, - { - "a": { - "node": "Spine-01", - "interface": "e1-3", - "mac": "aa:c1:ab:5a:b7:ea", - "peer": "z" - }, - "z": { - "node": "Leaf-03", - "interface": "e1-3", - "mac": "aa:c1:ab:eb:3b:47", - "peer": "a" - } - }, - { - "a": { - "node": "Spine-01", - "interface": "e1-4", - "mac": "aa:c1:ab:04:97:ae", - "peer": "z" - }, - "z": { - "node": "Leaf-04", - "interface": "e1-3", - "mac": "aa:c1:ab:ac:c3:dc", - "peer": "a" - } - }, - { - "a": { - "node": "Spine-02", - "interface": "e1-1", - "mac": "aa:c1:ab:72:7e:6b", - "peer": "z" - }, - "z": { - "node": "Leaf-01", - "interface": "e1-2", - "mac": "aa:c1:ab:cc:ae:53", - "peer": "a" - } - }, - { - "a": { - "node": "Spine-02", - "interface": "e1-2", - "mac": "aa:c1:ab:b0:61:6a", - "peer": "z" - }, - "z": { - "node": "Leaf-02", - "interface": "e1-2", - "mac": "aa:c1:ab:04:64:7e", - "peer": "a" - } - }, - { - "a": { - "node": "Spine-02", - "interface": "e1-3", - "mac": "aa:c1:ab:ec:02:dd", - "peer": "z" - }, - "z": { - "node": "Leaf-03", - "interface": "e1-4", - "mac": "aa:c1:ab:82:f1:e1", - "peer": "a" - } - }, - { - "a": { - "node": "Spine-02", - "interface": "e1-4", - "mac": "aa:c1:ab:c4:a9:aa", - "peer": "z" - }, - "z": { - "node": "Leaf-04", - "interface": "e1-4", - "mac": "aa:c1:ab:f4:c7:0c", - "peer": "a" - } - } - ] -} diff --git a/rawTopoFile/topoviewer/pumba_linux_amd64 b/rawTopoFile/topoviewer/pumba_linux_amd64 deleted file mode 100755 index e39eeec1e..000000000 Binary files a/rawTopoFile/topoviewer/pumba_linux_amd64 and /dev/null differ diff --git a/rawTopoFile/topoviewer/topoviewer b/rawTopoFile/topoviewer/topoviewer deleted file mode 100755 index 4b6c32c97..000000000 --- a/rawTopoFile/topoviewer/topoviewer +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:eac773fb054b9836fb95741b7701e9e13602c2aa8db3d6a74332b7892cdd2296 -size 77787288 diff --git a/tools/clab-client-windows/ClabCapture.app.zip b/tools/clab-client-windows/ClabCapture.app.zip index 0a682b8fa..dfafebd68 100755 Binary files a/tools/clab-client-windows/ClabCapture.app.zip and b/tools/clab-client-windows/ClabCapture.app.zip differ diff --git a/tools/clab-client-windows/ClabPumbaDelay.app.zip b/tools/clab-client-windows/ClabPumbaDelay.app.zip deleted file mode 100755 index 774de39c3..000000000 Binary files a/tools/clab-client-windows/ClabPumbaDelay.app.zip and /dev/null differ diff --git a/tools/dist.sh b/tools/dist.sh index c3010d286..2155aca6c 100755 --- a/tools/dist.sh +++ b/tools/dist.sh @@ -23,18 +23,15 @@ echo "Copy TopoViewer Binary..." mv topoviewer dist/topoviewer cp -r config dist -echo "Create clab client Package..." +echo "Create clab client windows package..." rm -f tools/clab-client-windows/ClabCapture.app.zip -# rm -f tools/clab-client-windows/ClabPumbaDelay.app.zip +rm -f tools/clab-client-windows/ClabPumbaDelay.app.zip zip tools/clab-client-windows/ClabCapture.app.zip tools/clab-client-windows/clabcapture.bat tools/clab-client-windows/clab-capture.reg tools/clab-client-windows/clab-capture-readme.MD # zip tools/clab-client-windows/ClabPumbaDelay.app.zip tools/clab-client-windows/clabpumba.bat tools/clab-client-windows/clab-pumba.reg tools/clab-client-windows/clab-pumba-readme.MD -echo "Copy clab client..." -cp -r tools/clab-client-mac dist/clab-client-mac - - -echo "Clab export template..." -cp rawTopoFile/clab-topo-export-template-example/clab-topo-new-version-cytoscape.tmpl dist/clab-topoviewer.tmpl +echo "Copy clab client packages..." +mkdir dist/clab-client-mac +cp -r tools/clab-client-mac/ClabCapture.app.zip dist/clab-client-mac/ClabCapture.app.zip mkdir dist/clab-client-windows chmod 775 tools/clab-client-windows/* @@ -42,6 +39,8 @@ cp tools/clab-client-windows/ClabCapture.app.zip dist/clab-client-windows/ClabCa # cp tools/clab-client-windows/ClabPumbaDelay.app.zip dist/clab-client-windows/ClabPumbaDelay.app.zip chmod 775 dist/clab-client-windows/* +echo "Clab export template..." +cp rawTopoFile/clab-topo-export-template-example/clab-topo-new-version-cytoscape.tmpl dist/clab-topoviewer.tmpl rm -rR html-static/clab-client mkdir html-static/clab-client @@ -49,8 +48,8 @@ cp -r dist/clab-client-mac html-static/clab-client/ cp -r dist/clab-client-windows html-static/clab-client/ -echo "Copy Pumba_linux_amd64 Binary..." -cp -r tools/pumba_linux_amd64 dist/pumba_linux_amd64 +# echo "Copy Pumba_linux_amd64 Binary..." +# cp -r tools/pumba_linux_amd64 dist/pumba_linux_amd64 echo "Copy html folder and assets..." cp -rR html-static dist/html-static