76 lines
2.5 KiB
HTML
76 lines
2.5 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
<title>SugarScale SQL Agent</title>
|
|
<link rel="stylesheet" href="/static/styles.css" />
|
|
</head>
|
|
<body>
|
|
<header>
|
|
<h1>SugarScale SQL Agent</h1>
|
|
<p>Ask natural-language questions and optionally execute the generated SQL.</p>
|
|
</header>
|
|
|
|
<main>
|
|
<section class="panel">
|
|
<form id="query-form">
|
|
<label for="question">Question</label>
|
|
<textarea id="question" name="question" rows="3" placeholder="e.g., How many loads were completed yesterday?" required></textarea>
|
|
|
|
<label for="tables">Table hints (comma-separated)</label>
|
|
<input id="tables" name="tables" type="text" placeholder="dbo.SugarLoadData" />
|
|
|
|
<div class="options">
|
|
<label>
|
|
<input type="checkbox" id="execute" name="execute" /> Execute SQL
|
|
</label>
|
|
<label for="max-rows">Max rows</label>
|
|
<input id="max-rows" name="max_rows" type="number" min="1" value="500" />
|
|
</div>
|
|
|
|
<button type="submit">Run</button>
|
|
</form>
|
|
</section>
|
|
|
|
<section class="panel" id="results" hidden>
|
|
<h2>Results</h2>
|
|
<div class="warning" id="warning" hidden></div>
|
|
<div id="summary"></div>
|
|
<details>
|
|
<summary>Generated SQL</summary>
|
|
<pre><code id="generated-sql"></code></pre>
|
|
</details>
|
|
<details id="sanitized-block" hidden>
|
|
<summary>Sanitized SQL (executed)</summary>
|
|
<pre><code id="sanitized-sql"></code></pre>
|
|
</details>
|
|
<div id="row-count"></div>
|
|
<table id="result-table" hidden>
|
|
<thead id="result-thead"></thead>
|
|
<tbody id="result-tbody"></tbody>
|
|
</table>
|
|
<div id="feedback-panel" hidden>
|
|
<h3>Was this answer helpful?</h3>
|
|
<div class="feedback-actions">
|
|
<button type="button" id="feedback-correct">Mark Correct</button>
|
|
<button type="button" id="feedback-incorrect" class="secondary">Needs Work</button>
|
|
</div>
|
|
<p id="feedback-status" hidden></p>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="panel error" id="error" hidden>
|
|
<h2>Error</h2>
|
|
<pre id="error-message"></pre>
|
|
</section>
|
|
</main>
|
|
|
|
<footer>
|
|
<small>Powered by the SugarScale SQL agent.</small>
|
|
</footer>
|
|
|
|
<script src="/static/app.js" type="module"></script>
|
|
</body>
|
|
</html>
|