mirror of
				https://github.com/searxng/searxng.git
				synced 2025-11-04 03:27:06 -05:00 
			
		
		
		
	Merge pull request #927 from dalf/simple-checkbox
[simple] make checkboxes accessible
This commit is contained in:
		
						commit
						67fd4e139d
					
				
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										8
									
								
								searx/static/themes/oscar/js/searxng.min.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								searx/static/themes/oscar/js/searxng.min.js
									
									
									
									
										vendored
									
									
								
							@ -4,7 +4,7 @@
 | 
				
			|||||||
 * (C) Copyright Contributors to the searx project (2014 - 2021).
 | 
					 * (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
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
window.searxng=function(t){"use strict";t.getElementsByTagName("html")[0].className="js";t=t.currentScript||(t=t.getElementsByTagName("script"))[t.length-1];return{autocompleter:"true"===t.getAttribute("data-autocompleter"),infinite_scroll:"true"===t.getAttribute("data-infinite-scroll"),method:t.getAttribute("data-method"),translations:JSON.parse(t.getAttribute("data-translations"))}}(document),
 | 
					window.searxng=function(t){"use strict";t.getElementsByTagName("html")[0].className="js";var e=t.currentScript||(e=t.getElementsByTagName("script"))[e.length-1];return{autocompleter:"true"===e.getAttribute("data-autocompleter"),infinite_scroll:"true"===e.getAttribute("data-infinite-scroll"),method:e.getAttribute("data-method"),translations:JSON.parse(e.getAttribute("data-translations"))}}(document),
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * @license
 | 
					 * @license
 | 
				
			||||||
 * (C) Copyright Contributors to the SearXNG project.
 | 
					 * (C) Copyright Contributors to the SearXNG project.
 | 
				
			||||||
@ -20,7 +20,7 @@ $(document).ready(function(){var t,n="";searxng.autocompleter&&((t=new Bloodhoun
 | 
				
			|||||||
 * (C) 2014 by Thomas Pointhuber, <thomas.pointhuber@gmx.at>
 | 
					 * (C) 2014 by Thomas Pointhuber, <thomas.pointhuber@gmx.at>
 | 
				
			||||||
 * SPDX-License-Identifier: AGPL-3.0-or-later
 | 
					 * SPDX-License-Identifier: AGPL-3.0-or-later
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
$(document).ready(function(){$("#q.autofocus").focus(),$("#clear_search").click(function(){document.getElementById("q").value=""}),$(".select-all-on-click").click(function(){$(this).select()}),$(".btn-collapse").click(function(){var t=$(this).data("btn-text-collapsed"),e=$(this).data("btn-text-not-collapsed");""!==t&&""!==e&&(new_html=$(this).hasClass("collapsed")?$(this).html().replace(t,e):$(this).html().replace(e,t),$(this).html(new_html))}),$(".btn-toggle .btn").click(function(){var t="btn-"+$(this).data("btn-class"),e=$(this).data("btn-label-default"),n=$(this).data("btn-label-toggled");""!==n&&(new_html=$(this).hasClass("btn-default")?$(this).html().replace(e,n):$(this).html().replace(n,e),$(this).html(new_html)),$(this).toggleClass(t),$(this).toggleClass("btn-default")}),$(".media-loader").click(function(){var t=$(this).data("target"),t=$(t+" > iframe"),e=t.attr("src");void 0!==e&&!1!==e||t.attr("src",t.data("src"))}),$(".btn-sm").dblclick(function(){var t="btn-"+$(this).data("btn-class");$(this).hasClass("btn-default")?($(".btn-sm > input").attr("checked","checked"),$(".btn-sm > input").prop("checked",!0),$(".btn-sm").addClass(t),$(".btn-sm").addClass("active"),$(".btn-sm").removeClass("btn-default")):($(".btn-sm > input").attr("checked",""),$(".btn-sm > input").removeAttr("checked"),$(".btn-sm > input").checked=!1,$(".btn-sm").removeClass(t),$(".btn-sm").removeClass("active"),$(".btn-sm").addClass("btn-default"))}),$(".nav-tabs").click(function(t){$(t.target).parents("ul").children().attr("aria-selected","false"),$(t.target).parent().attr("aria-selected","true")}),searxng.image_thumbnail_layout=new searxng.ImageLayout("#main_results","#main_results .result-images","img.img-thumbnail",15,3,200),searxng.image_thumbnail_layout.watch()}),
 | 
					$(document).ready(function(){$("#q.autofocus").focus(),$("#clear_search").click(function(){document.getElementById("q").value=""}),$(".select-all-on-click").click(function(){$(this).select()}),$(".btn-collapse").click(function(){var t=$(this).data("btn-text-collapsed"),e=$(this).data("btn-text-not-collapsed");""!==t&&""!==e&&(new_html=$(this).hasClass("collapsed")?$(this).html().replace(t,e):$(this).html().replace(e,t),$(this).html(new_html))}),$(".btn-toggle .btn").click(function(){var t="btn-"+$(this).data("btn-class"),e=$(this).data("btn-label-default"),n=$(this).data("btn-label-toggled");""!==n&&(new_html=$(this).hasClass("btn-default")?$(this).html().replace(e,n):$(this).html().replace(n,e),$(this).html(new_html)),$(this).toggleClass(t),$(this).toggleClass("btn-default")}),$(".media-loader").click(function(){var t=$(this).data("target"),e=$(t+" > iframe"),t=e.attr("src");void 0!==t&&!1!==t||e.attr("src",e.data("src"))}),$(".btn-sm").dblclick(function(){var t="btn-"+$(this).data("btn-class");$(this).hasClass("btn-default")?($(".btn-sm > input").attr("checked","checked"),$(".btn-sm > input").prop("checked",!0),$(".btn-sm").addClass(t),$(".btn-sm").addClass("active"),$(".btn-sm").removeClass("btn-default")):($(".btn-sm > input").attr("checked",""),$(".btn-sm > input").removeAttr("checked"),$(".btn-sm > input").checked=!1,$(".btn-sm").removeClass(t),$(".btn-sm").removeClass("active"),$(".btn-sm").addClass("btn-default"))}),$(".nav-tabs").click(function(t){$(t.target).parents("ul").children().attr("aria-selected","false"),$(t.target).parent().attr("aria-selected","true")}),searxng.image_thumbnail_layout=new searxng.ImageLayout("#main_results","#main_results .result-images","img.img-thumbnail",15,3,200),searxng.image_thumbnail_layout.watch()}),
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
*
 | 
					*
 | 
				
			||||||
* Google Image Layout v0.0.1
 | 
					* Google Image Layout v0.0.1
 | 
				
			||||||
@ -42,7 +42,7 @@ $(document).ready(function(){$("#q.autofocus").focus(),$("#clear_search").click(
 | 
				
			|||||||
* );
 | 
					* );
 | 
				
			||||||
* searxng.image_thumbnail_layout.watch();
 | 
					* searxng.image_thumbnail_layout.watch();
 | 
				
			||||||
*/
 | 
					*/
 | 
				
			||||||
function(s,c){function t(t,e,n,a,i,o){this.container_selector=t,this.results_selector=e,this.img_selector=n,this.verticalMargin=a,this.horizontalMargin=i,this.maxHeight=o,this.trottleCallToAlign=null,this.alignAfterThrotteling=!1}t.prototype._getHeigth=function(t,e){for(var n,a=0,i=0;i<t.length;i++)0<(n=t[i]).naturalWidth&&0<n.naturalHeight?a+=n.naturalWidth/n.naturalHeight:a+=1;return(e-t.length*this.verticalMargin)/a},t.prototype._setSize=function(t,e){for(var n,a,i=t.length,o=0;o<i;o++)a=0<(n=t[o]).naturalWidth&&0<n.naturalHeight?e*n.naturalWidth/n.naturalHeight:e,n.setAttribute("width",Math.round(a)),n.setAttribute("height",Math.round(e)),n.style.marginLeft=Math.round(this.horizontalMargin)+"px",n.style.marginTop=Math.round(this.horizontalMargin)+"px",n.style.marginRight=Math.round(this.verticalMargin-7)+"px",n.style.marginBottom=Math.round(this.verticalMargin-7)+"px",(a=n.parentNode.parentNode).classList.contains("js")||a.classList.add("js")},t.prototype._alignImgs=function(t){for(var e,n,a,i,o=c.querySelector(this.container_selector),s=window.getComputedStyle(o),r=parseInt(s.getPropertyValue("padding-left"),10),s=parseInt(s.getPropertyValue("padding-right"),10),l=o.clientWidth-r-s;0<t.length;){for(e=!0,a=1;a<=t.length&&e;a++)n=t.slice(0,a),(i=this._getHeigth(n,l))<this.maxHeight&&(this._setSize(n,i),t=t.slice(a),e=!1);if(e){this._setSize(n,Math.min(this.maxHeight,i));break}}},t.prototype.throttleAlign=function(){var t=this;t.trottleCallToAlign?t.alignAfterThrotteling=!0:(t.alignAfterThrotteling=!1,t.align(),t.trottleCallToAlign=setTimeout(function(){t.alignAfterThrotteling&&t.align(),t.alignAfterThrotteling=!1,t.trottleCallToAlign=null},20))},t.prototype.align=function(){for(var t=c.querySelectorAll(this.results_selector),e=t.length,n=null,a=null,i=[],o=0;o<e;o++)(a=t[o]).previousElementSibling!==n&&0<i.length&&(this._alignImgs(i),i=[]),i.push(a.querySelector(this.img_selector)),n=a;0<i.length&&this._alignImgs(i)},t.prototype._monitorImages=function(){var t,e,n=this.throttleAlign.bind(this),a=c.querySelectorAll(this.results_selector),i=a.length;function o(t){t.originalTarget.src=s.searxng.static_path+s.searxng.theme.img_load_error}for(t=0;t<i;t++)null==(e=a[t].querySelector(this.img_selector))||e.classList.contains("aligned")||(e.addEventListener("load",n),e.addEventListener("error",n),e.addEventListener("timeout",n),s.searxng.theme.img_load_error&&e.addEventListener("error",o,{once:!0}),e.classList.add("aligned"))},t.prototype.watch=function(){var t=this.throttleAlign.bind(this),a=(s.addEventListener("pageshow",t),s.addEventListener("load",t),s.addEventListener("resize",t),this._monitorImages(),this);let e=new MutationObserver(e=>{let n=!1;for(let t=0;t<e.length;t++)if(0<e[t].addedNodes.length&&e[t].addedNodes[0].classList.contains("result")){n=!0;break}n&&a._monitorImages()});e.observe(c.querySelector(this.container_selector),{childList:!0,subtree:!0,attributes:!1,characterData:!1})},s.searxng.ImageLayout=t}(window,document),
 | 
					function(s,c){function t(t,e,n,a,i,o){this.container_selector=t,this.results_selector=e,this.img_selector=n,this.verticalMargin=a,this.horizontalMargin=i,this.maxHeight=o,this.trottleCallToAlign=null,this.alignAfterThrotteling=!1}t.prototype._getHeigth=function(t,e){for(var n,a=0,i=0;i<t.length;i++)0<(n=t[i]).naturalWidth&&0<n.naturalHeight?a+=n.naturalWidth/n.naturalHeight:a+=1;return(e-t.length*this.verticalMargin)/a},t.prototype._setSize=function(t,e){for(var n,a,i=t.length,o=0;o<i;o++)n=0<(a=t[o]).naturalWidth&&0<a.naturalHeight?e*a.naturalWidth/a.naturalHeight:e,a.setAttribute("width",Math.round(n)),a.setAttribute("height",Math.round(e)),a.style.marginLeft=Math.round(this.horizontalMargin)+"px",a.style.marginTop=Math.round(this.horizontalMargin)+"px",a.style.marginRight=Math.round(this.verticalMargin-7)+"px",a.style.marginBottom=Math.round(this.verticalMargin-7)+"px",(a=a.parentNode.parentNode).classList.contains("js")||a.classList.add("js")},t.prototype._alignImgs=function(t){for(var e,n,a,i,o=c.querySelector(this.container_selector),s=window.getComputedStyle(o),r=parseInt(s.getPropertyValue("padding-left"),10),s=parseInt(s.getPropertyValue("padding-right"),10),l=o.clientWidth-r-s;0<t.length;){for(e=!0,a=1;a<=t.length&&e;a++)n=t.slice(0,a),(i=this._getHeigth(n,l))<this.maxHeight&&(this._setSize(n,i),t=t.slice(a),e=!1);if(e){this._setSize(n,Math.min(this.maxHeight,i));break}}},t.prototype.throttleAlign=function(){var t=this;t.trottleCallToAlign?t.alignAfterThrotteling=!0:(t.alignAfterThrotteling=!1,t.align(),t.trottleCallToAlign=setTimeout(function(){t.alignAfterThrotteling&&t.align(),t.alignAfterThrotteling=!1,t.trottleCallToAlign=null},20))},t.prototype.align=function(){for(var t=c.querySelectorAll(this.results_selector),e=t.length,n=null,a=null,i=[],o=0;o<e;o++)(a=t[o]).previousElementSibling!==n&&0<i.length&&(this._alignImgs(i),i=[]),i.push(a.querySelector(this.img_selector)),n=a;0<i.length&&this._alignImgs(i)},t.prototype._monitorImages=function(){var t,e,n=this.throttleAlign.bind(this),a=c.querySelectorAll(this.results_selector),i=a.length;function o(t){t.originalTarget.src=s.searxng.static_path+s.searxng.theme.img_load_error}for(t=0;t<i;t++)null==(e=a[t].querySelector(this.img_selector))||e.classList.contains("aligned")||(e.addEventListener("load",n),e.addEventListener("error",n),e.addEventListener("timeout",n),s.searxng.theme.img_load_error&&e.addEventListener("error",o,{once:!0}),e.classList.add("aligned"))},t.prototype.watch=function(){var t=this.throttleAlign.bind(this);s.addEventListener("pageshow",t),s.addEventListener("load",t),s.addEventListener("resize",t),this._monitorImages();var a=this;let e=new MutationObserver(e=>{let n=!1;for(let t=0;t<e.length;t++)if(0<e[t].addedNodes.length&&e[t].addedNodes[0].classList.contains("result")){n=!0;break}n&&a._monitorImages()});e.observe(c.querySelector(this.container_selector),{childList:!0,subtree:!0,attributes:!1,characterData:!1})},s.searxng.ImageLayout=t}(window,document),
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * @license
 | 
					 * @license
 | 
				
			||||||
 * (C) Copyright Contributors to the SearXNG project.
 | 
					 * (C) Copyright Contributors to the SearXNG project.
 | 
				
			||||||
@ -64,7 +64,7 @@ window.addEventListener("load",function(){$(".infobox").each(function(){var t=$(
 | 
				
			|||||||
 * (C) 2014 by Thomas Pointhuber, <thomas.pointhuber@gmx.at>
 | 
					 * (C) 2014 by Thomas Pointhuber, <thomas.pointhuber@gmx.at>
 | 
				
			||||||
 * SPDX-License-Identifier: AGPL-3.0-or-later
 | 
					 * SPDX-License-Identifier: AGPL-3.0-or-later
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
$(document).ready(function(){$(".searxng_init_map").on("click",function(t){var e=$(this).data("leaflet-target"),n=$(this).data("map-lon"),a=$(this).data("map-lat"),i=$(this).data("map-zoom"),o=$(this).data("map-boundingbox"),s=$(this).data("map-geojson"),r=(o&&(southWest=L.latLng(o[0],o[2]),northEast=L.latLng(o[1],o[3]),map_bounds=L.latLngBounds(southWest,northEast)),L.Icon.Default.imagePath="./static/themes/oscar/css/images/",L.map(e)),o=new L.TileLayer("https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",{minZoom:1,maxZoom:19,attribution:'Map data © <a href="https://openstreetmap.org">OpenStreetMap</a> contributors'}),e=(new L.TileLayer("https://maps.wikimedia.org/osm-intl/{z}/{x}/{y}.png",{minZoom:1,maxZoom:19,attribution:'Wikimedia maps beta | Maps data © <a href="https://openstreetmap.org">OpenStreetMap</a> contributors'}),setTimeout(function(){map_bounds?r.fitBounds(map_bounds,{maxZoom:17}):n&&a&&(i?r.setView(new L.LatLng(a,n),i):r.setView(new L.LatLng(a,n),8))},0),r.addLayer(o),{"OSM Mapnik":o});L.control.layers(e).addTo(r),s&&L.geoJson(s).addTo(r),$(this).off(t)})}),
 | 
					$(document).ready(function(){$(".searxng_init_map").on("click",function(t){var e=$(this).data("leaflet-target"),n=$(this).data("map-lon"),a=$(this).data("map-lat"),i=$(this).data("map-zoom"),o=$(this).data("map-boundingbox"),s=$(this).data("map-geojson");o&&(southWest=L.latLng(o[0],o[2]),northEast=L.latLng(o[1],o[3]),map_bounds=L.latLngBounds(southWest,northEast)),L.Icon.Default.imagePath="./static/themes/oscar/css/images/";var r=L.map(e),e=new L.TileLayer("https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",{minZoom:1,maxZoom:19,attribution:'Map data © <a href="https://openstreetmap.org">OpenStreetMap</a> contributors'});new L.TileLayer("https://maps.wikimedia.org/osm-intl/{z}/{x}/{y}.png",{minZoom:1,maxZoom:19,attribution:'Wikimedia maps beta | Maps data © <a href="https://openstreetmap.org">OpenStreetMap</a> contributors'});setTimeout(function(){map_bounds?r.fitBounds(map_bounds,{maxZoom:17}):n&&a&&(i?r.setView(new L.LatLng(a,n),i):r.setView(new L.LatLng(a,n),8))},0),r.addLayer(e),L.control.layers({"OSM Mapnik":e}).addTo(r),s&&L.geoJson(s).addTo(r),$(this).off(t)})}),
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * @license
 | 
					 * @license
 | 
				
			||||||
 * (C) Copyright Contributors to the SearXNG project.
 | 
					 * (C) Copyright Contributors to the SearXNG project.
 | 
				
			||||||
 | 
				
			|||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										2
									
								
								searx/static/themes/simple/js/searxng.min.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								searx/static/themes/simple/js/searxng.min.js
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							@ -13,3 +13,7 @@
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					input.checkbox-onoff[type="checkbox"]::before {
 | 
				
			||||||
 | 
					  transition: left 0.25s;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -96,10 +96,13 @@
 | 
				
			|||||||
  --color-toolkit-select-border: #ddd;
 | 
					  --color-toolkit-select-border: #ddd;
 | 
				
			||||||
  --color-toolkit-select-background-hover: #bbb;
 | 
					  --color-toolkit-select-background-hover: #bbb;
 | 
				
			||||||
  --color-toolkit-input-text-font: #222;
 | 
					  --color-toolkit-input-text-font: #222;
 | 
				
			||||||
  --color-toolkit-checkbox-onoff-background: #ddd;
 | 
					  --color-toolkit-checkbox-onoff-off-background: #ddd;
 | 
				
			||||||
  --color-toolkit-checkbox-onoff-label-background: #3050ff;
 | 
					  --color-toolkit-checkbox-onoff-on-background: #ddd;
 | 
				
			||||||
  --color-toolkit-checkbox-onoff-checked-background: #aaa;
 | 
					  --color-toolkit-checkbox-onoff-on-mark-background: #3050ff;
 | 
				
			||||||
  --color-toolkit-checkbox-label-background: #fff;
 | 
					  --color-toolkit-checkbox-onoff-on-mark-color: #fff;
 | 
				
			||||||
 | 
					  --color-toolkit-checkbox-onoff-off-mark-background: #aaa;
 | 
				
			||||||
 | 
					  --color-toolkit-checkbox-onoff-off-mark-color: #fff;
 | 
				
			||||||
 | 
					  --color-toolkit-checkbox-label-background: #ddd;
 | 
				
			||||||
  --color-toolkit-checkbox-label-border: #ddd;
 | 
					  --color-toolkit-checkbox-label-border: #ddd;
 | 
				
			||||||
  --color-toolkit-checkbox-input-border: #3050ff;
 | 
					  --color-toolkit-checkbox-input-border: #3050ff;
 | 
				
			||||||
  --color-toolkit-engine-tooltip-border: #ddd;
 | 
					  --color-toolkit-engine-tooltip-border: #ddd;
 | 
				
			||||||
@ -199,10 +202,13 @@
 | 
				
			|||||||
  --color-toolkit-select-border: #555;
 | 
					  --color-toolkit-select-border: #555;
 | 
				
			||||||
  --color-toolkit-select-background-hover: #333;
 | 
					  --color-toolkit-select-background-hover: #333;
 | 
				
			||||||
  --color-toolkit-input-text-font: #fff;
 | 
					  --color-toolkit-input-text-font: #fff;
 | 
				
			||||||
  --color-toolkit-checkbox-onoff-background: #3c3b31;
 | 
					  --color-toolkit-checkbox-onoff-off-background: #3c3b31;
 | 
				
			||||||
  --color-toolkit-checkbox-onoff-label-background: #58f;
 | 
					  --color-toolkit-checkbox-onoff-on-background: #3c3b31;
 | 
				
			||||||
  --color-toolkit-checkbox-onoff-checked-background: #ddd;
 | 
					  --color-toolkit-checkbox-onoff-on-mark-background: #58f;
 | 
				
			||||||
  --color-toolkit-checkbox-label-background: #fff;
 | 
					  --color-toolkit-checkbox-onoff-on-mark-color: #222;
 | 
				
			||||||
 | 
					  --color-toolkit-checkbox-onoff-off-mark-background: #ddd;
 | 
				
			||||||
 | 
					  --color-toolkit-checkbox-onoff-off-mark-color: #222;
 | 
				
			||||||
 | 
					  --color-toolkit-checkbox-label-background: #222;
 | 
				
			||||||
  --color-toolkit-checkbox-label-border: #333;
 | 
					  --color-toolkit-checkbox-label-border: #333;
 | 
				
			||||||
  --color-toolkit-checkbox-input-border: #58f;
 | 
					  --color-toolkit-checkbox-input-border: #58f;
 | 
				
			||||||
  --color-toolkit-engine-tooltip-border: #333;
 | 
					  --color-toolkit-engine-tooltip-border: #333;
 | 
				
			||||||
 | 
				
			|||||||
@ -80,6 +80,55 @@
 | 
				
			|||||||
    text-align: center;
 | 
					    text-align: center;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .category {
 | 
				
			||||||
 | 
					    .ltr-margin-right(0.5rem);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    label {
 | 
				
			||||||
 | 
					      border: 2px solid transparent;
 | 
				
			||||||
 | 
					      padding: 0.2rem 0.4rem;
 | 
				
			||||||
 | 
					      .rounded-corners-tiny;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .category input[type="checkbox"]:checked + label {
 | 
				
			||||||
 | 
					    border: 2px solid var(--color-categories-item-border-selected);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  table.table_engines {
 | 
				
			||||||
 | 
					    td {
 | 
				
			||||||
 | 
					      height: 3.75rem;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    th.name {
 | 
				
			||||||
 | 
					      /* stylelint-disable */
 | 
				
			||||||
 | 
					      label {
 | 
				
			||||||
 | 
					        cursor: pointer;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      /* stylelint-enable */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      .engine-tooltip {
 | 
				
			||||||
 | 
					        margin-top: 1.8rem;
 | 
				
			||||||
 | 
					        .ltr-left(calc((100% - 85em) / 2 + 10em));
 | 
				
			||||||
 | 
					        max-width: 40rem;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        .engine-description {
 | 
				
			||||||
 | 
					          margin-top: 0.5rem;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .engine-group {
 | 
				
			||||||
 | 
					      .ltr-text-align-left();
 | 
				
			||||||
 | 
					      font-weight: normal;
 | 
				
			||||||
 | 
					      background: var(--color-settings-engine-group-background);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .name,
 | 
				
			||||||
 | 
					    .shortcut {
 | 
				
			||||||
 | 
					      .ltr-text-align-left();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  table.cookies {
 | 
					  table.cookies {
 | 
				
			||||||
    width: 100%;
 | 
					    width: 100%;
 | 
				
			||||||
    direction: ltr;
 | 
					    direction: ltr;
 | 
				
			||||||
@ -109,25 +158,6 @@
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .category {
 | 
					 | 
				
			||||||
    .ltr-margin-right(0.5rem);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    label {
 | 
					 | 
				
			||||||
      border: 2px solid transparent;
 | 
					 | 
				
			||||||
      padding: 0.2rem 0.4rem;
 | 
					 | 
				
			||||||
      .rounded-corners-tiny;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  .category input[type="checkbox"]:checked + label {
 | 
					 | 
				
			||||||
    border: 2px solid var(--color-categories-item-border-selected);
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  .name,
 | 
					 | 
				
			||||||
  .shortcut {
 | 
					 | 
				
			||||||
    .ltr-text-align-left();
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  .preferences_back {
 | 
					  .preferences_back {
 | 
				
			||||||
    background: none repeat scroll 0 0 var(--color-btn-background);
 | 
					    background: none repeat scroll 0 0 var(--color-btn-background);
 | 
				
			||||||
    color: var(--color-btn-font);
 | 
					    color: var(--color-btn-font);
 | 
				
			||||||
@ -153,24 +183,6 @@
 | 
				
			|||||||
      width: 100%;
 | 
					      width: 100%;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					 | 
				
			||||||
  th.name {
 | 
					 | 
				
			||||||
    .engine-tooltip {
 | 
					 | 
				
			||||||
      margin-top: 1.8rem;
 | 
					 | 
				
			||||||
      .ltr-left(calc((100% - 85em) / 2 + 10em));
 | 
					 | 
				
			||||||
      max-width: 40rem;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      .engine-description {
 | 
					 | 
				
			||||||
        margin-top: 0.5rem;
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  .engine-group {
 | 
					 | 
				
			||||||
    .ltr-text-align-left();
 | 
					 | 
				
			||||||
    font-weight: normal;
 | 
					 | 
				
			||||||
    background: var(--color-settings-engine-group-background);
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@media screen and (max-width: @tablet) {
 | 
					@media screen and (max-width: @tablet) {
 | 
				
			||||||
 | 
				
			|||||||
@ -378,92 +378,126 @@ select {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* -- checkbox-onoff -- */
 | 
					/* -- checkbox-onoff -- */
 | 
				
			||||||
@supports (border-radius: 50px) {
 | 
					input.checkbox-onoff[type="checkbox"] {
 | 
				
			||||||
  .checkbox-onoff {
 | 
					  -webkit-appearance: none;
 | 
				
			||||||
    display: inline-block;
 | 
					  -moz-appearance: none;
 | 
				
			||||||
    width: 40px;
 | 
					  appearance: none;
 | 
				
			||||||
    height: 10px;
 | 
					  cursor: pointer;
 | 
				
			||||||
    background: var(--color-toolkit-checkbox-onoff-background);
 | 
					  display: inline-block;
 | 
				
			||||||
    margin: 8px 1rem;
 | 
					  width: 2.5em;
 | 
				
			||||||
    position: relative;
 | 
					  height: 0.7em;
 | 
				
			||||||
    border-radius: 50px;
 | 
					  box-shadow: none !important;
 | 
				
			||||||
 | 
					  margin: 0 16px;
 | 
				
			||||||
 | 
					  border-radius: 10px;
 | 
				
			||||||
 | 
					  position: relative;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    label {
 | 
					  /* focus & hover */
 | 
				
			||||||
      display: block;
 | 
					  &:focus,
 | 
				
			||||||
      width: 20px;
 | 
					  &:hover {
 | 
				
			||||||
      height: 20px;
 | 
					    outline: none;
 | 
				
			||||||
      position: absolute;
 | 
					  }
 | 
				
			||||||
      top: -5px;
 | 
					 | 
				
			||||||
      cursor: pointer;
 | 
					 | 
				
			||||||
      border-radius: 50px;
 | 
					 | 
				
			||||||
      transition: all 0.4s ease;
 | 
					 | 
				
			||||||
      left: 27px;
 | 
					 | 
				
			||||||
      background-color: var(--color-toolkit-checkbox-onoff-label-background);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    input[type=checkbox] {
 | 
					  &:focus::after {
 | 
				
			||||||
      visibility: hidden;
 | 
					    content: "";
 | 
				
			||||||
 | 
					    position: absolute;
 | 
				
			||||||
 | 
					    width: 3.5em;
 | 
				
			||||||
 | 
					    height: 1.65em;
 | 
				
			||||||
 | 
					    border: 1px solid var(--color-btn-background);
 | 
				
			||||||
 | 
					    border-radius: 12px;
 | 
				
			||||||
 | 
					    box-shadow: var(--color-btn-background) 0 0 3px;
 | 
				
			||||||
 | 
					    z-index: 10000;
 | 
				
			||||||
 | 
					    top: -0.55em;
 | 
				
			||||||
 | 
					    left: -0.6em;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      &:checked + label {
 | 
					  &::before {
 | 
				
			||||||
        left: -5px;
 | 
					    position: absolute;
 | 
				
			||||||
        background: var(--color-toolkit-checkbox-onoff-checked-background);
 | 
					    top: -0.5em;
 | 
				
			||||||
      }
 | 
					    display: flex;
 | 
				
			||||||
    }
 | 
					    justify-content: center;
 | 
				
			||||||
 | 
					    align-items: center;
 | 
				
			||||||
 | 
					    font-size: 0.75em;
 | 
				
			||||||
 | 
					    width: 1.875em;
 | 
				
			||||||
 | 
					    height: 1.875em;
 | 
				
			||||||
 | 
					    border-radius: 50%;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* check mark
 | 
				
			||||||
 | 
					reversed-checkbox displays unchecked checkedboxes as checked, and vice versa.
 | 
				
			||||||
 | 
					see https://github.com/searxng/searxng/blob/3408d061aab9abc6168fec9bbc6deab71b236dac/searx/templates/simple/preferences.html#L313
 | 
				
			||||||
 | 
					*/
 | 
				
			||||||
 | 
					input.checkbox-onoff[type="checkbox"],
 | 
				
			||||||
 | 
					.reversed-checkbox input.checkbox-onoff[type="checkbox"]:checked {
 | 
				
			||||||
 | 
					  background: var(--color-toolkit-checkbox-onoff-off-background);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  &::before {
 | 
				
			||||||
 | 
					    left: -0.5em;
 | 
				
			||||||
 | 
					    content: "\2715";
 | 
				
			||||||
 | 
					    color: var(--color-toolkit-checkbox-onoff-off-mark-color);
 | 
				
			||||||
 | 
					    background: var(--color-toolkit-checkbox-onoff-off-mark-background);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					input.checkbox-onoff[type="checkbox"]:checked,
 | 
				
			||||||
 | 
					.reversed-checkbox input.checkbox-onoff[type="checkbox"] {
 | 
				
			||||||
 | 
					  background: var(--color-toolkit-checkbox-onoff-on-background);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  &::before {
 | 
				
			||||||
 | 
					    left: calc(100% - 1.5em);
 | 
				
			||||||
 | 
					    content: "\2713";
 | 
				
			||||||
 | 
					    color: var(--color-toolkit-checkbox-onoff-on-mark-color);
 | 
				
			||||||
 | 
					    background: var(--color-toolkit-checkbox-onoff-on-mark-background);
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/* -- checkbox -- */
 | 
					/* -- checkbox -- */
 | 
				
			||||||
@supports (transform: rotate(-45deg)) {
 | 
					@supports (transform: rotate(-45deg)) {
 | 
				
			||||||
  .checkbox {
 | 
					  input[type=checkbox]:not(.checkbox-onoff) {
 | 
				
			||||||
 | 
					    -webkit-appearance: none;
 | 
				
			||||||
 | 
					    -moz-appearance: none;
 | 
				
			||||||
 | 
					    appearance: none;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    width: 20px;
 | 
					    width: 20px;
 | 
				
			||||||
 | 
					    height: 20px;
 | 
				
			||||||
 | 
					    cursor: pointer;
 | 
				
			||||||
    position: relative;
 | 
					    position: relative;
 | 
				
			||||||
    margin: 20px auto;
 | 
					    top: 0;
 | 
				
			||||||
 | 
					    left: 0;
 | 
				
			||||||
 | 
					    border: 2px solid var(--color-toolkit-checkbox-input-border);
 | 
				
			||||||
 | 
					    .rounded-corners(0.3em);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    label {
 | 
					    &::after {
 | 
				
			||||||
      width: 20px;
 | 
					      content: '';
 | 
				
			||||||
      height: 20px;
 | 
					      width: 9px;
 | 
				
			||||||
      cursor: pointer;
 | 
					      height: 5px;
 | 
				
			||||||
      position: absolute;
 | 
					      position: absolute;
 | 
				
			||||||
      top: 0;
 | 
					      top: 3px;
 | 
				
			||||||
      left: 0;
 | 
					      left: 2px;
 | 
				
			||||||
      background: var(--color-toolkit-checkbox-label-background);
 | 
					      border: 3px solid var(--color-toolkit-checkbox-label-border);
 | 
				
			||||||
      .rounded-corners;
 | 
					      border-top: none;
 | 
				
			||||||
 | 
					      border-right: none;
 | 
				
			||||||
      &::after {
 | 
					      background: transparent;
 | 
				
			||||||
        content: '';
 | 
					      opacity: 0;
 | 
				
			||||||
        width: 9px;
 | 
					      transform: rotate(-45deg);
 | 
				
			||||||
        height: 5px;
 | 
					 | 
				
			||||||
        position: absolute;
 | 
					 | 
				
			||||||
        top: 4px;
 | 
					 | 
				
			||||||
        left: 4px;
 | 
					 | 
				
			||||||
        border: 3px solid var(--color-toolkit-checkbox-label-border);
 | 
					 | 
				
			||||||
        border-top: none;
 | 
					 | 
				
			||||||
        border-right: none;
 | 
					 | 
				
			||||||
        background: transparent;
 | 
					 | 
				
			||||||
        opacity: 0;
 | 
					 | 
				
			||||||
        transform: rotate(-45deg);
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    input[type=checkbox] {
 | 
					    &:checked::after {
 | 
				
			||||||
      visibility: hidden;
 | 
					      border-color: var(--color-toolkit-checkbox-input-border);
 | 
				
			||||||
 | 
					      opacity: 1;
 | 
				
			||||||
      &:checked + label::after {
 | 
					 | 
				
			||||||
        border-color: var(--color-toolkit-checkbox-input-border);
 | 
					 | 
				
			||||||
        opacity: 1;
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // disabled : can''t be focused, show only the check mark
 | 
					  // disabled : can't be focused, show only the check mark
 | 
				
			||||||
    input[disabled] + label {
 | 
					  input[type=checkbox][disabled]:not(.checkbox-onoff) {
 | 
				
			||||||
      background-color: transparent !important;
 | 
					    border: inherit;
 | 
				
			||||||
      cursor: inherit;
 | 
					    background-color: transparent !important;
 | 
				
			||||||
    }
 | 
					    cursor: inherit;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // if not checked and possible to checked then display a "light" check mark on hover
 | 
					  // if not checked and possible to checked then display a "light" check mark on hover
 | 
				
			||||||
    input:not(:checked):not([readonly]):not([disabled]) + label:hover::after {
 | 
					  input.checkbox[type=checkbox]:not(:checked):not([disabled]):not(.checkbox-onoff):hover::after {
 | 
				
			||||||
      opacity: 0.5;
 | 
					    opacity: 0.5;
 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -72,19 +72,13 @@
 | 
				
			|||||||
{%- endmacro -%}
 | 
					{%- endmacro -%}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
{%- macro checkbox_onoff(name, checked) -%}
 | 
					{%- macro checkbox_onoff(name, checked) -%}
 | 
				
			||||||
<div class="checkbox-onoff">{{- '' -}}
 | 
					  <input type="checkbox" name="{{ name }}" id="{{ name }}" value="None" class="checkbox-onoff" {% if checked %}checked{% endif %} />
 | 
				
			||||||
    <input type="checkbox" value="None" id="{{ name }}" name="{{ name }}" {% if checked %}checked{% endif %}/>{{- '' -}}
 | 
					 | 
				
			||||||
    <label for="{{ name }}"></label>{{- '' -}}
 | 
					 | 
				
			||||||
</div>
 | 
					 | 
				
			||||||
{%- endmacro -%}
 | 
					{%- endmacro -%}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
{%- macro checkbox(name, checked, readonly, disabled) -%}
 | 
					{%- macro checkbox(name, checked, disabled) -%}
 | 
				
			||||||
<div class="checkbox">{{- '' -}}
 | 
					{%- if checked == '?' -%}
 | 
				
			||||||
    {%- if checked == '?' -%}
 | 
					  {{- icon_small('warning') -}}
 | 
				
			||||||
      {{ icon_small('warning') }}
 | 
					{%- else -%}
 | 
				
			||||||
    {%- else -%}
 | 
					  <input type="checkbox"{% if name %} name="{{ name }}"{% endif %} value="None"{% if checked %} checked{% endif %}{% if disabled %} disabled{% endif %} />
 | 
				
			||||||
      <input type="checkbox" value="None" id="{{ name }}" name="{{ name }}" {% if checked %}checked{% endif %}{% if readonly %} readonly="readonly" {% endif %}{% if disabled %} disabled="disabled" {% endif %}/>{{- '' -}}
 | 
					{%- endif -%}
 | 
				
			||||||
      <label for="{{ name }}"></label>{{- '' -}}
 | 
					 | 
				
			||||||
    {%- endif -%}
 | 
					 | 
				
			||||||
</div>
 | 
					 | 
				
			||||||
{%- endmacro -%}
 | 
					{%- endmacro -%}
 | 
				
			||||||
 | 
				
			|||||||
@ -23,13 +23,13 @@
 | 
				
			|||||||
{% if search_engine.about is defined %}
 | 
					{% if search_engine.about is defined %}
 | 
				
			||||||
{% set about = search_engine.about %}
 | 
					{% set about = search_engine.about %}
 | 
				
			||||||
<div class="engine-tooltip" role="tooltip">{{- "" -}}
 | 
					<div class="engine-tooltip" role="tooltip">{{- "" -}}
 | 
				
			||||||
    <p class="engine-description"></p>
 | 
					    <p class="engine-description"></p>{{- "" -}}
 | 
				
			||||||
    <p><a href="{{about.website}}" rel="noreferrer">{{about.website}}</a></p>
 | 
					    <p><a href="{{about.website}}" rel="noreferrer">{{about.website}}</a></p>
 | 
				
			||||||
    {%- if about.wikidata_id -%}<p><a href="https://www.wikidata.org/wiki/{{about.wikidata_id}}" rel="noreferrer">wikidata.org/wiki/{{about.wikidata_id}}</a></p>{%- endif -%}
 | 
					    {%- if about.wikidata_id -%}<p><a href="https://www.wikidata.org/wiki/{{about.wikidata_id}}" rel="noreferrer">wikidata.org/wiki/{{about.wikidata_id}}</a></p>{%- endif -%}
 | 
				
			||||||
    {%- if search_engine.enable_http %}<p>{{ icon_big('exclamation-sign', 'No HTTPS') }}{{ _('No HTTPS')}}</p>{% endif -%}
 | 
					    {%- if search_engine.enable_http %}<p>{{ icon_big('exclamation-sign', 'No HTTPS') }}{{ _('No HTTPS')}}</p>{% endif -%}
 | 
				
			||||||
    {%- if reliabilities.get(search_engine.name, {}).errors or reliabilities.get(search_engine.name, {}).checker -%}
 | 
					    {%- if reliabilities.get(search_engine.name, {}).errors or reliabilities.get(search_engine.name, {}).checker -%}
 | 
				
			||||||
    <a href="{{ url_for('stats', engine=search_engine.name|e) }}" title="{{ _('View error logs and submit a bug report') }}">
 | 
					    <a href="{{ url_for('stats', engine=search_engine.name|e) }}" title="{{ _('View error logs and submit a bug report') }}">
 | 
				
			||||||
      {{ _('View error logs and submit a bug report') }}
 | 
					      {{ _('View error logs and submit a bug report') -}}
 | 
				
			||||||
    </a>
 | 
					    </a>
 | 
				
			||||||
    {%- endif -%}
 | 
					    {%- endif -%}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -89,7 +89,7 @@
 | 
				
			|||||||
    </div>{{- "" -}}
 | 
					    </div>{{- "" -}}
 | 
				
			||||||
</td>
 | 
					</td>
 | 
				
			||||||
{%- else -%}
 | 
					{%- else -%}
 | 
				
			||||||
<td class="{{ label }}"><span>{{ r }}</span></td>
 | 
					<td class="{{ label }}">{% if r %}<span>{{ r }}</span>{% endif %}</td>
 | 
				
			||||||
{%- endif -%}
 | 
					{%- endif -%}
 | 
				
			||||||
{%- endmacro -%}
 | 
					{%- endmacro -%}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -98,7 +98,7 @@
 | 
				
			|||||||
{% block content %}
 | 
					{% block content %}
 | 
				
			||||||
<h1>{{ _('Preferences') }}</h1>
 | 
					<h1>{{ _('Preferences') }}</h1>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<form id="search_form" method="post" action="{{ url_for('preferences') }}" autocomplete="off">
 | 
					<form id="search_form" method="post" action="{{ url_for('preferences') }}" autocomplete="off" class="reversed-checkbox">
 | 
				
			||||||
 | 
					
 | 
				
			||||||
{{ tabs_open() }}
 | 
					{{ tabs_open() }}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -182,9 +182,9 @@
 | 
				
			|||||||
      <legend>{{ _('Interface language') }}</legend>
 | 
					      <legend>{{ _('Interface language') }}</legend>
 | 
				
			||||||
      <p class="value">
 | 
					      <p class="value">
 | 
				
			||||||
        <select name='locale'>
 | 
					        <select name='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 -%}
 | 
				
			||||||
        </select>
 | 
					        </select>
 | 
				
			||||||
      </p>
 | 
					      </p>
 | 
				
			||||||
      <div class="description">{{ _('Change the language of the layout') }}</div>
 | 
					      <div class="description">{{ _('Change the language of the layout') }}</div>
 | 
				
			||||||
@ -290,17 +290,17 @@
 | 
				
			|||||||
      <p>{{_('This tab does not show up for search results, but you can search the engines listed here via bangs.')}}</p>
 | 
					      <p>{{_('This tab does not show up for search results, but you can search the engines listed here via bangs.')}}</p>
 | 
				
			||||||
    {% endif %}
 | 
					    {% endif %}
 | 
				
			||||||
    <div class="scrollx">
 | 
					    <div class="scrollx">
 | 
				
			||||||
    <table class="striped">
 | 
					    <table class="striped table_engines">
 | 
				
			||||||
      <tr>
 | 
					      <tr>{{- "" -}}
 | 
				
			||||||
        <th class="engine_checkbox">{{ _("Allow") }}</th>
 | 
					        <th class="engine_checkbox">{{ _("Allow") }}</th>{{- "" -}}
 | 
				
			||||||
        <th class="name">{{ _("Engine name") }}</th>
 | 
					        <th class="name">{{ _("Engine name") }}</th>{{- "" -}}
 | 
				
			||||||
        <th class="shortcut">{{ _("Shortcut") }}</th>
 | 
					        <th class="shortcut">{{ _("Shortcut") }}</th>{{- "" -}}
 | 
				
			||||||
        <th>{{ _("Supports selected language") }}</th>
 | 
					        <th>{{ _("Supports selected language") }}</th>{{- "" -}}
 | 
				
			||||||
        <th>{{ _("SafeSearch") }}</th>
 | 
					        <th>{{ _("SafeSearch") }}</th>{{- "" -}}
 | 
				
			||||||
        <th>{{ _("Time range") }}</th>
 | 
					        <th>{{ _("Time range") }}</th>{{- "" -}}
 | 
				
			||||||
        <th>{{ _("Response time") }}</th>
 | 
					        <th>{{ _("Response time") }}</th>{{- "" -}}
 | 
				
			||||||
        <th>{{ _("Max time") }}</th>
 | 
					        <th>{{ _("Max time") }}</th>{{- "" -}}
 | 
				
			||||||
        <th>{{ _("Reliability") }}</th>
 | 
					        <th>{{ _("Reliability") }}</th>{{- "" -}}
 | 
				
			||||||
      </tr>
 | 
					      </tr>
 | 
				
			||||||
      {% for group, engines in engines_by_category[categ] | group_engines_in_tab %}
 | 
					      {% for group, engines in engines_by_category[categ] | group_engines_in_tab %}
 | 
				
			||||||
      {% if loop.length > 1 %}
 | 
					      {% if loop.length > 1 %}
 | 
				
			||||||
@ -309,22 +309,24 @@
 | 
				
			|||||||
      {% for search_engine in engines %}
 | 
					      {% for search_engine in engines %}
 | 
				
			||||||
      {% if not search_engine.private %}
 | 
					      {% if not search_engine.private %}
 | 
				
			||||||
      {% set engine_id = 'engine_' + search_engine.name|replace(' ', '_') + '__' + categ|replace(' ', '_') %}
 | 
					      {% set engine_id = 'engine_' + search_engine.name|replace(' ', '_') + '__' + categ|replace(' ', '_') %}
 | 
				
			||||||
      <tr>
 | 
					      <tr>{{- "" -}}
 | 
				
			||||||
        <td class="engine_checkbox">{{ checkbox_onoff(engine_id, (search_engine.name, categ) in disabled_engines) }}</td>
 | 
					        <td>{{ checkbox_onoff(engine_id, (search_engine.name, categ) in disabled_engines) }}</td>{{- "" -}}
 | 
				
			||||||
        <th class="name" data-engine-name="{{ search_engine.name }}">{% if search_engine.enable_http %}{{ icon_big('warning', 'No HTTPS') }}{% endif %}
 | 
					        <th class="name" data-engine-name="{{ search_engine.name }}">{% if search_engine.enable_http %}{{ icon_big('warning', 'No HTTPS') }}{% endif -%}
 | 
				
			||||||
          {{ search_engine.name }}
 | 
					          <label for="{{ engine_id }}">
 | 
				
			||||||
          {%- if search_engine.about and search_engine.about.language %}
 | 
					            {{- search_engine.name -}}
 | 
				
			||||||
 | 
					            {%- if search_engine.about and search_engine.about.language -%}
 | 
				
			||||||
              ({{search_engine.about.language | upper}})
 | 
					              ({{search_engine.about.language | upper}})
 | 
				
			||||||
          {%- endif %}
 | 
					            {%- endif -%}
 | 
				
			||||||
          {{ engine_about(search_engine) }}
 | 
					          </label>
 | 
				
			||||||
        </th>
 | 
					          {{- engine_about(search_engine) -}}
 | 
				
			||||||
        <td class="shortcut">{{ shortcuts[search_engine.name] }}</td>
 | 
					        </th>{{- "" -}}
 | 
				
			||||||
        <td>{{ checkbox(engine_id + '_supported_languages', supports[search_engine.name]['supports_selected_language'], true, true) }}</td>
 | 
					        <td class="shortcut">{{ shortcuts[search_engine.name] }}</td>{{- "" -}}
 | 
				
			||||||
        <td>{{ checkbox(engine_id + '_safesearch', supports[search_engine.name]['safesearch'], true, true) }}</td>
 | 
					        <td>{{ checkbox(None, supports[search_engine.name]['supports_selected_language'], true) }}</td>{{- "" -}}
 | 
				
			||||||
        <td>{{ checkbox(engine_id + '_time_range_support', supports[search_engine.name]['time_range_support'], true, true) }}</td>
 | 
					        <td>{{ checkbox(None, supports[search_engine.name]['safesearch'], true) }}</td>{{- "" -}}
 | 
				
			||||||
        {{ engine_time(search_engine.name) }}
 | 
					        <td>{{ checkbox(None, supports[search_engine.name]['time_range_support'], true) }}</td>{{- "" -}}
 | 
				
			||||||
        <td class="{{ 'danger' if stats[search_engine.name]['warn_timeout'] else '' }}">{{ search_engine.timeout }}</td>
 | 
					        {{- engine_time(search_engine.name) -}}
 | 
				
			||||||
        {{ engine_reliability(search_engine.name) }}
 | 
					        <td class="{{ 'danger' if stats[search_engine.name]['warn_timeout'] else '' }}">{{ search_engine.timeout }}</td>{{- "" -}}
 | 
				
			||||||
 | 
					        {{ engine_reliability(search_engine.name) -}}
 | 
				
			||||||
      </tr>
 | 
					      </tr>
 | 
				
			||||||
      {% endif %}
 | 
					      {% endif %}
 | 
				
			||||||
      {% endfor %}
 | 
					      {% endfor %}
 | 
				
			||||||
@ -377,20 +379,20 @@
 | 
				
			|||||||
  {{ tab_footer() }}
 | 
					  {{ tab_footer() }}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  {{ tab_header('maintab', 'cookies', _('Cookies')) }}
 | 
					  {{ tab_header('maintab', 'cookies', _('Cookies')) }}
 | 
				
			||||||
     <p class="text-muted">
 | 
					     <p class="text-muted">{{- "" -}}
 | 
				
			||||||
        {{ _('This is the list of cookies and their values SearXNG is storing on your computer.') }}<br />
 | 
					        {{- _('This is the list of cookies and their values SearXNG is storing on your computer.') }}<br />{{- "" -}}
 | 
				
			||||||
        {{ _('With that list, you can assess SearXNG transparency.') }}<br />
 | 
					        {{- _('With that list, you can assess SearXNG transparency.') }}<br />{{- "" -}}
 | 
				
			||||||
     </p>
 | 
					     </p>
 | 
				
			||||||
     {% if cookies %}
 | 
					     {% if cookies %}
 | 
				
			||||||
     <table class="cookies">
 | 
					     <table class="cookies">
 | 
				
			||||||
       <tr>
 | 
					       <tr>{{- "" -}}
 | 
				
			||||||
          <th>{{ _('Cookie name') }}</th>
 | 
					          <th>{{ _('Cookie name') }}</th>{{- "" -}}
 | 
				
			||||||
          <th>{{ _('Value') }}</th>
 | 
					          <th>{{ _('Value') }}</th>{{- "" -}}
 | 
				
			||||||
       </tr>
 | 
					       </tr>
 | 
				
			||||||
       {% for cookie in cookies %}
 | 
					       {% for cookie in cookies %}
 | 
				
			||||||
       <tr>
 | 
					       <tr>{{- "" -}}
 | 
				
			||||||
          <td>{{ cookie }}</td>
 | 
					          <td>{{ cookie }}</td>{{- "" -}}
 | 
				
			||||||
          <td>{{ cookies[cookie] }}</td>
 | 
					          <td>{{ cookies[cookie] }}</td>{{- "" -}}
 | 
				
			||||||
       </tr>
 | 
					       </tr>
 | 
				
			||||||
       {% endfor %}
 | 
					       {% endfor %}
 | 
				
			||||||
     </table>
 | 
					     </table>
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user