2024-02-05 22:50:40 +00:00
|
|
|
"""
|
|
|
|
project: lollms_webui
|
|
|
|
file: shell_execution_engine.py
|
|
|
|
author: ParisNeo
|
|
|
|
description:
|
|
|
|
This is a utility for executing python code
|
|
|
|
|
|
|
|
"""
|
|
|
|
from lollms_webui import LOLLMSWebUI
|
|
|
|
from ascii_colors import get_trace_exception, trace_exception
|
|
|
|
import time
|
|
|
|
import subprocess
|
|
|
|
import json
|
2024-02-28 00:06:59 +00:00
|
|
|
from lollms.client_session import Client
|
|
|
|
|
2024-02-05 22:50:40 +00:00
|
|
|
|
|
|
|
lollmsElfServer:LOLLMSWebUI = LOLLMSWebUI.get_instance()
|
|
|
|
|
|
|
|
def build_mermaid_output(code, ifram_name="unnamed"):
|
|
|
|
"""
|
|
|
|
This function creates an HTML5 iframe with the given HTML content and iframe name.
|
|
|
|
|
|
|
|
Args:
|
2024-02-08 22:04:27 +00:00
|
|
|
code (str): The mermaid code
|
2024-02-05 22:50:40 +00:00
|
|
|
ifram_name (str, optional): The name of the iframe. Defaults to "unnamed".
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
str: The HTML string for the iframe.
|
|
|
|
"""
|
|
|
|
# Start the timer.
|
|
|
|
start_time = time.time()
|
|
|
|
rendered = "\n".join([
|
|
|
|
'<div style="width: 100%; margin: 0 auto;">',
|
2024-02-08 22:28:50 +00:00
|
|
|
f'<iframe id="{ifram_name}" style="width: 100%" srcdoc="',
|
2024-02-05 22:50:40 +00:00
|
|
|
'<style>',
|
2024-02-08 22:28:50 +00:00
|
|
|
'iframe {',
|
|
|
|
'width: 100%;',
|
|
|
|
'height: 100%;',
|
|
|
|
'border: none;',
|
|
|
|
'}',
|
2024-02-05 22:50:40 +00:00
|
|
|
'.mermaid {',
|
|
|
|
'background-color: transparent;',
|
|
|
|
'padding: 20px;',
|
|
|
|
'border-radius: 10px;',
|
|
|
|
'display: flex;',
|
|
|
|
'justify-content: center;',
|
|
|
|
'align-items: center;',
|
|
|
|
'height: 100%;',
|
|
|
|
'}',
|
|
|
|
'</style>',
|
|
|
|
'<div class=\'mermaid\'>',
|
|
|
|
"\n".join([c for c in code.split("\n") if c.strip()!=""]),
|
|
|
|
'</div>',
|
|
|
|
'<script src=\'https://cdn.jsdelivr.net/npm/mermaid/dist/mermaid.min.js\'></script>',
|
|
|
|
'<script>',
|
|
|
|
'// Initialize the mermaid library and render our diagram',
|
|
|
|
'mermaid.initialize({ startOnLoad: true });',
|
2024-02-08 22:04:27 +00:00
|
|
|
'// Function to save SVG content to a file',
|
|
|
|
'function saveSVG() {',
|
|
|
|
'var svg = document.querySelector(".mermaid > svg");',
|
|
|
|
'var serializer = new XMLSerializer();',
|
|
|
|
'var source = serializer.serializeToString(svg);',
|
|
|
|
'var blob = new Blob([source], {type: "image/svg+xml;charset=utf-8"});',
|
|
|
|
'var url = URL.createObjectURL(blob);',
|
|
|
|
'var a = document.createElement("a");',
|
|
|
|
'a.href = url;',
|
|
|
|
'a.download = "diagram.svg";',
|
|
|
|
'a.click();',
|
2024-02-08 22:28:50 +00:00
|
|
|
'}',
|
2024-02-05 22:50:40 +00:00
|
|
|
'</script>',
|
|
|
|
'<div style=\'text-align: center;\'>',
|
|
|
|
'</div>',
|
2024-02-08 22:28:50 +00:00
|
|
|
'<button onclick="saveSVG()">Save SVG</button>',
|
2024-02-05 22:50:40 +00:00
|
|
|
'" style="width: 100%; height: 600px; border: none;"></iframe>',
|
|
|
|
'</div>'
|
|
|
|
]
|
|
|
|
)
|
|
|
|
execution_time = time.time() - start_time
|
|
|
|
return {"output": rendered, "execution_time": execution_time}
|
|
|
|
|
2024-02-08 22:04:27 +00:00
|
|
|
|
2024-02-08 22:28:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2024-02-28 21:56:34 +00:00
|
|
|
def execute_mermaid(code):
|
2024-02-05 22:50:40 +00:00
|
|
|
|
|
|
|
return build_mermaid_output(code)
|