{% from 'simple/macros.html' import icon %}
{% from '__common__/new_issue.html' import new_issue %}

{% extends "simple/base.html" %}

{%- macro th_sort(column_order, column_name) -%}
    {% if selected_engine_name %}
        {{ column_name }}
    {% elif column_order==sort_order %}
        {{ column_name }} {{ icon('arrow-dropdown') }}
    {% else %}
        <a href="{{ url_for('stats', sort=column_order) }}">{{ column_name }}</a>
    {% endif %}
{%- endmacro -%}

{% block head %} {% endblock %}
{% block content %}

<a href="{{ url_for('index') }}"><h1><span>searx</span></h1></a>

<h2>{{ _('Engine stats') }}{% if selected_engine_name %} - {{ selected_engine_name }}{% endif %}</h2>

{% if not engine_stats.get('time') %}
{{ _('There is currently no data available. ') }}
{% else %}
<table class="engine-stats">
    <tr>
        <th scope="col" class="engine-name">{{ th_sort('name', _("Engine name")) }}</th>
        <th scope="col" class="engine-score">{{ th_sort('score', _('Scores')) }}</th>
        <th scope="col" class="result-count">{{ th_sort('result_count', _('Result count')) }}</th>
        <th scope="col" class="response-time">{{ th_sort('time', _('Response time')) }}</th>
        <th scope="col" class="engine-reliability">{{ th_sort('reliability', _('Reliability')) }}</th>
    </tr>
    {% for engine_stat in engine_stats.get('time', []) %}
    <tr>
        <td class="engine-name"><a href="{{ url_for('stats', engine=engine_stat.name|e) }}">{{ engine_stat.name }}</a></td>
        <td class="engine-score">
            {% if engine_stat.score %}
            <span aria-labelledby="{{engine_stat.name}}_score" >{{ engine_stat.score|round(1) }}</span>
            <div class="engine-tooltip" role="tooltip" id="{{engine_stat.name}}_score">{{- "" -}}
                <p>{{ _('Scores per result') }}: {{ engine_stat.score_per_result | round(3) }}</p>
            </div>
            {% endif %}
        </td>
        <td class="engine-result-count">
            {%- if engine_stat.result_count -%}

            <div class="bar-chart-value">{{- engine_stat.result_count | int -}}</div>{{- "" -}}
        <div class="bar-chart-graph" aria-hidden="true">
          <div class="bar-chart-bar bar{{ (100 * engine_stat.result_count / engine_stats.max_result_count)|round }}"></div>{{- "" -}}
        </div>
            {%- endif -%}
        </td>
        <td class="response-time">
            {%- if engine_stat.total is not none -%}
            <div class="bar-chart-value">{{- engine_stat.total | round(1) -}}</div>{{- "" -}}
        <div class="bar-chart-graph" aria-labelledby="{{engine_stat.name}}_time" aria-hidden="true">
              {% if engine_stat.http is not none and engine_stats.max_time %}<div class="bar-chart-serie1 bar{{ (100 * engine_stat.http / engine_stats.max_time)|round }}"></div>{%- endif -%}
              {% if engine_stat.processing is not none and engine_stats.max_time %}<div class="bar-chart-serie2 bar{{ (100 * engine_stat.processing / engine_stats.max_time)|round }}"></div>{%- endif -%}
        </div>
            <div class="engine-tooltip" role="tooltip" id="{{engine_stat.name}}_time">{{- "" -}}
                <table>
                    <tr>
                        <th scope="col"></th>
                        <th scope="col">{{ _('Total') }}</th>
                        <th scope="col">{{ _('HTTP') }}</th>
                        <th scope="col">{{ _('Processing') }}</th>
                    </tr>
                    <tr>
                        <th scope="col">{{ _('Median') }}</th>
                        <td>{{ engine_stat.total }}</td>
                        <td>{{ engine_stat.http or ''}}</td>
                        <td>{{ engine_stat.processing }}</td>
                    </tr>
                    <tr>
                        <th scope="col">{{ _('P80') }}</th>
                        <td>{{ engine_stat.total_p80 }}</td>
                        <td>{{ engine_stat.http_p80 or '' }}</td>
                        <td>{{ engine_stat.processing_p80 }}</td>
                    </tr>
                    <tr>
                        <th scope="col">{{ _('P95') }}</th>
                        <td>{{ engine_stat.total_p95 }}</td>
                        <td>{{ engine_stat.http_p95 or '' }}</td>
                        <td>{{ engine_stat.processing_p95 }}</td>
                    </tr>
                </table>
            </div>
            {%- endif -%}
        </td>
        <td class="engine-reliability"> {{ engine_reliabilities.get(engine_stat.name, {}).get('reliablity') }}</td>
    </tr>
    {% endfor %}
</table>
{% endif %}

<div>
    {% if selected_engine_name %}
        {% for secondary in [False, True] %}
            {% set ns = namespace(first=true) %}
            {% for error in engine_reliabilities[selected_engine_name].errors %}
                {% if secondary == error.secondary %}
                    {% if ns.first %}
                        {% set ns.first = false %}
                        <h3>{% if secondary %}{{ _('Warnings') }}{% else %}{{ _('Errors and exceptions') }}{% endif %}</h3>
                    {% endif %}
                    <table class="engine-error">
                        <tbody>
                            <tr>
                                {%- if error.exception_classname -%}
                                    <th scope="row" class="engine-error-type">{{ _('Exception') }}</th><td>{{ error.exception_classname }}</td>
                                {%- elif error.log_message -%}
                                    <th scope="row" class="engine-error-type">{{ _('Message') }}</th><td>{{ error.log_message }}</td>
                                {%- endif -%}
                                <th scope="row" class="engine-error-type">{{ _('Percentage') }}</th><td class="engine-error-type">{{ error.percentage }}</td>
                            </tr>
                            {% if error.log_parameters and error.log_parameters != (None, None, None) %}<tr><th scope="row">{{ _('Parameter') }}</th>{{- '' -}}
                                <td colspan="3">
                                    {%- for param in error.log_parameters -%}
                                        <span class="log_parameters">{{ param }}</span>
                                    {%- endfor -%}
                                </td>
                            </tr>
                            {% endif %}
                            <tr><th scope="row">{{ _('Filename') }}</th><td colspan="3">{{ error.filename }}:{{ error.line_no }}</td></tr>
                            <tr><th scope="row">{{ _('Function') }}</th><td colspan="3">{{ error.function }}</td></tr>
                            <tr><th scope="row">{{ _('Code') }}</th><td colspan="3">{{ error.code }}</td></tr>
                        </tbody>
                    </table>
                {% endif %}
            {% endfor %}
        {% endfor %}
        {% if engine_reliabilities[selected_engine_name].checker %}
            <h3>{{ _('Checker') }}</h3>
            <table>
                <tr>
                    <th scope="col" class="failed-test">{{ _('Failed test') }}</th>
                    <th scope="col">{{ _('Comment(s)') }}</th>
                </tr>
                {% for test_name, results in engine_reliabilities[selected_engine_name].checker.items() %}
                <tr>
                    <td>{{ test_name }}</td>
                    <td>
                        {% for r in results %}<p>{{ r }}</p>{% endfor %}
                    </td>
                </tr>
                {% endfor %}
            </table>
        {% endif %}
        {{ new_issue(brand.NEW_ISSUE_URL, selected_engine_name, engine_reliabilities[selected_engine_name]) }}
    {% endif %}
</div>

{% endblock %}