113 lines
3.5 KiB
JavaScript
113 lines
3.5 KiB
JavaScript
'use strict';
|
|
|
|
|
|
(function(hscd) {
|
|
var ctx = {};
|
|
|
|
function onAdjust(name, value) {
|
|
ctx.searchParams[name] = value;
|
|
|
|
var params = {
|
|
searchParams: ctx.searchParams,
|
|
searchRange: ctx.searchRange,
|
|
minScore: ctx.minScore,
|
|
hintSteps: ctx.hintSteps,
|
|
maxResults: ctx.maxResults
|
|
};
|
|
|
|
$.getJSON('/node/search', params, function(results) {
|
|
var hintData = {};
|
|
for (var keyword in results.columns) {
|
|
hintData[keyword] = results.columns[keyword].hints;
|
|
}
|
|
|
|
ctx.grapher.setColumnHints(hintData);
|
|
outputResults(results.items, results.count);
|
|
});
|
|
}
|
|
|
|
function onSearch() {
|
|
var params = {
|
|
keywords: $('#keywords').val(),
|
|
searchRange: { min: -1.0, max: 1.0 },
|
|
minScore: parseFloat($('#minScore').val()),
|
|
hintSteps: parseInt($('#hintSteps').val()),
|
|
maxResults: parseInt($('#maxResults').val())
|
|
};
|
|
|
|
$.getJSON('/node/search', params, function(results) {
|
|
ctx.searchParams = results.params;
|
|
ctx.searchRange = params.searchRange;
|
|
ctx.minScore = params.minScore;
|
|
ctx.hintSteps = params.hintSteps;
|
|
ctx.maxResults = params.maxResults;
|
|
|
|
ctx.grapher = new Grapher('grapher', ctx.searchRange, true, true);
|
|
ctx.grapher.setColumns(results.columns);
|
|
ctx.grapher.setValueChangedListener(onAdjust);
|
|
|
|
outputResults(results.items, results.count);
|
|
|
|
if (params.keywords) {
|
|
$('#query').text(params.keywords.join(', '));
|
|
}
|
|
|
|
$('#useLocalScale').click(function() {
|
|
var useLocalScale = $('#useLocalScale').is(':checked');
|
|
ctx.grapher.setUseLocalScale(useLocalScale);
|
|
});
|
|
$('#useRelativeScale').click(function() {
|
|
var useRelativeScale = $('#useRelativeScale').is(':checked');
|
|
ctx.grapher.setUseRelativeScale(useRelativeScale);
|
|
});
|
|
$('#input').fadeOut(function() {
|
|
$('#output').fadeIn();
|
|
});
|
|
});
|
|
}
|
|
|
|
function outputResults(results, count) {
|
|
$('#results').empty();
|
|
|
|
var searchResultCnt = String(results.length);
|
|
if (results.length < count) {
|
|
searchResultCnt += ' of ' + count;
|
|
}
|
|
$('#count').text(searchResultCnt);
|
|
|
|
var template = Handlebars.compile($('#template').html());
|
|
$('#results').append(template({'results': results}));
|
|
}
|
|
|
|
$(document).on({
|
|
ajaxStart: function() {
|
|
$('#spinner').show();
|
|
},
|
|
|
|
ajaxStop: function() {
|
|
$('#spinner').hide();
|
|
},
|
|
|
|
ready: function() {
|
|
$('#keywords').selectpicker();
|
|
|
|
$.getJSON('/node/keywords', function(keywords) {
|
|
for (var i = 0, count = keywords.length; i < count; ++i) {
|
|
$('#keywords').append($('<option></option>', {
|
|
value: keywords[i],
|
|
text: keywords[i]
|
|
}));
|
|
}
|
|
|
|
$('#keywords').selectpicker('refresh');
|
|
$('#keywords').change(function() {
|
|
$('#search').prop('disabled', $(this).val() === null);
|
|
});
|
|
|
|
$('#search').click(onSearch);
|
|
});
|
|
}
|
|
});
|
|
|
|
}(window.hscd = window.hscd || {}));
|