mirror of
https://github.com/searxng/searxng.git
synced 2024-11-26 12:51:02 +00:00
Merge pull request #894 from dalf/simple-aria-1
[enh] simple: basic ARIA fixes
This commit is contained in:
commit
b692035120
10 changed files with 62 additions and 64 deletions
|
@ -1,4 +1,4 @@
|
||||||
<select class="language" id="language" name="language" tabindex="1">{{- '' -}}
|
<select class="language" id="language" name="language" aria-label="{{ _('Search language') }}">{{- '' -}}
|
||||||
<option value="all" {% if current_language == 'all' %}selected="selected"{% endif %}>{{ _('Default language') }}</option>
|
<option value="all" {% if current_language == 'all' %}selected="selected"{% endif %}>{{ _('Default language') }}</option>
|
||||||
{%- for lang_id,lang_name,country_name,english_name in language_codes | sort(attribute=1) -%}
|
{%- for lang_id,lang_name,country_name,english_name in language_codes | sort(attribute=1) -%}
|
||||||
<option value="{{ lang_id }}" {% if lang_id == current_language %}selected="selected"{% endif %}>
|
<option value="{{ lang_id }}" {% if lang_id == current_language %}selected="selected"{% endif %}>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<select name="safesearch" id="safesearch" class="safesearch" tabindex="3">
|
<select name="safesearch" id="safesearch" class="safesearch" aria-label="{{ _('SafeSearch') }}">
|
||||||
<option value="2" {% if safesearch == '2' %}selected="selected"{% endif %}>{{ _("SafeSearch") + ": " + _('Strict') }}</option>
|
<option value="2" {% if safesearch == '2' %}selected="selected"{% endif %} aria-label="{{ _('Strict') }}">{{ _("SafeSearch") + ": " + _('Strict') }}</option>
|
||||||
<option value="1" {% if safesearch == '1' %}selected="selected"{% endif %}>{{ _("SafeSearch") + ": " + _('Moderate') }}</option>
|
<option value="1" {% if safesearch == '1' %}selected="selected"{% endif %} aria-label="{{ _('Moderate') }}">{{ _("SafeSearch") + ": " + _('Moderate') }}</option>
|
||||||
<option value="0" {% if safesearch == '0' %}selected="selected"{% endif %}>{{ _("SafeSearch") + ": " + _('None') }}</option>
|
<option value="0" {% if safesearch == '0' %}selected="selected"{% endif %} aria-label="{{ _('None') }}">{{ _("SafeSearch") + ": " + _('None') }}</option>
|
||||||
</select>
|
</select>
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<select name="time_range" id="time_range" class="time_range" tabindex="2">{{- '' -}}
|
<select name="time_range" id="time_range" class="time_range" aria-label="{{ _('Time range') }}">{{- '' -}}
|
||||||
<option id="time-range-anytime" value="" {{ "selected" if time_range=="" or not time_range else ""}}>
|
<option id="time-range-anytime" value="" {{ "selected" if time_range=="" or not time_range else ""}}>
|
||||||
{{- _('Anytime') -}}
|
{{- _('Anytime') -}}
|
||||||
</option>{{- '' -}}
|
</option>{{- '' -}}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<aside class="infobox">
|
<aside class="infobox" aria-label="{{ infobox.infobox }}">
|
||||||
<h2><bdi>{{ infobox.infobox }}</bdi></h2>
|
<h2><bdi>{{ infobox.infobox }}</bdi></h2>
|
||||||
{% if infobox.img_src %}<img src="{{ image_proxify(infobox.img_src) }}" title="{{ infobox.infobox|striptags }}" alt="{{ infobox.infobox|striptags }}">{%- endif -%}
|
{% if infobox.img_src %}<img src="{{ image_proxify(infobox.img_src) }}" title="{{ infobox.infobox|striptags }}" alt="{{ infobox.infobox|striptags }}">{%- endif -%}
|
||||||
<p><bdi>{{ infobox.content | safe }}</bdi></p>
|
<p><bdi>{{ infobox.content | safe }}</bdi></p>
|
||||||
|
|
|
@ -56,11 +56,9 @@
|
||||||
{%- endmacro -%}
|
{%- endmacro -%}
|
||||||
|
|
||||||
{%- macro tab_header(name, id, label) -%}
|
{%- macro tab_header(name, id, label) -%}
|
||||||
<input type="radio" name="{{ name }}" id="tab_{{ id }}"/>
|
<input type="radio" name="{{ name }}" id="tab-{{ id }}"/>
|
||||||
<label for="tab_{{ id }}" role="tab"
|
<label id="tab-label-{{ label }}" for="tab-{{ id }}" role="tab" aria-controls="tab-content-{{ id }}">{{ label }}</label>
|
||||||
aria-controls="panel{{ id }}">{{ label }}</label>
|
<section id="tab-content-{{ id }}" role="tabpanel" aria-labelledby="tab-label-{{ label }}" aria-hidden="false">
|
||||||
<section id="tab-content{{ id }}" role="tabpanel"
|
|
||||||
aria-labelledby="{{ label }}" aria-hidden="false">
|
|
||||||
{%- endmacro -%}
|
{%- endmacro -%}
|
||||||
|
|
||||||
{%- macro tab_footer() -%}
|
{%- macro tab_footer() -%}
|
||||||
|
|
|
@ -112,23 +112,23 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if 'language' not in locked_preferences %}
|
{% if 'language' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('Search language') }}</legend>
|
<legend id="pref_language">{{ _('Search language') }}</legend>
|
||||||
<p class="value">{{- '' -}}
|
<p class="value">{{- '' -}}
|
||||||
<select name='language'>{{- '' -}}
|
<select name='language' aria-labelledby="pref_language" aria-describedby="desc_language">{{- '' -}}
|
||||||
<option value="all" {% if current_language == 'all' %}selected="selected"{% endif %}>{{ _('Default language') }}</option>
|
<option value="all" {% if current_language == 'all' %}selected="selected"{% endif %}>{{ _('Default language') }}</option>
|
||||||
{%- for lang_id,lang_name,country_name,english_name in language_codes | sort(attribute=1) -%}
|
{%- for lang_id,lang_name,country_name,english_name in language_codes | sort(attribute=1) -%}
|
||||||
<option value="{{ lang_id }}" {% if lang_id == current_language %}selected="selected"{% endif %}>{{ lang_name }} {% if country_name %}({{ country_name }}) {% endif %}- {{ lang_id }}</option>
|
<option value="{{ lang_id }}" {% if lang_id == current_language %}selected="selected"{% endif %}>{{ lang_name }} {% if country_name %}({{ country_name }}) {% endif %}- {{ lang_id }}</option>
|
||||||
{%- endfor -%}
|
{%- endfor -%}
|
||||||
</select>{{- '' -}}
|
</select>{{- '' -}}
|
||||||
</p>
|
</p>
|
||||||
<div class="description">{{ _('What language do you prefer for search?') }}</div>
|
<div class="description" id="desc_language">{{ _('What language do you prefer for search?') }}</div>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if 'autocomplete' not in locked_preferences %}
|
{% if 'autocomplete' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('Autocomplete') }}</legend>
|
<legend id="pref_autocomplete">{{ _('Autocomplete') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select name="autocomplete">
|
<select name="autocomplete" aria-labelledby="pref_autocomplete">
|
||||||
<option value=""> - </option>
|
<option value=""> - </option>
|
||||||
{%- for backend in autocomplete_backends -%}
|
{%- for backend in autocomplete_backends -%}
|
||||||
<option value="{{ backend }}" {% if backend == autocomplete %}selected="selected"{% endif %}>{{ backend }}</option>
|
<option value="{{ backend }}" {% if backend == autocomplete %}selected="selected"{% endif %}>{{ backend }}</option>
|
||||||
|
@ -140,9 +140,9 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if 'safesearch' not in locked_preferences %}
|
{% if 'safesearch' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('SafeSearch') }}</legend>
|
<legend id="pref_safesearch">{{ _('SafeSearch') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select name='safesearch'>
|
<select name='safesearch' aria-labelledby="pref_safesearch">
|
||||||
<option value="2" {% if safesearch == '2' %}selected="selected"{% endif %}>{{ _('Strict') }}</option>
|
<option value="2" {% if safesearch == '2' %}selected="selected"{% endif %}>{{ _('Strict') }}</option>
|
||||||
<option value="1" {% if safesearch == '1' %}selected="selected"{% endif %}>{{ _('Moderate') }}</option>
|
<option value="1" {% if safesearch == '1' %}selected="selected"{% endif %}>{{ _('Moderate') }}</option>
|
||||||
<option value="0" {% if safesearch == '0' %}selected="selected"{% endif %}>{{ _('None') }}</option>
|
<option value="0" {% if safesearch == '0' %}selected="selected"{% endif %}>{{ _('None') }}</option>
|
||||||
|
@ -154,9 +154,9 @@
|
||||||
{{ plugin_preferences('general') }}
|
{{ plugin_preferences('general') }}
|
||||||
{% if 'doi_resolver' not in locked_preferences %}
|
{% if 'doi_resolver' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('Open Access DOI resolver') }}</legend>
|
<legend id="pref_doi_resolver">{{ _('Open Access DOI resolver') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select id='doi_resolver' name='doi_resolver'>
|
<select id='doi_resolver' name='doi_resolver' aria-labelledby="pref_doi_resolver">
|
||||||
{%- for doi_resolver_name,doi_resolver_url in doi_resolvers.items() -%}
|
{%- for doi_resolver_name,doi_resolver_url in doi_resolvers.items() -%}
|
||||||
<option value="{{ doi_resolver_name }}" {% if doi_resolver_url == current_doi_resolver %}selected="selected"{% endif %}>
|
<option value="{{ doi_resolver_name }}" {% if doi_resolver_url == current_doi_resolver %}selected="selected"{% endif %}>
|
||||||
{{- doi_resolver_name }} - {{ doi_resolver_url -}}
|
{{- doi_resolver_name }} - {{ doi_resolver_url -}}
|
||||||
|
@ -168,9 +168,9 @@
|
||||||
</fieldset>
|
</fieldset>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('Engine tokens') }}</legend>
|
<legend id="pref_tokens">{{ _('Engine tokens') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<input name="tokens" type="text" autocomplete="off" spellcheck="false" autocorrect="off" value='{{ preferences.tokens.get_value() }}'/>
|
<input name="tokens" aria-labelledby="pref_tokens" type="text" autocomplete="off" spellcheck="false" autocorrect="off" value='{{ preferences.tokens.get_value() }}'/>
|
||||||
</p>
|
</p>
|
||||||
<p class="description">{{ _('Access tokens for private engines') }}</p>
|
<p class="description">{{ _('Access tokens for private engines') }}</p>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
|
@ -179,9 +179,9 @@
|
||||||
{{ tab_header('maintab', 'ui', _('User interface')) }}
|
{{ tab_header('maintab', 'ui', _('User interface')) }}
|
||||||
{% if 'locale' not in locked_preferences %}
|
{% if 'locale' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('Interface language') }}</legend>
|
<legend id="pref_locale">{{ _('Interface language') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select name='locale'>
|
<select name='locale' aria-labelledby="pref_locale">
|
||||||
{%- for locale_id,locale_name in locales.items() | sort -%}
|
{%- for locale_id,locale_name in locales.items() | sort -%}
|
||||||
<option value="{{ locale_id }}" {% if locale_id == current_locale %}selected="selected"{% endif %}>{{ locale_name }}</option>
|
<option value="{{ locale_id }}" {% if locale_id == current_locale %}selected="selected"{% endif %}>{{ locale_name }}</option>
|
||||||
{%- endfor -%}
|
{%- endfor -%}
|
||||||
|
@ -192,9 +192,9 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if 'theme' not in locked_preferences %}
|
{% if 'theme' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('Theme') }}</legend>
|
<legend id="pref_theme">{{ _('Theme') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select name="theme">
|
<select name="theme" aria-labelledby="pref_theme">
|
||||||
{%- for name in themes -%}
|
{%- for name in themes -%}
|
||||||
<option value="{{ name }}" {% if name == theme %}selected="selected"{% endif %}>{{ name }}</option>
|
<option value="{{ name }}" {% if name == theme %}selected="selected"{% endif %}>{{ name }}</option>
|
||||||
{%- endfor -%}
|
{%- endfor -%}
|
||||||
|
@ -203,9 +203,9 @@
|
||||||
<div class="description">{{ _('Change SearXNG layout') }}</div>
|
<div class="description">{{ _('Change SearXNG layout') }}</div>
|
||||||
</fieldset>
|
</fieldset>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('Theme style') }}</legend>
|
<legend id="pref_simple_style">{{ _('Theme style') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select name="simple_style">
|
<select name="simple_style" aria-labelledby="pref_simple_style">
|
||||||
{%- for name in ['auto', 'light', 'dark'] -%}
|
{%- for name in ['auto', 'light', 'dark'] -%}
|
||||||
<option value="{{ name }}" {% if name == preferences.get_value('simple_style') %}selected="selected"{% endif %}>{{ _(name) }}</option>
|
<option value="{{ name }}" {% if name == preferences.get_value('simple_style') %}selected="selected"{% endif %}>{{ _(name) }}</option>
|
||||||
{%- endfor -%}
|
{%- endfor -%}
|
||||||
|
@ -216,9 +216,9 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if 'results_on_new_tab' not in locked_preferences %}
|
{% if 'results_on_new_tab' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('Results on new tabs') }}</legend>
|
<legend id="pref_results_on_new_tab">{{ _('Results on new tabs') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select name='results_on_new_tab'>
|
<select name='results_on_new_tab' aria-labelledby="pref_results_on_new_tab">
|
||||||
<option value="1" {% if results_on_new_tab %}selected="selected"{% endif %}>{{ _('On') }}</option>
|
<option value="1" {% if results_on_new_tab %}selected="selected"{% endif %}>{{ _('On') }}</option>
|
||||||
<option value="0" {% if not results_on_new_tab %}selected="selected"{% endif %}>{{ _('Off')}}</option>
|
<option value="0" {% if not results_on_new_tab %}selected="selected"{% endif %}>{{ _('Off')}}</option>
|
||||||
</select>
|
</select>
|
||||||
|
@ -244,9 +244,9 @@
|
||||||
{{ tab_header('maintab', 'privacy', _('Privacy')) }}
|
{{ tab_header('maintab', 'privacy', _('Privacy')) }}
|
||||||
{% if 'method' not in locked_preferences %}
|
{% if 'method' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('HTTP Method') }}</legend>
|
<legend id="pref_method">{{ _('HTTP Method') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select name='method'>
|
<select name='method' aria-labelledby="pref_method">
|
||||||
<option value="POST" {% if method == 'POST' %}selected="selected"{% endif %}>POST</option>
|
<option value="POST" {% if method == 'POST' %}selected="selected"{% endif %}>POST</option>
|
||||||
<option value="GET" {% if method == 'GET' %}selected="selected"{% endif %}>GET</option>
|
<option value="GET" {% if method == 'GET' %}selected="selected"{% endif %}>GET</option>
|
||||||
</select>
|
</select>
|
||||||
|
@ -256,9 +256,9 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if 'image_proxy' not in locked_preferences %}
|
{% if 'image_proxy' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _('Image proxy') }}</legend>
|
<legend id="pref_image_proxy">{{ _('Image proxy') }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select name='image_proxy'>
|
<select name='image_proxy' aria-labelledby="pref_image_proxy">
|
||||||
<option value="1" {% if image_proxy %}selected="selected"{% endif %}>{{ _('Enabled') }}</option>
|
<option value="1" {% if image_proxy %}selected="selected"{% endif %}>{{ _('Enabled') }}</option>
|
||||||
<option value="" {% if not image_proxy %}selected="selected"{% endif %}>{{ _('Disabled') }}</option>
|
<option value="" {% if not image_proxy %}selected="selected"{% endif %}>{{ _('Disabled') }}</option>
|
||||||
</select>
|
</select>
|
||||||
|
@ -268,9 +268,9 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% if 'query_in_title' not in locked_preferences %}
|
{% if 'query_in_title' not in locked_preferences %}
|
||||||
<fieldset>
|
<fieldset>
|
||||||
<legend>{{ _("Query in the page's title") }}</legend>
|
<legend id="pref_query_in_title">{{ _("Query in the page's title") }}</legend>
|
||||||
<p class="value">
|
<p class="value">
|
||||||
<select name='query_in_title'>
|
<select name='query_in_title' aria-labelledby="pref_query_in_title">
|
||||||
<option value="1" {% if query_in_title %}selected="selected"{% endif %}>{{ _('Enabled') }}</option>
|
<option value="1" {% if query_in_title %}selected="selected"{% endif %}>{{ _('Enabled') }}</option>
|
||||||
<option value="" {% if not query_in_title %}selected="selected"{% endif %}>{{ _('Disabled') }}</option>
|
<option value="" {% if not query_in_title %}selected="selected"{% endif %}>{{ _('Disabled') }}</option>
|
||||||
</select>
|
</select>
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
|
|
||||||
<div id="results" class="{{ only_template }}">
|
<div id="results" class="{{ only_template }}">
|
||||||
{% if answers -%}
|
{% if answers -%}
|
||||||
<div id="answers"><h4 class="title">{{ _('Answers') }} : </h4>
|
<div id="answers" role="complementary" aria-labelledby="answers-title"><h4 class="title" id="answers-title">{{ _('Answers') }} : </h4>
|
||||||
{%- for answer in answers.values() -%}
|
{%- for answer in answers.values() -%}
|
||||||
<div class="answer">
|
<div class="answer">
|
||||||
{% if answer.url %}
|
{% if answer.url %}
|
||||||
|
@ -64,8 +64,8 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
{% if suggestions %}
|
{% if suggestions %}
|
||||||
<div id="suggestions">
|
<div id="suggestions" role="complementary" aria-labelledby="suggestions-title">
|
||||||
<h4 class="title">{{ _('Suggestions') }} : </h4>
|
<h4 class="title" id="suggestions-title">{{ _('Suggestions') }} : </h4>
|
||||||
<div class="wrapper">
|
<div class="wrapper">
|
||||||
{% for suggestion in suggestions %}
|
{% for suggestion in suggestions %}
|
||||||
<form method="{{ method or 'POST' }}" action="{{ url_for('search') }}">
|
<form method="{{ method or 'POST' }}" action="{{ url_for('search') }}">
|
||||||
|
@ -75,20 +75,20 @@
|
||||||
<input type="hidden" name="safesearch" value="{{ safesearch }}">
|
<input type="hidden" name="safesearch" value="{{ safesearch }}">
|
||||||
<input type="hidden" name="theme" value="{{ theme }}">
|
<input type="hidden" name="theme" value="{{ theme }}">
|
||||||
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit|e }}" >{% endif %}
|
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit|e }}" >{% endif %}
|
||||||
<input type="submit" class="suggestion" value="• {{ suggestion.title }}">
|
<input type="submit" class="suggestion" role="link" value="• {{ suggestion.title }}">
|
||||||
</form>
|
</form>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
<div id="search_url">
|
<div id="search_url" role="complementary" aria-labelledby="search_url-title">
|
||||||
<h4 class="title">{{ _('Search URL') }} :</h4>
|
<h4 class="title" id="search_url-title">{{ _('Search URL') }} :</h4>
|
||||||
<div class="selectable_url"><pre>{{ url_for('search', _external=True) }}?q={{ q|urlencode }}&language={{ current_language }}&time_range={{ time_range }}&safesearch={{ safesearch }}{% if pageno > 1 %}&pageno={{ pageno }}{% endif %}{% if selected_categories %}&categories={{ selected_categories|join(",") | replace(' ','+') }}{% endif %}{% if timeout_limit %}&timeout_limit={{ timeout_limit|urlencode }}{% endif %}</pre></div>
|
<div class="selectable_url"><pre>{{ url_for('search', _external=True) }}?q={{ q|urlencode }}&language={{ current_language }}&time_range={{ time_range }}&safesearch={{ safesearch }}{% if pageno > 1 %}&pageno={{ pageno }}{% endif %}{% if selected_categories %}&categories={{ selected_categories|join(",") | replace(' ','+') }}{% endif %}{% if timeout_limit %}&timeout_limit={{ timeout_limit|urlencode }}{% endif %}</pre></div>
|
||||||
</div>
|
</div>
|
||||||
<div id="apis">
|
<div id="apis" role="complementary" aria-labelledby="apis-title">
|
||||||
{% if search_formats %}
|
{% if search_formats %}
|
||||||
<h4 class="title">{{ _('Download results') }}</h4>
|
<h4 class="title" id="apis-title">{{ _('Download results') }}</h4>
|
||||||
{% for output_type in search_formats %}
|
{% for output_type in search_formats %}
|
||||||
<div class="left">
|
<div class="left">
|
||||||
<form method="{{ method or 'POST' }}" action="{{ url_for('search') }}">
|
<form method="{{ method or 'POST' }}" action="{{ url_for('search') }}">
|
||||||
|
@ -102,7 +102,7 @@
|
||||||
<input type="hidden" name="safesearch" value="{{ safesearch }}">
|
<input type="hidden" name="safesearch" value="{{ safesearch }}">
|
||||||
<input type="hidden" name="format" value="{{ output_type }}">
|
<input type="hidden" name="format" value="{{ output_type }}">
|
||||||
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit|e }}" >{% endif %}
|
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit|e }}" >{% endif %}
|
||||||
<input type="submit" value="{{ output_type }}">
|
<input type="submit" role="link" value="{{ output_type }}">
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
@ -111,8 +111,8 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% if corrections %}
|
{% if corrections %}
|
||||||
<div id="corrections">
|
<div id="corrections" role="complementary" aria-labelledby="corrections-title">
|
||||||
<h4>{{ _('Try searching for:') }}</h4>
|
<h4 id="corrections-title">{{ _('Try searching for:') }}</h4>
|
||||||
{% for correction in corrections %}
|
{% for correction in corrections %}
|
||||||
<div class="left">
|
<div class="left">
|
||||||
<form method="{{ method or 'POST' }}" action="{{ url_for('search') }}" role="navigation">
|
<form method="{{ method or 'POST' }}" action="{{ url_for('search') }}" role="navigation">
|
||||||
|
@ -122,14 +122,14 @@
|
||||||
<input type="hidden" name="safesearch" value="{{ safesearch }}">
|
<input type="hidden" name="safesearch" value="{{ safesearch }}">
|
||||||
<input type="hidden" name="theme" value="{{ theme }}">
|
<input type="hidden" name="theme" value="{{ theme }}">
|
||||||
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit }}" >{% endif %}
|
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit }}" >{% endif %}
|
||||||
<input type="submit" value="{{ correction.title }}">
|
<input type="submit" role="link" value="{{ correction.title }}">
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
<div id="urls">
|
<div id="urls" role="main">
|
||||||
{% for result in results %}
|
{% for result in results %}
|
||||||
{% if result.open_group and not only_template %}<div class="template_group_{{ result['template']|replace('.html', '') }}">{% endif %}
|
{% if result.open_group and not only_template %}<div class="template_group_{{ result['template']|replace('.html', '') }}">{% endif %}
|
||||||
{% set index = loop.index %}
|
{% set index = loop.index %}
|
||||||
|
@ -141,10 +141,10 @@
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
<div id="backToTop">
|
<div id="backToTop">
|
||||||
<a href="#">{{ icon_small('chevron-up-outline') }}</a>
|
<a href="#" aria-label="{{ _('Back to top') }}">{{ icon_small('chevron-up-outline') }}</a>
|
||||||
</div>
|
</div>
|
||||||
{% if paging %}
|
{% if paging %}
|
||||||
<nav id="pagination">
|
<nav id="pagination" role="navigation">
|
||||||
{% if pageno > 1 %}
|
{% if pageno > 1 %}
|
||||||
<form method="{{ method or 'POST' }}" action="{{ url_for('search') }}" class="previous_page">
|
<form method="{{ method or 'POST' }}" action="{{ url_for('search') }}" class="previous_page">
|
||||||
<div class="{% if rtl %}right{% else %}left{% endif %}">
|
<div class="{% if rtl %}right{% else %}left{% endif %}">
|
||||||
|
@ -159,7 +159,7 @@
|
||||||
<input type="hidden" name="safesearch" value="{{ safesearch }}" >
|
<input type="hidden" name="safesearch" value="{{ safesearch }}" >
|
||||||
<input type="hidden" name="theme" value="{{ theme }}" >
|
<input type="hidden" name="theme" value="{{ theme }}" >
|
||||||
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit|e }}" >{% endif %}
|
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit|e }}" >{% endif %}
|
||||||
<button type="submit">{{ icon_small('chevron-left') }} {{ _('Previous page') }}</button>
|
<button role="link" type="submit">{{ icon_small('chevron-left') }} {{ _('Previous page') }}</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@ -176,7 +176,7 @@
|
||||||
<input type="hidden" name="safesearch" value="{{ safesearch }}" >
|
<input type="hidden" name="safesearch" value="{{ safesearch }}" >
|
||||||
<input type="hidden" name="theme" value="{{ theme }}" >
|
<input type="hidden" name="theme" value="{{ theme }}" >
|
||||||
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit|e }}" >{% endif %}
|
{% if timeout_limit %}<input type="hidden" name="timeout_limit" value="{{ timeout_limit|e }}" >{% endif %}
|
||||||
<button type="submit">{{ _('Next page') }} {{ icon_small('chevron-right') }}</button>
|
<button role="link" type="submit">{{ _('Next page') }} {{ icon_small('chevron-right') }}</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
<form id="search" method="{{ method or 'POST' }}" action="{{ url_for('search') }}">
|
<form id="search" method="{{ method or 'POST' }}" action="{{ url_for('search') }}" role="search">
|
||||||
<div id="search_header">
|
<div id="search_header">
|
||||||
<a id="search_logo" href="{{ url_for('index') }}">
|
<a id="search_logo" href="{{ url_for('index') }}" tabindex="0" title="{{ _('Display the front page') }}">
|
||||||
<span hidden>SearXNG</span>
|
<span hidden>SearXNG</span>
|
||||||
{% include '__common__/searxng-wordmark.min.svg' without context %}
|
{% include '__common__/searxng-wordmark.min.svg' without context %}
|
||||||
</a>
|
</a>
|
||||||
<div class="search_box">
|
<div class="search_box">
|
||||||
<input id="q" autofocus name="q" type="text" placeholder="{{ _('Search for...') }}" tabindex="1" autocomplete="off" spellcheck="false" dir="auto" {% if q %}value="{{ q }}"{% endif %} >
|
<input id="q" autofocus name="q" type="text" placeholder="{{ _('Search for...') }}" autocomplete="off" spellcheck="false" dir="auto" value="{{ q or '' }}">
|
||||||
<button id="clear_search" type="button" tabindex="-1"><span class="hide_if_nojs">{{ icon_big('close') }}</span><span class="show_if_nojs">{{ _('clear') }}</span></button>
|
<button id="clear_search" type="reset" aria-label="{{ _('clear') }}"><span class="hide_if_nojs">{{ icon_big('close') }}</span><span class="show_if_nojs">{{ _('clear') }}</span></button>
|
||||||
<button id="send_search" type="submit" tabindex="-1"><span class="hide_if_nojs">{{ icon_big('search-outline') }}</span><span class="show_if_nojs">{{ _('search') }}</span></button>
|
<button id="send_search" type="submit" aria-label="{{ _('search') }}"><span class="hide_if_nojs">{{ icon_big('search-outline') }}</span><span class="show_if_nojs">{{ _('search') }}</span></button>
|
||||||
</div>
|
</div>
|
||||||
{% set display_tooltip = true %}
|
{% set display_tooltip = true %}
|
||||||
{% include 'simple/categories.html' %}
|
{% include 'simple/categories.html' %}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
<form id="search" method="{{ method or 'POST' }}" action="{{ url_for('search') }}">
|
<form id="search" method="{{ method or 'POST' }}" action="{{ url_for('search') }}" role="search">
|
||||||
<div id="search_header">
|
<div id="search_header">
|
||||||
<div class="search_box">
|
<div class="search_box">
|
||||||
<input id="q" autofocus name="q" type="text" placeholder="{{ _('Search for...') }}" tabindex="1" autocomplete="off" spellcheck="false" dir="auto" {% if q %}value="{{ q }}"{% endif %} >
|
<input id="q" autofocus name="q" type="text" placeholder="{{ _('Search for...') }}" autocomplete="off" spellcheck="false" dir="auto" value="{{ q or '' }}">
|
||||||
<button id="clear_search" type="button" tabindex="-1"><span class="hide_if_nojs">{{ icon_big('close') }}</span><span class="show_if_nojs">{{ _('clear') }}</span></button>
|
<button id="clear_search" type="reset" aria-label="{{ _('clear') }}"><span class="hide_if_nojs">{{ icon_big('close') }}</span><span class="show_if_nojs">{{ _('clear') }}</span></button>
|
||||||
<button id="send_search" type="submit" tabindex="-1"><span class="hide_if_nojs">{{ icon_big('search-outline') }}</span><span class="show_if_nojs">{{ _('search') }}</span></button>
|
<button id="send_search" type="submit" aria-label="{{ _('search') }}"><span class="hide_if_nojs">{{ icon_big('search-outline') }}</span><span class="show_if_nojs">{{ _('search') }}</span></button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
|
|
@ -198,7 +198,7 @@ class ViewsTestCase(SearxTestCase):
|
||||||
self.assertIn(
|
self.assertIn(
|
||||||
b'<input type="checkbox" id="checkbox_general" name="category_general" checked="checked"/>', result.data
|
b'<input type="checkbox" id="checkbox_general" name="category_general" checked="checked"/>', result.data
|
||||||
)
|
)
|
||||||
self.assertIn(b'<legend>Interface language</legend>', result.data)
|
self.assertIn(b'<legend id="pref_locale">Interface language</legend>', result.data)
|
||||||
|
|
||||||
def test_browser_locale(self):
|
def test_browser_locale(self):
|
||||||
result = self.app.get('/preferences', headers={'Accept-Language': 'zh-tw;q=0.8'})
|
result = self.app.get('/preferences', headers={'Accept-Language': 'zh-tw;q=0.8'})
|
||||||
|
|
Loading…
Reference in a new issue