Spaces:
Paused
Paused
| <html lang="en"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <title>Flare Admin UI</title> | |
| <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css"> | |
| <link rel="stylesheet" href="style.css"> | |
| </head> | |
| <body class="p-4"> | |
| <div class="container"> | |
| <h1 class="mb-4 text-center">🔥 Flare Admin UI</h1> | |
| <!-- Login Panel --> | |
| <div id="login-panel" class="card mb-3"> | |
| <div class="card-header">Login</div> | |
| <div class="card-body"> | |
| <input type="text" id="login-username" class="form-control mb-2" placeholder="Username"> | |
| <input type="password" id="login-password" class="form-control mb-2" placeholder="Password"> | |
| <button class="btn btn-primary btn-block" onclick="login()">Login</button> | |
| <div id="login-result" class="mt-2 text-danger"></div> | |
| </div> | |
| </div> | |
| <!-- Main Tabs Panel (hidden until login) --> | |
| <div id="main-tabs" class="d-none"> | |
| <ul class="nav nav-tabs mb-3" role="tablist"> | |
| <li class="nav-item"> | |
| <a class="nav-link active" data-toggle="tab" href="#config" role="tab">Config</a> | |
| </li> | |
| <li class="nav-item"> | |
| <a class="nav-link" data-toggle="tab" href="#projects" role="tab">Projects</a> | |
| </li> | |
| <li class="nav-item"> | |
| <a class="nav-link" data-toggle="tab" href="#spark" role="tab">Spark</a> | |
| </li> | |
| <li class="nav-item"> | |
| <a class="nav-link" data-toggle="tab" href="#test" role="tab">Test</a> | |
| </li> | |
| <li class="nav-item"> | |
| <a class="nav-link" data-toggle="tab" href="#admin" role="tab">Admin Tools</a> | |
| </li> | |
| <li class="nav-item"> | |
| <a class="nav-link" data-toggle="tab" href="#api" role="tab">API Definitions</a> | |
| </li> | |
| </ul> | |
| <div class="tab-content"> | |
| <!-- Config Tab --> | |
| <div class="tab-pane fade show active" id="config" role="tabpanel"> | |
| <form> | |
| <div class="form-group"> | |
| <label for="work-mode">Work Mode</label> | |
| <select id="work-mode" class="form-control" onchange="toggleCloudToken()"> | |
| <option value="hfcloud">hfcloud</option> | |
| <option value="cloud">cloud</option> | |
| <option value="on-premise">on-premise</option> | |
| </select> | |
| </div> | |
| <div class="form-group"> | |
| <label for="cloud-token">Cloud Token</label> | |
| <input type="text" id="cloud-token" class="form-control"> | |
| </div> | |
| <button type="button" class="btn btn-info mb-2" onclick="getConfig()">Load Config</button> | |
| <button type="button" class="btn btn-success mb-2" onclick="updateConfig()">Update Config</button> | |
| <div id="config-result" class="mt-2"></div> | |
| </form> | |
| </div> | |
| <!-- Projects Tab --> | |
| <div class="tab-pane fade" id="projects" role="tabpanel"> | |
| <button class="btn btn-info mb-2" onclick="listProjects()">Refresh Project List</button> | |
| <div class="form-group"> | |
| <label for="project-select">Select Project</label> | |
| <select id="project-select" class="form-control" onchange="loadProjectDetails()"> | |
| <option value="">-- Select a project --</option> | |
| </select> | |
| </div> | |
| <div id="project-details" class="mt-3 d-none"> | |
| <h5>Project Details</h5> | |
| <div id="project-info"></div> | |
| <button class="btn btn-success mt-2" onclick="saveProject()">Save Changes</button> | |
| <button class="btn btn-warning mt-2" onclick="publishProject()">Publish Version</button> | |
| </div> | |
| <div id="project-result" class="mt-2"></div> | |
| </div> | |
| <!-- Spark Tab --> | |
| <div class="tab-pane fade" id="spark" role="tabpanel"> | |
| <button class="btn btn-info mb-2" onclick="sparkProjectList()">Get Spark Project List</button> | |
| <div id="spark-table" class="table-responsive"> | |
| <table class="table table-bordered"> | |
| <thead> | |
| <tr> | |
| <th>Project</th> | |
| <th>Version</th> | |
| <th>Enabled</th> | |
| <th>Status</th> | |
| <th>Last Accessed</th> | |
| </tr> | |
| </thead> | |
| <tbody id="spark-body"> | |
| <!-- Spark rows here --> | |
| </tbody> | |
| </table> | |
| </div> | |
| <div id="spark-result" class="mt-2"></div> | |
| </div> | |
| <!-- Test Tab --> | |
| <div class="tab-pane fade" id="test" role="tabpanel"> | |
| <button class="btn btn-warning mb-2" onclick="runTests()">Run All Tests</button> | |
| <div id="test-result" class="mt-2"></div> | |
| </div> | |
| <!-- Admin Tools Tab --> | |
| <div class="tab-pane fade" id="admin" role="tabpanel"> | |
| <button class="btn btn-danger mb-2" onclick="seedTestData()">Seed Test Data</button> | |
| <button class="btn btn-danger mb-2" onclick="clearAllProjects()">Clear All Projects</button> | |
| <div id="admin-result" class="mt-2"></div> | |
| </div> | |
| <!-- API Definitions Tab --> | |
| <div class="tab-pane fade" id="api" role="tabpanel"> | |
| <button class="btn btn-info mb-2" onclick="listApis()">Refresh API List</button> | |
| <button class="btn btn-success mb-2" onclick="addApi()">+ Add API</button> | |
| <div id="api-table" class="table-responsive"> | |
| <table class="table table-bordered"> | |
| <thead> | |
| <tr> | |
| <th>API Name</th> | |
| <th>URL</th> | |
| <th>Method</th> | |
| <th>Actions</th> | |
| </tr> | |
| </thead> | |
| <tbody id="api-body"> | |
| <!-- API rows here --> | |
| </tbody> | |
| </table> | |
| </div> | |
| <div id="api-result" class="mt-2"></div> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- Intent Edit Modal --> | |
| <div class="modal fade" id="intentModal" tabindex="-1" role="dialog" aria-labelledby="intentModalLabel" aria-hidden="true"> | |
| <div class="modal-dialog modal-lg" role="document"> | |
| <div class="modal-content"> | |
| <div class="modal-header"> | |
| <h5 class="modal-title" id="intentModalLabel">Edit Intent</h5> | |
| <button type="button" class="close" data-dismiss="modal" aria-label="Close"> | |
| <span aria-hidden="true">×</span> | |
| </button> | |
| </div> | |
| <div class="modal-body"> | |
| <input type="hidden" id="intent-project-name"> | |
| <input type="hidden" id="intent-name"> | |
| <div class="form-group"> | |
| <label for="intent-action">Action (API)</label> | |
| <input type="text" id="intent-action" class="form-control"> | |
| </div> | |
| <div class="form-group"> | |
| <label for="intent-fallback">Fallback Error Message</label> | |
| <input type="text" id="intent-fallback" class="form-control"> | |
| </div> | |
| <div class="form-group"> | |
| <label for="intent-prompt">Humanization Prompt</label> | |
| <textarea id="intent-prompt" class="form-control"></textarea> | |
| </div> | |
| <div class="form-group"> | |
| <label for="intent-examples">Examples (comma-separated)</label> | |
| <input type="text" id="intent-examples" class="form-control"> | |
| </div> | |
| <div class="form-group"> | |
| <label for="intent-parameters">Parameters (JSON array)</label> | |
| <div class="form-group"> | |
| <label>Parameters</label> | |
| <button class="btn btn-sm btn-success ml-2" onclick="addParameterRow()">+ Add Parameter</button> | |
| <table class="table table-sm mt-2"> | |
| <thead> | |
| <tr> | |
| <th>Name</th> | |
| <th>Type</th> | |
| <th>Regex</th> | |
| <th>Validation Message</th> | |
| <th>Actions</th> | |
| </tr> | |
| </thead> | |
| <tbody id="parameter-body"> | |
| <!-- parameter rows --> | |
| </tbody> | |
| </table> | |
| </div> | |
| </div> | |
| </div> | |
| <div class="modal-footer"> | |
| <button type="button" class="btn btn-secondary" data-dismiss="modal">Close</button> | |
| <button type="button" class="btn btn-primary" onclick="saveIntent()">Save Changes</button> | |
| </div> | |
| </div> | |
| </div> | |
| </div> | |
| <!-- JS Files --> | |
| <script src="js/common.js"></script> | |
| <script src="js/auth.js"></script> | |
| <script src="js/config.js"></script> | |
| <script src="js/project.js"></script> | |
| <script src="js/spark.js"></script> | |
| <script src="js/test.js"></script> | |
| <script src="js/admin.js"></script> | |
| <script src="js/api.js"></script> | |
| <script src="https://code.jquery.com/jquery-3.5.1.slim.min.js"></script> | |
| <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js"></script> | |
| </body> | |
| </html> | |