<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Token Importance Visualization Analysis Tool</title>
    <link rel="stylesheet" href="{{ url_for('static', filename='css/styles.css') }}">
    <!-- Import Bootstrap 5 -->
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet">
    <!-- Import Font Awesome icon library -->
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css">
    <!-- Import Chart.js -->
    <script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
</head>
<body>
    <div class="container-fluid">
        <header class="py-3 text-center bg-primary text-white">
            <h1><i class="fas fa-brain me-2"></i>Token Importance Visualization Analysis Tool</h1>
            <p class="lead">Based on gradient attribution technology, intuitively displays the influence intensity of each token in text on model predictions</p>
        </header>

        <div class="container py-4">
            <!-- Analysis Panel -->
            <div class="row">
                <div class="col-lg-12">
                    <div class="card shadow-sm mb-4">
                        <div class="card-header bg-light">
                            <h3 class="card-title"><i class="fas fa-edit me-2"></i>Input Text for Analysis</h3>
                        </div>
                        <div class="card-body">
                            <form id="analysis-form">
                                <div class="mb-3">
                                    <label for="text-input" class="form-label">Input Text:</label>
                                    <textarea id="text-input" class="form-control" rows="3" 
                                    placeholder="Please enter the text content to be analyzed..."></textarea>
                                </div>
                                
                                <div class="row">
                                    <div class="col-md-6 mb-3">
                                        <label for="model-select" class="form-label">Select Model:</label>
                                        <select id="model-select" class="form-select">
                                            <!-- Model options will be loaded dynamically via JavaScript -->
                                            <option value="" disabled selected>Loading...</option>
                                        </select>
                                    </div>
                                    <div class="col-md-6 mb-3">
                                        <label for="label-input" class="form-label">Target Label (Optional):</label>
                                        <input type="number" id="label-input" class="form-control" 
                                        placeholder="Leave empty to use model predicted label">
                                    </div>
                                </div>
                                
                                <div class="d-grid gap-2 d-md-flex justify-content-md-end">
                                    <button type="button" id="analyze-button" class="btn btn-primary">
                                        <i class="fas fa-search me-1"></i>Analyze Text
                                    </button>
                                </div>
                            </form>
                        </div>
                    </div>
                </div>
            </div>
            
            <!-- Loading Indicator -->
            <div id="loading-indicator" class="text-center py-4 d-none">
                <div class="spinner-border text-primary" role="status">
                    <span class="visually-hidden">Loading...</span>
                </div>
                <p class="mt-2">Analyzing, please wait...</p>
            </div>
            
            <!-- Results Area (Initially Hidden) -->
            <div id="results-container" class="d-none">
                <!-- Visualization Results -->
                <div class="row">
                    <div class="col-lg-12">
                        <div class="card shadow-sm mb-4">
                            <div class="card-header bg-light d-flex justify-content-between align-items-center">
                                <h3 class="card-title mb-0"><i class="fas fa-highlighter me-2"></i>Text Importance Highlighting</h3>
                                <div class="btn-group">
                                    <button class="btn btn-sm btn-outline-secondary active" data-view="heatmap">Heatmap</button>
                                    <button class="btn btn-sm btn-outline-secondary" data-view="bicolor">Dual-color Contrast</button>
                                </div>
                            </div>
                            <div class="card-body">
                                <div class="mb-3">
                                    <div class="d-flex justify-content-between align-items-center mb-2">
                                        <p class="text-muted mb-0"><small>Higher token importance, darker color</small></p>
                                        <div class="legend d-flex align-items-center">
                                            <span class="legend-low me-1">Low</span>
                                            <div class="legend-gradient"></div>
                                            <span class="legend-high ms-1">High</span>
                                        </div>
                                    </div>
                                    <div id="highlighted-text" class="p-3 border rounded"></div>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
                
                <!-- Data Tables and Charts -->
                <div class="row">
                    <!-- Token Table -->
                    <div class="col-lg-6">
                        <div class="card shadow-sm mb-4">
                            <div class="card-header bg-light">
                                <h3 class="card-title"><i class="fas fa-table me-2"></i>Token Importance Table</h3>
                            </div>
                            <div class="card-body">
                                <div class="table-responsive" style="max-height: 400px; overflow-y: auto;">
                                    <table class="table table-hover">
                                        <thead class="table-light">
                                            <tr>
                                                <th scope="col">#</th>
                                                <th scope="col">Token</th>
                                                <th scope="col">Importance Score</th>
                                                <th scope="col">Normalized Score</th>
                                            </tr>
                                        </thead>
                                        <tbody id="token-table-body">
                                            <!-- Token data will be loaded dynamically via JavaScript -->
                                        </tbody>
                                    </table>
                                </div>
                            </div>
                        </div>
                    </div>
                    
                    <!-- Chart -->
                    <div class="col-lg-6">
                        <div class="card shadow-sm mb-4">
                            <div class="card-header bg-light">
                                <h3 class="card-title"><i class="fas fa-chart-bar me-2"></i>Token Importance Distribution</h3>
                            </div>
                            <div class="card-body">
                                <canvas id="importance-chart" height="300"></canvas>
                            </div>
                        </div>
                    </div>
                </div>
                
                <!-- Analysis Information -->
                <div class="row">
                    <div class="col-lg-12">
                        <div class="card shadow-sm mb-4">
                            <div class="card-header bg-light">
                                <h3 class="card-title"><i class="fas fa-info-circle me-2"></i>Analysis Information</h3>
                            </div>
                            <div class="card-body">
                                <div class="row">
                                    <div class="col-md-4">
                                        <p><strong>Model Used:</strong> <span id="result-model"></span></p>
                                    </div>
                                    <div class="col-md-4">
                                        <p><strong>Target Label:</strong> <span id="result-label"></span></p>
                                    </div>
                                    <div class="col-md-4">
                                        <p><strong>Analysis Time:</strong> <span id="result-time"></span></p>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
        
        <footer class="py-3 text-center text-muted bg-light mt-4">
            <p>Token Importance Visualization Tool based on Gradient Attribution &copy; 2025</p>
        </footer>
    </div>
    
    <!-- Bootstrap 5 JS and Popper -->
    <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.bundle.min.js"></script>
    <!-- Custom JavaScript -->
    <script src="{{ url_for('static', filename='js/script.js') }}"></script>
</body>
</html>
