diff options
author | Markus Heiser <markus.heiser@darmarit.de> | 2022-04-13 17:08:19 +0200 |
---|---|---|
committer | Markus Heiser <markus.heiser@darmarit.de> | 2022-05-07 17:58:30 +0200 |
commit | ed2a4c80879d2d3741514ea1117ab672b8f55d54 (patch) | |
tree | 6a1cb65e74ceade9372f65e2cfb7cb9e04322d3e | |
parent | 9177172ea21852e16f00896806bf1b573fd9bb8f (diff) | |
download | searxng-ed2a4c80879d2d3741514ea1117ab672b8f55d54.tar.gz searxng-ed2a4c80879d2d3741514ea1117ab672b8f55d54.zip |
[mod] client_settings: pass settings from server to JS client
Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
-rw-r--r-- | searx/static/themes/simple/src/js/head/00_init.js | 23 | ||||
-rw-r--r-- | searx/static/themes/simple/src/js/main/00_toolkit.js | 4 | ||||
-rw-r--r-- | searx/static/themes/simple/src/js/main/infinite_scroll.js | 4 | ||||
-rw-r--r-- | searx/static/themes/simple/src/js/main/keyboard.js | 2 | ||||
-rw-r--r-- | searx/static/themes/simple/src/js/main/preferences.js | 2 | ||||
-rw-r--r-- | searx/static/themes/simple/src/js/main/search.js | 8 | ||||
-rw-r--r-- | searx/templates/simple/base.html | 9 | ||||
-rwxr-xr-x | searx/webapp.py | 34 |
8 files changed, 45 insertions, 41 deletions
diff --git a/searx/static/themes/simple/src/js/head/00_init.js b/searx/static/themes/simple/src/js/head/00_init.js index acd437f39..4aeece8c2 100644 --- a/searx/static/themes/simple/src/js/head/00_init.js +++ b/searx/static/themes/simple/src/js/head/00_init.js @@ -1,9 +1,4 @@ -/** - * @license - * (C) Copyright Contributors to the SearXNG project. - * (C) Copyright Contributors to the searx project (2014 - 2021). - * SPDX-License-Identifier: AGPL-3.0-or-later - */ +/* SPDX-License-Identifier: AGPL-3.0-or-later */ (function (w, d) { 'use strict'; @@ -13,23 +8,13 @@ return scripts[scripts.length - 1]; })(); - // try to detect touch screen w.searxng = { - method: script.getAttribute('data-method'), - autocompleter: script.getAttribute('data-autocompleter') === 'true', - search_on_category_select: script.getAttribute('data-search-on-category-select') === 'true', - infinite_scroll: script.getAttribute('data-infinite-scroll') === 'true', - hotkeys: script.getAttribute('data-hotkeys') === 'true', - static_path: script.getAttribute('data-static-path'), - translations: JSON.parse(script.getAttribute('data-translations')), - theme: { - // image that is displayed if load of <img src='...'> failed - img_load_error: 'img/img_load_error.svg' - } + settings: JSON.parse(atob(script.getAttribute('client_settings'))) }; // update the css var hmtlElement = d.getElementsByTagName("html")[0]; hmtlElement.classList.remove('no-js'); hmtlElement.classList.add('js'); -})(window, document);
\ No newline at end of file + +})(window, document); diff --git a/searx/static/themes/simple/src/js/main/00_toolkit.js b/searx/static/themes/simple/src/js/main/00_toolkit.js index f53842d72..699731ee4 100644 --- a/searx/static/themes/simple/src/js/main/00_toolkit.js +++ b/searx/static/themes/simple/src/js/main/00_toolkit.js @@ -101,7 +101,7 @@ window.searxng = (function (w, d) { }; searxng.loadStyle = function (src) { - var path = searxng.static_path + src, + var path = searxng.settings.theme_static_path + src, id = "style_" + src.replace('.', '_'), s = d.getElementById(id); if (s === null) { @@ -115,7 +115,7 @@ window.searxng = (function (w, d) { }; searxng.loadScript = function (src, callback) { - var path = searxng.static_path + src, + var path = searxng.settings.theme_static_path + src, id = "script_" + src.replace('.', '_'), s = d.getElementById(id); if (s === null) { diff --git a/searx/static/themes/simple/src/js/main/infinite_scroll.js b/searx/static/themes/simple/src/js/main/infinite_scroll.js index b900e66e2..07db3305a 100644 --- a/searx/static/themes/simple/src/js/main/infinite_scroll.js +++ b/searx/static/themes/simple/src/js/main/infinite_scroll.js @@ -62,7 +62,7 @@ searxng.ready(function () { function (err) { console.log(err); var e = d.createElement('div'); - e.textContent = searxng.translations.error_loading_next_page; + e.textContent = searxng.settings.translations.error_loading_next_page; e.classList.add('dialog-error'); e.setAttribute('role', 'alert'); replaceChildrenWith(d.querySelector('#pagination'), [ e ]); @@ -70,7 +70,7 @@ searxng.ready(function () { ) } - if (searxng.infinite_scroll && searxng.infinite_scroll_supported) { + if (searxng.settings.infinite_scroll && searxng.infinite_scroll_supported) { const intersectionObserveOptions = { rootMargin: "20rem", }; diff --git a/searx/static/themes/simple/src/js/main/keyboard.js b/searx/static/themes/simple/src/js/main/keyboard.js index a8ab7222f..f29ed86f4 100644 --- a/searx/static/themes/simple/src/js/main/keyboard.js +++ b/searx/static/themes/simple/src/js/main/keyboard.js @@ -154,7 +154,7 @@ searxng.ready(function () { } }; - if (searxng.hotkeys) { + if (searxng.settings.hotkeys) { searxng.on(document, "keydown", function (e) { // check for modifiers so we don't break browser's hotkeys if (Object.prototype.hasOwnProperty.call(vimKeys, e.keyCode) && !e.ctrlKey && !e.altKey && !e.shiftKey && !e.metaKey) { diff --git a/searx/static/themes/simple/src/js/main/preferences.js b/searx/static/themes/simple/src/js/main/preferences.js index 09f9cdde4..1e3ae5981 100644 --- a/searx/static/themes/simple/src/js/main/preferences.js +++ b/searx/static/themes/simple/src/js/main/preferences.js @@ -15,7 +15,7 @@ for (const [engine_name, description] of Object.entries(engine_descriptions)) { let elements = d.querySelectorAll('[data-engine-name="' + engine_name + '"] .engine-description'); for (const element of elements) { - let source = ' (<i>' + searxng.translations['Source'] + ': ' + description[1] + '</i>)'; + let source = ' (<i>' + searxng.settings.translations.Source + ': ' + description[1] + '</i>)'; element.innerHTML = description[0] + source; } } diff --git a/searx/static/themes/simple/src/js/main/search.js b/searx/static/themes/simple/src/js/main/search.js index 798c9b2d3..edd68d259 100644 --- a/searx/static/themes/simple/src/js/main/search.js +++ b/searx/static/themes/simple/src/js/main/search.js @@ -59,11 +59,11 @@ createClearButton(qinput); // autocompleter - if (searxng.autocompleter) { + if (searxng.settings.autocomplete_provider) { searxng.autocomplete = AutoComplete.call(w, { Url: "./autocompleter", - EmptyMessage: searxng.translations.no_item_found, - HttpMethod: searxng.method, + EmptyMessage: searxng.settings.translations.no_item_found, + HttpMethod: searxng.settings.http_method, HttpHeaders: { "Content-type": "application/x-www-form-urlencoded", "X-Requested-With": "XMLHttpRequest" @@ -92,7 +92,7 @@ } // vanilla js version of search_on_category_select.js - if (qinput !== null && d.querySelector('.help') != null && searxng.search_on_category_select) { + if (qinput !== null && d.querySelector('.help') != null && searxng.settings.search_on_category_select) { d.querySelector('.help').className = 'invisible'; searxng.on('#categories input', 'change', function () { diff --git a/searx/templates/simple/base.html b/searx/templates/simple/base.html index a82c26a61..d8eaaa02b 100644 --- a/searx/templates/simple/base.html +++ b/searx/templates/simple/base.html @@ -19,14 +19,7 @@ {% endif %} {% block styles %}{% endblock %} <!--[if gte IE 9]>--> - <script src="{{ url_for('static', filename='js/searxng.head.min.js') }}" - data-method="{{ method or 'POST' }}" - data-autocompleter="{% if autocomplete %}true{% else %}false{% endif %}" - data-search-on-category-select="{{ 'true' if 'plugins/js/search_on_category_select.js' in scripts else 'false'}}" - data-infinite-scroll="{% if infinite_scroll %}true{% else %}false{% endif %}" - data-hotkeys="{{ 'true' if 'plugins/js/vim_hotkeys.js' in scripts else 'false' }}" - data-static-path="{{ url_for('static', filename='themes/simple') }}/" - data-translations="{{ translations }}"></script> + <script src="{{ url_for('static', filename='js/searxng.head.min.js') }}" client_settings="{{ client_settings }}"></script> <!--<![endif]--> {% block head %} <link title="{{ instance_name }}" type="application/opensearchdescription+xml" rel="search" href="{{ opensearch_url }}"/> diff --git a/searx/webapp.py b/searx/webapp.py index 3d3f736a5..b91e96df1 100755 --- a/searx/webapp.py +++ b/searx/webapp.py @@ -10,6 +10,7 @@ import hmac import json import os import sys +import base64 from datetime import datetime, timedelta from timeit import default_timer @@ -444,7 +445,36 @@ def get_pretty_url(parsed_url: urllib.parse.ParseResult): return [parsed_url.scheme + "://" + parsed_url.netloc, path] +def get_client_settings(): + req_pref = request.preferences + return { + 'autocomplete_provider': req_pref.get_value('autocomplete'), + 'http_method': req_pref.get_value('method'), + 'infinite_scroll': req_pref.get_value('infinite_scroll'), + 'translations': get_translations(), + 'search_on_category_select': req_pref.plugins.choices['searx.plugins.search_on_category_select'], + 'hotkeys': req_pref.plugins.choices['searx.plugins.vim_hotkeys'], + 'theme_static_path': custom_url_for('static', filename='themes/simple'), + } + + def render(template_name: str, override_theme: str = None, **kwargs): + + kwargs['client_settings'] = str( + base64.b64encode( + bytes( + json.dumps(get_client_settings()), + encoding='utf-8', + ) + ), encoding='utf-8', + ) + + # obsolete, only needed by oscar + kwargs['autocomplete'] = request.preferences.get_value('autocomplete') + kwargs['method'] = request.preferences.get_value('method') + kwargs['infinite_scroll'] = request.preferences.get_value('infinite_scroll') + kwargs['translations'] = json.dumps(get_translations(), separators=(',', ':')) + # values from the HTTP requests kwargs['endpoint'] = 'results' if 'q' in kwargs else request.endpoint kwargs['cookies'] = request.cookies @@ -452,9 +482,6 @@ def render(template_name: str, override_theme: str = None, **kwargs): # values from the preferences kwargs['preferences'] = request.preferences - kwargs['method'] = request.preferences.get_value('method') - kwargs['autocomplete'] = request.preferences.get_value('autocomplete') - kwargs['infinite_scroll'] = request.preferences.get_value('infinite_scroll') kwargs['results_on_new_tab'] = request.preferences.get_value('results_on_new_tab') kwargs['advanced_search'] = request.preferences.get_value('advanced_search') kwargs['query_in_title'] = request.preferences.get_value('query_in_title') @@ -466,7 +493,6 @@ def render(template_name: str, override_theme: str = None, **kwargs): # i18n kwargs['language_codes'] = [l for l in languages if l[0] in settings['search']['languages']] - kwargs['translations'] = json.dumps(get_translations(), separators=(',', ':')) locale = request.preferences.get_value('locale') kwargs['locale_rfc5646'] = _get_locale_rfc5646(locale) |