forked from zaclys/searxng
		
	Merge branch 'master' of https://github.com/asciimoo/searx into feature/seedpeer-engine-integration
This commit is contained in:
		
						commit
						41ce76e9c9
					
				
					 27 changed files with 82 additions and 43 deletions
				
			
		|  | @ -227,7 +227,8 @@ class Preferences(object): | ||||||
|                                    'safesearch': MapSetting(settings['search']['safe_search'], map={'0': 0, |                                    'safesearch': MapSetting(settings['search']['safe_search'], map={'0': 0, | ||||||
|                                                                                                     '1': 1, |                                                                                                     '1': 1, | ||||||
|                                                                                                     '2': 2}), |                                                                                                     '2': 2}), | ||||||
|                                    'theme': EnumStringSetting(settings['ui']['default_theme'], choices=themes)} |                                    'theme': EnumStringSetting(settings['ui']['default_theme'], choices=themes), | ||||||
|  |                                    'results_on_new_tab': MapSetting(False, map={'0': False, '1': True})} | ||||||
| 
 | 
 | ||||||
|         self.engines = EnginesSetting('engines', choices=engines) |         self.engines = EnginesSetting('engines', choices=engines) | ||||||
|         self.plugins = PluginsSetting('plugins', choices=plugins) |         self.plugins = PluginsSetting('plugins', choices=plugins) | ||||||
|  |  | ||||||
|  | @ -2,6 +2,8 @@ | ||||||
| {% block content %} | {% block content %} | ||||||
| <div class="center"> | <div class="center"> | ||||||
|     <h1>{{ _('Page not found') }}</h1> |     <h1>{{ _('Page not found') }}</h1> | ||||||
|     <p>{{ _('Go to <a href="/">search page</a>.') }}</p> |     {% autoescape false %} | ||||||
|  |     <p>{{ _('Go to %(search_page)s.', search_page='<a href="{}">{}</a>'.decode('utf-8').format(url_for('index'), _('search page'))) }}</p> | ||||||
|  |     {% endautoescape %} | ||||||
| </div> | </div> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|  |  | ||||||
|  | @ -1,8 +1,8 @@ | ||||||
| <div class="result {{ result.class }}"> | <div class="result {{ result.class }}"> | ||||||
|     <h3 class="result_title">{% if result['favicon'] %}<img width="14" height="14" class="favicon" src="static/{{theme}}/img/icon_{{result['favicon']}}.ico" alt="{{result['favicon']}}" />{% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |     <h3 class="result_title">{% if result['favicon'] %}<img width="14" height="14" class="favicon" src="static/{{theme}}/img/icon_{{result['favicon']}}.ico" alt="{{result['favicon']}}" />{% endif %}<a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %} |     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %} | ||||||
|     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p> |     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p> | ||||||
|     {% if result.repository %}<p class="content"><a href="{{ result.repository|safe }}" rel="noreferrer">{{ result.repository }}</a></p>{% endif %} |     {% if result.repository %}<p class="content"><a href="{{ result.repository|safe }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.repository }}</a></p>{% endif %} | ||||||
|     <div dir="ltr"> |     <div dir="ltr"> | ||||||
|     {{ result.codelines|code_highlighter(result.code_language)|safe }} |     {{ result.codelines|code_highlighter(result.code_language)|safe }} | ||||||
| 	</div> | 	</div> | ||||||
|  |  | ||||||
|  | @ -5,7 +5,7 @@ | ||||||
|     {% endif %} |     {% endif %} | ||||||
| 
 | 
 | ||||||
|     <div> |     <div> | ||||||
|         <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |         <h3 class="result_title"><a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %} |         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %} | ||||||
|         <p class="content">{% if result.content %}{{ result.content|safe }}<br />{% endif %}</p> |         <p class="content">{% if result.content %}{{ result.content|safe }}<br />{% endif %}</p> | ||||||
|         <p class="url">{{ result.pretty_url }}‎</p> |         <p class="url">{{ result.pretty_url }}‎</p> | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| <div class="image_result"> | <div class="image_result"> | ||||||
|     <p> |     <p> | ||||||
|         <a href="{{ result.img_src }}" rel="noreferrer"><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a> |         <a href="{{ result.img_src }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a> | ||||||
|         <span class="url"><a href="{{ result.url }}" rel="noreferrer" class="small_font">{{ _('original context') }}</a></span> |         <span class="url"><a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %} class="small_font">{{ _('original context') }}</a></span> | ||||||
|     </p> |     </p> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | @ -5,7 +5,7 @@ | ||||||
|     {% endif %} |     {% endif %} | ||||||
| 
 | 
 | ||||||
|     <div> |     <div> | ||||||
|         <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |         <h3 class="result_title"><a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %} |         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %} | ||||||
|         <p class="content">{% if result.content %}{{ result.content|safe }}<br />{% endif %}</p> |         <p class="content">{% if result.content %}{{ result.content|safe }}<br />{% endif %}</p> | ||||||
|         <p class="url">{{ result.pretty_url }}‎</p> |         <p class="url">{{ result.pretty_url }}‎</p> | ||||||
|  |  | ||||||
|  | @ -2,12 +2,12 @@ | ||||||
|     {% if "icon_"~result.engine~".ico" in favicons %} |     {% if "icon_"~result.engine~".ico" in favicons %} | ||||||
|     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" /> |     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" /> | ||||||
|     {% endif %} |     {% endif %} | ||||||
|     <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |     <h3 class="result_title"><a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|     {% if result.content %}<span class="content">{{ result.content|safe }}</span><br />{% endif %} |     {% if result.content %}<span class="content">{{ result.content|safe }}</span><br />{% endif %} | ||||||
|     <span class="stats">{{ _('Seeder') }} : {{ result.seed }}, {{ _('Leecher') }} : {{ result.leech }}</span><br /> |     <span class="stats">{{ _('Seeder') }} : {{ result.seed }}, {{ _('Leecher') }} : {{ result.leech }}</span><br /> | ||||||
|     <span> |     <span> | ||||||
|         {% if result.magnetlink %}<a href="{{ result.magnetlink }}" class="magnetlink">{{ _('magnet link') }}</a>{% endif %}  |         {% if result.magnetlink %}<a href="{{ result.magnetlink }}" class="magnetlink">{{ _('magnet link') }}</a>{% endif %}  | ||||||
|         {% if result.torrentfile %}<a href="{{ result.torrentfile }}" class="torrentfile" rel="noreferrer">{{ _('torrent file') }}</a>{% endif %} |         {% if result.torrentfile %}<a href="{{ result.torrentfile }}" class="torrentfile" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ _('torrent file') }}</a>{% endif %} | ||||||
|     </span> |     </span> | ||||||
|     <p class="url">{{ result.pretty_url }}‎</p> |     <p class="url">{{ result.pretty_url }}‎</p> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | @ -3,8 +3,8 @@ | ||||||
|     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" /> |     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" /> | ||||||
| 	{% endif %} | 	{% endif %} | ||||||
| 
 | 
 | ||||||
|     <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |     <h3 class="result_title"><a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span><br />{% endif %} |     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span><br />{% endif %} | ||||||
|     <a href="{{ result.url }}" rel="noreferrer"><img width="400" src="{{ image_proxify(result.thumbnail) }}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a> |     <a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}><img width="400" src="{{ image_proxify(result.thumbnail) }}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a> | ||||||
|     <p class="url">{{ result.pretty_url }}‎</p> |     <p class="url">{{ result.pretty_url }}‎</p> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | @ -2,6 +2,8 @@ | ||||||
| {% block content %} | {% block content %} | ||||||
| <div class="center"> | <div class="center"> | ||||||
|     <h1>{{ _('Page not found') }}</h1> |     <h1>{{ _('Page not found') }}</h1> | ||||||
|     <p>{{ _('Go to <a href="/">search page</a>.') }}</p> |     {% autoescape false %} | ||||||
|  |     <p>{{ _('Go to %(search_page)s.', search_page='<a href="{}">{}</a>'.decode('utf-8').format(url_for('index'), _('search page'))) }}</p> | ||||||
|  |     {% endautoescape %} | ||||||
| </div> | </div> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|  |  | ||||||
|  | @ -24,7 +24,7 @@ | ||||||
|     <div class="urls"> |     <div class="urls"> | ||||||
|         <ul> |         <ul> | ||||||
|             {% for url in infobox.urls %} |             {% for url in infobox.urls %} | ||||||
|             <li class="url"><bdi><a href="{{ url.url }}" rel="noreferrer">{{ url.title }}</a></bdi></li> |             <li class="url"><bdi><a href="{{ url.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ url.title }}</a></bdi></li> | ||||||
|             {% endfor %} |             {% endfor %} | ||||||
|         </ul> |         </ul> | ||||||
|     </div> |     </div> | ||||||
|  |  | ||||||
|  | @ -80,6 +80,15 @@ | ||||||
|         </select> |         </select> | ||||||
|         </p> |         </p> | ||||||
|     </fieldset> |     </fieldset> | ||||||
|  |     <fieldset> | ||||||
|  |         <legend>{{ _('Results on new tabs') }}</legend> | ||||||
|  |         <p> | ||||||
|  |             <select name='results_on_new_tab'> | ||||||
|  |                 <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> | ||||||
|  |             </select> | ||||||
|  |         </p> | ||||||
|  |     </fieldset> | ||||||
|     <fieldset> |     <fieldset> | ||||||
|     <legend>{{ _('Currently used search engines') }}</legend> |     <legend>{{ _('Currently used search engines') }}</legend> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,9 +1,9 @@ | ||||||
| <div class="result {{ result.class }}"> | <div class="result {{ result.class }}"> | ||||||
|     <h3 class="result_title"> {% if result['favicon'] %}<img width="14" height="14" class="favicon" src="static/{{theme}}/img/icon_{{result['favicon']}}.ico" alt="{{result['favicon']}}" />{% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |     <h3 class="result_title"> {% if result['favicon'] %}<img width="14" height="14" class="favicon" src="static/{{theme}}/img/icon_{{result['favicon']}}.ico" alt="{{result['favicon']}}" />{% endif %}<a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|     <p class="url">{{ result.pretty_url }}‎ <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}" rel="noreferrer">{{ _('cached') }}</a></p> |     <p class="url">{{ result.pretty_url }}‎ <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ _('cached') }}</a></p> | ||||||
|     {% if result.publishedDate %}<p class="published_date">{{ result.publishedDate }}</p>{% endif %} |     {% if result.publishedDate %}<p class="published_date">{{ result.publishedDate }}</p>{% endif %} | ||||||
|     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p> |     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p> | ||||||
|     {% if result.repository %}<p class="result-content"><a href="{{ result.repository|safe }}" rel="noreferrer">{{ result.repository }}</a></p>{% endif %} |     {% if result.repository %}<p class="result-content"><a href="{{ result.repository|safe }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.repository }}</a></p>{% endif %} | ||||||
|      |      | ||||||
|     <div dir="ltr"> |     <div dir="ltr"> | ||||||
|     {{ result.codelines|code_highlighter(result.code_language)|safe }} |     {{ result.codelines|code_highlighter(result.code_language)|safe }} | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| <div class="result {{ result.class }}"> | <div class="result {{ result.class }}"> | ||||||
|     <h3 class="result_title">{% if "icon_"~result.engine~".ico" in favicons %}<img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />{% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |     <h3 class="result_title">{% if "icon_"~result.engine~".ico" in favicons %}<img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />{% endif %}<a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|     <p class="url">{{ result.pretty_url }}‎ <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}" rel="noreferrer">{{ _('cached') }}</a> |     <p class="url">{{ result.pretty_url }}‎ <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ _('cached') }}</a> | ||||||
|     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}</p> |     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}</p> | ||||||
|     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p> |     <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| <div class="image_result"> | <div class="image_result"> | ||||||
|     <p> |     <p> | ||||||
|         <a href="{{ result.img_src }}" rel="noreferrer"><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}" /></a> |         <a href="{{ result.img_src }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}><img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}" /></a> | ||||||
|         <span class="url"><a href="{{ result.url }}" rel="noreferrer" class="small_font">{{ _('original context') }}</a></span> |         <span class="url"><a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %} class="small_font">{{ _('original context') }}</a></span> | ||||||
|     </p> |     </p> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | @ -5,8 +5,8 @@ | ||||||
|     {% endif %} |     {% endif %} | ||||||
| 
 | 
 | ||||||
|     <div> |     <div> | ||||||
|         <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |         <h3 class="result_title"><a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|         <p class="url">{{ result.pretty_url }}‎ <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}" rel="noreferrer">{{ _('cached') }}</a> |         <p class="url">{{ result.pretty_url }}‎ <a class="cache_link" href="https://web.archive.org/web/{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ _('cached') }}</a> | ||||||
|         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}</p> |         {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span>{% endif %}</p> | ||||||
|         <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p> |         <p class="content">{% if result.img_src %}<img src="{{ image_proxify(result.img_src) }}" class="image" />{% endif %}{% if result.content %}{{ result.content|safe }}<br class="last"/>{% endif %}</p> | ||||||
|     </div> |     </div> | ||||||
|  |  | ||||||
|  | @ -2,12 +2,12 @@ | ||||||
|   {% if "icon_"~result.engine~".ico" in favicons %} |   {% if "icon_"~result.engine~".ico" in favicons %} | ||||||
|     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" /> |     <img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" /> | ||||||
|   {% endif %} |   {% endif %} | ||||||
|     <h3 class="result_title"><a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |     <h3 class="result_title"><a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|     <p class="url">{{ result.pretty_url }}‎</p> |     <p class="url">{{ result.pretty_url }}‎</p> | ||||||
|     {% if result.content %}<p class="content">{{ result.content|safe }}</p>{% endif %} |     {% if result.content %}<p class="content">{{ result.content|safe }}</p>{% endif %} | ||||||
|     <p> |     <p> | ||||||
|         {% if result.magnetlink %}<a href="{{ result.magnetlink }}" class="magnetlink">{{ _('magnet link') }}</a>{% endif %}  |         {% if result.magnetlink %}<a href="{{ result.magnetlink }}" class="magnetlink">{{ _('magnet link') }}</a>{% endif %}  | ||||||
|         {% if result.torrentfile %}<a href="{{ result.torrentfile }}" rel="noreferrer" class="torrentfile">{{ _('torrent file') }}</a>{% endif %} -  |         {% if result.torrentfile %}<a href="{{ result.torrentfile }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %} class="torrentfile">{{ _('torrent file') }}</a>{% endif %} -  | ||||||
|         <span class="stats">{{ _('Seeder') }} : {{ result.seed }}, {{ _('Leecher') }} : {{ result.leech }}</span> |         <span class="stats">{{ _('Seeder') }} : {{ result.seed }}, {{ _('Leecher') }} : {{ result.leech }}</span> | ||||||
|     </p> |     </p> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| <div class="result"> | <div class="result"> | ||||||
|     <h3 class="result_title">{% if "icon_"~result.engine~".ico" in favicons %}<img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />{% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h3> |     <h3 class="result_title">{% if "icon_"~result.engine~".ico" in favicons %}<img width="14" height="14" class="favicon" src="{{ url_for('static', filename='img/icons/icon_'+result.engine+'.ico') }}" alt="{{result.engine}}" />{% endif %}<a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.title|safe }}</a></h3> | ||||||
|     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span><br />{% endif %} |     {% if result.publishedDate %}<span class="published_date">{{ result.publishedDate }}</span><br />{% endif %} | ||||||
|     <a href="{{ result.url }}" rel="noreferrer"><img class="thumbnail" src="{{ image_proxify(result.thumbnail) }}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a> |     <a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}><img class="thumbnail" src="{{ image_proxify(result.thumbnail) }}" title="{{ result.title|striptags }}" alt="{{ result.title|striptags }}"/></a> | ||||||
|     <p class="url">{{ result.url }}‎</p> |     <p class="url">{{ result.url }}‎</p> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | @ -2,6 +2,8 @@ | ||||||
| {% block content %} | {% block content %} | ||||||
| <div class="text-center"> | <div class="text-center"> | ||||||
|     <h1>{{ _('Page not found') }}</h1> |     <h1>{{ _('Page not found') }}</h1> | ||||||
|     <p>{{ _('Go to <a href="/">search page</a>.') }}</p> |     {% autoescape false %} | ||||||
|  |     <p>{{ _('Go to %(search_page)s.', search_page='<a href="{}">{}</a>'.decode('utf-8').format(url_for('index'), _('search page'))) }}</p> | ||||||
|  |     {% endautoescape %} | ||||||
| </div> | </div> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|  |  | ||||||
|  | @ -1,3 +1,4 @@ | ||||||
|  | {% from 'oscar/macros.html' import result_link with context %} | ||||||
| <div class="panel panel-default infobox"> | <div class="panel panel-default infobox"> | ||||||
|     <div class="panel-heading"> |     <div class="panel-heading"> | ||||||
|         <h4 class="panel-title infobox_part"><bdi>{{ infobox.infobox }}</bdi></h4> |         <h4 class="panel-title infobox_part"><bdi>{{ infobox.infobox }}</bdi></h4> | ||||||
|  | @ -25,7 +26,7 @@ | ||||||
|         <div class="infobox_part"> |         <div class="infobox_part"> | ||||||
|             <bdi> |             <bdi> | ||||||
|             {% for url in infobox.urls %} |             {% for url in infobox.urls %} | ||||||
|             <p class="btn btn-default btn-xs"><a href="{{ url.url }}" rel="noreferrer">{{ url.title }}</a></p> |             <p class="btn btn-default btn-xs">{{ result_link(url.url, url.title) }}</a></p> | ||||||
|             {% endfor %} |             {% endfor %} | ||||||
|             </bdi> |             </bdi> | ||||||
|         </div> |         </div> | ||||||
|  |  | ||||||
|  | @ -9,16 +9,20 @@ | ||||||
|     <img width="32" height="32" class="favicon" src="static/themes/oscar/img/icons/{{ favicon }}.png" alt="{{ favicon }}" /> |     <img width="32" height="32" class="favicon" src="static/themes/oscar/img/icons/{{ favicon }}.png" alt="{{ favicon }}" /> | ||||||
| {%- endmacro %} | {%- endmacro %} | ||||||
| 
 | 
 | ||||||
|  | {%- macro result_link(url, title, classes='') -%} | ||||||
|  | <a href="{{ url }}" {% if classes %}class="{{ classes }} "{% endif %}{% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ title }}</a> | ||||||
|  | {%- endmacro -%} | ||||||
|  | 
 | ||||||
| <!-- Draw result header --> | <!-- Draw result header --> | ||||||
| {% macro result_header(result, favicons) -%} | {% macro result_header(result, favicons) -%} | ||||||
|     <h4 class="result_header">{% if result.engine~".png" in favicons %}{{ draw_favicon(result.engine) }} {% endif %}<a href="{{ result.url }}" rel="noreferrer">{{ result.title|safe }}</a></h4> | <h4 class="result_header">{% if result.engine~".png" in favicons %}{{ draw_favicon(result.engine) }} {% endif %}{{ result_link(result.url, result.title|safe) }}</h4> | ||||||
| {%- endmacro %} | {%- endmacro %} | ||||||
| 
 | 
 | ||||||
| <!-- Draw result sub header --> | <!-- Draw result sub header --> | ||||||
| {% macro result_sub_header(result) -%} | {% macro result_sub_header(result) -%} | ||||||
|     {% if result.publishedDate %}<time class="text-muted" datetime="{{ result.pubdate }}" >{{ result.publishedDate }}</time>{% endif %} |     {% if result.publishedDate %}<time class="text-muted" datetime="{{ result.pubdate }}" >{{ result.publishedDate }}</time>{% endif %} | ||||||
|     {% if result.magnetlink %}<small> • <a href="{{ result.magnetlink }}" class="magnetlink">{{ icon('magnet') }} {{ _('magnet link') }}</a></small>{% endif %} |     {% if result.magnetlink %}<small> • {{ result_link(result.magnetlink, icon('magnet') + _('magnet link'), "magnetlink") }}</small>{% endif %} | ||||||
|     {% if result.torrentfile %}<small> • <a href="{{ result.torrentfile }}" class="torrentfile" rel="noreferrer">{{ icon('download-alt') }} {{ _('torrent file') }}</a></small>{% endif %} |     {% if result.torrentfile %}<small> • {{ result_link(result.torrentfile, icon('download-alt') + _('torrent file'), "torrentfile") }}</small>{% endif %} | ||||||
| {%- endmacro %} | {%- endmacro %} | ||||||
| 
 | 
 | ||||||
| <!-- Draw result footer --> | <!-- Draw result footer --> | ||||||
|  | @ -28,7 +32,7 @@ | ||||||
|     {% for engine in result.engines %} |     {% for engine in result.engines %} | ||||||
|         <span class="label label-default">{{ engine }}</span> |         <span class="label label-default">{{ engine }}</span> | ||||||
|     {% endfor %} |     {% endfor %} | ||||||
|     <small><a class="text-info" href="https://web.archive.org/web/{{ result.url }}" rel="noreferrer">{{ icon('link') }} {{ _('cached') }}</a></small> |     <small>{{ result_link("https://web.archive.org/web/" + result.url, icon('link') + _('cached'), "text-info") }}</small> | ||||||
| </div> | </div> | ||||||
|     <div class="text-muted"><small>{{ result.pretty_url }}</small></div> |     <div class="text-muted"><small>{{ result.pretty_url }}</small></div> | ||||||
| {%- endmacro %} | {%- endmacro %} | ||||||
|  | @ -39,7 +43,7 @@ | ||||||
|     {% for engine in result.engines %} |     {% for engine in result.engines %} | ||||||
|         <span class="label label-default">{{ engine }}</span> |         <span class="label label-default">{{ engine }}</span> | ||||||
|     {% endfor %} |     {% endfor %} | ||||||
|     <small><a class="text-info" href="https://web.archive.org/web/{{ result.url }}" rel="noreferrer">{{ icon('link') }} {{ _('cached') }}</a></small> |     <small>{{ result_link("https://web.archive.org/web/" + result.url, icon('link') + _('cached'), "text-info") }}</small> | ||||||
|     <div class="text-muted"><small>{{ result.pretty_url }}</small></div> |     <div class="text-muted"><small>{{ result.pretty_url }}</small></div> | ||||||
| {%- endmacro %} | {%- endmacro %} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -117,6 +117,15 @@ | ||||||
|                             <option value="pointhi" {% if cookies['oscar-style'] == 'pointhi' %}selected="selected"{% endif %}>Pointhi</option> |                             <option value="pointhi" {% if cookies['oscar-style'] == 'pointhi' %}selected="selected"{% endif %}>Pointhi</option> | ||||||
|                         </select> |                         </select> | ||||||
|                     {{ preferences_item_footer(_('Choose style for this theme'), _('Style'), rtl) }} |                     {{ preferences_item_footer(_('Choose style for this theme'), _('Style'), rtl) }} | ||||||
|  | 
 | ||||||
|  |                     {% set label = _('Results on new tabs') %} | ||||||
|  |                     {% set info = _('Open result links on new browser tabs') %} | ||||||
|  |                     {{ preferences_item_header(info, label, rtl) }} | ||||||
|  |                         <select class="form-control" name='results_on_new_tab'> | ||||||
|  |                             <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> | ||||||
|  |                         </select> | ||||||
|  |                     {{ preferences_item_footer(info, label, rtl) }} | ||||||
|                 </div> |                 </div> | ||||||
|                 </fieldset> |                 </fieldset> | ||||||
|             </div> |             </div> | ||||||
|  |  | ||||||
|  | @ -5,7 +5,7 @@ | ||||||
| 
 | 
 | ||||||
| {% if result.content %}<p class="result-content">{{ result.content|safe }}</p>{% endif %} | {% if result.content %}<p class="result-content">{{ result.content|safe }}</p>{% endif %} | ||||||
| 
 | 
 | ||||||
| {% if result.repository %}<p class="result-content">{{ icon('file') }} <a href="{{ result.repository|safe }}" rel="noreferrer">{{ result.repository }}</a></p>{% endif %} | {% if result.repository %}<p class="result-content">{{ icon('file') }} <a href="{{ result.repository }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}>{{ result.repository }}</a></p>{% endif %} | ||||||
| 
 | 
 | ||||||
| <div dir="ltr"> | <div dir="ltr"> | ||||||
| {{ result.codelines|code_highlighter(result.code_language)|safe }} | {{ result.codelines|code_highlighter(result.code_language)|safe }} | ||||||
|  |  | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
| {% from 'oscar/macros.html' import result_header, result_sub_header, result_footer, result_footer_rtl, icon %} | {% from 'oscar/macros.html' import result_header, result_sub_header, result_footer, result_footer_rtl, icon with context %} | ||||||
| 
 | 
 | ||||||
| {{ result_header(result, favicons) }} | {{ result_header(result, favicons) }} | ||||||
| {{ result_sub_header(result) }} | {{ result_sub_header(result) }} | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| {% from 'oscar/macros.html' import draw_favicon %} | {% from 'oscar/macros.html' import draw_favicon %} | ||||||
| 
 | 
 | ||||||
| <a href="{{ result.img_src }}" rel="noreferrer" data-toggle="modal" data-target="#modal-{{ index }}"> | <a href="{{ result.img_src }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %} data-toggle="modal" data-target="#modal-{{ index }}"> | ||||||
|     <img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" alt="{{ result.title|striptags }}" title="{{ result.title|striptags }}" class="img-thumbnail"> |     <img src="{% if result.thumbnail_src %}{{ image_proxify(result.thumbnail_src) }}{% else %}{{ image_proxify(result.img_src) }}{% endif %}" alt="{{ result.title|striptags }}" title="{{ result.title|striptags }}" class="img-thumbnail"> | ||||||
| </a> | </a> | ||||||
| 
 | 
 | ||||||
|  | @ -20,8 +20,8 @@ | ||||||
|                 <span class="label label-default pull-right">{{ result.engine }}</span> |                 <span class="label label-default pull-right">{{ result.engine }}</span> | ||||||
|                 <p class="text-muted pull-left">{{ result.pretty_url }}</p> |                 <p class="text-muted pull-left">{{ result.pretty_url }}</p> | ||||||
|                 <div class="clearfix"></div> |                 <div class="clearfix"></div> | ||||||
|                 <a href="{{ result.img_src }}" rel="noreferrer" class="btn btn-default">{{ _('Get image') }}</a> |                 <a href="{{ result.img_src }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %} class="btn btn-default">{{ _('Get image') }}</a> | ||||||
|                 <a href="{{ result.url }}" rel="noreferrer" class="btn btn-default">{{ _('View source') }}</a> |                 <a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %} class="btn btn-default">{{ _('View source') }}</a> | ||||||
|             </div> |             </div> | ||||||
|         </div> |         </div> | ||||||
|     </div> |     </div> | ||||||
|  |  | ||||||
|  | @ -15,7 +15,7 @@ | ||||||
| 
 | 
 | ||||||
| <div class="container-fluid"> | <div class="container-fluid"> | ||||||
|     <div class="row"> |     <div class="row"> | ||||||
|         <a href="{{ result.url }}" rel="noreferrer"><img class="thumbnail col-xs-6 col-sm-4 col-md-4 result-content" src="{{ image_proxify(result.thumbnail) }}" alt="{{ result.title|striptags }} {{ result.engine }}" /></a> |         <a href="{{ result.url }}" {% if results_on_new_tab %}target="_blank" rel="noopener noreferrer"{% else %}rel="noreferrer"{% endif %}><img class="thumbnail col-xs-6 col-sm-4 col-md-4 result-content" src="{{ image_proxify(result.thumbnail) }}" alt="{{ result.title|striptags }} {{ result.engine }}" /></a> | ||||||
|         {% if result.content %}<p class="col-xs-12 col-sm-8 col-md-8 result-content">{{ result.content|safe }}</p>{% endif %} |         {% if result.content %}<p class="col-xs-12 col-sm-8 col-md-8 result-content">{{ result.content|safe }}</p>{% endif %} | ||||||
|     </div> |     </div> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|  | @ -2,6 +2,8 @@ | ||||||
| {% block content %} | {% block content %} | ||||||
| <div class="center"> | <div class="center"> | ||||||
|     <h1>{{ _('Page not found') }}</h1> |     <h1>{{ _('Page not found') }}</h1> | ||||||
|     <p>{{ _('Go to <a href="/">search page</a>.') }}</p> |     {% autoescape false %} | ||||||
|  |     <p>{{ _('Go to %(search_page)s.', search_page='<a href="{}">{}</a>'.decode('utf-8').format(url_for('index'), _('search page'))) }}</p> | ||||||
|  |     {% endautoescape %} | ||||||
| </div> | </div> | ||||||
| {% endblock %} | {% endblock %} | ||||||
|  |  | ||||||
|  | @ -320,6 +320,8 @@ def render(template_name, override_theme=None, **kwargs): | ||||||
| 
 | 
 | ||||||
|     kwargs['instance_name'] = settings['general']['instance_name'] |     kwargs['instance_name'] = settings['general']['instance_name'] | ||||||
| 
 | 
 | ||||||
|  |     kwargs['results_on_new_tab'] = request.preferences.get_value('results_on_new_tab') | ||||||
|  | 
 | ||||||
|     kwargs['scripts'] = set() |     kwargs['scripts'] = set() | ||||||
|     for plugin in request.user_plugins: |     for plugin in request.user_plugins: | ||||||
|         for script in plugin.js_dependencies: |         for script in plugin.js_dependencies: | ||||||
|  | @ -338,7 +340,11 @@ def render(template_name, override_theme=None, **kwargs): | ||||||
| def pre_request(): | def pre_request(): | ||||||
|     # merge GET, POST vars |     # merge GET, POST vars | ||||||
|     preferences = Preferences(themes, categories.keys(), engines, plugins) |     preferences = Preferences(themes, categories.keys(), engines, plugins) | ||||||
|     preferences.parse_cookies(request.cookies) |     try: | ||||||
|  |         preferences.parse_cookies(request.cookies) | ||||||
|  |     except: | ||||||
|  |         # TODO throw error message to the user | ||||||
|  |         logger.warning('Invalid config') | ||||||
|     request.preferences = preferences |     request.preferences = preferences | ||||||
| 
 | 
 | ||||||
|     request.form = dict(request.form.items()) |     request.form = dict(request.form.items()) | ||||||
|  | @ -553,6 +559,7 @@ def preferences(): | ||||||
|     lang = request.preferences.get_value('language') |     lang = request.preferences.get_value('language') | ||||||
|     disabled_engines = request.preferences.engines.get_disabled() |     disabled_engines = request.preferences.engines.get_disabled() | ||||||
|     allowed_plugins = request.preferences.plugins.get_enabled() |     allowed_plugins = request.preferences.plugins.get_enabled() | ||||||
|  |     results_on_new_tab = request.preferences.get_value('results_on_new_tab') | ||||||
| 
 | 
 | ||||||
|     # stats for preferences page |     # stats for preferences page | ||||||
|     stats = {} |     stats = {} | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Pydo
						Pydo