forked from Ponysearch/Ponysearch
[enh][oscar_template] split js-files and compile them together
This commit is contained in:
parent
08f4b7f506
commit
e687f5c290
14 changed files with 248 additions and 81 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -9,6 +9,7 @@ setup.cfg
|
||||||
|
|
||||||
*.pyc
|
*.pyc
|
||||||
*/*.pyc
|
*/*.pyc
|
||||||
|
*~
|
||||||
|
|
||||||
bin/
|
bin/
|
||||||
build/
|
build/
|
||||||
|
|
|
@ -5,6 +5,7 @@ before_install:
|
||||||
- "export DISPLAY=:99.0"
|
- "export DISPLAY=:99.0"
|
||||||
- "sh -e /etc/init.d/xvfb start"
|
- "sh -e /etc/init.d/xvfb start"
|
||||||
- npm install -g less
|
- npm install -g less
|
||||||
|
- cd searx/static/oscar;npm install
|
||||||
install:
|
install:
|
||||||
- "make"
|
- "make"
|
||||||
- pip install coveralls
|
- pip install coveralls
|
||||||
|
@ -12,6 +13,7 @@ script:
|
||||||
- "make tests"
|
- "make tests"
|
||||||
- "make robot"
|
- "make robot"
|
||||||
- "make styles"
|
- "make styles"
|
||||||
|
- "make grunt"
|
||||||
- make coverage
|
- make coverage
|
||||||
after_success:
|
after_success:
|
||||||
coveralls
|
coveralls
|
||||||
|
|
4
Makefile
4
Makefile
|
@ -20,6 +20,7 @@ $(python):
|
||||||
|
|
||||||
tests: .installed.cfg
|
tests: .installed.cfg
|
||||||
@bin/test
|
@bin/test
|
||||||
|
@grunt test --gruntfile searx/static/oscar/gruntfile.js
|
||||||
|
|
||||||
robot: .installed.cfg
|
robot: .installed.cfg
|
||||||
@bin/robot
|
@bin/robot
|
||||||
|
@ -48,6 +49,9 @@ styles:
|
||||||
@lessc -x searx/static/oscar/less/bootstrap/bootstrap.less > searx/static/oscar/css/bootstrap.min.css
|
@lessc -x searx/static/oscar/less/bootstrap/bootstrap.less > searx/static/oscar/css/bootstrap.min.css
|
||||||
@lessc -x searx/static/oscar/less/oscar/oscar.less > searx/static/oscar/css/oscar.min.css
|
@lessc -x searx/static/oscar/less/oscar/oscar.less > searx/static/oscar/css/oscar.min.css
|
||||||
|
|
||||||
|
grunt:
|
||||||
|
@grunt --gruntfile searx/static/oscar/gruntfile.js
|
||||||
|
|
||||||
locales:
|
locales:
|
||||||
@pybabel compile -d searx/translations
|
@pybabel compile -d searx/translations
|
||||||
|
|
||||||
|
|
1
searx/static/oscar/.gitignore
vendored
Normal file
1
searx/static/oscar/.gitignore
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
node_modules/
|
17
searx/static/oscar/README.rst
Normal file
17
searx/static/oscar/README.rst
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
install dependencies
|
||||||
|
~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
run this command in the directory ``searx/static/oscar``
|
||||||
|
|
||||||
|
``npm install``
|
||||||
|
|
||||||
|
compile sources
|
||||||
|
~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
run this command in the directory ``searx/static/oscar``
|
||||||
|
|
||||||
|
``grunt``
|
||||||
|
|
||||||
|
or in the root directory:
|
||||||
|
|
||||||
|
``make grunt``
|
51
searx/static/oscar/gruntfile.js
Normal file
51
searx/static/oscar/gruntfile.js
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
module.exports = function(grunt) {
|
||||||
|
|
||||||
|
grunt.initConfig({
|
||||||
|
pkg: grunt.file.readJSON('package.json'),
|
||||||
|
concat: {
|
||||||
|
options: {
|
||||||
|
separator: ';'
|
||||||
|
},
|
||||||
|
dist: {
|
||||||
|
src: ['js/searx_src/*.js'],
|
||||||
|
dest: 'js/searx.js'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
uglify: {
|
||||||
|
options: {
|
||||||
|
banner: '/*! oscar/searx.min.js | <%= grunt.template.today("dd-mm-yyyy") %> | https://github.com/asciimoo/searx */\n'
|
||||||
|
},
|
||||||
|
dist: {
|
||||||
|
files: {
|
||||||
|
'js/searx.min.js': ['<%= concat.dist.dest %>']
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
jshint: {
|
||||||
|
files: ['gruntfile.js', 'js/searx_src/*.js'],
|
||||||
|
options: {
|
||||||
|
// options here to override JSHint defaults
|
||||||
|
globals: {
|
||||||
|
jQuery: true,
|
||||||
|
console: true,
|
||||||
|
module: true,
|
||||||
|
document: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
watch: {
|
||||||
|
files: ['<%= jshint.files %>'],
|
||||||
|
tasks: ['jshint']
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-uglify');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-jshint');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-watch');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-concat');
|
||||||
|
|
||||||
|
grunt.registerTask('test', ['jshint']);
|
||||||
|
|
||||||
|
grunt.registerTask('default', ['jshint', 'concat', 'uglify']);
|
||||||
|
|
||||||
|
};
|
2
searx/static/oscar/js/searx.min.js
vendored
Normal file
2
searx/static/oscar/js/searx.min.js
vendored
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
/*! oscar/searx.min.js | 30-11-2014 | https://github.com/asciimoo/searx */
|
||||||
|
requirejs.config({baseUrl:"/static/oscar/js",paths:{app:"../app"}}),searx.autocompleter&&(searx.searchResults=new Bloodhound({datumTokenizer:Bloodhound.tokenizers.obj.whitespace("value"),queryTokenizer:Bloodhound.tokenizers.whitespace,remote:"/autocompleter?q=%QUERY"}),searx.searchResults.initialize()),$(document).ready(function(){searx.autocompleter&&$("#q").typeahead(null,{name:"search-results",displayKey:function(a){return a},source:searx.searchResults.ttAdapter()})}),$(document).ready(function(){$("#q.autofocus").focus(),$(".select-all-on-click").click(function(){$(this).select()}),$(".btn-collapse").click(function(){var a=$(this).data("btn-text-collapsed"),b=$(this).data("btn-text-not-collapsed");""!==a&&""!==b&&(new_html=$(this).hasClass("collapsed")?$(this).html().replace(a,b):$(this).html().replace(b,a),$(this).html(new_html))}),$(".btn-toggle .btn").click(function(){var a="btn-"+$(this).data("btn-class"),b=$(this).data("btn-label-default"),c=$(this).data("btn-label-toggled");""!==c&&(new_html=$(this).hasClass("btn-default")?$(this).html().replace(b,c):$(this).html().replace(c,b),$(this).html(new_html)),$(this).toggleClass(a),$(this).toggleClass("btn-default")})}),$(document).ready(function(){$(".searx_overpass_request").on("click",function(a){var b="https://overpass-api.de/api/interpreter?data=",c=b+"[out:json][timeout:25];(",d=");out meta;",e=$(this).data("osm-id"),f=$(this).data("osm-type"),g=$(this).data("result-table"),h="#"+$(this).data("result-table-loadicon"),i=["addr:city","addr:country","addr:housenumber","addr:postcode","addr:street"];if(e&&f&&g){g="#"+g;var j=null;switch(f){case"node":j=c+"node("+e+");"+d;break;case"way":j=c+"way("+e+");"+d;break;case"relation":j=c+"relation("+e+");"+d}if(j){$.ajax(j).done(function(a){if(a&&a.elements&&a.elements[0]){var b=a.elements[0],c=$(g).html();for(var d in b.tags)if(null===b.tags.name||-1==i.indexOf(d)){switch(c+="<tr><td>"+d+"</td><td>",d){case"phone":case"fax":c+='<a href="tel:'+b.tags[d].replace(/ /g,"")+'">'+b.tags[d]+"</a>";break;case"email":c+='<a href="mailto:'+b.tags[d]+'">'+b.tags[d]+"</a>";break;case"website":case"url":c+='<a href="'+b.tags[d]+'">'+b.tags[d]+"</a>";break;case"wikidata":c+='<a href="https://www.wikidata.org/wiki/'+b.tags[d]+'">'+b.tags[d]+"</a>";break;case"wikipedia":if(-1!=b.tags[d].indexOf(":")){c+='<a href="https://'+b.tags[d].substring(0,b.tags[d].indexOf(":"))+".wikipedia.org/wiki/"+b.tags[d].substring(b.tags[d].indexOf(":")+1)+'">'+b.tags[d]+"</a>";break}default:c+=b.tags[d]}c+="</td></tr>"}$(g).html(c),$(g).removeClass("hidden"),$(h).addClass("hidden")}}).fail(function(){$(h).html($(h).html()+'<p class="text-muted">could not load data!</p>')})}}$(this).off(a)}),$(".searx_init_map").on("click",function(a){var b=$(this).data("leaflet-target"),c=$(this).data("map-lon"),d=$(this).data("map-lat"),e=$(this).data("map-zoom"),f=$(this).data("map-boundingbox"),g=$(this).data("map-geojson");require(["leaflet-0.7.3.min"],function(){f&&(southWest=L.latLng(f[0],f[2]),northEast=L.latLng(f[1],f[3]),map_bounds=L.latLngBounds(southWest,northEast)),L.Icon.Default.imagePath="/static/oscar/img/map";{var a=L.map(b),h="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png",i='Map data © <a href="https://openstreetmap.org">OpenStreetMap</a> contributors',j=new L.TileLayer(h,{minZoom:1,maxZoom:19,attribution:i}),k="http://otile{s}.mqcdn.com/tiles/1.0.0/map/{z}/{x}/{y}.jpg",l='Map data © <a href="https://openstreetmap.org">OpenStreetMap</a> contributors | Tiles Courtesy of <a href="http://www.mapquest.com/" target="_blank">MapQuest</a> <img src="http://developer.mapquest.com/content/osm/mq_logo.png">',m=new L.TileLayer(k,{minZoom:1,maxZoom:18,subdomains:"1234",attribution:l}),n="http://otile{s}.mqcdn.com/tiles/1.0.0/sat/{z}/{x}/{y}.jpg",o='Map data © <a href="https://openstreetmap.org">OpenStreetMap</a> contributors | Tiles Courtesy of <a href="http://www.mapquest.com/" target="_blank">MapQuest</a> <img src="https://developer.mapquest.com/content/osm/mq_logo.png"> | Portions Courtesy NASA/JPL-Caltech and U.S. Depart. of Agriculture, Farm Service Agency';new L.TileLayer(n,{minZoom:1,maxZoom:11,subdomains:"1234",attribution:o})}map_bounds?setTimeout(function(){a.fitBounds(map_bounds,{maxZoom:17})},0):c&&d&&(e?a.setView(new L.LatLng(d,c),e):a.setView(new L.LatLng(d,c),8)),a.addLayer(m);var p={"OSM Mapnik":j,MapQuest:m};L.control.layers(p).addTo(a),g&&L.geoJson(g).addTo(a)}),$(this).off(a)})});
|
23
searx/static/oscar/js/searx_src/00_requirejs_config.js
Normal file
23
searx/static/oscar/js/searx_src/00_requirejs_config.js
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
/**
|
||||||
|
* searx is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* searx is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with searx. If not, see < http://www.gnu.org/licenses/ >.
|
||||||
|
*
|
||||||
|
* (C) 2014 by Thomas Pointhuber, <thomas.pointhuber@gmx.at>
|
||||||
|
*/
|
||||||
|
|
||||||
|
requirejs.config({
|
||||||
|
baseUrl: '/static/oscar/js',
|
||||||
|
paths: {
|
||||||
|
app: '../app'
|
||||||
|
}
|
||||||
|
});
|
37
searx/static/oscar/js/searx_src/autocompleter.js
Normal file
37
searx/static/oscar/js/searx_src/autocompleter.js
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
/**
|
||||||
|
* searx is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* searx is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with searx. If not, see < http://www.gnu.org/licenses/ >.
|
||||||
|
*
|
||||||
|
* (C) 2014 by Thomas Pointhuber, <thomas.pointhuber@gmx.at>
|
||||||
|
*/
|
||||||
|
|
||||||
|
if(searx.autocompleter) {
|
||||||
|
searx.searchResults = new Bloodhound({
|
||||||
|
datumTokenizer: Bloodhound.tokenizers.obj.whitespace('value'),
|
||||||
|
queryTokenizer: Bloodhound.tokenizers.whitespace,
|
||||||
|
remote: '/autocompleter?q=%QUERY'
|
||||||
|
});
|
||||||
|
searx.searchResults.initialize();
|
||||||
|
}
|
||||||
|
|
||||||
|
$(document).ready(function(){
|
||||||
|
if(searx.autocompleter) {
|
||||||
|
$('#q').typeahead(null, {
|
||||||
|
name: 'search-results',
|
||||||
|
displayKey: function(result) {
|
||||||
|
return result;
|
||||||
|
},
|
||||||
|
source: searx.searchResults.ttAdapter()
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
66
searx/static/oscar/js/searx_src/element_modifiers.js
Normal file
66
searx/static/oscar/js/searx_src/element_modifiers.js
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
/**
|
||||||
|
* searx is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* searx is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with searx. If not, see < http://www.gnu.org/licenses/ >.
|
||||||
|
*
|
||||||
|
* (C) 2014 by Thomas Pointhuber, <thomas.pointhuber@gmx.at>
|
||||||
|
*/
|
||||||
|
|
||||||
|
$(document).ready(function(){
|
||||||
|
/**
|
||||||
|
* focus element if class="autofocus" and id="q"
|
||||||
|
*/
|
||||||
|
$('#q.autofocus').focus();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* select full content on click if class="select-all-on-click"
|
||||||
|
*/
|
||||||
|
$(".select-all-on-click").click(function () {
|
||||||
|
$(this).select();
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* change text during btn-collapse click if possible
|
||||||
|
*/
|
||||||
|
$('.btn-collapse').click(function() {
|
||||||
|
var btnTextCollapsed = $(this).data('btn-text-collapsed');
|
||||||
|
var btnTextNotCollapsed = $(this).data('btn-text-not-collapsed');
|
||||||
|
|
||||||
|
if(btnTextCollapsed !== '' && btnTextNotCollapsed !== '') {
|
||||||
|
if($(this).hasClass('collapsed')) {
|
||||||
|
new_html = $(this).html().replace(btnTextCollapsed, btnTextNotCollapsed);
|
||||||
|
} else {
|
||||||
|
new_html = $(this).html().replace(btnTextNotCollapsed, btnTextCollapsed);
|
||||||
|
}
|
||||||
|
$(this).html(new_html);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* change text during btn-toggle click if possible
|
||||||
|
*/
|
||||||
|
$('.btn-toggle .btn').click(function() {
|
||||||
|
var btnClass = 'btn-' + $(this).data('btn-class');
|
||||||
|
var btnLabelDefault = $(this).data('btn-label-default');
|
||||||
|
var btnLabelToggled = $(this).data('btn-label-toggled');
|
||||||
|
if(btnLabelToggled !== '') {
|
||||||
|
if($(this).hasClass('btn-default')) {
|
||||||
|
new_html = $(this).html().replace(btnLabelDefault, btnLabelToggled);
|
||||||
|
} else {
|
||||||
|
new_html = $(this).html().replace(btnLabelToggled, btnLabelDefault);
|
||||||
|
}
|
||||||
|
$(this).html(new_html);
|
||||||
|
}
|
||||||
|
$(this).toggleClass(btnClass);
|
||||||
|
$(this).toggleClass('btn-default');
|
||||||
|
});
|
||||||
|
});
|
|
@ -1,74 +1,21 @@
|
||||||
/**
|
/**
|
||||||
_ _ _
|
* searx is free software: you can redistribute it and/or modify
|
||||||
| |__ ___ ___ | |_ ___| |_ _ __ __ ___ __
|
* it under the terms of the GNU Affero General Public License as published by
|
||||||
| '_ \ / _ \ / _ \| __/ __| __| '__/ _` \ \/ /
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
| |_) | (_) | (_) | |_\__ | |_| | | (_| |> <
|
* (at your option) any later version.
|
||||||
|_.__/ \___/ \___/ \__|___/\__|_| \__,_/_/\_\.js
|
*
|
||||||
|
* searx is distributed in the hope that it will be useful,
|
||||||
*/
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
requirejs.config({
|
* GNU Affero General Public License for more details.
|
||||||
baseUrl: '/static/oscar/js',
|
*
|
||||||
paths: {
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
app: '../app'
|
* along with searx. If not, see < http://www.gnu.org/licenses/ >.
|
||||||
}
|
*
|
||||||
});
|
* (C) 2014 by Thomas Pointhuber, <thomas.pointhuber@gmx.at>
|
||||||
|
*/
|
||||||
if(searx.autocompleter) {
|
|
||||||
searx.searchResults = new Bloodhound({
|
|
||||||
datumTokenizer: Bloodhound.tokenizers.obj.whitespace('value'),
|
|
||||||
queryTokenizer: Bloodhound.tokenizers.whitespace,
|
|
||||||
remote: '/autocompleter?q=%QUERY'
|
|
||||||
});
|
|
||||||
searx.searchResults.initialize();
|
|
||||||
}
|
|
||||||
|
|
||||||
$(document).ready(function(){
|
$(document).ready(function(){
|
||||||
$('.btn-toggle .btn').click(function() {
|
|
||||||
var btnClass = 'btn-' + $(this).data('btn-class');
|
|
||||||
var btnLabelDefault = $(this).data('btn-label-default');
|
|
||||||
var btnLabelToggled = $(this).data('btn-label-toggled');
|
|
||||||
if(btnLabelToggled != '') {
|
|
||||||
if($(this).hasClass('btn-default')) {
|
|
||||||
|
|
||||||
var html = $(this).html().replace(btnLabelDefault, btnLabelToggled);
|
|
||||||
} else {
|
|
||||||
var html = $(this).html().replace(btnLabelToggled, btnLabelDefault);
|
|
||||||
}
|
|
||||||
$(this).html(html);
|
|
||||||
}
|
|
||||||
$(this).toggleClass(btnClass);
|
|
||||||
$(this).toggleClass('btn-default');
|
|
||||||
});
|
|
||||||
|
|
||||||
$('.btn-collapse').click(function() {
|
|
||||||
var btnTextCollapsed = $(this).data('btn-text-collapsed');
|
|
||||||
var btnTextNotCollapsed = $(this).data('btn-text-not-collapsed');
|
|
||||||
|
|
||||||
if(btnTextCollapsed != '' && btnTextNotCollapsed != '') {
|
|
||||||
if($(this).hasClass('collapsed')) {
|
|
||||||
var html = $(this).html().replace(btnTextCollapsed, btnTextNotCollapsed);
|
|
||||||
} else {
|
|
||||||
var html = $(this).html().replace(btnTextNotCollapsed, btnTextCollapsed);
|
|
||||||
}
|
|
||||||
$(this).html(html);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
$(".select-all-on-click").click(function () {
|
|
||||||
$(this).select();
|
|
||||||
});
|
|
||||||
|
|
||||||
if(searx.autocompleter) {
|
|
||||||
$('#q').typeahead(null, {
|
|
||||||
name: 'search-results',
|
|
||||||
displayKey: function(result) {
|
|
||||||
return result;
|
|
||||||
},
|
|
||||||
source: searx.searchResults.ttAdapter()
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
$(".searx_overpass_request").on( "click", function( event ) {
|
$(".searx_overpass_request").on( "click", function( event ) {
|
||||||
var overpass_url = "https://overpass-api.de/api/interpreter?data=";
|
var overpass_url = "https://overpass-api.de/api/interpreter?data=";
|
||||||
var query_start = overpass_url + "[out:json][timeout:25];(";
|
var query_start = overpass_url + "[out:json][timeout:25];(";
|
||||||
|
@ -80,7 +27,7 @@ $(document).ready(function(){
|
||||||
var result_table_loadicon = "#" + $(this).data('result-table-loadicon');
|
var result_table_loadicon = "#" + $(this).data('result-table-loadicon');
|
||||||
|
|
||||||
// tags which can be ignored
|
// tags which can be ignored
|
||||||
var osm_ignore_tags = [ "addr:city", "addr:country", "addr:housenumber", "addr:postcode", "addr:street" ]
|
var osm_ignore_tags = [ "addr:city", "addr:country", "addr:housenumber", "addr:postcode", "addr:street" ];
|
||||||
|
|
||||||
if(osm_id && osm_type && result_table) {
|
if(osm_id && osm_type && result_table) {
|
||||||
result_table = "#" + result_table;
|
result_table = "#" + result_table;
|
||||||
|
@ -102,11 +49,11 @@ $(document).ready(function(){
|
||||||
//alert(query);
|
//alert(query);
|
||||||
var ajaxRequest = $.ajax( query )
|
var ajaxRequest = $.ajax( query )
|
||||||
.done(function( html) {
|
.done(function( html) {
|
||||||
if(html && html['elements'] && html['elements'][0]) {
|
if(html && html.elements && html.elements[0]) {
|
||||||
var element = html['elements'][0];
|
var element = html.elements[0];
|
||||||
var newHtml = $(result_table).html();
|
var newHtml = $(result_table).html();
|
||||||
for (var row in element.tags) {
|
for (var row in element.tags) {
|
||||||
if(element.tags["name"] == null || osm_ignore_tags.indexOf(row) == -1) {
|
if(element.tags.name === null || osm_ignore_tags.indexOf(row) == -1) {
|
||||||
newHtml += "<tr><td>" + row + "</td><td>";
|
newHtml += "<tr><td>" + row + "</td><td>";
|
||||||
switch(row) {
|
switch(row) {
|
||||||
case "phone":
|
case "phone":
|
||||||
|
@ -125,11 +72,12 @@ $(document).ready(function(){
|
||||||
break;
|
break;
|
||||||
case "wikipedia":
|
case "wikipedia":
|
||||||
if(element.tags[row].indexOf(":") != -1) {
|
if(element.tags[row].indexOf(":") != -1) {
|
||||||
newHtml += "<a href=\"https://" + element.tags[row].substring(0,element.tags[row].indexOf(":")) + ".wikipedia.org/wiki/"
|
newHtml += "<a href=\"https://" + element.tags[row].substring(0,element.tags[row].indexOf(":")) + ".wikipedia.org/wiki/" + element.tags[row].substring(element.tags[row].indexOf(":")+1) + "\">" + element.tags[row] + "</a>";
|
||||||
+ element.tags[row].substring(element.tags[row].indexOf(":")+1) + "\">" + element.tags[row] + "</a>";
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
/* jshint ignore:start */
|
||||||
default:
|
default:
|
||||||
|
/* jshint ignore:end */
|
||||||
newHtml += element.tags[row];
|
newHtml += element.tags[row];
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -143,7 +91,7 @@ $(document).ready(function(){
|
||||||
})
|
})
|
||||||
.fail(function() {
|
.fail(function() {
|
||||||
$(result_table_loadicon).html($(result_table_loadicon).html() + "<p class=\"text-muted\">could not load data!</p>");
|
$(result_table_loadicon).html($(result_table_loadicon).html() + "<p class=\"text-muted\">could not load data!</p>");
|
||||||
})
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -161,8 +109,8 @@ $(document).ready(function(){
|
||||||
|
|
||||||
require(['leaflet-0.7.3.min'], function(leaflet) {
|
require(['leaflet-0.7.3.min'], function(leaflet) {
|
||||||
if(map_boundingbox) {
|
if(map_boundingbox) {
|
||||||
var southWest = L.latLng(map_boundingbox[0], map_boundingbox[2]),
|
southWest = L.latLng(map_boundingbox[0], map_boundingbox[2]);
|
||||||
northEast = L.latLng(map_boundingbox[1], map_boundingbox[3]),
|
northEast = L.latLng(map_boundingbox[1], map_boundingbox[3]);
|
||||||
map_bounds = L.latLngBounds(southWest, northEast);
|
map_bounds = L.latLngBounds(southWest, northEast);
|
||||||
}
|
}
|
||||||
|
|
15
searx/static/oscar/package.json
Normal file
15
searx/static/oscar/package.json
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
{
|
||||||
|
"devDependencies": {
|
||||||
|
"grunt": "~0.4.5",
|
||||||
|
"grunt-contrib-uglify": "~0.6.0",
|
||||||
|
"grunt-contrib-watch" : "~0.6.1",
|
||||||
|
"grunt-contrib-concat" : "~0.5.0",
|
||||||
|
"grunt-contrib-jshint" : "~0.10.0"
|
||||||
|
},
|
||||||
|
|
||||||
|
"scripts": {
|
||||||
|
"build": "npm install && grunt",
|
||||||
|
"start": "grunt watch",
|
||||||
|
"test": "grunt"
|
||||||
|
}
|
||||||
|
}
|
|
@ -73,6 +73,6 @@
|
||||||
<script src="{{ url_for('static', filename='js/bootstrap.min.js') }}"></script>
|
<script src="{{ url_for('static', filename='js/bootstrap.min.js') }}"></script>
|
||||||
{% if autocomplete %}<script src="{{ url_for('static', filename='js/typeahead.bundle.min.js') }}"></script>{% endif %}
|
{% if autocomplete %}<script src="{{ url_for('static', filename='js/typeahead.bundle.min.js') }}"></script>{% endif %}
|
||||||
<script src="{{ url_for('static', filename='js/require-2.1.15.min.js') }}"></script>
|
<script src="{{ url_for('static', filename='js/require-2.1.15.min.js') }}"></script>
|
||||||
<script src="{{ url_for('static', filename='js/scripts.js') }}"></script>
|
<script src="{{ url_for('static', filename='js/searx.min.js') }}"></script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
<form method="{{ method or 'POST' }}" action="{{ url_for('index') }}" id="search_form" role="search">
|
<form method="{{ method or 'POST' }}" action="{{ url_for('index') }}" id="search_form" role="search">
|
||||||
<div class="input-group col-md-8 col-md-offset-2">
|
<div class="input-group col-md-8 col-md-offset-2">
|
||||||
<input type="search" name="q" class="form-control input-lg" id="q" placeholder="{{ _('Search for...') }}" autocomplete="off" value="{{ q }}">
|
<input type="search" name="q" class="form-control input-lg autofocus" id="q" placeholder="{{ _('Search for...') }}" autocomplete="off" value="{{ q }}">
|
||||||
<span class="input-group-btn">
|
<span class="input-group-btn">
|
||||||
<button type="submit" class="btn btn-default input-lg">{{ icon('search') }}<span class="sr-only">{{ _('Start search') }}</span></button>
|
<button type="submit" class="btn btn-default input-lg">{{ icon('search') }}<span class="sr-only">{{ _('Start search') }}</span></button>
|
||||||
</span>
|
</span>
|
||||||
|
|
Loading…
Reference in a new issue